diff options
| author | Jeff Carr <[email protected]> | 2025-10-26 10:17:37 -0500 |
|---|---|---|
| committer | Jeff Carr <[email protected]> | 2025-10-26 10:17:37 -0500 |
| commit | 6d74699580cd1d25e97e129a6e796bf324298663 (patch) | |
| tree | 81ad1d13f4ee2d56d941d505d00b4d6c14cd1444 /complete.go | |
| parent | e1e8951cc3cad6db900ac1240512902936c4f97a (diff) | |
argv is better nowv0.0.68
Diffstat (limited to 'complete.go')
| -rw-r--r-- | complete.go | 37 |
1 files changed, 37 insertions, 0 deletions
diff --git a/complete.go b/complete.go new file mode 100644 index 0000000..178f57d --- /dev/null +++ b/complete.go @@ -0,0 +1,37 @@ +package main + +import ( + "fmt" + "strings" + + "go.wit.com/dev/alexflint/arg" + "go.wit.com/lib/protobuf/argvpb" +) + +// are sent via -ldflags at buildtime +var VERSION string +var BUILDTIME string +var APPNAME string = "forged" + +func (args) MustParse() error { + me.pp = arg.MustParse(&argv) + return nil +} + +// sends the strings to bash or zsh that will be your options +func (a args) DoAutoComplete() error { + if argvpb.PB.GetCmd() == "" { + matches := []string{"--bash", "repos", "gui", "patches", "--daemon", "missing"} + fmt.Fprintf(argvpb.Stdout, " %s", strings.Join(matches, " ")) + return nil + } + var err error + if me.pp == nil { + me.pp, err = arg.ParseFlagsArgv(&argv) + if err != nil { + return err + } + } + err = me.pp.WriteHelpForAutocomplete(argvpb.PB.Partial, argvpb.PB.Real...) + return err +} |
