mirror of
				git://git.code.sf.net/p/zsh/code
				synced 2025-10-26 16:40:29 +01:00 
			
		
		
		
	37062: tentative mechanism for git commit descriptions.
Mechanism for forcing completion system into verbose mode is subject to change.
This commit is contained in:
		
							parent
							
								
									9642aeeaeb
								
							
						
					
					
						commit
						20153c573e
					
				
					 2 changed files with 39 additions and 9 deletions
				
			
		|  | @ -1,3 +1,9 @@ | ||||||
|  | 2015-11-04  Peter Stephenson  <p.stephenson@samsung.com> | ||||||
|  | 
 | ||||||
|  | 	* 37062: Completion/Unix/Command/_git: allow verbose | ||||||
|  | 	descriptions of commits and branches using git log.  Mechanism | ||||||
|  | 	for turning this on subject to change. | ||||||
|  | 
 | ||||||
| 2015-11-02  Daniel Hahler  <zsh@thequod.de> | 2015-11-02  Daniel Hahler  <zsh@thequod.de> | ||||||
| 
 | 
 | ||||||
| 	* 35303: Completion/Unix/Command/_systemd: remove it in favour of the | 	* 35303: Completion/Unix/Command/_systemd: remove it in favour of the | ||||||
|  |  | ||||||
|  | @ -5004,6 +5004,33 @@ __git_is_in_middle_of_merge () { | ||||||
|   [[ -f $gitdir/MERGE_HEAD ]] |   [[ -f $gitdir/MERGE_HEAD ]] | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | (( $+functions[__git_describe_branch] )) || | ||||||
|  | __git_describe_branch () { | ||||||
|  |   local __commits_in=$1 | ||||||
|  |   local __tag=$2 | ||||||
|  |   local __desc=$3 | ||||||
|  |   shift 3 | ||||||
|  | 
 | ||||||
|  |   integer maxverbose | ||||||
|  |   if zstyle -s :completion:$curcontext max-verbose maxverbose && | ||||||
|  |     (( ${compstate[nmatches]} <= maxverbose )); then | ||||||
|  |     local __c | ||||||
|  |     local -a __commits | ||||||
|  |     for __c in ${(P)__commits_in}; do | ||||||
|  |       __commits+=("${__c}:${$(_call_program describe git log -1 --oneline $__c)//:/\\:}") | ||||||
|  |     done | ||||||
|  |     _describe -t $__tag $__desc __commits "$@" | ||||||
|  |   else | ||||||
|  |     local expl | ||||||
|  |     _wanted $__tag expl $__desc compadd "$@" -a - $__commits_in | ||||||
|  |   fi | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | (( $+functions[__git_describe_commit] )) || | ||||||
|  | __git_describe_commit () { | ||||||
|  |   __git_describe_branch $1 $2 $3 -M 'r:|/=**' "${(@)argv[4,-1]}" | ||||||
|  | } | ||||||
|  | 
 | ||||||
| # Completion Wrappers | # Completion Wrappers | ||||||
| 
 | 
 | ||||||
| (( $+functions[__git_ignore_line] )) || | (( $+functions[__git_ignore_line] )) || | ||||||
|  | @ -5541,29 +5568,27 @@ __git_branch_names () { | ||||||
|   branch_names=(${${(f)"$(_call_program branchrefs git for-each-ref --format='"%(refname)"' refs/heads 2>/dev/null)"}#refs/heads/}) |   branch_names=(${${(f)"$(_call_program branchrefs git for-each-ref --format='"%(refname)"' refs/heads 2>/dev/null)"}#refs/heads/}) | ||||||
|   __git_command_successful $pipestatus || return 1 |   __git_command_successful $pipestatus || return 1 | ||||||
| 
 | 
 | ||||||
|   _wanted branch-names expl branch-name compadd -M 'r:|/=**' "$@" -a - branch_names |   __git_describe_commit branch_names branch-names 'branch name' "$@" | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| (( $+functions[__git_remote_branch_names] )) || | (( $+functions[__git_remote_branch_names] )) || | ||||||
| __git_remote_branch_names () { | __git_remote_branch_names () { | ||||||
|   local expl |  | ||||||
|   declare -a branch_names |   declare -a branch_names | ||||||
| 
 | 
 | ||||||
|   branch_names=(${${(f)"$(_call_program remote-branch-refs git for-each-ref --format='"%(refname)"' refs/remotes 2>/dev/null)"}#refs/remotes/}) |   branch_names=(${${(f)"$(_call_program remote-branch-refs git for-each-ref --format='"%(refname)"' refs/remotes 2>/dev/null)"}#refs/remotes/}) | ||||||
|   __git_command_successful $pipestatus || return 1 |   __git_command_successful $pipestatus || return 1 | ||||||
| 
 | 
 | ||||||
|   _wanted remote-branch-names expl 'remote branch name' compadd -M 'r:|/=**' "$@" -a - branch_names |   __git_describe_commit branch_names remote-branch-names 'remote branch name' "$@" | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| (( $+functions[__git_remote_branch_names_noprefix] )) || | (( $+functions[__git_remote_branch_names_noprefix] )) || | ||||||
| __git_remote_branch_names_noprefix () { | __git_remote_branch_names_noprefix () { | ||||||
|   local expl |  | ||||||
|   declare -a heads |   declare -a heads | ||||||
| 
 | 
 | ||||||
|   branch_names=(${${${${(f)"$(_call_program remote-branch-refs-noprefix git for-each-ref --format='"%(refname)"' refs/remotes 2>/dev/null)"}#refs/remotes/}#*/}:#HEAD}) |   branch_names=(${${${${(f)"$(_call_program remote-branch-refs-noprefix git for-each-ref --format='"%(refname)"' refs/remotes 2>/dev/null)"}#refs/remotes/}#*/}:#HEAD}) | ||||||
|   __git_command_successful $pipestatus || return 1 |   __git_command_successful $pipestatus || return 1 | ||||||
| 
 | 
 | ||||||
|   _wanted remote-branch-names-noprefix expl 'remote branch name' compadd -M 'r:|/=**' "$@" -a - branch_names |   __git_describe_commit branch_names remote-branch-names-noprefix 'remote branch name' "$@" | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| (( $+functions[__git_commit_objects_prefer_recent] )) || | (( $+functions[__git_commit_objects_prefer_recent] )) || | ||||||
|  | @ -5603,7 +5628,7 @@ __git_heads () { | ||||||
| 
 | 
 | ||||||
| (( $+functions[__git_heads_local] )) || | (( $+functions[__git_heads_local] )) || | ||||||
| __git_heads_local () { | __git_heads_local () { | ||||||
|   local gitdir expl start |   local gitdir | ||||||
|   declare -a heads |   declare -a heads | ||||||
| 
 | 
 | ||||||
|   heads=(${(f)"$(_call_program headrefs git for-each-ref --format='"%(refname:short)" refs/heads' 2>/dev/null)"}) |   heads=(${(f)"$(_call_program headrefs git for-each-ref --format='"%(refname:short)" refs/heads' 2>/dev/null)"}) | ||||||
|  | @ -5615,17 +5640,16 @@ __git_heads_local () { | ||||||
|     [[ -f $gitdir/refs/stash ]] && heads+=stash |     [[ -f $gitdir/refs/stash ]] && heads+=stash | ||||||
|   fi |   fi | ||||||
| 
 | 
 | ||||||
|   _wanted heads-local expl "local head" compadd -M 'r:|/=**' "$@" -a - heads |   __git_describe_commit heads heads-local "local head" "$@" | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| (( $+functions[__git_heads_remote] )) || | (( $+functions[__git_heads_remote] )) || | ||||||
| __git_heads_remote () { | __git_heads_remote () { | ||||||
|   local gitdir expl start |  | ||||||
|   declare -a heads |   declare -a heads | ||||||
| 
 | 
 | ||||||
|   heads=(${(f)"$(_call_program headrefs git for-each-ref --format='"%(refname:short)" refs/remotes' 2>/dev/null)"}) |   heads=(${(f)"$(_call_program headrefs git for-each-ref --format='"%(refname:short)" refs/remotes' 2>/dev/null)"}) | ||||||
| 
 | 
 | ||||||
|   _wanted heads-remote expl "remote head" compadd -M 'r:|/=**' "$@" -a - heads |   __git_describe_commit heads heads-remote "remote head" "$@" | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| (( $+functions[__git_commit_objects] )) || | (( $+functions[__git_commit_objects] )) || | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue