mirror of
				https://github.com/tailscale/tailscale.git
				synced 2025-10-25 18:20:07 +00:00 
			
		
		
		
	
		
			
	
	
		
			140 lines
		
	
	
		
			4.7 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
		
		
			
		
	
	
			140 lines
		
	
	
		
			4.7 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
|   | // Copyright 2013-2023 The Cobra 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 cobra contains shell scripts and constants copied from | ||
|  | // https://github.com/spf13/cobra for use in our own shell tab-completion logic. | ||
|  | package cobra | ||
|  | 
 | ||
|  | import ( | ||
|  | 	"fmt" | ||
|  | 	"strings" | ||
|  | ) | ||
|  | 
 | ||
|  | // ShellCompDirective is a bit map representing the different behaviors the shell | ||
|  | // can be instructed to have once completions have been provided. | ||
|  | type ShellCompDirective int | ||
|  | 
 | ||
|  | const ( | ||
|  | 	// ShellCompDirectiveError indicates an error occurred and completions should be ignored. | ||
|  | 	ShellCompDirectiveError ShellCompDirective = 1 << iota | ||
|  | 
 | ||
|  | 	// ShellCompDirectiveNoSpace indicates that the shell should not add a space | ||
|  | 	// after the completion even if there is a single completion provided. | ||
|  | 	ShellCompDirectiveNoSpace | ||
|  | 
 | ||
|  | 	// ShellCompDirectiveNoFileComp indicates that the shell should not provide | ||
|  | 	// file completion even when no completion is provided. | ||
|  | 	ShellCompDirectiveNoFileComp | ||
|  | 
 | ||
|  | 	// ShellCompDirectiveFilterFileExt indicates that the provided completions | ||
|  | 	// should be used as file extension filters. | ||
|  | 	ShellCompDirectiveFilterFileExt | ||
|  | 
 | ||
|  | 	// ShellCompDirectiveFilterDirs indicates that only directory names should | ||
|  | 	// be provided in file completion.  To request directory names within another | ||
|  | 	// directory, the returned completions should specify the directory within | ||
|  | 	// which to search. | ||
|  | 	ShellCompDirectiveFilterDirs | ||
|  | 
 | ||
|  | 	// ShellCompDirectiveKeepOrder indicates that the shell should preserve the order | ||
|  | 	// in which the completions are provided | ||
|  | 	ShellCompDirectiveKeepOrder | ||
|  | 
 | ||
|  | 	// =========================================================================== | ||
|  | 
 | ||
|  | 	// All directives using iota should be above this one. | ||
|  | 	// For internal use. | ||
|  | 	shellCompDirectiveMaxValue | ||
|  | 
 | ||
|  | 	// ShellCompDirectiveDefault indicates to let the shell perform its default | ||
|  | 	// behavior after completions have been provided. | ||
|  | 	// This one must be last to avoid messing up the iota count. | ||
|  | 	ShellCompDirectiveDefault ShellCompDirective = 0 | ||
|  | ) | ||
|  | 
 | ||
|  | // Returns a string listing the different directive enabled in the specified parameter | ||
|  | func (d ShellCompDirective) String() string { | ||
|  | 	var directives []string | ||
|  | 	if d&ShellCompDirectiveError != 0 { | ||
|  | 		directives = append(directives, "ShellCompDirectiveError") | ||
|  | 	} | ||
|  | 	if d&ShellCompDirectiveNoSpace != 0 { | ||
|  | 		directives = append(directives, "ShellCompDirectiveNoSpace") | ||
|  | 	} | ||
|  | 	if d&ShellCompDirectiveNoFileComp != 0 { | ||
|  | 		directives = append(directives, "ShellCompDirectiveNoFileComp") | ||
|  | 	} | ||
|  | 	if d&ShellCompDirectiveFilterFileExt != 0 { | ||
|  | 		directives = append(directives, "ShellCompDirectiveFilterFileExt") | ||
|  | 	} | ||
|  | 	if d&ShellCompDirectiveFilterDirs != 0 { | ||
|  | 		directives = append(directives, "ShellCompDirectiveFilterDirs") | ||
|  | 	} | ||
|  | 	if d&ShellCompDirectiveKeepOrder != 0 { | ||
|  | 		directives = append(directives, "ShellCompDirectiveKeepOrder") | ||
|  | 	} | ||
|  | 	if len(directives) == 0 { | ||
|  | 		directives = append(directives, "ShellCompDirectiveDefault") | ||
|  | 	} | ||
|  | 
 | ||
|  | 	if d >= shellCompDirectiveMaxValue { | ||
|  | 		return fmt.Sprintf("ERROR: unexpected ShellCompDirective value: %d", d) | ||
|  | 	} | ||
|  | 	return strings.Join(directives, " | ") | ||
|  | } | ||
|  | 
 | ||
|  | const UsageTemplate = `To load completions: | ||
|  | 
 | ||
|  | Bash: | ||
|  | 
 | ||
|  | 	$ source <(%[1]s completion bash) | ||
|  | 
 | ||
|  | 	# To load completions for each session, execute once: | ||
|  | 	# Linux: | ||
|  | 	$ %[1]s completion bash > /etc/bash_completion.d/%[1]s | ||
|  | 	# macOS: | ||
|  | 	$ %[1]s completion bash > $(brew --prefix)/etc/bash_completion.d/%[1]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: | ||
|  | 	$ %[1]s completion zsh > "${fpath[1]}/_%[1]s" | ||
|  | 
 | ||
|  | 	# You will need to start a new shell for this setup to take effect. | ||
|  | 
 | ||
|  | fish: | ||
|  | 
 | ||
|  | 	$ %[1]s completion fish | source | ||
|  | 
 | ||
|  | 	# To load completions for each session, execute once: | ||
|  | 	$ %[1]s completion fish > ~/.config/fish/completions/%[1]s.fish | ||
|  | 
 | ||
|  | PowerShell: | ||
|  | 
 | ||
|  | 	PS> %[1]s completion powershell | Out-String | Invoke-Expression | ||
|  | 
 | ||
|  | 	# To load completions for every new session, run: | ||
|  | 	PS> %[1]s completion powershell > %[1]s.ps1 | ||
|  | 	# and source this file from your PowerShell profile. | ||
|  | 
 | ||
|  | The shell scripts and this help message have been adapted from the | ||
|  | Cobra project (https://cobra.dev, https://github.com/spf13/cobra) | ||
|  | under the Apache-2.0 license. Thank you for making these available. | ||
|  | ` |