chezmoi init
This commit is contained in:
commit
530d6d7195
1176 changed files with 111325 additions and 0 deletions
31
dot_oh-my-zsh/plugins/jump/README.md
Normal file
31
dot_oh-my-zsh/plugins/jump/README.md
Normal file
|
@ -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
|
||||
```
|
60
dot_oh-my-zsh/plugins/jump/jump.plugin.zsh
Normal file
60
dot_oh-my-zsh/plugins/jump/jump.plugin.zsh
Normal file
|
@ -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
|
Loading…
Add table
Add a link
Reference in a new issue