All patches and comments are welcome. Please squash your changes to logical
commits before using git-format-patch and git-send-email to
patches@git.madduck.net.
If you'd read over the Git project's submission guidelines and adhered to them,
I'd be especially grateful.
3 function __vcsh_repositories () {
6 repos=( ${(f)"$(command vcsh list)"} )
7 _describe -t repos 'repositories' repos
10 function __vcsh_not_implemented_yet () {
11 _message "Subcommand completion '${1#*-}': not implemented yet"
14 function _vcsh-clone () {
15 __vcsh_not_implemented_yet "$0" #TODO
18 function _vcsh-delete () {
19 (( CURRENT == 2 )) && __vcsh_repositories
22 function _vcsh-enter () {
23 (( CURRENT == 2 )) && __vcsh_repositories
26 function _vcsh-help () {
30 function _vcsh-init () {
34 function _vcsh-list () {
38 function _vcsh-list-tracked () {
39 (( CURRENT == 2 )) && __vcsh_repositories
42 function _vcsh-list-untracked () {
46 function _vcsh-pull () {
50 function _vcsh-push () {
54 function _vcsh-rename () {
55 (( CURRENT == 2 )) && __vcsh_repositories
56 (( CURRENT == 3 )) && _message "new repository name"
57 (( CURRENT > 3 )) && _nothing
60 function _vcsh-run () {
61 (( CURRENT == 2 )) && __vcsh_repositories
62 if (( CURRENT >= 3 )); then
63 words=( "${(@)words[3,-1]}" )
69 function _vcsh-status () {
70 (( CURRENT == 2 )) && __vcsh_repositories
73 function _vcsh-upgrade () {
74 (( CURRENT == 2 )) && __vcsh_repositories
77 function _vcsh-version () {
81 function _vcsh-which () {
85 function _vcsh-write-gitignore () {
86 (( CURRENT == 2 )) && __vcsh_repositories
90 local curcontext="${curcontext}"
91 local state vcshcommand
92 local -a args subcommands
95 "clone:clone an existing repository"
96 "commit:commit in all repositories"
97 "delete:delete an existing repository"
98 "enter:enter repository; spawn new <\$SHELL>"
100 "init:initialize an empty repository"
101 "list:list all local vcsh repositories"
102 "list-tracked:list all files tracked by vcsh"
103 "list-untracked:list all files not tracked by vcsh"
104 "pull:pull from all vcsh remotes"
105 "push:push to vcsh remotes"
106 "rename:rename a repository"
107 "run:run command with <\$GIT_DIR> and <\$GIT_WORK_TREE> set"
108 "status:show statuses of all/one vcsh repositories"
109 "upgrade:upgrade repository to currently recommended settings"
110 "version:print version information"
111 "which:find <substring> in name of any tracked file"
112 "write-gitignore:write .gitignore.d/<repo> via git ls-files"
116 '-c[source <file> prior to other configuration files]:config files:_path_files'
117 '-d[enable debug mode]'
118 '-v[enable verbose mode]'
119 '*:: :->subcommand_or_options_or_repo'
122 _arguments -C ${args} && return
124 if [[ ${state} == "subcommand_or_options_or_repo" ]]; then
125 if (( CURRENT == 1 )); then
126 _describe -t subcommands 'vcsh sub-commands' subcommands
129 vcshcommand="${words[1]}"
130 if ! (( ${+functions[_vcsh-$vcshcommand]} )); then
131 # There is no handler function, so this is probably the name
132 # of a repository. Act accordingly.
135 curcontext="${curcontext%:*:*}:vcsh-${vcshcommand}:"
136 _call_function ret _vcsh-${vcshcommand}