/
cmd.go
87 lines (67 loc) · 2.34 KB
/
cmd.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
/*
Copyright (c) 2019 Red Hat, Inc.
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 completion
import (
"fmt"
"os"
"github.com/spf13/cobra"
)
var Cmd = &cobra.Command{
Use: "completion [bash|zsh|fish|powershell]",
Short: "Generate completion scripts for various shells",
Long: `To load completions:
Bash:
$ source <(ocm completion bash)
# To load completions for each session, execute once:
Linux:
$ ocm completion bash > /etc/bash_completion.d/ocm
MacOS:
$ ocm completion bash > /usr/local/etc/bash_completion.d/ocm
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:
$ ocm completion zsh > "${fpath[1]}/_ocm"
# You will need to start a new shell for this setup to take effect.
Fish:
$ ocm completion fish | source
# To load completions for each session, execute once:
$ ocm completion fish > ~/.config/fish/completions/ocm.fish
P.S. Debugging completion logic:
- Set BASH_COMP_DEBUG_FILE env var to enable logging to that file.
- See https://github.com/spf13/cobra/blob/master/shell_completions.md.
`,
DisableFlagsInUseLine: true,
ValidArgs: []string{"bash", "zsh", "fish", "powershell"},
Args: cobra.RangeArgs(0, 1),
RunE: func(cmd *cobra.Command, args []string) error {
// backward compatibility (previously only supported bash, took no args)
if len(args) == 0 {
args = []string{"bash"}
}
switch args[0] {
case "bash":
cmd.Root().GenBashCompletion(os.Stdout)
case "zsh":
cmd.Root().GenZshCompletion(os.Stdout)
case "fish":
cmd.Root().GenFishCompletion(os.Stdout, true)
case "powershell":
cmd.Root().GenPowerShellCompletion(os.Stdout)
default:
return fmt.Errorf("invalid shell %q", args[0])
}
return nil
},
}