#compdef vcsh
function __vcsh_repositories () {
- #TODO list only one repo and stop
local expl
local -a repos
repos=( ${(f)"$(command vcsh list)"} )
}
function _vcsh-delete () {
- __vcsh_repositories
+ (( CURRENT == 2 )) && __vcsh_repositories
}
function _vcsh-enter () {
- __vcsh_repositories
+ (( CURRENT == 2 )) && __vcsh_repositories
}
function _vcsh-help () {
}
function _vcsh-list-tracked-by () {
- __vcsh_repositories
+ (( CURRENT == 2 )) && __vcsh_repositories
+}
+
+function _vcsh-pull () {
+ _nothing
+}
+
+function _vcsh-push () {
+ _nothing
}
function _vcsh-rename () {
- __vcsh_repositories
- #TODO tell the user to write new stuff
+ (( CURRENT == 2 )) && __vcsh_repositories
+ (( CURRENT == 3 )) && _message "new repository name"
+ (( CURRENT > 3 )) && _nothing
}
function _vcsh-run () {
- __vcsh_repositories
- _commands
- #TODO normal commands
+ (( CURRENT == 2 )) && __vcsh_repositories
+ if (( CURRENT >= 3 )); then
+ words=( "${(@)words[3,-1]}" )
+ (( CURRENT -= 2 ))
+ _complete
+ fi
}
-function _vcsh-setup () {
- __vcsh_repositories
+function _vcsh-upgrade () {
+ (( CURRENT == 2 )) && __vcsh_repositories
}
function _vcsh-version () {
+ _nothing
}
function _vcsh-which () {
- __vcsh_not_implemented_yet "$0" #TODO
+ _files
}
function _vcsh-write-gitignore () {
- __vcsh_repositories
+ (( CURRENT == 2 )) && __vcsh_repositories
}
function _vcsh () {
"list:list all local vcsh repositories"
"list-tracked:list all files tracked by vcsh"
"list-tracked-by:list files tracked by a repository"
+ "pull:pull from all vcsh remotes"
"rename:rename a repository"
"run:run command with <\$GIT_DIR> and <\$GIT_WORK_TREE> set"
- "setup:set up repository with recommended settings"
+ "upgrade:upgrade repository to currently recommended settings"
"version:print version information"
"which:find <substring> in name of any tracked file"
"write-gitignore:write .gitignore.d/<repo> via git ls-files"
if ! (( ${+functions[_vcsh-$vcshcommand]} )); then
# There is no handler function, so this is probably the name
# of a repository. Act accordingly.
- _message "git sub-command"
- #TODO and now we need to complete on git subcommands
+ _dispatch git git
else
curcontext="${curcontext%:*:*}:vcsh-${vcshcommand}:"
_call_function ret _vcsh-${vcshcommand}