-
Notifications
You must be signed in to change notification settings - Fork 1.6k
/
completion.go
92 lines (78 loc) · 2.57 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
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
/*
Copyright 2019 The Skaffold Authors
Licensed under the Apache License, Version 2.0 (the "License");
you may not use this file except in compliance with the License.
You may obtain a copy of the License at
http://www.apache.org/licenses/LICENSE-2.0
Unless required by applicable law or agreed to in writing, software
distributed under the License is distributed on an "AS IS" BASIS,
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
See the License for the specific language governing permissions and
limitations under the License.
*/
package cmd
import (
"fmt"
"io"
"os"
"strings"
"github.com/spf13/cobra"
)
const (
longDescription = `
Outputs shell completion for the given shell (bash, fish or zsh)
This depends on the bash-completion binary. Example installation instructions:
OS X:
$ brew install bash-completion
$ source $(brew --prefix)/etc/bash_completion
$ skaffold completion bash > ~/.skaffold-completion # for bash users
$ skaffold completion fish > ~/.skaffold-completion # for fish users
$ skaffold completion zsh > ~/.skaffold-completion # for zsh users
$ source ~/.skaffold-completion
Ubuntu:
$ apt-get install bash-completion
$ source /etc/bash-completion
$ source <(skaffold completion bash) # for bash users
$ skaffold completion fish | source # for fish users
$ source <(skaffold completion zsh) # for zsh users
Additionally, you may want to output the completion to a file and source in your .bashrc
`
zshCompdef = "\ncompdef _skaffold skaffold\n"
)
func completion(cmd *cobra.Command, args []string) {
switch args[0] {
case "bash":
rootCmd(cmd).GenBashCompletion(os.Stdout)
case "fish":
rootCmd(cmd).GenFishCompletion(os.Stdout, true)
case "zsh":
runCompletionZsh(cmd, os.Stdout)
}
}
// NewCmdCompletion returns the cobra command that outputs shell completion code
func NewCmdCompletion() *cobra.Command {
return &cobra.Command{
Use: "completion SHELL",
Args: func(cmd *cobra.Command, args []string) error {
if len(args) != 1 {
return fmt.Errorf("missing shell: %s", strings.Join(cmd.ValidArgs, ", "))
}
return cobra.OnlyValidArgs(cmd, args)
},
ValidArgs: []string{"bash", "fish", "zsh"},
Short: "Output shell completion for the given shell (bash, fish or zsh)",
Long: longDescription,
Run: completion,
}
}
func runCompletionZsh(cmd *cobra.Command, out io.Writer) {
rootCmd(cmd).GenZshCompletion(out)
io.WriteString(out, zshCompdef)
}
func rootCmd(cmd *cobra.Command) *cobra.Command {
parent := cmd
for parent.HasParent() {
parent = parent.Parent()
}
return parent
}