commands/completion/completion.go (100 lines of code) (raw):

package completion import ( "fmt" "github.com/MakeNowJust/heredoc/v2" "gitlab.com/gitlab-org/cli/pkg/iostreams" "github.com/spf13/cobra" ) func NewCmdCompletion(io *iostreams.IOStreams) *cobra.Command { var ( shellType string // description will not be added if true excludeDesc = false ) completionCmd := &cobra.Command{ Use: "completion", Short: "Generate shell completion scripts.", Long: heredoc.Docf(` This command outputs code meant to be saved to a file, or immediately evaluated by an interactive shell. To load completions: ### Bash To load completions in your current shell session: %[2]sshell source <(glab completion -s bash) %[2]s To load completions for every new session, run this command one time: #### Linux %[2]sshell glab completion -s bash > /etc/bash_completion.d/glab %[2]s #### macOS %[2]sshell glab completion -s bash > /usr/local/etc/bash_completion.d/glab %[2]s ### Zsh If shell completion is not already enabled in your environment you must enable it. Run this command one time: %[2]sshell echo "autoload -U compinit; compinit" >> ~/.zshrc %[2]s To load completions in your current shell session: %[2]sshell source <(glab completion -s zsh); compdef _glab glab %[2]s To load completions for every new session, run this command one time: #### Linux %[2]sshell glab completion -s zsh > "${fpath[1]}/_glab" %[2]s #### macOS For older versions of macOS, you might need this command: %[2]sshell glab completion -s zsh > /usr/local/share/zsh/site-functions/_glab %[2]s The Homebrew version of glab should install completions automatically. ### fish To load completions in your current shell session: %[2]sshell glab completion -s fish | source %[2]s To load completions for every new session, run this command one time: %[2]sshell glab completion -s fish > ~/.config/fish/completions/glab.fish %[2]s ### PowerShell To load completions in your current shell session: %[2]sshell glab completion -s powershell | Out-String | Invoke-Expression %[2]s To load completions for every new session, add the output of the above command to your PowerShell profile. When installing glab through a package manager, however, you might not need more shell configuration to support completions. For Homebrew, see [brew shell completion](https://docs.brew.sh/Shell-Completion) `, "`", "```"), RunE: func(cmd *cobra.Command, args []string) error { out := io.StdOut rootCmd := cmd.Parent() switch shellType { case "bash": return rootCmd.GenBashCompletionV2(out, !excludeDesc) case "zsh": if excludeDesc { return rootCmd.GenZshCompletionNoDesc(out) } return rootCmd.GenZshCompletion(out) case "powershell": if excludeDesc { return rootCmd.GenPowerShellCompletion(out) } return rootCmd.GenPowerShellCompletionWithDesc(out) case "fish": return rootCmd.GenFishCompletion(out, !excludeDesc) default: return fmt.Errorf("unsupported shell type %q", shellType) } }, } completionCmd.Flags().StringVarP(&shellType, "shell", "s", "bash", "Shell type: bash, zsh, fish, powershell.") completionCmd.Flags().BoolVarP(&excludeDesc, "no-desc", "", false, "Do not include shell completion description.") return completionCmd }