Merge branch 'maint'
[git] / contrib / completion / git-completion.bash
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
48 case "$COMP_WORDBREAKS" in
49 *:*) : great ;;
50 *)   COMP_WORDBREAKS="$COMP_WORDBREAKS:"
51 esac
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_archive ()
565 {
566         local cur="${COMP_WORDS[COMP_CWORD]}"
567         case "$cur" in
568         --format=*)
569                 __gitcomp "$(git archive --list)" "" "${cur##--format=}"
570                 return
571                 ;;
572         --remote=*)
573                 __gitcomp "$(__git_remotes)" "" "${cur##--remote=}"
574                 return
575                 ;;
576         --*)
577                 __gitcomp "
578                         --format= --list --verbose
579                         --prefix= --remote= --exec=
580                         "
581                 return
582                 ;;
583         esac
584         __git_complete_file
585 }
586
587 _git_bisect ()
588 {
589         __git_has_doubledash && return
590
591         local subcommands="start bad good skip reset visualize replay log run"
592         local subcommand="$(__git_find_subcommand "$subcommands")"
593         if [ -z "$subcommand" ]; then
594                 __gitcomp "$subcommands"
595                 return
596         fi
597
598         case "$subcommand" in
599         bad|good|reset|skip)
600                 __gitcomp "$(__git_refs)"
601                 ;;
602         *)
603                 COMPREPLY=()
604                 ;;
605         esac
606 }
607
608 _git_branch ()
609 {
610         local i c=1 only_local_ref="n" has_r="n"
611
612         while [ $c -lt $COMP_CWORD ]; do
613                 i="${COMP_WORDS[c]}"
614                 case "$i" in
615                 -d|-m)  only_local_ref="y" ;;
616                 -r)     has_r="y" ;;
617                 esac
618                 c=$((++c))
619         done
620
621         case "${COMP_WORDS[COMP_CWORD]}" in
622         --*=*)  COMPREPLY=() ;;
623         --*)
624                 __gitcomp "
625                         --color --no-color --verbose --abbrev= --no-abbrev
626                         --track --no-track --contains --merged --no-merged
627                         "
628                 ;;
629         *)
630                 if [ $only_local_ref = "y" -a $has_r = "n" ]; then
631                         __gitcomp "$(__git_heads)"
632                 else
633                         __gitcomp "$(__git_refs)"
634                 fi
635                 ;;
636         esac
637 }
638
639 _git_bundle ()
640 {
641         local mycword="$COMP_CWORD"
642         case "${COMP_WORDS[0]}" in
643         git)
644                 local cmd="${COMP_WORDS[2]}"
645                 mycword="$((mycword-1))"
646                 ;;
647         git-bundle*)
648                 local cmd="${COMP_WORDS[1]}"
649                 ;;
650         esac
651         case "$mycword" in
652         1)
653                 __gitcomp "create list-heads verify unbundle"
654                 ;;
655         2)
656                 # looking for a file
657                 ;;
658         *)
659                 case "$cmd" in
660                         create)
661                                 __git_complete_revlist
662                         ;;
663                 esac
664                 ;;
665         esac
666 }
667
668 _git_checkout ()
669 {
670         __git_has_doubledash && return
671
672         __gitcomp "$(__git_refs)"
673 }
674
675 _git_cherry ()
676 {
677         __gitcomp "$(__git_refs)"
678 }
679
680 _git_cherry_pick ()
681 {
682         local cur="${COMP_WORDS[COMP_CWORD]}"
683         case "$cur" in
684         --*)
685                 __gitcomp "--edit --no-commit"
686                 ;;
687         *)
688                 __gitcomp "$(__git_refs)"
689                 ;;
690         esac
691 }
692
693 _git_clean ()
694 {
695         __git_has_doubledash && return
696
697         local cur="${COMP_WORDS[COMP_CWORD]}"
698         case "$cur" in
699         --*)
700                 __gitcomp "--dry-run --quiet"
701                 return
702                 ;;
703         esac
704         COMPREPLY=()
705 }
706
707 _git_clone ()
708 {
709         local cur="${COMP_WORDS[COMP_CWORD]}"
710         case "$cur" in
711         --*)
712                 __gitcomp "
713                         --local
714                         --no-hardlinks
715                         --shared
716                         --reference
717                         --quiet
718                         --no-checkout
719                         --bare
720                         --mirror
721                         --origin
722                         --upload-pack
723                         --template=
724                         --depth
725                         "
726                 return
727                 ;;
728         esac
729         COMPREPLY=()
730 }
731
732 _git_commit ()
733 {
734         __git_has_doubledash && return
735
736         local cur="${COMP_WORDS[COMP_CWORD]}"
737         case "$cur" in
738         --*)
739                 __gitcomp "
740                         --all --author= --signoff --verify --no-verify
741                         --edit --amend --include --only
742                         "
743                 return
744         esac
745         COMPREPLY=()
746 }
747
748 _git_describe ()
749 {
750         local cur="${COMP_WORDS[COMP_CWORD]}"
751         case "$cur" in
752         --*)
753                 __gitcomp "
754                         --all --tags --contains --abbrev= --candidates=
755                         --exact-match --debug --long --match --always
756                         "
757                 return
758         esac
759         __gitcomp "$(__git_refs)"
760 }
761
762 _git_diff ()
763 {
764         __git_has_doubledash && return
765
766         local cur="${COMP_WORDS[COMP_CWORD]}"
767         case "$cur" in
768         --*)
769                 __gitcomp "--cached --stat --numstat --shortstat --summary
770                         --patch-with-stat --name-only --name-status --color
771                         --no-color --color-words --no-renames --check
772                         --full-index --binary --abbrev --diff-filter
773                         --find-copies-harder --pickaxe-all --pickaxe-regex
774                         --text --ignore-space-at-eol --ignore-space-change
775                         --ignore-all-space --exit-code --quiet --ext-diff
776                         --no-ext-diff
777                         --no-prefix --src-prefix= --dst-prefix=
778                         --base --ours --theirs
779                         "
780                 return
781                 ;;
782         esac
783         __git_complete_file
784 }
785
786 _git_fetch ()
787 {
788         local cur="${COMP_WORDS[COMP_CWORD]}"
789
790         case "${COMP_WORDS[0]},$COMP_CWORD" in
791         git-fetch*,1)
792                 __gitcomp "$(__git_remotes)"
793                 ;;
794         git,2)
795                 __gitcomp "$(__git_remotes)"
796                 ;;
797         *)
798                 case "$cur" in
799                 *:*)
800                         local pfx=""
801                         case "$COMP_WORDBREAKS" in
802                         *:*) : great ;;
803                         *)   pfx="${cur%%:*}:" ;;
804                         esac
805                         __gitcomp "$(__git_refs)" "$pfx" "${cur#*:}"
806                         ;;
807                 *)
808                         local remote
809                         case "${COMP_WORDS[0]}" in
810                         git-fetch) remote="${COMP_WORDS[1]}" ;;
811                         git)       remote="${COMP_WORDS[2]}" ;;
812                         esac
813                         __gitcomp "$(__git_refs2 "$remote")"
814                         ;;
815                 esac
816                 ;;
817         esac
818 }
819
820 _git_format_patch ()
821 {
822         local cur="${COMP_WORDS[COMP_CWORD]}"
823         case "$cur" in
824         --*)
825                 __gitcomp "
826                         --stdout --attach --thread
827                         --output-directory
828                         --numbered --start-number
829                         --numbered-files
830                         --keep-subject
831                         --signoff
832                         --in-reply-to=
833                         --full-index --binary
834                         --not --all
835                         --cover-letter
836                         --no-prefix --src-prefix= --dst-prefix=
837                         "
838                 return
839                 ;;
840         esac
841         __git_complete_revlist
842 }
843
844 _git_gc ()
845 {
846         local cur="${COMP_WORDS[COMP_CWORD]}"
847         case "$cur" in
848         --*)
849                 __gitcomp "--prune --aggressive"
850                 return
851                 ;;
852         esac
853         COMPREPLY=()
854 }
855
856 _git_grep ()
857 {
858         __git_has_doubledash && return
859
860         local cur="${COMP_WORDS[COMP_CWORD]}"
861         case "$cur" in
862         --*)
863                 __gitcomp "
864                         --cached
865                         --text --ignore-case --word-regexp --invert-match
866                         --full-name
867                         --extended-regexp --basic-regexp --fixed-strings
868                         --files-with-matches --name-only
869                         --files-without-match
870                         --count
871                         --and --or --not --all-match
872                         "
873                 return
874                 ;;
875         esac
876         COMPREPLY=()
877 }
878
879 _git_help ()
880 {
881         local cur="${COMP_WORDS[COMP_CWORD]}"
882         case "$cur" in
883         --*)
884                 __gitcomp "--all --info --man --web"
885                 return
886                 ;;
887         esac
888         __gitcomp "$(__git_all_commands)"
889 }
890
891 _git_init ()
892 {
893         local cur="${COMP_WORDS[COMP_CWORD]}"
894         case "$cur" in
895         --shared=*)
896                 __gitcomp "
897                         false true umask group all world everybody
898                         " "" "${cur##--shared=}"
899                 return
900                 ;;
901         --*)
902                 __gitcomp "--quiet --bare --template= --shared --shared="
903                 return
904                 ;;
905         esac
906         COMPREPLY=()
907 }
908
909 _git_ls_files ()
910 {
911         __git_has_doubledash && return
912
913         local cur="${COMP_WORDS[COMP_CWORD]}"
914         case "$cur" in
915         --*)
916                 __gitcomp "--cached --deleted --modified --others --ignored
917                         --stage --directory --no-empty-directory --unmerged
918                         --killed --exclude= --exclude-from=
919                         --exclude-per-directory= --exclude-standard
920                         --error-unmatch --with-tree= --full-name
921                         --abbrev --ignored --exclude-per-directory
922                         "
923                 return
924                 ;;
925         esac
926         COMPREPLY=()
927 }
928
929 _git_ls_remote ()
930 {
931         __gitcomp "$(__git_remotes)"
932 }
933
934 _git_ls_tree ()
935 {
936         __git_complete_file
937 }
938
939 _git_log ()
940 {
941         __git_has_doubledash && return
942
943         local cur="${COMP_WORDS[COMP_CWORD]}"
944         case "$cur" in
945         --pretty=*)
946                 __gitcomp "
947                         oneline short medium full fuller email raw
948                         " "" "${cur##--pretty=}"
949                 return
950                 ;;
951         --date=*)
952                 __gitcomp "
953                         relative iso8601 rfc2822 short local default
954                 " "" "${cur##--date=}"
955                 return
956                 ;;
957         --*)
958                 __gitcomp "
959                         --max-count= --max-age= --since= --after=
960                         --min-age= --before= --until=
961                         --root --topo-order --date-order --reverse
962                         --no-merges --follow
963                         --abbrev-commit --abbrev=
964                         --relative-date --date=
965                         --author= --committer= --grep=
966                         --all-match
967                         --pretty= --name-status --name-only --raw
968                         --not --all
969                         --left-right --cherry-pick
970                         --graph
971                         --stat --numstat --shortstat
972                         --decorate --diff-filter=
973                         --color-words --walk-reflogs
974                         --parents --children --full-history
975                         "
976                 return
977                 ;;
978         esac
979         __git_complete_revlist
980 }
981
982 _git_merge ()
983 {
984         local cur="${COMP_WORDS[COMP_CWORD]}"
985         case "${COMP_WORDS[COMP_CWORD-1]}" in
986         -s|--strategy)
987                 __gitcomp "$(__git_merge_strategies)"
988                 return
989         esac
990         case "$cur" in
991         --strategy=*)
992                 __gitcomp "$(__git_merge_strategies)" "" "${cur##--strategy=}"
993                 return
994                 ;;
995         --*)
996                 __gitcomp "
997                         --no-commit --no-stat --log --no-log --squash --strategy
998                         "
999                 return
1000         esac
1001         __gitcomp "$(__git_refs)"
1002 }
1003
1004 _git_merge_base ()
1005 {
1006         __gitcomp "$(__git_refs)"
1007 }
1008
1009 _git_mv ()
1010 {
1011         local cur="${COMP_WORDS[COMP_CWORD]}"
1012         case "$cur" in
1013         --*)
1014                 __gitcomp "--dry-run"
1015                 return
1016                 ;;
1017         esac
1018         COMPREPLY=()
1019 }
1020
1021 _git_name_rev ()
1022 {
1023         __gitcomp "--tags --all --stdin"
1024 }
1025
1026 _git_pull ()
1027 {
1028         local cur="${COMP_WORDS[COMP_CWORD]}"
1029
1030         case "${COMP_WORDS[0]},$COMP_CWORD" in
1031         git-pull*,1)
1032                 __gitcomp "$(__git_remotes)"
1033                 ;;
1034         git,2)
1035                 __gitcomp "$(__git_remotes)"
1036                 ;;
1037         *)
1038                 local remote
1039                 case "${COMP_WORDS[0]}" in
1040                 git-pull)  remote="${COMP_WORDS[1]}" ;;
1041                 git)       remote="${COMP_WORDS[2]}" ;;
1042                 esac
1043                 __gitcomp "$(__git_refs "$remote")"
1044                 ;;
1045         esac
1046 }
1047
1048 _git_push ()
1049 {
1050         local cur="${COMP_WORDS[COMP_CWORD]}"
1051
1052         case "${COMP_WORDS[0]},$COMP_CWORD" in
1053         git-push*,1)
1054                 __gitcomp "$(__git_remotes)"
1055                 ;;
1056         git,2)
1057                 __gitcomp "$(__git_remotes)"
1058                 ;;
1059         *)
1060                 case "$cur" in
1061                 *:*)
1062                         local remote
1063                         case "${COMP_WORDS[0]}" in
1064                         git-push)  remote="${COMP_WORDS[1]}" ;;
1065                         git)       remote="${COMP_WORDS[2]}" ;;
1066                         esac
1067
1068                         local pfx=""
1069                         case "$COMP_WORDBREAKS" in
1070                         *:*) : great ;;
1071                         *)   pfx="${cur%%:*}:" ;;
1072                         esac
1073
1074                         __gitcomp "$(__git_refs "$remote")" "$pfx" "${cur#*:}"
1075                         ;;
1076                 +*)
1077                         __gitcomp "$(__git_refs)" + "${cur#+}"
1078                         ;;
1079                 *)
1080                         __gitcomp "$(__git_refs)"
1081                         ;;
1082                 esac
1083                 ;;
1084         esac
1085 }
1086
1087 _git_rebase ()
1088 {
1089         local cur="${COMP_WORDS[COMP_CWORD]}" dir="$(__gitdir)"
1090         if [ -d "$dir"/rebase-apply ] || [ -d "$dir"/rebase-merge ]; then
1091                 __gitcomp "--continue --skip --abort"
1092                 return
1093         fi
1094         case "${COMP_WORDS[COMP_CWORD-1]}" in
1095         -s|--strategy)
1096                 __gitcomp "$(__git_merge_strategies)"
1097                 return
1098         esac
1099         case "$cur" in
1100         --strategy=*)
1101                 __gitcomp "$(__git_merge_strategies)" "" "${cur##--strategy=}"
1102                 return
1103                 ;;
1104         --*)
1105                 __gitcomp "--onto --merge --strategy --interactive"
1106                 return
1107         esac
1108         __gitcomp "$(__git_refs)"
1109 }
1110
1111 _git_send_email ()
1112 {
1113         local cur="${COMP_WORDS[COMP_CWORD]}"
1114         case "$cur" in
1115         --*)
1116                 __gitcomp "--bcc --cc --cc-cmd --chain-reply-to --compose
1117                         --dry-run --envelope-sender --from --identity
1118                         --in-reply-to --no-chain-reply-to --no-signed-off-by-cc
1119                         --no-suppress-from --no-thread --quiet
1120                         --signed-off-by-cc --smtp-pass --smtp-server
1121                         --smtp-server-port --smtp-ssl --smtp-user --subject
1122                         --suppress-cc --suppress-from --thread --to"
1123                 return
1124                 ;;
1125         esac
1126         COMPREPLY=()
1127 }
1128
1129 _git_config ()
1130 {
1131         local cur="${COMP_WORDS[COMP_CWORD]}"
1132         local prv="${COMP_WORDS[COMP_CWORD-1]}"
1133         case "$prv" in
1134         branch.*.remote)
1135                 __gitcomp "$(__git_remotes)"
1136                 return
1137                 ;;
1138         branch.*.merge)
1139                 __gitcomp "$(__git_refs)"
1140                 return
1141                 ;;
1142         remote.*.fetch)
1143                 local remote="${prv#remote.}"
1144                 remote="${remote%.fetch}"
1145                 __gitcomp "$(__git_refs_remotes "$remote")"
1146                 return
1147                 ;;
1148         remote.*.push)
1149                 local remote="${prv#remote.}"
1150                 remote="${remote%.push}"
1151                 __gitcomp "$(git --git-dir="$(__gitdir)" \
1152                         for-each-ref --format='%(refname):%(refname)' \
1153                         refs/heads)"
1154                 return
1155                 ;;
1156         pull.twohead|pull.octopus)
1157                 __gitcomp "$(__git_merge_strategies)"
1158                 return
1159                 ;;
1160         color.branch|color.diff|color.status)
1161                 __gitcomp "always never auto"
1162                 return
1163                 ;;
1164         color.*.*)
1165                 __gitcomp "
1166                         black red green yellow blue magenta cyan white
1167                         bold dim ul blink reverse
1168                         "
1169                 return
1170                 ;;
1171         *.*)
1172                 COMPREPLY=()
1173                 return
1174                 ;;
1175         esac
1176         case "$cur" in
1177         --*)
1178                 __gitcomp "
1179                         --global --system --file=
1180                         --list --replace-all
1181                         --get --get-all --get-regexp
1182                         --add --unset --unset-all
1183                         --remove-section --rename-section
1184                         "
1185                 return
1186                 ;;
1187         branch.*.*)
1188                 local pfx="${cur%.*}."
1189                 cur="${cur##*.}"
1190                 __gitcomp "remote merge" "$pfx" "$cur"
1191                 return
1192                 ;;
1193         branch.*)
1194                 local pfx="${cur%.*}."
1195                 cur="${cur#*.}"
1196                 __gitcomp "$(__git_heads)" "$pfx" "$cur" "."
1197                 return
1198                 ;;
1199         remote.*.*)
1200                 local pfx="${cur%.*}."
1201                 cur="${cur##*.}"
1202                 __gitcomp "
1203                         url fetch push skipDefaultUpdate
1204                         receivepack uploadpack tagopt
1205                         " "$pfx" "$cur"
1206                 return
1207                 ;;
1208         remote.*)
1209                 local pfx="${cur%.*}."
1210                 cur="${cur#*.}"
1211                 __gitcomp "$(__git_remotes)" "$pfx" "$cur" "."
1212                 return
1213                 ;;
1214         esac
1215         __gitcomp "
1216                 apply.whitespace
1217                 core.fileMode
1218                 core.gitProxy
1219                 core.ignoreStat
1220                 core.preferSymlinkRefs
1221                 core.logAllRefUpdates
1222                 core.loosecompression
1223                 core.repositoryFormatVersion
1224                 core.sharedRepository
1225                 core.warnAmbiguousRefs
1226                 core.compression
1227                 core.packedGitWindowSize
1228                 core.packedGitLimit
1229                 clean.requireForce
1230                 color.branch
1231                 color.branch.current
1232                 color.branch.local
1233                 color.branch.remote
1234                 color.branch.plain
1235                 color.diff
1236                 color.diff.plain
1237                 color.diff.meta
1238                 color.diff.frag
1239                 color.diff.old
1240                 color.diff.new
1241                 color.diff.commit
1242                 color.diff.whitespace
1243                 color.pager
1244                 color.status
1245                 color.status.header
1246                 color.status.added
1247                 color.status.changed
1248                 color.status.untracked
1249                 diff.renameLimit
1250                 diff.renames
1251                 fetch.unpackLimit
1252                 format.headers
1253                 format.subjectprefix
1254                 gitcvs.enabled
1255                 gitcvs.logfile
1256                 gitcvs.allbinary
1257                 gitcvs.dbname gitcvs.dbdriver gitcvs.dbuser gitcvs.dbpass
1258                 gitcvs.dbtablenameprefix
1259                 gc.packrefs
1260                 gc.reflogexpire
1261                 gc.reflogexpireunreachable
1262                 gc.rerereresolved
1263                 gc.rerereunresolved
1264                 http.sslVerify
1265                 http.sslCert
1266                 http.sslKey
1267                 http.sslCAInfo
1268                 http.sslCAPath
1269                 http.maxRequests
1270                 http.lowSpeedLimit
1271                 http.lowSpeedTime
1272                 http.noEPSV
1273                 i18n.commitEncoding
1274                 i18n.logOutputEncoding
1275                 log.showroot
1276                 merge.tool
1277                 merge.summary
1278                 merge.verbosity
1279                 pack.window
1280                 pack.depth
1281                 pack.windowMemory
1282                 pack.compression
1283                 pack.deltaCacheSize
1284                 pack.deltaCacheLimit
1285                 pull.octopus
1286                 pull.twohead
1287                 repack.useDeltaBaseOffset
1288                 showbranch.default
1289                 tar.umask
1290                 transfer.unpackLimit
1291                 receive.unpackLimit
1292                 receive.denyNonFastForwards
1293                 user.name
1294                 user.email
1295                 user.signingkey
1296                 branch. remote.
1297         "
1298 }
1299
1300 _git_remote ()
1301 {
1302         local subcommands="add rm show prune update"
1303         local subcommand="$(__git_find_subcommand "$subcommands")"
1304         if [ -z "$subcommand" ]; then
1305                 __gitcomp "$subcommands"
1306                 return
1307         fi
1308
1309         case "$subcommand" in
1310         rm|show|prune)
1311                 __gitcomp "$(__git_remotes)"
1312                 ;;
1313         update)
1314                 local i c='' IFS=$'\n'
1315                 for i in $(git --git-dir="$(__gitdir)" config --list); do
1316                         case "$i" in
1317                         remotes.*)
1318                                 i="${i#remotes.}"
1319                                 c="$c ${i/=*/}"
1320                                 ;;
1321                         esac
1322                 done
1323                 __gitcomp "$c"
1324                 ;;
1325         *)
1326                 COMPREPLY=()
1327                 ;;
1328         esac
1329 }
1330
1331 _git_reset ()
1332 {
1333         __git_has_doubledash && return
1334
1335         local cur="${COMP_WORDS[COMP_CWORD]}"
1336         case "$cur" in
1337         --*)
1338                 __gitcomp "--mixed --hard --soft"
1339                 return
1340                 ;;
1341         esac
1342         __gitcomp "$(__git_refs)"
1343 }
1344
1345 _git_revert ()
1346 {
1347         local cur="${COMP_WORDS[COMP_CWORD]}"
1348         case "$cur" in
1349         --*)
1350                 __gitcomp "--edit --mainline --no-edit --no-commit --signoff"
1351                 return
1352                 ;;
1353         esac
1354         COMPREPLY=()
1355 }
1356
1357 _git_rm ()
1358 {
1359         __git_has_doubledash && return
1360
1361         local cur="${COMP_WORDS[COMP_CWORD]}"
1362         case "$cur" in
1363         --*)
1364                 __gitcomp "--cached --dry-run --ignore-unmatch --quiet"
1365                 return
1366                 ;;
1367         esac
1368         COMPREPLY=()
1369 }
1370
1371 _git_shortlog ()
1372 {
1373         __git_has_doubledash && return
1374
1375         local cur="${COMP_WORDS[COMP_CWORD]}"
1376         case "$cur" in
1377         --*)
1378                 __gitcomp "
1379                         --max-count= --max-age= --since= --after=
1380                         --min-age= --before= --until=
1381                         --no-merges
1382                         --author= --committer= --grep=
1383                         --all-match
1384                         --not --all
1385                         --numbered --summary
1386                         "
1387                 return
1388                 ;;
1389         esac
1390         __git_complete_revlist
1391 }
1392
1393 _git_show ()
1394 {
1395         local cur="${COMP_WORDS[COMP_CWORD]}"
1396         case "$cur" in
1397         --pretty=*)
1398                 __gitcomp "
1399                         oneline short medium full fuller email raw
1400                         " "" "${cur##--pretty=}"
1401                 return
1402                 ;;
1403         --*)
1404                 __gitcomp "--pretty="
1405                 return
1406                 ;;
1407         esac
1408         __git_complete_file
1409 }
1410
1411 _git_show_branch ()
1412 {
1413         local cur="${COMP_WORDS[COMP_CWORD]}"
1414         case "$cur" in
1415         --*)
1416                 __gitcomp "
1417                         --all --remotes --topo-order --current --more=
1418                         --list --independent --merge-base --no-name
1419                         --sha1-name --topics --reflog
1420                         "
1421                 return
1422                 ;;
1423         esac
1424         __git_complete_revlist
1425 }
1426
1427 _git_stash ()
1428 {
1429         local subcommands='save list show apply clear drop pop create branch'
1430         local subcommand="$(__git_find_subcommand "$subcommands")"
1431         if [ -z "$subcommand" ]; then
1432                 __gitcomp "$subcommands"
1433         else
1434                 local cur="${COMP_WORDS[COMP_CWORD]}"
1435                 case "$subcommand,$cur" in
1436                 save,--*)
1437                         __gitcomp "--keep-index"
1438                         ;;
1439                 apply,--*)
1440                         __gitcomp "--index"
1441                         ;;
1442                 show,--*|drop,--*|pop,--*|branch,--*)
1443                         COMPREPLY=()
1444                         ;;
1445                 show,*|apply,*|drop,*|pop,*|branch,*)
1446                         __gitcomp "$(git --git-dir="$(__gitdir)" stash list \
1447                                         | sed -n -e 's/:.*//p')"
1448                         ;;
1449                 *)
1450                         COMPREPLY=()
1451                         ;;
1452                 esac
1453         fi
1454 }
1455
1456 _git_submodule ()
1457 {
1458         __git_has_doubledash && return
1459
1460         local subcommands="add status init update"
1461         if [ -z "$(__git_find_subcommand "$subcommands")" ]; then
1462                 local cur="${COMP_WORDS[COMP_CWORD]}"
1463                 case "$cur" in
1464                 --*)
1465                         __gitcomp "--quiet --cached"
1466                         ;;
1467                 *)
1468                         __gitcomp "$subcommands"
1469                         ;;
1470                 esac
1471                 return
1472         fi
1473 }
1474
1475 _git_svn ()
1476 {
1477         local subcommands="
1478                 init fetch clone rebase dcommit log find-rev
1479                 set-tree commit-diff info create-ignore propget
1480                 proplist show-ignore show-externals
1481                 "
1482         local subcommand="$(__git_find_subcommand "$subcommands")"
1483         if [ -z "$subcommand" ]; then
1484                 __gitcomp "$subcommands"
1485         else
1486                 local remote_opts="--username= --config-dir= --no-auth-cache"
1487                 local fc_opts="
1488                         --follow-parent --authors-file= --repack=
1489                         --no-metadata --use-svm-props --use-svnsync-props
1490                         --log-window-size= --no-checkout --quiet
1491                         --repack-flags --user-log-author $remote_opts
1492                         "
1493                 local init_opts="
1494                         --template= --shared= --trunk= --tags=
1495                         --branches= --stdlayout --minimize-url
1496                         --no-metadata --use-svm-props --use-svnsync-props
1497                         --rewrite-root= $remote_opts
1498                         "
1499                 local cmt_opts="
1500                         --edit --rmdir --find-copies-harder --copy-similarity=
1501                         "
1502
1503                 local cur="${COMP_WORDS[COMP_CWORD]}"
1504                 case "$subcommand,$cur" in
1505                 fetch,--*)
1506                         __gitcomp "--revision= --fetch-all $fc_opts"
1507                         ;;
1508                 clone,--*)
1509                         __gitcomp "--revision= $fc_opts $init_opts"
1510                         ;;
1511                 init,--*)
1512                         __gitcomp "$init_opts"
1513                         ;;
1514                 dcommit,--*)
1515                         __gitcomp "
1516                                 --merge --strategy= --verbose --dry-run
1517                                 --fetch-all --no-rebase $cmt_opts $fc_opts
1518                                 "
1519                         ;;
1520                 set-tree,--*)
1521                         __gitcomp "--stdin $cmt_opts $fc_opts"
1522                         ;;
1523                 create-ignore,--*|propget,--*|proplist,--*|show-ignore,--*|\
1524                 show-externals,--*)
1525                         __gitcomp "--revision="
1526                         ;;
1527                 log,--*)
1528                         __gitcomp "
1529                                 --limit= --revision= --verbose --incremental
1530                                 --oneline --show-commit --non-recursive
1531                                 --authors-file=
1532                                 "
1533                         ;;
1534                 rebase,--*)
1535                         __gitcomp "
1536                                 --merge --verbose --strategy= --local
1537                                 --fetch-all $fc_opts
1538                                 "
1539                         ;;
1540                 commit-diff,--*)
1541                         __gitcomp "--message= --file= --revision= $cmt_opts"
1542                         ;;
1543                 info,--*)
1544                         __gitcomp "--url"
1545                         ;;
1546                 *)
1547                         COMPREPLY=()
1548                         ;;
1549                 esac
1550         fi
1551 }
1552
1553 _git_tag ()
1554 {
1555         local i c=1 f=0
1556         while [ $c -lt $COMP_CWORD ]; do
1557                 i="${COMP_WORDS[c]}"
1558                 case "$i" in
1559                 -d|-v)
1560                         __gitcomp "$(__git_tags)"
1561                         return
1562                         ;;
1563                 -f)
1564                         f=1
1565                         ;;
1566                 esac
1567                 c=$((++c))
1568         done
1569
1570         case "${COMP_WORDS[COMP_CWORD-1]}" in
1571         -m|-F)
1572                 COMPREPLY=()
1573                 ;;
1574         -*|tag|git-tag)
1575                 if [ $f = 1 ]; then
1576                         __gitcomp "$(__git_tags)"
1577                 else
1578                         COMPREPLY=()
1579                 fi
1580                 ;;
1581         *)
1582                 __gitcomp "$(__git_refs)"
1583                 ;;
1584         esac
1585 }
1586
1587 _git ()
1588 {
1589         local i c=1 command __git_dir
1590
1591         while [ $c -lt $COMP_CWORD ]; do
1592                 i="${COMP_WORDS[c]}"
1593                 case "$i" in
1594                 --git-dir=*) __git_dir="${i#--git-dir=}" ;;
1595                 --bare)      __git_dir="." ;;
1596                 --version|-p|--paginate) ;;
1597                 --help) command="help"; break ;;
1598                 *) command="$i"; break ;;
1599                 esac
1600                 c=$((++c))
1601         done
1602
1603         if [ -z "$command" ]; then
1604                 case "${COMP_WORDS[COMP_CWORD]}" in
1605                 --*=*) COMPREPLY=() ;;
1606                 --*)   __gitcomp "
1607                         --paginate
1608                         --no-pager
1609                         --git-dir=
1610                         --bare
1611                         --version
1612                         --exec-path
1613                         --work-tree=
1614                         --help
1615                         "
1616                         ;;
1617                 *)     __gitcomp "$(__git_porcelain_commands) $(__git_aliases)" ;;
1618                 esac
1619                 return
1620         fi
1621
1622         local expansion=$(__git_aliased_command "$command")
1623         [ "$expansion" ] && command="$expansion"
1624
1625         case "$command" in
1626         am)          _git_am ;;
1627         add)         _git_add ;;
1628         apply)       _git_apply ;;
1629         archive)     _git_archive ;;
1630         bisect)      _git_bisect ;;
1631         bundle)      _git_bundle ;;
1632         branch)      _git_branch ;;
1633         checkout)    _git_checkout ;;
1634         cherry)      _git_cherry ;;
1635         cherry-pick) _git_cherry_pick ;;
1636         clean)       _git_clean ;;
1637         clone)       _git_clone ;;
1638         commit)      _git_commit ;;
1639         config)      _git_config ;;
1640         describe)    _git_describe ;;
1641         diff)        _git_diff ;;
1642         fetch)       _git_fetch ;;
1643         format-patch) _git_format_patch ;;
1644         gc)          _git_gc ;;
1645         grep)        _git_grep ;;
1646         help)        _git_help ;;
1647         init)        _git_init ;;
1648         log)         _git_log ;;
1649         ls-files)    _git_ls_files ;;
1650         ls-remote)   _git_ls_remote ;;
1651         ls-tree)     _git_ls_tree ;;
1652         merge)       _git_merge;;
1653         merge-base)  _git_merge_base ;;
1654         mv)          _git_mv ;;
1655         name-rev)    _git_name_rev ;;
1656         pull)        _git_pull ;;
1657         push)        _git_push ;;
1658         rebase)      _git_rebase ;;
1659         remote)      _git_remote ;;
1660         reset)       _git_reset ;;
1661         revert)      _git_revert ;;
1662         rm)          _git_rm ;;
1663         send-email)  _git_send_email ;;
1664         shortlog)    _git_shortlog ;;
1665         show)        _git_show ;;
1666         show-branch) _git_show_branch ;;
1667         stash)       _git_stash ;;
1668         submodule)   _git_submodule ;;
1669         svn)         _git_svn ;;
1670         tag)         _git_tag ;;
1671         whatchanged) _git_log ;;
1672         *)           COMPREPLY=() ;;
1673         esac
1674 }
1675
1676 _gitk ()
1677 {
1678         __git_has_doubledash && return
1679
1680         local cur="${COMP_WORDS[COMP_CWORD]}"
1681         local g="$(git rev-parse --git-dir 2>/dev/null)"
1682         local merge=""
1683         if [ -f $g/MERGE_HEAD ]; then
1684                 merge="--merge"
1685         fi
1686         case "$cur" in
1687         --*)
1688                 __gitcomp "--not --all $merge"
1689                 return
1690                 ;;
1691         esac
1692         __git_complete_revlist
1693 }
1694
1695 complete -o default -o nospace -F _git git
1696 complete -o default -o nospace -F _gitk gitk
1697
1698 # The following are necessary only for Cygwin, and only are needed
1699 # when the user has tab-completed the executable name and consequently
1700 # included the '.exe' suffix.
1701 #
1702 if [ Cygwin = "$(uname -o 2>/dev/null)" ]; then
1703 complete -o default -o nospace -F _git git.exe
1704 fi