Documentation ¶
Overview ¶
Package carapace is a command argument completion generator for spf13/cobra
Index ¶
- Variables
- func ActionExecCommand(name string, arg ...string) func(f func(output []byte) Action) Action
- func ActionExecCommandE(name string, arg ...string) func(f func(output []byte, err error) Action) Action
- func Batch(actions ...Action) batch
- func IsCallback() bool
- func Test(t interface{ ... })
- type Action
- func ActionCallback(callback CompletionCallback) Action
- func ActionCobra(...) Action
- func ActionCommands(cmd *cobra.Command) Action
- func ActionDirectories() Action
- func ActionExecutables() Action
- func ActionExecute(cmd *cobra.Command) Action
- func ActionFiles(suffix ...string) Action
- func ActionImport(output []byte) Action
- func ActionMessage(msg string, args ...interface{}) Action
- func ActionMultiParts(sep string, callback func(c Context) Action) Action
- func ActionMultiPartsN(sep string, n int, callback func(c Context) Action) Action
- func ActionPositional(cmd *cobra.Command) Action
- func ActionStyleConfig() Action
- func ActionStyledValues(values ...string) Action
- func ActionStyledValuesDescribed(values ...string) Action
- func ActionStyles(styles ...string) Action
- func ActionValues(values ...string) Action
- func ActionValuesDescribed(values ...string) Action
- func (a Action) Cache(timeout time.Duration, keys ...pkgcache.Key) Action
- func (a Action) Chdir(dir string) Action
- func (a Action) ChdirF(f func(tc pkgtraverse.Context) (string, error)) Action
- func (a Action) Filter(values ...string) Action
- func (a Action) FilterArgs() Action
- func (a Action) FilterParts() Action
- func (a Action) Invoke(c Context) InvokedAction
- func (a Action) List(divider string) Action
- func (a Action) MultiParts(dividers ...string) Action
- func (a Action) MultiPartsP(delimiter string, pattern string, ...) Action
- func (a Action) NoSpace(suffixes ...rune) Action
- func (a Action) Prefix(prefix string) Action
- func (a Action) Retain(values ...string) Action
- func (a Action) Shift(n int) Action
- func (a Action) Split() Action
- func (a Action) SplitP() Action
- func (a Action) Style(s string) Action
- func (a Action) StyleF(f func(s string, sc style.Context) string) Action
- func (a Action) StyleR(s *string) Action
- func (a Action) Suffix(suffix string) Action
- func (a Action) Suppress(expr ...string) Action
- func (a Action) Tag(tag string) Action
- func (a Action) TagF(f func(s string) string) Action
- func (a Action) Timeout(d time.Duration, alternative Action) Action
- func (a Action) UniqueList(divider string) Action
- func (a Action) UniqueListF(divider string, f func(s string) string) Action
- func (a Action) Usage(usage string, args ...interface{}) Action
- func (a Action) UsageF(f func() string) Action
- type ActionMap
- type Carapace
- func (c Carapace) DashAnyCompletion(action Action)
- func (c Carapace) DashCompletion(action ...Action)
- func (c Carapace) FlagCompletion(actions ActionMap)
- func (c Carapace) PositionalAnyCompletion(action Action)
- func (c Carapace) PositionalCompletion(action ...Action)
- func (c Carapace) PreInvoke(f func(cmd *cobra.Command, flag *pflag.Flag, action Action) Action)
- func (c Carapace) PreRun(f func(cmd *cobra.Command, args []string))
- func (c Carapace) Snippet(name string) (string, error)
- func (c Carapace) Standalone()
- type CompletionCallback
- type Context
- func (c Context) Abs(path string) (string, error)
- func (c Context) Command(name string, arg ...string) *execabs.Cmd
- func (c Context) Envsubst(s string) (string, error)
- func (c Context) Getenv(key string) string
- func (c Context) LookupEnv(key string) (string, bool)
- func (c *Context) Setenv(key, value string)
- type InvokedAction
- func (a InvokedAction) Filter(values ...string) InvokedAction
- func (a InvokedAction) Merge(others ...InvokedAction) InvokedAction
- func (a InvokedAction) Prefix(prefix string) InvokedAction
- func (a InvokedAction) Retain(values ...string) InvokedAction
- func (a InvokedAction) Suffix(suffix string) InvokedAction
- func (a InvokedAction) ToA() Action
- func (a InvokedAction) ToMultiPartsA(dividers ...string) Action
Constants ¶
This section is empty.
Variables ¶
Functions ¶
func ActionExecCommand ¶ added in v0.5.8
ActionExecCommand executes an external command.
carapace.ActionExecCommand("git", "remote")(func(output []byte) carapace.Action { lines := strings.Split(string(output), "\n") return carapace.ActionValues(lines[:len(lines)-1]...) })
func ActionExecCommandE ¶ added in v0.33.5
func ActionExecCommandE(name string, arg ...string) func(f func(output []byte, err error) Action) Action
ActionExecCommandE is like ActionExecCommand but with custom error handling.
carapace.ActionExecCommandE("supervisorctl", "--configuration", path, "status")(func(output []byte, err error) carapace.Action { if err != nil { const NOT_RUNNING = 3 if exitErr, ok := err.(*exec.ExitError); !ok || exitErr.ExitCode() != NOT_RUNNING { return carapace.ActionMessage(err.Error()) } } return carapace.ActionValues("success") })
func Batch ¶ added in v0.8.0
func Batch(actions ...Action) batch
Batch creates a batch of Actions that can be invoked in parallel.
func IsCallback ¶ added in v0.0.6
func IsCallback() bool
IsCallback returns true if current program invocation is a callback.
Types ¶
type Action ¶
type Action struct {
// contains filtered or unexported fields
}
Action indicates how to complete a flag or positional argument.
func ActionCallback ¶
func ActionCallback(callback CompletionCallback) Action
ActionCallback invokes a go function during completion.
func ActionCobra ¶ added in v0.45.0
func ActionCobra(f func(cmd *cobra.Command, args []string, toComplete string) ([]string, cobra.ShellCompDirective)) Action
ActionCora bridges given cobra completion function.
func ActionCommands ¶ added in v0.44.0
ActionCommands completes (sub)commands of given command. `Context.Args` is used to traverse the command tree further down. Use `Action.Shift` to avoid this.
carapace.Gen(helpCmd).PositionalAnyCompletion( carapace.ActionCommands(rootCmd), )
func ActionDirectories ¶ added in v0.0.11
func ActionDirectories() Action
ActionDirectories completes directories.
func ActionExecutables ¶ added in v0.35.0
func ActionExecutables() Action
ActionExecutables completes PATH executables
nvim chmod
func ActionExecute ¶
ActionExecute executes completion on an internal command TODO example.
func ActionFiles ¶
ActionFiles completes files with optional suffix filtering.
func ActionImport ¶ added in v0.12.7
ActionImport parses the json output from export as Action
carapace.Gen(rootCmd).PositionalAnyCompletion( carapace.ActionCallback(func(c carapace.Context) carapace.Action { args := []string{"_carapace", "export", ""} args = append(args, c.Args...) args = append(args, c.Value) return carapace.ActionExecCommand("command", args...)(func(output []byte) carapace.Action { return carapace.ActionImport(output) }) }), )
func ActionMessage ¶
ActionMessage displays a help messages in places where no completions can be generated.
func ActionMultiParts ¶
ActionMultiParts completes parts of an argument separated by sep.
func ActionMultiPartsN ¶ added in v0.40.0
ActionMultiPartsN is like ActionMultiParts but limits the number of parts to `n`.
func ActionPositional ¶ added in v0.33.10
ActionPositional completes positional arguments for given command ignoring `--` (dash). TODO: experimental - likely gives issues with preinvoke (does not have the full args)
carapace.Gen(cmd).DashAnyCompletion( carapace.ActionPositional(cmd), )
func ActionStyleConfig ¶ added in v0.19.0
func ActionStyleConfig() Action
ActionStyleConfig completes style configuration
carapace.Value=blue carapace.Description=magenta
func ActionStyledValues ¶ added in v0.18.0
ActionStyledValues is like ActionValues but also accepts a style.
func ActionStyledValuesDescribed ¶ added in v0.18.0
ActionStyledValuesDescribed is like ActionValues but also accepts a style.
func ActionValues ¶
ActionValues completes arbitrary keywords (values).
func ActionValuesDescribed ¶
ActionValuesDescribed completes arbitrary key (values) with an additional description (value, description pairs).
func (Action) Cache ¶ added in v0.2.4
Cache cashes values of a CompletionCallback for given duration and keys.
func (Action) Chdir ¶ added in v0.8.10
Chdir changes the current working directory to the named directory for the duration of invocation.
func (Action) Filter ¶ added in v0.38.3
Filter filters given values.
carapace.ActionValues("A", "B", "C").Filter("B") // ["A", "C"]
func (Action) FilterArgs ¶ added in v0.42.0
FilterArgs filters Context.Args
func (Action) FilterParts ¶ added in v0.42.0
FilterArgs filters Context.Parts
func (Action) Invoke ¶ added in v0.1.1
func (a Action) Invoke(c Context) InvokedAction
Invoke executes the callback of an action if it exists (supports nesting).
func (Action) List ¶ added in v0.26.4
List wraps the Action in an ActionMultiParts with given divider.
func (Action) MultiParts ¶ added in v0.28.1
MultiParts splits values of an Action by given dividers and completes each segment separately.
func (Action) MultiPartsP ¶ added in v0.40.4
func (a Action) MultiPartsP(delimiter string, pattern string, f func(placeholder string, matches map[string]string) Action) Action
MultiPartsP is like MultiParts but with placeholders
func (Action) NoSpace ¶ added in v0.8.1
NoSpace disables space suffix for given characters (or all if none are given).
func (Action) Prefix ¶ added in v0.1.0
Prefix adds a prefix to values (only the ones inserted, not the display values).
carapace.ActionValues("melon", "drop", "fall").Prefix("water")
func (Action) Retain ¶ added in v0.38.3
Retain retains given values.
carapace.ActionValues("A", "B", "C").Retain("A", "C") // ["A", "C"]
func (Action) Split ¶ added in v0.40.0
Split splits `Context.Value` lexicographically and replaces `Context.Args` with the tokens.
func (Action) Style ¶ added in v0.18.0
Style sets the style.
ActionValues("yes").Style(style.Green) ActionValues("no").Style(style.Red)
func (Action) StyleF ¶ added in v0.19.0
Style sets the style using a function.
ActionValues("dir/", "test.txt").StyleF(style.ForPathExt) ActionValues("true", "false").StyleF(style.ForKeyword)
func (Action) StyleR ¶ added in v0.20.0
Style sets the style using a reference.
ActionValues("value").StyleR(&style.Carapace.Value) ActionValues("description").StyleR(&style.Carapace.Value)
func (Action) Suffix ¶ added in v0.1.0
Suffix adds a suffx to values (only the ones inserted, not the display values).
carapace.ActionValues("apple", "melon", "orange").Suffix("juice")
func (Action) Suppress ¶ added in v0.12.5
Suppress suppresses specific error messages using regular expressions.
func (Action) Tag ¶ added in v0.26.5
Tag sets the tag.
ActionValues("192.168.1.1", "127.0.0.1").Tag("interfaces").
func (Action) TagF ¶ added in v0.26.5
Tag sets the tag using a function.
ActionValues("192.168.1.1", "127.0.0.1").TagF(func(value string) string { return "interfaces" })
func (Action) Timeout ¶ added in v0.32.0
Timeout sets the maximum duration an Action may take to invoke.
carapace.ActionCallback(func(c carapace.Context) carapace.Action { time.Sleep(2*time.Second) return carapace.ActionValues("done") }).Timeout(1*time.Second, carapace.ActionMessage("timeout exceeded"))
func (Action) UniqueList ¶ added in v0.26.2
UniqueList wraps the Action in an ActionMultiParts with given divider.
func (Action) UniqueListF ¶ added in v0.43.4
UniqueListF is like UniqueList but uses a function to transform values before filtering.
type Carapace ¶
type Carapace struct {
// contains filtered or unexported fields
}
Carapace wraps cobra.Command to define completions.
func (Carapace) DashAnyCompletion ¶ added in v0.13.0
DashAnyCompletion defines completion for any positional arguments after dash (`--`) not already defined.
func (Carapace) DashCompletion ¶ added in v0.13.0
DashCompletion defines completion for positional arguments after dash (`--`) using a list of Actions.
func (Carapace) FlagCompletion ¶
FlagCompletion defines completion for flags using a map consisting of name and Action.
func (Carapace) PositionalAnyCompletion ¶ added in v0.0.14
PositionalAnyCompletion defines completion for any positional arguments not already defined.
func (Carapace) PositionalCompletion ¶
PositionalCompletion defines completion for positional arguments using a list of Actions.
func (Carapace) PreInvoke ¶ added in v0.20.0
PreInvoke sets a function to alter actions before they are invoked.
func (Carapace) Standalone ¶ added in v0.0.14
func (c Carapace) Standalone()
Standalone prevents cobra defaults interfering with standalone mode (e.g. implicit help command).
type CompletionCallback ¶
CompletionCallback is executed during completion of associated flag or positional argument.
type Context ¶ added in v0.4.0
type Context struct { // Value contains the value currently being completed (or part of it during an ActionMultiParts). Value string // Args contains the positional arguments of current (sub)command (exclusive the one currently being completed). Args []string // Parts contains the splitted Value during an ActionMultiParts (exclusive the part currently being completed). Parts []string // Env contains environment variables for current context. Env []string // Dir contains the working directory for current context. Dir string // contains filtered or unexported fields }
Context provides information during completion.
func NewContext ¶ added in v0.30.0
NewContext creates a new context for given arguments.
func (Context) Command ¶ added in v0.20.0
Command returns the Cmd struct to execute the named program with the given arguments. Env and Dir are set using the Context. See exec.Command for most details.
func (Context) Envsubst ¶ added in v0.20.2
Envsubst replaces ${var} in the string based on environment variables in current context.
func (Context) Getenv ¶ added in v0.20.2
Getenv retrieves the value of the environment variable named by the key.
type InvokedAction ¶ added in v0.1.1
type InvokedAction struct {
Action
}
InvokedAction is a logical alias for an Action whose (nested) callback was invoked.
func (InvokedAction) Filter ¶ added in v0.1.1
func (a InvokedAction) Filter(values ...string) InvokedAction
Filter filters given values.
a := carapace.ActionValues("A", "B", "C").Invoke(c) b := a.Filter([]string{"B"}) // ["A", "C"]
func (InvokedAction) Merge ¶ added in v0.1.8
func (a InvokedAction) Merge(others ...InvokedAction) InvokedAction
Merge merges InvokedActions (existing values are overwritten)
a := carapace.ActionValues("A", "B").Invoke(c) b := carapace.ActionValues("B", "C").Invoke(c) c := a.Merge(b) // ["A", "B", "C"]
func (InvokedAction) Prefix ¶ added in v0.1.1
func (a InvokedAction) Prefix(prefix string) InvokedAction
Prefix adds a prefix to values (only the ones inserted, not the display values)
carapace.ActionValues("melon", "drop", "fall").Invoke(c).Prefix("water")
func (InvokedAction) Retain ¶ added in v0.38.3
func (a InvokedAction) Retain(values ...string) InvokedAction
Retain retains given values.
a := carapace.ActionValues("A", "B", "C").Invoke(c) b := a.Retain([]string{"A", "C"}) // ["A", "C"]
func (InvokedAction) Suffix ¶ added in v0.1.1
func (a InvokedAction) Suffix(suffix string) InvokedAction
Suffix adds a suffx to values (only the ones inserted, not the display values)
carapace.ActionValues("apple", "melon", "orange").Invoke(c).Suffix("juice")
func (InvokedAction) ToA ¶ added in v0.1.1
func (a InvokedAction) ToA() Action
ToA casts an InvokedAction to Action.
func (InvokedAction) ToMultiPartsA ¶ added in v0.2.2
func (a InvokedAction) ToMultiPartsA(dividers ...string) Action
ToMultiPartsA create an ActionMultiParts from values with given dividers
a := carapace.ActionValues("A/B/C", "A/C", "B/C", "C").Invoke(c) b := a.ToMultiPartsA("/") // completes segments separately (first one is ["A/", "B/", "C"])
Source Files ¶
Directories ¶
Path | Synopsis |
---|---|
example-nonposix
module
|
|
internal
|
|
assert
Package assert provides test helpers
|
Package assert provides test helpers |
cache
Package cache provides disk cache for Actions
|
Package cache provides disk cache for Actions |
common
Package common code
|
Package common code |
shell/bash
Package bash provides bash completion
|
Package bash provides bash completion |
shell/bash_ble
Package bash_ble provides bash-ble completion
|
Package bash_ble provides bash-ble completion |
shell/elvish
Package elvish provides elvish completion
|
Package elvish provides elvish completion |
shell/export
Package export provides command structure export
|
Package export provides command structure export |
shell/fish
Package fish provides fish completion
|
Package fish provides fish completion |
shell/ion
Package ion provides Ion completion
|
Package ion provides Ion completion |
shell/nushell
Package nushell provides Nushell completion
|
Package nushell provides Nushell completion |
shell/oil
Package oil provides Oil completion
|
Package oil provides Oil completion |
shell/powershell
Package powershell provides powershell completion
|
Package powershell provides powershell completion |
shell/spec
Package spec provides spec file generation for use with carapace-bin
|
Package spec provides spec file generation for use with carapace-bin |
shell/tcsh
Package tcsh provides tcsh completion
|
Package tcsh provides tcsh completion |
shell/xonsh
Package xonsh provides Xonsh completion
|
Package xonsh provides Xonsh completion |
shell/zsh
Package zsh provides zsh completion
|
Package zsh provides zsh completion |
uid
Package uid provides unique identifiers
|
Package uid provides unique identifiers |
pkg
|
|
cache
Package cache provides cache keys
|
Package cache provides cache keys |
ps
Package ps provides shell determination by process name
|
Package ps provides shell determination by process name |
style
Package style provide display coloring
|
Package style provide display coloring |
third_party
|
|
github.com/elves/elvish/pkg/cli/lscolors
Package lscolors provides styling of filenames based on file features.
|
Package lscolors provides styling of filenames based on file features. |
github.com/hexops/gotextdiff
package gotextdiff supports a pluggable diff algorithm.
|
package gotextdiff supports a pluggable diff algorithm. |
github.com/hexops/gotextdiff/myers
Package myers implements the Myers diff algorithm.
|
Package myers implements the Myers diff algorithm. |
github.com/hexops/gotextdiff/span
Package span contains support for representing with positions and ranges in text files.
|
Package span contains support for representing with positions and ranges in text files. |
github.com/mitchellh/go-ps
ps provides an API for finding and listing processes in a platform-agnostic way.
|
ps provides an API for finding and listing processes in a platform-agnostic way. |
golang.org/x/sys/execabs
Package execabs is a drop-in replacement for os/exec that requires PATH lookups to find absolute paths.
|
Package execabs is a drop-in replacement for os/exec that requires PATH lookups to find absolute paths. |