From 03a81087d64811cbaf802336820ac2af77034ba7 Mon Sep 17 00:00:00 2001 From: Marcel Kloubert Date: Fri, 3 Jan 2025 07:58:43 +0100 Subject: [PATCH] fix: doctor command --- CHANGELOG.md | 2 +- commands/doctor.go | 24 ++++++++++++++---------- 2 files changed, 15 insertions(+), 11 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index ff2e83f..e030cfe 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,6 +1,6 @@ # Change Log (go-package-manager) -## 0.29.6 +## 0.29.7 - feat: self-update by executing `gpm update --self` - chore: improve (self-)update scripts diff --git a/commands/doctor.go b/commands/doctor.go index c7e9905..2dfe037 100644 --- a/commands/doctor.go +++ b/commands/doctor.go @@ -114,14 +114,18 @@ func Init_Doctor_Command(parentCmd *cobra.Command, app *types.AppContext) { fmt.Println() - // cleanups and extract direct items - directItems := make([]GoModFileRequireItem, 0) + // cleanups and extract items as references + allItems := make([]*GoModFileRequireItem, 0) + directItems := make([]*GoModFileRequireItem, 0) for _, item := range goMod.Require { - item.Path = strings.TrimSpace(strings.ToLower(item.Path)) - item.Version = strings.TrimSpace(item.Version) + refItem := &item - if item.Indirect == nil || !*item.Indirect { - directItems = append(directItems, item) + refItem.Path = strings.TrimSpace(strings.ToLower(refItem.Path)) + refItem.Version = strings.TrimSpace(refItem.Version) + + allItems = append(allItems, refItem) + if refItem.Indirect == nil || !*refItem.Indirect { + directItems = append(directItems, refItem) } } @@ -199,10 +203,10 @@ func Init_Doctor_Command(parentCmd *cobra.Command, app *types.AppContext) { fmt.Println() fmt.Println("Checking for unsed dependencies ...") - for i, item := range goMod.Require { + for i, item := range allItems { s := spinner.New(spinner.CharSets[24], 100*time.Millisecond) s.Prefix = "\t[" - s.Suffix = fmt.Sprintf("] Checking '%s' (%v/%v) ...", item.Path, i+1, len(goMod.Require)) + s.Suffix = fmt.Sprintf("] Checking '%s' (%v/%v) ...", item.Path, i+1, len(allItems)) s.Start() p := exec.Command("go", "mod", "why", "-m", item.Path) @@ -228,10 +232,10 @@ func Init_Doctor_Command(parentCmd *cobra.Command, app *types.AppContext) { fmt.Println() fmt.Println("Checking all dependencies for security issues ...") - for i, item := range goMod.Require { + for i, item := range allItems { s := spinner.New(spinner.CharSets[24], 100*time.Millisecond) s.Prefix = "\t[" - s.Suffix = fmt.Sprintf("] Checking '%s' (%v/%v) ...", item.Path, i+1, len(goMod.Require)) + s.Suffix = fmt.Sprintf("] Checking '%s' (%v/%v) ...", item.Path, i+1, len(allItems)) s.Start() url := "https://api.osv.dev/v1/query"