X-Git-Url: https://git.distorted.org.uk/~mdw/stgit/blobdiff_plain/ebbd6f00a745851a7c914b76bc963be50d12818e..340793d1f7dc889720ceef3271ca58187474d110:/contrib/stgit-completion.bash diff --git a/contrib/stgit-completion.bash b/contrib/stgit-completion.bash index 37277a9..8d49e21 100644 --- a/contrib/stgit-completion.bash +++ b/contrib/stgit-completion.bash @@ -13,18 +13,20 @@ _stg_commands=" add applied - assimilate branch delete diff clean clone commit + cp + edit export files float fold goto + hide id import init @@ -36,16 +38,21 @@ _stg_commands=" pop pull push + rebase refresh rename + repair resolved rm series show + sink status + sync top unapplied uncommit + unhide " # The path to .git, or empty if we're not in a repository. @@ -75,6 +82,13 @@ _unapplied_patches () [ "$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 () { @@ -89,13 +103,43 @@ _all_other_patches () local b=$(_current_branch) local g=$(_gitdir) [ "$g" ] && cat "$g/patches/$b/applied" "$g/patches/$b/unapplied" \ - | grep -v "^$(< $g/patches/$b/current)$" + | grep -v "^$(cat $g/patches/$b/current 2> /dev/null)$" +} + +_all_branches () +{ + local g=$(_gitdir) + [ "$g" ] && (cd $g/patches/ && echo *) +} + +_conflicting_files () +{ + local g=$(_gitdir) + [ "$g" ] && stg status --conflict +} + +_dirty_files () +{ + local g=$(_gitdir) + [ "$g" ] && stg status --modified --new --deleted +} + +_unknown_files () +{ + local g=$(_gitdir) + [ "$g" ] && stg status --unknown +} + +_known_files () +{ + local g=$(_gitdir) + [ "$g" ] && git ls-files } # List the command options _cmd_options () { - stg $1 --help | grep -e " --[A-Za-z]" | sed -e "s/.*\(--[^ =]\+\).*/\1/" + stg $1 --help 2>/dev/null | grep -e " --[A-Za-z]" | sed -e "s/.*\(--[^ =]\+\).*/\1/" } # Generate completions for patches and patch ranges from the given @@ -131,6 +175,11 @@ _complete_patch_range_options () 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 () { @@ -138,6 +187,11 @@ _complete_options () COMPREPLY=($(compgen -W "$options" -- "${COMP_WORDS[COMP_CWORD]}")) } +_complete_files () +{ + COMPREPLY=($(compgen -W "$(_cmd_options $1) $2" -- "${COMP_WORDS[COMP_CWORD]}")) +} + _stg_common () { _complete_options "$(_cmd_options $1)" @@ -186,20 +240,33 @@ _stg () # stack commands float) _stg_patches $command _all_patches ;; goto) _stg_patches $command _all_other_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 ;; + sink) _stg_patches $command _all_patches ;; + unhide) _stg_patches $command _hidden_patches ;; # patch commands delete) _stg_patches $command _all_patches ;; - export) _stg_patches_options $command _applied_patches "-r --range" ;; + edit) _stg_patches $command _applied_patches ;; + export) _stg_patches $command _all_patches ;; files) _stg_patches $command _all_patches ;; log) _stg_patches $command _all_patches ;; - mail) _stg_patches $command _applied_patches ;; + mail) _stg_patches $command _all_patches ;; pick) _stg_patches $command _unapplied_patches ;; - refresh)_stg_patches_options $command _applied_patches "-p --patch" ;; +# refresh)_stg_patches_options $command _applied_patches "-p --patch" ;; + refresh) _complete_files $command "$(_dirty_files)" ;; rename) _stg_patches $command _all_patches ;; show) _stg_patches $command _all_patches ;; + sync) _stg_patches $command _applied_patches ;; # working-copy commands diff) _stg_patches_options $command _applied_patches "-r --range" ;; + resolved) _complete_files $command "$(_conflicting_files)" ;; + add) _complete_files $command "$(_unknown_files)" ;; +# rm) _complete_files $command "$(_known_files)" ;; + # 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