Re: [PATCH] completion: Support the DWIM mode for git checkout

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



Hi,


On Thu, Oct 07, 2010 at 05:08:12PM -0700, Kevin Ballard wrote:
> Signed-off-by: Kevin Ballard <kevin@xxxxxx>
> ---

I think the commit message should add some details about how the patch
changes the completion script's behavior.  At least I didn't know
offhand what "DWIM mode for git checkout" is, and once I found it
(70c9ac2 (DWIM "git checkout frotz" to "git checkout -b frotz
origin/frotz", 2009-10-18), right?), I didn't know how the completion
script is supposed to support that, and once I applied the patch and
played around a bit, I was surprised that only 'git checkout h<tab>'
includes the 'html' branch but 'git checkout <tab>' don't.


>  contrib/completion/git-completion.bash |   35 +++++++++++++++++++++++++++++--
>  1 files changed, 32 insertions(+), 3 deletions(-)
> 
> diff --git a/contrib/completion/git-completion.bash b/contrib/completion/git-completion.bash
> index f83f019..be0498c 100755
> --- a/contrib/completion/git-completion.bash
> +++ b/contrib/completion/git-completion.bash


> @@ -988,7 +1007,17 @@ _git_checkout ()
>  			"
>  		;;
>  	*)
> -		__gitcomp "$(__git_refs)"
> +		# check if --track, --no-track, or --no-guess was specified
> +		# if so, disable DWIM mode
> +		local i c=1 track=1
> +		while [ $c -lt $COMP_CWORD ]; do
> +			i="${COMP_WORDS[c]}"
> +			case "$i" in
> +			--track|--no-track|--no-guess) track=''; break ;;
> +			esac
> +			c=$((++c))
> +		done
> +		__gitcomp "$(__git_refs '' $track)"

You could use the __git_find_on_cmdline() helper function instead.


Best,
Gábor

--
To unsubscribe from this list: send the line "unsubscribe git" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at  http://vger.kernel.org/majordomo-info.html


[Index of Archives]     [Linux Kernel Development]     [Gcc Help]     [IETF Annouce]     [DCCP]     [Netdev]     [Networking]     [Security]     [V4L]     [Bugtraq]     [Yosemite]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux SCSI]     [Fedora Users]