Mercurial > public > mercurial-scm > hg
annotate contrib/bash_completion @ 1149:f82b084bd904
bash_completion: update for new help output format
author | Alexis S. L. Carvalho <alexis@cecm.usp.br> |
---|---|
date | Mon, 29 Aug 2005 20:37:07 +0200 |
parents | 89f54e72581d |
children | 4ee09418c8e5 |
rev | line source |
---|---|
1115
89f54e72581d
bash_completion: add debugindex and debugdata support
mpm@selenic.com
parents:
1018
diff
changeset
|
1 #!/bin/bash |
89f54e72581d
bash_completion: add debugindex and debugdata support
mpm@selenic.com
parents:
1018
diff
changeset
|
2 |
916 | 3 _hg_commands() |
4 { | |
5 local commands="$(hg -v help | sed -e '1,/^list of commands:/d' \ | |
952
dbfabfcb485e
bash_completion: support GNU sed 3 and non-GNU sed
TK Soh <teekaysoh@yahoo.com>
parents:
935
diff
changeset
|
6 -e '/^global options:/,$d' \ |
916 | 7 -e '/^ [^ ]/!d; s/[,:]//g;')" |
8 | |
9 # hide debug commands from users, but complete them if | |
10 # specifically asked for | |
11 if [[ "$cur" == de* ]]; then | |
12 commands="$commands debugcheckstate debugstate debugindex" | |
1115
89f54e72581d
bash_completion: add debugindex and debugdata support
mpm@selenic.com
parents:
1018
diff
changeset
|
13 commands="$commands debugindexdot debugwalk debugdata" |
916 | 14 fi |
15 COMPREPLY=( ${COMPREPLY[@]:-} $(compgen -W "$commands" -- "$cur") ) | |
16 } | |
17 | |
18 _hg_paths() | |
19 { | |
20 local paths="$(hg paths | sed -e 's/ = .*$//')" | |
21 COMPREPLY=(${COMPREPLY[@]:-} $( compgen -W "$paths" -- "$cur" )) | |
22 } | |
23 | |
935
925563ff1b18
bash: Add smarter completion of add/commit/remove/forget/diff/revert
mpm@selenic.com
parents:
929
diff
changeset
|
24 _hg_status() |
925563ff1b18
bash: Add smarter completion of add/commit/remove/forget/diff/revert
mpm@selenic.com
parents:
929
diff
changeset
|
25 { |
925563ff1b18
bash: Add smarter completion of add/commit/remove/forget/diff/revert
mpm@selenic.com
parents:
929
diff
changeset
|
26 local files="$( hg status -$1 | cut -b 3- )" |
925563ff1b18
bash: Add smarter completion of add/commit/remove/forget/diff/revert
mpm@selenic.com
parents:
929
diff
changeset
|
27 COMPREPLY=(${COMPREPLY[@]:-} $( compgen -W "$files" -- "$cur" )) |
925563ff1b18
bash: Add smarter completion of add/commit/remove/forget/diff/revert
mpm@selenic.com
parents:
929
diff
changeset
|
28 } |
925563ff1b18
bash: Add smarter completion of add/commit/remove/forget/diff/revert
mpm@selenic.com
parents:
929
diff
changeset
|
29 |
916 | 30 _hg_tags() |
31 { | |
32 local tags="$(hg tags | sed -e 's/[0-9]*:[a-f0-9]\{40\}$//; s/ *$//')" | |
33 COMPREPLY=( ${COMPREPLY[@]:-} $(compgen -W "$tags" -- "$cur") ) | |
34 } | |
35 | |
36 # this is "kind of" ugly... | |
37 _hg_count_non_option() | |
38 { | |
39 local i count=0 | |
40 local filters="$1" | |
41 | |
42 for (( i=1; $i<=$COMP_CWORD; i++ )); do | |
43 if [[ "${COMP_WORDS[i]}" != -* ]]; then | |
44 for f in $filters; do | |
45 if [[ ${COMP_WORDS[i-1]} == $f ]]; then | |
46 continue 2 | |
47 fi | |
48 done | |
49 count=$(($count + 1)) | |
50 fi | |
51 done | |
52 | |
53 echo $(($count - 1)) | |
54 } | |
55 | |
56 _hg() | |
57 { | |
58 local cur prev cmd opts i | |
59 | |
60 COMPREPLY=() | |
61 cur="$2" | |
62 prev="$3" | |
63 | |
64 # searching for the command | |
65 # (first non-option argument that doesn't follow -R/--repository) | |
66 for (( i=1; $i<=$COMP_CWORD; i++ )); do | |
67 if [[ ${COMP_WORDS[i]} != -* ]] \ | |
68 && [ "${COMP_WORDS[i-1]}" != -R ] \ | |
69 && [ "${COMP_WORDS[i-1]}" != --repository ]; then | |
70 cmd="${COMP_WORDS[i]}" | |
71 break | |
72 fi | |
73 done | |
74 | |
75 if [[ "$cur" == -* ]]; then | |
1149
f82b084bd904
bash_completion: update for new help output format
Alexis S. L. Carvalho <alexis@cecm.usp.br>
parents:
1115
diff
changeset
|
76 # this assumes that there are no commands with spaces in the name |
f82b084bd904
bash_completion: update for new help output format
Alexis S. L. Carvalho <alexis@cecm.usp.br>
parents:
1115
diff
changeset
|
77 opts=$(hg -v help $cmd | sed -e '/^ *-/!d; s/ [^- ].*//') |
916 | 78 |
79 COMPREPLY=( ${COMPREPLY[@]:-} $(compgen -W "$opts" -- "$cur") ) | |
80 return | |
81 fi | |
82 | |
83 if [ "$prev" = -R ] || [ "$prev" = --repository ]; then | |
84 COMPREPLY=(${COMPREPLY[@]:-} $( compgen -d -- "$cur" )) | |
85 return | |
86 fi | |
87 | |
88 if [ -z "$cmd" ] || [ $COMP_CWORD -eq $i ]; then | |
89 _hg_commands | |
90 return | |
91 fi | |
92 | |
93 if [ "$cmd" != status ] && [ "$prev" = -r ] || [ "$prev" = --rev ]; then | |
94 _hg_tags | |
95 return | |
96 fi | |
97 | |
98 case "$cmd" in | |
99 help) | |
100 _hg_commands | |
101 ;; | |
102 export|manifest|update|checkout|up|co) | |
103 _hg_tags | |
104 ;; | |
1018 | 105 pull|push|outgoing|incoming|out|in) |
916 | 106 _hg_paths |
107 COMPREPLY=(${COMPREPLY[@]:-} $( compgen -d -- "$cur" )) | |
108 ;; | |
109 paths) | |
110 _hg_paths | |
111 ;; | |
935
925563ff1b18
bash: Add smarter completion of add/commit/remove/forget/diff/revert
mpm@selenic.com
parents:
929
diff
changeset
|
112 add) |
925563ff1b18
bash: Add smarter completion of add/commit/remove/forget/diff/revert
mpm@selenic.com
parents:
929
diff
changeset
|
113 _hg_status "u" |
925563ff1b18
bash: Add smarter completion of add/commit/remove/forget/diff/revert
mpm@selenic.com
parents:
929
diff
changeset
|
114 ;; |
1018 | 115 commit|ci) |
935
925563ff1b18
bash: Add smarter completion of add/commit/remove/forget/diff/revert
mpm@selenic.com
parents:
929
diff
changeset
|
116 _hg_status "mra" |
925563ff1b18
bash: Add smarter completion of add/commit/remove/forget/diff/revert
mpm@selenic.com
parents:
929
diff
changeset
|
117 ;; |
925563ff1b18
bash: Add smarter completion of add/commit/remove/forget/diff/revert
mpm@selenic.com
parents:
929
diff
changeset
|
118 remove) |
925563ff1b18
bash: Add smarter completion of add/commit/remove/forget/diff/revert
mpm@selenic.com
parents:
929
diff
changeset
|
119 _hg_status "r" |
925563ff1b18
bash: Add smarter completion of add/commit/remove/forget/diff/revert
mpm@selenic.com
parents:
929
diff
changeset
|
120 ;; |
925563ff1b18
bash: Add smarter completion of add/commit/remove/forget/diff/revert
mpm@selenic.com
parents:
929
diff
changeset
|
121 forget) |
925563ff1b18
bash: Add smarter completion of add/commit/remove/forget/diff/revert
mpm@selenic.com
parents:
929
diff
changeset
|
122 _hg_status "a" |
925563ff1b18
bash: Add smarter completion of add/commit/remove/forget/diff/revert
mpm@selenic.com
parents:
929
diff
changeset
|
123 ;; |
925563ff1b18
bash: Add smarter completion of add/commit/remove/forget/diff/revert
mpm@selenic.com
parents:
929
diff
changeset
|
124 diff) |
925563ff1b18
bash: Add smarter completion of add/commit/remove/forget/diff/revert
mpm@selenic.com
parents:
929
diff
changeset
|
125 _hg_status "mra" |
925563ff1b18
bash: Add smarter completion of add/commit/remove/forget/diff/revert
mpm@selenic.com
parents:
929
diff
changeset
|
126 ;; |
925563ff1b18
bash: Add smarter completion of add/commit/remove/forget/diff/revert
mpm@selenic.com
parents:
929
diff
changeset
|
127 revert) |
925563ff1b18
bash: Add smarter completion of add/commit/remove/forget/diff/revert
mpm@selenic.com
parents:
929
diff
changeset
|
128 _hg_status "mra" |
925563ff1b18
bash: Add smarter completion of add/commit/remove/forget/diff/revert
mpm@selenic.com
parents:
929
diff
changeset
|
129 ;; |
916 | 130 clone) |
131 local count=$(_hg_count_non_option) | |
132 if [ $count = 1 ]; then | |
133 _hg_paths | |
134 fi | |
135 COMPREPLY=(${COMPREPLY[@]:-} $( compgen -d -- "$cur" )) | |
136 ;; | |
1115
89f54e72581d
bash_completion: add debugindex and debugdata support
mpm@selenic.com
parents:
1018
diff
changeset
|
137 debugindex|debugindexdot) |
89f54e72581d
bash_completion: add debugindex and debugdata support
mpm@selenic.com
parents:
1018
diff
changeset
|
138 COMPREPLY=(${COMPREPLY[@]:-} $( compgen -f -X "!*.i" -- "$cur" )) |
89f54e72581d
bash_completion: add debugindex and debugdata support
mpm@selenic.com
parents:
1018
diff
changeset
|
139 ;; |
89f54e72581d
bash_completion: add debugindex and debugdata support
mpm@selenic.com
parents:
1018
diff
changeset
|
140 debugdata) |
89f54e72581d
bash_completion: add debugindex and debugdata support
mpm@selenic.com
parents:
1018
diff
changeset
|
141 COMPREPLY=(${COMPREPLY[@]:-} $( compgen -f -X "!*.d" -- "$cur" )) |
89f54e72581d
bash_completion: add debugindex and debugdata support
mpm@selenic.com
parents:
1018
diff
changeset
|
142 ;; |
916 | 143 cat) |
144 local count=$(_hg_count_non_option -o --output) | |
145 if [ $count = 2 ]; then | |
146 _hg_tags | |
147 else | |
148 COMPREPLY=(${COMPREPLY[@]:-} $( compgen -f -- "$cur" )) | |
149 fi | |
150 ;; | |
151 *) | |
152 COMPREPLY=(${COMPREPLY[@]:-} $( compgen -f -- "$cur" )) | |
153 ;; | |
154 esac | |
155 | |
156 } | |
157 | |
935
925563ff1b18
bash: Add smarter completion of add/commit/remove/forget/diff/revert
mpm@selenic.com
parents:
929
diff
changeset
|
158 complete -o default -F _hg hg |