2017-05-05 08:57:22 -05:00
|
|
|
package complete
|
|
|
|
|
2019-11-13 22:51:44 -06:00
|
|
|
// Command is an object that can be used to create complete options for a go executable that does
|
|
|
|
// not have a good binding to the `Completer` interface, or to use a Go program as complete binary
|
|
|
|
// for another executable (see ./gocomplete as an example.)
|
2017-05-06 14:06:49 -05:00
|
|
|
type Command struct {
|
2019-11-13 22:51:44 -06:00
|
|
|
// Sub is map of sub commands of the current command. The key refer to the sub command name, and
|
|
|
|
// the value is it's command descriptive struct.
|
|
|
|
Sub map[string]*Command
|
|
|
|
// Flags is a map of flags that the command accepts. The key is the flag name, and the value is
|
|
|
|
// it's predictions. In a chain of sub commands, no duplicate flags should be defined.
|
|
|
|
Flags map[string]Predictor
|
|
|
|
// Args are extra arguments that the command accepts, those who are given without any flag
|
|
|
|
// before. In any chain of sub commands, only one of them should predict positional arguments.
|
2017-05-11 12:28:31 -05:00
|
|
|
Args Predictor
|
2017-05-05 08:57:22 -05:00
|
|
|
}
|
|
|
|
|
2019-11-13 22:51:44 -06:00
|
|
|
// Complete runs the completion of the described command.
|
|
|
|
func (c *Command) Complete(name string) {
|
|
|
|
Complete(name, c)
|
2017-05-12 07:08:36 -05:00
|
|
|
}
|
|
|
|
|
2019-11-13 22:51:44 -06:00
|
|
|
func (c *Command) SubCmdList() []string {
|
|
|
|
subs := make([]string, 0, len(c.Sub))
|
|
|
|
for sub := range c.Sub {
|
|
|
|
subs = append(subs, sub)
|
2017-05-12 07:08:36 -05:00
|
|
|
}
|
2019-11-13 22:51:44 -06:00
|
|
|
return subs
|
2017-05-12 07:08:36 -05:00
|
|
|
}
|
|
|
|
|
2019-11-13 22:51:44 -06:00
|
|
|
func (c *Command) SubCmdGet(cmd string) Completer {
|
|
|
|
if c.Sub[cmd] == nil {
|
|
|
|
return nil
|
2017-05-12 07:08:36 -05:00
|
|
|
}
|
2019-11-13 22:51:44 -06:00
|
|
|
return c.Sub[cmd]
|
2017-05-11 12:28:31 -05:00
|
|
|
}
|
2019-11-13 22:51:44 -06:00
|
|
|
func (c *Command) FlagList() []string {
|
|
|
|
flags := make([]string, 0, len(c.Flags))
|
|
|
|
for flag := range c.Flags {
|
|
|
|
flags = append(flags, flag)
|
2017-05-15 11:32:59 -05:00
|
|
|
}
|
2019-11-13 22:51:44 -06:00
|
|
|
return flags
|
|
|
|
}
|
2017-05-15 11:32:59 -05:00
|
|
|
|
2019-11-13 22:51:44 -06:00
|
|
|
func (c *Command) FlagGet(flag string) Predictor {
|
|
|
|
return PredictFunc(func(prefix string) (options []string) {
|
|
|
|
f := c.Flags[flag]
|
|
|
|
if f == nil {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
return f.Predict(prefix)
|
|
|
|
})
|
|
|
|
}
|
2017-05-05 15:07:18 -05:00
|
|
|
|
2019-11-13 22:51:44 -06:00
|
|
|
func (c *Command) ArgsGet() Predictor {
|
|
|
|
return PredictFunc(func(prefix string) (options []string) {
|
|
|
|
if c.Args == nil {
|
|
|
|
return nil
|
|
|
|
}
|
|
|
|
return c.Args.Predict(prefix)
|
|
|
|
})
|
2017-05-05 08:57:22 -05:00
|
|
|
}
|