Documentation ¶
Overview ¶
Package complete is everything for bash completion and Go.
Writing bash completion scripts is a hard work, usually done in the bash scripting language. This package provides:
* A library for bash completion for Go programs.
* A tool for writing bash completion script in the Go language. For any Go or non Go program.
* Bash completion for the `go` command line (See ./gocomplete).
* Library for bash-completion enabled flags (See ./compflag).
* Enables an easy way to install/uninstall the completion of the command.
The library and tools are extensible such that any program can add its one logic, completion types or methologies.
Go Command Bash Completion ¶
./gocomplete is the script for bash completion for the `go` command line. This is an example that uses the `complete` package on the `go` command - the `complete` package can also be used to implement any completions, see #usage.
Install:
1. Type in your shell:
go get -u github.com/chriswalz/complete/v3/gocomplete COMP_INSTALL=1 gocomplete
2. Restart your shell
Uninstall by `COMP_UNINSTALL=1 gocomplete`
Features:
- Complete `go` command, including sub commands and flags. - Complete packages names or `.go` files when necessary. - Complete test names after `-run` flag.
Complete Package ¶
Supported shells:
- [x] bash - [x] zsh - [x] fish
The installation of completion for a command line tool is done automatically by this library by running the command line tool with the `COMP_INSTALL` environment variable set. Uninstalling the completion is similarly done by the `COMP_UNINSTALL` environment variable. For example, if a tool called `my-cli` uses this library, the completion can install by running `COMP_INSTALL=1 my-cli`.
Usage ¶
Add bash completion capabilities to any Go program. See ./example/command.
import ( "flag" "github.com/chriswalz/complete/v3" "github.com/chriswalz/complete/v3/predict" ) var ( // Add variables to the program. Name = flag.String("Name", "", "") something = flag.String("something", "", "") nothing = flag.String("nothing", "", "") ) func main() { // Create the complete command. // Here we define completion values for each flag. cmd := &complete.Command{ Flags: map[string]complete.Predictor{ "Name": predict.Set{"foo", "bar", "foo bar"}, "something": predict.Something, "nothing": predict.Nothing, }, } // Run the completion - provide it with the binary Name. cmd.Complete("my-program") // Parse the flags. flag.Parse() // Program logic... }
This package also enables to complete flags defined by the standard library `flag` package. To use this feature, simply call `complete.CommandLine` before `flag.Parse`. (See ./example/stdlib).
import ( "flag" + "github.com/chriswalz/complete/v3" ) var ( // Define flags here... foo = flag.Bool("foo", false, "") ) func main() { // Call command line completion before parsing the flags - provide it with the binary Name. + complete.CommandLine("my-program") flag.Parse() }
If flag value completion is desired, it can be done by providing the standard library `flag.Var` function a `flag.Value` that also implements the `complete.Predictor` interface. For standard flag with values, it is possible to use the `github.com/chriswalz/complete/v3/compflag` package. (See ./example/compflag).
import ( "flag" + "github.com/chriswalz/complete/v3" + "github.com/chriswalz/complete/v3/compflag" ) var ( // Define flags here... - foo = flag.Bool("foo", false, "") + foo = compflag.Bool("foo", false, "") ) func main() { // Call command line completion before parsing the flags. + complete.CommandLine("my-program") flag.Parse() }
Instead of calling both `complete.CommandLine` and `flag.Parse`, one can call just `compflag.Parse` which does them both.
Testing ¶
For command line bash completion testing use the `complete.Test` function.
Index ¶
Constants ¶
This section is empty.
Variables ¶
This section is empty.
Functions ¶
func CommandLine ¶
func CommandLine()
Complete default command line flag set defined by the standard library.
Types ¶
type Command ¶
type Command struct { Description string // 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. Args Predictor }
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.)
func (*Command) SubCmdList ¶
type CompTree ¶ added in v3.0.9
type CompTree struct { Flags map[string]*CompTree // FIXME: Args & Sub may be able to be combined since thus far there doesn't seem to necessitate a difference Args map[string]*CompTree Sub map[string]*CompTree Dynamic func(prefix string) []Suggestion Desc string }
a tree representation of CLI commands & sub commands
type Completer ¶
type Completer interface { // SubCmdList should return the list of all sub commands of the current command. SubCmdList() []string // SubCmdGet should return a sub command of the current command for the given sub command Name. SubCmdGet(cmd string) Completer // FlagList should return a list of all the flag names of the current command. The flag names // should not have the dash prefix. FlagList() []string // FlagGet should return completion options for a given flag. It is invoked with the flag Name // without the dash prefix. The flag is not promised to be in the command flags. In that case, // this method should return a nil predictor. FlagGet(flag string) Predictor // ArgsGet should return predictor for positional arguments of the command line. ArgsGet() Predictor }
Completer is an interface that a command line should implement in order to get bash completion.
type PredictFunc ¶
PredictFunc is a function that implements the Predictor interface.
func (PredictFunc) Predict ¶
func (p PredictFunc) Predict(prefix string) []string
type Predictor ¶
type Predictor interface { // Predict returns prediction options for a given prefix. The prefix is what currently is typed // as a hint for what to return, but the returned values can have any prefix. The returned // values will be filtered by the prefix when needed regardless. The prefix may be empty which // means that no value was typed. Predict(prefix string) []string }
Predictor can predict completion options.
type SearchMethod ¶ added in v3.0.13
type Suggestion ¶
func AutoComplete ¶
func AutoComplete(text string, completionTree *CompTree, queryFunc SearchMethod) ([]Suggestion, error)
e.g. AutoComplete("git sta", completionTree, strings.Prefix)
func CompleteLine ¶
func CompleteLine(line string, cmdCompletionTree *CompTree, searchMethod SearchMethod) ([]Suggestion, error)
Source Files ¶
Directories ¶
Path | Synopsis |
---|---|
Package compflag provides a handful of standard library-compatible flags with bash complition capabilities.
|
Package compflag provides a handful of standard library-compatible flags with bash complition capabilities. |
gen
Generates flags.go.
|
Generates flags.go. |
example
|
|
command
command shows how to have bash completion to an arbitrary Go program using the `complete.Command` struct.
|
command shows how to have bash completion to an arbitrary Go program using the `complete.Command` struct. |
compflag
compflag shows how to use the github.com/chriswalz/complete/v3/compflag package to have auto bash completion for a defined set of flags.
|
compflag shows how to use the github.com/chriswalz/complete/v3/compflag package to have auto bash completion for a defined set of flags. |
stdlib
stdlib shows how to have flags bash completion to an arbitrary Go program that uses the standard library flag package.
|
stdlib shows how to have flags bash completion to an arbitrary Go program that uses the standard library flag package. |
Package main is complete tool for the go command line
|
Package main is complete tool for the go command line |
Package install provide installation functions of command completion.
|
Package install provide installation functions of command completion. |
internal
|
|
Package predict provides helper functions for completion predictors.
|
Package predict provides helper functions for completion predictors. |