Merge pull request #2045 from jeroenjanssens/master
Add jump plugin, which allows you to easily jump around the file systemmaster
commit
d7b594e5cd
1 changed files with 52 additions and 0 deletions
@ -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 |
||||
Loading…
Reference in new issue