1 # bash completion support for StGIT -*- shell-script -*-
3 # Copyright (C) 2006, Karl Hasselström <kha@treskal.com>
4 # Based on git-completion.sh
6 # To use these routines:
8 # 1. Copy this file to somewhere (e.g. ~/.stgit-completion.bash).
10 # 2. Add the following line to your .bashrc:
11 # . ~/.stgit-completion.bash
57 # The path to .git, or empty if we're not in a repository.
60 echo "$(git rev-parse --git-dir 2>/dev/null)"
63 # Name of the current branch, or empty if there isn't one.
66 local b
=$
(git symbolic-ref HEAD
2>/dev
/null
)
70 # List of all applied patches.
74 [ "$g" ] && cat "$g/patches/$(_current_branch)/applied"
77 # List of all unapplied patches.
81 [ "$g" ] && cat "$g/patches/$(_current_branch)/unapplied"
84 # List of all patches.
87 local b
=$
(_current_branch
)
89 [ "$g" ] && cat "$g/patches/$b/applied" "$g/patches/$b/unapplied"
92 # List of all patches except the current patch.
95 local b
=$
(_current_branch
)
97 [ "$g" ] && cat "$g/patches/$b/applied" "$g/patches/$b/unapplied" \
98 |
grep -v "^$(cat $g/patches/$b/current 2> /dev/null)$"
104 [ "$g" ] && (cd .git
/patches
/ && echo *)
107 # List the command options
110 stg
$1 --help 2>/dev
/null |
grep -e " --[A-Za-z]" |
sed -e "s/.*\(--[^ =]\+\).*/\1/"
113 # Generate completions for patches and patch ranges from the given
114 # patch list function, and options from the given list.
115 _complete_patch_range
()
117 local patchlist
="$1" options
="$2"
118 local pfx cur
="${COMP_WORDS[COMP_CWORD]}"
123 COMPREPLY
=($
(compgen
-P "$pfx" -W "$($patchlist)" -- "$cur"))
126 COMPREPLY
=($
(compgen
-W "$options $($patchlist)" -- "$cur"))
131 _complete_patch_range_options
()
133 local patchlist
="$1" options
="$2" patch_options
="$3"
134 local prev
="${COMP_WORDS[COMP_CWORD-1]}"
135 local cur
="${COMP_WORDS[COMP_CWORD]}"
137 for popt
in $patch_options; do
138 if [ $prev == $popt ]; then
139 _complete_patch_range
$patchlist
143 COMPREPLY
=($
(compgen
-W "$options" -- "$cur"))
148 COMPREPLY
=($
(compgen
-W "$(_cmd_options $1) $($2)" -- "${COMP_WORDS[COMP_CWORD]}"))
151 # Generate completions for options from the given list.
155 COMPREPLY
=($
(compgen
-W "$options" -- "${COMP_WORDS[COMP_CWORD]}"))
160 _complete_options
"$(_cmd_options $1)"
165 _complete_patch_range
"$2" "$(_cmd_options $1)"
168 _stg_patches_options
()
170 _complete_patch_range_options
"$2" "$(_cmd_options $1)" "$3"
175 _complete_options
"$_stg_commands"
182 while [ $c -lt $COMP_CWORD ]; do
184 command="${COMP_WORDS[c]}"
189 # Complete name of subcommand.
190 if [ $c -eq $COMP_CWORD -a -z "$command" ]; then
191 COMPREPLY
=($
(compgen \
192 -W "--help --version copyright help $_stg_commands" \
193 -- "${COMP_WORDS[COMP_CWORD]}"))
197 # Complete arguments to subcommands.
201 # repository commands
202 id
) _stg_patches
$command _all_patches
;;
204 bury
) _stg_patches
$command _all_patches
;;
205 float
) _stg_patches
$command _all_patches
;;
206 goto
) _stg_patches
$command _all_other_patches
;;
207 hide
) _stg_patches
$command _all_patches
;;
208 pop
) _stg_patches
$command _applied_patches
;;
209 push
) _stg_patches
$command _unapplied_patches
;;
210 series
) _stg_patches
$command _all_patches
;;
211 unhide
) _stg_patches
$command _all_patches
;;
213 delete
) _stg_patches
$command _all_patches
;;
214 export) _stg_patches
$command _applied_patches
;;
215 files
) _stg_patches
$command _all_patches
;;
216 log
) _stg_patches
$command _all_patches
;;
217 mail) _stg_patches
$command _all_patches
;;
218 pick
) _stg_patches
$command _unapplied_patches
;;
219 refresh
)_stg_patches_options
$command _applied_patches
"-p --patch" ;;
220 rename
) _stg_patches
$command _all_patches
;;
221 show
) _stg_patches
$command _all_patches
;;
222 sync
) _stg_patches
$command _applied_patches
;;
223 # working-copy commands
224 diff) _stg_patches_options
$command _applied_patches
"-r --range" ;;
225 # commands that usually raher accept branches
226 branch
) _complete_branch
$command _all_branches
;;
227 rebase
) _complete_branch
$command _all_branches
;;
228 # all the other commands
229 *) _stg_common
$command ;;
233 complete
-o default
-F _stg stg