bash: Support completion on git-cherry.
[git/gitweb.git] / contrib / completion / git-completion.bash
blobb434332bf7c9bbf58ca82ef0b1804441eaf2b65c
2 # bash completion support for core Git.
4 # Copyright (C) 2006,2007 Shawn Pearce
5 # Conceptually based on gitcompletion (http://gitweb.hawaga.org.uk/).
7 # The contained completion routines provide support for completing:
9 # *) local and remote branch names
10 # *) local and remote tag names
11 # *) .git/remotes file names
12 # *) git 'subcommands'
13 # *) tree paths within 'ref:path/to/file' expressions
15 # To use these routines:
17 # 1) Copy this file to somewhere (e.g. ~/.git-completion.sh).
18 # 2) Added the following line to your .bashrc:
19 # source ~/.git-completion.sh
21 # 3) You may want to make sure the git executable is available
22 # in your PATH before this script is sourced, as some caching
23 # is performed while the script loads. If git isn't found
24 # at source time then all lookups will be done on demand,
25 # which may be slightly slower.
27 # 4) Consider changing your PS1 to also show the current branch:
28 # PS1='[\u@\h \W$(__git_ps1 " (%s)")]\$ '
30 # The argument to __git_ps1 will be displayed only if you
31 # are currently in a git repository. The %s token will be
32 # the name of the current branch.
35 __gitdir ()
37 if [ -z "$1" ]; then
38 if [ -n "$__git_dir" ]; then
39 echo "$__git_dir"
40 elif [ -d .git ]; then
41 echo .git
42 else
43 git rev-parse --git-dir 2>/dev/null
45 elif [ -d "$1/.git" ]; then
46 echo "$1/.git"
47 else
48 echo "$1"
52 __git_ps1 ()
54 local b="$(git symbolic-ref HEAD 2>/dev/null)"
55 if [ -n "$b" ]; then
56 if [ -n "$1" ]; then
57 printf "$1" "${b##refs/heads/}"
58 else
59 printf " (%s)" "${b##refs/heads/}"
64 __gitcomp ()
66 local all c s=$'\n' IFS=' '$'\t'$'\n'
67 local cur="${COMP_WORDS[COMP_CWORD]}"
68 if [ $# -gt 2 ]; then
69 cur="$3"
71 for c in $1; do
72 case "$c$4" in
73 --*=*) all="$all$c$4$s" ;;
74 *.) all="$all$c$4$s" ;;
75 *) all="$all$c$4 $s" ;;
76 esac
77 done
78 IFS=$s
79 COMPREPLY=($(compgen -P "$2" -W "$all" -- "$cur"))
80 return
83 __git_heads ()
85 local cmd i is_hash=y dir="$(__gitdir "$1")"
86 if [ -d "$dir" ]; then
87 for i in $(git --git-dir="$dir" \
88 for-each-ref --format='%(refname)' \
89 refs/heads ); do
90 echo "${i#refs/heads/}"
91 done
92 return
94 for i in $(git-ls-remote "$1" 2>/dev/null); do
95 case "$is_hash,$i" in
96 y,*) is_hash=n ;;
97 n,*^{}) is_hash=y ;;
98 n,refs/heads/*) is_hash=y; echo "${i#refs/heads/}" ;;
99 n,*) is_hash=y; echo "$i" ;;
100 esac
101 done
104 __git_refs ()
106 local cmd i is_hash=y dir="$(__gitdir "$1")"
107 if [ -d "$dir" ]; then
108 if [ -e "$dir/HEAD" ]; then echo HEAD; fi
109 for i in $(git --git-dir="$dir" \
110 for-each-ref --format='%(refname)' \
111 refs/tags refs/heads refs/remotes); do
112 case "$i" in
113 refs/tags/*) echo "${i#refs/tags/}" ;;
114 refs/heads/*) echo "${i#refs/heads/}" ;;
115 refs/remotes/*) echo "${i#refs/remotes/}" ;;
116 *) echo "$i" ;;
117 esac
118 done
119 return
121 for i in $(git-ls-remote "$dir" 2>/dev/null); do
122 case "$is_hash,$i" in
123 y,*) is_hash=n ;;
124 n,*^{}) is_hash=y ;;
125 n,refs/tags/*) is_hash=y; echo "${i#refs/tags/}" ;;
126 n,refs/heads/*) is_hash=y; echo "${i#refs/heads/}" ;;
127 n,refs/remotes/*) is_hash=y; echo "${i#refs/remotes/}" ;;
128 n,*) is_hash=y; echo "$i" ;;
129 esac
130 done
133 __git_refs2 ()
135 local i
136 for i in $(__git_refs "$1"); do
137 echo "$i:$i"
138 done
141 __git_refs_remotes ()
143 local cmd i is_hash=y
144 for i in $(git-ls-remote "$1" 2>/dev/null); do
145 case "$is_hash,$i" in
146 n,refs/heads/*)
147 is_hash=y
148 echo "$i:refs/remotes/$1/${i#refs/heads/}"
150 y,*) is_hash=n ;;
151 n,*^{}) is_hash=y ;;
152 n,refs/tags/*) is_hash=y;;
153 n,*) is_hash=y; ;;
154 esac
155 done
158 __git_remotes ()
160 local i ngoff IFS=$'\n' d="$(__gitdir)"
161 shopt -q nullglob || ngoff=1
162 shopt -s nullglob
163 for i in "$d/remotes"/*; do
164 echo ${i#$d/remotes/}
165 done
166 [ "$ngoff" ] && shopt -u nullglob
167 for i in $(git --git-dir="$d" config --list); do
168 case "$i" in
169 remote.*.url=*)
170 i="${i#remote.}"
171 echo "${i/.url=*/}"
173 esac
174 done
177 __git_merge_strategies ()
179 if [ -n "$__git_merge_strategylist" ]; then
180 echo "$__git_merge_strategylist"
181 return
183 sed -n "/^all_strategies='/{
184 s/^all_strategies='//
185 s/'//
188 }" "$(git --exec-path)/git-merge"
190 __git_merge_strategylist=
191 __git_merge_strategylist="$(__git_merge_strategies 2>/dev/null)"
193 __git_complete_file ()
195 local pfx ls ref cur="${COMP_WORDS[COMP_CWORD]}"
196 case "$cur" in
197 ?*:*)
198 ref="${cur%%:*}"
199 cur="${cur#*:}"
200 case "$cur" in
201 ?*/*)
202 pfx="${cur%/*}"
203 cur="${cur##*/}"
204 ls="$ref:$pfx"
205 pfx="$pfx/"
208 ls="$ref"
210 esac
211 COMPREPLY=($(compgen -P "$pfx" \
212 -W "$(git --git-dir="$(__gitdir)" ls-tree "$ls" \
213 | sed '/^100... blob /s,^.* ,,
214 /^040000 tree /{
215 s,^.* ,,
216 s,$,/,
218 s/^.* //')" \
219 -- "$cur"))
222 __gitcomp "$(__git_refs)"
224 esac
227 __git_complete_revlist ()
229 local pfx cur="${COMP_WORDS[COMP_CWORD]}"
230 case "$cur" in
231 *...*)
232 pfx="${cur%...*}..."
233 cur="${cur#*...}"
234 __gitcomp "$(__git_refs)" "$pfx" "$cur"
236 *..*)
237 pfx="${cur%..*}.."
238 cur="${cur#*..}"
239 __gitcomp "$(__git_refs)" "$pfx" "$cur"
242 __gitcomp "$cur."
245 __gitcomp "$(__git_refs)"
247 esac
250 __git_commands ()
252 if [ -n "$__git_commandlist" ]; then
253 echo "$__git_commandlist"
254 return
256 local i IFS=" "$'\n'
257 for i in $(git help -a|egrep '^ ')
259 case $i in
260 add--interactive) : plumbing;;
261 applymbox) : ask gittus;;
262 applypatch) : ask gittus;;
263 archimport) : import;;
264 cat-file) : plumbing;;
265 check-ref-format) : plumbing;;
266 commit-tree) : plumbing;;
267 convert-objects) : plumbing;;
268 cvsexportcommit) : export;;
269 cvsimport) : import;;
270 cvsserver) : daemon;;
271 daemon) : daemon;;
272 fsck-objects) : plumbing;;
273 fetch-pack) : plumbing;;
274 fmt-merge-msg) : plumbing;;
275 hash-object) : plumbing;;
276 http-*) : transport;;
277 index-pack) : plumbing;;
278 init-db) : deprecated;;
279 local-fetch) : plumbing;;
280 mailinfo) : plumbing;;
281 mailsplit) : plumbing;;
282 merge-*) : plumbing;;
283 mktree) : plumbing;;
284 mktag) : plumbing;;
285 pack-objects) : plumbing;;
286 pack-redundant) : plumbing;;
287 pack-refs) : plumbing;;
288 parse-remote) : plumbing;;
289 patch-id) : plumbing;;
290 peek-remote) : plumbing;;
291 prune) : plumbing;;
292 prune-packed) : plumbing;;
293 quiltimport) : import;;
294 read-tree) : plumbing;;
295 receive-pack) : plumbing;;
296 reflog) : plumbing;;
297 repo-config) : plumbing;;
298 rerere) : plumbing;;
299 rev-list) : plumbing;;
300 rev-parse) : plumbing;;
301 runstatus) : plumbing;;
302 sh-setup) : internal;;
303 shell) : daemon;;
304 send-pack) : plumbing;;
305 show-index) : plumbing;;
306 ssh-*) : transport;;
307 stripspace) : plumbing;;
308 svn) : import export;;
309 svnimport) : import;;
310 symbolic-ref) : plumbing;;
311 tar-tree) : deprecated;;
312 unpack-file) : plumbing;;
313 unpack-objects) : plumbing;;
314 update-index) : plumbing;;
315 update-ref) : plumbing;;
316 update-server-info) : daemon;;
317 upload-archive) : plumbing;;
318 upload-pack) : plumbing;;
319 write-tree) : plumbing;;
320 verify-tag) : plumbing;;
321 *) echo $i;;
322 esac
323 done
325 __git_commandlist=
326 __git_commandlist="$(__git_commands 2>/dev/null)"
328 __git_aliases ()
330 local i IFS=$'\n'
331 for i in $(git --git-dir="$(__gitdir)" config --list); do
332 case "$i" in
333 alias.*)
334 i="${i#alias.}"
335 echo "${i/=*/}"
337 esac
338 done
341 __git_aliased_command ()
343 local word cmdline=$(git --git-dir="$(__gitdir)" \
344 config --get "alias.$1")
345 for word in $cmdline; do
346 if [ "${word##-*}" ]; then
347 echo $word
348 return
350 done
353 __git_whitespacelist="nowarn warn error error-all strip"
355 _git_am ()
357 local cur="${COMP_WORDS[COMP_CWORD]}"
358 if [ -d .dotest ]; then
359 __gitcomp "--skip --resolved"
360 return
362 case "$cur" in
363 --whitespace=*)
364 __gitcomp "$__git_whitespacelist" "" "${cur##--whitespace=}"
365 return
367 --*)
368 __gitcomp "
369 --signoff --utf8 --binary --3way --interactive
370 --whitespace=
372 return
373 esac
374 COMPREPLY=()
377 _git_apply ()
379 local cur="${COMP_WORDS[COMP_CWORD]}"
380 case "$cur" in
381 --whitespace=*)
382 __gitcomp "$__git_whitespacelist" "" "${cur##--whitespace=}"
383 return
385 --*)
386 __gitcomp "
387 --stat --numstat --summary --check --index
388 --cached --index-info --reverse --reject --unidiff-zero
389 --apply --no-add --exclude=
390 --whitespace= --inaccurate-eof --verbose
392 return
393 esac
394 COMPREPLY=()
397 _git_add ()
399 local cur="${COMP_WORDS[COMP_CWORD]}"
400 case "$cur" in
401 --*)
402 __gitcomp "--interactive"
403 return
404 esac
405 COMPREPLY=()
408 _git_branch ()
410 __gitcomp "$(__git_refs)"
413 _git_checkout ()
415 __gitcomp "$(__git_refs)"
418 _git_cherry ()
420 __gitcomp "$(__git_refs)"
423 _git_cherry_pick ()
425 local cur="${COMP_WORDS[COMP_CWORD]}"
426 case "$cur" in
427 --*)
428 __gitcomp "--edit --no-commit"
431 __gitcomp "$(__git_refs)"
433 esac
436 _git_commit ()
438 local cur="${COMP_WORDS[COMP_CWORD]}"
439 case "$cur" in
440 --*)
441 __gitcomp "
442 --all --author= --signoff --verify --no-verify
443 --edit --amend --include --only
445 return
446 esac
447 COMPREPLY=()
450 _git_diff ()
452 __git_complete_file
455 _git_diff_tree ()
457 __gitcomp "$(__git_refs)"
460 _git_fetch ()
462 local cur="${COMP_WORDS[COMP_CWORD]}"
464 case "${COMP_WORDS[0]},$COMP_CWORD" in
465 git-fetch*,1)
466 __gitcomp "$(__git_remotes)"
468 git,2)
469 __gitcomp "$(__git_remotes)"
472 case "$cur" in
473 *:*)
474 __gitcomp "$(__git_refs)" "" "${cur#*:}"
477 local remote
478 case "${COMP_WORDS[0]}" in
479 git-fetch) remote="${COMP_WORDS[1]}" ;;
480 git) remote="${COMP_WORDS[2]}" ;;
481 esac
482 __gitcomp "$(__git_refs2 "$remote")"
484 esac
486 esac
489 _git_format_patch ()
491 local cur="${COMP_WORDS[COMP_CWORD]}"
492 case "$cur" in
493 --*)
494 __gitcomp "
495 --stdout --attach --thread
496 --output-directory
497 --numbered --start-number
498 --keep-subject
499 --signoff
500 --in-reply-to=
501 --full-index --binary
502 --not --all
504 return
506 esac
507 __git_complete_revlist
510 _git_ls_remote ()
512 __gitcomp "$(__git_remotes)"
515 _git_ls_tree ()
517 __git_complete_file
520 _git_log ()
522 local cur="${COMP_WORDS[COMP_CWORD]}"
523 case "$cur" in
524 --pretty=*)
525 __gitcomp "
526 oneline short medium full fuller email raw
527 " "" "${cur##--pretty=}"
528 return
530 --*)
531 __gitcomp "
532 --max-count= --max-age= --since= --after=
533 --min-age= --before= --until=
534 --root --not --topo-order --date-order
535 --no-merges
536 --abbrev-commit --abbrev=
537 --relative-date
538 --author= --committer= --grep=
539 --all-match
540 --pretty= --name-status --name-only
541 --not --all
543 return
545 esac
546 __git_complete_revlist
549 _git_merge ()
551 local cur="${COMP_WORDS[COMP_CWORD]}"
552 case "${COMP_WORDS[COMP_CWORD-1]}" in
553 -s|--strategy)
554 __gitcomp "$(__git_merge_strategies)"
555 return
556 esac
557 case "$cur" in
558 --strategy=*)
559 __gitcomp "$(__git_merge_strategies)" "" "${cur##--strategy=}"
560 return
562 --*)
563 __gitcomp "
564 --no-commit --no-summary --squash --strategy
566 return
567 esac
568 __gitcomp "$(__git_refs)"
571 _git_merge_base ()
573 __gitcomp "$(__git_refs)"
576 _git_name_rev ()
578 __gitcomp "--tags --all --stdin"
581 _git_pull ()
583 local cur="${COMP_WORDS[COMP_CWORD]}"
585 case "${COMP_WORDS[0]},$COMP_CWORD" in
586 git-pull*,1)
587 __gitcomp "$(__git_remotes)"
589 git,2)
590 __gitcomp "$(__git_remotes)"
593 local remote
594 case "${COMP_WORDS[0]}" in
595 git-pull) remote="${COMP_WORDS[1]}" ;;
596 git) remote="${COMP_WORDS[2]}" ;;
597 esac
598 __gitcomp "$(__git_refs "$remote")"
600 esac
603 _git_push ()
605 local cur="${COMP_WORDS[COMP_CWORD]}"
607 case "${COMP_WORDS[0]},$COMP_CWORD" in
608 git-push*,1)
609 __gitcomp "$(__git_remotes)"
611 git,2)
612 __gitcomp "$(__git_remotes)"
615 case "$cur" in
616 *:*)
617 local remote
618 case "${COMP_WORDS[0]}" in
619 git-push) remote="${COMP_WORDS[1]}" ;;
620 git) remote="${COMP_WORDS[2]}" ;;
621 esac
622 __gitcomp "$(__git_refs "$remote")" "" "${cur#*:}"
625 __gitcomp "$(__git_refs2)"
627 esac
629 esac
632 _git_rebase ()
634 local cur="${COMP_WORDS[COMP_CWORD]}"
635 if [ -d .dotest ]; then
636 __gitcomp "--continue --skip --abort"
637 return
639 case "${COMP_WORDS[COMP_CWORD-1]}" in
640 -s|--strategy)
641 __gitcomp "$(__git_merge_strategies)"
642 return
643 esac
644 case "$cur" in
645 --strategy=*)
646 __gitcomp "$(__git_merge_strategies)" "" "${cur##--strategy=}"
647 return
649 --*)
650 __gitcomp "--onto --merge --strategy"
651 return
652 esac
653 __gitcomp "$(__git_refs)"
656 _git_config ()
658 local cur="${COMP_WORDS[COMP_CWORD]}"
659 local prv="${COMP_WORDS[COMP_CWORD-1]}"
660 case "$prv" in
661 branch.*.remote)
662 __gitcomp "$(__git_remotes)"
663 return
665 branch.*.merge)
666 __gitcomp "$(__git_refs)"
667 return
669 remote.*.fetch)
670 local remote="${prv#remote.}"
671 remote="${remote%.fetch}"
672 __gitcomp "$(__git_refs_remotes "$remote")"
673 return
675 remote.*.push)
676 local remote="${prv#remote.}"
677 remote="${remote%.push}"
678 __gitcomp "$(git --git-dir="$(__gitdir)" \
679 for-each-ref --format='%(refname):%(refname)' \
680 refs/heads)"
681 return
683 pull.twohead|pull.octopus)
684 __gitcomp "$(__git_merge_strategies)"
685 return
687 color.branch|color.diff|color.status)
688 __gitcomp "always never auto"
689 return
691 color.*.*)
692 __gitcomp "
693 black red green yellow blue magenta cyan white
694 bold dim ul blink reverse
696 return
698 *.*)
699 COMPREPLY=()
700 return
702 esac
703 case "$cur" in
704 --*)
705 __gitcomp "
706 --global --list --replace-all
707 --get --get-all --get-regexp
708 --unset --unset-all
710 return
712 branch.*.*)
713 local pfx="${cur%.*}."
714 cur="${cur##*.}"
715 __gitcomp "remote merge" "$pfx" "$cur"
716 return
718 branch.*)
719 local pfx="${cur%.*}."
720 cur="${cur#*.}"
721 __gitcomp "$(__git_heads)" "$pfx" "$cur" "."
722 return
724 remote.*.*)
725 local pfx="${cur%.*}."
726 cur="${cur##*.}"
727 __gitcomp "url fetch push" "$pfx" "$cur"
728 return
730 remote.*)
731 local pfx="${cur%.*}."
732 cur="${cur#*.}"
733 __gitcomp "$(__git_remotes)" "$pfx" "$cur" "."
734 return
736 esac
737 __gitcomp "
738 apply.whitespace
739 core.fileMode
740 core.gitProxy
741 core.ignoreStat
742 core.preferSymlinkRefs
743 core.logAllRefUpdates
744 core.repositoryFormatVersion
745 core.sharedRepository
746 core.warnAmbiguousRefs
747 core.compression
748 core.legacyHeaders
749 core.packedGitWindowSize
750 core.packedGitLimit
751 color.branch
752 color.branch.current
753 color.branch.local
754 color.branch.remote
755 color.branch.plain
756 color.diff
757 color.diff.plain
758 color.diff.meta
759 color.diff.frag
760 color.diff.old
761 color.diff.new
762 color.diff.commit
763 color.diff.whitespace
764 color.pager
765 color.status
766 color.status.header
767 color.status.added
768 color.status.changed
769 color.status.untracked
770 diff.renameLimit
771 diff.renames
772 fetch.unpackLimit
773 format.headers
774 gitcvs.enabled
775 gitcvs.logfile
776 gc.reflogexpire
777 gc.reflogexpireunreachable
778 gc.rerereresolved
779 gc.rerereunresolved
780 http.sslVerify
781 http.sslCert
782 http.sslKey
783 http.sslCAInfo
784 http.sslCAPath
785 http.maxRequests
786 http.lowSpeedLimit
787 http.lowSpeedTime
788 http.noEPSV
789 i18n.commitEncoding
790 i18n.logOutputEncoding
791 log.showroot
792 merge.summary
793 merge.verbosity
794 pack.window
795 pull.octopus
796 pull.twohead
797 repack.useDeltaBaseOffset
798 show.difftree
799 showbranch.default
800 tar.umask
801 transfer.unpackLimit
802 receive.unpackLimit
803 receive.denyNonFastForwards
804 user.name
805 user.email
806 user.signingkey
807 whatchanged.difftree
808 branch. remote.
812 _git_reset ()
814 local cur="${COMP_WORDS[COMP_CWORD]}"
815 case "$cur" in
816 --*)
817 __gitcomp "--mixed --hard --soft"
818 return
820 esac
821 __gitcomp "$(__git_refs)"
824 _git_show ()
826 local cur="${COMP_WORDS[COMP_CWORD]}"
827 case "$cur" in
828 --pretty=*)
829 __gitcomp "
830 oneline short medium full fuller email raw
831 " "" "${cur##--pretty=}"
832 return
834 --*)
835 __gitcomp "--pretty="
836 return
838 esac
839 __git_complete_file
842 _git ()
844 local i c=1 command __git_dir
846 while [ $c -lt $COMP_CWORD ]; do
847 i="${COMP_WORDS[c]}"
848 case "$i" in
849 --git-dir=*) __git_dir="${i#--git-dir=}" ;;
850 --bare) __git_dir="." ;;
851 --version|--help|-p|--paginate) ;;
852 *) command="$i"; break ;;
853 esac
854 c=$((++c))
855 done
857 if [ $c -eq $COMP_CWORD -a -z "$command" ]; then
858 case "${COMP_WORDS[COMP_CWORD]}" in
859 --*=*) COMPREPLY=() ;;
860 --*) __gitcomp "--git-dir= --bare --version --exec-path" ;;
861 *) __gitcomp "$(__git_commands) $(__git_aliases)" ;;
862 esac
863 return
866 local expansion=$(__git_aliased_command "$command")
867 [ "$expansion" ] && command="$expansion"
869 case "$command" in
870 am) _git_am ;;
871 add) _git_add ;;
872 apply) _git_apply ;;
873 branch) _git_branch ;;
874 checkout) _git_checkout ;;
875 cherry) _git_cherry ;;
876 cherry-pick) _git_cherry_pick ;;
877 commit) _git_commit ;;
878 config) _git_config ;;
879 diff) _git_diff ;;
880 diff-tree) _git_diff_tree ;;
881 fetch) _git_fetch ;;
882 format-patch) _git_format_patch ;;
883 log) _git_log ;;
884 ls-remote) _git_ls_remote ;;
885 ls-tree) _git_ls_tree ;;
886 merge) _git_merge;;
887 merge-base) _git_merge_base ;;
888 name-rev) _git_name_rev ;;
889 pull) _git_pull ;;
890 push) _git_push ;;
891 rebase) _git_rebase ;;
892 reset) _git_reset ;;
893 show) _git_show ;;
894 show-branch) _git_log ;;
895 whatchanged) _git_log ;;
896 *) COMPREPLY=() ;;
897 esac
900 _gitk ()
902 local cur="${COMP_WORDS[COMP_CWORD]}"
903 case "$cur" in
904 --*)
905 __gitcomp "--not --all"
906 return
908 esac
909 __git_complete_revlist
912 complete -o default -o nospace -F _git git
913 complete -o default -o nospace -F _gitk gitk
914 complete -o default -o nospace -F _git_am git-am
915 complete -o default -o nospace -F _git_apply git-apply
916 complete -o default -o nospace -F _git_branch git-branch
917 complete -o default -o nospace -F _git_checkout git-checkout
918 complete -o default -o nospace -F _git_cherry git-cherry
919 complete -o default -o nospace -F _git_cherry_pick git-cherry-pick
920 complete -o default -o nospace -F _git_commit git-commit
921 complete -o default -o nospace -F _git_diff git-diff
922 complete -o default -o nospace -F _git_diff_tree git-diff-tree
923 complete -o default -o nospace -F _git_fetch git-fetch
924 complete -o default -o nospace -F _git_format_patch git-format-patch
925 complete -o default -o nospace -F _git_log git-log
926 complete -o default -o nospace -F _git_ls_remote git-ls-remote
927 complete -o default -o nospace -F _git_ls_tree git-ls-tree
928 complete -o default -o nospace -F _git_merge git-merge
929 complete -o default -o nospace -F _git_merge_base git-merge-base
930 complete -o default -o nospace -F _git_name_rev git-name-rev
931 complete -o default -o nospace -F _git_pull git-pull
932 complete -o default -o nospace -F _git_push git-push
933 complete -o default -o nospace -F _git_rebase git-rebase
934 complete -o default -o nospace -F _git_config git-config
935 complete -o default -o nospace -F _git_reset git-reset
936 complete -o default -o nospace -F _git_show git-show
937 complete -o default -o nospace -F _git_log git-show-branch
938 complete -o default -o nospace -F _git_log git-whatchanged
940 # The following are necessary only for Cygwin, and only are needed
941 # when the user has tab-completed the executable name and consequently
942 # included the '.exe' suffix.
944 if [ Cygwin = "$(uname -o 2>/dev/null)" ]; then
945 complete -o default -o nospace -F _git_add git-add.exe
946 complete -o default -o nospace -F _git_apply git-apply.exe
947 complete -o default -o nospace -F _git git.exe
948 complete -o default -o nospace -F _git_branch git-branch.exe
949 complete -o default -o nospace -F _git_cherry git-cherry.exe
950 complete -o default -o nospace -F _git_diff git-diff.exe
951 complete -o default -o nospace -F _git_diff_tree git-diff-tree.exe
952 complete -o default -o nospace -F _git_format_patch git-format-patch.exe
953 complete -o default -o nospace -F _git_log git-log.exe
954 complete -o default -o nospace -F _git_ls_tree git-ls-tree.exe
955 complete -o default -o nospace -F _git_merge_base git-merge-base.exe
956 complete -o default -o nospace -F _git_name_rev git-name-rev.exe
957 complete -o default -o nospace -F _git_push git-push.exe
958 complete -o default -o nospace -F _git_config git-config
959 complete -o default -o nospace -F _git_show git-show.exe
960 complete -o default -o nospace -F _git_log git-show-branch.exe
961 complete -o default -o nospace -F _git_log git-whatchanged.exe