diff options
| author | navewindre <boneyaard@gmail.com> | 2025-07-13 06:42:05 +0200 |
|---|---|---|
| committer | navewindre <boneyaard@gmail.com> | 2025-07-13 06:42:05 +0200 |
| commit | 02f14a9cb152561a5e44062aac79f3b700403b40 (patch) | |
| tree | 2db8ebda3b7f6f8777783aeb5c60018e6e1359d8 /home/.oh-my-zsh/plugins/jump/jump.plugin.zsh | |
| parent | cbbdeb2f6b40a102a829f0c47cff052937231f00 (diff) | |
omz
Diffstat (limited to 'home/.oh-my-zsh/plugins/jump/jump.plugin.zsh')
| -rw-r--r-- | home/.oh-my-zsh/plugins/jump/jump.plugin.zsh | 60 |
1 files changed, 60 insertions, 0 deletions
diff --git a/home/.oh-my-zsh/plugins/jump/jump.plugin.zsh b/home/.oh-my-zsh/plugins/jump/jump.plugin.zsh new file mode 100644 index 0000000..c2b21e9 --- /dev/null +++ b/home/.oh-my-zsh/plugins/jump/jump.plugin.zsh @@ -0,0 +1,60 @@ +# 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() { + local markpath="$(readlink $MARKPATH/$1)" || {echo "No such mark: $1"; return 1} + builtin cd "$markpath" 2>/dev/null || {echo "Destination does not exist for mark [$1]: $markpath"; return 2} +} + +mark() { + if [[ $# -eq 0 || "$1" = "." ]]; then + MARK=${PWD:t} + else + MARK="$1" + fi + if read -q "?Mark $PWD as ${MARK}? (y/n) "; then + command mkdir -p "$MARKPATH" + command ln -sfn "$PWD" "$MARKPATH/$MARK" + fi +} + +unmark() { + LANG= command rm -i "$MARKPATH/$1" +} + +marks() { + local link max=0 + for link in $MARKPATH/{,.}*(@N); do + if [[ ${#link:t} -gt $max ]]; then + max=${#link:t} + fi + done + local printf_markname_template="$(printf -- "%%%us" "$max")" + for link in $MARKPATH/{,.}*(@N); do + local markname="$fg[cyan]$(printf -- "$printf_markname_template" "${link:t}")$reset_color" + local markpath="$fg[blue]$(readlink $link)$reset_color" + printf -- "%s -> %s\n" "$markname" "$markpath" + done +} + +_completemarks() { + reply=("${MARKPATH}"/{,.}*(@N:t)) +} +compctl -K _completemarks jump +compctl -K _completemarks unmark + +_mark_expansion() { + setopt localoptions extendedglob + autoload -U modify-current-argument + modify-current-argument '$(readlink "$MARKPATH/$ARG" || echo "$ARG")' +} +zle -N _mark_expansion +bindkey "^g" _mark_expansion |
