summaryrefslogtreecommitdiff
path: root/plugins/jump
diff options
context:
space:
mode:
authoryleo77 <ylep77@gmail.com>2013-09-19 12:40:45 +0800
committeryleo77 <ylep77@gmail.com>2013-09-19 12:40:45 +0800
commit0240ac6496fc01b287caaab1a62cd760590144be (patch)
tree120cbd08b851e012d8843652ccf8bf89c5a023f7 /plugins/jump
parentfda5afaebca57250792696e29c2e111f41f6fce4 (diff)
parentb51c2a0d0b0af68d4b2b70b922f7d56a14a23dcc (diff)
downloadzsh-0240ac6496fc01b287caaab1a62cd760590144be.tar.gz
zsh-0240ac6496fc01b287caaab1a62cd760590144be.tar.bz2
zsh-0240ac6496fc01b287caaab1a62cd760590144be.zip
Merge remote-tracking branch 'robbyrussell/master'
Diffstat (limited to 'plugins/jump')
-rw-r--r--plugins/jump/jump.plugin.zsh52
1 files changed, 52 insertions, 0 deletions
diff --git a/plugins/jump/jump.plugin.zsh b/plugins/jump/jump.plugin.zsh
new file mode 100644
index 000000000..a3c5cf8c3
--- /dev/null
+++ b/plugins/jump/jump.plugin.zsh
@@ -0,0 +1,52 @@
+# Easily jump around the file system by manually adding marks
+# marks are stored as symbolic links in the directory $MARKPATH (default $HOME/.marks)
+#
+# jump FOO: jump to a mark named FOO
+# mark FOO: create a mark named FOO
+# unmark FOO: delete a mark
+# marks: lists all marks
+#
+export MARKPATH=$HOME/.marks
+
+jump() {
+ cd -P "$MARKPATH/$1" 2>/dev/null || echo "No such mark: $1"
+}
+
+mark() {
+ if (( $# == 0 )); then
+ MARK=$(basename "$(pwd)")
+ else
+ MARK="$1"
+ fi
+ if read -q \?"Mark $(pwd) as ${MARK}? (y/n) "; then
+ mkdir -p "$MARKPATH"; ln -s "$(pwd)" "$MARKPATH/$MARK"
+ fi
+}
+
+unmark() {
+ rm -i "$MARKPATH/$1"
+}
+
+autoload colors
+marks() {
+ for link in $MARKPATH/*(@); do
+ local markname="$fg[cyan]${link:t}$reset_color"
+ local markpath="$fg[blue]$(readlink $link)$reset_color"
+ printf "%s\t" $markname
+ printf "-> %s \t\n" $markpath
+ done
+}
+
+_completemarks() {
+ reply=($(ls $MARKPATH/**/*(-) | grep : | sed -E 's/(.*)\/([_\da-zA-Z\-]*):$/\2/g'))
+}
+compctl -K _completemarks jump
+compctl -K _completemarks unmark
+
+_mark_expansion() {
+ setopt extendedglob
+ autoload -U modify-current-argument
+ modify-current-argument '$(readlink "$MARKPATH/$ARG")'
+}
+zle -N _mark_expansion
+bindkey "^g" _mark_expansion