diff options
author | Aditya <bluenerd@protonmail.com> | 2023-02-27 20:04:56 +0530 |
---|---|---|
committer | Aditya <bluenerd@protonmail.com> | 2023-02-27 20:04:56 +0530 |
commit | edc449275b6c04445f58b108ca0937a87c1e8430 (patch) | |
tree | 9fd484d58145b616f29a78857cc0b1c8b1c18f05 /oh-my-zsh/plugins/jump | |
parent | 6f5424ca96c4221ef433f545642669e9c104d0ed (diff) |
add zsh
Diffstat (limited to 'oh-my-zsh/plugins/jump')
-rw-r--r-- | oh-my-zsh/plugins/jump/README.md | 31 | ||||
-rw-r--r-- | oh-my-zsh/plugins/jump/jump.plugin.zsh | 59 |
2 files changed, 90 insertions, 0 deletions
diff --git a/oh-my-zsh/plugins/jump/README.md b/oh-my-zsh/plugins/jump/README.md new file mode 100644 index 0000000..1b0ce68 --- /dev/null +++ b/oh-my-zsh/plugins/jump/README.md @@ -0,0 +1,31 @@ +# Jump plugin + +This plugin allows to easily jump around the file system by manually adding marks. +Those marks are stored as symbolic links in the directory `$MARKPATH` (default `$HOME/.marks`) + +To use it, add `jump` to the plugins array in your zshrc file: + +```zsh +plugins=(... jump) +``` + +## Commands + +| Command | Description | +|----------------------|-------------------------------------------------------------------------------------------------| +| `jump <mark-name>` | Jump to the given mark | +| `mark [mark-name]` | Create a mark with the given name or with the name of the current directory if none is provided | +| `unmark <mark-name>` | Remove the given mark | +| `marks` | List the existing marks and the directories they point to | + +## Key bindings + +Pressing `CTRL`+`G` substitutes the written mark name for the full path of the mark. +For example, with a mark named `mymark` pointing to `/path/to/my/mark`: +```zsh +$ cp /tmp/file mymark<C-g> +``` +will become: +```zsh +$ cp /tmp/file /path/to/my/mark +``` diff --git a/oh-my-zsh/plugins/jump/jump.plugin.zsh b/oh-my-zsh/plugins/jump/jump.plugin.zsh new file mode 100644 index 0000000..c2da114 --- /dev/null +++ b/oh-my-zsh/plugins/jump/jump.plugin.zsh @@ -0,0 +1,59 @@ +# 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() { + builtin cd -P "$MARKPATH/$1" 2>/dev/null || {echo "No such mark: $1"; return 1} +} + +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]${link:t}$reset_color" + local markpath="$fg[blue]$(readlink $link)$reset_color" + printf -- "$printf_markname_template" "$markname" + printf -- "-> %s\n" "$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 |