contrib / completion / git-completion.bashon commit commit-graph: compute generation numbers (3258c66)
   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-graph)     : plumbing;;
 845                commit-tree)      : plumbing;;
 846                count-objects)    : infrequent;;
 847                credential)       : credentials;;
 848                credential-*)     : credentials helper;;
 849                cvsexportcommit)  : export;;
 850                cvsimport)        : import;;
 851                cvsserver)        : daemon;;
 852                daemon)           : daemon;;
 853                diff-files)       : plumbing;;
 854                diff-index)       : plumbing;;
 855                diff-tree)        : plumbing;;
 856                fast-import)      : import;;
 857                fast-export)      : export;;
 858                fsck-objects)     : plumbing;;
 859                fetch-pack)       : plumbing;;
 860                fmt-merge-msg)    : plumbing;;
 861                for-each-ref)     : plumbing;;
 862                hash-object)      : plumbing;;
 863                http-*)           : transport;;
 864                index-pack)       : plumbing;;
 865                init-db)          : deprecated;;
 866                local-fetch)      : plumbing;;
 867                ls-files)         : plumbing;;
 868                ls-remote)        : plumbing;;
 869                ls-tree)          : plumbing;;
 870                mailinfo)         : plumbing;;
 871                mailsplit)        : plumbing;;
 872                merge-*)          : plumbing;;
 873                mktree)           : plumbing;;
 874                mktag)            : plumbing;;
 875                pack-objects)     : plumbing;;
 876                pack-redundant)   : plumbing;;
 877                pack-refs)        : plumbing;;
 878                parse-remote)     : plumbing;;
 879                patch-id)         : plumbing;;
 880                prune)            : plumbing;;
 881                prune-packed)     : plumbing;;
 882                quiltimport)      : import;;
 883                read-tree)        : plumbing;;
 884                receive-pack)     : plumbing;;
 885                remote-*)         : transport;;
 886                rerere)           : plumbing;;
 887                rev-list)         : plumbing;;
 888                rev-parse)        : plumbing;;
 889                runstatus)        : plumbing;;
 890                sh-setup)         : internal;;
 891                shell)            : daemon;;
 892                show-ref)         : plumbing;;
 893                send-pack)        : plumbing;;
 894                show-index)       : plumbing;;
 895                ssh-*)            : transport;;
 896                stripspace)       : plumbing;;
 897                symbolic-ref)     : plumbing;;
 898                unpack-file)      : plumbing;;
 899                unpack-objects)   : plumbing;;
 900                update-index)     : plumbing;;
 901                update-ref)       : plumbing;;
 902                update-server-info) : daemon;;
 903                upload-archive)   : plumbing;;
 904                upload-pack)      : plumbing;;
 905                write-tree)       : plumbing;;
 906                var)              : infrequent;;
 907                verify-pack)      : infrequent;;
 908                verify-tag)       : plumbing;;
 909                *) echo $i;;
 910                esac
 911        done
 912}
 913
 914__git_porcelain_commands=
 915__git_compute_porcelain_commands ()
 916{
 917        test -n "$__git_porcelain_commands" ||
 918        __git_porcelain_commands=$(__git_list_porcelain_commands)
 919}
 920
 921# Lists all set config variables starting with the given section prefix,
 922# with the prefix removed.
 923__git_get_config_variables ()
 924{
 925        local section="$1" i IFS=$'\n'
 926        for i in $(__git config --name-only --get-regexp "^$section\..*"); do
 927                echo "${i#$section.}"
 928        done
 929}
 930
 931__git_pretty_aliases ()
 932{
 933        __git_get_config_variables "pretty"
 934}
 935
 936__git_aliases ()
 937{
 938        __git_get_config_variables "alias"
 939}
 940
 941# __git_aliased_command requires 1 argument
 942__git_aliased_command ()
 943{
 944        local word cmdline=$(__git config --get "alias.$1")
 945        for word in $cmdline; do
 946                case "$word" in
 947                \!gitk|gitk)
 948                        echo "gitk"
 949                        return
 950                        ;;
 951                \!*)    : shell command alias ;;
 952                -*)     : option ;;
 953                *=*)    : setting env ;;
 954                git)    : git itself ;;
 955                \(\))   : skip parens of shell function definition ;;
 956                {)      : skip start of shell helper function ;;
 957                :)      : skip null command ;;
 958                \'*)    : skip opening quote after sh -c ;;
 959                *)
 960                        echo "$word"
 961                        return
 962                esac
 963        done
 964}
 965
 966# __git_find_on_cmdline requires 1 argument
 967__git_find_on_cmdline ()
 968{
 969        local word subcommand c=1
 970        while [ $c -lt $cword ]; do
 971                word="${words[c]}"
 972                for subcommand in $1; do
 973                        if [ "$subcommand" = "$word" ]; then
 974                                echo "$subcommand"
 975                                return
 976                        fi
 977                done
 978                ((c++))
 979        done
 980}
 981
 982# Echo the value of an option set on the command line or config
 983#
 984# $1: short option name
 985# $2: long option name including =
 986# $3: list of possible values
 987# $4: config string (optional)
 988#
 989# example:
 990# result="$(__git_get_option_value "-d" "--do-something=" \
 991#     "yes no" "core.doSomething")"
 992#
 993# result is then either empty (no option set) or "yes" or "no"
 994#
 995# __git_get_option_value requires 3 arguments
 996__git_get_option_value ()
 997{
 998        local c short_opt long_opt val
 999        local result= values config_key word
1000
1001        short_opt="$1"
1002        long_opt="$2"
1003        values="$3"
1004        config_key="$4"
1005
1006        ((c = $cword - 1))
1007        while [ $c -ge 0 ]; do
1008                word="${words[c]}"
1009                for val in $values; do
1010                        if [ "$short_opt$val" = "$word" ] ||
1011                           [ "$long_opt$val"  = "$word" ]; then
1012                                result="$val"
1013                                break 2
1014                        fi
1015                done
1016                ((c--))
1017        done
1018
1019        if [ -n "$config_key" ] && [ -z "$result" ]; then
1020                result="$(__git config "$config_key")"
1021        fi
1022
1023        echo "$result"
1024}
1025
1026__git_has_doubledash ()
1027{
1028        local c=1
1029        while [ $c -lt $cword ]; do
1030                if [ "--" = "${words[c]}" ]; then
1031                        return 0
1032                fi
1033                ((c++))
1034        done
1035        return 1
1036}
1037
1038# Try to count non option arguments passed on the command line for the
1039# specified git command.
1040# When options are used, it is necessary to use the special -- option to
1041# tell the implementation were non option arguments begin.
1042# XXX this can not be improved, since options can appear everywhere, as
1043# an example:
1044#       git mv x -n y
1045#
1046# __git_count_arguments requires 1 argument: the git command executed.
1047__git_count_arguments ()
1048{
1049        local word i c=0
1050
1051        # Skip "git" (first argument)
1052        for ((i=1; i < ${#words[@]}; i++)); do
1053                word="${words[i]}"
1054
1055                case "$word" in
1056                        --)
1057                                # Good; we can assume that the following are only non
1058                                # option arguments.
1059                                ((c = 0))
1060                                ;;
1061                        "$1")
1062                                # Skip the specified git command and discard git
1063                                # main options
1064                                ((c = 0))
1065                                ;;
1066                        ?*)
1067                                ((c++))
1068                                ;;
1069                esac
1070        done
1071
1072        printf "%d" $c
1073}
1074
1075__git_whitespacelist="nowarn warn error error-all fix"
1076
1077_git_am ()
1078{
1079        __git_find_repo_path
1080        if [ -d "$__git_repo_path"/rebase-apply ]; then
1081                __gitcomp "--skip --continue --resolved --abort"
1082                return
1083        fi
1084        case "$cur" in
1085        --whitespace=*)
1086                __gitcomp "$__git_whitespacelist" "" "${cur##--whitespace=}"
1087                return
1088                ;;
1089        --*)
1090                __gitcomp "
1091                        --3way --committer-date-is-author-date --ignore-date
1092                        --ignore-whitespace --ignore-space-change
1093                        --interactive --keep --no-utf8 --signoff --utf8
1094                        --whitespace= --scissors
1095                        "
1096                return
1097        esac
1098}
1099
1100_git_apply ()
1101{
1102        case "$cur" in
1103        --whitespace=*)
1104                __gitcomp "$__git_whitespacelist" "" "${cur##--whitespace=}"
1105                return
1106                ;;
1107        --*)
1108                __gitcomp "
1109                        --stat --numstat --summary --check --index
1110                        --cached --index-info --reverse --reject --unidiff-zero
1111                        --apply --no-add --exclude=
1112                        --ignore-whitespace --ignore-space-change
1113                        --whitespace= --inaccurate-eof --verbose
1114                        --recount --directory=
1115                        "
1116                return
1117        esac
1118}
1119
1120_git_add ()
1121{
1122        case "$cur" in
1123        --*)
1124                __gitcomp "
1125                        --interactive --refresh --patch --update --dry-run
1126                        --ignore-errors --intent-to-add --force --edit --chmod=
1127                        "
1128                return
1129        esac
1130
1131        local complete_opt="--others --modified --directory --no-empty-directory"
1132        if test -n "$(__git_find_on_cmdline "-u --update")"
1133        then
1134                complete_opt="--modified"
1135        fi
1136        __git_complete_index_file "$complete_opt"
1137}
1138
1139_git_archive ()
1140{
1141        case "$cur" in
1142        --format=*)
1143                __gitcomp "$(git archive --list)" "" "${cur##--format=}"
1144                return
1145                ;;
1146        --remote=*)
1147                __gitcomp_nl "$(__git_remotes)" "" "${cur##--remote=}"
1148                return
1149                ;;
1150        --*)
1151                __gitcomp "
1152                        --format= --list --verbose
1153                        --prefix= --remote= --exec= --output
1154                        "
1155                return
1156                ;;
1157        esac
1158        __git_complete_file
1159}
1160
1161_git_bisect ()
1162{
1163        __git_has_doubledash && return
1164
1165        local subcommands="start bad good skip reset visualize replay log run"
1166        local subcommand="$(__git_find_on_cmdline "$subcommands")"
1167        if [ -z "$subcommand" ]; then
1168                __git_find_repo_path
1169                if [ -f "$__git_repo_path"/BISECT_START ]; then
1170                        __gitcomp "$subcommands"
1171                else
1172                        __gitcomp "replay start"
1173                fi
1174                return
1175        fi
1176
1177        case "$subcommand" in
1178        bad|good|reset|skip|start)
1179                __git_complete_refs
1180                ;;
1181        *)
1182                ;;
1183        esac
1184}
1185
1186_git_branch ()
1187{
1188        local i c=1 only_local_ref="n" has_r="n"
1189
1190        while [ $c -lt $cword ]; do
1191                i="${words[c]}"
1192                case "$i" in
1193                -d|--delete|-m|--move)  only_local_ref="y" ;;
1194                -r|--remotes)           has_r="y" ;;
1195                esac
1196                ((c++))
1197        done
1198
1199        case "$cur" in
1200        --set-upstream-to=*)
1201                __git_complete_refs --cur="${cur##--set-upstream-to=}"
1202                ;;
1203        --*)
1204                __gitcomp "
1205                        --color --no-color --verbose --abbrev= --no-abbrev
1206                        --track --no-track --contains --no-contains --merged --no-merged
1207                        --set-upstream-to= --edit-description --list
1208                        --unset-upstream --delete --move --copy --remotes
1209                        --column --no-column --sort= --points-at
1210                        "
1211                ;;
1212        *)
1213                if [ $only_local_ref = "y" -a $has_r = "n" ]; then
1214                        __gitcomp_direct "$(__git_heads "" "$cur" " ")"
1215                else
1216                        __git_complete_refs
1217                fi
1218                ;;
1219        esac
1220}
1221
1222_git_bundle ()
1223{
1224        local cmd="${words[2]}"
1225        case "$cword" in
1226        2)
1227                __gitcomp "create list-heads verify unbundle"
1228                ;;
1229        3)
1230                # looking for a file
1231                ;;
1232        *)
1233                case "$cmd" in
1234                        create)
1235                                __git_complete_revlist
1236                        ;;
1237                esac
1238                ;;
1239        esac
1240}
1241
1242_git_checkout ()
1243{
1244        __git_has_doubledash && return
1245
1246        case "$cur" in
1247        --conflict=*)
1248                __gitcomp "diff3 merge" "" "${cur##--conflict=}"
1249                ;;
1250        --*)
1251                __gitcomp "
1252                        --quiet --ours --theirs --track --no-track --merge
1253                        --conflict= --orphan --patch --detach --ignore-skip-worktree-bits
1254                        --recurse-submodules --no-recurse-submodules
1255                        "
1256                ;;
1257        *)
1258                # check if --track, --no-track, or --no-guess was specified
1259                # if so, disable DWIM mode
1260                local flags="--track --no-track --no-guess" track_opt="--track"
1261                if [ "$GIT_COMPLETION_CHECKOUT_NO_GUESS" = "1" ] ||
1262                   [ -n "$(__git_find_on_cmdline "$flags")" ]; then
1263                        track_opt=''
1264                fi
1265                __git_complete_refs $track_opt
1266                ;;
1267        esac
1268}
1269
1270_git_cherry ()
1271{
1272        __git_complete_refs
1273}
1274
1275_git_cherry_pick ()
1276{
1277        __git_find_repo_path
1278        if [ -f "$__git_repo_path"/CHERRY_PICK_HEAD ]; then
1279                __gitcomp "--continue --quit --abort"
1280                return
1281        fi
1282        case "$cur" in
1283        --*)
1284                __gitcomp "--edit --no-commit --signoff --strategy= --mainline"
1285                ;;
1286        *)
1287                __git_complete_refs
1288                ;;
1289        esac
1290}
1291
1292_git_clean ()
1293{
1294        case "$cur" in
1295        --*)
1296                __gitcomp "--dry-run --quiet"
1297                return
1298                ;;
1299        esac
1300
1301        # XXX should we check for -x option ?
1302        __git_complete_index_file "--others --directory"
1303}
1304
1305_git_clone ()
1306{
1307        case "$cur" in
1308        --*)
1309                __gitcomp "
1310                        --local
1311                        --no-hardlinks
1312                        --shared
1313                        --reference
1314                        --quiet
1315                        --no-checkout
1316                        --bare
1317                        --mirror
1318                        --origin
1319                        --upload-pack
1320                        --template=
1321                        --depth
1322                        --single-branch
1323                        --no-tags
1324                        --branch
1325                        --recurse-submodules
1326                        --no-single-branch
1327                        --shallow-submodules
1328                        "
1329                return
1330                ;;
1331        esac
1332}
1333
1334__git_untracked_file_modes="all no normal"
1335
1336_git_commit ()
1337{
1338        case "$prev" in
1339        -c|-C)
1340                __git_complete_refs
1341                return
1342                ;;
1343        esac
1344
1345        case "$cur" in
1346        --cleanup=*)
1347                __gitcomp "default scissors strip verbatim whitespace
1348                        " "" "${cur##--cleanup=}"
1349                return
1350                ;;
1351        --reuse-message=*|--reedit-message=*|\
1352        --fixup=*|--squash=*)
1353                __git_complete_refs --cur="${cur#*=}"
1354                return
1355                ;;
1356        --untracked-files=*)
1357                __gitcomp "$__git_untracked_file_modes" "" "${cur##--untracked-files=}"
1358                return
1359                ;;
1360        --*)
1361                __gitcomp "
1362                        --all --author= --signoff --verify --no-verify
1363                        --edit --no-edit
1364                        --amend --include --only --interactive
1365                        --dry-run --reuse-message= --reedit-message=
1366                        --reset-author --file= --message= --template=
1367                        --cleanup= --untracked-files --untracked-files=
1368                        --verbose --quiet --fixup= --squash=
1369                        --patch --short --date --allow-empty
1370                        "
1371                return
1372        esac
1373
1374        if __git rev-parse --verify --quiet HEAD >/dev/null; then
1375                __git_complete_index_file "--committable"
1376        else
1377                # This is the first commit
1378                __git_complete_index_file "--cached"
1379        fi
1380}
1381
1382_git_describe ()
1383{
1384        case "$cur" in
1385        --*)
1386                __gitcomp "
1387                        --all --tags --contains --abbrev= --candidates=
1388                        --exact-match --debug --long --match --always --first-parent
1389                        --exclude --dirty --broken
1390                        "
1391                return
1392        esac
1393        __git_complete_refs
1394}
1395
1396__git_diff_algorithms="myers minimal patience histogram"
1397
1398__git_diff_submodule_formats="diff log short"
1399
1400__git_diff_common_options="--stat --numstat --shortstat --summary
1401                        --patch-with-stat --name-only --name-status --color
1402                        --no-color --color-words --no-renames --check
1403                        --full-index --binary --abbrev --diff-filter=
1404                        --find-copies-harder --ignore-cr-at-eol
1405                        --text --ignore-space-at-eol --ignore-space-change
1406                        --ignore-all-space --ignore-blank-lines --exit-code
1407                        --quiet --ext-diff --no-ext-diff
1408                        --no-prefix --src-prefix= --dst-prefix=
1409                        --inter-hunk-context=
1410                        --patience --histogram --minimal
1411                        --raw --word-diff --word-diff-regex=
1412                        --dirstat --dirstat= --dirstat-by-file
1413                        --dirstat-by-file= --cumulative
1414                        --diff-algorithm=
1415                        --submodule --submodule=
1416"
1417
1418_git_diff ()
1419{
1420        __git_has_doubledash && return
1421
1422        case "$cur" in
1423        --diff-algorithm=*)
1424                __gitcomp "$__git_diff_algorithms" "" "${cur##--diff-algorithm=}"
1425                return
1426                ;;
1427        --submodule=*)
1428                __gitcomp "$__git_diff_submodule_formats" "" "${cur##--submodule=}"
1429                return
1430                ;;
1431        --*)
1432                __gitcomp "--cached --staged --pickaxe-all --pickaxe-regex
1433                        --base --ours --theirs --no-index
1434                        $__git_diff_common_options
1435                        "
1436                return
1437                ;;
1438        esac
1439        __git_complete_revlist_file
1440}
1441
1442__git_mergetools_common="diffuse diffmerge ecmerge emerge kdiff3 meld opendiff
1443                        tkdiff vimdiff gvimdiff xxdiff araxis p4merge bc codecompare
1444"
1445
1446_git_difftool ()
1447{
1448        __git_has_doubledash && return
1449
1450        case "$cur" in
1451        --tool=*)
1452                __gitcomp "$__git_mergetools_common kompare" "" "${cur##--tool=}"
1453                return
1454                ;;
1455        --*)
1456                __gitcomp "--cached --staged --pickaxe-all --pickaxe-regex
1457                        --base --ours --theirs
1458                        --no-renames --diff-filter= --find-copies-harder
1459                        --relative --ignore-submodules
1460                        --tool="
1461                return
1462                ;;
1463        esac
1464        __git_complete_revlist_file
1465}
1466
1467__git_fetch_recurse_submodules="yes on-demand no"
1468
1469__git_fetch_options="
1470        --quiet --verbose --append --upload-pack --force --keep --depth=
1471        --tags --no-tags --all --prune --dry-run --recurse-submodules=
1472        --unshallow --update-shallow
1473"
1474
1475_git_fetch ()
1476{
1477        case "$cur" in
1478        --recurse-submodules=*)
1479                __gitcomp "$__git_fetch_recurse_submodules" "" "${cur##--recurse-submodules=}"
1480                return
1481                ;;
1482        --*)
1483                __gitcomp "$__git_fetch_options"
1484                return
1485                ;;
1486        esac
1487        __git_complete_remote_or_refspec
1488}
1489
1490__git_format_patch_options="
1491        --stdout --attach --no-attach --thread --thread= --no-thread
1492        --numbered --start-number --numbered-files --keep-subject --signoff
1493        --signature --no-signature --in-reply-to= --cc= --full-index --binary
1494        --not --all --cover-letter --no-prefix --src-prefix= --dst-prefix=
1495        --inline --suffix= --ignore-if-in-upstream --subject-prefix=
1496        --output-directory --reroll-count --to= --quiet --notes
1497"
1498
1499_git_format_patch ()
1500{
1501        case "$cur" in
1502        --thread=*)
1503                __gitcomp "
1504                        deep shallow
1505                        " "" "${cur##--thread=}"
1506                return
1507                ;;
1508        --*)
1509                __gitcomp "$__git_format_patch_options"
1510                return
1511                ;;
1512        esac
1513        __git_complete_revlist
1514}
1515
1516_git_fsck ()
1517{
1518        case "$cur" in
1519        --*)
1520                __gitcomp "
1521                        --tags --root --unreachable --cache --no-reflogs --full
1522                        --strict --verbose --lost-found --name-objects
1523                        "
1524                return
1525                ;;
1526        esac
1527}
1528
1529_git_gc ()
1530{
1531        case "$cur" in
1532        --*)
1533                __gitcomp "--prune --aggressive"
1534                return
1535                ;;
1536        esac
1537}
1538
1539_git_gitk ()
1540{
1541        _gitk
1542}
1543
1544# Lists matching symbol names from a tag (as in ctags) file.
1545# 1: List symbol names matching this word.
1546# 2: The tag file to list symbol names from.
1547# 3: A prefix to be added to each listed symbol name (optional).
1548# 4: A suffix to be appended to each listed symbol name (optional).
1549__git_match_ctag () {
1550        awk -v pfx="${3-}" -v sfx="${4-}" "
1551                /^${1//\//\\/}/ { print pfx \$1 sfx }
1552                " "$2"
1553}
1554
1555# Complete symbol names from a tag file.
1556# Usage: __git_complete_symbol [<option>]...
1557# --tags=<file>: The tag file to list symbol names from instead of the
1558#                default "tags".
1559# --pfx=<prefix>: A prefix to be added to each symbol name.
1560# --cur=<word>: The current symbol name to be completed.  Defaults to
1561#               the current word to be completed.
1562# --sfx=<suffix>: A suffix to be appended to each symbol name instead
1563#                 of the default space.
1564__git_complete_symbol () {
1565        local tags=tags pfx="" cur_="${cur-}" sfx=" "
1566
1567        while test $# != 0; do
1568                case "$1" in
1569                --tags=*)       tags="${1##--tags=}" ;;
1570                --pfx=*)        pfx="${1##--pfx=}" ;;
1571                --cur=*)        cur_="${1##--cur=}" ;;
1572                --sfx=*)        sfx="${1##--sfx=}" ;;
1573                *)              return 1 ;;
1574                esac
1575                shift
1576        done
1577
1578        if test -r "$tags"; then
1579                __gitcomp_direct "$(__git_match_ctag "$cur_" "$tags" "$pfx" "$sfx")"
1580        fi
1581}
1582
1583_git_grep ()
1584{
1585        __git_has_doubledash && return
1586
1587        case "$cur" in
1588        --*)
1589                __gitcomp "
1590                        --cached
1591                        --text --ignore-case --word-regexp --invert-match
1592                        --full-name --line-number
1593                        --extended-regexp --basic-regexp --fixed-strings
1594                        --perl-regexp
1595                        --threads
1596                        --files-with-matches --name-only
1597                        --files-without-match
1598                        --max-depth
1599                        --count
1600                        --and --or --not --all-match
1601                        --break --heading --show-function --function-context
1602                        --untracked --no-index
1603                        "
1604                return
1605                ;;
1606        esac
1607
1608        case "$cword,$prev" in
1609        2,*|*,-*)
1610                __git_complete_symbol && return
1611                ;;
1612        esac
1613
1614        __git_complete_refs
1615}
1616
1617_git_help ()
1618{
1619        case "$cur" in
1620        --*)
1621                __gitcomp "--all --guides --info --man --web"
1622                return
1623                ;;
1624        esac
1625        __git_compute_all_commands
1626        __gitcomp "$__git_all_commands $(__git_aliases)
1627                attributes cli core-tutorial cvs-migration
1628                diffcore everyday gitk glossary hooks ignore modules
1629                namespaces repository-layout revisions tutorial tutorial-2
1630                workflows
1631                "
1632}
1633
1634_git_init ()
1635{
1636        case "$cur" in
1637        --shared=*)
1638                __gitcomp "
1639                        false true umask group all world everybody
1640                        " "" "${cur##--shared=}"
1641                return
1642                ;;
1643        --*)
1644                __gitcomp "--quiet --bare --template= --shared --shared="
1645                return
1646                ;;
1647        esac
1648}
1649
1650_git_ls_files ()
1651{
1652        case "$cur" in
1653        --*)
1654                __gitcomp "--cached --deleted --modified --others --ignored
1655                        --stage --directory --no-empty-directory --unmerged
1656                        --killed --exclude= --exclude-from=
1657                        --exclude-per-directory= --exclude-standard
1658                        --error-unmatch --with-tree= --full-name
1659                        --abbrev --ignored --exclude-per-directory
1660                        "
1661                return
1662                ;;
1663        esac
1664
1665        # XXX ignore options like --modified and always suggest all cached
1666        # files.
1667        __git_complete_index_file "--cached"
1668}
1669
1670_git_ls_remote ()
1671{
1672        case "$cur" in
1673        --*)
1674                __gitcomp "--heads --tags --refs --get-url --symref"
1675                return
1676                ;;
1677        esac
1678        __gitcomp_nl "$(__git_remotes)"
1679}
1680
1681_git_ls_tree ()
1682{
1683        __git_complete_file
1684}
1685
1686# Options that go well for log, shortlog and gitk
1687__git_log_common_options="
1688        --not --all
1689        --branches --tags --remotes
1690        --first-parent --merges --no-merges
1691        --max-count=
1692        --max-age= --since= --after=
1693        --min-age= --until= --before=
1694        --min-parents= --max-parents=
1695        --no-min-parents --no-max-parents
1696"
1697# Options that go well for log and gitk (not shortlog)
1698__git_log_gitk_options="
1699        --dense --sparse --full-history
1700        --simplify-merges --simplify-by-decoration
1701        --left-right --notes --no-notes
1702"
1703# Options that go well for log and shortlog (not gitk)
1704__git_log_shortlog_options="
1705        --author= --committer= --grep=
1706        --all-match --invert-grep
1707"
1708
1709__git_log_pretty_formats="oneline short medium full fuller email raw format:"
1710__git_log_date_formats="relative iso8601 rfc2822 short local default raw"
1711
1712_git_log ()
1713{
1714        __git_has_doubledash && return
1715        __git_find_repo_path
1716
1717        local merge=""
1718        if [ -f "$__git_repo_path/MERGE_HEAD" ]; then
1719                merge="--merge"
1720        fi
1721        case "$prev,$cur" in
1722        -L,:*:*)
1723                return  # fall back to Bash filename completion
1724                ;;
1725        -L,:*)
1726                __git_complete_symbol --cur="${cur#:}" --sfx=":"
1727                return
1728                ;;
1729        -G,*|-S,*)
1730                __git_complete_symbol
1731                return
1732                ;;
1733        esac
1734        case "$cur" in
1735        --pretty=*|--format=*)
1736                __gitcomp "$__git_log_pretty_formats $(__git_pretty_aliases)
1737                        " "" "${cur#*=}"
1738                return
1739                ;;
1740        --date=*)
1741                __gitcomp "$__git_log_date_formats" "" "${cur##--date=}"
1742                return
1743                ;;
1744        --decorate=*)
1745                __gitcomp "full short no" "" "${cur##--decorate=}"
1746                return
1747                ;;
1748        --diff-algorithm=*)
1749                __gitcomp "$__git_diff_algorithms" "" "${cur##--diff-algorithm=}"
1750                return
1751                ;;
1752        --submodule=*)
1753                __gitcomp "$__git_diff_submodule_formats" "" "${cur##--submodule=}"
1754                return
1755                ;;
1756        --*)
1757                __gitcomp "
1758                        $__git_log_common_options
1759                        $__git_log_shortlog_options
1760                        $__git_log_gitk_options
1761                        --root --topo-order --date-order --reverse
1762                        --follow --full-diff
1763                        --abbrev-commit --abbrev=
1764                        --relative-date --date=
1765                        --pretty= --format= --oneline
1766                        --show-signature
1767                        --cherry-mark
1768                        --cherry-pick
1769                        --graph
1770                        --decorate --decorate=
1771                        --walk-reflogs
1772                        --parents --children
1773                        $merge
1774                        $__git_diff_common_options
1775                        --pickaxe-all --pickaxe-regex
1776                        "
1777                return
1778                ;;
1779        -L:*:*)
1780                return  # fall back to Bash filename completion
1781                ;;
1782        -L:*)
1783                __git_complete_symbol --cur="${cur#-L:}" --sfx=":"
1784                return
1785                ;;
1786        -G*)
1787                __git_complete_symbol --pfx="-G" --cur="${cur#-G}"
1788                return
1789                ;;
1790        -S*)
1791                __git_complete_symbol --pfx="-S" --cur="${cur#-S}"
1792                return
1793                ;;
1794        esac
1795        __git_complete_revlist
1796}
1797
1798# Common merge options shared by git-merge(1) and git-pull(1).
1799__git_merge_options="
1800        --no-commit --no-stat --log --no-log --squash --strategy
1801        --commit --stat --no-squash --ff --no-ff --ff-only --edit --no-edit
1802        --verify-signatures --no-verify-signatures --gpg-sign
1803        --quiet --verbose --progress --no-progress
1804"
1805
1806_git_merge ()
1807{
1808        __git_complete_strategy && return
1809
1810        case "$cur" in
1811        --*)
1812                __gitcomp "$__git_merge_options
1813                        --rerere-autoupdate --no-rerere-autoupdate --abort --continue"
1814                return
1815        esac
1816        __git_complete_refs
1817}
1818
1819_git_mergetool ()
1820{
1821        case "$cur" in
1822        --tool=*)
1823                __gitcomp "$__git_mergetools_common tortoisemerge" "" "${cur##--tool=}"
1824                return
1825                ;;
1826        --*)
1827                __gitcomp "--tool= --prompt --no-prompt"
1828                return
1829                ;;
1830        esac
1831}
1832
1833_git_merge_base ()
1834{
1835        case "$cur" in
1836        --*)
1837                __gitcomp "--octopus --independent --is-ancestor --fork-point"
1838                return
1839                ;;
1840        esac
1841        __git_complete_refs
1842}
1843
1844_git_mv ()
1845{
1846        case "$cur" in
1847        --*)
1848                __gitcomp "--dry-run"
1849                return
1850                ;;
1851        esac
1852
1853        if [ $(__git_count_arguments "mv") -gt 0 ]; then
1854                # We need to show both cached and untracked files (including
1855                # empty directories) since this may not be the last argument.
1856                __git_complete_index_file "--cached --others --directory"
1857        else
1858                __git_complete_index_file "--cached"
1859        fi
1860}
1861
1862_git_name_rev ()
1863{
1864        __gitcomp "--tags --all --stdin"
1865}
1866
1867_git_notes ()
1868{
1869        local subcommands='add append copy edit list prune remove show'
1870        local subcommand="$(__git_find_on_cmdline "$subcommands")"
1871
1872        case "$subcommand,$cur" in
1873        ,--*)
1874                __gitcomp '--ref'
1875                ;;
1876        ,*)
1877                case "$prev" in
1878                --ref)
1879                        __git_complete_refs
1880                        ;;
1881                *)
1882                        __gitcomp "$subcommands --ref"
1883                        ;;
1884                esac
1885                ;;
1886        add,--reuse-message=*|append,--reuse-message=*|\
1887        add,--reedit-message=*|append,--reedit-message=*)
1888                __git_complete_refs --cur="${cur#*=}"
1889                ;;
1890        add,--*|append,--*)
1891                __gitcomp '--file= --message= --reedit-message=
1892                                --reuse-message='
1893                ;;
1894        copy,--*)
1895                __gitcomp '--stdin'
1896                ;;
1897        prune,--*)
1898                __gitcomp '--dry-run --verbose'
1899                ;;
1900        prune,*)
1901                ;;
1902        *)
1903                case "$prev" in
1904                -m|-F)
1905                        ;;
1906                *)
1907                        __git_complete_refs
1908                        ;;
1909                esac
1910                ;;
1911        esac
1912}
1913
1914_git_pull ()
1915{
1916        __git_complete_strategy && return
1917
1918        case "$cur" in
1919        --recurse-submodules=*)
1920                __gitcomp "$__git_fetch_recurse_submodules" "" "${cur##--recurse-submodules=}"
1921                return
1922                ;;
1923        --*)
1924                __gitcomp "
1925                        --rebase --no-rebase
1926                        --autostash --no-autostash
1927                        $__git_merge_options
1928                        $__git_fetch_options
1929                "
1930                return
1931                ;;
1932        esac
1933        __git_complete_remote_or_refspec
1934}
1935
1936__git_push_recurse_submodules="check on-demand only"
1937
1938__git_complete_force_with_lease ()
1939{
1940        local cur_=$1
1941
1942        case "$cur_" in
1943        --*=)
1944                ;;
1945        *:*)
1946                __git_complete_refs --cur="${cur_#*:}"
1947                ;;
1948        *)
1949                __git_complete_refs --cur="$cur_"
1950                ;;
1951        esac
1952}
1953
1954_git_push ()
1955{
1956        case "$prev" in
1957        --repo)
1958                __gitcomp_nl "$(__git_remotes)"
1959                return
1960                ;;
1961        --recurse-submodules)
1962                __gitcomp "$__git_push_recurse_submodules"
1963                return
1964                ;;
1965        esac
1966        case "$cur" in
1967        --repo=*)
1968                __gitcomp_nl "$(__git_remotes)" "" "${cur##--repo=}"
1969                return
1970                ;;
1971        --recurse-submodules=*)
1972                __gitcomp "$__git_push_recurse_submodules" "" "${cur##--recurse-submodules=}"
1973                return
1974                ;;
1975        --force-with-lease=*)
1976                __git_complete_force_with_lease "${cur##--force-with-lease=}"
1977                return
1978                ;;
1979        --*)
1980                __gitcomp "
1981                        --all --mirror --tags --dry-run --force --verbose
1982                        --quiet --prune --delete --follow-tags
1983                        --receive-pack= --repo= --set-upstream
1984                        --force-with-lease --force-with-lease= --recurse-submodules=
1985                "
1986                return
1987                ;;
1988        esac
1989        __git_complete_remote_or_refspec
1990}
1991
1992_git_rebase ()
1993{
1994        __git_find_repo_path
1995        if [ -f "$__git_repo_path"/rebase-merge/interactive ]; then
1996                __gitcomp "--continue --skip --abort --quit --edit-todo"
1997                return
1998        elif [ -d "$__git_repo_path"/rebase-apply ] || \
1999             [ -d "$__git_repo_path"/rebase-merge ]; then
2000                __gitcomp "--continue --skip --abort --quit"
2001                return
2002        fi
2003        __git_complete_strategy && return
2004        case "$cur" in
2005        --whitespace=*)
2006                __gitcomp "$__git_whitespacelist" "" "${cur##--whitespace=}"
2007                return
2008                ;;
2009        --*)
2010                __gitcomp "
2011                        --onto --merge --strategy --interactive
2012                        --preserve-merges --stat --no-stat
2013                        --committer-date-is-author-date --ignore-date
2014                        --ignore-whitespace --whitespace=
2015                        --autosquash --no-autosquash
2016                        --fork-point --no-fork-point
2017                        --autostash --no-autostash
2018                        --verify --no-verify
2019                        --keep-empty --root --force-rebase --no-ff
2020                        --exec
2021                        "
2022
2023                return
2024        esac
2025        __git_complete_refs
2026}
2027
2028_git_reflog ()
2029{
2030        local subcommands="show delete expire"
2031        local subcommand="$(__git_find_on_cmdline "$subcommands")"
2032
2033        if [ -z "$subcommand" ]; then
2034                __gitcomp "$subcommands"
2035        else
2036                __git_complete_refs
2037        fi
2038}
2039
2040__git_send_email_confirm_options="always never auto cc compose"
2041__git_send_email_suppresscc_options="author self cc bodycc sob cccmd body all"
2042
2043_git_send_email ()
2044{
2045        case "$prev" in
2046        --to|--cc|--bcc|--from)
2047                __gitcomp "$(__git send-email --dump-aliases)"
2048                return
2049                ;;
2050        esac
2051
2052        case "$cur" in
2053        --confirm=*)
2054                __gitcomp "
2055                        $__git_send_email_confirm_options
2056                        " "" "${cur##--confirm=}"
2057                return
2058                ;;
2059        --suppress-cc=*)
2060                __gitcomp "
2061                        $__git_send_email_suppresscc_options
2062                        " "" "${cur##--suppress-cc=}"
2063
2064                return
2065                ;;
2066        --smtp-encryption=*)
2067                __gitcomp "ssl tls" "" "${cur##--smtp-encryption=}"
2068                return
2069                ;;
2070        --thread=*)
2071                __gitcomp "
2072                        deep shallow
2073                        " "" "${cur##--thread=}"
2074                return
2075                ;;
2076        --to=*|--cc=*|--bcc=*|--from=*)
2077                __gitcomp "$(__git send-email --dump-aliases)" "" "${cur#--*=}"
2078                return
2079                ;;
2080        --*)
2081                __gitcomp "--annotate --bcc --cc --cc-cmd --chain-reply-to
2082                        --compose --confirm= --dry-run --envelope-sender
2083                        --from --identity
2084                        --in-reply-to --no-chain-reply-to --no-signed-off-by-cc
2085                        --no-suppress-from --no-thread --quiet
2086                        --signed-off-by-cc --smtp-pass --smtp-server
2087                        --smtp-server-port --smtp-encryption= --smtp-user
2088                        --subject --suppress-cc= --suppress-from --thread --to
2089                        --validate --no-validate
2090                        $__git_format_patch_options"
2091                return
2092                ;;
2093        esac
2094        __git_complete_revlist
2095}
2096
2097_git_stage ()
2098{
2099        _git_add
2100}
2101
2102_git_status ()
2103{
2104        local complete_opt
2105        local untracked_state
2106
2107        case "$cur" in
2108        --ignore-submodules=*)
2109                __gitcomp "none untracked dirty all" "" "${cur##--ignore-submodules=}"
2110                return
2111                ;;
2112        --untracked-files=*)
2113                __gitcomp "$__git_untracked_file_modes" "" "${cur##--untracked-files=}"
2114                return
2115                ;;
2116        --column=*)
2117                __gitcomp "
2118                        always never auto column row plain dense nodense
2119                        " "" "${cur##--column=}"
2120                return
2121                ;;
2122        --*)
2123                __gitcomp "
2124                        --short --branch --porcelain --long --verbose
2125                        --untracked-files= --ignore-submodules= --ignored
2126                        --column= --no-column
2127                        "
2128                return
2129                ;;
2130        esac
2131
2132        untracked_state="$(__git_get_option_value "-u" "--untracked-files=" \
2133                "$__git_untracked_file_modes" "status.showUntrackedFiles")"
2134
2135        case "$untracked_state" in
2136        no)
2137                # --ignored option does not matter
2138                complete_opt=
2139                ;;
2140        all|normal|*)
2141                complete_opt="--cached --directory --no-empty-directory --others"
2142
2143                if [ -n "$(__git_find_on_cmdline "--ignored")" ]; then
2144                        complete_opt="$complete_opt --ignored --exclude=*"
2145                fi
2146                ;;
2147        esac
2148
2149        __git_complete_index_file "$complete_opt"
2150}
2151
2152__git_config_get_set_variables ()
2153{
2154        local prevword word config_file= c=$cword
2155        while [ $c -gt 1 ]; do
2156                word="${words[c]}"
2157                case "$word" in
2158                --system|--global|--local|--file=*)
2159                        config_file="$word"
2160                        break
2161                        ;;
2162                -f|--file)
2163                        config_file="$word $prevword"
2164                        break
2165                        ;;
2166                esac
2167                prevword=$word
2168                c=$((--c))
2169        done
2170
2171        __git config $config_file --name-only --list
2172}
2173
2174_git_config ()
2175{
2176        case "$prev" in
2177        branch.*.remote|branch.*.pushremote)
2178                __gitcomp_nl "$(__git_remotes)"
2179                return
2180                ;;
2181        branch.*.merge)
2182                __git_complete_refs
2183                return
2184                ;;
2185        branch.*.rebase)
2186                __gitcomp "false true preserve interactive"
2187                return
2188                ;;
2189        remote.pushdefault)
2190                __gitcomp_nl "$(__git_remotes)"
2191                return
2192                ;;
2193        remote.*.fetch)
2194                local remote="${prev#remote.}"
2195                remote="${remote%.fetch}"
2196                if [ -z "$cur" ]; then
2197                        __gitcomp_nl "refs/heads/" "" "" ""
2198                        return
2199                fi
2200                __gitcomp_nl "$(__git_refs_remotes "$remote")"
2201                return
2202                ;;
2203        remote.*.push)
2204                local remote="${prev#remote.}"
2205                remote="${remote%.push}"
2206                __gitcomp_nl "$(__git for-each-ref \
2207                        --format='%(refname):%(refname)' refs/heads)"
2208                return
2209                ;;
2210        pull.twohead|pull.octopus)
2211                __git_compute_merge_strategies
2212                __gitcomp "$__git_merge_strategies"
2213                return
2214                ;;
2215        color.branch|color.diff|color.interactive|\
2216        color.showbranch|color.status|color.ui)
2217                __gitcomp "always never auto"
2218                return
2219                ;;
2220        color.pager)
2221                __gitcomp "false true"
2222                return
2223                ;;
2224        color.*.*)
2225                __gitcomp "
2226                        normal black red green yellow blue magenta cyan white
2227                        bold dim ul blink reverse
2228                        "
2229                return
2230                ;;
2231        diff.submodule)
2232                __gitcomp "log short"
2233                return
2234                ;;
2235        help.format)
2236                __gitcomp "man info web html"
2237                return
2238                ;;
2239        log.date)
2240                __gitcomp "$__git_log_date_formats"
2241                return
2242                ;;
2243        sendemail.aliasesfiletype)
2244                __gitcomp "mutt mailrc pine elm gnus"
2245                return
2246                ;;
2247        sendemail.confirm)
2248                __gitcomp "$__git_send_email_confirm_options"
2249                return
2250                ;;
2251        sendemail.suppresscc)
2252                __gitcomp "$__git_send_email_suppresscc_options"
2253                return
2254                ;;
2255        sendemail.transferencoding)
2256                __gitcomp "7bit 8bit quoted-printable base64"
2257                return
2258                ;;
2259        --get|--get-all|--unset|--unset-all)
2260                __gitcomp_nl "$(__git_config_get_set_variables)"
2261                return
2262                ;;
2263        *.*)
2264                return
2265                ;;
2266        esac
2267        case "$cur" in
2268        --*)
2269                __gitcomp "
2270                        --system --global --local --file=
2271                        --list --replace-all
2272                        --get --get-all --get-regexp
2273                        --add --unset --unset-all
2274                        --remove-section --rename-section
2275                        --name-only
2276                        "
2277                return
2278                ;;
2279        branch.*.*)
2280                local pfx="${cur%.*}." cur_="${cur##*.}"
2281                __gitcomp "remote pushremote merge mergeoptions rebase" "$pfx" "$cur_"
2282                return
2283                ;;
2284        branch.*)
2285                local pfx="${cur%.*}." cur_="${cur#*.}"
2286                __gitcomp_direct "$(__git_heads "$pfx" "$cur_" ".")"
2287                __gitcomp_nl_append $'autosetupmerge\nautosetuprebase\n' "$pfx" "$cur_"
2288                return
2289                ;;
2290        guitool.*.*)
2291                local pfx="${cur%.*}." cur_="${cur##*.}"
2292                __gitcomp "
2293                        argprompt cmd confirm needsfile noconsole norescan
2294                        prompt revprompt revunmerged title
2295                        " "$pfx" "$cur_"
2296                return
2297                ;;
2298        difftool.*.*)
2299                local pfx="${cur%.*}." cur_="${cur##*.}"
2300                __gitcomp "cmd path" "$pfx" "$cur_"
2301                return
2302                ;;
2303        man.*.*)
2304                local pfx="${cur%.*}." cur_="${cur##*.}"
2305                __gitcomp "cmd path" "$pfx" "$cur_"
2306                return
2307                ;;
2308        mergetool.*.*)
2309                local pfx="${cur%.*}." cur_="${cur##*.}"
2310                __gitcomp "cmd path trustExitCode" "$pfx" "$cur_"
2311                return
2312                ;;
2313        pager.*)
2314                local pfx="${cur%.*}." cur_="${cur#*.}"
2315                __git_compute_all_commands
2316                __gitcomp_nl "$__git_all_commands" "$pfx" "$cur_"
2317                return
2318                ;;
2319        remote.*.*)
2320                local pfx="${cur%.*}." cur_="${cur##*.}"
2321                __gitcomp "
2322                        url proxy fetch push mirror skipDefaultUpdate
2323                        receivepack uploadpack tagopt pushurl
2324                        " "$pfx" "$cur_"
2325                return
2326                ;;
2327        remote.*)
2328                local pfx="${cur%.*}." cur_="${cur#*.}"
2329                __gitcomp_nl "$(__git_remotes)" "$pfx" "$cur_" "."
2330                __gitcomp_nl_append "pushdefault" "$pfx" "$cur_"
2331                return
2332                ;;
2333        url.*.*)
2334                local pfx="${cur%.*}." cur_="${cur##*.}"
2335                __gitcomp "insteadOf pushInsteadOf" "$pfx" "$cur_"
2336                return
2337                ;;
2338        esac
2339        __gitcomp "
2340                add.ignoreErrors
2341                advice.amWorkDir
2342                advice.commitBeforeMerge
2343                advice.detachedHead
2344                advice.implicitIdentity
2345                advice.pushAlreadyExists
2346                advice.pushFetchFirst
2347                advice.pushNeedsForce
2348                advice.pushNonFFCurrent
2349                advice.pushNonFFMatching
2350                advice.pushUpdateRejected
2351                advice.resolveConflict
2352                advice.rmHints
2353                advice.statusHints
2354                advice.statusUoption
2355                advice.ignoredHook
2356                alias.
2357                am.keepcr
2358                am.threeWay
2359                apply.ignorewhitespace
2360                apply.whitespace
2361                branch.autosetupmerge
2362                branch.autosetuprebase
2363                browser.
2364                clean.requireForce
2365                color.branch
2366                color.branch.current
2367                color.branch.local
2368                color.branch.plain
2369                color.branch.remote
2370                color.decorate.HEAD
2371                color.decorate.branch
2372                color.decorate.remoteBranch
2373                color.decorate.stash
2374                color.decorate.tag
2375                color.diff
2376                color.diff.commit
2377                color.diff.frag
2378                color.diff.func
2379                color.diff.meta
2380                color.diff.new
2381                color.diff.old
2382                color.diff.plain
2383                color.diff.whitespace
2384                color.grep
2385                color.grep.context
2386                color.grep.filename
2387                color.grep.function
2388                color.grep.linenumber
2389                color.grep.match
2390                color.grep.selected
2391                color.grep.separator
2392                color.interactive
2393                color.interactive.error
2394                color.interactive.header
2395                color.interactive.help
2396                color.interactive.prompt
2397                color.pager
2398                color.showbranch
2399                color.status
2400                color.status.added
2401                color.status.changed
2402                color.status.header
2403                color.status.localBranch
2404                color.status.nobranch
2405                color.status.remoteBranch
2406                color.status.unmerged
2407                color.status.untracked
2408                color.status.updated
2409                color.ui
2410                commit.cleanup
2411                commit.gpgSign
2412                commit.status
2413                commit.template
2414                commit.verbose
2415                core.abbrev
2416                core.askpass
2417                core.attributesfile
2418                core.autocrlf
2419                core.bare
2420                core.bigFileThreshold
2421                core.checkStat
2422                core.commentChar
2423                core.commitGraph
2424                core.compression
2425                core.createObject
2426                core.deltaBaseCacheLimit
2427                core.editor
2428                core.eol
2429                core.excludesfile
2430                core.fileMode
2431                core.fsyncobjectfiles
2432                core.gitProxy
2433                core.hideDotFiles
2434                core.hooksPath
2435                core.ignoreStat
2436                core.ignorecase
2437                core.logAllRefUpdates
2438                core.loosecompression
2439                core.notesRef
2440                core.packedGitLimit
2441                core.packedGitWindowSize
2442                core.packedRefsTimeout
2443                core.pager
2444                core.precomposeUnicode
2445                core.preferSymlinkRefs
2446                core.preloadindex
2447                core.protectHFS
2448                core.protectNTFS
2449                core.quotepath
2450                core.repositoryFormatVersion
2451                core.safecrlf
2452                core.sharedRepository
2453                core.sparseCheckout
2454                core.splitIndex
2455                core.sshCommand
2456                core.symlinks
2457                core.trustctime
2458                core.untrackedCache
2459                core.warnAmbiguousRefs
2460                core.whitespace
2461                core.worktree
2462                credential.helper
2463                credential.useHttpPath
2464                credential.username
2465                credentialCache.ignoreSIGHUP
2466                diff.autorefreshindex
2467                diff.external
2468                diff.ignoreSubmodules
2469                diff.mnemonicprefix
2470                diff.noprefix
2471                diff.renameLimit
2472                diff.renames
2473                diff.statGraphWidth
2474                diff.submodule
2475                diff.suppressBlankEmpty
2476                diff.tool
2477                diff.wordRegex
2478                diff.algorithm
2479                difftool.
2480                difftool.prompt
2481                fetch.recurseSubmodules
2482                fetch.unpackLimit
2483                format.attach
2484                format.cc
2485                format.coverLetter
2486                format.from
2487                format.headers
2488                format.numbered
2489                format.pretty
2490                format.signature
2491                format.signoff
2492                format.subjectprefix
2493                format.suffix
2494                format.thread
2495                format.to
2496                gc.
2497                gc.aggressiveDepth
2498                gc.aggressiveWindow
2499                gc.auto
2500                gc.autoDetach
2501                gc.autopacklimit
2502                gc.logExpiry
2503                gc.packrefs
2504                gc.pruneexpire
2505                gc.reflogexpire
2506                gc.reflogexpireunreachable
2507                gc.rerereresolved
2508                gc.rerereunresolved
2509                gc.worktreePruneExpire
2510                gitcvs.allbinary
2511                gitcvs.commitmsgannotation
2512                gitcvs.dbTableNamePrefix
2513                gitcvs.dbdriver
2514                gitcvs.dbname
2515                gitcvs.dbpass
2516                gitcvs.dbuser
2517                gitcvs.enabled
2518                gitcvs.logfile
2519                gitcvs.usecrlfattr
2520                guitool.
2521                gui.blamehistoryctx
2522                gui.commitmsgwidth
2523                gui.copyblamethreshold
2524                gui.diffcontext
2525                gui.encoding
2526                gui.fastcopyblame
2527                gui.matchtrackingbranch
2528                gui.newbranchtemplate
2529                gui.pruneduringfetch
2530                gui.spellingdictionary
2531                gui.trustmtime
2532                help.autocorrect
2533                help.browser
2534                help.format
2535                http.lowSpeedLimit
2536                http.lowSpeedTime
2537                http.maxRequests
2538                http.minSessions
2539                http.noEPSV
2540                http.postBuffer
2541                http.proxy
2542                http.sslCipherList
2543                http.sslVersion
2544                http.sslCAInfo
2545                http.sslCAPath
2546                http.sslCert
2547                http.sslCertPasswordProtected
2548                http.sslKey
2549                http.sslVerify
2550                http.useragent
2551                i18n.commitEncoding
2552                i18n.logOutputEncoding
2553                imap.authMethod
2554                imap.folder
2555                imap.host
2556                imap.pass
2557                imap.port
2558                imap.preformattedHTML
2559                imap.sslverify
2560                imap.tunnel
2561                imap.user
2562                init.templatedir
2563                instaweb.browser
2564                instaweb.httpd
2565                instaweb.local
2566                instaweb.modulepath
2567                instaweb.port
2568                interactive.singlekey
2569                log.date
2570                log.decorate
2571                log.showroot
2572                mailmap.file
2573                man.
2574                man.viewer
2575                merge.
2576                merge.conflictstyle
2577                merge.log
2578                merge.renameLimit
2579                merge.renormalize
2580                merge.stat
2581                merge.tool
2582                merge.verbosity
2583                mergetool.
2584                mergetool.keepBackup
2585                mergetool.keepTemporaries
2586                mergetool.prompt
2587                notes.displayRef
2588                notes.rewrite.
2589                notes.rewrite.amend
2590                notes.rewrite.rebase
2591                notes.rewriteMode
2592                notes.rewriteRef
2593                pack.compression
2594                pack.deltaCacheLimit
2595                pack.deltaCacheSize
2596                pack.depth
2597                pack.indexVersion
2598                pack.packSizeLimit
2599                pack.threads
2600                pack.window
2601                pack.windowMemory
2602                pager.
2603                pretty.
2604                pull.octopus
2605                pull.twohead
2606                push.default
2607                push.followTags
2608                rebase.autosquash
2609                rebase.stat
2610                receive.autogc
2611                receive.denyCurrentBranch
2612                receive.denyDeleteCurrent
2613                receive.denyDeletes
2614                receive.denyNonFastForwards
2615                receive.fsckObjects
2616                receive.unpackLimit
2617                receive.updateserverinfo
2618                remote.pushdefault
2619                remotes.
2620                repack.usedeltabaseoffset
2621                rerere.autoupdate
2622                rerere.enabled
2623                sendemail.
2624                sendemail.aliasesfile
2625                sendemail.aliasfiletype
2626                sendemail.bcc
2627                sendemail.cc
2628                sendemail.cccmd
2629                sendemail.chainreplyto
2630                sendemail.confirm
2631                sendemail.envelopesender
2632                sendemail.from
2633                sendemail.identity
2634                sendemail.multiedit
2635                sendemail.signedoffbycc
2636                sendemail.smtpdomain
2637                sendemail.smtpencryption
2638                sendemail.smtppass
2639                sendemail.smtpserver
2640                sendemail.smtpserveroption
2641                sendemail.smtpserverport
2642                sendemail.smtpuser
2643                sendemail.suppresscc
2644                sendemail.suppressfrom
2645                sendemail.thread
2646                sendemail.to
2647                sendemail.tocmd
2648                sendemail.validate
2649                sendemail.smtpbatchsize
2650                sendemail.smtprelogindelay
2651                showbranch.default
2652                status.relativePaths
2653                status.showUntrackedFiles
2654                status.submodulesummary
2655                submodule.
2656                tar.umask
2657                transfer.unpackLimit
2658                url.
2659                user.email
2660                user.name
2661                user.signingkey
2662                web.browser
2663                branch. remote.
2664        "
2665}
2666
2667_git_remote ()
2668{
2669        local subcommands="
2670                add rename remove set-head set-branches
2671                get-url set-url show prune update
2672                "
2673        local subcommand="$(__git_find_on_cmdline "$subcommands")"
2674        if [ -z "$subcommand" ]; then
2675                case "$cur" in
2676                --*)
2677                        __gitcomp "--verbose"
2678                        ;;
2679                *)
2680                        __gitcomp "$subcommands"
2681                        ;;
2682                esac
2683                return
2684        fi
2685
2686        case "$subcommand,$cur" in
2687        add,--*)
2688                __gitcomp "--track --master --fetch --tags --no-tags --mirror="
2689                ;;
2690        add,*)
2691                ;;
2692        set-head,--*)
2693                __gitcomp "--auto --delete"
2694                ;;
2695        set-branches,--*)
2696                __gitcomp "--add"
2697                ;;
2698        set-head,*|set-branches,*)
2699                __git_complete_remote_or_refspec
2700                ;;
2701        update,--*)
2702                __gitcomp "--prune"
2703                ;;
2704        update,*)
2705                __gitcomp "$(__git_get_config_variables "remotes")"
2706                ;;
2707        set-url,--*)
2708                __gitcomp "--push --add --delete"
2709                ;;
2710        get-url,--*)
2711                __gitcomp "--push --all"
2712                ;;
2713        prune,--*)
2714                __gitcomp "--dry-run"
2715                ;;
2716        *)
2717                __gitcomp_nl "$(__git_remotes)"
2718                ;;
2719        esac
2720}
2721
2722_git_replace ()
2723{
2724        case "$cur" in
2725        --*)
2726                __gitcomp "--edit --graft --format= --list --delete"
2727                return
2728                ;;
2729        esac
2730        __git_complete_refs
2731}
2732
2733_git_rerere ()
2734{
2735        local subcommands="clear forget diff remaining status gc"
2736        local subcommand="$(__git_find_on_cmdline "$subcommands")"
2737        if test -z "$subcommand"
2738        then
2739                __gitcomp "$subcommands"
2740                return
2741        fi
2742}
2743
2744_git_reset ()
2745{
2746        __git_has_doubledash && return
2747
2748        case "$cur" in
2749        --*)
2750                __gitcomp "--merge --mixed --hard --soft --patch --keep"
2751                return
2752                ;;
2753        esac
2754        __git_complete_refs
2755}
2756
2757_git_revert ()
2758{
2759        __git_find_repo_path
2760        if [ -f "$__git_repo_path"/REVERT_HEAD ]; then
2761                __gitcomp "--continue --quit --abort"
2762                return
2763        fi
2764        case "$cur" in
2765        --*)
2766                __gitcomp "
2767                        --edit --mainline --no-edit --no-commit --signoff
2768                        --strategy= --strategy-option=
2769                        "
2770                return
2771                ;;
2772        esac
2773        __git_complete_refs
2774}
2775
2776_git_rm ()
2777{
2778        case "$cur" in
2779        --*)
2780                __gitcomp "--cached --dry-run --ignore-unmatch --quiet"
2781                return
2782                ;;
2783        esac
2784
2785        __git_complete_index_file "--cached"
2786}
2787
2788_git_shortlog ()
2789{
2790        __git_has_doubledash && return
2791
2792        case "$cur" in
2793        --*)
2794                __gitcomp "
2795                        $__git_log_common_options
2796                        $__git_log_shortlog_options
2797                        --numbered --summary --email
2798                        "
2799                return
2800                ;;
2801        esac
2802        __git_complete_revlist
2803}
2804
2805_git_show ()
2806{
2807        __git_has_doubledash && return
2808
2809        case "$cur" in
2810        --pretty=*|--format=*)
2811                __gitcomp "$__git_log_pretty_formats $(__git_pretty_aliases)
2812                        " "" "${cur#*=}"
2813                return
2814                ;;
2815        --diff-algorithm=*)
2816                __gitcomp "$__git_diff_algorithms" "" "${cur##--diff-algorithm=}"
2817                return
2818                ;;
2819        --submodule=*)
2820                __gitcomp "$__git_diff_submodule_formats" "" "${cur##--submodule=}"
2821                return
2822                ;;
2823        --*)
2824                __gitcomp "--pretty= --format= --abbrev-commit --oneline
2825                        --show-signature
2826                        $__git_diff_common_options
2827                        "
2828                return
2829                ;;
2830        esac
2831        __git_complete_revlist_file
2832}
2833
2834_git_show_branch ()
2835{
2836        case "$cur" in
2837        --*)
2838                __gitcomp "
2839                        --all --remotes --topo-order --date-order --current --more=
2840                        --list --independent --merge-base --no-name
2841                        --color --no-color
2842                        --sha1-name --sparse --topics --reflog
2843                        "
2844                return
2845                ;;
2846        esac
2847        __git_complete_revlist
2848}
2849
2850_git_stash ()
2851{
2852        local save_opts='--all --keep-index --no-keep-index --quiet --patch --include-untracked'
2853        local subcommands='push save list show apply clear drop pop create branch'
2854        local subcommand="$(__git_find_on_cmdline "$subcommands")"
2855        if [ -z "$subcommand" ]; then
2856                case "$cur" in
2857                --*)
2858                        __gitcomp "$save_opts"
2859                        ;;
2860                *)
2861                        if [ -z "$(__git_find_on_cmdline "$save_opts")" ]; then
2862                                __gitcomp "$subcommands"
2863                        fi
2864                        ;;
2865                esac
2866        else
2867                case "$subcommand,$cur" in
2868                push,--*)
2869                        __gitcomp "$save_opts --message"
2870                        ;;
2871                save,--*)
2872                        __gitcomp "$save_opts"
2873                        ;;
2874                apply,--*|pop,--*)
2875                        __gitcomp "--index --quiet"
2876                        ;;
2877                drop,--*)
2878                        __gitcomp "--quiet"
2879                        ;;
2880                show,--*|branch,--*)
2881                        ;;
2882                branch,*)
2883                        if [ $cword -eq 3 ]; then
2884                                __git_complete_refs
2885                        else
2886                                __gitcomp_nl "$(__git stash list \
2887                                                | sed -n -e 's/:.*//p')"
2888                        fi
2889                        ;;
2890                show,*|apply,*|drop,*|pop,*)
2891                        __gitcomp_nl "$(__git stash list \
2892                                        | sed -n -e 's/:.*//p')"
2893                        ;;
2894                *)
2895                        ;;
2896                esac
2897        fi
2898}
2899
2900_git_submodule ()
2901{
2902        __git_has_doubledash && return
2903
2904        local subcommands="add status init deinit update summary foreach sync"
2905        local subcommand="$(__git_find_on_cmdline "$subcommands")"
2906        if [ -z "$subcommand" ]; then
2907                case "$cur" in
2908                --*)
2909                        __gitcomp "--quiet"
2910                        ;;
2911                *)
2912                        __gitcomp "$subcommands"
2913                        ;;
2914                esac
2915                return
2916        fi
2917
2918        case "$subcommand,$cur" in
2919        add,--*)
2920                __gitcomp "--branch --force --name --reference --depth"
2921                ;;
2922        status,--*)
2923                __gitcomp "--cached --recursive"
2924                ;;
2925        deinit,--*)
2926                __gitcomp "--force --all"
2927                ;;
2928        update,--*)
2929                __gitcomp "
2930                        --init --remote --no-fetch
2931                        --recommend-shallow --no-recommend-shallow
2932                        --force --rebase --merge --reference --depth --recursive --jobs
2933                "
2934                ;;
2935        summary,--*)
2936                __gitcomp "--cached --files --summary-limit"
2937                ;;
2938        foreach,--*|sync,--*)
2939                __gitcomp "--recursive"
2940                ;;
2941        *)
2942                ;;
2943        esac
2944}
2945
2946_git_svn ()
2947{
2948        local subcommands="
2949                init fetch clone rebase dcommit log find-rev
2950                set-tree commit-diff info create-ignore propget
2951                proplist show-ignore show-externals branch tag blame
2952                migrate mkdirs reset gc
2953                "
2954        local subcommand="$(__git_find_on_cmdline "$subcommands")"
2955        if [ -z "$subcommand" ]; then
2956                __gitcomp "$subcommands"
2957        else
2958                local remote_opts="--username= --config-dir= --no-auth-cache"
2959                local fc_opts="
2960                        --follow-parent --authors-file= --repack=
2961                        --no-metadata --use-svm-props --use-svnsync-props
2962                        --log-window-size= --no-checkout --quiet
2963                        --repack-flags --use-log-author --localtime
2964                        --add-author-from
2965                        --ignore-paths= --include-paths= $remote_opts
2966                        "
2967                local init_opts="
2968                        --template= --shared= --trunk= --tags=
2969                        --branches= --stdlayout --minimize-url
2970                        --no-metadata --use-svm-props --use-svnsync-props
2971                        --rewrite-root= --prefix= $remote_opts
2972                        "
2973                local cmt_opts="
2974                        --edit --rmdir --find-copies-harder --copy-similarity=
2975                        "
2976
2977                case "$subcommand,$cur" in
2978                fetch,--*)
2979                        __gitcomp "--revision= --fetch-all $fc_opts"
2980                        ;;
2981                clone,--*)
2982                        __gitcomp "--revision= $fc_opts $init_opts"
2983                        ;;
2984                init,--*)
2985                        __gitcomp "$init_opts"
2986                        ;;
2987                dcommit,--*)
2988                        __gitcomp "
2989                                --merge --strategy= --verbose --dry-run
2990                                --fetch-all --no-rebase --commit-url
2991                                --revision --interactive $cmt_opts $fc_opts
2992                                "
2993                        ;;
2994                set-tree,--*)
2995                        __gitcomp "--stdin $cmt_opts $fc_opts"
2996                        ;;
2997                create-ignore,--*|propget,--*|proplist,--*|show-ignore,--*|\
2998                show-externals,--*|mkdirs,--*)
2999                        __gitcomp "--revision="
3000                        ;;
3001                log,--*)
3002                        __gitcomp "
3003                                --limit= --revision= --verbose --incremental
3004                                --oneline --show-commit --non-recursive
3005                                --authors-file= --color
3006                                "
3007                        ;;
3008                rebase,--*)
3009                        __gitcomp "
3010                                --merge --verbose --strategy= --local
3011                                --fetch-all --dry-run $fc_opts
3012                                "
3013                        ;;
3014                commit-diff,--*)
3015                        __gitcomp "--message= --file= --revision= $cmt_opts"
3016                        ;;
3017                info,--*)
3018                        __gitcomp "--url"
3019                        ;;
3020                branch,--*)
3021                        __gitcomp "--dry-run --message --tag"
3022                        ;;
3023                tag,--*)
3024                        __gitcomp "--dry-run --message"
3025                        ;;
3026                blame,--*)
3027                        __gitcomp "--git-format"
3028                        ;;
3029                migrate,--*)
3030                        __gitcomp "
3031                                --config-dir= --ignore-paths= --minimize
3032                                --no-auth-cache --username=
3033                                "
3034                        ;;
3035                reset,--*)
3036                        __gitcomp "--revision= --parent"
3037                        ;;
3038                *)
3039                        ;;
3040                esac
3041        fi
3042}
3043
3044_git_tag ()
3045{
3046        local i c=1 f=0
3047        while [ $c -lt $cword ]; do
3048                i="${words[c]}"
3049                case "$i" in
3050                -d|-v)
3051                        __gitcomp_direct "$(__git_tags "" "$cur" " ")"
3052                        return
3053                        ;;
3054                -f)
3055                        f=1
3056                        ;;
3057                esac
3058                ((c++))
3059        done
3060
3061        case "$prev" in
3062        -m|-F)
3063                ;;
3064        -*|tag)
3065                if [ $f = 1 ]; then
3066                        __gitcomp_direct "$(__git_tags "" "$cur" " ")"
3067                fi
3068                ;;
3069        *)
3070                __git_complete_refs
3071                ;;
3072        esac
3073
3074        case "$cur" in
3075        --*)
3076                __gitcomp "
3077                        --list --delete --verify --annotate --message --file
3078                        --sign --cleanup --local-user --force --column --sort=
3079                        --contains --no-contains --points-at --merged --no-merged --create-reflog
3080                        "
3081                ;;
3082        esac
3083}
3084
3085_git_whatchanged ()
3086{
3087        _git_log
3088}
3089
3090_git_worktree ()
3091{
3092        local subcommands="add list lock prune unlock"
3093        local subcommand="$(__git_find_on_cmdline "$subcommands")"
3094        if [ -z "$subcommand" ]; then
3095                __gitcomp "$subcommands"
3096        else
3097                case "$subcommand,$cur" in
3098                add,--*)
3099                        __gitcomp "--detach"
3100                        ;;
3101                list,--*)
3102                        __gitcomp "--porcelain"
3103                        ;;
3104                lock,--*)
3105                        __gitcomp "--reason"
3106                        ;;
3107                prune,--*)
3108                        __gitcomp "--dry-run --expire --verbose"
3109                        ;;
3110                *)
3111                        ;;
3112                esac
3113        fi
3114}
3115
3116__git_main ()
3117{
3118        local i c=1 command __git_dir __git_repo_path
3119        local __git_C_args C_args_count=0
3120
3121        while [ $c -lt $cword ]; do
3122                i="${words[c]}"
3123                case "$i" in
3124                --git-dir=*) __git_dir="${i#--git-dir=}" ;;
3125                --git-dir)   ((c++)) ; __git_dir="${words[c]}" ;;
3126                --bare)      __git_dir="." ;;
3127                --help) command="help"; break ;;
3128                -c|--work-tree|--namespace) ((c++)) ;;
3129                -C)     __git_C_args[C_args_count++]=-C
3130                        ((c++))
3131                        __git_C_args[C_args_count++]="${words[c]}"
3132                        ;;
3133                -*) ;;
3134                *) command="$i"; break ;;
3135                esac
3136                ((c++))
3137        done
3138
3139        if [ -z "$command" ]; then
3140                case "$prev" in
3141                --git-dir|-C|--work-tree)
3142                        # these need a path argument, let's fall back to
3143                        # Bash filename completion
3144                        return
3145                        ;;
3146                -c|--namespace)
3147                        # we don't support completing these options' arguments
3148                        return
3149                        ;;
3150                esac
3151                case "$cur" in
3152                --*)   __gitcomp "
3153                        --paginate
3154                        --no-pager
3155                        --git-dir=
3156                        --bare
3157                        --version
3158                        --exec-path
3159                        --exec-path=
3160                        --html-path
3161                        --man-path
3162                        --info-path
3163                        --work-tree=
3164                        --namespace=
3165                        --no-replace-objects
3166                        --help
3167                        "
3168                        ;;
3169                *)     __git_compute_porcelain_commands
3170                       __gitcomp "$__git_porcelain_commands $(__git_aliases)" ;;
3171                esac
3172                return
3173        fi
3174
3175        local completion_func="_git_${command//-/_}"
3176        declare -f $completion_func >/dev/null 2>/dev/null && $completion_func && return
3177
3178        local expansion=$(__git_aliased_command "$command")
3179        if [ -n "$expansion" ]; then
3180                words[1]=$expansion
3181                completion_func="_git_${expansion//-/_}"
3182                declare -f $completion_func >/dev/null 2>/dev/null && $completion_func
3183        fi
3184}
3185
3186__gitk_main ()
3187{
3188        __git_has_doubledash && return
3189
3190        local __git_repo_path
3191        __git_find_repo_path
3192
3193        local merge=""
3194        if [ -f "$__git_repo_path/MERGE_HEAD" ]; then
3195                merge="--merge"
3196        fi
3197        case "$cur" in
3198        --*)
3199                __gitcomp "
3200                        $__git_log_common_options
3201                        $__git_log_gitk_options
3202                        $merge
3203                        "
3204                return
3205                ;;
3206        esac
3207        __git_complete_revlist
3208}
3209
3210if [[ -n ${ZSH_VERSION-} ]]; then
3211        echo "WARNING: this script is deprecated, please see git-completion.zsh" 1>&2
3212
3213        autoload -U +X compinit && compinit
3214
3215        __gitcomp ()
3216        {
3217                emulate -L zsh
3218
3219                local cur_="${3-$cur}"
3220
3221                case "$cur_" in
3222                --*=)
3223                        ;;
3224                *)
3225                        local c IFS=$' \t\n'
3226                        local -a array
3227                        for c in ${=1}; do
3228                                c="$c${4-}"
3229                                case $c in
3230                                --*=*|*.) ;;
3231                                *) c="$c " ;;
3232                                esac
3233                                array[${#array[@]}+1]="$c"
3234                        done
3235                        compset -P '*[=:]'
3236                        compadd -Q -S '' -p "${2-}" -a -- array && _ret=0
3237                        ;;
3238                esac
3239        }
3240
3241        __gitcomp_direct ()
3242        {
3243                emulate -L zsh
3244
3245                local IFS=$'\n'
3246                compset -P '*[=:]'
3247                compadd -Q -- ${=1} && _ret=0
3248        }
3249
3250        __gitcomp_nl ()
3251        {
3252                emulate -L zsh
3253
3254                local IFS=$'\n'
3255                compset -P '*[=:]'
3256                compadd -Q -S "${4- }" -p "${2-}" -- ${=1} && _ret=0
3257        }
3258
3259        __gitcomp_file ()
3260        {
3261                emulate -L zsh
3262
3263                local IFS=$'\n'
3264                compset -P '*[=:]'
3265                compadd -Q -p "${2-}" -f -- ${=1} && _ret=0
3266        }
3267
3268        _git ()
3269        {
3270                local _ret=1 cur cword prev
3271                cur=${words[CURRENT]}
3272                prev=${words[CURRENT-1]}
3273                let cword=CURRENT-1
3274                emulate ksh -c __${service}_main
3275                let _ret && _default && _ret=0
3276                return _ret
3277        }
3278
3279        compdef _git git gitk
3280        return
3281fi
3282
3283__git_func_wrap ()
3284{
3285        local cur words cword prev
3286        _get_comp_words_by_ref -n =: cur words cword prev
3287        $1
3288}
3289
3290# Setup completion for certain functions defined above by setting common
3291# variables and workarounds.
3292# This is NOT a public function; use at your own risk.
3293__git_complete ()
3294{
3295        local wrapper="__git_wrap${2}"
3296        eval "$wrapper () { __git_func_wrap $2 ; }"
3297        complete -o bashdefault -o default -o nospace -F $wrapper $1 2>/dev/null \
3298                || complete -o default -o nospace -F $wrapper $1
3299}
3300
3301# wrapper for backwards compatibility
3302_git ()
3303{
3304        __git_wrap__git_main
3305}
3306
3307# wrapper for backwards compatibility
3308_gitk ()
3309{
3310        __git_wrap__gitk_main
3311}
3312
3313__git_complete git __git_main
3314__git_complete gitk __gitk_main
3315
3316# The following are necessary only for Cygwin, and only are needed
3317# when the user has tab-completed the executable name and consequently
3318# included the '.exe' suffix.
3319#
3320if [ Cygwin = "$(uname -o 2>/dev/null)" ]; then
3321__git_complete git.exe __git_main
3322fi