summaryrefslogtreecommitdiff
path: root/plugins
diff options
context:
space:
mode:
authorRobby Russell <robby@planetargon.com>2012-12-04 06:39:49 -0800
committerRobby Russell <robby@planetargon.com>2012-12-04 06:39:49 -0800
commit24188fda800936b1abcbb37d9f9a7cff841215f8 (patch)
tree8055ad82d45d0ded66c32eb8da23375abda2ed77 /plugins
parentdbeb74ece85ff3624a11c2929bba3a35b327d880 (diff)
parent8088e8ac7935e9289d049278e117befd87f48809 (diff)
downloadzsh-24188fda800936b1abcbb37d9f9a7cff841215f8.tar.gz
zsh-24188fda800936b1abcbb37d9f9a7cff841215f8.tar.bz2
zsh-24188fda800936b1abcbb37d9f9a7cff841215f8.zip
Merge pull request #1181 from paulmars/master
Plugin for git_remote_branch autocomplete.
Diffstat (limited to 'plugins')
-rw-r--r--plugins/git-remote-branch/git-remote-branch.plugin.zsh18
1 files changed, 18 insertions, 0 deletions
diff --git a/plugins/git-remote-branch/git-remote-branch.plugin.zsh b/plugins/git-remote-branch/git-remote-branch.plugin.zsh
new file mode 100644
index 000000000..ff98cbf87
--- /dev/null
+++ b/plugins/git-remote-branch/git-remote-branch.plugin.zsh
@@ -0,0 +1,18 @@
+_git_remote_branch() {
+ ref=$(git symbolic-ref HEAD 2> /dev/null)
+ if [[ -n $ref ]]; then
+ if (( CURRENT == 2 )); then
+ # first arg: operation
+ compadd create publish rename delete track
+ elif (( CURRENT == 3 )); then
+ # second arg: remote branch name
+ compadd `git branch -r | grep -v HEAD | sed "s/.*\///" | sed "s/ //g"`
+ elif (( CURRENT == 4 )); then
+ # third arg: remote name
+ compadd `git remote`
+ fi
+ else;
+ _files
+ fi
+}
+compdef _git_remote_branch grb