From 1a602f3ed11e7be99f965e78dbe17088989b7612 Mon Sep 17 00:00:00 2001 From: Jeff Carr Date: Sat, 25 Oct 2025 23:06:27 -0500 Subject: try out these names --- argv.custom.go | 126 ------------------------------------------ argv.go | 172 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++ argv.struct.go | 172 --------------------------------------------------------- complete.go | 126 ++++++++++++++++++++++++++++++++++++++++++ 4 files changed, 298 insertions(+), 298 deletions(-) delete mode 100644 argv.custom.go create mode 100644 argv.go delete mode 100644 argv.struct.go create mode 100644 complete.go diff --git a/argv.custom.go b/argv.custom.go deleted file mode 100644 index 987a812..0000000 --- a/argv.custom.go +++ /dev/null @@ -1,126 +0,0 @@ -// Copyright 2017-2025 WIT.COM Inc. All rights reserved. -// Use of this source code is governed by the GPL 3.0 - -package main - -import ( - "fmt" - "strings" - - "go.wit.com/dev/alexflint/arg" - "go.wit.com/gui" - "go.wit.com/lib/debugger" - "go.wit.com/lib/env" - "go.wit.com/lib/fhelp" - "go.wit.com/lib/protobuf/argvpb" - "go.wit.com/log" -) - -// sent via -ldflags // is there a better way? -var VERSION string -var BUILDTIME string - -// used for shell auto completion -var APPNAME string = "forge" - -func (args) InitArgv() (string, string, string) { - return APPNAME, BUILDTIME, VERSION -} - -func (args) InitGui() error { - // panic("got here") - arg.Register(&gui.ArgvGui) - // me.gui = gui.PreInit() - me.myGui = fhelp.Gui() - return nil -} - -func (args) Exit() { - gui.UnloadToolkits() - if env.Verbose() { - log.Info("argv.Exit() called", APPNAME+".Exit() because env.Verbose() == true") - } - // remove this from the template for your app (or make one for youself if you need it) - forgeExit() // custom forge shutdown function -} - -func (args) MustParse() error { - me.pp = arg.MustParse(&argv) - return nil -} - -func (a args) Description() string { - // doHelp() - - return ` -forge -- a tool to manage lots of git repos. forge includes a GUI and TUI. - - forge only executes the 'git' command. Everything it does, you can run by hand with 'git'. - - Orginally written to maintain the +50 GO git repositories for the WIT Private Cloud -` -} - -// arg.Register(&argGui) -// log.Info("ArgvGui() started") -func (args) ArgvGui() error { - me.myGui = fhelp.Gui() // adds the GUI package argv support - me.origGui = gui.New() - return nil -} - -func (args) ArgvDebugger() bool { - debugger.InitDebugger() - // me.myGui = gui.Init() - return true -} - -func (args) Examples() string { - var out string - out += "forge show # show the state of all your repos\n" - out += "forge normal # the defaults for 'normal' forge distributed development\n" - out += " # it will makes a user branch in every git repo\n" - out += "forge clean # removes changes forge might have made\n" - out += " # purges all untracked git files, etc\n" - out += "forge pull --force # 'git pull' on all repos\n" - out += "forge commit --al # 'git commit' in every dirty repo\n" - out += "forge merge --all # 'git merge' all patches to devel & master\n" - out += "forge add # scan your current directory for all git repos\n" - return out -} - -// matches -func (c CleanCmd) Match(partial string) []string { - // return repos here - return []string{"go.wit.com/apps/forge", "go.wit.com/apps/virtigo"} -} - -// sends the strings to bash or zsh that will be your options -func (a args) SendCompletionStrings(pb *argvpb.Argv) { - if pb.IsMatch("mode.config") { - matches := []string{"mine", "favorites"} - fmt.Fprintf(argvpb.Stdout, strings.Join(matches, " ")) - return - } - if pb.IsMatch("mode") { - matches := []string{"once", "many", "mine", "favorites"} - fmt.Fprintf(argvpb.Stdout, strings.Join(matches, " ")) - return - } - if pb.GetCmd() == "" { - // these are base autocomplete strings - matches := []string{"clean", "commit", "merge", "patch", "normal", "pull", "rebuild", "generate", "config"} - matches = append(matches, "show", "add", "fixer", "dev", "verify", "mode", "gui", "whatchanged") - matches = append(matches, "--version", "--force", "--all") - fmt.Fprintf(argvpb.Stdout, strings.Join(matches, " ")) - return - } - var err error - if me.pp == nil { - me.pp, err = arg.ParseFlagsArgv(&argv) - fmt.Fprintf(argvpb.Stderr, "returned from parseFlagsArgv(%v)\n", err) - } - err = me.pp.WriteHelpForAutocomplete(argvpb.PB.Partial, argvpb.PB.Real...) - fmt.Fprintf(argvpb.Stderr, "returned from WriteHelpForAutocomplete() pb.Real(%v)\n", pb.Real) - fmt.Fprintf(argvpb.Stderr, "returned from WriteHelpForAutocomplete(%v)\n", err) -} diff --git a/argv.go b/argv.go new file mode 100644 index 0000000..ab5e83d --- /dev/null +++ b/argv.go @@ -0,0 +1,172 @@ +// Copyright 2017-2025 WIT.COM Inc. All rights reserved. +// Use of this source code is governed by the GPL 3.0 + +package main + +/* + this parses the command line arguements using alex flint's go-arg +*/ + +var argv args + +type args struct { + Clean *CleanCmd `arg:"subcommand:clean" help:"'git clean' + reset repos to original state"` + Commit *CommitCmd `arg:"subcommand:commit" help:"'git commit'"` + Gui *EmptyCmd `arg:"subcommand:gui" help:"open the gui"` + Config *ConfigCmd `arg:"subcommand:config" help:"show your .config/forge/ settings"` + Merge *MergeCmd `arg:"subcommand:merge" help:"merge branches"` + Normal *EmptyCmd `arg:"subcommand:normal" help:"shortcut to 'forge mode normal'"` + Mode *ModeCmd `arg:"subcommand:mode" help:"sets the mode (hacking, merging, publishing)"` + Patch *PatchCmd `arg:"subcommand:patch" help:"work with patchsets"` + Pull *PullCmd `arg:"subcommand:pull" help:"'git pull'"` + Show *ShowCmd `arg:"subcommand:show" help:"print out things"` + Dev *DevCmd `arg:"subcommand:dev" help:"features under development"` + Add *EmptyCmd `arg:"subcommand:add" help:"Scan directores for git repos"` + Fixer *FixCmd `arg:"subcommand:fixer" help:"send in the fixer"` + Verify *VerifyCmd `arg:"subcommand:verify" help:"populate stats"` + Whatchanged *EmptyCmd `arg:"subcommand:whatchanged" help:"being deprecated (perhaps?). this is just for finger memory."` + Rebuild *RebuildCmd `arg:"subcommand:rebuild" help:"download all the forge sources and rebuild forge"` + Generate *GenerateCmd `arg:"subcommand:generate" help:"helps run autogenpb in repos with .proto files"` + All bool `arg:"--all" help:"whatever you are doing, do it all over"` + Force bool `arg:"--force" help:"try to strong-arm things"` + Verbose bool `arg:"--verbose" help:"show more output than usual"` + Fix bool `arg:"--fix" help:"try to make repairs"` +} + +type EmptyCmd struct { +} + +type testCmd string + +type ShowCmd struct { + Dirty *EmptyCmd `arg:"subcommand:dirty" help:"show dirty git repos"` + DirtySave *EmptyCmd `arg:"subcommand:dirtysave" help:"check dirty then save"` + MasterDefault *EmptyCmd `arg:"subcommand:masterdefault" help:"run the default behavior for master branches"` + Mtime *EmptyCmd `arg:"subcommand:mtime" help:"show mtime changes"` + ENV *EmptyCmd `arg:"subcommand:ENV" help:"show the ENV"` + Repo *RepoCmd `arg:"subcommand:repos" help:"print a table of the current repos"` + Tag *TagCmd `arg:"subcommand:tag" help:"show git tags"` +} + +type RebuildCmd struct { + Forge *EmptyCmd `arg:"subcommand:forge" help:"rebuild forge"` + GoClone *EmptyCmd `arg:"subcommand:go-clone" help:"rebuild go-clone"` + Autogenpb *EmptyCmd `arg:"subcommand:autogenpb" help:"rebuild autogenpb"` +} + +type FixCmd struct { + Porcelain *EmptyCmd `arg:"subcommand:porcelain" help:"git status --porcelain"` + Urls bool `arg:"--urls" help:"check for changes in repo urls"` + Untracked bool `arg:"--untracked" help:"git untracked file list"` + DeleteUser bool `arg:"--delete-user" help:"delete all user branches (checks for safety)"` + Prune bool `arg:"--prune" help:"'git fetch --prune' everywhere"` +} + +type VerifyCmd struct { + Namespace *EmptyCmd `arg:"subcommand:namespace" help:"check the namespaces"` + Stats *StatsCmd `arg:"subcommand:stats" help:"generate origin.pb"` + DryRun bool `arg:"--dry-run" help:"try not to change anything"` +} + +type StatsCmd struct { + All bool `arg:"--all" help:"process all stats"` + Sizes bool `arg:"--sizes" help:"show sizes"` + List bool `arg:"--list" help:"list all stats"` +} + +func (ShowCmd) Examples() string { + return "forge show dirty\nforge show repos --all" +} + +type RepoCmd struct { + Urls *EmptyCmd `arg:"subcommand:urls" help:"show repo urls"` + All bool `arg:"--all" help:"select every repo (the default)"` + Mine bool `arg:"--mine" help:"your repos as defined in the forge config"` + Favorites bool `arg:"--favorites" help:"your repos configured as favorites"` + Private bool `arg:"--private" help:"your private repos from your .config/forge/"` + User bool `arg:"--user" help:"show repos on the user branch"` + Full bool `arg:"--full" help:"show full repo names"` +} + +type ModeCmd struct { + Master *EmptyCmd `arg:"subcommand:master" help:"keep all repos on the master branch"` + Devel *EmptyCmd `arg:"subcommand:devel" help:"use devel branches"` + User *EmptyCmd `arg:"subcommand:user" help:"use user branches"` + Normal *EmptyCmd `arg:"subcommand:normal" help:"use the 'normal' forge development mode"` + Clean *EmptyCmd `arg:"subcommand:clean" help:"clean mode. removes everything to origin/HEAD"` + Config *EmptyCmd `arg:"subcommand:config" help:"select which config to use"` +} + +type CommitCmd struct { + All bool `arg:"--all" help:"git commit in all dirty repos"` +} + +type DevCmd struct { + Build *EmptyCmd `arg:"subcommand:build" help:"build this repo"` + Install *EmptyCmd `arg:"subcommand:install" help:"build & install this repo"` + URL string `arg:"--connect" help:"forge url"` +} + +type GenerateCmd struct { + Make *EmptyCmd `arg:"subcommand:make" help:"make all the autogenerated files"` + Clean *EmptyCmd `arg:"subcommand:clean" help:"clean out all the autogenerated files"` + Verbose bool `arg:"--verbose" help:"be verbose about it"` + Strict bool `arg:"--strict" help:"die if any namespaces are missing"` +} + +type CleanCmd struct { + List *EmptyCmd `arg:"subcommand:list" help:"list not clean repos"` +} + +type CleanDevelCmd struct { + Force bool `arg:"--force" help:"try to strong arm things"` +} + +type PatchCmd struct { + Apply bool `arg:"--apply" help:"attempt to apply any new patches"` + Show bool `arg:"--show" help:"show the current patches"` + Submit bool `arg:"--resubmit" help:"resubmit your git commits"` +} + +type PullCmd struct { + Force bool `arg:"--force" help:"try to strong-arm things"` + List *EmptyCmd `arg:"subcommand:list" help:"list repo versions"` + Check *RepoCmd `arg:"subcommand:check" help:"check for repo changes"` + Update *EmptyCmd `arg:"subcommand:update" help:"report updates"` +} + +type TagCmd struct { + List *EmptyCmd `arg:"subcommand:list" help:"list the tags"` + Clean *EmptyCmd `arg:"subcommand:clean" help:"clean out old and duplicate tags"` + Delete string `arg:"--delete" help:"delete a tag"` +} + +type MergeCmd struct { + All bool `arg:"--all" help:"merge all"` + Devel *EmptyCmd `arg:"subcommand:devel" help:"merge user to devel"` + Master *EmptyCmd `arg:"subcommand:master" help:"merge devel to master"` + Publish *EmptyCmd `arg:"subcommand:publish" help:"increment versions and publish master branch"` + Check *EmptyCmd `arg:"subcommand:check" help:"check if merge is complete and ready to publish"` +} + +type ConfigCmd struct { + Add *ConfigAddCmd `arg:"subcommand:add" help:"add a config setting"` + List *EmptyCmd `arg:"subcommand:list" help:"list your config settings"` + Delete string `arg:"--delete" help:"delete this repo"` + Register string `arg:"--register" help:"register your git URL (foo.com/mystuff) or (github.com/foo/bar)"` +} + +type ConfigAddCmd struct { + Path string `arg:"--path" help:"absolute path of the git repo"` + Namespace string `arg:"--namespace" help:"namespace of the git repo"` + Directory bool `arg:"--directory" help:"repo is a directory to match against"` + ReadOnly bool `arg:"--readonly" help:"repo is readonly"` + Writable bool `arg:"--writable" help:"repo is writable"` + Favorite bool `arg:"--favorite" help:"forge will always go-clone or git clone this" default:"false"` + Private bool `arg:"--private" default:"false" help:"repo can not be published"` + Interesting bool `arg:"--interesting" default:"false" help:"something you decided was cool"` + DebName string `arg:"--debname" help:"the name of the debian package (or rpm, etc)"` + Master string `arg:"--master" help:"the git 'master' or 'main' branch name"` + Devel string `arg:"--devel" help:"the git devel branch name"` + User string `arg:"--user" help:"the git user branch name"` +} diff --git a/argv.struct.go b/argv.struct.go deleted file mode 100644 index ab5e83d..0000000 --- a/argv.struct.go +++ /dev/null @@ -1,172 +0,0 @@ -// Copyright 2017-2025 WIT.COM Inc. All rights reserved. -// Use of this source code is governed by the GPL 3.0 - -package main - -/* - this parses the command line arguements using alex flint's go-arg -*/ - -var argv args - -type args struct { - Clean *CleanCmd `arg:"subcommand:clean" help:"'git clean' + reset repos to original state"` - Commit *CommitCmd `arg:"subcommand:commit" help:"'git commit'"` - Gui *EmptyCmd `arg:"subcommand:gui" help:"open the gui"` - Config *ConfigCmd `arg:"subcommand:config" help:"show your .config/forge/ settings"` - Merge *MergeCmd `arg:"subcommand:merge" help:"merge branches"` - Normal *EmptyCmd `arg:"subcommand:normal" help:"shortcut to 'forge mode normal'"` - Mode *ModeCmd `arg:"subcommand:mode" help:"sets the mode (hacking, merging, publishing)"` - Patch *PatchCmd `arg:"subcommand:patch" help:"work with patchsets"` - Pull *PullCmd `arg:"subcommand:pull" help:"'git pull'"` - Show *ShowCmd `arg:"subcommand:show" help:"print out things"` - Dev *DevCmd `arg:"subcommand:dev" help:"features under development"` - Add *EmptyCmd `arg:"subcommand:add" help:"Scan directores for git repos"` - Fixer *FixCmd `arg:"subcommand:fixer" help:"send in the fixer"` - Verify *VerifyCmd `arg:"subcommand:verify" help:"populate stats"` - Whatchanged *EmptyCmd `arg:"subcommand:whatchanged" help:"being deprecated (perhaps?). this is just for finger memory."` - Rebuild *RebuildCmd `arg:"subcommand:rebuild" help:"download all the forge sources and rebuild forge"` - Generate *GenerateCmd `arg:"subcommand:generate" help:"helps run autogenpb in repos with .proto files"` - All bool `arg:"--all" help:"whatever you are doing, do it all over"` - Force bool `arg:"--force" help:"try to strong-arm things"` - Verbose bool `arg:"--verbose" help:"show more output than usual"` - Fix bool `arg:"--fix" help:"try to make repairs"` -} - -type EmptyCmd struct { -} - -type testCmd string - -type ShowCmd struct { - Dirty *EmptyCmd `arg:"subcommand:dirty" help:"show dirty git repos"` - DirtySave *EmptyCmd `arg:"subcommand:dirtysave" help:"check dirty then save"` - MasterDefault *EmptyCmd `arg:"subcommand:masterdefault" help:"run the default behavior for master branches"` - Mtime *EmptyCmd `arg:"subcommand:mtime" help:"show mtime changes"` - ENV *EmptyCmd `arg:"subcommand:ENV" help:"show the ENV"` - Repo *RepoCmd `arg:"subcommand:repos" help:"print a table of the current repos"` - Tag *TagCmd `arg:"subcommand:tag" help:"show git tags"` -} - -type RebuildCmd struct { - Forge *EmptyCmd `arg:"subcommand:forge" help:"rebuild forge"` - GoClone *EmptyCmd `arg:"subcommand:go-clone" help:"rebuild go-clone"` - Autogenpb *EmptyCmd `arg:"subcommand:autogenpb" help:"rebuild autogenpb"` -} - -type FixCmd struct { - Porcelain *EmptyCmd `arg:"subcommand:porcelain" help:"git status --porcelain"` - Urls bool `arg:"--urls" help:"check for changes in repo urls"` - Untracked bool `arg:"--untracked" help:"git untracked file list"` - DeleteUser bool `arg:"--delete-user" help:"delete all user branches (checks for safety)"` - Prune bool `arg:"--prune" help:"'git fetch --prune' everywhere"` -} - -type VerifyCmd struct { - Namespace *EmptyCmd `arg:"subcommand:namespace" help:"check the namespaces"` - Stats *StatsCmd `arg:"subcommand:stats" help:"generate origin.pb"` - DryRun bool `arg:"--dry-run" help:"try not to change anything"` -} - -type StatsCmd struct { - All bool `arg:"--all" help:"process all stats"` - Sizes bool `arg:"--sizes" help:"show sizes"` - List bool `arg:"--list" help:"list all stats"` -} - -func (ShowCmd) Examples() string { - return "forge show dirty\nforge show repos --all" -} - -type RepoCmd struct { - Urls *EmptyCmd `arg:"subcommand:urls" help:"show repo urls"` - All bool `arg:"--all" help:"select every repo (the default)"` - Mine bool `arg:"--mine" help:"your repos as defined in the forge config"` - Favorites bool `arg:"--favorites" help:"your repos configured as favorites"` - Private bool `arg:"--private" help:"your private repos from your .config/forge/"` - User bool `arg:"--user" help:"show repos on the user branch"` - Full bool `arg:"--full" help:"show full repo names"` -} - -type ModeCmd struct { - Master *EmptyCmd `arg:"subcommand:master" help:"keep all repos on the master branch"` - Devel *EmptyCmd `arg:"subcommand:devel" help:"use devel branches"` - User *EmptyCmd `arg:"subcommand:user" help:"use user branches"` - Normal *EmptyCmd `arg:"subcommand:normal" help:"use the 'normal' forge development mode"` - Clean *EmptyCmd `arg:"subcommand:clean" help:"clean mode. removes everything to origin/HEAD"` - Config *EmptyCmd `arg:"subcommand:config" help:"select which config to use"` -} - -type CommitCmd struct { - All bool `arg:"--all" help:"git commit in all dirty repos"` -} - -type DevCmd struct { - Build *EmptyCmd `arg:"subcommand:build" help:"build this repo"` - Install *EmptyCmd `arg:"subcommand:install" help:"build & install this repo"` - URL string `arg:"--connect" help:"forge url"` -} - -type GenerateCmd struct { - Make *EmptyCmd `arg:"subcommand:make" help:"make all the autogenerated files"` - Clean *EmptyCmd `arg:"subcommand:clean" help:"clean out all the autogenerated files"` - Verbose bool `arg:"--verbose" help:"be verbose about it"` - Strict bool `arg:"--strict" help:"die if any namespaces are missing"` -} - -type CleanCmd struct { - List *EmptyCmd `arg:"subcommand:list" help:"list not clean repos"` -} - -type CleanDevelCmd struct { - Force bool `arg:"--force" help:"try to strong arm things"` -} - -type PatchCmd struct { - Apply bool `arg:"--apply" help:"attempt to apply any new patches"` - Show bool `arg:"--show" help:"show the current patches"` - Submit bool `arg:"--resubmit" help:"resubmit your git commits"` -} - -type PullCmd struct { - Force bool `arg:"--force" help:"try to strong-arm things"` - List *EmptyCmd `arg:"subcommand:list" help:"list repo versions"` - Check *RepoCmd `arg:"subcommand:check" help:"check for repo changes"` - Update *EmptyCmd `arg:"subcommand:update" help:"report updates"` -} - -type TagCmd struct { - List *EmptyCmd `arg:"subcommand:list" help:"list the tags"` - Clean *EmptyCmd `arg:"subcommand:clean" help:"clean out old and duplicate tags"` - Delete string `arg:"--delete" help:"delete a tag"` -} - -type MergeCmd struct { - All bool `arg:"--all" help:"merge all"` - Devel *EmptyCmd `arg:"subcommand:devel" help:"merge user to devel"` - Master *EmptyCmd `arg:"subcommand:master" help:"merge devel to master"` - Publish *EmptyCmd `arg:"subcommand:publish" help:"increment versions and publish master branch"` - Check *EmptyCmd `arg:"subcommand:check" help:"check if merge is complete and ready to publish"` -} - -type ConfigCmd struct { - Add *ConfigAddCmd `arg:"subcommand:add" help:"add a config setting"` - List *EmptyCmd `arg:"subcommand:list" help:"list your config settings"` - Delete string `arg:"--delete" help:"delete this repo"` - Register string `arg:"--register" help:"register your git URL (foo.com/mystuff) or (github.com/foo/bar)"` -} - -type ConfigAddCmd struct { - Path string `arg:"--path" help:"absolute path of the git repo"` - Namespace string `arg:"--namespace" help:"namespace of the git repo"` - Directory bool `arg:"--directory" help:"repo is a directory to match against"` - ReadOnly bool `arg:"--readonly" help:"repo is readonly"` - Writable bool `arg:"--writable" help:"repo is writable"` - Favorite bool `arg:"--favorite" help:"forge will always go-clone or git clone this" default:"false"` - Private bool `arg:"--private" default:"false" help:"repo can not be published"` - Interesting bool `arg:"--interesting" default:"false" help:"something you decided was cool"` - DebName string `arg:"--debname" help:"the name of the debian package (or rpm, etc)"` - Master string `arg:"--master" help:"the git 'master' or 'main' branch name"` - Devel string `arg:"--devel" help:"the git devel branch name"` - User string `arg:"--user" help:"the git user branch name"` -} diff --git a/complete.go b/complete.go new file mode 100644 index 0000000..987a812 --- /dev/null +++ b/complete.go @@ -0,0 +1,126 @@ +// Copyright 2017-2025 WIT.COM Inc. All rights reserved. +// Use of this source code is governed by the GPL 3.0 + +package main + +import ( + "fmt" + "strings" + + "go.wit.com/dev/alexflint/arg" + "go.wit.com/gui" + "go.wit.com/lib/debugger" + "go.wit.com/lib/env" + "go.wit.com/lib/fhelp" + "go.wit.com/lib/protobuf/argvpb" + "go.wit.com/log" +) + +// sent via -ldflags // is there a better way? +var VERSION string +var BUILDTIME string + +// used for shell auto completion +var APPNAME string = "forge" + +func (args) InitArgv() (string, string, string) { + return APPNAME, BUILDTIME, VERSION +} + +func (args) InitGui() error { + // panic("got here") + arg.Register(&gui.ArgvGui) + // me.gui = gui.PreInit() + me.myGui = fhelp.Gui() + return nil +} + +func (args) Exit() { + gui.UnloadToolkits() + if env.Verbose() { + log.Info("argv.Exit() called", APPNAME+".Exit() because env.Verbose() == true") + } + // remove this from the template for your app (or make one for youself if you need it) + forgeExit() // custom forge shutdown function +} + +func (args) MustParse() error { + me.pp = arg.MustParse(&argv) + return nil +} + +func (a args) Description() string { + // doHelp() + + return ` +forge -- a tool to manage lots of git repos. forge includes a GUI and TUI. + + forge only executes the 'git' command. Everything it does, you can run by hand with 'git'. + + Orginally written to maintain the +50 GO git repositories for the WIT Private Cloud +` +} + +// arg.Register(&argGui) +// log.Info("ArgvGui() started") +func (args) ArgvGui() error { + me.myGui = fhelp.Gui() // adds the GUI package argv support + me.origGui = gui.New() + return nil +} + +func (args) ArgvDebugger() bool { + debugger.InitDebugger() + // me.myGui = gui.Init() + return true +} + +func (args) Examples() string { + var out string + out += "forge show # show the state of all your repos\n" + out += "forge normal # the defaults for 'normal' forge distributed development\n" + out += " # it will makes a user branch in every git repo\n" + out += "forge clean # removes changes forge might have made\n" + out += " # purges all untracked git files, etc\n" + out += "forge pull --force # 'git pull' on all repos\n" + out += "forge commit --al # 'git commit' in every dirty repo\n" + out += "forge merge --all # 'git merge' all patches to devel & master\n" + out += "forge add # scan your current directory for all git repos\n" + return out +} + +// matches +func (c CleanCmd) Match(partial string) []string { + // return repos here + return []string{"go.wit.com/apps/forge", "go.wit.com/apps/virtigo"} +} + +// sends the strings to bash or zsh that will be your options +func (a args) SendCompletionStrings(pb *argvpb.Argv) { + if pb.IsMatch("mode.config") { + matches := []string{"mine", "favorites"} + fmt.Fprintf(argvpb.Stdout, strings.Join(matches, " ")) + return + } + if pb.IsMatch("mode") { + matches := []string{"once", "many", "mine", "favorites"} + fmt.Fprintf(argvpb.Stdout, strings.Join(matches, " ")) + return + } + if pb.GetCmd() == "" { + // these are base autocomplete strings + matches := []string{"clean", "commit", "merge", "patch", "normal", "pull", "rebuild", "generate", "config"} + matches = append(matches, "show", "add", "fixer", "dev", "verify", "mode", "gui", "whatchanged") + matches = append(matches, "--version", "--force", "--all") + fmt.Fprintf(argvpb.Stdout, strings.Join(matches, " ")) + return + } + var err error + if me.pp == nil { + me.pp, err = arg.ParseFlagsArgv(&argv) + fmt.Fprintf(argvpb.Stderr, "returned from parseFlagsArgv(%v)\n", err) + } + err = me.pp.WriteHelpForAutocomplete(argvpb.PB.Partial, argvpb.PB.Real...) + fmt.Fprintf(argvpb.Stderr, "returned from WriteHelpForAutocomplete() pb.Real(%v)\n", pb.Real) + fmt.Fprintf(argvpb.Stderr, "returned from WriteHelpForAutocomplete(%v)\n", err) +} -- cgit v1.2.3