/
completion.go
66 lines (50 loc) · 1.64 KB
/
completion.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
package cmd
import "github.com/spf13/cobra"
type completionCmd struct {
cmd *cobra.Command
}
func newCompletionCmd() *completionCmd {
var root = &completionCmd{}
var cmd = &cobra.Command{
Use: "completion [bash|zsh|fish]",
Short: "Print shell autocompletion scripts for goreleaser",
Long: `To load completions:
Bash:
$ source <(goreleaser completion bash)
# To load completions for each session, execute once:
Linux:
$ goreleaser completion bash > /etc/bash_completion.d/goreleaser
MacOS:
$ goreleaser completion bash > /usr/local/etc/bash_completion.d/goreleaser
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:
$ goreleaser completion zsh > "${fpath[1]}/_goreleaser"
# You will need to start a new shell for this setup to take effect.
Fish:
$ goreleaser completion fish | source
# To load completions for each session, execute once:
$ goreleaser completion fish > ~/.config/fish/completions/goreleaser.fish
`,
SilenceUsage: true,
DisableFlagsInUseLine: true,
ValidArgs: []string{"bash", "zsh", "fish"},
Args: cobra.ExactValidArgs(1),
RunE: func(cmd *cobra.Command, args []string) error {
var err error
switch args[0] {
case "bash":
err = cmd.Root().GenBashCompletion(cmd.OutOrStdout())
case "zsh":
err = cmd.Root().GenZshCompletion(cmd.OutOrStdout())
case "fish":
err = cmd.Root().GenFishCompletion(cmd.OutOrStdout(), true)
}
return err
},
}
root.cmd = cmd
return root
}