contrib / completion / git-completion.bashon commit Merge branch 'jt/binsearch-with-fanout' into HEAD (7d4bebf)
   1# bash/zsh completion support for core Git.
   2#
   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.
   6#
   7# The contained completion routines provide support for completing:
   8#
   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
  17#
  18# To use these routines:
  19#
  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.
  25#
  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 ; ... '".
  31#
  32# You can set the following environment variables to influence the behavior of
  33# the completion routines:
  34#
  35#   GIT_COMPLETION_CHECKOUT_NO_GUESS
  36#
  37#     When set to "1", do not include "DWIM" suggestions in git-checkout
  38#     completion (e.g., completing "foo" when "origin/foo" exists).
  39
  40case "$COMP_WORDBREAKS" in
  41*:*) : great ;;
  42*)   COMP_WORDBREAKS="$COMP_WORDBREAKS:"
  43esac
  44
  45# Discovers the path to the git repository taking any '--git-dir=<path>' and
  46# '-C <path>' options into account and stores it in the $__git_repo_path
  47# variable.
  48__git_find_repo_path ()
  49{
  50        if [ -n "$__git_repo_path" ]; then
  51                # we already know where it is
  52                return
  53        fi
  54
  55        if [ -n "${__git_C_args-}" ]; then
  56                __git_repo_path="$(git "${__git_C_args[@]}" \
  57                        ${__git_dir:+--git-dir="$__git_dir"} \
  58                        rev-parse --absolute-git-dir 2>/dev/null)"
  59        elif [ -n "${__git_dir-}" ]; then
  60                test -d "$__git_dir" &&
  61                __git_repo_path="$__git_dir"
  62        elif [ -n "${GIT_DIR-}" ]; then
  63                test -d "${GIT_DIR-}" &&
  64                __git_repo_path="$GIT_DIR"
  65        elif [ -d .git ]; then
  66                __git_repo_path=.git
  67        else
  68                __git_repo_path="$(git rev-parse --git-dir 2>/dev/null)"
  69        fi
  70}
  71
  72# Deprecated: use __git_find_repo_path() and $__git_repo_path instead
  73# __gitdir accepts 0 or 1 arguments (i.e., location)
  74# returns location of .git repo
  75__gitdir ()
  76{
  77        if [ -z "${1-}" ]; then
  78                __git_find_repo_path || return 1
  79                echo "$__git_repo_path"
  80        elif [ -d "$1/.git" ]; then
  81                echo "$1/.git"
  82        else
  83                echo "$1"
  84        fi
  85}
  86
  87# Runs git with all the options given as argument, respecting any
  88# '--git-dir=<path>' and '-C <path>' options present on the command line
  89__git ()
  90{
  91        git ${__git_C_args:+"${__git_C_args[@]}"} \
  92                ${__git_dir:+--git-dir="$__git_dir"} "$@" 2>/dev/null
  93}
  94
  95# The following function is based on code from:
  96#
  97#   bash_completion - programmable completion functions for bash 3.2+
  98#
  99#   Copyright © 2006-2008, Ian Macdonald <ian@caliban.org>
 100#             © 2009-2010, Bash Completion Maintainers
 101#                     <bash-completion-devel@lists.alioth.debian.org>
 102#
 103#   This program is free software; you can redistribute it and/or modify
 104#   it under the terms of the GNU General Public License as published by
 105#   the Free Software Foundation; either version 2, or (at your option)
 106#   any later version.
 107#
 108#   This program is distributed in the hope that it will be useful,
 109#   but WITHOUT ANY WARRANTY; without even the implied warranty of
 110#   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 111#   GNU General Public License for more details.
 112#
 113#   You should have received a copy of the GNU General Public License
 114#   along with this program; if not, see <http://www.gnu.org/licenses/>.
 115#
 116#   The latest version of this software can be obtained here:
 117#
 118#   http://bash-completion.alioth.debian.org/
 119#
 120#   RELEASE: 2.x
 121
 122# This function can be used to access a tokenized list of words
 123# on the command line:
 124#
 125#       __git_reassemble_comp_words_by_ref '=:'
 126#       if test "${words_[cword_-1]}" = -w
 127#       then
 128#               ...
 129#       fi
 130#
 131# The argument should be a collection of characters from the list of
 132# word completion separators (COMP_WORDBREAKS) to treat as ordinary
 133# characters.
 134#
 135# This is roughly equivalent to going back in time and setting
 136# COMP_WORDBREAKS to exclude those characters.  The intent is to
 137# make option types like --date=<type> and <rev>:<path> easy to
 138# recognize by treating each shell word as a single token.
 139#
 140# It is best not to set COMP_WORDBREAKS directly because the value is
 141# shared with other completion scripts.  By the time the completion
 142# function gets called, COMP_WORDS has already been populated so local
 143# changes to COMP_WORDBREAKS have no effect.
 144#
 145# Output: words_, cword_, cur_.
 146
 147__git_reassemble_comp_words_by_ref()
 148{
 149        local exclude i j first
 150        # Which word separators to exclude?
 151        exclude="${1//[^$COMP_WORDBREAKS]}"
 152        cword_=$COMP_CWORD
 153        if [ -z "$exclude" ]; then
 154                words_=("${COMP_WORDS[@]}")
 155                return
 156        fi
 157        # List of word completion separators has shrunk;
 158        # re-assemble words to complete.
 159        for ((i=0, j=0; i < ${#COMP_WORDS[@]}; i++, j++)); do
 160                # Append each nonempty word consisting of just
 161                # word separator characters to the current word.
 162                first=t
 163                while
 164                        [ $i -gt 0 ] &&
 165                        [ -n "${COMP_WORDS[$i]}" ] &&
 166                        # word consists of excluded word separators
 167                        [ "${COMP_WORDS[$i]//[^$exclude]}" = "${COMP_WORDS[$i]}" ]
 168                do
 169                        # Attach to the previous token,
 170                        # unless the previous token is the command name.
 171                        if [ $j -ge 2 ] && [ -n "$first" ]; then
 172                                ((j--))
 173                        fi
 174                        first=
 175                        words_[$j]=${words_[j]}${COMP_WORDS[i]}
 176                        if [ $i = $COMP_CWORD ]; then
 177                                cword_=$j
 178                        fi
 179                        if (($i < ${#COMP_WORDS[@]} - 1)); then
 180                                ((i++))
 181                        else
 182                                # Done.
 183                                return
 184                        fi
 185                done
 186                words_[$j]=${words_[j]}${COMP_WORDS[i]}
 187                if [ $i = $COMP_CWORD ]; then
 188                        cword_=$j
 189                fi
 190        done
 191}
 192
 193if ! type _get_comp_words_by_ref >/dev/null 2>&1; then
 194_get_comp_words_by_ref ()
 195{
 196        local exclude cur_ words_ cword_
 197        if [ "$1" = "-n" ]; then
 198                exclude=$2
 199                shift 2
 200        fi
 201        __git_reassemble_comp_words_by_ref "$exclude"
 202        cur_=${words_[cword_]}
 203        while [ $# -gt 0 ]; do
 204                case "$1" in
 205                cur)
 206                        cur=$cur_
 207                        ;;
 208                prev)
 209                        prev=${words_[$cword_-1]}
 210                        ;;
 211                words)
 212                        words=("${words_[@]}")
 213                        ;;
 214                cword)
 215                        cword=$cword_
 216                        ;;
 217                esac
 218                shift
 219        done
 220}
 221fi
 222
 223# Fills the COMPREPLY array with prefiltered words without any additional
 224# processing.
 225# Callers must take care of providing only words that match the current word
 226# to be completed and adding any prefix and/or suffix (trailing space!), if
 227# necessary.
 228# 1: List of newline-separated matching completion words, complete with
 229#    prefix and suffix.
 230__gitcomp_direct ()
 231{
 232        local IFS=$'\n'
 233
 234        COMPREPLY=($1)
 235}
 236
 237__gitcompappend ()
 238{
 239        local x i=${#COMPREPLY[@]}
 240        for x in $1; do
 241                if [[ "$x" == "$3"* ]]; then
 242                        COMPREPLY[i++]="$2$x$4"
 243                fi
 244        done
 245}
 246
 247__gitcompadd ()
 248{
 249        COMPREPLY=()
 250        __gitcompappend "$@"
 251}
 252
 253# Generates completion reply, appending a space to possible completion words,
 254# if necessary.
 255# It accepts 1 to 4 arguments:
 256# 1: List of possible completion words.
 257# 2: A prefix to be added to each possible completion word (optional).
 258# 3: Generate possible completion matches for this word (optional).
 259# 4: A suffix to be appended to each possible completion word (optional).
 260__gitcomp ()
 261{
 262        local cur_="${3-$cur}"
 263
 264        case "$cur_" in
 265        --*=)
 266                ;;
 267        *)
 268                local c i=0 IFS=$' \t\n'
 269                for c in $1; do
 270                        c="$c${4-}"
 271                        if [[ $c == "$cur_"* ]]; then
 272                                case $c in
 273                                --*=*|*.) ;;
 274                                *) c="$c " ;;
 275                                esac
 276                                COMPREPLY[i++]="${2-}$c"
 277                        fi
 278                done
 279                ;;
 280        esac
 281}
 282
 283# Variation of __gitcomp_nl () that appends to the existing list of
 284# completion candidates, COMPREPLY.
 285__gitcomp_nl_append ()
 286{
 287        local IFS=$'\n'
 288        __gitcompappend "$1" "${2-}" "${3-$cur}" "${4- }"
 289}
 290
 291# Generates completion reply from newline-separated possible completion words
 292# by appending a space to all of them.
 293# It accepts 1 to 4 arguments:
 294# 1: List of possible completion words, separated by a single newline.
 295# 2: A prefix to be added to each possible completion word (optional).
 296# 3: Generate possible completion matches for this word (optional).
 297# 4: A suffix to be appended to each possible completion word instead of
 298#    the default space (optional).  If specified but empty, nothing is
 299#    appended.
 300__gitcomp_nl ()
 301{
 302        COMPREPLY=()
 303        __gitcomp_nl_append "$@"
 304}
 305
 306# Generates completion reply with compgen from newline-separated possible
 307# completion filenames.
 308# It accepts 1 to 3 arguments:
 309# 1: List of possible completion filenames, separated by a single newline.
 310# 2: A directory prefix to be added to each possible completion filename
 311#    (optional).
 312# 3: Generate possible completion matches for this word (optional).
 313__gitcomp_file ()
 314{
 315        local IFS=$'\n'
 316
 317        # XXX does not work when the directory prefix contains a tilde,
 318        # since tilde expansion is not applied.
 319        # This means that COMPREPLY will be empty and Bash default
 320        # completion will be used.
 321        __gitcompadd "$1" "${2-}" "${3-$cur}" ""
 322
 323        # use a hack to enable file mode in bash < 4
 324        compopt -o filenames +o nospace 2>/dev/null ||
 325        compgen -f /non-existing-dir/ > /dev/null
 326}
 327
 328# Execute 'git ls-files', unless the --committable option is specified, in
 329# which case it runs 'git diff-index' to find out the files that can be
 330# committed.  It return paths relative to the directory specified in the first
 331# argument, and using the options specified in the second argument.
 332__git_ls_files_helper ()
 333{
 334        if [ "$2" == "--committable" ]; then
 335                __git -C "$1" diff-index --name-only --relative HEAD
 336        else
 337                # NOTE: $2 is not quoted in order to support multiple options
 338                __git -C "$1" ls-files --exclude-standard $2
 339        fi
 340}
 341
 342
 343# __git_index_files accepts 1 or 2 arguments:
 344# 1: Options to pass to ls-files (required).
 345# 2: A directory path (optional).
 346#    If provided, only files within the specified directory are listed.
 347#    Sub directories are never recursed.  Path must have a trailing
 348#    slash.
 349__git_index_files ()
 350{
 351        local root="${2-.}" file
 352
 353        __git_ls_files_helper "$root" "$1" |
 354        while read -r file; do
 355                case "$file" in
 356                ?*/*) echo "${file%%/*}" ;;
 357                *) echo "$file" ;;
 358                esac
 359        done | sort | uniq
 360}
 361
 362# Lists branches from the local repository.
 363# 1: A prefix to be added to each listed branch (optional).
 364# 2: List only branches matching this word (optional; list all branches if
 365#    unset or empty).
 366# 3: A suffix to be appended to each listed branch (optional).
 367__git_heads ()
 368{
 369        local pfx="${1-}" cur_="${2-}" sfx="${3-}"
 370
 371        __git for-each-ref --format="${pfx//\%/%%}%(refname:strip=2)$sfx" \
 372                        "refs/heads/$cur_*" "refs/heads/$cur_*/**"
 373}
 374
 375# Lists tags from the local repository.
 376# Accepts the same positional parameters as __git_heads() above.
 377__git_tags ()
 378{
 379        local pfx="${1-}" cur_="${2-}" sfx="${3-}"
 380
 381        __git for-each-ref --format="${pfx//\%/%%}%(refname:strip=2)$sfx" \
 382                        "refs/tags/$cur_*" "refs/tags/$cur_*/**"
 383}
 384
 385# Lists refs from the local (by default) or from a remote repository.
 386# It accepts 0, 1 or 2 arguments:
 387# 1: The remote to list refs from (optional; ignored, if set but empty).
 388#    Can be the name of a configured remote, a path, or a URL.
 389# 2: In addition to local refs, list unique branches from refs/remotes/ for
 390#    'git checkout's tracking DWIMery (optional; ignored, if set but empty).
 391# 3: A prefix to be added to each listed ref (optional).
 392# 4: List only refs matching this word (optional; list all refs if unset or
 393#    empty).
 394# 5: A suffix to be appended to each listed ref (optional; ignored, if set
 395#    but empty).
 396#
 397# Use __git_complete_refs() instead.
 398__git_refs ()
 399{
 400        local i hash dir track="${2-}"
 401        local list_refs_from=path remote="${1-}"
 402        local format refs
 403        local pfx="${3-}" cur_="${4-$cur}" sfx="${5-}"
 404        local match="${4-}"
 405        local fer_pfx="${pfx//\%/%%}" # "escape" for-each-ref format specifiers
 406
 407        __git_find_repo_path
 408        dir="$__git_repo_path"
 409
 410        if [ -z "$remote" ]; then
 411                if [ -z "$dir" ]; then
 412                        return
 413                fi
 414        else
 415                if __git_is_configured_remote "$remote"; then
 416                        # configured remote takes precedence over a
 417                        # local directory with the same name
 418                        list_refs_from=remote
 419                elif [ -d "$remote/.git" ]; then
 420                        dir="$remote/.git"
 421                elif [ -d "$remote" ]; then
 422                        dir="$remote"
 423                else
 424                        list_refs_from=url
 425                fi
 426        fi
 427
 428        if [ "$list_refs_from" = path ]; then
 429                if [[ "$cur_" == ^* ]]; then
 430                        pfx="$pfx^"
 431                        fer_pfx="$fer_pfx^"
 432                        cur_=${cur_#^}
 433                        match=${match#^}
 434                fi
 435                case "$cur_" in
 436                refs|refs/*)
 437                        format="refname"
 438                        refs=("$match*" "$match*/**")
 439                        track=""
 440                        ;;
 441                *)
 442                        for i in HEAD FETCH_HEAD ORIG_HEAD MERGE_HEAD; do
 443                                case "$i" in
 444                                $match*)
 445                                        if [ -e "$dir/$i" ]; then
 446                                                echo "$pfx$i$sfx"
 447                                        fi
 448                                        ;;
 449                                esac
 450                        done
 451                        format="refname:strip=2"
 452                        refs=("refs/tags/$match*" "refs/tags/$match*/**"
 453                                "refs/heads/$match*" "refs/heads/$match*/**"
 454                                "refs/remotes/$match*" "refs/remotes/$match*/**")
 455                        ;;
 456                esac
 457                __git_dir="$dir" __git for-each-ref --format="$fer_pfx%($format)$sfx" \
 458                        "${refs[@]}"
 459                if [ -n "$track" ]; then
 460                        # employ the heuristic used by git checkout
 461                        # Try to find a remote branch that matches the completion word
 462                        # but only output if the branch name is unique
 463                        __git for-each-ref --format="$fer_pfx%(refname:strip=3)$sfx" \
 464                                --sort="refname:strip=3" \
 465                                "refs/remotes/*/$match*" "refs/remotes/*/$match*/**" | \
 466                        uniq -u
 467                fi
 468                return
 469        fi
 470        case "$cur_" in
 471        refs|refs/*)
 472                __git ls-remote "$remote" "$match*" | \
 473                while read -r hash i; do
 474                        case "$i" in
 475                        *^{}) ;;
 476                        *) echo "$pfx$i$sfx" ;;
 477                        esac
 478                done
 479                ;;
 480        *)
 481                if [ "$list_refs_from" = remote ]; then
 482                        case "HEAD" in
 483                        $match*)        echo "${pfx}HEAD$sfx" ;;
 484                        esac
 485                        __git for-each-ref --format="$fer_pfx%(refname:strip=3)$sfx" \
 486                                "refs/remotes/$remote/$match*" \
 487                                "refs/remotes/$remote/$match*/**"
 488                else
 489                        local query_symref
 490                        case "HEAD" in
 491                        $match*)        query_symref="HEAD" ;;
 492                        esac
 493                        __git ls-remote "$remote" $query_symref \
 494                                "refs/tags/$match*" "refs/heads/$match*" \
 495                                "refs/remotes/$match*" |
 496                        while read -r hash i; do
 497                                case "$i" in
 498                                *^{})   ;;
 499                                refs/*) echo "$pfx${i#refs/*/}$sfx" ;;
 500                                *)      echo "$pfx$i$sfx" ;;  # symbolic refs
 501                                esac
 502                        done
 503                fi
 504                ;;
 505        esac
 506}
 507
 508# Completes refs, short and long, local and remote, symbolic and pseudo.
 509#
 510# Usage: __git_complete_refs [<option>]...
 511# --remote=<remote>: The remote to list refs from, can be the name of a
 512#                    configured remote, a path, or a URL.
 513# --track: List unique remote branches for 'git checkout's tracking DWIMery.
 514# --pfx=<prefix>: A prefix to be added to each ref.
 515# --cur=<word>: The current ref to be completed.  Defaults to the current
 516#               word to be completed.
 517# --sfx=<suffix>: A suffix to be appended to each ref instead of the default
 518#                 space.
 519__git_complete_refs ()
 520{
 521        local remote track pfx cur_="$cur" sfx=" "
 522
 523        while test $# != 0; do
 524                case "$1" in
 525                --remote=*)     remote="${1##--remote=}" ;;
 526                --track)        track="yes" ;;
 527                --pfx=*)        pfx="${1##--pfx=}" ;;
 528                --cur=*)        cur_="${1##--cur=}" ;;
 529                --sfx=*)        sfx="${1##--sfx=}" ;;
 530                *)              return 1 ;;
 531                esac
 532                shift
 533        done
 534
 535        __gitcomp_direct "$(__git_refs "$remote" "$track" "$pfx" "$cur_" "$sfx")"
 536}
 537
 538# __git_refs2 requires 1 argument (to pass to __git_refs)
 539# Deprecated: use __git_complete_fetch_refspecs() instead.
 540__git_refs2 ()
 541{
 542        local i
 543        for i in $(__git_refs "$1"); do
 544                echo "$i:$i"
 545        done
 546}
 547
 548# Completes refspecs for fetching from a remote repository.
 549# 1: The remote repository.
 550# 2: A prefix to be added to each listed refspec (optional).
 551# 3: The ref to be completed as a refspec instead of the current word to be
 552#    completed (optional)
 553# 4: A suffix to be appended to each listed refspec instead of the default
 554#    space (optional).
 555__git_complete_fetch_refspecs ()
 556{
 557        local i remote="$1" pfx="${2-}" cur_="${3-$cur}" sfx="${4- }"
 558
 559        __gitcomp_direct "$(
 560                for i in $(__git_refs "$remote" "" "" "$cur_") ; do
 561                        echo "$pfx$i:$i$sfx"
 562                done
 563                )"
 564}
 565
 566# __git_refs_remotes requires 1 argument (to pass to ls-remote)
 567__git_refs_remotes ()
 568{
 569        local i hash
 570        __git ls-remote "$1" 'refs/heads/*' | \
 571        while read -r hash i; do
 572                echo "$i:refs/remotes/$1/${i#refs/heads/}"
 573        done
 574}
 575
 576__git_remotes ()
 577{
 578        __git_find_repo_path
 579        test -d "$__git_repo_path/remotes" && ls -1 "$__git_repo_path/remotes"
 580        __git remote
 581}
 582
 583# Returns true if $1 matches the name of a configured remote, false otherwise.
 584__git_is_configured_remote ()
 585{
 586        local remote
 587        for remote in $(__git_remotes); do
 588                if [ "$remote" = "$1" ]; then
 589                        return 0
 590                fi
 591        done
 592        return 1
 593}
 594
 595__git_list_merge_strategies ()
 596{
 597        LANG=C LC_ALL=C git merge -s help 2>&1 |
 598        sed -n -e '/[Aa]vailable strategies are: /,/^$/{
 599                s/\.$//
 600                s/.*://
 601                s/^[    ]*//
 602                s/[     ]*$//
 603                p
 604        }'
 605}
 606
 607__git_merge_strategies=
 608# 'git merge -s help' (and thus detection of the merge strategy
 609# list) fails, unfortunately, if run outside of any git working
 610# tree.  __git_merge_strategies is set to the empty string in
 611# that case, and the detection will be repeated the next time it
 612# is needed.
 613__git_compute_merge_strategies ()
 614{
 615        test -n "$__git_merge_strategies" ||
 616        __git_merge_strategies=$(__git_list_merge_strategies)
 617}
 618
 619__git_complete_revlist_file ()
 620{
 621        local pfx ls ref cur_="$cur"
 622        case "$cur_" in
 623        *..?*:*)
 624                return
 625                ;;
 626        ?*:*)
 627                ref="${cur_%%:*}"
 628                cur_="${cur_#*:}"
 629                case "$cur_" in
 630                ?*/*)
 631                        pfx="${cur_%/*}"
 632                        cur_="${cur_##*/}"
 633                        ls="$ref:$pfx"
 634                        pfx="$pfx/"
 635                        ;;
 636                *)
 637                        ls="$ref"
 638                        ;;
 639                esac
 640
 641                case "$COMP_WORDBREAKS" in
 642                *:*) : great ;;
 643                *)   pfx="$ref:$pfx" ;;
 644                esac
 645
 646                __gitcomp_nl "$(__git ls-tree "$ls" \
 647                                | sed '/^100... blob /{
 648                                           s,^.*        ,,
 649                                           s,$, ,
 650                                       }
 651                                       /^120000 blob /{
 652                                           s,^.*        ,,
 653                                           s,$, ,
 654                                       }
 655                                       /^040000 tree /{
 656                                           s,^.*        ,,
 657                                           s,$,/,
 658                                       }
 659                                       s/^.*    //')" \
 660                        "$pfx" "$cur_" ""
 661                ;;
 662        *...*)
 663                pfx="${cur_%...*}..."
 664                cur_="${cur_#*...}"
 665                __git_complete_refs --pfx="$pfx" --cur="$cur_"
 666                ;;
 667        *..*)
 668                pfx="${cur_%..*}.."
 669                cur_="${cur_#*..}"
 670                __git_complete_refs --pfx="$pfx" --cur="$cur_"
 671                ;;
 672        *)
 673                __git_complete_refs
 674                ;;
 675        esac
 676}
 677
 678
 679# __git_complete_index_file requires 1 argument:
 680# 1: the options to pass to ls-file
 681#
 682# The exception is --committable, which finds the files appropriate commit.
 683__git_complete_index_file ()
 684{
 685        local pfx="" cur_="$cur"
 686
 687        case "$cur_" in
 688        ?*/*)
 689                pfx="${cur_%/*}"
 690                cur_="${cur_##*/}"
 691                pfx="${pfx}/"
 692                ;;
 693        esac
 694
 695        __gitcomp_file "$(__git_index_files "$1" ${pfx:+"$pfx"})" "$pfx" "$cur_"
 696}
 697
 698__git_complete_file ()
 699{
 700        __git_complete_revlist_file
 701}
 702
 703__git_complete_revlist ()
 704{
 705        __git_complete_revlist_file
 706}
 707
 708__git_complete_remote_or_refspec ()
 709{
 710        local cur_="$cur" cmd="${words[1]}"
 711        local i c=2 remote="" pfx="" lhs=1 no_complete_refspec=0
 712        if [ "$cmd" = "remote" ]; then
 713                ((c++))
 714        fi
 715        while [ $c -lt $cword ]; do
 716                i="${words[c]}"
 717                case "$i" in
 718                --mirror) [ "$cmd" = "push" ] && no_complete_refspec=1 ;;
 719                -d|--delete) [ "$cmd" = "push" ] && lhs=0 ;;
 720                --all)
 721                        case "$cmd" in
 722                        push) no_complete_refspec=1 ;;
 723                        fetch)
 724                                return
 725                                ;;
 726                        *) ;;
 727                        esac
 728                        ;;
 729                -*) ;;
 730                *) remote="$i"; break ;;
 731                esac
 732                ((c++))
 733        done
 734        if [ -z "$remote" ]; then
 735                __gitcomp_nl "$(__git_remotes)"
 736                return
 737        fi
 738        if [ $no_complete_refspec = 1 ]; then
 739                return
 740        fi
 741        [ "$remote" = "." ] && remote=
 742        case "$cur_" in
 743        *:*)
 744                case "$COMP_WORDBREAKS" in
 745                *:*) : great ;;
 746                *)   pfx="${cur_%%:*}:" ;;
 747                esac
 748                cur_="${cur_#*:}"
 749                lhs=0
 750                ;;
 751        +*)
 752                pfx="+"
 753                cur_="${cur_#+}"
 754                ;;
 755        esac
 756        case "$cmd" in
 757        fetch)
 758                if [ $lhs = 1 ]; then
 759                        __git_complete_fetch_refspecs "$remote" "$pfx" "$cur_"
 760                else
 761                        __git_complete_refs --pfx="$pfx" --cur="$cur_"
 762                fi
 763                ;;
 764        pull|remote)
 765                if [ $lhs = 1 ]; then
 766                        __git_complete_refs --remote="$remote" --pfx="$pfx" --cur="$cur_"
 767                else
 768                        __git_complete_refs --pfx="$pfx" --cur="$cur_"
 769                fi
 770                ;;
 771        push)
 772                if [ $lhs = 1 ]; then
 773                        __git_complete_refs --pfx="$pfx" --cur="$cur_"
 774                else
 775                        __git_complete_refs --remote="$remote" --pfx="$pfx" --cur="$cur_"
 776                fi
 777                ;;
 778        esac
 779}
 780
 781__git_complete_strategy ()
 782{
 783        __git_compute_merge_strategies
 784        case "$prev" in
 785        -s|--strategy)
 786                __gitcomp "$__git_merge_strategies"
 787                return 0
 788        esac
 789        case "$cur" in
 790        --strategy=*)
 791                __gitcomp "$__git_merge_strategies" "" "${cur##--strategy=}"
 792                return 0
 793                ;;
 794        esac
 795        return 1
 796}
 797
 798__git_commands () {
 799        if test -n "${GIT_TESTING_COMMAND_COMPLETION:-}"
 800        then
 801                printf "%s" "${GIT_TESTING_COMMAND_COMPLETION}"
 802        else
 803                git help -a|egrep '^  [a-zA-Z0-9]'
 804        fi
 805}
 806
 807__git_list_all_commands ()
 808{
 809        local i IFS=" "$'\n'
 810        for i in $(__git_commands)
 811        do
 812                case $i in
 813                *--*)             : helper pattern;;
 814                *) echo $i;;
 815                esac
 816        done
 817}
 818
 819__git_all_commands=
 820__git_compute_all_commands ()
 821{
 822        test -n "$__git_all_commands" ||
 823        __git_all_commands=$(__git_list_all_commands)
 824}
 825
 826__git_list_porcelain_commands ()
 827{
 828        local i IFS=" "$'\n'
 829        __git_compute_all_commands
 830        for i in $__git_all_commands
 831        do
 832                case $i in
 833                *--*)             : helper pattern;;
 834                applymbox)        : ask gittus;;
 835                applypatch)       : ask gittus;;
 836                archimport)       : import;;
 837                cat-file)         : plumbing;;
 838                check-attr)       : plumbing;;
 839                check-ignore)     : plumbing;;
 840                check-mailmap)    : plumbing;;
 841                check-ref-format) : plumbing;;
 842                checkout-index)   : plumbing;;
 843                column)           : internal helper;;
 844                commit-tree)      : plumbing;;
 845                count-objects)    : infrequent;;
 846                credential)       : credentials;;
 847                credential-*)     : credentials helper;;
 848                cvsexportcommit)  : export;;
 849                cvsimport)        : import;;
 850                cvsserver)        : daemon;;
 851                daemon)           : daemon;;
 852                diff-files)       : plumbing;;
 853                diff-index)       : plumbing;;
 854                diff-tree)        : plumbing;;
 855                fast-import)      : import;;
 856                fast-export)      : export;;
 857                fsck-objects)     : plumbing;;
 858                fetch-pack)       : plumbing;;
 859                fmt-merge-msg)    : plumbing;;
 860                for-each-ref)     : plumbing;;
 861                hash-object)      : plumbing;;
 862                http-*)           : transport;;
 863                index-pack)       : plumbing;;
 864                init-db)          : deprecated;;
 865                local-fetch)      : plumbing;;
 866                ls-files)         : plumbing;;
 867                ls-remote)        : plumbing;;
 868                ls-tree)          : plumbing;;
 869                mailinfo)         : plumbing;;
 870                mailsplit)        : plumbing;;
 871                merge-*)          : plumbing;;
 872                mktree)           : plumbing;;
 873                mktag)            : plumbing;;
 874                pack-objects)     : plumbing;;
 875                pack-redundant)   : plumbing;;
 876                pack-refs)        : plumbing;;
 877                parse-remote)     : plumbing;;
 878                patch-id)         : plumbing;;
 879                prune)            : plumbing;;
 880                prune-packed)     : plumbing;;
 881                quiltimport)      : import;;
 882                read-tree)        : plumbing;;
 883                receive-pack)     : plumbing;;
 884                remote-*)         : transport;;
 885                rerere)           : plumbing;;
 886                rev-list)         : plumbing;;
 887                rev-parse)        : plumbing;;
 888                runstatus)        : plumbing;;
 889                sh-setup)         : internal;;
 890                shell)            : daemon;;
 891                show-ref)         : plumbing;;
 892                send-pack)        : plumbing;;
 893                show-index)       : plumbing;;
 894                ssh-*)            : transport;;
 895                stripspace)       : plumbing;;
 896                symbolic-ref)     : plumbing;;
 897                unpack-file)      : plumbing;;
 898                unpack-objects)   : plumbing;;
 899                update-index)     : plumbing;;
 900                update-ref)       : plumbing;;
 901                update-server-info) : daemon;;
 902                upload-archive)   : plumbing;;
 903                upload-pack)      : plumbing;;
 904                write-tree)       : plumbing;;
 905                var)              : infrequent;;
 906                verify-pack)      : infrequent;;
 907                verify-tag)       : plumbing;;
 908                *) echo $i;;
 909                esac
 910        done
 911}
 912
 913__git_porcelain_commands=
 914__git_compute_porcelain_commands ()
 915{
 916        test -n "$__git_porcelain_commands" ||
 917        __git_porcelain_commands=$(__git_list_porcelain_commands)
 918}
 919
 920# Lists all set config variables starting with the given section prefix,
 921# with the prefix removed.
 922__git_get_config_variables ()
 923{
 924        local section="$1" i IFS=$'\n'
 925        for i in $(__git config --name-only --get-regexp "^$section\..*"); do
 926                echo "${i#$section.}"
 927        done
 928}
 929
 930__git_pretty_aliases ()
 931{
 932        __git_get_config_variables "pretty"
 933}
 934
 935__git_aliases ()
 936{
 937        __git_get_config_variables "alias"
 938}
 939
 940# __git_aliased_command requires 1 argument
 941__git_aliased_command ()
 942{
 943        local word cmdline=$(__git config --get "alias.$1")
 944        for word in $cmdline; do
 945                case "$word" in
 946                \!gitk|gitk)
 947                        echo "gitk"
 948                        return
 949                        ;;
 950                \!*)    : shell command alias ;;
 951                -*)     : option ;;
 952                *=*)    : setting env ;;
 953                git)    : git itself ;;
 954                \(\))   : skip parens of shell function definition ;;
 955                {)      : skip start of shell helper function ;;
 956                :)      : skip null command ;;
 957                \'*)    : skip opening quote after sh -c ;;
 958                *)
 959                        echo "$word"
 960                        return
 961                esac
 962        done
 963}
 964
 965# __git_find_on_cmdline requires 1 argument
 966__git_find_on_cmdline ()
 967{
 968        local word subcommand c=1
 969        while [ $c -lt $cword ]; do
 970                word="${words[c]}"
 971                for subcommand in $1; do
 972                        if [ "$subcommand" = "$word" ]; then
 973                                echo "$subcommand"
 974                                return
 975                        fi
 976                done
 977                ((c++))
 978        done
 979}
 980
 981# Echo the value of an option set on the command line or config
 982#
 983# $1: short option name
 984# $2: long option name including =
 985# $3: list of possible values
 986# $4: config string (optional)
 987#
 988# example:
 989# result="$(__git_get_option_value "-d" "--do-something=" \
 990#     "yes no" "core.doSomething")"
 991#
 992# result is then either empty (no option set) or "yes" or "no"
 993#
 994# __git_get_option_value requires 3 arguments
 995__git_get_option_value ()
 996{
 997        local c short_opt long_opt val
 998        local result= values config_key word
 999
1000        short_opt="$1"
1001        long_opt="$2"
1002        values="$3"
1003        config_key="$4"
1004
1005        ((c = $cword - 1))
1006        while [ $c -ge 0 ]; do
1007                word="${words[c]}"
1008                for val in $values; do
1009                        if [ "$short_opt$val" = "$word" ] ||
1010                           [ "$long_opt$val"  = "$word" ]; then
1011                                result="$val"
1012                                break 2
1013                        fi
1014                done
1015                ((c--))
1016        done
1017
1018        if [ -n "$config_key" ] && [ -z "$result" ]; then
1019                result="$(__git config "$config_key")"
1020        fi
1021
1022        echo "$result"
1023}
1024
1025__git_has_doubledash ()
1026{
1027        local c=1
1028        while [ $c -lt $cword ]; do
1029                if [ "--" = "${words[c]}" ]; then
1030                        return 0
1031                fi
1032                ((c++))
1033        done
1034        return 1
1035}
1036
1037# Try to count non option arguments passed on the command line for the
1038# specified git command.
1039# When options are used, it is necessary to use the special -- option to
1040# tell the implementation were non option arguments begin.
1041# XXX this can not be improved, since options can appear everywhere, as
1042# an example:
1043#       git mv x -n y
1044#
1045# __git_count_arguments requires 1 argument: the git command executed.
1046__git_count_arguments ()
1047{
1048        local word i c=0
1049
1050        # Skip "git" (first argument)
1051        for ((i=1; i < ${#words[@]}; i++)); do
1052                word="${words[i]}"
1053
1054                case "$word" in
1055                        --)
1056                                # Good; we can assume that the following are only non
1057                                # option arguments.
1058                                ((c = 0))
1059                                ;;
1060                        "$1")
1061                                # Skip the specified git command and discard git
1062                                # main options
1063                                ((c = 0))
1064                                ;;
1065                        ?*)
1066                                ((c++))
1067                                ;;
1068                esac
1069        done
1070
1071        printf "%d" $c
1072}
1073
1074__git_whitespacelist="nowarn warn error error-all fix"
1075
1076_git_am ()
1077{
1078        __git_find_repo_path
1079        if [ -d "$__git_repo_path"/rebase-apply ]; then
1080                __gitcomp "--skip --continue --resolved --abort"
1081                return
1082        fi
1083        case "$cur" in
1084        --whitespace=*)
1085                __gitcomp "$__git_whitespacelist" "" "${cur##--whitespace=}"
1086                return
1087                ;;
1088        --*)
1089                __gitcomp "
1090                        --3way --committer-date-is-author-date --ignore-date
1091                        --ignore-whitespace --ignore-space-change
1092                        --interactive --keep --no-utf8 --signoff --utf8
1093                        --whitespace= --scissors
1094                        "
1095                return
1096        esac
1097}
1098
1099_git_apply ()
1100{
1101        case "$cur" in
1102        --whitespace=*)
1103                __gitcomp "$__git_whitespacelist" "" "${cur##--whitespace=}"
1104                return
1105                ;;
1106        --*)
1107                __gitcomp "
1108                        --stat --numstat --summary --check --index
1109                        --cached --index-info --reverse --reject --unidiff-zero
1110                        --apply --no-add --exclude=
1111                        --ignore-whitespace --ignore-space-change
1112                        --whitespace= --inaccurate-eof --verbose
1113                        --recount --directory=
1114                        "
1115                return
1116        esac
1117}
1118
1119_git_add ()
1120{
1121        case "$cur" in
1122        --*)
1123                __gitcomp "
1124                        --interactive --refresh --patch --update --dry-run
1125                        --ignore-errors --intent-to-add --force --edit --chmod=
1126                        "
1127                return
1128        esac
1129
1130        local complete_opt="--others --modified --directory --no-empty-directory"
1131        if test -n "$(__git_find_on_cmdline "-u --update")"
1132        then
1133                complete_opt="--modified"
1134        fi
1135        __git_complete_index_file "$complete_opt"
1136}
1137
1138_git_archive ()
1139{
1140        case "$cur" in
1141        --format=*)
1142                __gitcomp "$(git archive --list)" "" "${cur##--format=}"
1143                return
1144                ;;
1145        --remote=*)
1146                __gitcomp_nl "$(__git_remotes)" "" "${cur##--remote=}"
1147                return
1148                ;;
1149        --*)
1150                __gitcomp "
1151                        --format= --list --verbose
1152                        --prefix= --remote= --exec= --output
1153                        "
1154                return
1155                ;;
1156        esac
1157        __git_complete_file
1158}
1159
1160_git_bisect ()
1161{
1162        __git_has_doubledash && return
1163
1164        local subcommands="start bad good skip reset visualize replay log run"
1165        local subcommand="$(__git_find_on_cmdline "$subcommands")"
1166        if [ -z "$subcommand" ]; then
1167                __git_find_repo_path
1168                if [ -f "$__git_repo_path"/BISECT_START ]; then
1169                        __gitcomp "$subcommands"
1170                else
1171                        __gitcomp "replay start"
1172                fi
1173                return
1174        fi
1175
1176        case "$subcommand" in
1177        bad|good|reset|skip|start)
1178                __git_complete_refs
1179                ;;
1180        *)
1181                ;;
1182        esac
1183}
1184
1185_git_branch ()
1186{
1187        local i c=1 only_local_ref="n" has_r="n"
1188
1189        while [ $c -lt $cword ]; do
1190                i="${words[c]}"
1191                case "$i" in
1192                -d|--delete|-m|--move)  only_local_ref="y" ;;
1193                -r|--remotes)           has_r="y" ;;
1194                esac
1195                ((c++))
1196        done
1197
1198        case "$cur" in
1199        --set-upstream-to=*)
1200                __git_complete_refs --cur="${cur##--set-upstream-to=}"
1201                ;;
1202        --*)
1203                __gitcomp "
1204                        --color --no-color --verbose --abbrev= --no-abbrev
1205                        --track --no-track --contains --no-contains --merged --no-merged
1206                        --set-upstream-to= --edit-description --list
1207                        --unset-upstream --delete --move --copy --remotes
1208                        --column --no-column --sort= --points-at
1209                        "
1210                ;;
1211        *)
1212                if [ $only_local_ref = "y" -a $has_r = "n" ]; then
1213                        __gitcomp_direct "$(__git_heads "" "$cur" " ")"
1214                else
1215                        __git_complete_refs
1216                fi
1217                ;;
1218        esac
1219}
1220
1221_git_bundle ()
1222{
1223        local cmd="${words[2]}"
1224        case "$cword" in
1225        2)
1226                __gitcomp "create list-heads verify unbundle"
1227                ;;
1228        3)
1229                # looking for a file
1230                ;;
1231        *)
1232                case "$cmd" in
1233                        create)
1234                                __git_complete_revlist
1235                        ;;
1236                esac
1237                ;;
1238        esac
1239}
1240
1241_git_checkout ()
1242{
1243        __git_has_doubledash && return
1244
1245        case "$cur" in
1246        --conflict=*)
1247                __gitcomp "diff3 merge" "" "${cur##--conflict=}"
1248                ;;
1249        --*)
1250                __gitcomp "
1251                        --quiet --ours --theirs --track --no-track --merge
1252                        --conflict= --orphan --patch --detach --ignore-skip-worktree-bits
1253                        --recurse-submodules --no-recurse-submodules
1254                        "
1255                ;;
1256        *)
1257                # check if --track, --no-track, or --no-guess was specified
1258                # if so, disable DWIM mode
1259                local flags="--track --no-track --no-guess" track_opt="--track"
1260                if [ "$GIT_COMPLETION_CHECKOUT_NO_GUESS" = "1" ] ||
1261                   [ -n "$(__git_find_on_cmdline "$flags")" ]; then
1262                        track_opt=''
1263                fi
1264                __git_complete_refs $track_opt
1265                ;;
1266        esac
1267}
1268
1269_git_cherry ()
1270{
1271        __git_complete_refs
1272}
1273
1274_git_cherry_pick ()
1275{
1276        __git_find_repo_path
1277        if [ -f "$__git_repo_path"/CHERRY_PICK_HEAD ]; then
1278                __gitcomp "--continue --quit --abort"
1279                return
1280        fi
1281        case "$cur" in
1282        --*)
1283                __gitcomp "--edit --no-commit --signoff --strategy= --mainline"
1284                ;;
1285        *)
1286                __git_complete_refs
1287                ;;
1288        esac
1289}
1290
1291_git_clean ()
1292{
1293        case "$cur" in
1294        --*)
1295                __gitcomp "--dry-run --quiet"
1296                return
1297                ;;
1298        esac
1299
1300        # XXX should we check for -x option ?
1301        __git_complete_index_file "--others --directory"
1302}
1303
1304_git_clone ()
1305{
1306        case "$cur" in
1307        --*)
1308                __gitcomp "
1309                        --local
1310                        --no-hardlinks
1311                        --shared
1312                        --reference
1313                        --quiet
1314                        --no-checkout
1315                        --bare
1316                        --mirror
1317                        --origin
1318                        --upload-pack
1319                        --template=
1320                        --depth
1321                        --single-branch
1322                        --no-tags
1323                        --branch
1324                        --recurse-submodules
1325                        --no-single-branch
1326                        --shallow-submodules
1327                        "
1328                return
1329                ;;
1330        esac
1331}
1332
1333__git_untracked_file_modes="all no normal"
1334
1335_git_commit ()
1336{
1337        case "$prev" in
1338        -c|-C)
1339                __git_complete_refs
1340                return
1341                ;;
1342        esac
1343
1344        case "$cur" in
1345        --cleanup=*)
1346                __gitcomp "default scissors strip verbatim whitespace
1347                        " "" "${cur##--cleanup=}"
1348                return
1349                ;;
1350        --reuse-message=*|--reedit-message=*|\
1351        --fixup=*|--squash=*)
1352                __git_complete_refs --cur="${cur#*=}"
1353                return
1354                ;;
1355        --untracked-files=*)
1356                __gitcomp "$__git_untracked_file_modes" "" "${cur##--untracked-files=}"
1357                return
1358                ;;
1359        --*)
1360                __gitcomp "
1361                        --all --author= --signoff --verify --no-verify
1362                        --edit --no-edit
1363                        --amend --include --only --interactive
1364                        --dry-run --reuse-message= --reedit-message=
1365                        --reset-author --file= --message= --template=
1366                        --cleanup= --untracked-files --untracked-files=
1367                        --verbose --quiet --fixup= --squash=
1368                        --patch --short --date --allow-empty
1369                        "
1370                return
1371        esac
1372
1373        if __git rev-parse --verify --quiet HEAD >/dev/null; then
1374                __git_complete_index_file "--committable"
1375        else
1376                # This is the first commit
1377                __git_complete_index_file "--cached"
1378        fi
1379}
1380
1381_git_describe ()
1382{
1383        case "$cur" in
1384        --*)
1385                __gitcomp "
1386                        --all --tags --contains --abbrev= --candidates=
1387                        --exact-match --debug --long --match --always --first-parent
1388                        --exclude --dirty --broken
1389                        "
1390                return
1391        esac
1392        __git_complete_refs
1393}
1394
1395__git_diff_algorithms="myers minimal patience histogram"
1396
1397__git_diff_submodule_formats="diff log short"
1398
1399__git_diff_common_options="--stat --numstat --shortstat --summary
1400                        --patch-with-stat --name-only --name-status --color
1401                        --no-color --color-words --no-renames --check
1402                        --full-index --binary --abbrev --diff-filter=
1403                        --find-copies-harder --ignore-cr-at-eol
1404                        --text --ignore-space-at-eol --ignore-space-change
1405                        --ignore-all-space --ignore-blank-lines --exit-code
1406                        --quiet --ext-diff --no-ext-diff
1407                        --no-prefix --src-prefix= --dst-prefix=
1408                        --inter-hunk-context=
1409                        --patience --histogram --minimal
1410                        --raw --word-diff --word-diff-regex=
1411                        --dirstat --dirstat= --dirstat-by-file
1412                        --dirstat-by-file= --cumulative
1413                        --diff-algorithm=
1414                        --submodule --submodule=
1415"
1416
1417_git_diff ()
1418{
1419        __git_has_doubledash && return
1420
1421        case "$cur" in
1422        --diff-algorithm=*)
1423                __gitcomp "$__git_diff_algorithms" "" "${cur##--diff-algorithm=}"
1424                return
1425                ;;
1426        --submodule=*)
1427                __gitcomp "$__git_diff_submodule_formats" "" "${cur##--submodule=}"
1428                return
1429                ;;
1430        --*)
1431                __gitcomp "--cached --staged --pickaxe-all --pickaxe-regex
1432                        --base --ours --theirs --no-index
1433                        $__git_diff_common_options
1434                        "
1435                return
1436                ;;
1437        esac
1438        __git_complete_revlist_file
1439}
1440
1441__git_mergetools_common="diffuse diffmerge ecmerge emerge kdiff3 meld opendiff
1442                        tkdiff vimdiff gvimdiff xxdiff araxis p4merge bc codecompare
1443"
1444
1445_git_difftool ()
1446{
1447        __git_has_doubledash && return
1448
1449        case "$cur" in
1450        --tool=*)
1451                __gitcomp "$__git_mergetools_common kompare" "" "${cur##--tool=}"
1452                return
1453                ;;
1454        --*)
1455                __gitcomp "--cached --staged --pickaxe-all --pickaxe-regex
1456                        --base --ours --theirs
1457                        --no-renames --diff-filter= --find-copies-harder
1458                        --relative --ignore-submodules
1459                        --tool="
1460                return
1461                ;;
1462        esac
1463        __git_complete_revlist_file
1464}
1465
1466__git_fetch_recurse_submodules="yes on-demand no"
1467
1468__git_fetch_options="
1469        --quiet --verbose --append --upload-pack --force --keep --depth=
1470        --tags --no-tags --all --prune --dry-run --recurse-submodules=
1471        --unshallow --update-shallow
1472"
1473
1474_git_fetch ()
1475{
1476        case "$cur" in
1477        --recurse-submodules=*)
1478                __gitcomp "$__git_fetch_recurse_submodules" "" "${cur##--recurse-submodules=}"
1479                return
1480                ;;
1481        --*)
1482                __gitcomp "$__git_fetch_options"
1483                return
1484                ;;
1485        esac
1486        __git_complete_remote_or_refspec
1487}
1488
1489__git_format_patch_options="
1490        --stdout --attach --no-attach --thread --thread= --no-thread
1491        --numbered --start-number --numbered-files --keep-subject --signoff
1492        --signature --no-signature --in-reply-to= --cc= --full-index --binary
1493        --not --all --cover-letter --no-prefix --src-prefix= --dst-prefix=
1494        --inline --suffix= --ignore-if-in-upstream --subject-prefix=
1495        --output-directory --reroll-count --to= --quiet --notes
1496"
1497
1498_git_format_patch ()
1499{
1500        case "$cur" in
1501        --thread=*)
1502                __gitcomp "
1503                        deep shallow
1504                        " "" "${cur##--thread=}"
1505                return
1506                ;;
1507        --*)
1508                __gitcomp "$__git_format_patch_options"
1509                return
1510                ;;
1511        esac
1512        __git_complete_revlist
1513}
1514
1515_git_fsck ()
1516{
1517        case "$cur" in
1518        --*)
1519                __gitcomp "
1520                        --tags --root --unreachable --cache --no-reflogs --full
1521                        --strict --verbose --lost-found --name-objects
1522                        "
1523                return
1524                ;;
1525        esac
1526}
1527
1528_git_gc ()
1529{
1530        case "$cur" in
1531        --*)
1532                __gitcomp "--prune --aggressive"
1533                return
1534                ;;
1535        esac
1536}
1537
1538_git_gitk ()
1539{
1540        _gitk
1541}
1542
1543# Lists matching symbol names from a tag (as in ctags) file.
1544# 1: List symbol names matching this word.
1545# 2: The tag file to list symbol names from.
1546# 3: A prefix to be added to each listed symbol name (optional).
1547# 4: A suffix to be appended to each listed symbol name (optional).
1548__git_match_ctag () {
1549        awk -v pfx="${3-}" -v sfx="${4-}" "
1550                /^${1//\//\\/}/ { print pfx \$1 sfx }
1551                " "$2"
1552}
1553
1554# Complete symbol names from a tag file.
1555# Usage: __git_complete_symbol [<option>]...
1556# --tags=<file>: The tag file to list symbol names from instead of the
1557#                default "tags".
1558# --pfx=<prefix>: A prefix to be added to each symbol name.
1559# --cur=<word>: The current symbol name to be completed.  Defaults to
1560#               the current word to be completed.
1561# --sfx=<suffix>: A suffix to be appended to each symbol name instead
1562#                 of the default space.
1563__git_complete_symbol () {
1564        local tags=tags pfx="" cur_="${cur-}" sfx=" "
1565
1566        while test $# != 0; do
1567                case "$1" in
1568                --tags=*)       tags="${1##--tags=}" ;;
1569                --pfx=*)        pfx="${1##--pfx=}" ;;
1570                --cur=*)        cur_="${1##--cur=}" ;;
1571                --sfx=*)        sfx="${1##--sfx=}" ;;
1572                *)              return 1 ;;
1573                esac
1574                shift
1575        done
1576
1577        if test -r "$tags"; then
1578                __gitcomp_direct "$(__git_match_ctag "$cur_" "$tags" "$pfx" "$sfx")"
1579        fi
1580}
1581
1582_git_grep ()
1583{
1584        __git_has_doubledash && return
1585
1586        case "$cur" in
1587        --*)
1588                __gitcomp "
1589                        --cached
1590                        --text --ignore-case --word-regexp --invert-match
1591                        --full-name --line-number
1592                        --extended-regexp --basic-regexp --fixed-strings
1593                        --perl-regexp
1594                        --threads
1595                        --files-with-matches --name-only
1596                        --files-without-match
1597                        --max-depth
1598                        --count
1599                        --and --or --not --all-match
1600                        --break --heading --show-function --function-context
1601                        --untracked --no-index
1602                        "
1603                return
1604                ;;
1605        esac
1606
1607        case "$cword,$prev" in
1608        2,*|*,-*)
1609                __git_complete_symbol && return
1610                ;;
1611        esac
1612
1613        __git_complete_refs
1614}
1615
1616_git_help ()
1617{
1618        case "$cur" in
1619        --*)
1620                __gitcomp "--all --guides --info --man --web"
1621                return
1622                ;;
1623        esac
1624        __git_compute_all_commands
1625        __gitcomp "$__git_all_commands $(__git_aliases)
1626                attributes cli core-tutorial cvs-migration
1627                diffcore everyday gitk glossary hooks ignore modules
1628                namespaces repository-layout revisions tutorial tutorial-2
1629                workflows
1630                "
1631}
1632
1633_git_init ()
1634{
1635        case "$cur" in
1636        --shared=*)
1637                __gitcomp "
1638                        false true umask group all world everybody
1639                        " "" "${cur##--shared=}"
1640                return
1641                ;;
1642        --*)
1643                __gitcomp "--quiet --bare --template= --shared --shared="
1644                return
1645                ;;
1646        esac
1647}
1648
1649_git_ls_files ()
1650{
1651        case "$cur" in
1652        --*)
1653                __gitcomp "--cached --deleted --modified --others --ignored
1654                        --stage --directory --no-empty-directory --unmerged
1655                        --killed --exclude= --exclude-from=
1656                        --exclude-per-directory= --exclude-standard
1657                        --error-unmatch --with-tree= --full-name
1658                        --abbrev --ignored --exclude-per-directory
1659                        "
1660                return
1661                ;;
1662        esac
1663
1664        # XXX ignore options like --modified and always suggest all cached
1665        # files.
1666        __git_complete_index_file "--cached"
1667}
1668
1669_git_ls_remote ()
1670{
1671        case "$cur" in
1672        --*)
1673                __gitcomp "--heads --tags --refs --get-url --symref"
1674                return
1675                ;;
1676        esac
1677        __gitcomp_nl "$(__git_remotes)"
1678}
1679
1680_git_ls_tree ()
1681{
1682        __git_complete_file
1683}
1684
1685# Options that go well for log, shortlog and gitk
1686__git_log_common_options="
1687        --not --all
1688        --branches --tags --remotes
1689        --first-parent --merges --no-merges
1690        --max-count=
1691        --max-age= --since= --after=
1692        --min-age= --until= --before=
1693        --min-parents= --max-parents=
1694        --no-min-parents --no-max-parents
1695"
1696# Options that go well for log and gitk (not shortlog)
1697__git_log_gitk_options="
1698        --dense --sparse --full-history
1699        --simplify-merges --simplify-by-decoration
1700        --left-right --notes --no-notes
1701"
1702# Options that go well for log and shortlog (not gitk)
1703__git_log_shortlog_options="
1704        --author= --committer= --grep=
1705        --all-match --invert-grep
1706"
1707
1708__git_log_pretty_formats="oneline short medium full fuller email raw format:"
1709__git_log_date_formats="relative iso8601 rfc2822 short local default raw"
1710
1711_git_log ()
1712{
1713        __git_has_doubledash && return
1714        __git_find_repo_path
1715
1716        local merge=""
1717        if [ -f "$__git_repo_path/MERGE_HEAD" ]; then
1718                merge="--merge"
1719        fi
1720        case "$prev,$cur" in
1721        -L,:*:*)
1722                return  # fall back to Bash filename completion
1723                ;;
1724        -L,:*)
1725                __git_complete_symbol --cur="${cur#:}" --sfx=":"
1726                return
1727                ;;
1728        -G,*|-S,*)
1729                __git_complete_symbol
1730                return
1731                ;;
1732        esac
1733        case "$cur" in
1734        --pretty=*|--format=*)
1735                __gitcomp "$__git_log_pretty_formats $(__git_pretty_aliases)
1736                        " "" "${cur#*=}"
1737                return
1738                ;;
1739        --date=*)
1740                __gitcomp "$__git_log_date_formats" "" "${cur##--date=}"
1741                return
1742                ;;
1743        --decorate=*)
1744                __gitcomp "full short no" "" "${cur##--decorate=}"
1745                return
1746                ;;
1747        --diff-algorithm=*)
1748                __gitcomp "$__git_diff_algorithms" "" "${cur##--diff-algorithm=}"
1749                return
1750                ;;
1751        --submodule=*)
1752                __gitcomp "$__git_diff_submodule_formats" "" "${cur##--submodule=}"
1753                return
1754                ;;
1755        --*)
1756                __gitcomp "
1757                        $__git_log_common_options
1758                        $__git_log_shortlog_options
1759                        $__git_log_gitk_options
1760                        --root --topo-order --date-order --reverse
1761                        --follow --full-diff
1762                        --abbrev-commit --abbrev=
1763                        --relative-date --date=
1764                        --pretty= --format= --oneline
1765                        --show-signature
1766                        --cherry-mark
1767                        --cherry-pick
1768                        --graph
1769                        --decorate --decorate=
1770                        --walk-reflogs
1771                        --parents --children
1772                        $merge
1773                        $__git_diff_common_options
1774                        --pickaxe-all --pickaxe-regex
1775                        "
1776                return
1777                ;;
1778        -L:*:*)
1779                return  # fall back to Bash filename completion
1780                ;;
1781        -L:*)
1782                __git_complete_symbol --cur="${cur#-L:}" --sfx=":"
1783                return
1784                ;;
1785        -G*)
1786                __git_complete_symbol --pfx="-G" --cur="${cur#-G}"
1787                return
1788                ;;
1789        -S*)
1790                __git_complete_symbol --pfx="-S" --cur="${cur#-S}"
1791                return
1792                ;;
1793        esac
1794        __git_complete_revlist
1795}
1796
1797# Common merge options shared by git-merge(1) and git-pull(1).
1798__git_merge_options="
1799        --no-commit --no-stat --log --no-log --squash --strategy
1800        --commit --stat --no-squash --ff --no-ff --ff-only --edit --no-edit
1801        --verify-signatures --no-verify-signatures --gpg-sign
1802        --quiet --verbose --progress --no-progress
1803"
1804
1805_git_merge ()
1806{
1807        __git_complete_strategy && return
1808
1809        case "$cur" in
1810        --*)
1811                __gitcomp "$__git_merge_options
1812                        --rerere-autoupdate --no-rerere-autoupdate --abort --continue"
1813                return
1814        esac
1815        __git_complete_refs
1816}
1817
1818_git_mergetool ()
1819{
1820        case "$cur" in
1821        --tool=*)
1822                __gitcomp "$__git_mergetools_common tortoisemerge" "" "${cur##--tool=}"
1823                return
1824                ;;
1825        --*)
1826                __gitcomp "--tool= --prompt --no-prompt"
1827                return
1828                ;;
1829        esac
1830}
1831
1832_git_merge_base ()
1833{
1834        case "$cur" in
1835        --*)
1836                __gitcomp "--octopus --independent --is-ancestor --fork-point"
1837                return
1838                ;;
1839        esac
1840        __git_complete_refs
1841}
1842
1843_git_mv ()
1844{
1845        case "$cur" in
1846        --*)
1847                __gitcomp "--dry-run"
1848                return
1849                ;;
1850        esac
1851
1852        if [ $(__git_count_arguments "mv") -gt 0 ]; then
1853                # We need to show both cached and untracked files (including
1854                # empty directories) since this may not be the last argument.
1855                __git_complete_index_file "--cached --others --directory"
1856        else
1857                __git_complete_index_file "--cached"
1858        fi
1859}
1860
1861_git_name_rev ()
1862{
1863        __gitcomp "--tags --all --stdin"
1864}
1865
1866_git_notes ()
1867{
1868        local subcommands='add append copy edit list prune remove show'
1869        local subcommand="$(__git_find_on_cmdline "$subcommands")"
1870
1871        case "$subcommand,$cur" in
1872        ,--*)
1873                __gitcomp '--ref'
1874                ;;
1875        ,*)
1876                case "$prev" in
1877                --ref)
1878                        __git_complete_refs
1879                        ;;
1880                *)
1881                        __gitcomp "$subcommands --ref"
1882                        ;;
1883                esac
1884                ;;
1885        add,--reuse-message=*|append,--reuse-message=*|\
1886        add,--reedit-message=*|append,--reedit-message=*)
1887                __git_complete_refs --cur="${cur#*=}"
1888                ;;
1889        add,--*|append,--*)
1890                __gitcomp '--file= --message= --reedit-message=
1891                                --reuse-message='
1892                ;;
1893        copy,--*)
1894                __gitcomp '--stdin'
1895                ;;
1896        prune,--*)
1897                __gitcomp '--dry-run --verbose'
1898                ;;
1899        prune,*)
1900                ;;
1901        *)
1902                case "$prev" in
1903                -m|-F)
1904                        ;;
1905                *)
1906                        __git_complete_refs
1907                        ;;
1908                esac
1909                ;;
1910        esac
1911}
1912
1913_git_pull ()
1914{
1915        __git_complete_strategy && return
1916
1917        case "$cur" in
1918        --recurse-submodules=*)
1919                __gitcomp "$__git_fetch_recurse_submodules" "" "${cur##--recurse-submodules=}"
1920                return
1921                ;;
1922        --*)
1923                __gitcomp "
1924                        --rebase --no-rebase
1925                        --autostash --no-autostash
1926                        $__git_merge_options
1927                        $__git_fetch_options
1928                "
1929                return
1930                ;;
1931        esac
1932        __git_complete_remote_or_refspec
1933}
1934
1935__git_push_recurse_submodules="check on-demand only"
1936
1937__git_complete_force_with_lease ()
1938{
1939        local cur_=$1
1940
1941        case "$cur_" in
1942        --*=)
1943                ;;
1944        *:*)
1945                __git_complete_refs --cur="${cur_#*:}"
1946                ;;
1947        *)
1948                __git_complete_refs --cur="$cur_"
1949                ;;
1950        esac
1951}
1952
1953_git_push ()
1954{
1955        case "$prev" in
1956        --repo)
1957                __gitcomp_nl "$(__git_remotes)"
1958                return
1959                ;;
1960        --recurse-submodules)
1961                __gitcomp "$__git_push_recurse_submodules"
1962                return
1963                ;;
1964        esac
1965        case "$cur" in
1966        --repo=*)
1967                __gitcomp_nl "$(__git_remotes)" "" "${cur##--repo=}"
1968                return
1969                ;;
1970        --recurse-submodules=*)
1971                __gitcomp "$__git_push_recurse_submodules" "" "${cur##--recurse-submodules=}"
1972                return
1973                ;;
1974        --force-with-lease=*)
1975                __git_complete_force_with_lease "${cur##--force-with-lease=}"
1976                return
1977                ;;
1978        --*)
1979                __gitcomp "
1980                        --all --mirror --tags --dry-run --force --verbose
1981                        --quiet --prune --delete --follow-tags
1982                        --receive-pack= --repo= --set-upstream
1983                        --force-with-lease --force-with-lease= --recurse-submodules=
1984                "
1985                return
1986                ;;
1987        esac
1988        __git_complete_remote_or_refspec
1989}
1990
1991_git_rebase ()
1992{
1993        __git_find_repo_path
1994        if [ -f "$__git_repo_path"/rebase-merge/interactive ]; then
1995                __gitcomp "--continue --skip --abort --quit --edit-todo"
1996                return
1997        elif [ -d "$__git_repo_path"/rebase-apply ] || \
1998             [ -d "$__git_repo_path"/rebase-merge ]; then
1999                __gitcomp "--continue --skip --abort --quit"
2000                return
2001        fi
2002        __git_complete_strategy && return
2003        case "$cur" in
2004        --whitespace=*)
2005                __gitcomp "$__git_whitespacelist" "" "${cur##--whitespace=}"
2006                return
2007                ;;
2008        --*)
2009                __gitcomp "
2010                        --onto --merge --strategy --interactive
2011                        --preserve-merges --stat --no-stat
2012                        --committer-date-is-author-date --ignore-date
2013                        --ignore-whitespace --whitespace=
2014                        --autosquash --no-autosquash
2015                        --fork-point --no-fork-point
2016                        --autostash --no-autostash
2017                        --verify --no-verify
2018                        --keep-empty --root --force-rebase --no-ff
2019                        --exec
2020                        "
2021
2022                return
2023        esac
2024        __git_complete_refs
2025}
2026
2027_git_reflog ()
2028{
2029        local subcommands="show delete expire"
2030        local subcommand="$(__git_find_on_cmdline "$subcommands")"
2031
2032        if [ -z "$subcommand" ]; then
2033                __gitcomp "$subcommands"
2034        else
2035                __git_complete_refs
2036        fi
2037}
2038
2039__git_send_email_confirm_options="always never auto cc compose"
2040__git_send_email_suppresscc_options="author self cc bodycc sob cccmd body all"
2041
2042_git_send_email ()
2043{
2044        case "$prev" in
2045        --to|--cc|--bcc|--from)
2046                __gitcomp "$(__git send-email --dump-aliases)"
2047                return
2048                ;;
2049        esac
2050
2051        case "$cur" in
2052        --confirm=*)
2053                __gitcomp "
2054                        $__git_send_email_confirm_options
2055                        " "" "${cur##--confirm=}"
2056                return
2057                ;;
2058        --suppress-cc=*)
2059                __gitcomp "
2060                        $__git_send_email_suppresscc_options
2061                        " "" "${cur##--suppress-cc=}"
2062
2063                return
2064                ;;
2065        --smtp-encryption=*)
2066                __gitcomp "ssl tls" "" "${cur##--smtp-encryption=}"
2067                return
2068                ;;
2069        --thread=*)
2070                __gitcomp "
2071                        deep shallow
2072                        " "" "${cur##--thread=}"
2073                return
2074                ;;
2075        --to=*|--cc=*|--bcc=*|--from=*)
2076                __gitcomp "$(__git send-email --dump-aliases)" "" "${cur#--*=}"
2077                return
2078                ;;
2079        --*)
2080                __gitcomp "--annotate --bcc --cc --cc-cmd --chain-reply-to
2081                        --compose --confirm= --dry-run --envelope-sender
2082                        --from --identity
2083                        --in-reply-to --no-chain-reply-to --no-signed-off-by-cc
2084                        --no-suppress-from --no-thread --quiet
2085                        --signed-off-by-cc --smtp-pass --smtp-server
2086                        --smtp-server-port --smtp-encryption= --smtp-user
2087                        --subject --suppress-cc= --suppress-from --thread --to
2088                        --validate --no-validate
2089                        $__git_format_patch_options"
2090                return
2091                ;;
2092        esac
2093        __git_complete_revlist
2094}
2095
2096_git_stage ()
2097{
2098        _git_add
2099}
2100
2101_git_status ()
2102{
2103        local complete_opt
2104        local untracked_state
2105
2106        case "$cur" in
2107        --ignore-submodules=*)
2108                __gitcomp "none untracked dirty all" "" "${cur##--ignore-submodules=}"
2109                return
2110                ;;
2111        --untracked-files=*)
2112                __gitcomp "$__git_untracked_file_modes" "" "${cur##--untracked-files=}"
2113                return
2114                ;;
2115        --column=*)
2116                __gitcomp "
2117                        always never auto column row plain dense nodense
2118                        " "" "${cur##--column=}"
2119                return
2120                ;;
2121        --*)
2122                __gitcomp "
2123                        --short --branch --porcelain --long --verbose
2124                        --untracked-files= --ignore-submodules= --ignored
2125                        --column= --no-column
2126                        "
2127                return
2128                ;;
2129        esac
2130
2131        untracked_state="$(__git_get_option_value "-u" "--untracked-files=" \
2132                "$__git_untracked_file_modes" "status.showUntrackedFiles")"
2133
2134        case "$untracked_state" in
2135        no)
2136                # --ignored option does not matter
2137                complete_opt=
2138                ;;
2139        all|normal|*)
2140                complete_opt="--cached --directory --no-empty-directory --others"
2141
2142                if [ -n "$(__git_find_on_cmdline "--ignored")" ]; then
2143                        complete_opt="$complete_opt --ignored --exclude=*"
2144                fi
2145                ;;
2146        esac
2147
2148        __git_complete_index_file "$complete_opt"
2149}
2150
2151__git_config_get_set_variables ()
2152{
2153        local prevword word config_file= c=$cword
2154        while [ $c -gt 1 ]; do
2155                word="${words[c]}"
2156                case "$word" in
2157                --system|--global|--local|--file=*)
2158                        config_file="$word"
2159                        break
2160                        ;;
2161                -f|--file)
2162                        config_file="$word $prevword"
2163                        break
2164                        ;;
2165                esac
2166                prevword=$word
2167                c=$((--c))
2168        done
2169
2170        __git config $config_file --name-only --list
2171}
2172
2173_git_config ()
2174{
2175        case "$prev" in
2176        branch.*.remote|branch.*.pushremote)
2177                __gitcomp_nl "$(__git_remotes)"
2178                return
2179                ;;
2180        branch.*.merge)
2181                __git_complete_refs
2182                return
2183                ;;
2184        branch.*.rebase)
2185                __gitcomp "false true preserve interactive"
2186                return
2187                ;;
2188        remote.pushdefault)
2189                __gitcomp_nl "$(__git_remotes)"
2190                return
2191                ;;
2192        remote.*.fetch)
2193                local remote="${prev#remote.}"
2194                remote="${remote%.fetch}"
2195                if [ -z "$cur" ]; then
2196                        __gitcomp_nl "refs/heads/" "" "" ""
2197                        return
2198                fi
2199                __gitcomp_nl "$(__git_refs_remotes "$remote")"
2200                return
2201                ;;
2202        remote.*.push)
2203                local remote="${prev#remote.}"
2204                remote="${remote%.push}"
2205                __gitcomp_nl "$(__git for-each-ref \
2206                        --format='%(refname):%(refname)' refs/heads)"
2207                return
2208                ;;
2209        pull.twohead|pull.octopus)
2210                __git_compute_merge_strategies
2211                __gitcomp "$__git_merge_strategies"
2212                return
2213                ;;
2214        color.branch|color.diff|color.interactive|\
2215        color.showbranch|color.status|color.ui)
2216                __gitcomp "always never auto"
2217                return
2218                ;;
2219        color.pager)
2220                __gitcomp "false true"
2221                return
2222                ;;
2223        color.*.*)
2224                __gitcomp "
2225                        normal black red green yellow blue magenta cyan white
2226                        bold dim ul blink reverse
2227                        "
2228                return
2229                ;;
2230        diff.submodule)
2231                __gitcomp "log short"
2232                return
2233                ;;
2234        help.format)
2235                __gitcomp "man info web html"
2236                return
2237                ;;
2238        log.date)
2239                __gitcomp "$__git_log_date_formats"
2240                return
2241                ;;
2242        sendemail.aliasesfiletype)
2243                __gitcomp "mutt mailrc pine elm gnus"
2244                return
2245                ;;
2246        sendemail.confirm)
2247                __gitcomp "$__git_send_email_confirm_options"
2248                return
2249                ;;
2250        sendemail.suppresscc)
2251                __gitcomp "$__git_send_email_suppresscc_options"
2252                return
2253                ;;
2254        sendemail.transferencoding)
2255                __gitcomp "7bit 8bit quoted-printable base64"
2256                return
2257                ;;
2258        --get|--get-all|--unset|--unset-all)
2259                __gitcomp_nl "$(__git_config_get_set_variables)"
2260                return
2261                ;;
2262        *.*)
2263                return
2264                ;;
2265        esac
2266        case "$cur" in
2267        --*)
2268                __gitcomp "
2269                        --system --global --local --file=
2270                        --list --replace-all
2271                        --get --get-all --get-regexp
2272                        --add --unset --unset-all
2273                        --remove-section --rename-section
2274                        --name-only
2275                        "
2276                return
2277                ;;
2278        branch.*.*)
2279                local pfx="${cur%.*}." cur_="${cur##*.}"
2280                __gitcomp "remote pushremote merge mergeoptions rebase" "$pfx" "$cur_"
2281                return
2282                ;;
2283        branch.*)
2284                local pfx="${cur%.*}." cur_="${cur#*.}"
2285                __gitcomp_direct "$(__git_heads "$pfx" "$cur_" ".")"
2286                __gitcomp_nl_append $'autosetupmerge\nautosetuprebase\n' "$pfx" "$cur_"
2287                return
2288                ;;
2289        guitool.*.*)
2290                local pfx="${cur%.*}." cur_="${cur##*.}"
2291                __gitcomp "
2292                        argprompt cmd confirm needsfile noconsole norescan
2293                        prompt revprompt revunmerged title
2294                        " "$pfx" "$cur_"
2295                return
2296                ;;
2297        difftool.*.*)
2298                local pfx="${cur%.*}." cur_="${cur##*.}"
2299                __gitcomp "cmd path" "$pfx" "$cur_"
2300                return
2301                ;;
2302        man.*.*)
2303                local pfx="${cur%.*}." cur_="${cur##*.}"
2304                __gitcomp "cmd path" "$pfx" "$cur_"
2305                return
2306                ;;
2307        mergetool.*.*)
2308                local pfx="${cur%.*}." cur_="${cur##*.}"
2309                __gitcomp "cmd path trustExitCode" "$pfx" "$cur_"
2310                return
2311                ;;
2312        pager.*)
2313                local pfx="${cur%.*}." cur_="${cur#*.}"
2314                __git_compute_all_commands
2315                __gitcomp_nl "$__git_all_commands" "$pfx" "$cur_"
2316                return
2317                ;;
2318        remote.*.*)
2319                local pfx="${cur%.*}." cur_="${cur##*.}"
2320                __gitcomp "
2321                        url proxy fetch push mirror skipDefaultUpdate
2322                        receivepack uploadpack tagopt pushurl
2323                        " "$pfx" "$cur_"
2324                return
2325                ;;
2326        remote.*)
2327                local pfx="${cur%.*}." cur_="${cur#*.}"
2328                __gitcomp_nl "$(__git_remotes)" "$pfx" "$cur_" "."
2329                __gitcomp_nl_append "pushdefault" "$pfx" "$cur_"
2330                return
2331                ;;
2332        url.*.*)
2333                local pfx="${cur%.*}." cur_="${cur##*.}"
2334                __gitcomp "insteadOf pushInsteadOf" "$pfx" "$cur_"
2335                return
2336                ;;
2337        esac
2338        __gitcomp "
2339                add.ignoreErrors
2340                advice.amWorkDir
2341                advice.commitBeforeMerge
2342                advice.detachedHead
2343                advice.implicitIdentity
2344                advice.pushAlreadyExists
2345                advice.pushFetchFirst
2346                advice.pushNeedsForce
2347                advice.pushNonFFCurrent
2348                advice.pushNonFFMatching
2349                advice.pushUpdateRejected
2350                advice.resolveConflict
2351                advice.rmHints
2352                advice.statusHints
2353                advice.statusUoption
2354                advice.ignoredHook
2355                alias.
2356                am.keepcr
2357                am.threeWay
2358                apply.ignorewhitespace
2359                apply.whitespace
2360                branch.autosetupmerge
2361                branch.autosetuprebase
2362                browser.
2363                clean.requireForce
2364                color.branch
2365                color.branch.current
2366                color.branch.local
2367                color.branch.plain
2368                color.branch.remote
2369                color.decorate.HEAD
2370                color.decorate.branch
2371                color.decorate.remoteBranch
2372                color.decorate.stash
2373                color.decorate.tag
2374                color.diff
2375                color.diff.commit
2376                color.diff.frag
2377                color.diff.func
2378                color.diff.meta
2379                color.diff.new
2380                color.diff.old
2381                color.diff.plain
2382                color.diff.whitespace
2383                color.grep
2384                color.grep.context
2385                color.grep.filename
2386                color.grep.function
2387                color.grep.linenumber
2388                color.grep.match
2389                color.grep.selected
2390                color.grep.separator
2391                color.interactive
2392                color.interactive.error
2393                color.interactive.header
2394                color.interactive.help
2395                color.interactive.prompt
2396                color.pager
2397                color.showbranch
2398                color.status
2399                color.status.added
2400                color.status.changed
2401                color.status.header
2402                color.status.localBranch
2403                color.status.nobranch
2404                color.status.remoteBranch
2405                color.status.unmerged
2406                color.status.untracked
2407                color.status.updated
2408                color.ui
2409                commit.cleanup
2410                commit.gpgSign
2411                commit.status
2412                commit.template
2413                commit.verbose
2414                core.abbrev
2415                core.askpass
2416                core.attributesfile
2417                core.autocrlf
2418                core.bare
2419                core.bigFileThreshold
2420                core.checkStat
2421                core.commentChar
2422                core.compression
2423                core.createObject
2424                core.deltaBaseCacheLimit
2425                core.editor
2426                core.eol
2427                core.excludesfile
2428                core.fileMode
2429                core.fsyncobjectfiles
2430                core.gitProxy
2431                core.hideDotFiles
2432                core.hooksPath
2433                core.ignoreStat
2434                core.ignorecase
2435                core.logAllRefUpdates
2436                core.loosecompression
2437                core.notesRef
2438                core.packedGitLimit
2439                core.packedGitWindowSize
2440                core.packedRefsTimeout
2441                core.pager
2442                core.precomposeUnicode
2443                core.preferSymlinkRefs
2444                core.preloadindex
2445                core.protectHFS
2446                core.protectNTFS
2447                core.quotepath
2448                core.repositoryFormatVersion
2449                core.safecrlf
2450                core.sharedRepository
2451                core.sparseCheckout
2452                core.splitIndex
2453                core.sshCommand
2454                core.symlinks
2455                core.trustctime
2456                core.untrackedCache
2457                core.warnAmbiguousRefs
2458                core.whitespace
2459                core.worktree
2460                credential.helper
2461                credential.useHttpPath
2462                credential.username
2463                credentialCache.ignoreSIGHUP
2464                diff.autorefreshindex
2465                diff.external
2466                diff.ignoreSubmodules
2467                diff.mnemonicprefix
2468                diff.noprefix
2469                diff.renameLimit
2470                diff.renames
2471                diff.statGraphWidth
2472                diff.submodule
2473                diff.suppressBlankEmpty
2474                diff.tool
2475                diff.wordRegex
2476                diff.algorithm
2477                difftool.
2478                difftool.prompt
2479                fetch.recurseSubmodules
2480                fetch.unpackLimit
2481                format.attach
2482                format.cc
2483                format.coverLetter
2484                format.from
2485                format.headers
2486                format.numbered
2487                format.pretty
2488                format.signature
2489                format.signoff
2490                format.subjectprefix
2491                format.suffix
2492                format.thread
2493                format.to
2494                gc.
2495                gc.aggressiveDepth
2496                gc.aggressiveWindow
2497                gc.auto
2498                gc.autoDetach
2499                gc.autopacklimit
2500                gc.logExpiry
2501                gc.packrefs
2502                gc.pruneexpire
2503                gc.reflogexpire
2504                gc.reflogexpireunreachable
2505                gc.rerereresolved
2506                gc.rerereunresolved
2507                gc.worktreePruneExpire
2508                gitcvs.allbinary
2509                gitcvs.commitmsgannotation
2510                gitcvs.dbTableNamePrefix
2511                gitcvs.dbdriver
2512                gitcvs.dbname
2513                gitcvs.dbpass
2514                gitcvs.dbuser
2515                gitcvs.enabled
2516                gitcvs.logfile
2517                gitcvs.usecrlfattr
2518                guitool.
2519                gui.blamehistoryctx
2520                gui.commitmsgwidth
2521                gui.copyblamethreshold
2522                gui.diffcontext
2523                gui.encoding
2524                gui.fastcopyblame
2525                gui.matchtrackingbranch
2526                gui.newbranchtemplate
2527                gui.pruneduringfetch
2528                gui.spellingdictionary
2529                gui.trustmtime
2530                help.autocorrect
2531                help.browser
2532                help.format
2533                http.lowSpeedLimit
2534                http.lowSpeedTime
2535                http.maxRequests
2536                http.minSessions
2537                http.noEPSV
2538                http.postBuffer
2539                http.proxy
2540                http.sslCipherList
2541                http.sslVersion
2542                http.sslCAInfo
2543                http.sslCAPath
2544                http.sslCert
2545                http.sslCertPasswordProtected
2546                http.sslKey
2547                http.sslVerify
2548                http.useragent
2549                i18n.commitEncoding
2550                i18n.logOutputEncoding
2551                imap.authMethod
2552                imap.folder
2553                imap.host
2554                imap.pass
2555                imap.port
2556                imap.preformattedHTML
2557                imap.sslverify
2558                imap.tunnel
2559                imap.user
2560                init.templatedir
2561                instaweb.browser
2562                instaweb.httpd
2563                instaweb.local
2564                instaweb.modulepath
2565                instaweb.port
2566                interactive.singlekey
2567                log.date
2568                log.decorate
2569                log.showroot
2570                mailmap.file
2571                man.
2572                man.viewer
2573                merge.
2574                merge.conflictstyle
2575                merge.log
2576                merge.renameLimit
2577                merge.renormalize
2578                merge.stat
2579                merge.tool
2580                merge.verbosity
2581                mergetool.
2582                mergetool.keepBackup
2583                mergetool.keepTemporaries
2584                mergetool.prompt
2585                notes.displayRef
2586                notes.rewrite.
2587                notes.rewrite.amend
2588                notes.rewrite.rebase
2589                notes.rewriteMode
2590                notes.rewriteRef
2591                pack.compression
2592                pack.deltaCacheLimit
2593                pack.deltaCacheSize
2594                pack.depth
2595                pack.indexVersion
2596                pack.packSizeLimit
2597                pack.threads
2598                pack.window
2599                pack.windowMemory
2600                pager.
2601                pretty.
2602                pull.octopus
2603                pull.twohead
2604                push.default
2605                push.followTags
2606                rebase.autosquash
2607                rebase.stat
2608                receive.autogc
2609                receive.denyCurrentBranch
2610                receive.denyDeleteCurrent
2611                receive.denyDeletes
2612                receive.denyNonFastForwards
2613                receive.fsckObjects
2614                receive.unpackLimit
2615                receive.updateserverinfo
2616                remote.pushdefault
2617                remotes.
2618                repack.usedeltabaseoffset
2619                rerere.autoupdate
2620                rerere.enabled
2621                sendemail.
2622                sendemail.aliasesfile
2623                sendemail.aliasfiletype
2624                sendemail.bcc
2625                sendemail.cc
2626                sendemail.cccmd
2627                sendemail.chainreplyto
2628                sendemail.confirm
2629                sendemail.envelopesender
2630                sendemail.from
2631                sendemail.identity
2632                sendemail.multiedit
2633                sendemail.signedoffbycc
2634                sendemail.smtpdomain
2635                sendemail.smtpencryption
2636                sendemail.smtppass
2637                sendemail.smtpserver
2638                sendemail.smtpserveroption
2639                sendemail.smtpserverport
2640                sendemail.smtpuser
2641                sendemail.suppresscc
2642                sendemail.suppressfrom
2643                sendemail.thread
2644                sendemail.to
2645                sendemail.tocmd
2646                sendemail.validate
2647                sendemail.smtpbatchsize
2648                sendemail.smtprelogindelay
2649                showbranch.default
2650                status.relativePaths
2651                status.showUntrackedFiles
2652                status.submodulesummary
2653                submodule.
2654                tar.umask
2655                transfer.unpackLimit
2656                url.
2657                user.email
2658                user.name
2659                user.signingkey
2660                web.browser
2661                branch. remote.
2662        "
2663}
2664
2665_git_remote ()
2666{
2667        local subcommands="
2668                add rename remove set-head set-branches
2669                get-url set-url show prune update
2670                "
2671        local subcommand="$(__git_find_on_cmdline "$subcommands")"
2672        if [ -z "$subcommand" ]; then
2673                case "$cur" in
2674                --*)
2675                        __gitcomp "--verbose"
2676                        ;;
2677                *)
2678                        __gitcomp "$subcommands"
2679                        ;;
2680                esac
2681                return
2682        fi
2683
2684        case "$subcommand,$cur" in
2685        add,--*)
2686                __gitcomp "--track --master --fetch --tags --no-tags --mirror="
2687                ;;
2688        add,*)
2689                ;;
2690        set-head,--*)
2691                __gitcomp "--auto --delete"
2692                ;;
2693        set-branches,--*)
2694                __gitcomp "--add"
2695                ;;
2696        set-head,*|set-branches,*)
2697                __git_complete_remote_or_refspec
2698                ;;
2699        update,--*)
2700                __gitcomp "--prune"
2701                ;;
2702        update,*)
2703                __gitcomp "$(__git_get_config_variables "remotes")"
2704                ;;
2705        set-url,--*)
2706                __gitcomp "--push --add --delete"
2707                ;;
2708        get-url,--*)
2709                __gitcomp "--push --all"
2710                ;;
2711        prune,--*)
2712                __gitcomp "--dry-run"
2713                ;;
2714        *)
2715                __gitcomp_nl "$(__git_remotes)"
2716                ;;
2717        esac
2718}
2719
2720_git_replace ()
2721{
2722        case "$cur" in
2723        --*)
2724                __gitcomp "--edit --graft --format= --list --delete"
2725                return
2726                ;;
2727        esac
2728        __git_complete_refs
2729}
2730
2731_git_rerere ()
2732{
2733        local subcommands="clear forget diff remaining status gc"
2734        local subcommand="$(__git_find_on_cmdline "$subcommands")"
2735        if test -z "$subcommand"
2736        then
2737                __gitcomp "$subcommands"
2738                return
2739        fi
2740}
2741
2742_git_reset ()
2743{
2744        __git_has_doubledash && return
2745
2746        case "$cur" in
2747        --*)
2748                __gitcomp "--merge --mixed --hard --soft --patch --keep"
2749                return
2750                ;;
2751        esac
2752        __git_complete_refs
2753}
2754
2755_git_revert ()
2756{
2757        __git_find_repo_path
2758        if [ -f "$__git_repo_path"/REVERT_HEAD ]; then
2759                __gitcomp "--continue --quit --abort"
2760                return
2761        fi
2762        case "$cur" in
2763        --*)
2764                __gitcomp "
2765                        --edit --mainline --no-edit --no-commit --signoff
2766                        --strategy= --strategy-option=
2767                        "
2768                return
2769                ;;
2770        esac
2771        __git_complete_refs
2772}
2773
2774_git_rm ()
2775{
2776        case "$cur" in
2777        --*)
2778                __gitcomp "--cached --dry-run --ignore-unmatch --quiet"
2779                return
2780                ;;
2781        esac
2782
2783        __git_complete_index_file "--cached"
2784}
2785
2786_git_shortlog ()
2787{
2788        __git_has_doubledash && return
2789
2790        case "$cur" in
2791        --*)
2792                __gitcomp "
2793                        $__git_log_common_options
2794                        $__git_log_shortlog_options
2795                        --numbered --summary --email
2796                        "
2797                return
2798                ;;
2799        esac
2800        __git_complete_revlist
2801}
2802
2803_git_show ()
2804{
2805        __git_has_doubledash && return
2806
2807        case "$cur" in
2808        --pretty=*|--format=*)
2809                __gitcomp "$__git_log_pretty_formats $(__git_pretty_aliases)
2810                        " "" "${cur#*=}"
2811                return
2812                ;;
2813        --diff-algorithm=*)
2814                __gitcomp "$__git_diff_algorithms" "" "${cur##--diff-algorithm=}"
2815                return
2816                ;;
2817        --submodule=*)
2818                __gitcomp "$__git_diff_submodule_formats" "" "${cur##--submodule=}"
2819                return
2820                ;;
2821        --*)
2822                __gitcomp "--pretty= --format= --abbrev-commit --oneline
2823                        --show-signature
2824                        $__git_diff_common_options
2825                        "
2826                return
2827                ;;
2828        esac
2829        __git_complete_revlist_file
2830}
2831
2832_git_show_branch ()
2833{
2834        case "$cur" in
2835        --*)
2836                __gitcomp "
2837                        --all --remotes --topo-order --date-order --current --more=
2838                        --list --independent --merge-base --no-name
2839                        --color --no-color
2840                        --sha1-name --sparse --topics --reflog
2841                        "
2842                return
2843                ;;
2844        esac
2845        __git_complete_revlist
2846}
2847
2848_git_stash ()
2849{
2850        local save_opts='--all --keep-index --no-keep-index --quiet --patch --include-untracked'
2851        local subcommands='push save list show apply clear drop pop create branch'
2852        local subcommand="$(__git_find_on_cmdline "$subcommands")"
2853        if [ -z "$subcommand" ]; then
2854                case "$cur" in
2855                --*)
2856                        __gitcomp "$save_opts"
2857                        ;;
2858                *)
2859                        if [ -z "$(__git_find_on_cmdline "$save_opts")" ]; then
2860                                __gitcomp "$subcommands"
2861                        fi
2862                        ;;
2863                esac
2864        else
2865                case "$subcommand,$cur" in
2866                push,--*)
2867                        __gitcomp "$save_opts --message"
2868                        ;;
2869                save,--*)
2870                        __gitcomp "$save_opts"
2871                        ;;
2872                apply,--*|pop,--*)
2873                        __gitcomp "--index --quiet"
2874                        ;;
2875                drop,--*)
2876                        __gitcomp "--quiet"
2877                        ;;
2878                show,--*|branch,--*)
2879                        ;;
2880                branch,*)
2881                        if [ $cword -eq 3 ]; then
2882                                __git_complete_refs
2883                        else
2884                                __gitcomp_nl "$(__git stash list \
2885                                                | sed -n -e 's/:.*//p')"
2886                        fi
2887                        ;;
2888                show,*|apply,*|drop,*|pop,*)
2889                        __gitcomp_nl "$(__git stash list \
2890                                        | sed -n -e 's/:.*//p')"
2891                        ;;
2892                *)
2893                        ;;
2894                esac
2895        fi
2896}
2897
2898_git_submodule ()
2899{
2900        __git_has_doubledash && return
2901
2902        local subcommands="add status init deinit update summary foreach sync"
2903        local subcommand="$(__git_find_on_cmdline "$subcommands")"
2904        if [ -z "$subcommand" ]; then
2905                case "$cur" in
2906                --*)
2907                        __gitcomp "--quiet"
2908                        ;;
2909                *)
2910                        __gitcomp "$subcommands"
2911                        ;;
2912                esac
2913                return
2914        fi
2915
2916        case "$subcommand,$cur" in
2917        add,--*)
2918                __gitcomp "--branch --force --name --reference --depth"
2919                ;;
2920        status,--*)
2921                __gitcomp "--cached --recursive"
2922                ;;
2923        deinit,--*)
2924                __gitcomp "--force --all"
2925                ;;
2926        update,--*)
2927                __gitcomp "
2928                        --init --remote --no-fetch
2929                        --recommend-shallow --no-recommend-shallow
2930                        --force --rebase --merge --reference --depth --recursive --jobs
2931                "
2932                ;;
2933        summary,--*)
2934                __gitcomp "--cached --files --summary-limit"
2935                ;;
2936        foreach,--*|sync,--*)
2937                __gitcomp "--recursive"
2938                ;;
2939        *)
2940                ;;
2941        esac
2942}
2943
2944_git_svn ()
2945{
2946        local subcommands="
2947                init fetch clone rebase dcommit log find-rev
2948                set-tree commit-diff info create-ignore propget
2949                proplist show-ignore show-externals branch tag blame
2950                migrate mkdirs reset gc
2951                "
2952        local subcommand="$(__git_find_on_cmdline "$subcommands")"
2953        if [ -z "$subcommand" ]; then
2954                __gitcomp "$subcommands"
2955        else
2956                local remote_opts="--username= --config-dir= --no-auth-cache"
2957                local fc_opts="
2958                        --follow-parent --authors-file= --repack=
2959                        --no-metadata --use-svm-props --use-svnsync-props
2960                        --log-window-size= --no-checkout --quiet
2961                        --repack-flags --use-log-author --localtime
2962                        --add-author-from
2963                        --ignore-paths= --include-paths= $remote_opts
2964                        "
2965                local init_opts="
2966                        --template= --shared= --trunk= --tags=
2967                        --branches= --stdlayout --minimize-url
2968                        --no-metadata --use-svm-props --use-svnsync-props
2969                        --rewrite-root= --prefix= $remote_opts
2970                        "
2971                local cmt_opts="
2972                        --edit --rmdir --find-copies-harder --copy-similarity=
2973                        "
2974
2975                case "$subcommand,$cur" in
2976                fetch,--*)
2977                        __gitcomp "--revision= --fetch-all $fc_opts"
2978                        ;;
2979                clone,--*)
2980                        __gitcomp "--revision= $fc_opts $init_opts"
2981                        ;;
2982                init,--*)
2983                        __gitcomp "$init_opts"
2984                        ;;
2985                dcommit,--*)
2986                        __gitcomp "
2987                                --merge --strategy= --verbose --dry-run
2988                                --fetch-all --no-rebase --commit-url
2989                                --revision --interactive $cmt_opts $fc_opts
2990                                "
2991                        ;;
2992                set-tree,--*)
2993                        __gitcomp "--stdin $cmt_opts $fc_opts"
2994                        ;;
2995                create-ignore,--*|propget,--*|proplist,--*|show-ignore,--*|\
2996                show-externals,--*|mkdirs,--*)
2997                        __gitcomp "--revision="
2998                        ;;
2999                log,--*)
3000                        __gitcomp "
3001                                --limit= --revision= --verbose --incremental
3002                                --oneline --show-commit --non-recursive
3003                                --authors-file= --color
3004                                "
3005                        ;;
3006                rebase,--*)
3007                        __gitcomp "
3008                                --merge --verbose --strategy= --local
3009                                --fetch-all --dry-run $fc_opts
3010                                "
3011                        ;;
3012                commit-diff,--*)
3013                        __gitcomp "--message= --file= --revision= $cmt_opts"
3014                        ;;
3015                info,--*)
3016                        __gitcomp "--url"
3017                        ;;
3018                branch,--*)
3019                        __gitcomp "--dry-run --message --tag"
3020                        ;;
3021                tag,--*)
3022                        __gitcomp "--dry-run --message"
3023                        ;;
3024                blame,--*)
3025                        __gitcomp "--git-format"
3026                        ;;
3027                migrate,--*)
3028                        __gitcomp "
3029                                --config-dir= --ignore-paths= --minimize
3030                                --no-auth-cache --username=
3031                                "
3032                        ;;
3033                reset,--*)
3034                        __gitcomp "--revision= --parent"
3035                        ;;
3036                *)
3037                        ;;
3038                esac
3039        fi
3040}
3041
3042_git_tag ()
3043{
3044        local i c=1 f=0
3045        while [ $c -lt $cword ]; do
3046                i="${words[c]}"
3047                case "$i" in
3048                -d|-v)
3049                        __gitcomp_direct "$(__git_tags "" "$cur" " ")"
3050                        return
3051                        ;;
3052                -f)
3053                        f=1
3054                        ;;
3055                esac
3056                ((c++))
3057        done
3058
3059        case "$prev" in
3060        -m|-F)
3061                ;;
3062        -*|tag)
3063                if [ $f = 1 ]; then
3064                        __gitcomp_direct "$(__git_tags "" "$cur" " ")"
3065                fi
3066                ;;
3067        *)
3068                __git_complete_refs
3069                ;;
3070        esac
3071
3072        case "$cur" in
3073        --*)
3074                __gitcomp "
3075                        --list --delete --verify --annotate --message --file
3076                        --sign --cleanup --local-user --force --column --sort=
3077                        --contains --no-contains --points-at --merged --no-merged --create-reflog
3078                        "
3079                ;;
3080        esac
3081}
3082
3083_git_whatchanged ()
3084{
3085        _git_log
3086}
3087
3088_git_worktree ()
3089{
3090        local subcommands="add list lock prune unlock"
3091        local subcommand="$(__git_find_on_cmdline "$subcommands")"
3092        if [ -z "$subcommand" ]; then
3093                __gitcomp "$subcommands"
3094        else
3095                case "$subcommand,$cur" in
3096                add,--*)
3097                        __gitcomp "--detach"
3098                        ;;
3099                list,--*)
3100                        __gitcomp "--porcelain"
3101                        ;;
3102                lock,--*)
3103                        __gitcomp "--reason"
3104                        ;;
3105                prune,--*)
3106                        __gitcomp "--dry-run --expire --verbose"
3107                        ;;
3108                *)
3109                        ;;
3110                esac
3111        fi
3112}
3113
3114__git_main ()
3115{
3116        local i c=1 command __git_dir __git_repo_path
3117        local __git_C_args C_args_count=0
3118
3119        while [ $c -lt $cword ]; do
3120                i="${words[c]}"
3121                case "$i" in
3122                --git-dir=*) __git_dir="${i#--git-dir=}" ;;
3123                --git-dir)   ((c++)) ; __git_dir="${words[c]}" ;;
3124                --bare)      __git_dir="." ;;
3125                --help) command="help"; break ;;
3126                -c|--work-tree|--namespace) ((c++)) ;;
3127                -C)     __git_C_args[C_args_count++]=-C
3128                        ((c++))
3129                        __git_C_args[C_args_count++]="${words[c]}"
3130                        ;;
3131                -*) ;;
3132                *) command="$i"; break ;;
3133                esac
3134                ((c++))
3135        done
3136
3137        if [ -z "$command" ]; then
3138                case "$prev" in
3139                --git-dir|-C|--work-tree)
3140                        # these need a path argument, let's fall back to
3141                        # Bash filename completion
3142                        return
3143                        ;;
3144                -c|--namespace)
3145                        # we don't support completing these options' arguments
3146                        return
3147                        ;;
3148                esac
3149                case "$cur" in
3150                --*)   __gitcomp "
3151                        --paginate
3152                        --no-pager
3153                        --git-dir=
3154                        --bare
3155                        --version
3156                        --exec-path
3157                        --exec-path=
3158                        --html-path
3159                        --man-path
3160                        --info-path
3161                        --work-tree=
3162                        --namespace=
3163                        --no-replace-objects
3164                        --help
3165                        "
3166                        ;;
3167                *)     __git_compute_porcelain_commands
3168                       __gitcomp "$__git_porcelain_commands $(__git_aliases)" ;;
3169                esac
3170                return
3171        fi
3172
3173        local completion_func="_git_${command//-/_}"
3174        declare -f $completion_func >/dev/null 2>/dev/null && $completion_func && return
3175
3176        local expansion=$(__git_aliased_command "$command")
3177        if [ -n "$expansion" ]; then
3178                words[1]=$expansion
3179                completion_func="_git_${expansion//-/_}"
3180                declare -f $completion_func >/dev/null 2>/dev/null && $completion_func
3181        fi
3182}
3183
3184__gitk_main ()
3185{
3186        __git_has_doubledash && return
3187
3188        local __git_repo_path
3189        __git_find_repo_path
3190
3191        local merge=""
3192        if [ -f "$__git_repo_path/MERGE_HEAD" ]; then
3193                merge="--merge"
3194        fi
3195        case "$cur" in
3196        --*)
3197                __gitcomp "
3198                        $__git_log_common_options
3199                        $__git_log_gitk_options
3200                        $merge
3201                        "
3202                return
3203                ;;
3204        esac
3205        __git_complete_revlist
3206}
3207
3208if [[ -n ${ZSH_VERSION-} ]]; then
3209        echo "WARNING: this script is deprecated, please see git-completion.zsh" 1>&2
3210
3211        autoload -U +X compinit && compinit
3212
3213        __gitcomp ()
3214        {
3215                emulate -L zsh
3216
3217                local cur_="${3-$cur}"
3218
3219                case "$cur_" in
3220                --*=)
3221                        ;;
3222                *)
3223                        local c IFS=$' \t\n'
3224                        local -a array
3225                        for c in ${=1}; do
3226                                c="$c${4-}"
3227                                case $c in
3228                                --*=*|*.) ;;
3229                                *) c="$c " ;;
3230                                esac
3231                                array[${#array[@]}+1]="$c"
3232                        done
3233                        compset -P '*[=:]'
3234                        compadd -Q -S '' -p "${2-}" -a -- array && _ret=0
3235                        ;;
3236                esac
3237        }
3238
3239        __gitcomp_direct ()
3240        {
3241                emulate -L zsh
3242
3243                local IFS=$'\n'
3244                compset -P '*[=:]'
3245                compadd -Q -- ${=1} && _ret=0
3246        }
3247
3248        __gitcomp_nl ()
3249        {
3250                emulate -L zsh
3251
3252                local IFS=$'\n'
3253                compset -P '*[=:]'
3254                compadd -Q -S "${4- }" -p "${2-}" -- ${=1} && _ret=0
3255        }
3256
3257        __gitcomp_file ()
3258        {
3259                emulate -L zsh
3260
3261                local IFS=$'\n'
3262                compset -P '*[=:]'
3263                compadd -Q -p "${2-}" -f -- ${=1} && _ret=0
3264        }
3265
3266        _git ()
3267        {
3268                local _ret=1 cur cword prev
3269                cur=${words[CURRENT]}
3270                prev=${words[CURRENT-1]}
3271                let cword=CURRENT-1
3272                emulate ksh -c __${service}_main
3273                let _ret && _default && _ret=0
3274                return _ret
3275        }
3276
3277        compdef _git git gitk
3278        return
3279fi
3280
3281__git_func_wrap ()
3282{
3283        local cur words cword prev
3284        _get_comp_words_by_ref -n =: cur words cword prev
3285        $1
3286}
3287
3288# Setup completion for certain functions defined above by setting common
3289# variables and workarounds.
3290# This is NOT a public function; use at your own risk.
3291__git_complete ()
3292{
3293        local wrapper="__git_wrap${2}"
3294        eval "$wrapper () { __git_func_wrap $2 ; }"
3295        complete -o bashdefault -o default -o nospace -F $wrapper $1 2>/dev/null \
3296                || complete -o default -o nospace -F $wrapper $1
3297}
3298
3299# wrapper for backwards compatibility
3300_git ()
3301{
3302        __git_wrap__git_main
3303}
3304
3305# wrapper for backwards compatibility
3306_gitk ()
3307{
3308        __git_wrap__gitk_main
3309}
3310
3311__git_complete git __git_main
3312__git_complete gitk __gitk_main
3313
3314# The following are necessary only for Cygwin, and only are needed
3315# when the user has tab-completed the executable name and consequently
3316# included the '.exe' suffix.
3317#
3318if [ Cygwin = "$(uname -o 2>/dev/null)" ]; then
3319__git_complete git.exe __git_main
3320fi