1 # bash/zsh completion support for core Git.
 
   3 # Copyright (C) 2006,2007 Shawn O. Pearce <spearce@spearce.org>
 
   4 # Conceptually based on gitcompletion (http://gitweb.hawaga.org.uk/).
 
   5 # Distributed under the GNU General Public License, version 2.0.
 
   7 # The contained completion routines provide support for completing:
 
   9 #    *) local and remote branch names
 
  10 #    *) local and remote tag names
 
  11 #    *) .git/remotes file names
 
  12 #    *) git 'subcommands'
 
  13 #    *) git email aliases for git-send-email
 
  14 #    *) tree paths within 'ref:path/to/file' expressions
 
  15 #    *) file paths within current working directory and index
 
  16 #    *) common --long-options
 
  18 # To use these routines:
 
  20 #    1) Copy this file to somewhere (e.g. ~/.git-completion.bash).
 
  21 #    2) Add the following line to your .bashrc/.zshrc:
 
  22 #        source ~/.git-completion.bash
 
  23 #    3) Consider changing your PS1 to also show the current branch,
 
  24 #       see git-prompt.sh for details.
 
  26 # If you use complex aliases of form '!f() { ... }; f', you can use the null
 
  27 # command ':' as the first command in the function body to declare the desired
 
  28 # completion style.  For example '!f() { : git commit ; ... }; f' will
 
  29 # tell the completion to use commit completion.  This also works with aliases
 
  30 # of form "!sh -c '...'".  For example, "!sh -c ': git commit ; ... '".
 
  32 # Compatible with bash 3.2.57.
 
  34 # You can set the following environment variables to influence the behavior of
 
  35 # the completion routines:
 
  37 #   GIT_COMPLETION_CHECKOUT_NO_GUESS
 
  39 #     When set to "1", do not include "DWIM" suggestions in git-checkout
 
  40 #     completion (e.g., completing "foo" when "origin/foo" exists).
 
  42 case "$COMP_WORDBREAKS" in
 
  44 *)   COMP_WORDBREAKS="$COMP_WORDBREAKS:"
 
  47 # Discovers the path to the git repository taking any '--git-dir=<path>' and
 
  48 # '-C <path>' options into account and stores it in the $__git_repo_path
 
  50 __git_find_repo_path ()
 
  52         if [ -n "$__git_repo_path" ]; then
 
  53                 # we already know where it is
 
  57         if [ -n "${__git_C_args-}" ]; then
 
  58                 __git_repo_path="$(git "${__git_C_args[@]}" \
 
  59                         ${__git_dir:+--git-dir="$__git_dir"} \
 
  60                         rev-parse --absolute-git-dir 2>/dev/null)"
 
  61         elif [ -n "${__git_dir-}" ]; then
 
  62                 test -d "$__git_dir" &&
 
  63                 __git_repo_path="$__git_dir"
 
  64         elif [ -n "${GIT_DIR-}" ]; then
 
  65                 test -d "${GIT_DIR-}" &&
 
  66                 __git_repo_path="$GIT_DIR"
 
  67         elif [ -d .git ]; then
 
  70                 __git_repo_path="$(git rev-parse --git-dir 2>/dev/null)"
 
  74 # Deprecated: use __git_find_repo_path() and $__git_repo_path instead
 
  75 # __gitdir accepts 0 or 1 arguments (i.e., location)
 
  76 # returns location of .git repo
 
  79         if [ -z "${1-}" ]; then
 
  80                 __git_find_repo_path || return 1
 
  81                 echo "$__git_repo_path"
 
  82         elif [ -d "$1/.git" ]; then
 
  89 # Runs git with all the options given as argument, respecting any
 
  90 # '--git-dir=<path>' and '-C <path>' options present on the command line
 
  93         git ${__git_C_args:+"${__git_C_args[@]}"} \
 
  94                 ${__git_dir:+--git-dir="$__git_dir"} "$@" 2>/dev/null
 
  97 # Removes backslash escaping, single quotes and double quotes from a word,
 
  98 # stores the result in the variable $dequoted_word.
 
  99 # 1: The word to dequote.
 
 102         local rest="$1" len ch
 
 106         while test -n "$rest"; do
 
 107                 len=${#dequoted_word}
 
 108                 dequoted_word="$dequoted_word${rest%%[\\\'\"]*}"
 
 109                 rest="${rest:$((${#dequoted_word}-$len))}"
 
 111                 case "${rest:0:1}" in
 
 118                                 dequoted_word="$dequoted_word$ch"
 
 125                         len=${#dequoted_word}
 
 126                         dequoted_word="$dequoted_word${rest%%\'*}"
 
 127                         rest="${rest:$((${#dequoted_word}-$len+1))}"
 
 131                         while test -n "$rest" ; do
 
 132                                 len=${#dequoted_word}
 
 133                                 dequoted_word="$dequoted_word${rest%%[\\\"]*}"
 
 134                                 rest="${rest:$((${#dequoted_word}-$len))}"
 
 135                                 case "${rest:0:1}" in
 
 140                                                 dequoted_word="$dequoted_word$ch"
 
 145                                                 dequoted_word="$dequoted_word\\$ch"
 
 161 # The following function is based on code from:
 
 163 #   bash_completion - programmable completion functions for bash 3.2+
 
 165 #   Copyright © 2006-2008, Ian Macdonald <ian@caliban.org>
 
 166 #             © 2009-2010, Bash Completion Maintainers
 
 167 #                     <bash-completion-devel@lists.alioth.debian.org>
 
 169 #   This program is free software; you can redistribute it and/or modify
 
 170 #   it under the terms of the GNU General Public License as published by
 
 171 #   the Free Software Foundation; either version 2, or (at your option)
 
 174 #   This program is distributed in the hope that it will be useful,
 
 175 #   but WITHOUT ANY WARRANTY; without even the implied warranty of
 
 176 #   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 
 177 #   GNU General Public License for more details.
 
 179 #   You should have received a copy of the GNU General Public License
 
 180 #   along with this program; if not, see <http://www.gnu.org/licenses/>.
 
 182 #   The latest version of this software can be obtained here:
 
 184 #   http://bash-completion.alioth.debian.org/
 
 188 # This function can be used to access a tokenized list of words
 
 189 # on the command line:
 
 191 #       __git_reassemble_comp_words_by_ref '=:'
 
 192 #       if test "${words_[cword_-1]}" = -w
 
 197 # The argument should be a collection of characters from the list of
 
 198 # word completion separators (COMP_WORDBREAKS) to treat as ordinary
 
 201 # This is roughly equivalent to going back in time and setting
 
 202 # COMP_WORDBREAKS to exclude those characters.  The intent is to
 
 203 # make option types like --date=<type> and <rev>:<path> easy to
 
 204 # recognize by treating each shell word as a single token.
 
 206 # It is best not to set COMP_WORDBREAKS directly because the value is
 
 207 # shared with other completion scripts.  By the time the completion
 
 208 # function gets called, COMP_WORDS has already been populated so local
 
 209 # changes to COMP_WORDBREAKS have no effect.
 
 211 # Output: words_, cword_, cur_.
 
 213 __git_reassemble_comp_words_by_ref()
 
 215         local exclude i j first
 
 216         # Which word separators to exclude?
 
 217         exclude="${1//[^$COMP_WORDBREAKS]}"
 
 219         if [ -z "$exclude" ]; then
 
 220                 words_=("${COMP_WORDS[@]}")
 
 223         # List of word completion separators has shrunk;
 
 224         # re-assemble words to complete.
 
 225         for ((i=0, j=0; i < ${#COMP_WORDS[@]}; i++, j++)); do
 
 226                 # Append each nonempty word consisting of just
 
 227                 # word separator characters to the current word.
 
 231                         [ -n "${COMP_WORDS[$i]}" ] &&
 
 232                         # word consists of excluded word separators
 
 233                         [ "${COMP_WORDS[$i]//[^$exclude]}" = "${COMP_WORDS[$i]}" ]
 
 235                         # Attach to the previous token,
 
 236                         # unless the previous token is the command name.
 
 237                         if [ $j -ge 2 ] && [ -n "$first" ]; then
 
 241                         words_[$j]=${words_[j]}${COMP_WORDS[i]}
 
 242                         if [ $i = $COMP_CWORD ]; then
 
 245                         if (($i < ${#COMP_WORDS[@]} - 1)); then
 
 252                 words_[$j]=${words_[j]}${COMP_WORDS[i]}
 
 253                 if [ $i = $COMP_CWORD ]; then
 
 259 if ! type _get_comp_words_by_ref >/dev/null 2>&1; then
 
 260 _get_comp_words_by_ref ()
 
 262         local exclude cur_ words_ cword_
 
 263         if [ "$1" = "-n" ]; then
 
 267         __git_reassemble_comp_words_by_ref "$exclude"
 
 268         cur_=${words_[cword_]}
 
 269         while [ $# -gt 0 ]; do
 
 275                         prev=${words_[$cword_-1]}
 
 278                         words=("${words_[@]}")
 
 289 # Fills the COMPREPLY array with prefiltered words without any additional
 
 291 # Callers must take care of providing only words that match the current word
 
 292 # to be completed and adding any prefix and/or suffix (trailing space!), if
 
 294 # 1: List of newline-separated matching completion words, complete with
 
 305         local x i=${#COMPREPLY[@]}
 
 307                 if [[ "$x" == "$3"* ]]; then
 
 308                         COMPREPLY[i++]="$2$x$4"
 
 319 # Generates completion reply, appending a space to possible completion words,
 
 321 # It accepts 1 to 4 arguments:
 
 322 # 1: List of possible completion words.
 
 323 # 2: A prefix to be added to each possible completion word (optional).
 
 324 # 3: Generate possible completion matches for this word (optional).
 
 325 # 4: A suffix to be appended to each possible completion word (optional).
 
 328         local cur_="${3-$cur}"
 
 334                 local c i=0 IFS=$' \t\n'
 
 337                         if [[ $c == "$cur_"* ]]; then
 
 342                                 COMPREPLY[i++]="${2-}$c"
 
 349 # Clear the variables caching builtins' options when (re-)sourcing
 
 350 # the completion script.
 
 351 if [[ -n ${ZSH_VERSION-} ]]; then
 
 352         unset $(set |sed -ne 's/^\(__gitcomp_builtin_[a-zA-Z0-9_][a-zA-Z0-9_]*\)=.*/\1/p') 2>/dev/null
 
 354         unset $(compgen -v __gitcomp_builtin_)
 
 357 # This function is equivalent to
 
 359 #    __gitcomp "$(git xxx --git-completion-helper) ..."
 
 361 # except that the output is cached. Accept 1-3 arguments:
 
 362 # 1: the git command to execute, this is also the cache key
 
 363 # 2: extra options to be added on top (e.g. negative forms)
 
 364 # 3: options to be excluded
 
 367         # spaces must be replaced with underscore for multi-word
 
 368         # commands, e.g. "git remote add" becomes remote_add.
 
 373         local var=__gitcomp_builtin_"${cmd/-/_}"
 
 375         eval "options=\$$var"
 
 377         if [ -z "$options" ]; then
 
 378                 # leading and trailing spaces are significant to make
 
 379                 # option removal work correctly.
 
 380                 options=" $(__git ${cmd/_/ } --git-completion-helper) $incl "
 
 382                         options="${options/ $i / }"
 
 384                 eval "$var=\"$options\""
 
 390 # Variation of __gitcomp_nl () that appends to the existing list of
 
 391 # completion candidates, COMPREPLY.
 
 392 __gitcomp_nl_append ()
 
 395         __gitcompappend "$1" "${2-}" "${3-$cur}" "${4- }"
 
 398 # Generates completion reply from newline-separated possible completion words
 
 399 # by appending a space to all of them.
 
 400 # It accepts 1 to 4 arguments:
 
 401 # 1: List of possible completion words, separated by a single newline.
 
 402 # 2: A prefix to be added to each possible completion word (optional).
 
 403 # 3: Generate possible completion matches for this word (optional).
 
 404 # 4: A suffix to be appended to each possible completion word instead of
 
 405 #    the default space (optional).  If specified but empty, nothing is
 
 410         __gitcomp_nl_append "$@"
 
 413 # Fills the COMPREPLY array with prefiltered paths without any additional
 
 415 # Callers must take care of providing only paths that match the current path
 
 416 # to be completed and adding any prefix path components, if necessary.
 
 417 # 1: List of newline-separated matching paths, complete with all prefix
 
 419 __gitcomp_file_direct ()
 
 425         # use a hack to enable file mode in bash < 4
 
 426         compopt -o filenames +o nospace 2>/dev/null ||
 
 427         compgen -f /non-existing-dir/ >/dev/null ||
 
 431 # Generates completion reply with compgen from newline-separated possible
 
 432 # completion filenames.
 
 433 # It accepts 1 to 3 arguments:
 
 434 # 1: List of possible completion filenames, separated by a single newline.
 
 435 # 2: A directory prefix to be added to each possible completion filename
 
 437 # 3: Generate possible completion matches for this word (optional).
 
 442         # XXX does not work when the directory prefix contains a tilde,
 
 443         # since tilde expansion is not applied.
 
 444         # This means that COMPREPLY will be empty and Bash default
 
 445         # completion will be used.
 
 446         __gitcompadd "$1" "${2-}" "${3-$cur}" ""
 
 448         # use a hack to enable file mode in bash < 4
 
 449         compopt -o filenames +o nospace 2>/dev/null ||
 
 450         compgen -f /non-existing-dir/ >/dev/null ||
 
 454 # Execute 'git ls-files', unless the --committable option is specified, in
 
 455 # which case it runs 'git diff-index' to find out the files that can be
 
 456 # committed.  It return paths relative to the directory specified in the first
 
 457 # argument, and using the options specified in the second argument.
 
 458 __git_ls_files_helper ()
 
 460         if [ "$2" == "--committable" ]; then
 
 461                 __git -C "$1" -c core.quotePath=false diff-index \
 
 462                         --name-only --relative HEAD -- "${3//\\/\\\\}*"
 
 464                 # NOTE: $2 is not quoted in order to support multiple options
 
 465                 __git -C "$1" -c core.quotePath=false ls-files \
 
 466                         --exclude-standard $2 -- "${3//\\/\\\\}*"
 
 471 # __git_index_files accepts 1 or 2 arguments:
 
 472 # 1: Options to pass to ls-files (required).
 
 473 # 2: A directory path (optional).
 
 474 #    If provided, only files within the specified directory are listed.
 
 475 #    Sub directories are never recursed.  Path must have a trailing
 
 477 # 3: List only paths matching this path component (optional).
 
 480         local root="$2" match="$3"
 
 482         __git_ls_files_helper "$root" "$1" "$match" |
 
 483         awk -F / -v pfx="${2//\\/\\\\}" '{
 
 488                         if (substr(p, 1, 1) != "\"") {
 
 489                                 # No special characters, easy!
 
 494                         # The path is quoted.
 
 499                         # Even when a directory name itself does not contain
 
 500                         # any special characters, it will still be quoted if
 
 501                         # any of its (stripped) trailing path components do.
 
 502                         # Because of this we may have seen the same direcory
 
 503                         # both quoted and unquoted.
 
 505                                 # We have seen the same directory unquoted,
 
 512         function dequote(p,    bs_idx, out, esc, esc_idx, dec) {
 
 513                 # Skip opening double quote.
 
 516                 # Interpret backslash escape sequences.
 
 517                 while ((bs_idx = index(p, "\\")) != 0) {
 
 518                         out = out substr(p, 1, bs_idx - 1)
 
 519                         esc = substr(p, bs_idx + 1, 1)
 
 520                         p = substr(p, bs_idx + 2)
 
 522                         if ((esc_idx = index("abtvfr\"\\", esc)) != 0) {
 
 523                                 # C-style one-character escape sequence.
 
 524                                 out = out substr("\a\b\t\v\f\r\"\\",
 
 526                         } else if (esc == "n") {
 
 527                                 # Uh-oh, a newline character.
 
 528                                 # We cant reliably put a pathname
 
 529                                 # containing a newline into COMPREPLY,
 
 530                                 # and the newline would create a mess.
 
 534                                 # Must be a \nnn octal value, then.
 
 536                                       substr(p, 1, 1) * 8  + \
 
 538                                 out = out sprintf("%c", dec)
 
 542                 # Drop closing double quote, if there is one.
 
 543                 # (There isnt any if this is a directory, as it was
 
 544                 # already stripped with the trailing path components.)
 
 545                 if (substr(p, length(p), 1) == "\"")
 
 546                         out = out substr(p, 1, length(p) - 1)
 
 554 # __git_complete_index_file requires 1 argument:
 
 555 # 1: the options to pass to ls-file
 
 557 # The exception is --committable, which finds the files appropriate commit.
 
 558 __git_complete_index_file ()
 
 560         local dequoted_word pfx="" cur_
 
 564         case "$dequoted_word" in
 
 566                 pfx="${dequoted_word%/*}/"
 
 567                 cur_="${dequoted_word##*/}"
 
 570                 cur_="$dequoted_word"
 
 573         __gitcomp_file_direct "$(__git_index_files "$1" "$pfx" "$cur_")"
 
 576 # Lists branches from the local repository.
 
 577 # 1: A prefix to be added to each listed branch (optional).
 
 578 # 2: List only branches matching this word (optional; list all branches if
 
 580 # 3: A suffix to be appended to each listed branch (optional).
 
 583         local pfx="${1-}" cur_="${2-}" sfx="${3-}"
 
 585         __git for-each-ref --format="${pfx//\%/%%}%(refname:strip=2)$sfx" \
 
 586                         "refs/heads/$cur_*" "refs/heads/$cur_*/**"
 
 589 # Lists tags from the local repository.
 
 590 # Accepts the same positional parameters as __git_heads() above.
 
 593         local pfx="${1-}" cur_="${2-}" sfx="${3-}"
 
 595         __git for-each-ref --format="${pfx//\%/%%}%(refname:strip=2)$sfx" \
 
 596                         "refs/tags/$cur_*" "refs/tags/$cur_*/**"
 
 599 # Lists refs from the local (by default) or from a remote repository.
 
 600 # It accepts 0, 1 or 2 arguments:
 
 601 # 1: The remote to list refs from (optional; ignored, if set but empty).
 
 602 #    Can be the name of a configured remote, a path, or a URL.
 
 603 # 2: In addition to local refs, list unique branches from refs/remotes/ for
 
 604 #    'git checkout's tracking DWIMery (optional; ignored, if set but empty).
 
 605 # 3: A prefix to be added to each listed ref (optional).
 
 606 # 4: List only refs matching this word (optional; list all refs if unset or
 
 608 # 5: A suffix to be appended to each listed ref (optional; ignored, if set
 
 611 # Use __git_complete_refs() instead.
 
 614         local i hash dir track="${2-}"
 
 615         local list_refs_from=path remote="${1-}"
 
 617         local pfx="${3-}" cur_="${4-$cur}" sfx="${5-}"
 
 619         local fer_pfx="${pfx//\%/%%}" # "escape" for-each-ref format specifiers
 
 622         dir="$__git_repo_path"
 
 624         if [ -z "$remote" ]; then
 
 625                 if [ -z "$dir" ]; then
 
 629                 if __git_is_configured_remote "$remote"; then
 
 630                         # configured remote takes precedence over a
 
 631                         # local directory with the same name
 
 632                         list_refs_from=remote
 
 633                 elif [ -d "$remote/.git" ]; then
 
 635                 elif [ -d "$remote" ]; then
 
 642         if [ "$list_refs_from" = path ]; then
 
 643                 if [[ "$cur_" == ^* ]]; then
 
 652                         refs=("$match*" "$match*/**")
 
 656                         for i in HEAD FETCH_HEAD ORIG_HEAD MERGE_HEAD REBASE_HEAD; do
 
 659                                         if [ -e "$dir/$i" ]; then
 
 665                         format="refname:strip=2"
 
 666                         refs=("refs/tags/$match*" "refs/tags/$match*/**"
 
 667                                 "refs/heads/$match*" "refs/heads/$match*/**"
 
 668                                 "refs/remotes/$match*" "refs/remotes/$match*/**")
 
 671                 __git_dir="$dir" __git for-each-ref --format="$fer_pfx%($format)$sfx" \
 
 673                 if [ -n "$track" ]; then
 
 674                         # employ the heuristic used by git checkout
 
 675                         # Try to find a remote branch that matches the completion word
 
 676                         # but only output if the branch name is unique
 
 677                         __git for-each-ref --format="$fer_pfx%(refname:strip=3)$sfx" \
 
 678                                 --sort="refname:strip=3" \
 
 679                                 "refs/remotes/*/$match*" "refs/remotes/*/$match*/**" | \
 
 686                 __git ls-remote "$remote" "$match*" | \
 
 687                 while read -r hash i; do
 
 690                         *) echo "$pfx$i$sfx" ;;
 
 695                 if [ "$list_refs_from" = remote ]; then
 
 697                         $match*)        echo "${pfx}HEAD$sfx" ;;
 
 699                         __git for-each-ref --format="$fer_pfx%(refname:strip=3)$sfx" \
 
 700                                 "refs/remotes/$remote/$match*" \
 
 701                                 "refs/remotes/$remote/$match*/**"
 
 705                         $match*)        query_symref="HEAD" ;;
 
 707                         __git ls-remote "$remote" $query_symref \
 
 708                                 "refs/tags/$match*" "refs/heads/$match*" \
 
 709                                 "refs/remotes/$match*" |
 
 710                         while read -r hash i; do
 
 713                                 refs/*) echo "$pfx${i#refs/*/}$sfx" ;;
 
 714                                 *)      echo "$pfx$i$sfx" ;;  # symbolic refs
 
 722 # Completes refs, short and long, local and remote, symbolic and pseudo.
 
 724 # Usage: __git_complete_refs [<option>]...
 
 725 # --remote=<remote>: The remote to list refs from, can be the name of a
 
 726 #                    configured remote, a path, or a URL.
 
 727 # --track: List unique remote branches for 'git checkout's tracking DWIMery.
 
 728 # --pfx=<prefix>: A prefix to be added to each ref.
 
 729 # --cur=<word>: The current ref to be completed.  Defaults to the current
 
 730 #               word to be completed.
 
 731 # --sfx=<suffix>: A suffix to be appended to each ref instead of the default
 
 733 __git_complete_refs ()
 
 735         local remote track pfx cur_="$cur" sfx=" "
 
 737         while test $# != 0; do
 
 739                 --remote=*)     remote="${1##--remote=}" ;;
 
 740                 --track)        track="yes" ;;
 
 741                 --pfx=*)        pfx="${1##--pfx=}" ;;
 
 742                 --cur=*)        cur_="${1##--cur=}" ;;
 
 743                 --sfx=*)        sfx="${1##--sfx=}" ;;
 
 749         __gitcomp_direct "$(__git_refs "$remote" "$track" "$pfx" "$cur_" "$sfx")"
 
 752 # __git_refs2 requires 1 argument (to pass to __git_refs)
 
 753 # Deprecated: use __git_complete_fetch_refspecs() instead.
 
 757         for i in $(__git_refs "$1"); do
 
 762 # Completes refspecs for fetching from a remote repository.
 
 763 # 1: The remote repository.
 
 764 # 2: A prefix to be added to each listed refspec (optional).
 
 765 # 3: The ref to be completed as a refspec instead of the current word to be
 
 766 #    completed (optional)
 
 767 # 4: A suffix to be appended to each listed refspec instead of the default
 
 769 __git_complete_fetch_refspecs ()
 
 771         local i remote="$1" pfx="${2-}" cur_="${3-$cur}" sfx="${4- }"
 
 774                 for i in $(__git_refs "$remote" "" "" "$cur_") ; do
 
 780 # __git_refs_remotes requires 1 argument (to pass to ls-remote)
 
 781 __git_refs_remotes ()
 
 784         __git ls-remote "$1" 'refs/heads/*' | \
 
 785         while read -r hash i; do
 
 786                 echo "$i:refs/remotes/$1/${i#refs/heads/}"
 
 793         test -d "$__git_repo_path/remotes" && ls -1 "$__git_repo_path/remotes"
 
 797 # Returns true if $1 matches the name of a configured remote, false otherwise.
 
 798 __git_is_configured_remote ()
 
 801         for remote in $(__git_remotes); do
 
 802                 if [ "$remote" = "$1" ]; then
 
 809 __git_list_merge_strategies ()
 
 811         LANG=C LC_ALL=C git merge -s help 2>&1 |
 
 812         sed -n -e '/[Aa]vailable strategies are: /,/^$/{
 
 821 __git_merge_strategies=
 
 822 # 'git merge -s help' (and thus detection of the merge strategy
 
 823 # list) fails, unfortunately, if run outside of any git working
 
 824 # tree.  __git_merge_strategies is set to the empty string in
 
 825 # that case, and the detection will be repeated the next time it
 
 827 __git_compute_merge_strategies ()
 
 829         test -n "$__git_merge_strategies" ||
 
 830         __git_merge_strategies=$(__git_list_merge_strategies)
 
 833 __git_complete_revlist_file ()
 
 835         local pfx ls ref cur_="$cur"
 
 855                 case "$COMP_WORDBREAKS" in
 
 857                 *)   pfx="$ref:$pfx" ;;
 
 860                 __gitcomp_nl "$(__git ls-tree "$ls" \
 
 861                                 | sed '/^100... blob /{
 
 877                 pfx="${cur_%...*}..."
 
 879                 __git_complete_refs --pfx="$pfx" --cur="$cur_"
 
 884                 __git_complete_refs --pfx="$pfx" --cur="$cur_"
 
 892 __git_complete_file ()
 
 894         __git_complete_revlist_file
 
 897 __git_complete_revlist ()
 
 899         __git_complete_revlist_file
 
 902 __git_complete_remote_or_refspec ()
 
 904         local cur_="$cur" cmd="${words[1]}"
 
 905         local i c=2 remote="" pfx="" lhs=1 no_complete_refspec=0
 
 906         if [ "$cmd" = "remote" ]; then
 
 909         while [ $c -lt $cword ]; do
 
 912                 --mirror) [ "$cmd" = "push" ] && no_complete_refspec=1 ;;
 
 913                 -d|--delete) [ "$cmd" = "push" ] && lhs=0 ;;
 
 916                         push) no_complete_refspec=1 ;;
 
 924                 *) remote="$i"; break ;;
 
 928         if [ -z "$remote" ]; then
 
 929                 __gitcomp_nl "$(__git_remotes)"
 
 932         if [ $no_complete_refspec = 1 ]; then
 
 935         [ "$remote" = "." ] && remote=
 
 938                 case "$COMP_WORDBREAKS" in
 
 940                 *)   pfx="${cur_%%:*}:" ;;
 
 952                 if [ $lhs = 1 ]; then
 
 953                         __git_complete_fetch_refspecs "$remote" "$pfx" "$cur_"
 
 955                         __git_complete_refs --pfx="$pfx" --cur="$cur_"
 
 959                 if [ $lhs = 1 ]; then
 
 960                         __git_complete_refs --remote="$remote" --pfx="$pfx" --cur="$cur_"
 
 962                         __git_complete_refs --pfx="$pfx" --cur="$cur_"
 
 966                 if [ $lhs = 1 ]; then
 
 967                         __git_complete_refs --pfx="$pfx" --cur="$cur_"
 
 969                         __git_complete_refs --remote="$remote" --pfx="$pfx" --cur="$cur_"
 
 975 __git_complete_strategy ()
 
 977         __git_compute_merge_strategies
 
 980                 __gitcomp "$__git_merge_strategies"
 
 985                 __gitcomp "$__git_merge_strategies" "" "${cur##--strategy=}"
 
 993 __git_compute_all_commands ()
 
 995         test -n "$__git_all_commands" ||
 
 996         __git_all_commands=$(git --list-cmds=main,others,alias,nohelpers)
 
 999 # Lists all set config variables starting with the given section prefix,
 
1000 # with the prefix removed.
 
1001 __git_get_config_variables ()
 
1003         local section="$1" i IFS=$'\n'
 
1004         for i in $(__git config --name-only --get-regexp "^$section\..*"); do
 
1005                 echo "${i#$section.}"
 
1009 __git_pretty_aliases ()
 
1011         __git_get_config_variables "pretty"
 
1014 # __git_aliased_command requires 1 argument
 
1015 __git_aliased_command ()
 
1017         local word cmdline=$(__git config --get "alias.$1")
 
1018         for word in $cmdline; do
 
1024                 \!*)    : shell command alias ;;
 
1026                 *=*)    : setting env ;;
 
1027                 git)    : git itself ;;
 
1028                 \(\))   : skip parens of shell function definition ;;
 
1029                 {)      : skip start of shell helper function ;;
 
1030                 :)      : skip null command ;;
 
1031                 \'*)    : skip opening quote after sh -c ;;
 
1039 # __git_find_on_cmdline requires 1 argument
 
1040 __git_find_on_cmdline ()
 
1042         local word subcommand c=1
 
1043         while [ $c -lt $cword ]; do
 
1045                 for subcommand in $1; do
 
1046                         if [ "$subcommand" = "$word" ]; then
 
1055 # Echo the value of an option set on the command line or config
 
1057 # $1: short option name
 
1058 # $2: long option name including =
 
1059 # $3: list of possible values
 
1060 # $4: config string (optional)
 
1063 # result="$(__git_get_option_value "-d" "--do-something=" \
 
1064 #     "yes no" "core.doSomething")"
 
1066 # result is then either empty (no option set) or "yes" or "no"
 
1068 # __git_get_option_value requires 3 arguments
 
1069 __git_get_option_value ()
 
1071         local c short_opt long_opt val
 
1072         local result= values config_key word
 
1080         while [ $c -ge 0 ]; do
 
1082                 for val in $values; do
 
1083                         if [ "$short_opt$val" = "$word" ] ||
 
1084                            [ "$long_opt$val"  = "$word" ]; then
 
1092         if [ -n "$config_key" ] && [ -z "$result" ]; then
 
1093                 result="$(__git config "$config_key")"
 
1099 __git_has_doubledash ()
 
1102         while [ $c -lt $cword ]; do
 
1103                 if [ "--" = "${words[c]}" ]; then
 
1111 # Try to count non option arguments passed on the command line for the
 
1112 # specified git command.
 
1113 # When options are used, it is necessary to use the special -- option to
 
1114 # tell the implementation were non option arguments begin.
 
1115 # XXX this can not be improved, since options can appear everywhere, as
 
1119 # __git_count_arguments requires 1 argument: the git command executed.
 
1120 __git_count_arguments ()
 
1124         # Skip "git" (first argument)
 
1125         for ((i=1; i < ${#words[@]}; i++)); do
 
1130                                 # Good; we can assume that the following are only non
 
1135                                 # Skip the specified git command and discard git
 
1148 __git_whitespacelist="nowarn warn error error-all fix"
 
1149 __git_am_inprogress_options="--skip --continue --resolved --abort --quit --show-current-patch"
 
1153         __git_find_repo_path
 
1154         if [ -d "$__git_repo_path"/rebase-apply ]; then
 
1155                 __gitcomp "$__git_am_inprogress_options"
 
1160                 __gitcomp "$__git_whitespacelist" "" "${cur##--whitespace=}"
 
1164                 __gitcomp_builtin am "--no-utf8" \
 
1165                         "$__git_am_inprogress_options"
 
1174                 __gitcomp "$__git_whitespacelist" "" "${cur##--whitespace=}"
 
1178                 __gitcomp_builtin apply
 
1187                 __gitcomp_builtin add
 
1191         local complete_opt="--others --modified --directory --no-empty-directory"
 
1192         if test -n "$(__git_find_on_cmdline "-u --update")"
 
1194                 complete_opt="--modified"
 
1196         __git_complete_index_file "$complete_opt"
 
1203                 __gitcomp "$(git archive --list)" "" "${cur##--format=}"
 
1207                 __gitcomp_nl "$(__git_remotes)" "" "${cur##--remote=}"
 
1212                         --format= --list --verbose
 
1213                         --prefix= --remote= --exec= --output
 
1223         __git_has_doubledash && return
 
1225         local subcommands="start bad good skip reset visualize replay log run"
 
1226         local subcommand="$(__git_find_on_cmdline "$subcommands")"
 
1227         if [ -z "$subcommand" ]; then
 
1228                 __git_find_repo_path
 
1229                 if [ -f "$__git_repo_path"/BISECT_START ]; then
 
1230                         __gitcomp "$subcommands"
 
1232                         __gitcomp "replay start"
 
1237         case "$subcommand" in
 
1238         bad|good|reset|skip|start)
 
1248         local i c=1 only_local_ref="n" has_r="n"
 
1250         while [ $c -lt $cword ]; do
 
1253                 -d|--delete|-m|--move)  only_local_ref="y" ;;
 
1254                 -r|--remotes)           has_r="y" ;;
 
1260         --set-upstream-to=*)
 
1261                 __git_complete_refs --cur="${cur##--set-upstream-to=}"
 
1264                 __gitcomp_builtin branch "--no-color --no-abbrev
 
1265                         --no-track --no-column
 
1269                 if [ $only_local_ref = "y" -a $has_r = "n" ]; then
 
1270                         __gitcomp_direct "$(__git_heads "" "$cur" " ")"
 
1280         local cmd="${words[2]}"
 
1283                 __gitcomp "create list-heads verify unbundle"
 
1286                 # looking for a file
 
1291                                 __git_complete_revlist
 
1300         __git_has_doubledash && return
 
1304                 __gitcomp "diff3 merge" "" "${cur##--conflict=}"
 
1307                 __gitcomp_builtin checkout "--no-track --no-recurse-submodules"
 
1310                 # check if --track, --no-track, or --no-guess was specified
 
1311                 # if so, disable DWIM mode
 
1312                 local flags="--track --no-track --no-guess" track_opt="--track"
 
1313                 if [ "$GIT_COMPLETION_CHECKOUT_NO_GUESS" = "1" ] ||
 
1314                    [ -n "$(__git_find_on_cmdline "$flags")" ]; then
 
1317                 __git_complete_refs $track_opt
 
1326                 __gitcomp_builtin cherry
 
1333 __git_cherry_pick_inprogress_options="--continue --quit --abort"
 
1337         __git_find_repo_path
 
1338         if [ -f "$__git_repo_path"/CHERRY_PICK_HEAD ]; then
 
1339                 __gitcomp "$__git_cherry_pick_inprogress_options"
 
1344                 __gitcomp_builtin cherry-pick "" \
 
1345                         "$__git_cherry_pick_inprogress_options"
 
1357                 __gitcomp_builtin clean
 
1362         # XXX should we check for -x option ?
 
1363         __git_complete_index_file "--others --directory"
 
1370                 __gitcomp_builtin clone "--no-single-branch"
 
1376 __git_untracked_file_modes="all no normal"
 
1389                 __gitcomp "default scissors strip verbatim whitespace
 
1390                         " "" "${cur##--cleanup=}"
 
1393         --reuse-message=*|--reedit-message=*|\
 
1394         --fixup=*|--squash=*)
 
1395                 __git_complete_refs --cur="${cur#*=}"
 
1398         --untracked-files=*)
 
1399                 __gitcomp "$__git_untracked_file_modes" "" "${cur##--untracked-files=}"
 
1403                 __gitcomp_builtin commit "--no-edit --verify"
 
1407         if __git rev-parse --verify --quiet HEAD >/dev/null; then
 
1408                 __git_complete_index_file "--committable"
 
1410                 # This is the first commit
 
1411                 __git_complete_index_file "--cached"
 
1419                 __gitcomp_builtin describe
 
1425 __git_diff_algorithms="myers minimal patience histogram"
 
1427 __git_diff_submodule_formats="diff log short"
 
1429 __git_diff_common_options="--stat --numstat --shortstat --summary
 
1430                         --patch-with-stat --name-only --name-status --color
 
1431                         --no-color --color-words --no-renames --check
 
1432                         --full-index --binary --abbrev --diff-filter=
 
1433                         --find-copies-harder --ignore-cr-at-eol
 
1434                         --text --ignore-space-at-eol --ignore-space-change
 
1435                         --ignore-all-space --ignore-blank-lines --exit-code
 
1436                         --quiet --ext-diff --no-ext-diff
 
1437                         --no-prefix --src-prefix= --dst-prefix=
 
1438                         --inter-hunk-context=
 
1439                         --patience --histogram --minimal
 
1440                         --raw --word-diff --word-diff-regex=
 
1441                         --dirstat --dirstat= --dirstat-by-file
 
1442                         --dirstat-by-file= --cumulative
 
1444                         --submodule --submodule= --ignore-submodules
 
1449         __git_has_doubledash && return
 
1453                 __gitcomp "$__git_diff_algorithms" "" "${cur##--diff-algorithm=}"
 
1457                 __gitcomp "$__git_diff_submodule_formats" "" "${cur##--submodule=}"
 
1461                 __gitcomp "--cached --staged --pickaxe-all --pickaxe-regex
 
1462                         --base --ours --theirs --no-index
 
1463                         $__git_diff_common_options
 
1468         __git_complete_revlist_file
 
1471 __git_mergetools_common="diffuse diffmerge ecmerge emerge kdiff3 meld opendiff
 
1472                         tkdiff vimdiff gvimdiff xxdiff araxis p4merge bc codecompare
 
1477         __git_has_doubledash && return
 
1481                 __gitcomp "$__git_mergetools_common kompare" "" "${cur##--tool=}"
 
1485                 __gitcomp_builtin difftool "$__git_diff_common_options
 
1486                                         --base --cached --ours --theirs
 
1487                                         --pickaxe-all --pickaxe-regex
 
1493         __git_complete_revlist_file
 
1496 __git_fetch_recurse_submodules="yes on-demand no"
 
1501         --recurse-submodules=*)
 
1502                 __gitcomp "$__git_fetch_recurse_submodules" "" "${cur##--recurse-submodules=}"
 
1506                 __gitcomp_builtin fetch "--no-tags"
 
1510         __git_complete_remote_or_refspec
 
1513 __git_format_patch_options="
 
1514         --stdout --attach --no-attach --thread --thread= --no-thread
 
1515         --numbered --start-number --numbered-files --keep-subject --signoff
 
1516         --signature --no-signature --in-reply-to= --cc= --full-index --binary
 
1517         --not --all --cover-letter --no-prefix --src-prefix= --dst-prefix=
 
1518         --inline --suffix= --ignore-if-in-upstream --subject-prefix=
 
1519         --output-directory --reroll-count --to= --quiet --notes
 
1522 _git_format_patch ()
 
1528                         " "" "${cur##--thread=}"
 
1532                 __gitcomp "$__git_format_patch_options"
 
1536         __git_complete_revlist
 
1543                 __gitcomp_builtin fsck "--no-reflogs"
 
1554 # Lists matching symbol names from a tag (as in ctags) file.
 
1555 # 1: List symbol names matching this word.
 
1556 # 2: The tag file to list symbol names from.
 
1557 # 3: A prefix to be added to each listed symbol name (optional).
 
1558 # 4: A suffix to be appended to each listed symbol name (optional).
 
1559 __git_match_ctag () {
 
1560         awk -v pfx="${3-}" -v sfx="${4-}" "
 
1561                 /^${1//\//\\/}/ { print pfx \$1 sfx }
 
1565 # Complete symbol names from a tag file.
 
1566 # Usage: __git_complete_symbol [<option>]...
 
1567 # --tags=<file>: The tag file to list symbol names from instead of the
 
1569 # --pfx=<prefix>: A prefix to be added to each symbol name.
 
1570 # --cur=<word>: The current symbol name to be completed.  Defaults to
 
1571 #               the current word to be completed.
 
1572 # --sfx=<suffix>: A suffix to be appended to each symbol name instead
 
1573 #                 of the default space.
 
1574 __git_complete_symbol () {
 
1575         local tags=tags pfx="" cur_="${cur-}" sfx=" "
 
1577         while test $# != 0; do
 
1579                 --tags=*)       tags="${1##--tags=}" ;;
 
1580                 --pfx=*)        pfx="${1##--pfx=}" ;;
 
1581                 --cur=*)        cur_="${1##--cur=}" ;;
 
1582                 --sfx=*)        sfx="${1##--sfx=}" ;;
 
1588         if test -r "$tags"; then
 
1589                 __gitcomp_direct "$(__git_match_ctag "$cur_" "$tags" "$pfx" "$sfx")"
 
1595         __git_has_doubledash && return
 
1599                 __gitcomp_builtin grep
 
1604         case "$cword,$prev" in
 
1606                 __git_complete_symbol && return
 
1617                 __gitcomp_builtin help
 
1621         if test -n "$GIT_TESTING_ALL_COMMAND_LIST"
 
1623                 __gitcomp "$GIT_TESTING_ALL_COMMAND_LIST $(git --list-cmds=alias,list-guide) gitk"
 
1625                 __gitcomp "$(git --list-cmds=main,nohelpers,alias,list-guide) gitk"
 
1634                         false true umask group all world everybody
 
1635                         " "" "${cur##--shared=}"
 
1639                 __gitcomp_builtin init
 
1649                 __gitcomp_builtin ls-files "--no-empty-directory"
 
1654         # XXX ignore options like --modified and always suggest all cached
 
1656         __git_complete_index_file "--cached"
 
1663                 __gitcomp_builtin ls-remote
 
1667         __gitcomp_nl "$(__git_remotes)"
 
1674                 __gitcomp_builtin ls-tree
 
1682 # Options that go well for log, shortlog and gitk
 
1683 __git_log_common_options="
 
1685         --branches --tags --remotes
 
1686         --first-parent --merges --no-merges
 
1688         --max-age= --since= --after=
 
1689         --min-age= --until= --before=
 
1690         --min-parents= --max-parents=
 
1691         --no-min-parents --no-max-parents
 
1693 # Options that go well for log and gitk (not shortlog)
 
1694 __git_log_gitk_options="
 
1695         --dense --sparse --full-history
 
1696         --simplify-merges --simplify-by-decoration
 
1697         --left-right --notes --no-notes
 
1699 # Options that go well for log and shortlog (not gitk)
 
1700 __git_log_shortlog_options="
 
1701         --author= --committer= --grep=
 
1702         --all-match --invert-grep
 
1705 __git_log_pretty_formats="oneline short medium full fuller email raw format:"
 
1706 __git_log_date_formats="relative iso8601 rfc2822 short local default raw"
 
1710         __git_has_doubledash && return
 
1711         __git_find_repo_path
 
1714         if [ -f "$__git_repo_path/MERGE_HEAD" ]; then
 
1717         case "$prev,$cur" in
 
1719                 return  # fall back to Bash filename completion
 
1722                 __git_complete_symbol --cur="${cur#:}" --sfx=":"
 
1726                 __git_complete_symbol
 
1731         --pretty=*|--format=*)
 
1732                 __gitcomp "$__git_log_pretty_formats $(__git_pretty_aliases)
 
1737                 __gitcomp "$__git_log_date_formats" "" "${cur##--date=}"
 
1741                 __gitcomp "full short no" "" "${cur##--decorate=}"
 
1745                 __gitcomp "$__git_diff_algorithms" "" "${cur##--diff-algorithm=}"
 
1749                 __gitcomp "$__git_diff_submodule_formats" "" "${cur##--submodule=}"
 
1754                         $__git_log_common_options
 
1755                         $__git_log_shortlog_options
 
1756                         $__git_log_gitk_options
 
1757                         --root --topo-order --date-order --reverse
 
1758                         --follow --full-diff
 
1759                         --abbrev-commit --abbrev=
 
1760                         --relative-date --date=
 
1761                         --pretty= --format= --oneline
 
1766                         --decorate --decorate=
 
1768                         --parents --children
 
1770                         $__git_diff_common_options
 
1771                         --pickaxe-all --pickaxe-regex
 
1776                 return  # fall back to Bash filename completion
 
1779                 __git_complete_symbol --cur="${cur#-L:}" --sfx=":"
 
1783                 __git_complete_symbol --pfx="-G" --cur="${cur#-G}"
 
1787                 __git_complete_symbol --pfx="-S" --cur="${cur#-S}"
 
1791         __git_complete_revlist
 
1796         __git_complete_strategy && return
 
1800                 __gitcomp_builtin merge "--no-rerere-autoupdate
 
1801                                 --no-commit --no-edit --no-ff
 
1802                                 --no-log --no-progress
 
1803                                 --no-squash --no-stat
 
1804                                 --no-verify-signatures
 
1815                 __gitcomp "$__git_mergetools_common tortoisemerge" "" "${cur##--tool=}"
 
1819                 __gitcomp "--tool= --prompt --no-prompt"
 
1829                 __gitcomp_builtin merge-base
 
1840                 __gitcomp_builtin mv
 
1845         if [ $(__git_count_arguments "mv") -gt 0 ]; then
 
1846                 # We need to show both cached and untracked files (including
 
1847                 # empty directories) since this may not be the last argument.
 
1848                 __git_complete_index_file "--cached --others --directory"
 
1850                 __git_complete_index_file "--cached"
 
1856         local subcommands='add append copy edit get-ref list merge prune remove show'
 
1857         local subcommand="$(__git_find_on_cmdline "$subcommands")"
 
1859         case "$subcommand,$cur" in
 
1861                 __gitcomp_builtin notes
 
1869                         __gitcomp "$subcommands --ref"
 
1873         *,--reuse-message=*|*,--reedit-message=*)
 
1874                 __git_complete_refs --cur="${cur#*=}"
 
1877                 __gitcomp_builtin notes_$subcommand
 
1880                 # this command does not take a ref, do not complete it
 
1896         __git_complete_strategy && return
 
1899         --recurse-submodules=*)
 
1900                 __gitcomp "$__git_fetch_recurse_submodules" "" "${cur##--recurse-submodules=}"
 
1904                 __gitcomp_builtin pull "--no-autostash --no-commit --no-edit
 
1905                                         --no-ff --no-log --no-progress --no-rebase
 
1906                                         --no-squash --no-stat --no-tags
 
1907                                         --no-verify-signatures"
 
1912         __git_complete_remote_or_refspec
 
1915 __git_push_recurse_submodules="check on-demand only"
 
1917 __git_complete_force_with_lease ()
 
1925                 __git_complete_refs --cur="${cur_#*:}"
 
1928                 __git_complete_refs --cur="$cur_"
 
1937                 __gitcomp_nl "$(__git_remotes)"
 
1940         --recurse-submodules)
 
1941                 __gitcomp "$__git_push_recurse_submodules"
 
1947                 __gitcomp_nl "$(__git_remotes)" "" "${cur##--repo=}"
 
1950         --recurse-submodules=*)
 
1951                 __gitcomp "$__git_push_recurse_submodules" "" "${cur##--recurse-submodules=}"
 
1954         --force-with-lease=*)
 
1955                 __git_complete_force_with_lease "${cur##--force-with-lease=}"
 
1959                 __gitcomp_builtin push
 
1963         __git_complete_remote_or_refspec
 
1968         __git_find_repo_path
 
1969         if [ -f "$__git_repo_path"/rebase-merge/interactive ]; then
 
1970                 __gitcomp "--continue --skip --abort --quit --edit-todo --show-current-patch"
 
1972         elif [ -d "$__git_repo_path"/rebase-apply ] || \
 
1973              [ -d "$__git_repo_path"/rebase-merge ]; then
 
1974                 __gitcomp "--continue --skip --abort --quit --show-current-patch"
 
1977         __git_complete_strategy && return
 
1980                 __gitcomp "$__git_whitespacelist" "" "${cur##--whitespace=}"
 
1985                         --onto --merge --strategy --interactive
 
1986                         --rebase-merges --preserve-merges --stat --no-stat
 
1987                         --committer-date-is-author-date --ignore-date
 
1988                         --ignore-whitespace --whitespace=
 
1989                         --autosquash --no-autosquash
 
1990                         --fork-point --no-fork-point
 
1991                         --autostash --no-autostash
 
1992                         --verify --no-verify
 
1993                         --keep-empty --root --force-rebase --no-ff
 
2005         local subcommands="show delete expire"
 
2006         local subcommand="$(__git_find_on_cmdline "$subcommands")"
 
2008         if [ -z "$subcommand" ]; then
 
2009                 __gitcomp "$subcommands"
 
2015 __git_send_email_confirm_options="always never auto cc compose"
 
2016 __git_send_email_suppresscc_options="author self cc bodycc sob cccmd body all"
 
2021         --to|--cc|--bcc|--from)
 
2022                 __gitcomp "$(__git send-email --dump-aliases)"
 
2030                         $__git_send_email_confirm_options
 
2031                         " "" "${cur##--confirm=}"
 
2036                         $__git_send_email_suppresscc_options
 
2037                         " "" "${cur##--suppress-cc=}"
 
2041         --smtp-encryption=*)
 
2042                 __gitcomp "ssl tls" "" "${cur##--smtp-encryption=}"
 
2048                         " "" "${cur##--thread=}"
 
2051         --to=*|--cc=*|--bcc=*|--from=*)
 
2052                 __gitcomp "$(__git send-email --dump-aliases)" "" "${cur#--*=}"
 
2056                 __gitcomp "--annotate --bcc --cc --cc-cmd --chain-reply-to
 
2057                         --compose --confirm= --dry-run --envelope-sender
 
2059                         --in-reply-to --no-chain-reply-to --no-signed-off-by-cc
 
2060                         --no-suppress-from --no-thread --quiet --reply-to
 
2061                         --signed-off-by-cc --smtp-pass --smtp-server
 
2062                         --smtp-server-port --smtp-encryption= --smtp-user
 
2063                         --subject --suppress-cc= --suppress-from --thread --to
 
2064                         --validate --no-validate
 
2065                         $__git_format_patch_options"
 
2069         __git_complete_revlist
 
2080         local untracked_state
 
2083         --ignore-submodules=*)
 
2084                 __gitcomp "none untracked dirty all" "" "${cur##--ignore-submodules=}"
 
2087         --untracked-files=*)
 
2088                 __gitcomp "$__git_untracked_file_modes" "" "${cur##--untracked-files=}"
 
2093                         always never auto column row plain dense nodense
 
2094                         " "" "${cur##--column=}"
 
2098                 __gitcomp_builtin status "--no-column"
 
2103         untracked_state="$(__git_get_option_value "-u" "--untracked-files=" \
 
2104                 "$__git_untracked_file_modes" "status.showUntrackedFiles")"
 
2106         case "$untracked_state" in
 
2108                 # --ignored option does not matter
 
2112                 complete_opt="--cached --directory --no-empty-directory --others"
 
2114                 if [ -n "$(__git_find_on_cmdline "--ignored")" ]; then
 
2115                         complete_opt="$complete_opt --ignored --exclude=*"
 
2120         __git_complete_index_file "$complete_opt"
 
2123 __git_config_get_set_variables ()
 
2125         local prevword word config_file= c=$cword
 
2126         while [ $c -gt 1 ]; do
 
2129                 --system|--global|--local|--file=*)
 
2134                         config_file="$word $prevword"
 
2142         __git config $config_file --name-only --list
 
2148         branch.*.remote|branch.*.pushremote)
 
2149                 __gitcomp_nl "$(__git_remotes)"
 
2157                 __gitcomp "false true merges preserve interactive"
 
2161                 __gitcomp_nl "$(__git_remotes)"
 
2165                 local remote="${prev#remote.}"
 
2166                 remote="${remote%.fetch}"
 
2167                 if [ -z "$cur" ]; then
 
2168                         __gitcomp_nl "refs/heads/" "" "" ""
 
2171                 __gitcomp_nl "$(__git_refs_remotes "$remote")"
 
2175                 local remote="${prev#remote.}"
 
2176                 remote="${remote%.push}"
 
2177                 __gitcomp_nl "$(__git for-each-ref \
 
2178                         --format='%(refname):%(refname)' refs/heads)"
 
2181         pull.twohead|pull.octopus)
 
2182                 __git_compute_merge_strategies
 
2183                 __gitcomp "$__git_merge_strategies"
 
2186         color.branch|color.diff|color.interactive|\
 
2187         color.showbranch|color.status|color.ui)
 
2188                 __gitcomp "always never auto"
 
2192                 __gitcomp "false true"
 
2197                         normal black red green yellow blue magenta cyan white
 
2198                         bold dim ul blink reverse
 
2203                 __gitcomp "log short"
 
2207                 __gitcomp "man info web html"
 
2211                 __gitcomp "$__git_log_date_formats"
 
2214         sendemail.aliasfiletype)
 
2215                 __gitcomp "mutt mailrc pine elm gnus"
 
2219                 __gitcomp "$__git_send_email_confirm_options"
 
2222         sendemail.suppresscc)
 
2223                 __gitcomp "$__git_send_email_suppresscc_options"
 
2226         sendemail.transferencoding)
 
2227                 __gitcomp "7bit 8bit quoted-printable base64"
 
2230         --get|--get-all|--unset|--unset-all)
 
2231                 __gitcomp_nl "$(__git_config_get_set_variables)"
 
2240                 __gitcomp_builtin config
 
2244                 local pfx="${cur%.*}." cur_="${cur##*.}"
 
2245                 __gitcomp "remote pushremote merge mergeoptions rebase" "$pfx" "$cur_"
 
2249                 local pfx="${cur%.*}." cur_="${cur#*.}"
 
2250                 __gitcomp_direct "$(__git_heads "$pfx" "$cur_" ".")"
 
2251                 __gitcomp_nl_append $'autosetupmerge\nautosetuprebase\n' "$pfx" "$cur_"
 
2255                 local pfx="${cur%.*}." cur_="${cur##*.}"
 
2257                         argprompt cmd confirm needsfile noconsole norescan
 
2258                         prompt revprompt revunmerged title
 
2263                 local pfx="${cur%.*}." cur_="${cur##*.}"
 
2264                 __gitcomp "cmd path" "$pfx" "$cur_"
 
2268                 local pfx="${cur%.*}." cur_="${cur##*.}"
 
2269                 __gitcomp "cmd path" "$pfx" "$cur_"
 
2273                 local pfx="${cur%.*}." cur_="${cur##*.}"
 
2274                 __gitcomp "cmd path trustExitCode" "$pfx" "$cur_"
 
2278                 local pfx="${cur%.*}." cur_="${cur#*.}"
 
2279                 __git_compute_all_commands
 
2280                 __gitcomp_nl "$__git_all_commands" "$pfx" "$cur_"
 
2284                 local pfx="${cur%.*}." cur_="${cur##*.}"
 
2286                         url proxy fetch push mirror skipDefaultUpdate
 
2287                         receivepack uploadpack tagopt pushurl
 
2292                 local pfx="${cur%.*}." cur_="${cur#*.}"
 
2293                 __gitcomp_nl "$(__git_remotes)" "$pfx" "$cur_" "."
 
2294                 __gitcomp_nl_append "pushdefault" "$pfx" "$cur_"
 
2298                 local pfx="${cur%.*}." cur_="${cur##*.}"
 
2299                 __gitcomp "insteadOf pushInsteadOf" "$pfx" "$cur_"
 
2306                 advice.commitBeforeMerge
 
2308                 advice.implicitIdentity
 
2309                 advice.pushAlreadyExists
 
2310                 advice.pushFetchFirst
 
2311                 advice.pushNeedsForce
 
2312                 advice.pushNonFFCurrent
 
2313                 advice.pushNonFFMatching
 
2314                 advice.pushUpdateRejected
 
2315                 advice.resolveConflict
 
2318                 advice.statusUoption
 
2323                 apply.ignorewhitespace
 
2325                 branch.autosetupmerge
 
2326                 branch.autosetuprebase
 
2330                 color.branch.current
 
2335                 color.decorate.branch
 
2336                 color.decorate.remoteBranch
 
2337                 color.decorate.stash
 
2347                 color.diff.whitespace
 
2352                 color.grep.linenumber
 
2355                 color.grep.separator
 
2357                 color.interactive.error
 
2358                 color.interactive.header
 
2359                 color.interactive.help
 
2360                 color.interactive.prompt
 
2365                 color.status.changed
 
2367                 color.status.localBranch
 
2368                 color.status.nobranch
 
2369                 color.status.remoteBranch
 
2370                 color.status.unmerged
 
2371                 color.status.untracked
 
2372                 color.status.updated
 
2384                 core.bigFileThreshold
 
2390                 core.deltaBaseCacheLimit
 
2395                 core.fsyncobjectfiles
 
2401                 core.logAllRefUpdates
 
2402                 core.loosecompression
 
2405                 core.packedGitWindowSize
 
2406                 core.packedRefsTimeout
 
2408                 core.precomposeUnicode
 
2409                 core.preferSymlinkRefs
 
2414                 core.repositoryFormatVersion
 
2416                 core.sharedRepository
 
2423                 core.warnAmbiguousRefs
 
2427                 credential.useHttpPath
 
2429                 credentialCache.ignoreSIGHUP
 
2430                 diff.autorefreshindex
 
2432                 diff.ignoreSubmodules
 
2439                 diff.suppressBlankEmpty
 
2445                 fetch.recurseSubmodules
 
2456                 format.subjectprefix
 
2470                 gc.reflogexpireunreachable
 
2473                 gc.worktreePruneExpire
 
2475                 gitcvs.commitmsgannotation
 
2476                 gitcvs.dbTableNamePrefix
 
2487                 gui.copyblamethreshold
 
2491                 gui.matchtrackingbranch
 
2492                 gui.newbranchtemplate
 
2493                 gui.pruneduringfetch
 
2494                 gui.spellingdictionary
 
2511                 http.sslCertPasswordProtected
 
2516                 i18n.logOutputEncoding
 
2522                 imap.preformattedHTML
 
2532                 interactive.singlekey
 
2548                 mergetool.keepBackup
 
2549                 mergetool.keepTemporaries
 
2554                 notes.rewrite.rebase
 
2558                 pack.deltaCacheLimit
 
2575                 receive.denyCurrentBranch
 
2576                 receive.denyDeleteCurrent
 
2578                 receive.denyNonFastForwards
 
2581                 receive.updateserverinfo
 
2584                 repack.usedeltabaseoffset
 
2588                 sendemail.aliasesfile
 
2589                 sendemail.aliasfiletype
 
2593                 sendemail.chainreplyto
 
2595                 sendemail.envelopesender
 
2599                 sendemail.signedoffbycc
 
2600                 sendemail.smtpdomain
 
2601                 sendemail.smtpencryption
 
2603                 sendemail.smtpserver
 
2604                 sendemail.smtpserveroption
 
2605                 sendemail.smtpserverport
 
2607                 sendemail.suppresscc
 
2608                 sendemail.suppressfrom
 
2613                 sendemail.smtpbatchsize
 
2614                 sendemail.smtprelogindelay
 
2616                 status.relativePaths
 
2617                 status.showUntrackedFiles
 
2618                 status.submodulesummary
 
2621                 transfer.unpackLimit
 
2634                 add rename remove set-head set-branches
 
2635                 get-url set-url show prune update
 
2637         local subcommand="$(__git_find_on_cmdline "$subcommands")"
 
2638         if [ -z "$subcommand" ]; then
 
2641                         __gitcomp_builtin remote
 
2644                         __gitcomp "$subcommands"
 
2650         case "$subcommand,$cur" in
 
2652                 __gitcomp_builtin remote_add "--no-tags"
 
2657                 __gitcomp_builtin remote_set-head
 
2660                 __gitcomp_builtin remote_set-branches
 
2662         set-head,*|set-branches,*)
 
2663                 __git_complete_remote_or_refspec
 
2666                 __gitcomp_builtin remote_update
 
2669                 __gitcomp "$(__git_get_config_variables "remotes")"
 
2672                 __gitcomp_builtin remote_set-url
 
2675                 __gitcomp_builtin remote_get-url
 
2678                 __gitcomp_builtin remote_prune
 
2681                 __gitcomp_nl "$(__git_remotes)"
 
2690                 __gitcomp_builtin replace
 
2699         local subcommands="clear forget diff remaining status gc"
 
2700         local subcommand="$(__git_find_on_cmdline "$subcommands")"
 
2701         if test -z "$subcommand"
 
2703                 __gitcomp "$subcommands"
 
2710         __git_has_doubledash && return
 
2714                 __gitcomp_builtin reset
 
2721 __git_revert_inprogress_options="--continue --quit --abort"
 
2725         __git_find_repo_path
 
2726         if [ -f "$__git_repo_path"/REVERT_HEAD ]; then
 
2727                 __gitcomp "$__git_revert_inprogress_options"
 
2732                 __gitcomp_builtin revert "--no-edit" \
 
2733                         "$__git_revert_inprogress_options"
 
2744                 __gitcomp_builtin rm
 
2749         __git_complete_index_file "--cached"
 
2754         __git_has_doubledash && return
 
2759                         $__git_log_common_options
 
2760                         $__git_log_shortlog_options
 
2761                         --numbered --summary --email
 
2766         __git_complete_revlist
 
2771         __git_has_doubledash && return
 
2774         --pretty=*|--format=*)
 
2775                 __gitcomp "$__git_log_pretty_formats $(__git_pretty_aliases)
 
2780                 __gitcomp "$__git_diff_algorithms" "" "${cur##--diff-algorithm=}"
 
2784                 __gitcomp "$__git_diff_submodule_formats" "" "${cur##--submodule=}"
 
2788                 __gitcomp "--pretty= --format= --abbrev-commit --oneline
 
2790                         $__git_diff_common_options
 
2795         __git_complete_revlist_file
 
2802                 __gitcomp_builtin show-branch "--no-color"
 
2806         __git_complete_revlist
 
2811         local save_opts='--all --keep-index --no-keep-index --quiet --patch --include-untracked'
 
2812         local subcommands='push list show apply clear drop pop create branch'
 
2813         local subcommand="$(__git_find_on_cmdline "$subcommands save")"
 
2814         if [ -n "$(__git_find_on_cmdline "-p")" ]; then
 
2817         if [ -z "$subcommand" ]; then
 
2820                         __gitcomp "$save_opts"
 
2823                         if [ -z "$(__git_find_on_cmdline "$save_opts")" ]; then
 
2828                         if [ -z "$(__git_find_on_cmdline "$save_opts")" ]; then
 
2829                                 __gitcomp "$subcommands"
 
2834                 case "$subcommand,$cur" in
 
2836                         __gitcomp "$save_opts --message"
 
2839                         __gitcomp "$save_opts"
 
2842                         __gitcomp "--index --quiet"
 
2847                 show,--*|branch,--*)
 
2850                         if [ $cword -eq 3 ]; then
 
2853                                 __gitcomp_nl "$(__git stash list \
 
2854                                                 | sed -n -e 's/:.*//p')"
 
2857                 show,*|apply,*|drop,*|pop,*)
 
2858                         __gitcomp_nl "$(__git stash list \
 
2859                                         | sed -n -e 's/:.*//p')"
 
2869         __git_has_doubledash && return
 
2871         local subcommands="add status init deinit update summary foreach sync"
 
2872         local subcommand="$(__git_find_on_cmdline "$subcommands")"
 
2873         if [ -z "$subcommand" ]; then
 
2879                         __gitcomp "$subcommands"
 
2885         case "$subcommand,$cur" in
 
2887                 __gitcomp "--branch --force --name --reference --depth"
 
2890                 __gitcomp "--cached --recursive"
 
2893                 __gitcomp "--force --all"
 
2897                         --init --remote --no-fetch
 
2898                         --recommend-shallow --no-recommend-shallow
 
2899                         --force --rebase --merge --reference --depth --recursive --jobs
 
2903                 __gitcomp "--cached --files --summary-limit"
 
2905         foreach,--*|sync,--*)
 
2906                 __gitcomp "--recursive"
 
2916                 init fetch clone rebase dcommit log find-rev
 
2917                 set-tree commit-diff info create-ignore propget
 
2918                 proplist show-ignore show-externals branch tag blame
 
2919                 migrate mkdirs reset gc
 
2921         local subcommand="$(__git_find_on_cmdline "$subcommands")"
 
2922         if [ -z "$subcommand" ]; then
 
2923                 __gitcomp "$subcommands"
 
2925                 local remote_opts="--username= --config-dir= --no-auth-cache"
 
2927                         --follow-parent --authors-file= --repack=
 
2928                         --no-metadata --use-svm-props --use-svnsync-props
 
2929                         --log-window-size= --no-checkout --quiet
 
2930                         --repack-flags --use-log-author --localtime
 
2932                         --ignore-paths= --include-paths= $remote_opts
 
2935                         --template= --shared= --trunk= --tags=
 
2936                         --branches= --stdlayout --minimize-url
 
2937                         --no-metadata --use-svm-props --use-svnsync-props
 
2938                         --rewrite-root= --prefix= $remote_opts
 
2941                         --edit --rmdir --find-copies-harder --copy-similarity=
 
2944                 case "$subcommand,$cur" in
 
2946                         __gitcomp "--revision= --fetch-all $fc_opts"
 
2949                         __gitcomp "--revision= $fc_opts $init_opts"
 
2952                         __gitcomp "$init_opts"
 
2956                                 --merge --strategy= --verbose --dry-run
 
2957                                 --fetch-all --no-rebase --commit-url
 
2958                                 --revision --interactive $cmt_opts $fc_opts
 
2962                         __gitcomp "--stdin $cmt_opts $fc_opts"
 
2964                 create-ignore,--*|propget,--*|proplist,--*|show-ignore,--*|\
 
2965                 show-externals,--*|mkdirs,--*)
 
2966                         __gitcomp "--revision="
 
2970                                 --limit= --revision= --verbose --incremental
 
2971                                 --oneline --show-commit --non-recursive
 
2972                                 --authors-file= --color
 
2977                                 --merge --verbose --strategy= --local
 
2978                                 --fetch-all --dry-run $fc_opts
 
2982                         __gitcomp "--message= --file= --revision= $cmt_opts"
 
2988                         __gitcomp "--dry-run --message --tag"
 
2991                         __gitcomp "--dry-run --message"
 
2994                         __gitcomp "--git-format"
 
2998                                 --config-dir= --ignore-paths= --minimize
 
2999                                 --no-auth-cache --username=
 
3003                         __gitcomp "--revision= --parent"
 
3014         while [ $c -lt $cword ]; do
 
3017                 -d|--delete|-v|--verify)
 
3018                         __gitcomp_direct "$(__git_tags "" "$cur" " ")"
 
3033                         __gitcomp_direct "$(__git_tags "" "$cur" " ")"
 
3043                 __gitcomp_builtin tag
 
3055         local subcommands="add list lock move prune remove unlock"
 
3056         local subcommand="$(__git_find_on_cmdline "$subcommands")"
 
3057         if [ -z "$subcommand" ]; then
 
3058                 __gitcomp "$subcommands"
 
3060                 case "$subcommand,$cur" in
 
3062                         __gitcomp_builtin worktree_add
 
3065                         __gitcomp_builtin worktree_list
 
3068                         __gitcomp_builtin worktree_lock
 
3071                         __gitcomp_builtin worktree_prune
 
3082 __git_complete_common () {
 
3087                 __gitcomp_builtin "$command"
 
3092 __git_cmds_with_parseopt_helper=
 
3093 __git_support_parseopt_helper () {
 
3094         test -n "$__git_cmds_with_parseopt_helper" ||
 
3095                 __git_cmds_with_parseopt_helper="$(__git --list-cmds=parseopt)"
 
3097         case " $__git_cmds_with_parseopt_helper " in
 
3107 __git_complete_command () {
 
3109         local completion_func="_git_${command//-/_}"
 
3110         if ! declare -f $completion_func >/dev/null 2>/dev/null &&
 
3111                 declare -f _completion_loader >/dev/null 2>/dev/null
 
3113                 _completion_loader "git-$command"
 
3115         if declare -f $completion_func >/dev/null 2>/dev/null
 
3119         elif __git_support_parseopt_helper "$command"
 
3121                 __git_complete_common "$command"
 
3130         local i c=1 command __git_dir __git_repo_path
 
3131         local __git_C_args C_args_count=0
 
3133         while [ $c -lt $cword ]; do
 
3136                 --git-dir=*) __git_dir="${i#--git-dir=}" ;;
 
3137                 --git-dir)   ((c++)) ; __git_dir="${words[c]}" ;;
 
3138                 --bare)      __git_dir="." ;;
 
3139                 --help) command="help"; break ;;
 
3140                 -c|--work-tree|--namespace) ((c++)) ;;
 
3141                 -C)     __git_C_args[C_args_count++]=-C
 
3143                         __git_C_args[C_args_count++]="${words[c]}"
 
3146                 *) command="$i"; break ;;
 
3151         if [ -z "$command" ]; then
 
3153                 --git-dir|-C|--work-tree)
 
3154                         # these need a path argument, let's fall back to
 
3155                         # Bash filename completion
 
3159                         # we don't support completing these options' arguments
 
3177                         --no-replace-objects
 
3182                         if test -n "$GIT_TESTING_PORCELAIN_COMMAND_LIST"
 
3184                                 __gitcomp "$GIT_TESTING_PORCELAIN_COMMAND_LIST"
 
3186                                 __gitcomp "$(git --list-cmds=list-mainporcelain,others,nohelpers,alias,list-complete,config)"
 
3193         __git_complete_command "$command" && return
 
3195         local expansion=$(__git_aliased_command "$command")
 
3196         if [ -n "$expansion" ]; then
 
3198                 __git_complete_command "$expansion"
 
3204         __git_has_doubledash && return
 
3206         local __git_repo_path
 
3207         __git_find_repo_path
 
3210         if [ -f "$__git_repo_path/MERGE_HEAD" ]; then
 
3216                         $__git_log_common_options
 
3217                         $__git_log_gitk_options
 
3223         __git_complete_revlist
 
3226 if [[ -n ${ZSH_VERSION-} ]] &&
 
3227    # Don't define these functions when sourced from 'git-completion.zsh',
 
3228    # it has its own implementations.
 
3229    [[ -z ${GIT_SOURCING_ZSH_COMPLETION-} ]]; then
 
3230         echo "WARNING: this script is deprecated, please see git-completion.zsh" 1>&2
 
3232         autoload -U +X compinit && compinit
 
3238                 local cur_="${3-$cur}"
 
3244                         local c IFS=$' \t\n'
 
3252                                 array[${#array[@]}+1]="$c"
 
3255                         compadd -Q -S '' -p "${2-}" -a -- array && _ret=0
 
3266                 compadd -Q -- ${=1} && _ret=0
 
3275                 compadd -Q -S "${4- }" -p "${2-}" -- ${=1} && _ret=0
 
3278         __gitcomp_file_direct ()
 
3284                 compadd -Q -f -- ${=1} && _ret=0
 
3293                 compadd -Q -p "${2-}" -f -- ${=1} && _ret=0
 
3298                 local _ret=1 cur cword prev
 
3299                 cur=${words[CURRENT]}
 
3300                 prev=${words[CURRENT-1]}
 
3302                 emulate ksh -c __${service}_main
 
3303                 let _ret && _default && _ret=0
 
3307         compdef _git git gitk
 
3313         local cur words cword prev
 
3314         _get_comp_words_by_ref -n =: cur words cword prev
 
3318 # Setup completion for certain functions defined above by setting common
 
3319 # variables and workarounds.
 
3320 # This is NOT a public function; use at your own risk.
 
3323         local wrapper="__git_wrap${2}"
 
3324         eval "$wrapper () { __git_func_wrap $2 ; }"
 
3325         complete -o bashdefault -o default -o nospace -F $wrapper $1 2>/dev/null \
 
3326                 || complete -o default -o nospace -F $wrapper $1
 
3329 # wrapper for backwards compatibility
 
3332         __git_wrap__git_main
 
3335 # wrapper for backwards compatibility
 
3338         __git_wrap__gitk_main
 
3341 __git_complete git __git_main
 
3342 __git_complete gitk __gitk_main
 
3344 # The following are necessary only for Cygwin, and only are needed
 
3345 # when the user has tab-completed the executable name and consequently
 
3346 # included the '.exe' suffix.
 
3348 if [ Cygwin = "$(uname -o 2>/dev/null)" ]; then
 
3349 __git_complete git.exe __git_main