contrib / completion / git-completion.bashon commit correct argument checking test for git hash-object (8101407)
   1#
   2# bash completion support for core Git.
   3#
   4# Copyright (C) 2006,2007 Shawn O. Pearce <spearce@spearce.org>
   5# Conceptually based on gitcompletion (http://gitweb.hawaga.org.uk/).
   6# Distributed under the GNU General Public License, version 2.0.
   7#
   8# The contained completion routines provide support for completing:
   9#
  10#    *) local and remote branch names
  11#    *) local and remote tag names
  12#    *) .git/remotes file names
  13#    *) git 'subcommands'
  14#    *) tree paths within 'ref:path/to/file' expressions
  15#    *) common --long-options
  16#
  17# To use these routines:
  18#
  19#    1) Copy this file to somewhere (e.g. ~/.git-completion.sh).
  20#    2) Added the following line to your .bashrc:
  21#        source ~/.git-completion.sh
  22#
  23#    3) You may want to make sure the git executable is available
  24#       in your PATH before this script is sourced, as some caching
  25#       is performed while the script loads.  If git isn't found
  26#       at source time then all lookups will be done on demand,
  27#       which may be slightly slower.
  28#
  29#    4) Consider changing your PS1 to also show the current branch:
  30#        PS1='[\u@\h \W$(__git_ps1 " (%s)")]\$ '
  31#
  32#       The argument to __git_ps1 will be displayed only if you
  33#       are currently in a git repository.  The %s token will be
  34#       the name of the current branch.
  35#
  36# To submit patches:
  37#
  38#    *) Read Documentation/SubmittingPatches
  39#    *) Send all patches to the current maintainer:
  40#
  41#       "Shawn O. Pearce" <spearce@spearce.org>
  42#
  43#    *) Always CC the Git mailing list:
  44#
  45#       git@vger.kernel.org
  46#
  47
  48case "$COMP_WORDBREAKS" in
  49*:*) : great ;;
  50*)   COMP_WORDBREAKS="$COMP_WORDBREAKS:"
  51esac
  52
  53__gitdir ()
  54{
  55        if [ -z "$1" ]; then
  56                if [ -n "$__git_dir" ]; then
  57                        echo "$__git_dir"
  58                elif [ -d .git ]; then
  59                        echo .git
  60                else
  61                        git rev-parse --git-dir 2>/dev/null
  62                fi
  63        elif [ -d "$1/.git" ]; then
  64                echo "$1/.git"
  65        else
  66                echo "$1"
  67        fi
  68}
  69
  70__git_ps1 ()
  71{
  72        local g="$(git rev-parse --git-dir 2>/dev/null)"
  73        if [ -n "$g" ]; then
  74                local r
  75                local b
  76                if [ -d "$g/rebase-apply" ]
  77                then
  78                        if test -f "$g/rebase-apply/rebasing"
  79                        then
  80                                r="|REBASE"
  81                        elif test -f "$g/rebase-apply/applying"
  82                        then
  83                                r="|AM"
  84                        else
  85                                r="|AM/REBASE"
  86                        fi
  87                        b="$(git symbolic-ref HEAD 2>/dev/null)"
  88                elif [ -f "$g/rebase-merge/interactive" ]
  89                then
  90                        r="|REBASE-i"
  91                        b="$(cat "$g/rebase-merge/head-name")"
  92                elif [ -d "$g/rebase-merge" ]
  93                then
  94                        r="|REBASE-m"
  95                        b="$(cat "$g/rebase-merge/head-name")"
  96                elif [ -f "$g/MERGE_HEAD" ]
  97                then
  98                        r="|MERGING"
  99                        b="$(git symbolic-ref HEAD 2>/dev/null)"
 100                else
 101                        if [ -f "$g/BISECT_LOG" ]
 102                        then
 103                                r="|BISECTING"
 104                        fi
 105                        if ! b="$(git symbolic-ref HEAD 2>/dev/null)"
 106                        then
 107                                if ! b="$(git describe --exact-match HEAD 2>/dev/null)"
 108                                then
 109                                        b="$(cut -c1-7 "$g/HEAD")..."
 110                                fi
 111                        fi
 112                fi
 113
 114                if [ -n "$1" ]; then
 115                        printf "$1" "${b##refs/heads/}$r"
 116                else
 117                        printf " (%s)" "${b##refs/heads/}$r"
 118                fi
 119        fi
 120}
 121
 122__gitcomp_1 ()
 123{
 124        local c IFS=' '$'\t'$'\n'
 125        for c in $1; do
 126                case "$c$2" in
 127                --*=*) printf %s$'\n' "$c$2" ;;
 128                *.)    printf %s$'\n' "$c$2" ;;
 129                *)     printf %s$'\n' "$c$2 " ;;
 130                esac
 131        done
 132}
 133
 134__gitcomp ()
 135{
 136        local cur="${COMP_WORDS[COMP_CWORD]}"
 137        if [ $# -gt 2 ]; then
 138                cur="$3"
 139        fi
 140        case "$cur" in
 141        --*=)
 142                COMPREPLY=()
 143                ;;
 144        *)
 145                local IFS=$'\n'
 146                COMPREPLY=($(compgen -P "$2" \
 147                        -W "$(__gitcomp_1 "$1" "$4")" \
 148                        -- "$cur"))
 149                ;;
 150        esac
 151}
 152
 153__git_heads ()
 154{
 155        local cmd i is_hash=y dir="$(__gitdir "$1")"
 156        if [ -d "$dir" ]; then
 157                for i in $(git --git-dir="$dir" \
 158                        for-each-ref --format='%(refname)' \
 159                        refs/heads ); do
 160                        echo "${i#refs/heads/}"
 161                done
 162                return
 163        fi
 164        for i in $(git ls-remote "$1" 2>/dev/null); do
 165                case "$is_hash,$i" in
 166                y,*) is_hash=n ;;
 167                n,*^{}) is_hash=y ;;
 168                n,refs/heads/*) is_hash=y; echo "${i#refs/heads/}" ;;
 169                n,*) is_hash=y; echo "$i" ;;
 170                esac
 171        done
 172}
 173
 174__git_tags ()
 175{
 176        local cmd i is_hash=y dir="$(__gitdir "$1")"
 177        if [ -d "$dir" ]; then
 178                for i in $(git --git-dir="$dir" \
 179                        for-each-ref --format='%(refname)' \
 180                        refs/tags ); do
 181                        echo "${i#refs/tags/}"
 182                done
 183                return
 184        fi
 185        for i in $(git ls-remote "$1" 2>/dev/null); do
 186                case "$is_hash,$i" in
 187                y,*) is_hash=n ;;
 188                n,*^{}) is_hash=y ;;
 189                n,refs/tags/*) is_hash=y; echo "${i#refs/tags/}" ;;
 190                n,*) is_hash=y; echo "$i" ;;
 191                esac
 192        done
 193}
 194
 195__git_refs ()
 196{
 197        local cmd i is_hash=y dir="$(__gitdir "$1")"
 198        if [ -d "$dir" ]; then
 199                if [ -e "$dir/HEAD" ]; then echo HEAD; fi
 200                for i in $(git --git-dir="$dir" \
 201                        for-each-ref --format='%(refname)' \
 202                        refs/tags refs/heads refs/remotes); do
 203                        case "$i" in
 204                                refs/tags/*)    echo "${i#refs/tags/}" ;;
 205                                refs/heads/*)   echo "${i#refs/heads/}" ;;
 206                                refs/remotes/*) echo "${i#refs/remotes/}" ;;
 207                                *)              echo "$i" ;;
 208                        esac
 209                done
 210                return
 211        fi
 212        for i in $(git ls-remote "$dir" 2>/dev/null); do
 213                case "$is_hash,$i" in
 214                y,*) is_hash=n ;;
 215                n,*^{}) is_hash=y ;;
 216                n,refs/tags/*) is_hash=y; echo "${i#refs/tags/}" ;;
 217                n,refs/heads/*) is_hash=y; echo "${i#refs/heads/}" ;;
 218                n,refs/remotes/*) is_hash=y; echo "${i#refs/remotes/}" ;;
 219                n,*) is_hash=y; echo "$i" ;;
 220                esac
 221        done
 222}
 223
 224__git_refs2 ()
 225{
 226        local i
 227        for i in $(__git_refs "$1"); do
 228                echo "$i:$i"
 229        done
 230}
 231
 232__git_refs_remotes ()
 233{
 234        local cmd i is_hash=y
 235        for i in $(git ls-remote "$1" 2>/dev/null); do
 236                case "$is_hash,$i" in
 237                n,refs/heads/*)
 238                        is_hash=y
 239                        echo "$i:refs/remotes/$1/${i#refs/heads/}"
 240                        ;;
 241                y,*) is_hash=n ;;
 242                n,*^{}) is_hash=y ;;
 243                n,refs/tags/*) is_hash=y;;
 244                n,*) is_hash=y; ;;
 245                esac
 246        done
 247}
 248
 249__git_remotes ()
 250{
 251        local i ngoff IFS=$'\n' d="$(__gitdir)"
 252        shopt -q nullglob || ngoff=1
 253        shopt -s nullglob
 254        for i in "$d/remotes"/*; do
 255                echo ${i#$d/remotes/}
 256        done
 257        [ "$ngoff" ] && shopt -u nullglob
 258        for i in $(git --git-dir="$d" config --list); do
 259                case "$i" in
 260                remote.*.url=*)
 261                        i="${i#remote.}"
 262                        echo "${i/.url=*/}"
 263                        ;;
 264                esac
 265        done
 266}
 267
 268__git_merge_strategies ()
 269{
 270        if [ -n "$__git_merge_strategylist" ]; then
 271                echo "$__git_merge_strategylist"
 272                return
 273        fi
 274        sed -n "/^all_strategies='/{
 275                s/^all_strategies='//
 276                s/'//
 277                p
 278                q
 279                }" "$(git --exec-path)/git-merge"
 280}
 281__git_merge_strategylist=
 282__git_merge_strategylist="$(__git_merge_strategies 2>/dev/null)"
 283
 284__git_complete_file ()
 285{
 286        local pfx ls ref cur="${COMP_WORDS[COMP_CWORD]}"
 287        case "$cur" in
 288        ?*:*)
 289                ref="${cur%%:*}"
 290                cur="${cur#*:}"
 291                case "$cur" in
 292                ?*/*)
 293                        pfx="${cur%/*}"
 294                        cur="${cur##*/}"
 295                        ls="$ref:$pfx"
 296                        pfx="$pfx/"
 297                        ;;
 298                *)
 299                        ls="$ref"
 300                        ;;
 301            esac
 302
 303                case "$COMP_WORDBREAKS" in
 304                *:*) : great ;;
 305                *)   pfx="$ref:$pfx" ;;
 306                esac
 307
 308                local IFS=$'\n'
 309                COMPREPLY=($(compgen -P "$pfx" \
 310                        -W "$(git --git-dir="$(__gitdir)" ls-tree "$ls" \
 311                                | sed '/^100... blob /{
 312                                           s,^.*        ,,
 313                                           s,$, ,
 314                                       }
 315                                       /^120000 blob /{
 316                                           s,^.*        ,,
 317                                           s,$, ,
 318                                       }
 319                                       /^040000 tree /{
 320                                           s,^.*        ,,
 321                                           s,$,/,
 322                                       }
 323                                       s/^.*    //')" \
 324                        -- "$cur"))
 325                ;;
 326        *)
 327                __gitcomp "$(__git_refs)"
 328                ;;
 329        esac
 330}
 331
 332__git_complete_revlist ()
 333{
 334        local pfx cur="${COMP_WORDS[COMP_CWORD]}"
 335        case "$cur" in
 336        *...*)
 337                pfx="${cur%...*}..."
 338                cur="${cur#*...}"
 339                __gitcomp "$(__git_refs)" "$pfx" "$cur"
 340                ;;
 341        *..*)
 342                pfx="${cur%..*}.."
 343                cur="${cur#*..}"
 344                __gitcomp "$(__git_refs)" "$pfx" "$cur"
 345                ;;
 346        *)
 347                __gitcomp "$(__git_refs)"
 348                ;;
 349        esac
 350}
 351
 352__git_all_commands ()
 353{
 354        if [ -n "$__git_all_commandlist" ]; then
 355                echo "$__git_all_commandlist"
 356                return
 357        fi
 358        local i IFS=" "$'\n'
 359        for i in $(git help -a|egrep '^ ')
 360        do
 361                case $i in
 362                *--*)             : helper pattern;;
 363                *) echo $i;;
 364                esac
 365        done
 366}
 367__git_all_commandlist=
 368__git_all_commandlist="$(__git_all_commands 2>/dev/null)"
 369
 370__git_porcelain_commands ()
 371{
 372        if [ -n "$__git_porcelain_commandlist" ]; then
 373                echo "$__git_porcelain_commandlist"
 374                return
 375        fi
 376        local i IFS=" "$'\n'
 377        for i in "help" $(__git_all_commands)
 378        do
 379                case $i in
 380                *--*)             : helper pattern;;
 381                applymbox)        : ask gittus;;
 382                applypatch)       : ask gittus;;
 383                archimport)       : import;;
 384                cat-file)         : plumbing;;
 385                check-attr)       : plumbing;;
 386                check-ref-format) : plumbing;;
 387                commit-tree)      : plumbing;;
 388                cvsexportcommit)  : export;;
 389                cvsimport)        : import;;
 390                cvsserver)        : daemon;;
 391                daemon)           : daemon;;
 392                diff-files)       : plumbing;;
 393                diff-index)       : plumbing;;
 394                diff-tree)        : plumbing;;
 395                fast-import)      : import;;
 396                fsck-objects)     : plumbing;;
 397                fetch-pack)       : plumbing;;
 398                fmt-merge-msg)    : plumbing;;
 399                for-each-ref)     : plumbing;;
 400                hash-object)      : plumbing;;
 401                http-*)           : transport;;
 402                index-pack)       : plumbing;;
 403                init-db)          : deprecated;;
 404                local-fetch)      : plumbing;;
 405                mailinfo)         : plumbing;;
 406                mailsplit)        : plumbing;;
 407                merge-*)          : plumbing;;
 408                mktree)           : plumbing;;
 409                mktag)            : plumbing;;
 410                pack-objects)     : plumbing;;
 411                pack-redundant)   : plumbing;;
 412                pack-refs)        : plumbing;;
 413                parse-remote)     : plumbing;;
 414                patch-id)         : plumbing;;
 415                peek-remote)      : plumbing;;
 416                prune)            : plumbing;;
 417                prune-packed)     : plumbing;;
 418                quiltimport)      : import;;
 419                read-tree)        : plumbing;;
 420                receive-pack)     : plumbing;;
 421                reflog)           : plumbing;;
 422                repo-config)      : deprecated;;
 423                rerere)           : plumbing;;
 424                rev-list)         : plumbing;;
 425                rev-parse)        : plumbing;;
 426                runstatus)        : plumbing;;
 427                sh-setup)         : internal;;
 428                shell)            : daemon;;
 429                send-pack)        : plumbing;;
 430                show-index)       : plumbing;;
 431                ssh-*)            : transport;;
 432                stripspace)       : plumbing;;
 433                symbolic-ref)     : plumbing;;
 434                tar-tree)         : deprecated;;
 435                unpack-file)      : plumbing;;
 436                unpack-objects)   : plumbing;;
 437                update-index)     : plumbing;;
 438                update-ref)       : plumbing;;
 439                update-server-info) : daemon;;
 440                upload-archive)   : plumbing;;
 441                upload-pack)      : plumbing;;
 442                write-tree)       : plumbing;;
 443                verify-tag)       : plumbing;;
 444                *) echo $i;;
 445                esac
 446        done
 447}
 448__git_porcelain_commandlist=
 449__git_porcelain_commandlist="$(__git_porcelain_commands 2>/dev/null)"
 450
 451__git_aliases ()
 452{
 453        local i IFS=$'\n'
 454        for i in $(git --git-dir="$(__gitdir)" config --list); do
 455                case "$i" in
 456                alias.*)
 457                        i="${i#alias.}"
 458                        echo "${i/=*/}"
 459                        ;;
 460                esac
 461        done
 462}
 463
 464__git_aliased_command ()
 465{
 466        local word cmdline=$(git --git-dir="$(__gitdir)" \
 467                config --get "alias.$1")
 468        for word in $cmdline; do
 469                if [ "${word##-*}" ]; then
 470                        echo $word
 471                        return
 472                fi
 473        done
 474}
 475
 476__git_find_subcommand ()
 477{
 478        local word subcommand c=1
 479
 480        while [ $c -lt $COMP_CWORD ]; do
 481                word="${COMP_WORDS[c]}"
 482                for subcommand in $1; do
 483                        if [ "$subcommand" = "$word" ]; then
 484                                echo "$subcommand"
 485                                return
 486                        fi
 487                done
 488                c=$((++c))
 489        done
 490}
 491
 492__git_has_doubledash ()
 493{
 494        local c=1
 495        while [ $c -lt $COMP_CWORD ]; do
 496                if [ "--" = "${COMP_WORDS[c]}" ]; then
 497                        return 0
 498                fi
 499                c=$((++c))
 500        done
 501        return 1
 502}
 503
 504__git_whitespacelist="nowarn warn error error-all strip"
 505
 506_git_am ()
 507{
 508        local cur="${COMP_WORDS[COMP_CWORD]}" dir="$(__gitdir)"
 509        if [ -d "$dir"/rebase-apply ]; then
 510                __gitcomp "--skip --resolved --abort"
 511                return
 512        fi
 513        case "$cur" in
 514        --whitespace=*)
 515                __gitcomp "$__git_whitespacelist" "" "${cur##--whitespace=}"
 516                return
 517                ;;
 518        --*)
 519                __gitcomp "
 520                        --signoff --utf8 --binary --3way --interactive
 521                        --whitespace=
 522                        "
 523                return
 524        esac
 525        COMPREPLY=()
 526}
 527
 528_git_apply ()
 529{
 530        local cur="${COMP_WORDS[COMP_CWORD]}"
 531        case "$cur" in
 532        --whitespace=*)
 533                __gitcomp "$__git_whitespacelist" "" "${cur##--whitespace=}"
 534                return
 535                ;;
 536        --*)
 537                __gitcomp "
 538                        --stat --numstat --summary --check --index
 539                        --cached --index-info --reverse --reject --unidiff-zero
 540                        --apply --no-add --exclude=
 541                        --whitespace= --inaccurate-eof --verbose
 542                        "
 543                return
 544        esac
 545        COMPREPLY=()
 546}
 547
 548_git_add ()
 549{
 550        __git_has_doubledash && return
 551
 552        local cur="${COMP_WORDS[COMP_CWORD]}"
 553        case "$cur" in
 554        --*)
 555                __gitcomp "
 556                        --interactive --refresh --patch --update --dry-run
 557                        --ignore-errors
 558                        "
 559                return
 560        esac
 561        COMPREPLY=()
 562}
 563
 564_git_bisect ()
 565{
 566        __git_has_doubledash && return
 567
 568        local subcommands="start bad good skip reset visualize replay log run"
 569        local subcommand="$(__git_find_subcommand "$subcommands")"
 570        if [ -z "$subcommand" ]; then
 571                __gitcomp "$subcommands"
 572                return
 573        fi
 574
 575        case "$subcommand" in
 576        bad|good|reset|skip)
 577                __gitcomp "$(__git_refs)"
 578                ;;
 579        *)
 580                COMPREPLY=()
 581                ;;
 582        esac
 583}
 584
 585_git_branch ()
 586{
 587        local i c=1 only_local_ref="n" has_r="n"
 588
 589        while [ $c -lt $COMP_CWORD ]; do
 590                i="${COMP_WORDS[c]}"
 591                case "$i" in
 592                -d|-m)  only_local_ref="y" ;;
 593                -r)     has_r="y" ;;
 594                esac
 595                c=$((++c))
 596        done
 597
 598        case "${COMP_WORDS[COMP_CWORD]}" in
 599        --*=*)  COMPREPLY=() ;;
 600        --*)
 601                __gitcomp "
 602                        --color --no-color --verbose --abbrev= --no-abbrev
 603                        --track --no-track --contains --merged --no-merged
 604                        "
 605                ;;
 606        *)
 607                if [ $only_local_ref = "y" -a $has_r = "n" ]; then
 608                        __gitcomp "$(__git_heads)"
 609                else
 610                        __gitcomp "$(__git_refs)"
 611                fi
 612                ;;
 613        esac
 614}
 615
 616_git_bundle ()
 617{
 618        local mycword="$COMP_CWORD"
 619        case "${COMP_WORDS[0]}" in
 620        git)
 621                local cmd="${COMP_WORDS[2]}"
 622                mycword="$((mycword-1))"
 623                ;;
 624        git-bundle*)
 625                local cmd="${COMP_WORDS[1]}"
 626                ;;
 627        esac
 628        case "$mycword" in
 629        1)
 630                __gitcomp "create list-heads verify unbundle"
 631                ;;
 632        2)
 633                # looking for a file
 634                ;;
 635        *)
 636                case "$cmd" in
 637                        create)
 638                                __git_complete_revlist
 639                        ;;
 640                esac
 641                ;;
 642        esac
 643}
 644
 645_git_checkout ()
 646{
 647        __git_has_doubledash && return
 648
 649        __gitcomp "$(__git_refs)"
 650}
 651
 652_git_cherry ()
 653{
 654        __gitcomp "$(__git_refs)"
 655}
 656
 657_git_cherry_pick ()
 658{
 659        local cur="${COMP_WORDS[COMP_CWORD]}"
 660        case "$cur" in
 661        --*)
 662                __gitcomp "--edit --no-commit"
 663                ;;
 664        *)
 665                __gitcomp "$(__git_refs)"
 666                ;;
 667        esac
 668}
 669
 670_git_commit ()
 671{
 672        __git_has_doubledash && return
 673
 674        local cur="${COMP_WORDS[COMP_CWORD]}"
 675        case "$cur" in
 676        --*)
 677                __gitcomp "
 678                        --all --author= --signoff --verify --no-verify
 679                        --edit --amend --include --only
 680                        "
 681                return
 682        esac
 683        COMPREPLY=()
 684}
 685
 686_git_describe ()
 687{
 688        local cur="${COMP_WORDS[COMP_CWORD]}"
 689        case "$cur" in
 690        --*)
 691                __gitcomp "
 692                        --all --tags --contains --abbrev= --candidates=
 693                        --exact-match --debug --long --match --always
 694                        "
 695                return
 696        esac
 697        __gitcomp "$(__git_refs)"
 698}
 699
 700_git_diff ()
 701{
 702        __git_has_doubledash && return
 703
 704        local cur="${COMP_WORDS[COMP_CWORD]}"
 705        case "$cur" in
 706        --*)
 707                __gitcomp "--cached --stat --numstat --shortstat --summary
 708                        --patch-with-stat --name-only --name-status --color
 709                        --no-color --color-words --no-renames --check
 710                        --full-index --binary --abbrev --diff-filter
 711                        --find-copies-harder --pickaxe-all --pickaxe-regex
 712                        --text --ignore-space-at-eol --ignore-space-change
 713                        --ignore-all-space --exit-code --quiet --ext-diff
 714                        --no-ext-diff
 715                        --no-prefix --src-prefix= --dst-prefix=
 716                        --base --ours --theirs
 717                        "
 718                return
 719                ;;
 720        esac
 721        __git_complete_file
 722}
 723
 724_git_diff_tree ()
 725{
 726        __gitcomp "$(__git_refs)"
 727}
 728
 729_git_fetch ()
 730{
 731        local cur="${COMP_WORDS[COMP_CWORD]}"
 732
 733        case "${COMP_WORDS[0]},$COMP_CWORD" in
 734        git-fetch*,1)
 735                __gitcomp "$(__git_remotes)"
 736                ;;
 737        git,2)
 738                __gitcomp "$(__git_remotes)"
 739                ;;
 740        *)
 741                case "$cur" in
 742                *:*)
 743                        local pfx=""
 744                        case "$COMP_WORDBREAKS" in
 745                        *:*) : great ;;
 746                        *)   pfx="${cur%%:*}:" ;;
 747                        esac
 748                        __gitcomp "$(__git_refs)" "$pfx" "${cur#*:}"
 749                        ;;
 750                *)
 751                        local remote
 752                        case "${COMP_WORDS[0]}" in
 753                        git-fetch) remote="${COMP_WORDS[1]}" ;;
 754                        git)       remote="${COMP_WORDS[2]}" ;;
 755                        esac
 756                        __gitcomp "$(__git_refs2 "$remote")"
 757                        ;;
 758                esac
 759                ;;
 760        esac
 761}
 762
 763_git_format_patch ()
 764{
 765        local cur="${COMP_WORDS[COMP_CWORD]}"
 766        case "$cur" in
 767        --*)
 768                __gitcomp "
 769                        --stdout --attach --thread
 770                        --output-directory
 771                        --numbered --start-number
 772                        --numbered-files
 773                        --keep-subject
 774                        --signoff
 775                        --in-reply-to=
 776                        --full-index --binary
 777                        --not --all
 778                        --cover-letter
 779                        --no-prefix --src-prefix= --dst-prefix=
 780                        "
 781                return
 782                ;;
 783        esac
 784        __git_complete_revlist
 785}
 786
 787_git_gc ()
 788{
 789        local cur="${COMP_WORDS[COMP_CWORD]}"
 790        case "$cur" in
 791        --*)
 792                __gitcomp "--prune --aggressive"
 793                return
 794                ;;
 795        esac
 796        COMPREPLY=()
 797}
 798
 799_git_help ()
 800{
 801        local cur="${COMP_WORDS[COMP_CWORD]}"
 802        case "$cur" in
 803        --*)
 804                __gitcomp "--all --info --man --web"
 805                return
 806                ;;
 807        esac
 808        __gitcomp "$(__git_all_commands)"
 809}
 810
 811_git_ls_remote ()
 812{
 813        __gitcomp "$(__git_remotes)"
 814}
 815
 816_git_ls_tree ()
 817{
 818        __git_complete_file
 819}
 820
 821_git_log ()
 822{
 823        __git_has_doubledash && return
 824
 825        local cur="${COMP_WORDS[COMP_CWORD]}"
 826        case "$cur" in
 827        --pretty=*)
 828                __gitcomp "
 829                        oneline short medium full fuller email raw
 830                        " "" "${cur##--pretty=}"
 831                return
 832                ;;
 833        --date=*)
 834                __gitcomp "
 835                        relative iso8601 rfc2822 short local default
 836                " "" "${cur##--date=}"
 837                return
 838                ;;
 839        --*)
 840                __gitcomp "
 841                        --max-count= --max-age= --since= --after=
 842                        --min-age= --before= --until=
 843                        --root --topo-order --date-order --reverse
 844                        --no-merges --follow
 845                        --abbrev-commit --abbrev=
 846                        --relative-date --date=
 847                        --author= --committer= --grep=
 848                        --all-match
 849                        --pretty= --name-status --name-only --raw
 850                        --not --all
 851                        --left-right --cherry-pick
 852                        --graph
 853                        --stat --numstat --shortstat
 854                        --decorate --diff-filter=
 855                        --color-words --walk-reflogs
 856                        "
 857                return
 858                ;;
 859        esac
 860        __git_complete_revlist
 861}
 862
 863_git_merge ()
 864{
 865        local cur="${COMP_WORDS[COMP_CWORD]}"
 866        case "${COMP_WORDS[COMP_CWORD-1]}" in
 867        -s|--strategy)
 868                __gitcomp "$(__git_merge_strategies)"
 869                return
 870        esac
 871        case "$cur" in
 872        --strategy=*)
 873                __gitcomp "$(__git_merge_strategies)" "" "${cur##--strategy=}"
 874                return
 875                ;;
 876        --*)
 877                __gitcomp "
 878                        --no-commit --no-stat --log --no-log --squash --strategy
 879                        "
 880                return
 881        esac
 882        __gitcomp "$(__git_refs)"
 883}
 884
 885_git_merge_base ()
 886{
 887        __gitcomp "$(__git_refs)"
 888}
 889
 890_git_name_rev ()
 891{
 892        __gitcomp "--tags --all --stdin"
 893}
 894
 895_git_pull ()
 896{
 897        local cur="${COMP_WORDS[COMP_CWORD]}"
 898
 899        case "${COMP_WORDS[0]},$COMP_CWORD" in
 900        git-pull*,1)
 901                __gitcomp "$(__git_remotes)"
 902                ;;
 903        git,2)
 904                __gitcomp "$(__git_remotes)"
 905                ;;
 906        *)
 907                local remote
 908                case "${COMP_WORDS[0]}" in
 909                git-pull)  remote="${COMP_WORDS[1]}" ;;
 910                git)       remote="${COMP_WORDS[2]}" ;;
 911                esac
 912                __gitcomp "$(__git_refs "$remote")"
 913                ;;
 914        esac
 915}
 916
 917_git_push ()
 918{
 919        local cur="${COMP_WORDS[COMP_CWORD]}"
 920
 921        case "${COMP_WORDS[0]},$COMP_CWORD" in
 922        git-push*,1)
 923                __gitcomp "$(__git_remotes)"
 924                ;;
 925        git,2)
 926                __gitcomp "$(__git_remotes)"
 927                ;;
 928        *)
 929                case "$cur" in
 930                *:*)
 931                        local remote
 932                        case "${COMP_WORDS[0]}" in
 933                        git-push)  remote="${COMP_WORDS[1]}" ;;
 934                        git)       remote="${COMP_WORDS[2]}" ;;
 935                        esac
 936
 937                        local pfx=""
 938                        case "$COMP_WORDBREAKS" in
 939                        *:*) : great ;;
 940                        *)   pfx="${cur%%:*}:" ;;
 941                        esac
 942
 943                        __gitcomp "$(__git_refs "$remote")" "$pfx" "${cur#*:}"
 944                        ;;
 945                +*)
 946                        __gitcomp "$(__git_refs)" + "${cur#+}"
 947                        ;;
 948                *)
 949                        __gitcomp "$(__git_refs)"
 950                        ;;
 951                esac
 952                ;;
 953        esac
 954}
 955
 956_git_rebase ()
 957{
 958        local cur="${COMP_WORDS[COMP_CWORD]}" dir="$(__gitdir)"
 959        if [ -d "$dir"/rebase-apply ] || [ -d "$dir"/rebase-merge ]; then
 960                __gitcomp "--continue --skip --abort"
 961                return
 962        fi
 963        case "${COMP_WORDS[COMP_CWORD-1]}" in
 964        -s|--strategy)
 965                __gitcomp "$(__git_merge_strategies)"
 966                return
 967        esac
 968        case "$cur" in
 969        --strategy=*)
 970                __gitcomp "$(__git_merge_strategies)" "" "${cur##--strategy=}"
 971                return
 972                ;;
 973        --*)
 974                __gitcomp "--onto --merge --strategy --interactive"
 975                return
 976        esac
 977        __gitcomp "$(__git_refs)"
 978}
 979
 980_git_send_email ()
 981{
 982        local cur="${COMP_WORDS[COMP_CWORD]}"
 983        case "$cur" in
 984        --*)
 985                __gitcomp "--bcc --cc --cc-cmd --chain-reply-to --compose
 986                        --dry-run --envelope-sender --from --identity
 987                        --in-reply-to --no-chain-reply-to --no-signed-off-by-cc
 988                        --no-suppress-from --no-thread --quiet
 989                        --signed-off-by-cc --smtp-pass --smtp-server
 990                        --smtp-server-port --smtp-ssl --smtp-user --subject
 991                        --suppress-cc --suppress-from --thread --to"
 992                return
 993                ;;
 994        esac
 995        COMPREPLY=()
 996}
 997
 998_git_config ()
 999{
1000        local cur="${COMP_WORDS[COMP_CWORD]}"
1001        local prv="${COMP_WORDS[COMP_CWORD-1]}"
1002        case "$prv" in
1003        branch.*.remote)
1004                __gitcomp "$(__git_remotes)"
1005                return
1006                ;;
1007        branch.*.merge)
1008                __gitcomp "$(__git_refs)"
1009                return
1010                ;;
1011        remote.*.fetch)
1012                local remote="${prv#remote.}"
1013                remote="${remote%.fetch}"
1014                __gitcomp "$(__git_refs_remotes "$remote")"
1015                return
1016                ;;
1017        remote.*.push)
1018                local remote="${prv#remote.}"
1019                remote="${remote%.push}"
1020                __gitcomp "$(git --git-dir="$(__gitdir)" \
1021                        for-each-ref --format='%(refname):%(refname)' \
1022                        refs/heads)"
1023                return
1024                ;;
1025        pull.twohead|pull.octopus)
1026                __gitcomp "$(__git_merge_strategies)"
1027                return
1028                ;;
1029        color.branch|color.diff|color.status)
1030                __gitcomp "always never auto"
1031                return
1032                ;;
1033        color.*.*)
1034                __gitcomp "
1035                        black red green yellow blue magenta cyan white
1036                        bold dim ul blink reverse
1037                        "
1038                return
1039                ;;
1040        *.*)
1041                COMPREPLY=()
1042                return
1043                ;;
1044        esac
1045        case "$cur" in
1046        --*)
1047                __gitcomp "
1048                        --global --system --file=
1049                        --list --replace-all
1050                        --get --get-all --get-regexp
1051                        --add --unset --unset-all
1052                        --remove-section --rename-section
1053                        "
1054                return
1055                ;;
1056        branch.*.*)
1057                local pfx="${cur%.*}."
1058                cur="${cur##*.}"
1059                __gitcomp "remote merge" "$pfx" "$cur"
1060                return
1061                ;;
1062        branch.*)
1063                local pfx="${cur%.*}."
1064                cur="${cur#*.}"
1065                __gitcomp "$(__git_heads)" "$pfx" "$cur" "."
1066                return
1067                ;;
1068        remote.*.*)
1069                local pfx="${cur%.*}."
1070                cur="${cur##*.}"
1071                __gitcomp "
1072                        url fetch push skipDefaultUpdate
1073                        receivepack uploadpack tagopt
1074                        " "$pfx" "$cur"
1075                return
1076                ;;
1077        remote.*)
1078                local pfx="${cur%.*}."
1079                cur="${cur#*.}"
1080                __gitcomp "$(__git_remotes)" "$pfx" "$cur" "."
1081                return
1082                ;;
1083        esac
1084        __gitcomp "
1085                apply.whitespace
1086                core.fileMode
1087                core.gitProxy
1088                core.ignoreStat
1089                core.preferSymlinkRefs
1090                core.logAllRefUpdates
1091                core.loosecompression
1092                core.repositoryFormatVersion
1093                core.sharedRepository
1094                core.warnAmbiguousRefs
1095                core.compression
1096                core.packedGitWindowSize
1097                core.packedGitLimit
1098                clean.requireForce
1099                color.branch
1100                color.branch.current
1101                color.branch.local
1102                color.branch.remote
1103                color.branch.plain
1104                color.diff
1105                color.diff.plain
1106                color.diff.meta
1107                color.diff.frag
1108                color.diff.old
1109                color.diff.new
1110                color.diff.commit
1111                color.diff.whitespace
1112                color.pager
1113                color.status
1114                color.status.header
1115                color.status.added
1116                color.status.changed
1117                color.status.untracked
1118                diff.renameLimit
1119                diff.renames
1120                fetch.unpackLimit
1121                format.headers
1122                format.subjectprefix
1123                gitcvs.enabled
1124                gitcvs.logfile
1125                gitcvs.allbinary
1126                gitcvs.dbname gitcvs.dbdriver gitcvs.dbuser gitcvs.dbpass
1127                gitcvs.dbtablenameprefix
1128                gc.packrefs
1129                gc.reflogexpire
1130                gc.reflogexpireunreachable
1131                gc.rerereresolved
1132                gc.rerereunresolved
1133                http.sslVerify
1134                http.sslCert
1135                http.sslKey
1136                http.sslCAInfo
1137                http.sslCAPath
1138                http.maxRequests
1139                http.lowSpeedLimit
1140                http.lowSpeedTime
1141                http.noEPSV
1142                i18n.commitEncoding
1143                i18n.logOutputEncoding
1144                log.showroot
1145                merge.tool
1146                merge.summary
1147                merge.verbosity
1148                pack.window
1149                pack.depth
1150                pack.windowMemory
1151                pack.compression
1152                pack.deltaCacheSize
1153                pack.deltaCacheLimit
1154                pull.octopus
1155                pull.twohead
1156                repack.useDeltaBaseOffset
1157                showbranch.default
1158                tar.umask
1159                transfer.unpackLimit
1160                receive.unpackLimit
1161                receive.denyNonFastForwards
1162                user.name
1163                user.email
1164                user.signingkey
1165                branch. remote.
1166        "
1167}
1168
1169_git_remote ()
1170{
1171        local subcommands="add rm show prune update"
1172        local subcommand="$(__git_find_subcommand "$subcommands")"
1173        if [ -z "$subcommand" ]; then
1174                __gitcomp "$subcommands"
1175                return
1176        fi
1177
1178        case "$subcommand" in
1179        rm|show|prune)
1180                __gitcomp "$(__git_remotes)"
1181                ;;
1182        update)
1183                local i c='' IFS=$'\n'
1184                for i in $(git --git-dir="$(__gitdir)" config --list); do
1185                        case "$i" in
1186                        remotes.*)
1187                                i="${i#remotes.}"
1188                                c="$c ${i/=*/}"
1189                                ;;
1190                        esac
1191                done
1192                __gitcomp "$c"
1193                ;;
1194        *)
1195                COMPREPLY=()
1196                ;;
1197        esac
1198}
1199
1200_git_reset ()
1201{
1202        __git_has_doubledash && return
1203
1204        local cur="${COMP_WORDS[COMP_CWORD]}"
1205        case "$cur" in
1206        --*)
1207                __gitcomp "--mixed --hard --soft"
1208                return
1209                ;;
1210        esac
1211        __gitcomp "$(__git_refs)"
1212}
1213
1214_git_rm ()
1215{
1216        __git_has_doubledash && return
1217
1218        local cur="${COMP_WORDS[COMP_CWORD]}"
1219        case "$cur" in
1220        --*)
1221                __gitcomp "--cached --dry-run --ignore-unmatch --quiet"
1222                return
1223                ;;
1224        esac
1225        COMPREPLY=()
1226}
1227
1228_git_shortlog ()
1229{
1230        __git_has_doubledash && return
1231
1232        local cur="${COMP_WORDS[COMP_CWORD]}"
1233        case "$cur" in
1234        --*)
1235                __gitcomp "
1236                        --max-count= --max-age= --since= --after=
1237                        --min-age= --before= --until=
1238                        --no-merges
1239                        --author= --committer= --grep=
1240                        --all-match
1241                        --not --all
1242                        --numbered --summary
1243                        "
1244                return
1245                ;;
1246        esac
1247        __git_complete_revlist
1248}
1249
1250_git_show ()
1251{
1252        local cur="${COMP_WORDS[COMP_CWORD]}"
1253        case "$cur" in
1254        --pretty=*)
1255                __gitcomp "
1256                        oneline short medium full fuller email raw
1257                        " "" "${cur##--pretty=}"
1258                return
1259                ;;
1260        --*)
1261                __gitcomp "--pretty="
1262                return
1263                ;;
1264        esac
1265        __git_complete_file
1266}
1267
1268_git_show_branch ()
1269{
1270        local cur="${COMP_WORDS[COMP_CWORD]}"
1271        case "$cur" in
1272        --*)
1273                __gitcomp "
1274                        --all --remotes --topo-order --current --more=
1275                        --list --independent --merge-base --no-name
1276                        --sha1-name --topics --reflog
1277                        "
1278                return
1279                ;;
1280        esac
1281        __git_complete_revlist
1282}
1283
1284_git_stash ()
1285{
1286        local subcommands='save list show apply clear drop pop create'
1287        local subcommand="$(__git_find_subcommand "$subcommands")"
1288        if [ -z "$subcommand" ]; then
1289                __gitcomp "$subcommands"
1290        else
1291                local cur="${COMP_WORDS[COMP_CWORD]}"
1292                case "$subcommand,$cur" in
1293                save,--*)
1294                        __gitcomp "--keep-index"
1295                        ;;
1296                *)
1297                        COMPREPLY=()
1298                        ;;
1299                esac
1300        fi
1301}
1302
1303_git_submodule ()
1304{
1305        __git_has_doubledash && return
1306
1307        local subcommands="add status init update"
1308        if [ -z "$(__git_find_subcommand "$subcommands")" ]; then
1309                local cur="${COMP_WORDS[COMP_CWORD]}"
1310                case "$cur" in
1311                --*)
1312                        __gitcomp "--quiet --cached"
1313                        ;;
1314                *)
1315                        __gitcomp "$subcommands"
1316                        ;;
1317                esac
1318                return
1319        fi
1320}
1321
1322_git_svn ()
1323{
1324        local subcommands="
1325                init fetch clone rebase dcommit log find-rev
1326                set-tree commit-diff info create-ignore propget
1327                proplist show-ignore show-externals
1328                "
1329        local subcommand="$(__git_find_subcommand "$subcommands")"
1330        if [ -z "$subcommand" ]; then
1331                __gitcomp "$subcommands"
1332        else
1333                local remote_opts="--username= --config-dir= --no-auth-cache"
1334                local fc_opts="
1335                        --follow-parent --authors-file= --repack=
1336                        --no-metadata --use-svm-props --use-svnsync-props
1337                        --log-window-size= --no-checkout --quiet
1338                        --repack-flags --user-log-author $remote_opts
1339                        "
1340                local init_opts="
1341                        --template= --shared= --trunk= --tags=
1342                        --branches= --stdlayout --minimize-url
1343                        --no-metadata --use-svm-props --use-svnsync-props
1344                        --rewrite-root= $remote_opts
1345                        "
1346                local cmt_opts="
1347                        --edit --rmdir --find-copies-harder --copy-similarity=
1348                        "
1349
1350                local cur="${COMP_WORDS[COMP_CWORD]}"
1351                case "$subcommand,$cur" in
1352                fetch,--*)
1353                        __gitcomp "--revision= --fetch-all $fc_opts"
1354                        ;;
1355                clone,--*)
1356                        __gitcomp "--revision= $fc_opts $init_opts"
1357                        ;;
1358                init,--*)
1359                        __gitcomp "$init_opts"
1360                        ;;
1361                dcommit,--*)
1362                        __gitcomp "
1363                                --merge --strategy= --verbose --dry-run
1364                                --fetch-all --no-rebase $cmt_opts $fc_opts
1365                                "
1366                        ;;
1367                set-tree,--*)
1368                        __gitcomp "--stdin $cmt_opts $fc_opts"
1369                        ;;
1370                create-ignore,--*|propget,--*|proplist,--*|show-ignore,--*|\
1371                show-externals,--*)
1372                        __gitcomp "--revision="
1373                        ;;
1374                log,--*)
1375                        __gitcomp "
1376                                --limit= --revision= --verbose --incremental
1377                                --oneline --show-commit --non-recursive
1378                                --authors-file=
1379                                "
1380                        ;;
1381                rebase,--*)
1382                        __gitcomp "
1383                                --merge --verbose --strategy= --local
1384                                --fetch-all $fc_opts
1385                                "
1386                        ;;
1387                commit-diff,--*)
1388                        __gitcomp "--message= --file= --revision= $cmt_opts"
1389                        ;;
1390                info,--*)
1391                        __gitcomp "--url"
1392                        ;;
1393                *)
1394                        COMPREPLY=()
1395                        ;;
1396                esac
1397        fi
1398}
1399
1400_git_tag ()
1401{
1402        local i c=1 f=0
1403        while [ $c -lt $COMP_CWORD ]; do
1404                i="${COMP_WORDS[c]}"
1405                case "$i" in
1406                -d|-v)
1407                        __gitcomp "$(__git_tags)"
1408                        return
1409                        ;;
1410                -f)
1411                        f=1
1412                        ;;
1413                esac
1414                c=$((++c))
1415        done
1416
1417        case "${COMP_WORDS[COMP_CWORD-1]}" in
1418        -m|-F)
1419                COMPREPLY=()
1420                ;;
1421        -*|tag|git-tag)
1422                if [ $f = 1 ]; then
1423                        __gitcomp "$(__git_tags)"
1424                else
1425                        COMPREPLY=()
1426                fi
1427                ;;
1428        *)
1429                __gitcomp "$(__git_refs)"
1430                ;;
1431        esac
1432}
1433
1434_git ()
1435{
1436        local i c=1 command __git_dir
1437
1438        while [ $c -lt $COMP_CWORD ]; do
1439                i="${COMP_WORDS[c]}"
1440                case "$i" in
1441                --git-dir=*) __git_dir="${i#--git-dir=}" ;;
1442                --bare)      __git_dir="." ;;
1443                --version|-p|--paginate) ;;
1444                --help) command="help"; break ;;
1445                *) command="$i"; break ;;
1446                esac
1447                c=$((++c))
1448        done
1449
1450        if [ -z "$command" ]; then
1451                case "${COMP_WORDS[COMP_CWORD]}" in
1452                --*=*) COMPREPLY=() ;;
1453                --*)   __gitcomp "
1454                        --paginate
1455                        --no-pager
1456                        --git-dir=
1457                        --bare
1458                        --version
1459                        --exec-path
1460                        --work-tree=
1461                        --help
1462                        "
1463                        ;;
1464                *)     __gitcomp "$(__git_porcelain_commands) $(__git_aliases)" ;;
1465                esac
1466                return
1467        fi
1468
1469        local expansion=$(__git_aliased_command "$command")
1470        [ "$expansion" ] && command="$expansion"
1471
1472        case "$command" in
1473        am)          _git_am ;;
1474        add)         _git_add ;;
1475        apply)       _git_apply ;;
1476        bisect)      _git_bisect ;;
1477        bundle)      _git_bundle ;;
1478        branch)      _git_branch ;;
1479        checkout)    _git_checkout ;;
1480        cherry)      _git_cherry ;;
1481        cherry-pick) _git_cherry_pick ;;
1482        commit)      _git_commit ;;
1483        config)      _git_config ;;
1484        describe)    _git_describe ;;
1485        diff)        _git_diff ;;
1486        fetch)       _git_fetch ;;
1487        format-patch) _git_format_patch ;;
1488        gc)          _git_gc ;;
1489        help)        _git_help ;;
1490        log)         _git_log ;;
1491        ls-remote)   _git_ls_remote ;;
1492        ls-tree)     _git_ls_tree ;;
1493        merge)       _git_merge;;
1494        merge-base)  _git_merge_base ;;
1495        name-rev)    _git_name_rev ;;
1496        pull)        _git_pull ;;
1497        push)        _git_push ;;
1498        rebase)      _git_rebase ;;
1499        remote)      _git_remote ;;
1500        reset)       _git_reset ;;
1501        rm)          _git_rm ;;
1502        send-email)  _git_send_email ;;
1503        shortlog)    _git_shortlog ;;
1504        show)        _git_show ;;
1505        show-branch) _git_show_branch ;;
1506        stash)       _git_stash ;;
1507        submodule)   _git_submodule ;;
1508        svn)         _git_svn ;;
1509        tag)         _git_tag ;;
1510        whatchanged) _git_log ;;
1511        *)           COMPREPLY=() ;;
1512        esac
1513}
1514
1515_gitk ()
1516{
1517        __git_has_doubledash && return
1518
1519        local cur="${COMP_WORDS[COMP_CWORD]}"
1520        local g="$(git rev-parse --git-dir 2>/dev/null)"
1521        local merge=""
1522        if [ -f $g/MERGE_HEAD ]; then
1523                merge="--merge"
1524        fi
1525        case "$cur" in
1526        --*)
1527                __gitcomp "--not --all $merge"
1528                return
1529                ;;
1530        esac
1531        __git_complete_revlist
1532}
1533
1534complete -o default -o nospace -F _git git
1535complete -o default -o nospace -F _gitk gitk
1536
1537# The following are necessary only for Cygwin, and only are needed
1538# when the user has tab-completed the executable name and consequently
1539# included the '.exe' suffix.
1540#
1541if [ Cygwin = "$(uname -o 2>/dev/null)" ]; then
1542complete -o default -o nospace -F _git git.exe
1543fi