Git 1.8.1-rc2
[git/git.git] / contrib / completion / git-completion.bash
CommitLineData
a42577d4 1#!bash
690d8824 2#
b5a49471 3# bash/zsh completion support for core Git.
690d8824 4#
c70680ce 5# Copyright (C) 2006,2007 Shawn O. Pearce <spearce@spearce.org>
690d8824 6# Conceptually based on gitcompletion (http://gitweb.hawaga.org.uk/).
c70680ce 7# Distributed under the GNU General Public License, version 2.0.
690d8824
JH
8#
9# The contained completion routines provide support for completing:
10#
11# *) local and remote branch names
12# *) local and remote tag names
13# *) .git/remotes file names
14# *) git 'subcommands'
15# *) tree paths within 'ref:path/to/file' expressions
c70680ce 16# *) common --long-options
690d8824
JH
17#
18# To use these routines:
19#
20# 1) Copy this file to somewhere (e.g. ~/.git-completion.sh).
b5a49471 21# 2) Add the following line to your .bashrc/.zshrc:
06f44c3c 22# source ~/.git-completion.sh
af31a456
FC
23# 3) Consider changing your PS1 to also show the current branch,
24# see git-prompt.sh for details.
690d8824 25
db8a9ff0
SP
26case "$COMP_WORDBREAKS" in
27*:*) : great ;;
28*) COMP_WORDBREAKS="$COMP_WORDBREAKS:"
29esac
30
a42577d4
TP
31# __gitdir accepts 0 or 1 arguments (i.e., location)
32# returns location of .git repo
873537fa
SP
33__gitdir ()
34{
ac3eb1c3
JH
35 # Note: this function is duplicated in git-prompt.sh
36 # When updating it, make sure you update the other one to match.
25a31f81 37 if [ -z "${1-}" ]; then
5c9cc64a 38 if [ -n "${__git_dir-}" ]; then
67ffa114 39 echo "$__git_dir"
b7be4366
SG
40 elif [ -n "${GIT_DIR-}" ]; then
41 test -d "${GIT_DIR-}" || return 1
42 echo "$GIT_DIR"
67ffa114
SP
43 elif [ -d .git ]; then
44 echo .git
45 else
46 git rev-parse --git-dir 2>/dev/null
47 fi
48 elif [ -d "$1/.git" ]; then
49 echo "$1/.git"
50 else
51 echo "$1"
52 fi
873537fa
SP
53}
54
ab02dfe5
SP
55__gitcomp_1 ()
56{
3bf421ea 57 local c IFS=$' \t\n'
ab02dfe5 58 for c in $1; do
3bf421ea
FC
59 c="$c$2"
60 case $c in
61 --*=*|*.) ;;
62 *) c="$c " ;;
ab02dfe5 63 esac
3bf421ea 64 printf '%s\n' "$c"
ab02dfe5
SP
65 done
66}
67
dbda3b10
JN
68# The following function is based on code from:
69#
70# bash_completion - programmable completion functions for bash 3.2+
71#
72# Copyright © 2006-2008, Ian Macdonald <ian@caliban.org>
73# © 2009-2010, Bash Completion Maintainers
74# <bash-completion-devel@lists.alioth.debian.org>
75#
76# This program is free software; you can redistribute it and/or modify
77# it under the terms of the GNU General Public License as published by
78# the Free Software Foundation; either version 2, or (at your option)
79# any later version.
80#
81# This program is distributed in the hope that it will be useful,
82# but WITHOUT ANY WARRANTY; without even the implied warranty of
83# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
84# GNU General Public License for more details.
85#
86# You should have received a copy of the GNU General Public License
87# along with this program; if not, write to the Free Software Foundation,
88# Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
89#
90# The latest version of this software can be obtained here:
91#
92# http://bash-completion.alioth.debian.org/
93#
94# RELEASE: 2.x
95
96# This function can be used to access a tokenized list of words
97# on the command line:
98#
99# __git_reassemble_comp_words_by_ref '=:'
100# if test "${words_[cword_-1]}" = -w
101# then
102# ...
103# fi
104#
105# The argument should be a collection of characters from the list of
106# word completion separators (COMP_WORDBREAKS) to treat as ordinary
107# characters.
108#
109# This is roughly equivalent to going back in time and setting
110# COMP_WORDBREAKS to exclude those characters. The intent is to
111# make option types like --date=<type> and <rev>:<path> easy to
112# recognize by treating each shell word as a single token.
113#
114# It is best not to set COMP_WORDBREAKS directly because the value is
115# shared with other completion scripts. By the time the completion
116# function gets called, COMP_WORDS has already been populated so local
117# changes to COMP_WORDBREAKS have no effect.
118#
119# Output: words_, cword_, cur_.
120
121__git_reassemble_comp_words_by_ref()
122{
123 local exclude i j first
124 # Which word separators to exclude?
125 exclude="${1//[^$COMP_WORDBREAKS]}"
126 cword_=$COMP_CWORD
127 if [ -z "$exclude" ]; then
128 words_=("${COMP_WORDS[@]}")
129 return
130 fi
131 # List of word completion separators has shrunk;
132 # re-assemble words to complete.
133 for ((i=0, j=0; i < ${#COMP_WORDS[@]}; i++, j++)); do
134 # Append each nonempty word consisting of just
135 # word separator characters to the current word.
136 first=t
137 while
138 [ $i -gt 0 ] &&
139 [ -n "${COMP_WORDS[$i]}" ] &&
140 # word consists of excluded word separators
141 [ "${COMP_WORDS[$i]//[^$exclude]}" = "${COMP_WORDS[$i]}" ]
142 do
143 # Attach to the previous token,
144 # unless the previous token is the command name.
145 if [ $j -ge 2 ] && [ -n "$first" ]; then
146 ((j--))
147 fi
148 first=
149 words_[$j]=${words_[j]}${COMP_WORDS[i]}
150 if [ $i = $COMP_CWORD ]; then
151 cword_=$j
152 fi
153 if (($i < ${#COMP_WORDS[@]} - 1)); then
154 ((i++))
155 else
156 # Done.
157 return
158 fi
159 done
160 words_[$j]=${words_[j]}${COMP_WORDS[i]}
161 if [ $i = $COMP_CWORD ]; then
162 cword_=$j
163 fi
164 done
165}
166
da48616f
PD
167if ! type _get_comp_words_by_ref >/dev/null 2>&1; then
168_get_comp_words_by_ref ()
169{
dbda3b10
JN
170 local exclude cur_ words_ cword_
171 if [ "$1" = "-n" ]; then
172 exclude=$2
173 shift 2
174 fi
175 __git_reassemble_comp_words_by_ref "$exclude"
176 cur_=${words_[cword_]}
da48616f
PD
177 while [ $# -gt 0 ]; do
178 case "$1" in
179 cur)
dbda3b10 180 cur=$cur_
da48616f
PD
181 ;;
182 prev)
dbda3b10 183 prev=${words_[$cword_-1]}
da48616f
PD
184 ;;
185 words)
dbda3b10 186 words=("${words_[@]}")
da48616f
PD
187 ;;
188 cword)
dbda3b10 189 cword=$cword_
da48616f
PD
190 ;;
191 esac
192 shift
193 done
194}
195fi
196
f674bb80
SG
197# Generates completion reply with compgen, appending a space to possible
198# completion words, if necessary.
199# It accepts 1 to 4 arguments:
200# 1: List of possible completion words.
201# 2: A prefix to be added to each possible completion word (optional).
202# 3: Generate possible completion matches for this word (optional).
203# 4: A suffix to be appended to each possible completion word (optional).
72e5e989
SP
204__gitcomp ()
205{
583e4d57 206 local cur_="${3-$cur}"
9244d69b 207
9244d69b 208 case "$cur_" in
5447aac7
SG
209 --*=)
210 COMPREPLY=()
5447aac7
SG
211 ;;
212 *)
ab02dfe5 213 local IFS=$'\n'
25a31f81
TP
214 COMPREPLY=($(compgen -P "${2-}" \
215 -W "$(__gitcomp_1 "${1-}" "${4-}")" \
9244d69b 216 -- "$cur_"))
5447aac7
SG
217 ;;
218 esac
72e5e989
SP
219}
220
a31e6262
SG
221# Generates completion reply with compgen from newline-separated possible
222# completion words by appending a space to all of them.
223# It accepts 1 to 4 arguments:
224# 1: List of possible completion words, separated by a single newline.
225# 2: A prefix to be added to each possible completion word (optional).
226# 3: Generate possible completion matches for this word (optional).
227# 4: A suffix to be appended to each possible completion word instead of
228# the default space (optional). If specified but empty, nothing is
229# appended.
230__gitcomp_nl ()
231{
583e4d57 232 local IFS=$'\n'
666ca59a 233 COMPREPLY=($(compgen -P "${2-}" -S "${4- }" -W "$1" -- "${3-$cur}"))
a31e6262
SG
234}
235
5de40f59
SP
236__git_heads ()
237{
6486ca6d 238 local dir="$(__gitdir)"
5de40f59 239 if [ -d "$dir" ]; then
05e8b3d6
SG
240 git --git-dir="$dir" for-each-ref --format='%(refname:short)' \
241 refs/heads
5de40f59
SP
242 return
243 fi
5de40f59
SP
244}
245
88e21dc7
SP
246__git_tags ()
247{
6486ca6d 248 local dir="$(__gitdir)"
88e21dc7 249 if [ -d "$dir" ]; then
05e8b3d6
SG
250 git --git-dir="$dir" for-each-ref --format='%(refname:short)' \
251 refs/tags
88e21dc7
SP
252 return
253 fi
88e21dc7
SP
254}
255
34a6bbb5
KB
256# __git_refs accepts 0, 1 (to pass to __gitdir), or 2 arguments
257# presence of 2nd argument means use the guess heuristic employed
258# by checkout for tracking branches
690d8824
JH
259__git_refs ()
260{
d8c0453e 261 local i hash dir="$(__gitdir "${1-}")" track="${2-}"
da4902a7 262 local format refs
873537fa 263 if [ -d "$dir" ]; then
608efb87
SG
264 case "$cur" in
265 refs|refs/*)
266 format="refname"
267 refs="${cur%/*}"
34a6bbb5 268 track=""
608efb87
SG
269 ;;
270 *)
d23e7570
IWC
271 for i in HEAD FETCH_HEAD ORIG_HEAD MERGE_HEAD; do
272 if [ -e "$dir/$i" ]; then echo $i; fi
273 done
608efb87
SG
274 format="refname:short"
275 refs="refs/tags refs/heads refs/remotes"
276 ;;
277 esac
278 git --git-dir="$dir" for-each-ref --format="%($format)" \
279 $refs
34a6bbb5
KB
280 if [ -n "$track" ]; then
281 # employ the heuristic used by git checkout
282 # Try to find a remote branch that matches the completion word
283 # but only output if the branch name is unique
284 local ref entry
285 git --git-dir="$dir" for-each-ref --shell --format="ref=%(refname:short)" \
286 "refs/remotes/" | \
6f2dd720 287 while read -r entry; do
34a6bbb5
KB
288 eval "$entry"
289 ref="${ref#*/}"
290 if [[ "$ref" == "$cur"* ]]; then
291 echo "$ref"
292 fi
4db42b38 293 done | sort | uniq -u
34a6bbb5 294 fi
35e65ecc 295 return
690d8824 296 fi
fb772cca
SG
297 case "$cur" in
298 refs|refs/*)
299 git ls-remote "$dir" "$cur*" 2>/dev/null | \
6f2dd720 300 while read -r hash i; do
fb772cca
SG
301 case "$i" in
302 *^{}) ;;
303 *) echo "$i" ;;
304 esac
305 done
306 ;;
307 *)
308 git ls-remote "$dir" HEAD ORIG_HEAD 'refs/tags/*' 'refs/heads/*' 'refs/remotes/*' 2>/dev/null | \
6f2dd720 309 while read -r hash i; do
fb772cca
SG
310 case "$i" in
311 *^{}) ;;
312 refs/*) echo "${i#refs/*/}" ;;
313 *) echo "$i" ;;
314 esac
315 done
316 ;;
317 esac
690d8824
JH
318}
319
a42577d4 320# __git_refs2 requires 1 argument (to pass to __git_refs)
690d8824
JH
321__git_refs2 ()
322{
67ffa114
SP
323 local i
324 for i in $(__git_refs "$1"); do
325 echo "$i:$i"
690d8824
JH
326 done
327}
328
a42577d4 329# __git_refs_remotes requires 1 argument (to pass to ls-remote)
5de40f59
SP
330__git_refs_remotes ()
331{
48058f5d
SG
332 local i hash
333 git ls-remote "$1" 'refs/heads/*' 2>/dev/null | \
6f2dd720 334 while read -r hash i; do
48058f5d 335 echo "$i:refs/remotes/$1/${i#refs/heads/}"
5de40f59
SP
336 done
337}
338
690d8824
JH
339__git_remotes ()
340{
d79f81ad
FC
341 local i IFS=$'\n' d="$(__gitdir)"
342 test -d "$d/remotes" && ls -1 "$d/remotes"
518ef8f0
TZ
343 for i in $(git --git-dir="$d" config --get-regexp 'remote\..*\.url' 2>/dev/null); do
344 i="${i#remote.}"
345 echo "${i/.url*/}"
56fc25f2 346 done
690d8824
JH
347}
348
eaa4e6ee 349__git_list_merge_strategies ()
4ad91321 350{
25b3d4d6
JH
351 git merge -s help 2>&1 |
352 sed -n -e '/[Aa]vailable strategies are: /,/^$/{
353 s/\.$//
354 s/.*://
355 s/^[ ]*//
356 s/[ ]*$//
4ad91321 357 p
25b3d4d6 358 }'
4ad91321 359}
eaa4e6ee
JN
360
361__git_merge_strategies=
362# 'git merge -s help' (and thus detection of the merge strategy
363# list) fails, unfortunately, if run outside of any git working
364# tree. __git_merge_strategies is set to the empty string in
365# that case, and the detection will be repeated the next time it
366# is needed.
367__git_compute_merge_strategies ()
368{
cf0ff02a
FC
369 test -n "$__git_merge_strategies" ||
370 __git_merge_strategies=$(__git_list_merge_strategies)
eaa4e6ee 371}
4ad91321 372
1d66ec58 373__git_complete_revlist_file ()
690d8824 374{
da4902a7 375 local pfx ls ref cur_="$cur"
9244d69b 376 case "$cur_" in
1d66ec58
SG
377 *..?*:*)
378 return
379 ;;
690d8824 380 ?*:*)
9244d69b
SG
381 ref="${cur_%%:*}"
382 cur_="${cur_#*:}"
383 case "$cur_" in
690d8824 384 ?*/*)
9244d69b
SG
385 pfx="${cur_%/*}"
386 cur_="${cur_##*/}"
690d8824
JH
387 ls="$ref:$pfx"
388 pfx="$pfx/"
389 ;;
390 *)
391 ls="$ref"
392 ;;
80152b09 393 esac
db8a9ff0
SP
394
395 case "$COMP_WORDBREAKS" in
396 *:*) : great ;;
397 *) pfx="$ref:$pfx" ;;
398 esac
399
41e6229d 400 __gitcomp_nl "$(git --git-dir="$(__gitdir)" ls-tree "$ls" \
778306e4
SP
401 | sed '/^100... blob /{
402 s,^.* ,,
403 s,$, ,
404 }
405 /^120000 blob /{
406 s,^.* ,,
407 s,$, ,
408 }
690d8824
JH
409 /^040000 tree /{
410 s,^.* ,,
411 s,$,/,
412 }
413 s/^.* //')" \
41e6229d 414 "$pfx" "$cur_" ""
690d8824 415 ;;
f53352fb 416 *...*)
9244d69b
SG
417 pfx="${cur_%...*}..."
418 cur_="${cur_#*...}"
a31e6262 419 __gitcomp_nl "$(__git_refs)" "$pfx" "$cur_"
f53352fb
SP
420 ;;
421 *..*)
9244d69b
SG
422 pfx="${cur_%..*}.."
423 cur_="${cur_#*..}"
a31e6262 424 __gitcomp_nl "$(__git_refs)" "$pfx" "$cur_"
b3391775 425 ;;
f53352fb 426 *)
a31e6262 427 __gitcomp_nl "$(__git_refs)"
f53352fb
SP
428 ;;
429 esac
430}
431
1d66ec58
SG
432
433__git_complete_file ()
434{
435 __git_complete_revlist_file
436}
437
438__git_complete_revlist ()
439{
440 __git_complete_revlist_file
441}
442
52d5c3b5
JS
443__git_complete_remote_or_refspec ()
444{
9244d69b 445 local cur_="$cur" cmd="${words[1]}"
0a4e1472 446 local i c=2 remote="" pfx="" lhs=1 no_complete_refspec=0
f1c6ffe6 447 if [ "$cmd" = "remote" ]; then
6e8c755f 448 ((c++))
f1c6ffe6 449 fi
da48616f
PD
450 while [ $c -lt $cword ]; do
451 i="${words[c]}"
52d5c3b5 452 case "$i" in
e25e2b42
BG
453 --mirror) [ "$cmd" = "push" ] && no_complete_refspec=1 ;;
454 --all)
455 case "$cmd" in
456 push) no_complete_refspec=1 ;;
457 fetch)
458 COMPREPLY=()
459 return
460 ;;
461 *) ;;
462 esac
463 ;;
52d5c3b5
JS
464 -*) ;;
465 *) remote="$i"; break ;;
466 esac
6e8c755f 467 ((c++))
52d5c3b5
JS
468 done
469 if [ -z "$remote" ]; then
a31e6262 470 __gitcomp_nl "$(__git_remotes)"
52d5c3b5
JS
471 return
472 fi
0a4e1472
JS
473 if [ $no_complete_refspec = 1 ]; then
474 COMPREPLY=()
475 return
476 fi
52d5c3b5 477 [ "$remote" = "." ] && remote=
9244d69b 478 case "$cur_" in
52d5c3b5
JS
479 *:*)
480 case "$COMP_WORDBREAKS" in
481 *:*) : great ;;
9244d69b 482 *) pfx="${cur_%%:*}:" ;;
52d5c3b5 483 esac
9244d69b 484 cur_="${cur_#*:}"
52d5c3b5
JS
485 lhs=0
486 ;;
487 +*)
488 pfx="+"
9244d69b 489 cur_="${cur_#+}"
52d5c3b5
JS
490 ;;
491 esac
492 case "$cmd" in
493 fetch)
494 if [ $lhs = 1 ]; then
a31e6262 495 __gitcomp_nl "$(__git_refs2 "$remote")" "$pfx" "$cur_"
52d5c3b5 496 else
a31e6262 497 __gitcomp_nl "$(__git_refs)" "$pfx" "$cur_"
52d5c3b5
JS
498 fi
499 ;;
f1c6ffe6 500 pull|remote)
52d5c3b5 501 if [ $lhs = 1 ]; then
a31e6262 502 __gitcomp_nl "$(__git_refs "$remote")" "$pfx" "$cur_"
52d5c3b5 503 else
a31e6262 504 __gitcomp_nl "$(__git_refs)" "$pfx" "$cur_"
52d5c3b5
JS
505 fi
506 ;;
507 push)
508 if [ $lhs = 1 ]; then
a31e6262 509 __gitcomp_nl "$(__git_refs)" "$pfx" "$cur_"
52d5c3b5 510 else
a31e6262 511 __gitcomp_nl "$(__git_refs "$remote")" "$pfx" "$cur_"
52d5c3b5
JS
512 fi
513 ;;
514 esac
515}
516
3c7b480a
JS
517__git_complete_strategy ()
518{
eaa4e6ee 519 __git_compute_merge_strategies
da48616f 520 case "$prev" in
3c7b480a 521 -s|--strategy)
eaa4e6ee 522 __gitcomp "$__git_merge_strategies"
3c7b480a
JS
523 return 0
524 esac
3c7b480a
JS
525 case "$cur" in
526 --strategy=*)
eaa4e6ee 527 __gitcomp "$__git_merge_strategies" "" "${cur##--strategy=}"
3c7b480a
JS
528 return 0
529 ;;
530 esac
531 return 1
532}
533
eaa4e6ee 534__git_list_all_commands ()
f2bb9f88
SP
535{
536 local i IFS=" "$'\n'
427e586b 537 for i in $(git help -a|egrep '^ [a-zA-Z0-9]')
1eb7e2f8
LM
538 do
539 case $i in
540 *--*) : helper pattern;;
541 *) echo $i;;
542 esac
543 done
544}
1eb7e2f8 545
eaa4e6ee
JN
546__git_all_commands=
547__git_compute_all_commands ()
548{
cf0ff02a
FC
549 test -n "$__git_all_commands" ||
550 __git_all_commands=$(__git_list_all_commands)
eaa4e6ee
JN
551}
552
553__git_list_porcelain_commands ()
1eb7e2f8 554{
1eb7e2f8 555 local i IFS=" "$'\n'
eaa4e6ee 556 __git_compute_all_commands
585b96bd 557 for i in $__git_all_commands
f2bb9f88
SP
558 do
559 case $i in
718a087a 560 *--*) : helper pattern;;
a925c6f1
SP
561 applymbox) : ask gittus;;
562 applypatch) : ask gittus;;
563 archimport) : import;;
2e3a430a 564 cat-file) : plumbing;;
56d99c67 565 check-attr) : plumbing;;
f2bb9f88 566 check-ref-format) : plumbing;;
ff2549dc 567 checkout-index) : plumbing;;
f2bb9f88 568 commit-tree) : plumbing;;
ff2549dc 569 count-objects) : infrequent;;
1dad5c14
SG
570 credential-cache) : credentials helper;;
571 credential-store) : credentials helper;;
a925c6f1
SP
572 cvsexportcommit) : export;;
573 cvsimport) : import;;
f2bb9f88
SP
574 cvsserver) : daemon;;
575 daemon) : daemon;;
5cfb4fe5
SP
576 diff-files) : plumbing;;
577 diff-index) : plumbing;;
578 diff-tree) : plumbing;;
c6ec3b13 579 fast-import) : import;;
ff2549dc 580 fast-export) : export;;
a925c6f1 581 fsck-objects) : plumbing;;
f2bb9f88 582 fetch-pack) : plumbing;;
a925c6f1 583 fmt-merge-msg) : plumbing;;
56d99c67 584 for-each-ref) : plumbing;;
f2bb9f88
SP
585 hash-object) : plumbing;;
586 http-*) : transport;;
587 index-pack) : plumbing;;
a925c6f1 588 init-db) : deprecated;;
f2bb9f88 589 local-fetch) : plumbing;;
ff2549dc
PB
590 lost-found) : infrequent;;
591 ls-files) : plumbing;;
592 ls-remote) : plumbing;;
593 ls-tree) : plumbing;;
f2bb9f88
SP
594 mailinfo) : plumbing;;
595 mailsplit) : plumbing;;
596 merge-*) : plumbing;;
597 mktree) : plumbing;;
598 mktag) : plumbing;;
599 pack-objects) : plumbing;;
600 pack-redundant) : plumbing;;
601 pack-refs) : plumbing;;
602 parse-remote) : plumbing;;
603 patch-id) : plumbing;;
604 peek-remote) : plumbing;;
a925c6f1
SP
605 prune) : plumbing;;
606 prune-packed) : plumbing;;
607 quiltimport) : import;;
f2bb9f88
SP
608 read-tree) : plumbing;;
609 receive-pack) : plumbing;;
63d04a78 610 remote-*) : transport;;
5c66d0d4 611 repo-config) : deprecated;;
f2bb9f88
SP
612 rerere) : plumbing;;
613 rev-list) : plumbing;;
614 rev-parse) : plumbing;;
615 runstatus) : plumbing;;
616 sh-setup) : internal;;
617 shell) : daemon;;
ff2549dc 618 show-ref) : plumbing;;
f2bb9f88
SP
619 send-pack) : plumbing;;
620 show-index) : plumbing;;
621 ssh-*) : transport;;
622 stripspace) : plumbing;;
623 symbolic-ref) : plumbing;;
a925c6f1 624 tar-tree) : deprecated;;
f2bb9f88
SP
625 unpack-file) : plumbing;;
626 unpack-objects) : plumbing;;
a925c6f1 627 update-index) : plumbing;;
f2bb9f88
SP
628 update-ref) : plumbing;;
629 update-server-info) : daemon;;
630 upload-archive) : plumbing;;
631 upload-pack) : plumbing;;
632 write-tree) : plumbing;;
ff2549dc
PB
633 var) : infrequent;;
634 verify-pack) : infrequent;;
a925c6f1 635 verify-tag) : plumbing;;
f2bb9f88
SP
636 *) echo $i;;
637 esac
638 done
639}
eaa4e6ee
JN
640
641__git_porcelain_commands=
642__git_compute_porcelain_commands ()
643{
644 __git_compute_all_commands
cf0ff02a
FC
645 test -n "$__git_porcelain_commands" ||
646 __git_porcelain_commands=$(__git_list_porcelain_commands)
eaa4e6ee 647}
f2bb9f88 648
c3898111
SG
649__git_pretty_aliases ()
650{
651 local i IFS=$'\n'
652 for i in $(git --git-dir="$(__gitdir)" config --get-regexp "pretty\..*" 2>/dev/null); do
653 case "$i" in
654 pretty.*)
655 i="${i#pretty.}"
656 echo "${i/ */}"
657 ;;
658 esac
659 done
660}
661
367dce2a
DS
662__git_aliases ()
663{
56fc25f2 664 local i IFS=$'\n'
518ef8f0 665 for i in $(git --git-dir="$(__gitdir)" config --get-regexp "alias\..*" 2>/dev/null); do
e0d78059
SB
666 case "$i" in
667 alias.*)
668 i="${i#alias.}"
669 echo "${i/ */}"
670 ;;
671 esac
56fc25f2 672 done
367dce2a
DS
673}
674
a42577d4 675# __git_aliased_command requires 1 argument
367dce2a
DS
676__git_aliased_command ()
677{
873537fa 678 local word cmdline=$(git --git-dir="$(__gitdir)" \
e0d10e1c 679 config --get "alias.$1")
367dce2a 680 for word in $cmdline; do
c63437cb 681 case "$word" in
66729509
SG
682 \!gitk|gitk)
683 echo "gitk"
367dce2a 684 return
66729509 685 ;;
c63437cb
SG
686 \!*) : shell command alias ;;
687 -*) : option ;;
688 *=*) : setting env ;;
689 git) : git itself ;;
690 *)
691 echo "$word"
367dce2a 692 return
c63437cb 693 esac
367dce2a
DS
694 done
695}
696
918c03c2
SG
697# __git_find_on_cmdline requires 1 argument
698__git_find_on_cmdline ()
3ff1320d 699{
da4902a7 700 local word subcommand c=1
da48616f
PD
701 while [ $c -lt $cword ]; do
702 word="${words[c]}"
3ff1320d
SG
703 for subcommand in $1; do
704 if [ "$subcommand" = "$word" ]; then
705 echo "$subcommand"
706 return
707 fi
708 done
6e8c755f 709 ((c++))
3ff1320d
SG
710 done
711}
712
d773c631
SG
713__git_has_doubledash ()
714{
da4902a7 715 local c=1
da48616f
PD
716 while [ $c -lt $cword ]; do
717 if [ "--" = "${words[c]}" ]; then
d773c631
SG
718 return 0
719 fi
6e8c755f 720 ((c++))
d773c631
SG
721 done
722 return 1
723}
724
7950659d 725__git_whitespacelist="nowarn warn error error-all fix"
88329195
SP
726
727_git_am ()
728{
da4902a7 729 local dir="$(__gitdir)"
51ef1daa 730 if [ -d "$dir"/rebase-apply ]; then
85f6b439 731 __gitcomp "--skip --continue --resolved --abort"
88329195
SP
732 return
733 fi
734 case "$cur" in
735 --whitespace=*)
b3391775 736 __gitcomp "$__git_whitespacelist" "" "${cur##--whitespace=}"
88329195
SP
737 return
738 ;;
739 --*)
b3391775 740 __gitcomp "
43acdf24 741 --3way --committer-date-is-author-date --ignore-date
86c91f91 742 --ignore-whitespace --ignore-space-change
43acdf24 743 --interactive --keep --no-utf8 --signoff --utf8
af4e9e8c 744 --whitespace= --scissors
b3391775 745 "
88329195
SP
746 return
747 esac
748 COMPREPLY=()
749}
750
751_git_apply ()
752{
88329195
SP
753 case "$cur" in
754 --whitespace=*)
b3391775 755 __gitcomp "$__git_whitespacelist" "" "${cur##--whitespace=}"
88329195
SP
756 return
757 ;;
758 --*)
b3391775 759 __gitcomp "
88329195
SP
760 --stat --numstat --summary --check --index
761 --cached --index-info --reverse --reject --unidiff-zero
762 --apply --no-add --exclude=
86c91f91 763 --ignore-whitespace --ignore-space-change
88329195 764 --whitespace= --inaccurate-eof --verbose
b3391775 765 "
88329195
SP
766 return
767 esac
768 COMPREPLY=()
769}
770
8435b548
SP
771_git_add ()
772{
d773c631
SG
773 __git_has_doubledash && return
774
8435b548
SP
775 case "$cur" in
776 --*)
1d284cba
SG
777 __gitcomp "
778 --interactive --refresh --patch --update --dry-run
c9a114b5 779 --ignore-errors --intent-to-add
1d284cba 780 "
8435b548
SP
781 return
782 esac
783 COMPREPLY=()
784}
785
b3191ce2
LM
786_git_archive ()
787{
b3191ce2
LM
788 case "$cur" in
789 --format=*)
790 __gitcomp "$(git archive --list)" "" "${cur##--format=}"
791 return
792 ;;
793 --remote=*)
a31e6262 794 __gitcomp_nl "$(__git_remotes)" "" "${cur##--remote=}"
b3191ce2
LM
795 return
796 ;;
797 --*)
798 __gitcomp "
799 --format= --list --verbose
800 --prefix= --remote= --exec=
801 "
802 return
803 ;;
804 esac
805 __git_complete_file
806}
807
b2e69f62
SP
808_git_bisect ()
809{
d773c631
SG
810 __git_has_doubledash && return
811
bf11d461 812 local subcommands="start bad good skip reset visualize replay log run"
918c03c2 813 local subcommand="$(__git_find_on_cmdline "$subcommands")"
3ff1320d 814 if [ -z "$subcommand" ]; then
128191f5
SG
815 if [ -f "$(__gitdir)"/BISECT_START ]; then
816 __gitcomp "$subcommands"
817 else
818 __gitcomp "replay start"
819 fi
b2e69f62
SP
820 return
821 fi
822
3ff1320d 823 case "$subcommand" in
8205ff8e 824 bad|good|reset|skip|start)
a31e6262 825 __gitcomp_nl "$(__git_refs)"
b2e69f62
SP
826 ;;
827 *)
828 COMPREPLY=()
829 ;;
830 esac
831}
832
690d8824
JH
833_git_branch ()
834{
da4902a7 835 local i c=1 only_local_ref="n" has_r="n"
b9217642 836
da48616f
PD
837 while [ $c -lt $cword ]; do
838 i="${words[c]}"
b9217642
SG
839 case "$i" in
840 -d|-m) only_local_ref="y" ;;
841 -r) has_r="y" ;;
842 esac
6e8c755f 843 ((c++))
b9217642
SG
844 done
845
da48616f 846 case "$cur" in
ca45d0fa
MG
847 --set-upstream-to=*)
848 __gitcomp "$(__git_refs)" "" "${cur##--set-upstream-to=}"
849 ;;
3b376b0c
SG
850 --*)
851 __gitcomp "
852 --color --no-color --verbose --abbrev= --no-abbrev
50e61025 853 --track --no-track --contains --merged --no-merged
04308e9d
CMN
854 --set-upstream-to= --edit-description --list
855 --unset-upstream
3b376b0c
SG
856 "
857 ;;
b9217642
SG
858 *)
859 if [ $only_local_ref = "y" -a $has_r = "n" ]; then
a31e6262 860 __gitcomp_nl "$(__git_heads)"
b9217642 861 else
a31e6262 862 __gitcomp_nl "$(__git_refs)"
b9217642
SG
863 fi
864 ;;
3b376b0c 865 esac
690d8824
JH
866}
867
374a58c9
ML
868_git_bundle ()
869{
da48616f
PD
870 local cmd="${words[2]}"
871 case "$cword" in
8d8163f3 872 2)
374a58c9
ML
873 __gitcomp "create list-heads verify unbundle"
874 ;;
8d8163f3 875 3)
374a58c9
ML
876 # looking for a file
877 ;;
878 *)
879 case "$cmd" in
880 create)
881 __git_complete_revlist
882 ;;
883 esac
884 ;;
885 esac
886}
887
690d8824
JH
888_git_checkout ()
889{
c84bb14c
SG
890 __git_has_doubledash && return
891
e648f8b6
SG
892 case "$cur" in
893 --conflict=*)
894 __gitcomp "diff3 merge" "" "${cur##--conflict=}"
895 ;;
896 --*)
897 __gitcomp "
898 --quiet --ours --theirs --track --no-track --merge
86e8e7a5 899 --conflict= --orphan --patch
e648f8b6
SG
900 "
901 ;;
902 *)
34a6bbb5
KB
903 # check if --track, --no-track, or --no-guess was specified
904 # if so, disable DWIM mode
905 local flags="--track --no-track --no-guess" track=1
906 if [ -n "$(__git_find_on_cmdline "$flags")" ]; then
907 track=''
908 fi
a31e6262 909 __gitcomp_nl "$(__git_refs '' $track)"
e648f8b6
SG
910 ;;
911 esac
690d8824
JH
912}
913
d8a9fea5
SP
914_git_cherry ()
915{
916 __gitcomp "$(__git_refs)"
917}
918
1273231e
SP
919_git_cherry_pick ()
920{
1273231e
SP
921 case "$cur" in
922 --*)
b3391775 923 __gitcomp "--edit --no-commit"
1273231e
SP
924 ;;
925 *)
a31e6262 926 __gitcomp_nl "$(__git_refs)"
1273231e
SP
927 ;;
928 esac
929}
930
4181c7e8
LM
931_git_clean ()
932{
933 __git_has_doubledash && return
934
4181c7e8
LM
935 case "$cur" in
936 --*)
937 __gitcomp "--dry-run --quiet"
938 return
939 ;;
940 esac
941 COMPREPLY=()
942}
943
3eb11012
LM
944_git_clone ()
945{
3eb11012
LM
946 case "$cur" in
947 --*)
948 __gitcomp "
949 --local
950 --no-hardlinks
951 --shared
952 --reference
953 --quiet
954 --no-checkout
955 --bare
956 --mirror
957 --origin
958 --upload-pack
959 --template=
960 --depth
4047fecf
RT
961 --single-branch
962 --branch
3eb11012
LM
963 "
964 return
965 ;;
966 esac
967 COMPREPLY=()
968}
969
4548e855
SP
970_git_commit ()
971{
d773c631
SG
972 __git_has_doubledash && return
973
4548e855 974 case "$cur" in
9a424b27
SG
975 --cleanup=*)
976 __gitcomp "default strip verbatim whitespace
977 " "" "${cur##--cleanup=}"
978 return
979 ;;
77653abd
TM
980 --reuse-message=*|--reedit-message=*|\
981 --fixup=*|--squash=*)
a31e6262 982 __gitcomp_nl "$(__git_refs)" "" "${cur#*=}"
9a424b27
SG
983 return
984 ;;
985 --untracked-files=*)
986 __gitcomp "all no normal" "" "${cur##--untracked-files=}"
987 return
988 ;;
4548e855 989 --*)
b3391775 990 __gitcomp "
4548e855 991 --all --author= --signoff --verify --no-verify
7dd9ab0c
YB
992 --edit --no-edit
993 --amend --include --only --interactive
9a424b27
SG
994 --dry-run --reuse-message= --reedit-message=
995 --reset-author --file= --message= --template=
996 --cleanup= --untracked-files --untracked-files=
77653abd 997 --verbose --quiet --fixup= --squash=
b3391775 998 "
4548e855
SP
999 return
1000 esac
1001 COMPREPLY=()
1002}
1003
217926c0
SP
1004_git_describe ()
1005{
cbb504c9
TR
1006 case "$cur" in
1007 --*)
1008 __gitcomp "
1009 --all --tags --contains --abbrev= --candidates=
1010 --exact-match --debug --long --match --always
1011 "
1012 return
1013 esac
a31e6262 1014 __gitcomp_nl "$(__git_refs)"
217926c0
SP
1015}
1016
20bf7292 1017__git_diff_common_options="--stat --numstat --shortstat --summary
b3a4f858
JS
1018 --patch-with-stat --name-only --name-status --color
1019 --no-color --color-words --no-renames --check
f135aacb 1020 --full-index --binary --abbrev --diff-filter=
47d5a8fa 1021 --find-copies-harder
b3a4f858
JS
1022 --text --ignore-space-at-eol --ignore-space-change
1023 --ignore-all-space --exit-code --quiet --ext-diff
aba201c6
PO
1024 --no-ext-diff
1025 --no-prefix --src-prefix= --dst-prefix=
6d0e674a 1026 --inter-hunk-context=
cc545709 1027 --patience
20bf7292 1028 --raw
8fd2cfa7
SB
1029 --dirstat --dirstat= --dirstat-by-file
1030 --dirstat-by-file= --cumulative
20bf7292
TR
1031"
1032
1033_git_diff ()
1034{
1035 __git_has_doubledash && return
1036
20bf7292
TR
1037 case "$cur" in
1038 --*)
ebd15bf0 1039 __gitcomp "--cached --staged --pickaxe-all --pickaxe-regex
861514d3 1040 --base --ours --theirs --no-index
20bf7292 1041 $__git_diff_common_options
aba201c6 1042 "
b3a4f858
JS
1043 return
1044 ;;
1045 esac
1d66ec58 1046 __git_complete_revlist_file
690d8824
JH
1047}
1048
e2dc2de9 1049__git_mergetools_common="diffuse ecmerge emerge kdiff3 meld opendiff
755e8b3f 1050 tkdiff vimdiff gvimdiff xxdiff araxis p4merge bc3 codecompare
e2dc2de9
DA
1051"
1052
1053_git_difftool ()
1054{
f7ad96cf
MH
1055 __git_has_doubledash && return
1056
e2dc2de9
DA
1057 case "$cur" in
1058 --tool=*)
1059 __gitcomp "$__git_mergetools_common kompare" "" "${cur##--tool=}"
1060 return
1061 ;;
1062 --*)
f7ad96cf
MH
1063 __gitcomp "--cached --staged --pickaxe-all --pickaxe-regex
1064 --base --ours --theirs
1065 --no-renames --diff-filter= --find-copies-harder
1066 --relative --ignore-submodules
1067 --tool="
e2dc2de9
DA
1068 return
1069 ;;
1070 esac
f7ad96cf 1071 __git_complete_file
e2dc2de9
DA
1072}
1073
0a4e1472
JS
1074__git_fetch_options="
1075 --quiet --verbose --append --upload-pack --force --keep --depth=
e25e2b42 1076 --tags --no-tags --all --prune --dry-run
0a4e1472
JS
1077"
1078
690d8824
JH
1079_git_fetch ()
1080{
0a4e1472
JS
1081 case "$cur" in
1082 --*)
1083 __gitcomp "$__git_fetch_options"
1084 return
1085 ;;
1086 esac
52d5c3b5 1087 __git_complete_remote_or_refspec
690d8824
JH
1088}
1089
2f65494d
FC
1090__git_format_patch_options="
1091 --stdout --attach --no-attach --thread --thread= --output-directory
1092 --numbered --start-number --numbered-files --keep-subject --signoff
1093 --signature --no-signature --in-reply-to= --cc= --full-index --binary
1094 --not --all --cover-letter --no-prefix --src-prefix= --dst-prefix=
1095 --inline --suffix= --ignore-if-in-upstream --subject-prefix=
1096"
1097
f53352fb
SP
1098_git_format_patch ()
1099{
f53352fb 1100 case "$cur" in
e1d37937
SB
1101 --thread=*)
1102 __gitcomp "
1103 deep shallow
1104 " "" "${cur##--thread=}"
1105 return
1106 ;;
f53352fb 1107 --*)
2f65494d 1108 __gitcomp "$__git_format_patch_options"
f53352fb
SP
1109 return
1110 ;;
1111 esac
1112 __git_complete_revlist
1113}
1114
4bca8636
AJ
1115_git_fsck ()
1116{
4bca8636
AJ
1117 case "$cur" in
1118 --*)
1119 __gitcomp "
1120 --tags --root --unreachable --cache --no-reflogs --full
1121 --strict --verbose --lost-found
1122 "
1123 return
1124 ;;
1125 esac
1126 COMPREPLY=()
1127}
1128
b26c8748
SP
1129_git_gc ()
1130{
b26c8748
SP
1131 case "$cur" in
1132 --*)
47e98eec 1133 __gitcomp "--prune --aggressive"
b26c8748
SP
1134 return
1135 ;;
1136 esac
1137 COMPREPLY=()
1138}
1139
66729509
SG
1140_git_gitk ()
1141{
1142 _gitk
1143}
1144
29eec71f
JK
1145__git_match_ctag() {
1146 awk "/^${1////\\/}/ { print \$1 }" "$2"
1147}
1148
c72e0db1
LM
1149_git_grep ()
1150{
1151 __git_has_doubledash && return
1152
c72e0db1
LM
1153 case "$cur" in
1154 --*)
1155 __gitcomp "
1156 --cached
1157 --text --ignore-case --word-regexp --invert-match
5a69eaf5 1158 --full-name --line-number
c72e0db1 1159 --extended-regexp --basic-regexp --fixed-strings
63e7e9d8 1160 --perl-regexp
c72e0db1
LM
1161 --files-with-matches --name-only
1162 --files-without-match
a91f453f 1163 --max-depth
c72e0db1
LM
1164 --count
1165 --and --or --not --all-match
1166 "
1167 return
1168 ;;
1169 esac
17225c49 1170
29eec71f
JK
1171 case "$cword,$prev" in
1172 2,*|*,-*)
1173 if test -r tags; then
d2c78075 1174 __gitcomp_nl "$(__git_match_ctag "$cur" tags)"
29eec71f
JK
1175 return
1176 fi
1177 ;;
1178 esac
1179
a31e6262 1180 __gitcomp_nl "$(__git_refs)"
c72e0db1
LM
1181}
1182
1eb7e2f8
LM
1183_git_help ()
1184{
1eb7e2f8
LM
1185 case "$cur" in
1186 --*)
1187 __gitcomp "--all --info --man --web"
1188 return
1189 ;;
1190 esac
eaa4e6ee 1191 __git_compute_all_commands
f85a6f0b 1192 __gitcomp "$__git_all_commands $(__git_aliases)
2946cccf
MG
1193 attributes cli core-tutorial cvs-migration
1194 diffcore gitk glossary hooks ignore modules
d49483f0 1195 namespaces repository-layout tutorial tutorial-2
99f0b599 1196 workflows
2946cccf 1197 "
1eb7e2f8
LM
1198}
1199
5dad868b
LM
1200_git_init ()
1201{
5dad868b
LM
1202 case "$cur" in
1203 --shared=*)
1204 __gitcomp "
1205 false true umask group all world everybody
1206 " "" "${cur##--shared=}"
1207 return
1208 ;;
1209 --*)
1210 __gitcomp "--quiet --bare --template= --shared --shared="
1211 return
1212 ;;
1213 esac
1214 COMPREPLY=()
1215}
1216
b1bc1494
LM
1217_git_ls_files ()
1218{
1219 __git_has_doubledash && return
1220
b1bc1494
LM
1221 case "$cur" in
1222 --*)
1223 __gitcomp "--cached --deleted --modified --others --ignored
1224 --stage --directory --no-empty-directory --unmerged
1225 --killed --exclude= --exclude-from=
1226 --exclude-per-directory= --exclude-standard
1227 --error-unmatch --with-tree= --full-name
1228 --abbrev --ignored --exclude-per-directory
1229 "
1230 return
1231 ;;
1232 esac
1233 COMPREPLY=()
1234}
1235
690d8824
JH
1236_git_ls_remote ()
1237{
a31e6262 1238 __gitcomp_nl "$(__git_remotes)"
690d8824
JH
1239}
1240
1241_git_ls_tree ()
1242{
1243 __git_complete_file
1244}
1245
a393777e
TR
1246# Options that go well for log, shortlog and gitk
1247__git_log_common_options="
1248 --not --all
1249 --branches --tags --remotes
4fe1a619 1250 --first-parent --merges --no-merges
a393777e
TR
1251 --max-count=
1252 --max-age= --since= --after=
1253 --min-age= --until= --before=
6a6ebded
MG
1254 --min-parents= --max-parents=
1255 --no-min-parents --no-max-parents
a393777e
TR
1256"
1257# Options that go well for log and gitk (not shortlog)
1258__git_log_gitk_options="
1259 --dense --sparse --full-history
1260 --simplify-merges --simplify-by-decoration
3925b575 1261 --left-right --notes --no-notes
a393777e
TR
1262"
1263# Options that go well for log and shortlog (not gitk)
1264__git_log_shortlog_options="
1265 --author= --committer= --grep=
1266 --all-match
1267"
1268
3d279863 1269__git_log_pretty_formats="oneline short medium full fuller email raw format:"
672c68cb 1270__git_log_date_formats="relative iso8601 rfc2822 short local default raw"
3d279863 1271
690d8824
JH
1272_git_log ()
1273{
d773c631
SG
1274 __git_has_doubledash && return
1275
bf3c20f6
TR
1276 local g="$(git rev-parse --git-dir 2>/dev/null)"
1277 local merge=""
ba7906f2 1278 if [ -f "$g/MERGE_HEAD" ]; then
bf3c20f6
TR
1279 merge="--merge"
1280 fi
6e31b866 1281 case "$cur" in
e67d71e5 1282 --pretty=*|--format=*)
c3898111 1283 __gitcomp "$__git_log_pretty_formats $(__git_pretty_aliases)
e67d71e5 1284 " "" "${cur#*=}"
72de29c2
TL
1285 return
1286 ;;
47e98eec 1287 --date=*)
672c68cb 1288 __gitcomp "$__git_log_date_formats" "" "${cur##--date=}"
47e98eec
SP
1289 return
1290 ;;
af4e9e8c
SB
1291 --decorate=*)
1292 __gitcomp "long short" "" "${cur##--decorate=}"
1293 return
1294 ;;
6e31b866 1295 --*)
b3391775 1296 __gitcomp "
a393777e
TR
1297 $__git_log_common_options
1298 $__git_log_shortlog_options
1299 $__git_log_gitk_options
8f87fae6 1300 --root --topo-order --date-order --reverse
5d0e6343 1301 --follow --full-diff
6e31b866 1302 --abbrev-commit --abbrev=
47e98eec 1303 --relative-date --date=
72de29c2 1304 --pretty= --format= --oneline
a393777e 1305 --cherry-pick
20827d99 1306 --graph
af4e9e8c 1307 --decorate --decorate=
20bf7292 1308 --walk-reflogs
a393777e 1309 --parents --children
bf3c20f6 1310 $merge
20bf7292 1311 $__git_diff_common_options
47d5a8fa 1312 --pickaxe-all --pickaxe-regex
b3391775 1313 "
6e31b866
SP
1314 return
1315 ;;
1316 esac
f53352fb 1317 __git_complete_revlist
690d8824
JH
1318}
1319
0a4e1472
JS
1320__git_merge_options="
1321 --no-commit --no-stat --log --no-log --squash --strategy
2ff14e31 1322 --commit --stat --no-squash --ff --no-ff --ff-only --edit --no-edit
0a4e1472
JS
1323"
1324
4ad91321
SP
1325_git_merge ()
1326{
3c7b480a
JS
1327 __git_complete_strategy && return
1328
4ad91321
SP
1329 case "$cur" in
1330 --*)
0a4e1472 1331 __gitcomp "$__git_merge_options"
4ad91321
SP
1332 return
1333 esac
a31e6262 1334 __gitcomp_nl "$(__git_refs)"
4ad91321
SP
1335}
1336
b4c72162
LM
1337_git_mergetool ()
1338{
b4c72162
LM
1339 case "$cur" in
1340 --tool=*)
e2dc2de9 1341 __gitcomp "$__git_mergetools_common tortoisemerge" "" "${cur##--tool=}"
b4c72162
LM
1342 return
1343 ;;
1344 --*)
1345 __gitcomp "--tool="
1346 return
1347 ;;
1348 esac
1349 COMPREPLY=()
1350}
1351
690d8824
JH
1352_git_merge_base ()
1353{
a31e6262 1354 __gitcomp_nl "$(__git_refs)"
690d8824
JH
1355}
1356
1127c51c
LM
1357_git_mv ()
1358{
1127c51c
LM
1359 case "$cur" in
1360 --*)
1361 __gitcomp "--dry-run"
1362 return
1363 ;;
1364 esac
1365 COMPREPLY=()
1366}
1367
d33909bf
SP
1368_git_name_rev ()
1369{
b3391775 1370 __gitcomp "--tags --all --stdin"
d33909bf
SP
1371}
1372
00f09d0e
SG
1373_git_notes ()
1374{
2a5da755
SG
1375 local subcommands='add append copy edit list prune remove show'
1376 local subcommand="$(__git_find_on_cmdline "$subcommands")"
00f09d0e 1377
2a5da755
SG
1378 case "$subcommand,$cur" in
1379 ,--*)
1380 __gitcomp '--ref'
1381 ;;
1382 ,*)
39540681 1383 case "$prev" in
2a5da755 1384 --ref)
a31e6262 1385 __gitcomp_nl "$(__git_refs)"
2a5da755
SG
1386 ;;
1387 *)
1388 __gitcomp "$subcommands --ref"
1389 ;;
1390 esac
1391 ;;
a8f89bfa 1392 add,--reuse-message=*|append,--reuse-message=*|\
2a5da755 1393 add,--reedit-message=*|append,--reedit-message=*)
a31e6262 1394 __gitcomp_nl "$(__git_refs)" "" "${cur#*=}"
2a5da755
SG
1395 ;;
1396 add,--*|append,--*)
1397 __gitcomp '--file= --message= --reedit-message=
1398 --reuse-message='
1399 ;;
1400 copy,--*)
1401 __gitcomp '--stdin'
1402 ;;
1403 prune,--*)
1404 __gitcomp '--dry-run --verbose'
1405 ;;
1406 prune,*)
00f09d0e
SG
1407 ;;
1408 *)
39540681 1409 case "$prev" in
2a5da755
SG
1410 -m|-F)
1411 ;;
1412 *)
a31e6262 1413 __gitcomp_nl "$(__git_refs)"
2a5da755
SG
1414 ;;
1415 esac
00f09d0e
SG
1416 ;;
1417 esac
1418}
1419
690d8824
JH
1420_git_pull ()
1421{
0a4e1472
JS
1422 __git_complete_strategy && return
1423
0a4e1472
JS
1424 case "$cur" in
1425 --*)
1426 __gitcomp "
1427 --rebase --no-rebase
1428 $__git_merge_options
1429 $__git_fetch_options
1430 "
1431 return
1432 ;;
1433 esac
52d5c3b5 1434 __git_complete_remote_or_refspec
690d8824
JH
1435}
1436
1437_git_push ()
1438{
da48616f 1439 case "$prev" in
0a4e1472 1440 --repo)
a31e6262 1441 __gitcomp_nl "$(__git_remotes)"
0a4e1472
JS
1442 return
1443 esac
1444 case "$cur" in
1445 --repo=*)
a31e6262 1446 __gitcomp_nl "$(__git_remotes)" "" "${cur##--repo=}"
0a4e1472
JS
1447 return
1448 ;;
1449 --*)
1450 __gitcomp "
1451 --all --mirror --tags --dry-run --force --verbose
3623dc03 1452 --receive-pack= --repo= --set-upstream
0a4e1472
JS
1453 "
1454 return
1455 ;;
1456 esac
52d5c3b5 1457 __git_complete_remote_or_refspec
690d8824
JH
1458}
1459
61d926a3
SP
1460_git_rebase ()
1461{
da48616f 1462 local dir="$(__gitdir)"
51ef1daa 1463 if [ -d "$dir"/rebase-apply ] || [ -d "$dir"/rebase-merge ]; then
b3391775 1464 __gitcomp "--continue --skip --abort"
61d926a3
SP
1465 return
1466 fi
3c7b480a 1467 __git_complete_strategy && return
61d926a3 1468 case "$cur" in
93cf50a4
BG
1469 --whitespace=*)
1470 __gitcomp "$__git_whitespacelist" "" "${cur##--whitespace=}"
1471 return
1472 ;;
61d926a3 1473 --*)
93cf50a4
BG
1474 __gitcomp "
1475 --onto --merge --strategy --interactive
1476 --preserve-merges --stat --no-stat
1477 --committer-date-is-author-date --ignore-date
1478 --ignore-whitespace --whitespace=
6d0d465e 1479 --autosquash
93cf50a4
BG
1480 "
1481
61d926a3
SP
1482 return
1483 esac
a31e6262 1484 __gitcomp_nl "$(__git_refs)"
61d926a3
SP
1485}
1486
057f3279
TRC
1487_git_reflog ()
1488{
1489 local subcommands="show delete expire"
1490 local subcommand="$(__git_find_on_cmdline "$subcommands")"
1491
1492 if [ -z "$subcommand" ]; then
1493 __gitcomp "$subcommands"
1494 else
a31e6262 1495 __gitcomp_nl "$(__git_refs)"
057f3279
TRC
1496 fi
1497}
1498
ae616de6 1499__git_send_email_confirm_options="always never auto cc compose"
cb8a9bd5 1500__git_send_email_suppresscc_options="author self cc bodycc sob cccmd body all"
ae616de6 1501
25a1f374
TL
1502_git_send_email ()
1503{
25a1f374 1504 case "$cur" in
ae616de6
SB
1505 --confirm=*)
1506 __gitcomp "
1507 $__git_send_email_confirm_options
1508 " "" "${cur##--confirm=}"
1509 return
1510 ;;
1511 --suppress-cc=*)
1512 __gitcomp "
1513 $__git_send_email_suppresscc_options
1514 " "" "${cur##--suppress-cc=}"
1515
1516 return
1517 ;;
1518 --smtp-encryption=*)
1519 __gitcomp "ssl tls" "" "${cur##--smtp-encryption=}"
1520 return
1521 ;;
2f65494d
FC
1522 --thread=*)
1523 __gitcomp "
1524 deep shallow
1525 " "" "${cur##--thread=}"
1526 return
1527 ;;
25a1f374 1528 --*)
77813151 1529 __gitcomp "--annotate --bcc --cc --cc-cmd --chain-reply-to
ae616de6
SB
1530 --compose --confirm= --dry-run --envelope-sender
1531 --from --identity
25a1f374
TL
1532 --in-reply-to --no-chain-reply-to --no-signed-off-by-cc
1533 --no-suppress-from --no-thread --quiet
1534 --signed-off-by-cc --smtp-pass --smtp-server
ae616de6
SB
1535 --smtp-server-port --smtp-encryption= --smtp-user
1536 --subject --suppress-cc= --suppress-from --thread --to
2f65494d
FC
1537 --validate --no-validate
1538 $__git_format_patch_options"
25a1f374
TL
1539 return
1540 ;;
1541 esac
2f65494d 1542 __git_complete_revlist
25a1f374
TL
1543}
1544
424cce83
SG
1545_git_stage ()
1546{
1547 _git_add
1548}
1549
00652369
SB
1550__git_config_get_set_variables ()
1551{
da48616f 1552 local prevword word config_file= c=$cword
00652369 1553 while [ $c -gt 1 ]; do
da48616f 1554 word="${words[c]}"
00652369
SB
1555 case "$word" in
1556 --global|--system|--file=*)
1557 config_file="$word"
1558 break
1559 ;;
1560 -f|--file)
1561 config_file="$word $prevword"
1562 break
1563 ;;
1564 esac
1565 prevword=$word
1566 c=$((--c))
1567 done
1568
f581de1b 1569 git --git-dir="$(__gitdir)" config $config_file --list 2>/dev/null |
6f2dd720 1570 while read -r line
f581de1b
SB
1571 do
1572 case "$line" in
1573 *.*=*)
1574 echo "${line/=*/}"
00652369
SB
1575 ;;
1576 esac
1577 done
1578}
1579
e0d10e1c 1580_git_config ()
5de40f59 1581{
da48616f 1582 case "$prev" in
5de40f59 1583 branch.*.remote)
a31e6262 1584 __gitcomp_nl "$(__git_remotes)"
5de40f59
SP
1585 return
1586 ;;
1587 branch.*.merge)
a31e6262 1588 __gitcomp_nl "$(__git_refs)"
5de40f59
SP
1589 return
1590 ;;
1591 remote.*.fetch)
da48616f 1592 local remote="${prev#remote.}"
5de40f59 1593 remote="${remote%.fetch}"
d51a8ecd
SG
1594 if [ -z "$cur" ]; then
1595 COMPREPLY=("refs/heads/")
1596 return
1597 fi
a31e6262 1598 __gitcomp_nl "$(__git_refs_remotes "$remote")"
5de40f59
SP
1599 return
1600 ;;
1601 remote.*.push)
da48616f 1602 local remote="${prev#remote.}"
5de40f59 1603 remote="${remote%.push}"
a31e6262 1604 __gitcomp_nl "$(git --git-dir="$(__gitdir)" \
5de40f59 1605 for-each-ref --format='%(refname):%(refname)' \
78d4d6a2
SP
1606 refs/heads)"
1607 return
1608 ;;
1609 pull.twohead|pull.octopus)
eaa4e6ee
JN
1610 __git_compute_merge_strategies
1611 __gitcomp "$__git_merge_strategies"
78d4d6a2
SP
1612 return
1613 ;;
6123d719
MH
1614 color.branch|color.diff|color.interactive|\
1615 color.showbranch|color.status|color.ui)
78d4d6a2
SP
1616 __gitcomp "always never auto"
1617 return
1618 ;;
901d615c
MK
1619 color.pager)
1620 __gitcomp "false true"
1621 return
1622 ;;
78d4d6a2
SP
1623 color.*.*)
1624 __gitcomp "
98171a07 1625 normal black red green yellow blue magenta cyan white
78d4d6a2
SP
1626 bold dim ul blink reverse
1627 "
5de40f59
SP
1628 return
1629 ;;
9b82d63b
SB
1630 help.format)
1631 __gitcomp "man info web html"
1632 return
1633 ;;
672c68cb
SB
1634 log.date)
1635 __gitcomp "$__git_log_date_formats"
1636 return
1637 ;;
ae616de6
SB
1638 sendemail.aliasesfiletype)
1639 __gitcomp "mutt mailrc pine elm gnus"
1640 return
1641 ;;
1642 sendemail.confirm)
1643 __gitcomp "$__git_send_email_confirm_options"
1644 return
1645 ;;
1646 sendemail.suppresscc)
1647 __gitcomp "$__git_send_email_suppresscc_options"
1648 return
1649 ;;
00652369 1650 --get|--get-all|--unset|--unset-all)
a31e6262 1651 __gitcomp_nl "$(__git_config_get_set_variables)"
00652369
SB
1652 return
1653 ;;
5de40f59
SP
1654 *.*)
1655 COMPREPLY=()
1656 return
1657 ;;
1658 esac
1659 case "$cur" in
1660 --*)
78d4d6a2 1661 __gitcomp "
47e98eec 1662 --global --system --file=
12977705 1663 --list --replace-all
5de40f59 1664 --get --get-all --get-regexp
1b71eb35 1665 --add --unset --unset-all
12977705 1666 --remove-section --rename-section
78d4d6a2 1667 "
5de40f59
SP
1668 return
1669 ;;
1670 branch.*.*)
9244d69b
SG
1671 local pfx="${cur%.*}." cur_="${cur##*.}"
1672 __gitcomp "remote merge mergeoptions rebase" "$pfx" "$cur_"
5de40f59
SP
1673 return
1674 ;;
1675 branch.*)
9244d69b 1676 local pfx="${cur%.*}." cur_="${cur#*.}"
a31e6262 1677 __gitcomp_nl "$(__git_heads)" "$pfx" "$cur_" "."
5de40f59
SP
1678 return
1679 ;;
0aa62fd0 1680 guitool.*.*)
9244d69b 1681 local pfx="${cur%.*}." cur_="${cur##*.}"
0aa62fd0
SB
1682 __gitcomp "
1683 argprompt cmd confirm needsfile noconsole norescan
1684 prompt revprompt revunmerged title
9244d69b 1685 " "$pfx" "$cur_"
0aa62fd0
SB
1686 return
1687 ;;
1688 difftool.*.*)
9244d69b
SG
1689 local pfx="${cur%.*}." cur_="${cur##*.}"
1690 __gitcomp "cmd path" "$pfx" "$cur_"
0aa62fd0
SB
1691 return
1692 ;;
1693 man.*.*)
9244d69b
SG
1694 local pfx="${cur%.*}." cur_="${cur##*.}"
1695 __gitcomp "cmd path" "$pfx" "$cur_"
0aa62fd0
SB
1696 return
1697 ;;
1698 mergetool.*.*)
9244d69b
SG
1699 local pfx="${cur%.*}." cur_="${cur##*.}"
1700 __gitcomp "cmd path trustExitCode" "$pfx" "$cur_"
0aa62fd0
SB
1701 return
1702 ;;
1703 pager.*)
9244d69b 1704 local pfx="${cur%.*}." cur_="${cur#*.}"
eaa4e6ee 1705 __git_compute_all_commands
a31e6262 1706 __gitcomp_nl "$__git_all_commands" "$pfx" "$cur_"
0aa62fd0
SB
1707 return
1708 ;;
5de40f59 1709 remote.*.*)
9244d69b 1710 local pfx="${cur%.*}." cur_="${cur##*.}"
12977705 1711 __gitcomp "
98171a07 1712 url proxy fetch push mirror skipDefaultUpdate
6fac1b83 1713 receivepack uploadpack tagopt pushurl
9244d69b 1714 " "$pfx" "$cur_"
5de40f59
SP
1715 return
1716 ;;
1717 remote.*)
9244d69b 1718 local pfx="${cur%.*}." cur_="${cur#*.}"
a31e6262 1719 __gitcomp_nl "$(__git_remotes)" "$pfx" "$cur_" "."
5de40f59
SP
1720 return
1721 ;;
0aa62fd0 1722 url.*.*)
9244d69b
SG
1723 local pfx="${cur%.*}." cur_="${cur##*.}"
1724 __gitcomp "insteadOf pushInsteadOf" "$pfx" "$cur_"
0aa62fd0
SB
1725 return
1726 ;;
5de40f59 1727 esac
78d4d6a2 1728 __gitcomp "
6068ac88
MZ
1729 add.ignoreErrors
1730 advice.commitBeforeMerge
1731 advice.detachedHead
1732 advice.implicitIdentity
1733 advice.pushNonFastForward
1734 advice.resolveConflict
1735 advice.statusHints
226b343c 1736 alias.
6068ac88 1737 am.keepcr
86c91f91 1738 apply.ignorewhitespace
5de40f59 1739 apply.whitespace
98171a07
LM
1740 branch.autosetupmerge
1741 branch.autosetuprebase
6068ac88 1742 browser.
2122591b 1743 clean.requireForce
78d4d6a2
SP
1744 color.branch
1745 color.branch.current
1746 color.branch.local
78d4d6a2 1747 color.branch.plain
025a1929 1748 color.branch.remote
6068ac88
MZ
1749 color.decorate.HEAD
1750 color.decorate.branch
1751 color.decorate.remoteBranch
1752 color.decorate.stash
1753 color.decorate.tag
a159ca0c 1754 color.diff
025a1929 1755 color.diff.commit
78d4d6a2 1756 color.diff.frag
6068ac88 1757 color.diff.func
025a1929 1758 color.diff.meta
78d4d6a2 1759 color.diff.new
025a1929
LM
1760 color.diff.old
1761 color.diff.plain
78d4d6a2 1762 color.diff.whitespace
226b343c 1763 color.grep
6068ac88
MZ
1764 color.grep.context
1765 color.grep.filename
1766 color.grep.function
1767 color.grep.linenumber
226b343c 1768 color.grep.match
6068ac88
MZ
1769 color.grep.selected
1770 color.grep.separator
98171a07 1771 color.interactive
6068ac88 1772 color.interactive.error
98171a07
LM
1773 color.interactive.header
1774 color.interactive.help
1775 color.interactive.prompt
a159ca0c 1776 color.pager
6123d719 1777 color.showbranch
a159ca0c 1778 color.status
78d4d6a2
SP
1779 color.status.added
1780 color.status.changed
025a1929 1781 color.status.header
98171a07 1782 color.status.nobranch
78d4d6a2 1783 color.status.untracked
98171a07
LM
1784 color.status.updated
1785 color.ui
6068ac88 1786 commit.status
98171a07 1787 commit.template
cdb791f6 1788 core.abbrev
6068ac88
MZ
1789 core.askpass
1790 core.attributesfile
98171a07
LM
1791 core.autocrlf
1792 core.bare
6068ac88 1793 core.bigFileThreshold
025a1929 1794 core.compression
226b343c 1795 core.createObject
98171a07
LM
1796 core.deltaBaseCacheLimit
1797 core.editor
6068ac88 1798 core.eol
98171a07 1799 core.excludesfile
025a1929 1800 core.fileMode
98171a07 1801 core.fsyncobjectfiles
025a1929 1802 core.gitProxy
98171a07 1803 core.ignoreCygwinFSTricks
025a1929 1804 core.ignoreStat
6068ac88 1805 core.ignorecase
025a1929
LM
1806 core.logAllRefUpdates
1807 core.loosecompression
6068ac88 1808 core.notesRef
025a1929
LM
1809 core.packedGitLimit
1810 core.packedGitWindowSize
98171a07 1811 core.pager
025a1929 1812 core.preferSymlinkRefs
98171a07
LM
1813 core.preloadindex
1814 core.quotepath
025a1929 1815 core.repositoryFormatVersion
98171a07 1816 core.safecrlf
025a1929 1817 core.sharedRepository
6068ac88 1818 core.sparseCheckout
98171a07
LM
1819 core.symlinks
1820 core.trustctime
025a1929 1821 core.warnAmbiguousRefs
98171a07
LM
1822 core.whitespace
1823 core.worktree
1824 diff.autorefreshindex
df44483a 1825 diff.statGraphWidth
98171a07 1826 diff.external
6068ac88 1827 diff.ignoreSubmodules
98171a07 1828 diff.mnemonicprefix
6068ac88 1829 diff.noprefix
78d4d6a2
SP
1830 diff.renameLimit
1831 diff.renames
226b343c
SB
1832 diff.suppressBlankEmpty
1833 diff.tool
1834 diff.wordRegex
0aa62fd0 1835 difftool.
226b343c 1836 difftool.prompt
6068ac88 1837 fetch.recurseSubmodules
78d4d6a2 1838 fetch.unpackLimit
226b343c
SB
1839 format.attach
1840 format.cc
78d4d6a2 1841 format.headers
98171a07
LM
1842 format.numbered
1843 format.pretty
d8e1e5df 1844 format.signature
226b343c
SB
1845 format.signoff
1846 format.subjectprefix
98171a07 1847 format.suffix
226b343c 1848 format.thread
6068ac88
MZ
1849 format.to
1850 gc.
98171a07
LM
1851 gc.aggressiveWindow
1852 gc.auto
1853 gc.autopacklimit
12977705 1854 gc.packrefs
98171a07 1855 gc.pruneexpire
78d4d6a2
SP
1856 gc.reflogexpire
1857 gc.reflogexpireunreachable
1858 gc.rerereresolved
1859 gc.rerereunresolved
025a1929 1860 gitcvs.allbinary
226b343c 1861 gitcvs.commitmsgannotation
98171a07 1862 gitcvs.dbTableNamePrefix
025a1929
LM
1863 gitcvs.dbdriver
1864 gitcvs.dbname
1865 gitcvs.dbpass
025a1929
LM
1866 gitcvs.dbuser
1867 gitcvs.enabled
1868 gitcvs.logfile
98171a07 1869 gitcvs.usecrlfattr
0aa62fd0 1870 guitool.
98171a07
LM
1871 gui.blamehistoryctx
1872 gui.commitmsgwidth
1873 gui.copyblamethreshold
1874 gui.diffcontext
1875 gui.encoding
1876 gui.fastcopyblame
1877 gui.matchtrackingbranch
1878 gui.newbranchtemplate
1879 gui.pruneduringfetch
1880 gui.spellingdictionary
1881 gui.trustmtime
1882 help.autocorrect
1883 help.browser
1884 help.format
78d4d6a2
SP
1885 http.lowSpeedLimit
1886 http.lowSpeedTime
025a1929 1887 http.maxRequests
6068ac88 1888 http.minSessions
5de40f59 1889 http.noEPSV
6068ac88 1890 http.postBuffer
98171a07 1891 http.proxy
025a1929
LM
1892 http.sslCAInfo
1893 http.sslCAPath
1894 http.sslCert
6068ac88 1895 http.sslCertPasswordProtected
025a1929
LM
1896 http.sslKey
1897 http.sslVerify
6068ac88 1898 http.useragent
78d4d6a2
SP
1899 i18n.commitEncoding
1900 i18n.logOutputEncoding
6068ac88 1901 imap.authMethod
226b343c
SB
1902 imap.folder
1903 imap.host
1904 imap.pass
1905 imap.port
1906 imap.preformattedHTML
1907 imap.sslverify
1908 imap.tunnel
1909 imap.user
6068ac88 1910 init.templatedir
98171a07
LM
1911 instaweb.browser
1912 instaweb.httpd
1913 instaweb.local
1914 instaweb.modulepath
1915 instaweb.port
226b343c 1916 interactive.singlekey
98171a07 1917 log.date
6068ac88 1918 log.decorate
78d4d6a2 1919 log.showroot
226b343c 1920 mailmap.file
0aa62fd0 1921 man.
98171a07 1922 man.viewer
6068ac88 1923 merge.
98171a07
LM
1924 merge.conflictstyle
1925 merge.log
1926 merge.renameLimit
6068ac88 1927 merge.renormalize
98171a07 1928 merge.stat
025a1929 1929 merge.tool
78d4d6a2 1930 merge.verbosity
0aa62fd0 1931 mergetool.
98171a07 1932 mergetool.keepBackup
6068ac88 1933 mergetool.keepTemporaries
226b343c 1934 mergetool.prompt
6068ac88
MZ
1935 notes.displayRef
1936 notes.rewrite.
1937 notes.rewrite.amend
1938 notes.rewrite.rebase
1939 notes.rewriteMode
1940 notes.rewriteRef
47e98eec 1941 pack.compression
47e98eec 1942 pack.deltaCacheLimit
025a1929
LM
1943 pack.deltaCacheSize
1944 pack.depth
98171a07
LM
1945 pack.indexVersion
1946 pack.packSizeLimit
1947 pack.threads
025a1929
LM
1948 pack.window
1949 pack.windowMemory
0aa62fd0 1950 pager.
6068ac88 1951 pretty.
78d4d6a2
SP
1952 pull.octopus
1953 pull.twohead
226b343c 1954 push.default
6068ac88 1955 rebase.autosquash
226b343c 1956 rebase.stat
6068ac88 1957 receive.autogc
98171a07 1958 receive.denyCurrentBranch
6068ac88 1959 receive.denyDeleteCurrent
98171a07 1960 receive.denyDeletes
025a1929 1961 receive.denyNonFastForwards
98171a07 1962 receive.fsckObjects
025a1929 1963 receive.unpackLimit
6068ac88
MZ
1964 receive.updateserverinfo
1965 remotes.
98171a07
LM
1966 repack.usedeltabaseoffset
1967 rerere.autoupdate
1968 rerere.enabled
6068ac88 1969 sendemail.
226b343c 1970 sendemail.aliasesfile
6068ac88 1971 sendemail.aliasfiletype
226b343c
SB
1972 sendemail.bcc
1973 sendemail.cc
1974 sendemail.cccmd
1975 sendemail.chainreplyto
1976 sendemail.confirm
1977 sendemail.envelopesender
6068ac88
MZ
1978 sendemail.from
1979 sendemail.identity
226b343c
SB
1980 sendemail.multiedit
1981 sendemail.signedoffbycc
6068ac88 1982 sendemail.smtpdomain
226b343c
SB
1983 sendemail.smtpencryption
1984 sendemail.smtppass
1985 sendemail.smtpserver
6068ac88 1986 sendemail.smtpserveroption
226b343c
SB
1987 sendemail.smtpserverport
1988 sendemail.smtpuser
1989 sendemail.suppresscc
1990 sendemail.suppressfrom
1991 sendemail.thread
1992 sendemail.to
1993 sendemail.validate
78d4d6a2 1994 showbranch.default
98171a07
LM
1995 status.relativePaths
1996 status.showUntrackedFiles
6068ac88
MZ
1997 status.submodulesummary
1998 submodule.
78d4d6a2
SP
1999 tar.umask
2000 transfer.unpackLimit
0aa62fd0 2001 url.
78d4d6a2 2002 user.email
025a1929 2003 user.name
78d4d6a2 2004 user.signingkey
98171a07 2005 web.browser
5de40f59 2006 branch. remote.
78d4d6a2 2007 "
5de40f59
SP
2008}
2009
88293c67
SP
2010_git_remote ()
2011{
e17dba8f 2012 local subcommands="add rename remove set-head set-branches set-url show prune update"
918c03c2 2013 local subcommand="$(__git_find_on_cmdline "$subcommands")"
3ff1320d 2014 if [ -z "$subcommand" ]; then
3903c618 2015 __gitcomp "$subcommands"
88293c67
SP
2016 return
2017 fi
2018
3ff1320d 2019 case "$subcommand" in
e17dba8f 2020 rename|remove|set-url|show|prune)
a31e6262 2021 __gitcomp_nl "$(__git_remotes)"
88293c67 2022 ;;
f1c6ffe6
PJ
2023 set-head|set-branches)
2024 __git_complete_remote_or_refspec
2025 ;;
fb72759b
SP
2026 update)
2027 local i c='' IFS=$'\n'
518ef8f0
TZ
2028 for i in $(git --git-dir="$(__gitdir)" config --get-regexp "remotes\..*" 2>/dev/null); do
2029 i="${i#remotes.}"
2030 c="$c ${i/ */}"
fb72759b
SP
2031 done
2032 __gitcomp "$c"
2033 ;;
88293c67
SP
2034 *)
2035 COMPREPLY=()
2036 ;;
2037 esac
2038}
2039
e1c1a067
BG
2040_git_replace ()
2041{
a31e6262 2042 __gitcomp_nl "$(__git_refs)"
e1c1a067
BG
2043}
2044
67e78c3b
SP
2045_git_reset ()
2046{
d773c631
SG
2047 __git_has_doubledash && return
2048
b3391775
SP
2049 case "$cur" in
2050 --*)
9f040e95 2051 __gitcomp "--merge --mixed --hard --soft --patch"
b3391775
SP
2052 return
2053 ;;
2054 esac
a31e6262 2055 __gitcomp_nl "$(__git_refs)"
67e78c3b
SP
2056}
2057
a6c2be24
LM
2058_git_revert ()
2059{
a6c2be24
LM
2060 case "$cur" in
2061 --*)
2062 __gitcomp "--edit --mainline --no-edit --no-commit --signoff"
2063 return
2064 ;;
2065 esac
a31e6262 2066 __gitcomp_nl "$(__git_refs)"
a6c2be24
LM
2067}
2068
08c701d4
LM
2069_git_rm ()
2070{
2071 __git_has_doubledash && return
2072
08c701d4
LM
2073 case "$cur" in
2074 --*)
2075 __gitcomp "--cached --dry-run --ignore-unmatch --quiet"
2076 return
2077 ;;
2078 esac
2079 COMPREPLY=()
2080}
2081
1fd6bec9
SP
2082_git_shortlog ()
2083{
d773c631
SG
2084 __git_has_doubledash && return
2085
1fd6bec9
SP
2086 case "$cur" in
2087 --*)
2088 __gitcomp "
a393777e
TR
2089 $__git_log_common_options
2090 $__git_log_shortlog_options
1fd6bec9
SP
2091 --numbered --summary
2092 "
2093 return
2094 ;;
2095 esac
2096 __git_complete_revlist
2097}
2098
90131924
SP
2099_git_show ()
2100{
41d8cf7d
MH
2101 __git_has_doubledash && return
2102
90131924 2103 case "$cur" in
e67d71e5 2104 --pretty=*|--format=*)
c3898111 2105 __gitcomp "$__git_log_pretty_formats $(__git_pretty_aliases)
e67d71e5 2106 " "" "${cur#*=}"
72de29c2
TL
2107 return
2108 ;;
90131924 2109 --*)
076c3237 2110 __gitcomp "--pretty= --format= --abbrev-commit --oneline
20bf7292
TR
2111 $__git_diff_common_options
2112 "
90131924
SP
2113 return
2114 ;;
2115 esac
2116 __git_complete_file
2117}
2118
2ca880fe
TR
2119_git_show_branch ()
2120{
2ca880fe
TR
2121 case "$cur" in
2122 --*)
2123 __gitcomp "
2124 --all --remotes --topo-order --current --more=
2125 --list --independent --merge-base --no-name
6123d719 2126 --color --no-color
076c3237 2127 --sha1-name --sparse --topics --reflog
2ca880fe
TR
2128 "
2129 return
2130 ;;
2131 esac
2132 __git_complete_revlist
2133}
2134
7fd53fce
JH
2135_git_stash ()
2136{
59d5eeee 2137 local save_opts='--keep-index --no-keep-index --quiet --patch'
95d43780 2138 local subcommands='save list show apply clear drop pop create branch'
918c03c2 2139 local subcommand="$(__git_find_on_cmdline "$subcommands")"
7bedebca 2140 if [ -z "$subcommand" ]; then
59d5eeee
SG
2141 case "$cur" in
2142 --*)
2143 __gitcomp "$save_opts"
2144 ;;
2145 *)
2146 if [ -z "$(__git_find_on_cmdline "$save_opts")" ]; then
2147 __gitcomp "$subcommands"
2148 else
2149 COMPREPLY=()
2150 fi
2151 ;;
2152 esac
7bedebca 2153 else
7bedebca
SG
2154 case "$subcommand,$cur" in
2155 save,--*)
59d5eeee 2156 __gitcomp "$save_opts"
7bedebca 2157 ;;
8513c54b 2158 apply,--*|pop,--*)
59d5eeee 2159 __gitcomp "--index --quiet"
95d43780 2160 ;;
8513c54b 2161 show,--*|drop,--*|branch,--*)
95d43780
LM
2162 COMPREPLY=()
2163 ;;
2164 show,*|apply,*|drop,*|pop,*|branch,*)
a31e6262 2165 __gitcomp_nl "$(git --git-dir="$(__gitdir)" stash list \
95d43780
LM
2166 | sed -n -e 's/:.*//p')"
2167 ;;
7bedebca
SG
2168 *)
2169 COMPREPLY=()
2170 ;;
2171 esac
3ff1320d 2172 fi
7fd53fce
JH
2173}
2174
be86f7a0
SP
2175_git_submodule ()
2176{
d773c631
SG
2177 __git_has_doubledash && return
2178
1b0f7978 2179 local subcommands="add status init update summary foreach sync"
918c03c2 2180 if [ -z "$(__git_find_on_cmdline "$subcommands")" ]; then
be86f7a0
SP
2181 case "$cur" in
2182 --*)
2183 __gitcomp "--quiet --cached"
2184 ;;
2185 *)
3ff1320d 2186 __gitcomp "$subcommands"
be86f7a0
SP
2187 ;;
2188 esac
2189 return
2190 fi
2191}
2192
47f6ee28
SG
2193_git_svn ()
2194{
2195 local subcommands="
2196 init fetch clone rebase dcommit log find-rev
2197 set-tree commit-diff info create-ignore propget
4a5856cb 2198 proplist show-ignore show-externals branch tag blame
c18d5d82 2199 migrate mkdirs reset gc
47f6ee28 2200 "
918c03c2 2201 local subcommand="$(__git_find_on_cmdline "$subcommands")"
47f6ee28
SG
2202 if [ -z "$subcommand" ]; then
2203 __gitcomp "$subcommands"
2204 else
2205 local remote_opts="--username= --config-dir= --no-auth-cache"
2206 local fc_opts="
2207 --follow-parent --authors-file= --repack=
2208 --no-metadata --use-svm-props --use-svnsync-props
2209 --log-window-size= --no-checkout --quiet
4a5856cb
SG
2210 --repack-flags --use-log-author --localtime
2211 --ignore-paths= $remote_opts
47f6ee28
SG
2212 "
2213 local init_opts="
2214 --template= --shared= --trunk= --tags=
2215 --branches= --stdlayout --minimize-url
2216 --no-metadata --use-svm-props --use-svnsync-props
4a5856cb
SG
2217 --rewrite-root= --prefix= --use-log-author
2218 --add-author-from $remote_opts
47f6ee28
SG
2219 "
2220 local cmt_opts="
2221 --edit --rmdir --find-copies-harder --copy-similarity=
2222 "
2223
47f6ee28
SG
2224 case "$subcommand,$cur" in
2225 fetch,--*)
2226 __gitcomp "--revision= --fetch-all $fc_opts"
2227 ;;
2228 clone,--*)
2229 __gitcomp "--revision= $fc_opts $init_opts"
2230 ;;
2231 init,--*)
2232 __gitcomp "$init_opts"
2233 ;;
2234 dcommit,--*)
2235 __gitcomp "
2236 --merge --strategy= --verbose --dry-run
4a5856cb 2237 --fetch-all --no-rebase --commit-url
7b151f49 2238 --revision --interactive $cmt_opts $fc_opts
47f6ee28
SG
2239 "
2240 ;;
2241 set-tree,--*)
2242 __gitcomp "--stdin $cmt_opts $fc_opts"
2243 ;;
2244 create-ignore,--*|propget,--*|proplist,--*|show-ignore,--*|\
c18d5d82 2245 show-externals,--*|mkdirs,--*)
47f6ee28
SG
2246 __gitcomp "--revision="
2247 ;;
2248 log,--*)
2249 __gitcomp "
2250 --limit= --revision= --verbose --incremental
2251 --oneline --show-commit --non-recursive
4a5856cb 2252 --authors-file= --color
47f6ee28
SG
2253 "
2254 ;;
2255 rebase,--*)
2256 __gitcomp "
2257 --merge --verbose --strategy= --local
4a5856cb 2258 --fetch-all --dry-run $fc_opts
47f6ee28
SG
2259 "
2260 ;;
2261 commit-diff,--*)
2262 __gitcomp "--message= --file= --revision= $cmt_opts"
2263 ;;
2264 info,--*)
2265 __gitcomp "--url"
2266 ;;
4a5856cb
SG
2267 branch,--*)
2268 __gitcomp "--dry-run --message --tag"
2269 ;;
2270 tag,--*)
2271 __gitcomp "--dry-run --message"
2272 ;;
2273 blame,--*)
2274 __gitcomp "--git-format"
2275 ;;
2276 migrate,--*)
2277 __gitcomp "
2278 --config-dir= --ignore-paths= --minimize
2279 --no-auth-cache --username=
2280 "
2281 ;;
c18d5d82
RZ
2282 reset,--*)
2283 __gitcomp "--revision= --parent"
2284 ;;
47f6ee28
SG
2285 *)
2286 COMPREPLY=()
2287 ;;
2288 esac
2289 fi
2290}
2291
88e21dc7
SP
2292_git_tag ()
2293{
2294 local i c=1 f=0
da48616f
PD
2295 while [ $c -lt $cword ]; do
2296 i="${words[c]}"
88e21dc7
SP
2297 case "$i" in
2298 -d|-v)
a31e6262 2299 __gitcomp_nl "$(__git_tags)"
88e21dc7
SP
2300 return
2301 ;;
2302 -f)
2303 f=1
2304 ;;
2305 esac
6e8c755f 2306 ((c++))
88e21dc7
SP
2307 done
2308
da48616f 2309 case "$prev" in
88e21dc7
SP
2310 -m|-F)
2311 COMPREPLY=()
2312 ;;
8d8163f3 2313 -*|tag)
88e21dc7 2314 if [ $f = 1 ]; then
a31e6262 2315 __gitcomp_nl "$(__git_tags)"
88e21dc7
SP
2316 else
2317 COMPREPLY=()
2318 fi
2319 ;;
2320 *)
a31e6262 2321 __gitcomp_nl "$(__git_refs)"
88e21dc7
SP
2322 ;;
2323 esac
2324}
2325
424cce83
SG
2326_git_whatchanged ()
2327{
2328 _git_log
2329}
2330
93b291e0 2331__git_main ()
690d8824 2332{
873537fa
SP
2333 local i c=1 command __git_dir
2334
da48616f
PD
2335 while [ $c -lt $cword ]; do
2336 i="${words[c]}"
873537fa
SP
2337 case "$i" in
2338 --git-dir=*) __git_dir="${i#--git-dir=}" ;;
2339 --bare) __git_dir="." ;;
1eb7e2f8 2340 --help) command="help"; break ;;
911d5da6
SG
2341 -c) c=$((++c)) ;;
2342 -*) ;;
873537fa
SP
2343 *) command="$i"; break ;;
2344 esac
6e8c755f 2345 ((c++))
873537fa
SP
2346 done
2347
1d17b22e 2348 if [ -z "$command" ]; then
da48616f 2349 case "$cur" in
47e98eec 2350 --*) __gitcomp "
ce5a2c95 2351 --paginate
47e98eec
SP
2352 --no-pager
2353 --git-dir=
2354 --bare
2355 --version
2356 --exec-path
3ffcd086 2357 --exec-path=
89a56bfb 2358 --html-path
69ef3c02 2359 --info-path
ce5a2c95 2360 --work-tree=
a1bea2c1 2361 --namespace=
69ef3c02 2362 --no-replace-objects
ce5a2c95 2363 --help
47e98eec
SP
2364 "
2365 ;;
eaa4e6ee
JN
2366 *) __git_compute_porcelain_commands
2367 __gitcomp "$__git_porcelain_commands $(__git_aliases)" ;;
72e5e989
SP
2368 esac
2369 return
873537fa 2370 fi
367dce2a 2371
424cce83 2372 local completion_func="_git_${command//-/_}"
06f44c3c 2373 declare -f $completion_func >/dev/null && $completion_func && return
8024ea60 2374
873537fa 2375 local expansion=$(__git_aliased_command "$command")
8024ea60
SG
2376 if [ -n "$expansion" ]; then
2377 completion_func="_git_${expansion//-/_}"
06f44c3c 2378 declare -f $completion_func >/dev/null && $completion_func
8024ea60 2379 fi
690d8824
JH
2380}
2381
93b291e0 2382__gitk_main ()
690d8824 2383{
d773c631
SG
2384 __git_has_doubledash && return
2385
fa26a401 2386 local g="$(__gitdir)"
07ba53f7 2387 local merge=""
ba7906f2 2388 if [ -f "$g/MERGE_HEAD" ]; then
07ba53f7
RQ
2389 merge="--merge"
2390 fi
b3391775
SP
2391 case "$cur" in
2392 --*)
a393777e
TR
2393 __gitcomp "
2394 $__git_log_common_options
2395 $__git_log_gitk_options
2396 $merge
2397 "
b3391775
SP
2398 return
2399 ;;
2400 esac
ec804891 2401 __git_complete_revlist
690d8824
JH
2402}
2403
d8b45314
FC
2404if [[ -n ${ZSH_VERSION-} ]]; then
2405 echo "WARNING: this script is deprecated, please see git-completion.zsh" 1>&2
6b179adf 2406
9cd67bd2
FC
2407 autoload -U +X compinit && compinit
2408
d8b45314
FC
2409 __gitcomp ()
2410 {
2411 emulate -L zsh
6b179adf 2412
d8b45314
FC
2413 local cur_="${3-$cur}"
2414
2415 case "$cur_" in
2416 --*=)
2417 ;;
2418 *)
2419 local c IFS=$' \t\n'
2420 local -a array
2421 for c in ${=1}; do
2422 c="$c${4-}"
2423 case $c in
2424 --*=*|*.) ;;
2425 *) c="$c " ;;
2426 esac
2427 array+=("$c")
2428 done
2429 compset -P '*[=:]'
2430 compadd -Q -S '' -p "${2-}" -a -- array && _ret=0
2431 ;;
2432 esac
2433 }
2434
2435 __gitcomp_nl ()
2436 {
2437 emulate -L zsh
2438
2439 local IFS=$'\n'
2440 compset -P '*[=:]'
2441 compadd -Q -S "${4- }" -p "${2-}" -- ${=1} && _ret=0
2442 }
2443
2444 __git_zsh_helper ()
2445 {
2446 emulate -L ksh
2447 local cur cword prev
2448 cur=${words[CURRENT-1]}
2449 prev=${words[CURRENT-2]}
2450 let cword=CURRENT-1
2451 __${service}_main
2452 }
2453
2454 _git ()
2455 {
2456 emulate -L zsh
2457 local _ret=1
2458 __git_zsh_helper
2459 let _ret && _default -S '' && _ret=0
2460 return _ret
2461 }
2462
2463 compdef _git git gitk
2464 return
2465fi
2466
2467__git_func_wrap ()
2468{
6b179adf
FC
2469 local cur words cword prev
2470 _get_comp_words_by_ref -n =: cur words cword prev
2471 $1
2472}
2473
2474# Setup completion for certain functions defined above by setting common
2475# variables and workarounds.
2476# This is NOT a public function; use at your own risk.
2477__git_complete ()
2478{
2479 local wrapper="__git_wrap${2}"
2480 eval "$wrapper () { __git_func_wrap $2 ; }"
2481 complete -o bashdefault -o default -o nospace -F $wrapper $1 2>/dev/null \
2482 || complete -o default -o nospace -F $wrapper $1
2483}
2484
b0a4b2d2
FC
2485# wrapper for backwards compatibility
2486_git ()
2487{
93b291e0 2488 __git_wrap__git_main
b0a4b2d2
FC
2489}
2490
2491# wrapper for backwards compatibility
2492_gitk ()
2493{
93b291e0 2494 __git_wrap__gitk_main
b0a4b2d2
FC
2495}
2496
93b291e0
SG
2497__git_complete git __git_main
2498__git_complete gitk __gitk_main
690d8824
JH
2499
2500# The following are necessary only for Cygwin, and only are needed
2501# when the user has tab-completed the executable name and consequently
2502# included the '.exe' suffix.
2503#
76c3eb51 2504if [ Cygwin = "$(uname -o 2>/dev/null)" ]; then
93b291e0 2505__git_complete git.exe __git_main
76c3eb51 2506fi