chiark
/
gitweb
/
~mdw
/
stgit
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Fix the hidden patches functionality (bug #9077)
[stgit]
/
contrib
/
stgit-completion.bash
diff --git
a/contrib/stgit-completion.bash
b/contrib/stgit-completion.bash
index 18645dcb3c342849b4d24c84ea71628d2b69d066..a843db4407140dd68179950e51b82ba08cefe34e 100644
(file)
--- a/
contrib/stgit-completion.bash
+++ b/
contrib/stgit-completion.bash
@@
-20,6
+20,7
@@
_stg_commands="
clean
clone
commit
clean
clone
commit
+ cp
export
files
float
export
files
float
@@
-44,6
+45,7
@@
_stg_commands="
rm
series
show
rm
series
show
+ sink
status
sync
top
status
sync
top
@@
-79,6
+81,13
@@
_unapplied_patches ()
[ "$g" ] && cat "$g/patches/$(_current_branch)/unapplied"
}
[ "$g" ] && cat "$g/patches/$(_current_branch)/unapplied"
}
+# List of all applied patches.
+_hidden_patches ()
+{
+ local g=$(_gitdir)
+ [ "$g" ] && cat "$g/patches/$(_current_branch)/hidden"
+}
+
# List of all patches.
_all_patches ()
{
# List of all patches.
_all_patches ()
{
@@
-96,6
+105,12
@@
_all_other_patches ()
| grep -v "^$(cat $g/patches/$b/current 2> /dev/null)$"
}
| grep -v "^$(cat $g/patches/$b/current 2> /dev/null)$"
}
+_all_branches ()
+{
+ local g=$(_gitdir)
+ [ "$g" ] && (cd .git/patches/ && echo *)
+}
+
# List the command options
_cmd_options ()
{
# List the command options
_cmd_options ()
{
@@
-135,6
+150,11
@@
_complete_patch_range_options ()
COMPREPLY=($(compgen -W "$options" -- "$cur"))
}
COMPREPLY=($(compgen -W "$options" -- "$cur"))
}
+_complete_branch ()
+{
+ COMPREPLY=($(compgen -W "$(_cmd_options $1) $($2)" -- "${COMP_WORDS[COMP_CWORD]}"))
+}
+
# Generate completions for options from the given list.
_complete_options ()
{
# Generate completions for options from the given list.
_complete_options ()
{
@@
-190,11
+210,12
@@
_stg ()
# stack commands
float) _stg_patches $command _all_patches ;;
goto) _stg_patches $command _all_other_patches ;;
# stack commands
float) _stg_patches $command _all_patches ;;
goto) _stg_patches $command _all_other_patches ;;
- hide) _stg_patches $command _
all
_patches ;;
+ hide) _stg_patches $command _
unapplied
_patches ;;
pop) _stg_patches $command _applied_patches ;;
push) _stg_patches $command _unapplied_patches ;;
series) _stg_patches $command _all_patches ;;
pop) _stg_patches $command _applied_patches ;;
push) _stg_patches $command _unapplied_patches ;;
series) _stg_patches $command _all_patches ;;
- unhide) _stg_patches $command _all_patches ;;
+ sink) _stg_patches $command _all_patches ;;
+ unhide) _stg_patches $command _hidden_patches ;;
# patch commands
delete) _stg_patches $command _all_patches ;;
export) _stg_patches $command _applied_patches ;;
# patch commands
delete) _stg_patches $command _all_patches ;;
export) _stg_patches $command _applied_patches ;;
@@
-208,6
+229,9
@@
_stg ()
sync) _stg_patches $command _applied_patches ;;
# working-copy commands
diff) _stg_patches_options $command _applied_patches "-r --range" ;;
sync) _stg_patches $command _applied_patches ;;
# working-copy commands
diff) _stg_patches_options $command _applied_patches "-r --range" ;;
+ # commands that usually raher accept branches
+ branch) _complete_branch $command _all_branches ;;
+ rebase) _complete_branch $command _all_branches ;;
# all the other commands
*) _stg_common $command ;;
esac
# all the other commands
*) _stg_common $command ;;
esac