package autocomplete import ( "fmt" "github.com/spf13/cobra" ) const longHelpTemplate = `To load completions: Bash: $ source <(%s completion bash) To load completions for each session, execute once: Linux: $ %s completion bash > /etc/bash_completion.d/%s MacOS: $ %s completion bash > /usr/local/etc/bash_completion.d/%s Zsh: If shell completion is not already enabled in your environment you will need to enable it. You can execute the following once: $ echo "autoload -U compinit; compinit" >> ~/.zshrc To load completions for each session, execute once: $ %s completion zsh > "${fpath[1]}/_%s" You will need to start a new shell for this setup to take effect. Fish: $ %s completion fish | source To load completions for each session, execute once: $ %s completion fish > ~/.config/fish/completions/%s.fish ` // Command returns cobra command structure for autocomplete routine. func Command(name string) *cobra.Command { return &cobra.Command{ Use: "completion [bash|zsh|fish|powershell]", Short: "Generate completion script", Long: fmt.Sprintf(longHelpTemplate, name, name, name, name, name, name, name, name, name, name), DisableFlagsInUseLine: true, ValidArgs: []string{"bash", "zsh", "fish", "powershell"}, Args: cobra.MatchAll(cobra.ExactArgs(1), cobra.OnlyValidArgs), Run: func(cmd *cobra.Command, args []string) { switch args[0] { case "bash": _ = cmd.Root().GenBashCompletion(cmd.OutOrStdout()) case "zsh": _ = cmd.Root().GenZshCompletion(cmd.OutOrStdout()) case "fish": _ = cmd.Root().GenFishCompletion(cmd.OutOrStdout(), true) case "powershell": _ = cmd.Root().GenPowerShellCompletion(cmd.OutOrStdout()) } }, } }