mirror of
				https://github.com/ohmyzsh/ohmyzsh.git
				synced 2024-05-11 05:55:17 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			527 lines
		
	
	
		
			16 KiB
		
	
	
	
		
			Bash
		
	
	
	
	
	
			
		
		
	
	
			527 lines
		
	
	
		
			16 KiB
		
	
	
	
		
			Bash
		
	
	
	
	
	
| _git-flow ()
 | |
| {
 | |
|     local curcontext="$curcontext" state line
 | |
|     typeset -A opt_args
 | |
| 
 | |
|     _arguments -C \
 | |
|         ':command:->command' \
 | |
|         '*::options:->options'
 | |
| 
 | |
|     case $state in
 | |
|         (command)
 | |
| 
 | |
|             local -a subcommands
 | |
|             subcommands=(
 | |
|                 'init:Initialize a new git repo with support for the branching model.'
 | |
|                 'feature:Manage your feature branches.'
 | |
|                 'bugfix:Manage your bugfix branches.'
 | |
|                 'config:Manage your configuration.'
 | |
|                 'release:Manage your release branches.'
 | |
|                 'hotfix:Manage your hotfix branches.'
 | |
|                 'support:Manage your support branches.'
 | |
|                 'version:Shows version information.'
 | |
|                 'finish:Finish the branch you are currently on.'
 | |
|                 'delete:Delete the branch you are currently on.'
 | |
|                 'publish:Publish the branch you are currently on.'
 | |
|                 'rebase:Rebase the branch you are currently on.'
 | |
|             )
 | |
|             _describe -t commands 'git flow' subcommands
 | |
|         ;;
 | |
| 
 | |
|         (options)
 | |
|             case $line[1] in
 | |
| 
 | |
|                 (init)
 | |
|                     _arguments \
 | |
|                         -f'[Force setting of gitflow branches, even if already configured]'
 | |
|                     ;;
 | |
| 
 | |
|                     (version)
 | |
|                     ;;
 | |
| 
 | |
|                     (hotfix)
 | |
|                         __git-flow-hotfix
 | |
|                     ;;
 | |
| 
 | |
|                     (release)
 | |
|                         __git-flow-release
 | |
|                     ;;
 | |
| 
 | |
|                     (feature)
 | |
|                         __git-flow-feature
 | |
|                     ;;
 | |
|                     (bugfix)
 | |
|                         __git-flow-bugfix
 | |
|                     ;;
 | |
| 
 | |
|                     (config)
 | |
|                     __git-flow-config
 | |
|                     ;;
 | |
| 
 | |
|             esac
 | |
|         ;;
 | |
|     esac
 | |
| }
 | |
| 
 | |
| __git-flow-release ()
 | |
| {
 | |
|     local curcontext="$curcontext" state line
 | |
|     typeset -A opt_args
 | |
| 
 | |
|     _arguments -C \
 | |
|         ':command:->command' \
 | |
|         '*::options:->options'
 | |
| 
 | |
|     case $state in
 | |
|         (command)
 | |
| 
 | |
|             local -a subcommands
 | |
|             subcommands=(
 | |
|                 'start:Start a new release branch.'
 | |
|                 'finish:Finish a release branch.'
 | |
|                 'list:List all your release branches. (Alias to `git flow release`)'
 | |
|                 'publish:Publish release branch to remote.'
 | |
|                 'track:Checkout remote release branch.'
 | |
|                 'rebase:Rebase from integration branch.'
 | |
|                 'delete:Delete a release branch.'
 | |
|             )
 | |
|             _describe -t commands 'git flow release' subcommands
 | |
|             _arguments \
 | |
|                 -v'[Verbose (more) output]'
 | |
|         ;;
 | |
| 
 | |
|         (options)
 | |
|             case $line[1] in
 | |
| 
 | |
|                 (start)
 | |
|                     _arguments \
 | |
|                         -F'[Fetch from origin before performing finish]'\
 | |
|                         ':version:__git_flow_version_list'
 | |
|                 ;;
 | |
| 
 | |
|                 (finish)
 | |
|                     _arguments \
 | |
|                         -F'[Fetch from origin before performing finish]' \
 | |
|                         -s'[Sign the release tag cryptographically]'\
 | |
|                         -u'[Use the given GPG-key for the digital signature (implies -s)]'\
 | |
|                         -m'[Use the given tag message]'\
 | |
|                         -p'[Push to $ORIGIN after performing finish]'\
 | |
|                         ':version:__git_flow_version_list'
 | |
|                 ;;
 | |
| 
 | |
|                 (delete)
 | |
|                     _arguments \
 | |
|                         -f'[Force deletion]' \
 | |
|                         -r'[Delete remote branch]' \
 | |
|                         ':version:__git_flow_version_list'
 | |
|                 ;;
 | |
| 
 | |
|                 (publish)
 | |
|                     _arguments \
 | |
|                         ':version:__git_flow_version_list'
 | |
|                 ;;
 | |
| 
 | |
|                 (track)
 | |
|                     _arguments \
 | |
|                         ':version:__git_flow_version_list'
 | |
|                 ;;
 | |
| 
 | |
|                 (rebase)
 | |
|                     _arguments \
 | |
|                         -i'[Do an interactive rebase]' \
 | |
|                         ':branch:__git_branch_names'
 | |
|                 ;;
 | |
| 
 | |
|                 *)
 | |
|                     _arguments \
 | |
|                         -v'[Verbose (more) output]'
 | |
|                 ;;
 | |
|             esac
 | |
|         ;;
 | |
|     esac
 | |
| }
 | |
| 
 | |
| __git-flow-hotfix ()
 | |
| {
 | |
|     local curcontext="$curcontext" state line
 | |
|     typeset -A opt_args
 | |
| 
 | |
|     _arguments -C \
 | |
|         ':command:->command' \
 | |
|         '*::options:->options'
 | |
| 
 | |
|     case $state in
 | |
|         (command)
 | |
| 
 | |
|             local -a subcommands
 | |
|             subcommands=(
 | |
|                 'start:Start a new hotfix branch.'
 | |
|                 'finish:Finish a hotfix branch.'
 | |
|                 'delete:Delete a hotfix branch.'
 | |
|                 'rebase:Rebase from integration branch.'
 | |
|                 'list:List all your hotfix branches. (Alias to `git flow hotfix`)'
 | |
|                 'rename:Rename a hotfix branch.'
 | |
|             )
 | |
|             _describe -t commands 'git flow hotfix' subcommands
 | |
|             _arguments \
 | |
|                 -v'[Verbose (more) output]'
 | |
|         ;;
 | |
| 
 | |
|         (options)
 | |
|             case $line[1] in
 | |
| 
 | |
|                 (start)
 | |
|                     _arguments \
 | |
|                         -F'[Fetch from origin before performing finish]'\
 | |
|                         ':hotfix:__git_flow_version_list'\
 | |
|                         ':branch-name:__git_branch_names'
 | |
|                 ;;
 | |
| 
 | |
|                 (finish)
 | |
|                     _arguments \
 | |
|                         -F'[Fetch from origin before performing finish]' \
 | |
|                         -s'[Sign the release tag cryptographically]'\
 | |
|                         -u'[Use the given GPG-key for the digital signature (implies -s)]'\
 | |
|                         -m'[Use the given tag message]'\
 | |
|                         -p'[Push to $ORIGIN after performing finish]'\
 | |
|                         ':hotfix:__git_flow_hotfix_list'
 | |
|                 ;;
 | |
| 
 | |
|                 (delete)
 | |
|                     _arguments \
 | |
|                         -f'[Force deletion]' \
 | |
|                         -r'[Delete remote branch]' \
 | |
|                         ':hotfix:__git_flow_hotfix_list'
 | |
|                 ;;
 | |
| 
 | |
|                 (rebase)
 | |
|                     _arguments \
 | |
|                         -i'[Do an interactive rebase]' \
 | |
|                         ':branch:__git_branch_names'
 | |
|                 ;;
 | |
| 
 | |
|                 *)
 | |
|                     _arguments \
 | |
|                         -v'[Verbose (more) output]'
 | |
|                 ;;
 | |
|             esac
 | |
|         ;;
 | |
|     esac
 | |
| }
 | |
| 
 | |
| __git-flow-feature ()
 | |
| {
 | |
|     local curcontext="$curcontext" state line
 | |
|     typeset -A opt_args
 | |
| 
 | |
|     _arguments -C \
 | |
|         ':command:->command' \
 | |
|         '*::options:->options'
 | |
| 
 | |
|     case $state in
 | |
|         (command)
 | |
| 
 | |
|             local -a subcommands
 | |
|             subcommands=(
 | |
|                 'start:Start a new feature branch.'
 | |
|                 'finish:Finish a feature branch.'
 | |
|                 'delete:Delete a feature branch.'
 | |
|                 'list:List all your feature branches. (Alias to `git flow feature`)'
 | |
|                 'publish:Publish feature branch to remote.'
 | |
|                 'track:Checkout remote feature branch.'
 | |
|                 'diff:Show all changes.'
 | |
|                 'rebase:Rebase from integration branch.'
 | |
|                 'checkout:Checkout local feature branch.'
 | |
|                 'pull:Pull changes from remote.'
 | |
|                 'rename:Rename a feature branch.'
 | |
|             )
 | |
|             _describe -t commands 'git flow feature' subcommands
 | |
|             _arguments \
 | |
|                 -v'[Verbose (more) output]'
 | |
|         ;;
 | |
| 
 | |
|         (options)
 | |
|             case $line[1] in
 | |
| 
 | |
|                 (start)
 | |
|                     _arguments \
 | |
|                         -F'[Fetch from origin before performing finish]'\
 | |
|                         ':feature:__git_flow_feature_list'\
 | |
|                         ':branch-name:__git_branch_names'
 | |
|                 ;;
 | |
| 
 | |
|                 (finish)
 | |
|                     _arguments \
 | |
|                         -F'[Fetch from origin before performing finish]' \
 | |
|                         -r'[Rebase instead of merge]'\
 | |
|                         ':feature:__git_flow_feature_list'
 | |
|                 ;;
 | |
| 
 | |
|                 (delete)
 | |
|                     _arguments \
 | |
|                         -f'[Force deletion]' \
 | |
|                         -r'[Delete remote branch]' \
 | |
|                         ':feature:__git_flow_feature_list'
 | |
|                 ;;
 | |
| 
 | |
|                 (publish)
 | |
|                     _arguments \
 | |
|                         ':feature:__git_flow_feature_list'\
 | |
|                 ;;
 | |
| 
 | |
|                 (track)
 | |
|                     _arguments \
 | |
|                         ':feature:__git_flow_feature_list'\
 | |
|                 ;;
 | |
| 
 | |
|                 (diff)
 | |
|                     _arguments \
 | |
|                         ':branch:__git_branch_names'\
 | |
|                 ;;
 | |
| 
 | |
|                 (rebase)
 | |
|                     _arguments \
 | |
|                         -i'[Do an interactive rebase]' \
 | |
|                         ':branch:__git_branch_names'
 | |
|                 ;;
 | |
| 
 | |
|                 (checkout)
 | |
|                     _arguments \
 | |
|                         ':branch:__git_flow_feature_list'\
 | |
|                 ;;
 | |
| 
 | |
|                 (pull)
 | |
|                     _arguments \
 | |
|                         ':remote:__git_remotes'\
 | |
|                         ':branch:__git_branch_names'
 | |
|                 ;;
 | |
| 
 | |
|                 *)
 | |
|                     _arguments \
 | |
|                         -v'[Verbose (more) output]'
 | |
|                 ;;
 | |
|             esac
 | |
|         ;;
 | |
|     esac
 | |
| }
 | |
| 
 | |
| __git-flow-bugfix ()
 | |
| {
 | |
|     local curcontext="$curcontext" state line
 | |
|     typeset -A opt_args
 | |
| 
 | |
|     _arguments -C \
 | |
|         ':command:->command' \
 | |
|         '*::options:->options'
 | |
| 
 | |
|     case $state in
 | |
|         (command)
 | |
| 
 | |
|             local -a subcommands
 | |
|             subcommands=(
 | |
|                 'start:Start a new bugfix branch.'
 | |
|                 'finish:Finish a bugfix branch.'
 | |
|                 'delete:Delete a bugfix branch.'
 | |
|                 'list:List all your bugfix branches. (Alias to `git flow bugfix`)'
 | |
|                 'publish:Publish bugfix branch to remote.'
 | |
|                 'track:Checkout remote bugfix branch.'
 | |
|                 'diff:Show all changes.'
 | |
|                 'rebase:Rebase from integration branch.'
 | |
|                 'checkout:Checkout local bugfix branch.'
 | |
|                 'pull:Pull changes from remote.'
 | |
|                 'rename:Rename a bugfix branch.'
 | |
|             )
 | |
|             _describe -t commands 'git flow bugfix' subcommands
 | |
|             _arguments \
 | |
|                 -v'[Verbose (more) output]'
 | |
|         ;;
 | |
| 
 | |
|         (options)
 | |
|             case $line[1] in
 | |
| 
 | |
|                 (start)
 | |
|                     _arguments \
 | |
|                         -F'[Fetch from origin before performing finish]'\
 | |
|                         ':bugfix:__git_flow_bugfix_list'\
 | |
|                         ':branch-name:__git_branch_names'
 | |
|                 ;;
 | |
| 
 | |
|                 (finish)
 | |
|                     _arguments \
 | |
|                         -F'[Fetch from origin before performing finish]' \
 | |
|                         -r'[Rebase instead of merge]'\
 | |
|                         ':bugfix:__git_flow_bugfix_list'
 | |
|                 ;;
 | |
| 
 | |
|                 (delete)
 | |
|                     _arguments \
 | |
|                         -f'[Force deletion]' \
 | |
|                         -r'[Delete remote branch]' \
 | |
|                         ':bugfix:__git_flow_bugfix_list'
 | |
|                 ;;
 | |
| 
 | |
|                 (publish)
 | |
|                     _arguments \
 | |
|                         ':bugfix:__git_flow_bugfix_list'\
 | |
|                 ;;
 | |
| 
 | |
|                 (track)
 | |
|                     _arguments \
 | |
|                         ':bugfix:__git_flow_bugfix_list'\
 | |
|                 ;;
 | |
| 
 | |
|                 (diff)
 | |
|                     _arguments \
 | |
|                         ':branch:__git_branch_names'\
 | |
|                 ;;
 | |
| 
 | |
|                 (rebase)
 | |
|                     _arguments \
 | |
|                         -i'[Do an interactive rebase]' \
 | |
|                         ':branch:__git_branch_names'
 | |
|                 ;;
 | |
| 
 | |
|                 (checkout)
 | |
|                     _arguments \
 | |
|                         ':branch:__git_flow_bugfix_list'\
 | |
|                 ;;
 | |
| 
 | |
|                 (pull)
 | |
|                     _arguments \
 | |
|                         ':remote:__git_remotes'\
 | |
|                         ':branch:__git_branch_names'
 | |
|                 ;;
 | |
| 
 | |
|                 *)
 | |
|                     _arguments \
 | |
|                         -v'[Verbose (more) output]'
 | |
|                 ;;
 | |
|             esac
 | |
|         ;;
 | |
|     esac
 | |
| }
 | |
| 
 | |
| __git-flow-config ()
 | |
| {
 | |
|     local curcontext="$curcontext" state line
 | |
|     typeset -A opt_args
 | |
| 
 | |
|     _arguments -C \
 | |
|         ':command:->command' \
 | |
|         '*::options:->options'
 | |
| 
 | |
|     case $state in
 | |
|         (command)
 | |
| 
 | |
|             local -a subcommands
 | |
|             subcommands=(
 | |
|                 'list:List the configuration. (Alias to `git flow config`)'
 | |
|                 'set:Set the configuration option'
 | |
|             )
 | |
|             _describe -t commands 'git flow config' subcommands
 | |
|         ;;
 | |
| 
 | |
|         (options)
 | |
|             case $line[1] in
 | |
| 
 | |
|                 (set)
 | |
|                     _arguments \
 | |
|                         --local'[Use repository config file]' \
 | |
|                         --global'[Use global config file]'\
 | |
|                         --system'[Use system config file]'\
 | |
|                         --file'[Use given config file]'\
 | |
|                         ':option:(master develop feature hotfix release support versiontagprefix)'
 | |
|                 ;;
 | |
| 
 | |
|                 *)
 | |
|                     _arguments \
 | |
|                         --local'[Use repository config file]' \
 | |
|                         --global'[Use global config file]'\
 | |
|                         --system'[Use system config file]'\
 | |
|                         --file'[Use given config file]'
 | |
|                 ;;
 | |
|             esac
 | |
|         ;;
 | |
|     esac
 | |
| }
 | |
| __git_flow_version_list ()
 | |
| {
 | |
|     local expl
 | |
|     declare -a versions
 | |
| 
 | |
|     versions=(${${(f)"$(_call_program versions git flow release list 2> /dev/null | tr -d ' |*')"}})
 | |
|     __git_command_successful || return
 | |
| 
 | |
|     _wanted versions expl 'version' compadd $versions
 | |
| }
 | |
| 
 | |
| __git_flow_feature_list ()
 | |
| {
 | |
|     local expl
 | |
|     declare -a features
 | |
| 
 | |
|     features=(${${(f)"$(_call_program features git flow feature list 2> /dev/null | tr -d ' |*')"}})
 | |
|     __git_command_successful || return
 | |
| 
 | |
|     _wanted features expl 'feature' compadd $features
 | |
| }
 | |
| 
 | |
| __git_flow_bugfix_list ()
 | |
| {
 | |
|     local expl
 | |
|     declare -a bugfixes
 | |
| 
 | |
|     bugfixes=(${${(f)"$(_call_program bugfixes git flow bugfix list 2> /dev/null | tr -d ' |*')"}})
 | |
|     __git_command_successful || return
 | |
| 
 | |
|     _wanted bugfixes expl 'bugfix' compadd $bugfixes
 | |
| }
 | |
| 
 | |
| __git_remotes () {
 | |
|     local expl gitdir remotes
 | |
| 
 | |
|     gitdir=$(_call_program gitdir git rev-parse --git-dir 2>/dev/null)
 | |
|     __git_command_successful || return
 | |
| 
 | |
|     remotes=(${${(f)"$(_call_program remotes git config --get-regexp '"^remote\..*\.url$"')"}//#(#b)remote.(*).url */$match[1]})
 | |
|     __git_command_successful || return
 | |
| 
 | |
|     # TODO: Should combine the two instead of either or.
 | |
|     if (( $#remotes > 0 )); then
 | |
|         _wanted remotes expl remote compadd $* - $remotes
 | |
|     else
 | |
|         _wanted remotes expl remote _files $* - -W "($gitdir/remotes)" -g "$gitdir/remotes/*"
 | |
|     fi
 | |
| }
 | |
| 
 | |
| __git_flow_hotfix_list ()
 | |
| {
 | |
|     local expl
 | |
|     declare -a hotfixes
 | |
| 
 | |
|     hotfixes=(${${(f)"$(_call_program hotfixes git flow hotfix list 2> /dev/null | tr -d ' |*')"}})
 | |
|     __git_command_successful || return
 | |
| 
 | |
|     _wanted hotfixes expl 'hotfix' compadd $hotfixes
 | |
| }
 | |
| 
 | |
| __git_branch_names () {
 | |
|     local expl
 | |
|     declare -a branch_names
 | |
| 
 | |
|     branch_names=(${${(f)"$(_call_program branchrefs git for-each-ref --format='"%(refname)"' refs/heads 2>/dev/null)"}#refs/heads/})
 | |
|     __git_command_successful || return
 | |
| 
 | |
|     _wanted branch-names expl branch-name compadd $* - $branch_names
 | |
| }
 | |
| 
 | |
| __git_command_successful () {
 | |
|     if (( ${#pipestatus:#0} > 0 )); then
 | |
|         _message 'not a git repository'
 | |
|         return 1
 | |
|     fi
 | |
|     return 0
 | |
| }
 | |
| 
 | |
| zstyle ':completion:*:*:git:*' user-commands flow:'provide high-level repository operations'
 |