wd: update to latest version (#8530)

pull/8993/head
Marc Cornellà 2020-06-03 18:35:51 +02:00
parent 0fd11130a3
commit 82f02e80a6
4 changed files with 209 additions and 97 deletions

View File

@ -1,5 +1,4 @@
wd # wd
==
[![Build Status](https://travis-ci.org/mfaerevaag/wd.png?branch=master)](https://travis-ci.org/mfaerevaag/wd) [![Build Status](https://travis-ci.org/mfaerevaag/wd.png?branch=master)](https://travis-ci.org/mfaerevaag/wd)
@ -9,150 +8,232 @@ wd
*NEWS*: If you are not using zsh, check out the c-port, [wd-c](https://github.com/mfaerevaag/wd-c), which works with all shells using wrapper functions. *NEWS*: If you are not using zsh, check out the c-port, [wd-c](https://github.com/mfaerevaag/wd-c), which works with all shells using wrapper functions.
### Setup ## Setup
### oh-my-zsh ### oh-my-zsh
`wd` comes bundled with [oh-my-zshell](https://github.com/ohmyzsh/ohmyzsh)! `wd` comes bundled with [oh-my-zsh](https://github.com/ohmyzsh/ohmyzsh)!
Just add the plugin in your `~/.zshrc` file: Just add the plugin in your `~/.zshrc` file:
```zsh
plugins=(... wd) plugins=(... wd)
```
### [Antigen](https://github.com/zsh-users/antigen)
#### Automatic In your `.zshrc`:
```zsh
antigen bundle mfaerevaag/wd
```
### [Antibody](https://github.com/getantibody/antibody)
In your `.zshrc`:
```zsh
antibody bundle mfaerevaag/wd
```
### Arch ([AUR](https://aur.archlinux.org/packages/zsh-plugin-wd-git/))
```zsh
yay -S zsh-plugin-wd-git
# or use any other AUR helper
```
### [zplug](https://github.com/zplug/zplug)
```zsh
zplug "mfaerevaag/wd", as:command, use:"wd.sh", hook-load:"wd() { . $ZPLUG_REPOS/mfaerevaag/wd/wd.sh }"
```
### Automatic
Run either in terminal: Run either in terminal:
* `curl -L https://github.com/mfaerevaag/wd/raw/master/install.sh | sh` ```zsh
curl -L https://github.com/mfaerevaag/wd/raw/master/install.sh | sh
```
* `wget --no-check-certificate https://github.com/mfaerevaag/wd/raw/master/install.sh -O - | sh` or
##### Arch ([AUR](https://aur.archlinux.org/)) ```zsh
wget --no-check-certificate https://github.com/mfaerevaag/wd/raw/master/install.sh -O - | sh
```
# yaourt -S zsh-plugin-wd-git ### Manual
#### Manual
* Clone this repo to your liking * Clone this repo to your liking
* Add `wd` function to `.zshrc` (or `.profile` etc.): * Add `wd` function to `.zshrc` (or `.profile` etc.):
```zsh
wd() { wd() {
. ~/path/to/cloned/repo/wd/wd.sh . ~/path/to/cloned/repo/wd/wd.sh
} }
```
* Install manpage. From `wd`'s base directory (requires root permissions): * Install manpage. From `wd`'s base directory (requires root permissions):
# cp wd.1 /usr/share/man/man1/wd.1 ```zsh
# chmod 644 /usr/share/man/man1/wd.1 cp wd.1 /usr/share/man/man1/wd.1
chmod 644 /usr/share/man/man1/wd.1
```
Note, when pulling and updating `wd`, you'll need to do this again in case of changes to the manpage. **Note:** when pulling and updating `wd`, you'll need to do this again in case of changes to the manpage.
## Completion
#### Completion If you're NOT using [oh-my-zsh](https://github.com/robbyrussell/oh-my-zsh) and you want to utilize the zsh-completion feature, you will also need to add the path to your `wd` installation (`~/bin/wd` if you used the automatic installer) to your `fpath`. E.g. in your `~/.zshrc`:
If you're NOT using [oh-my-zsh](https://github.com/ohmyzsh/ohmyzsh) and you want to utilize the zsh-completion feature, you will also need to add the path to your `wd` installation (`~/bin/wd` if you used the automatic installer) to your `fpath`. E.g. in your `~/.zshrc`:
```zsh
fpath=(~/path/to/wd $fpath) fpath=(~/path/to/wd $fpath)
```
Also, you may have to force a rebuild of `zcompdump` by running: Also, you may have to force a rebuild of `zcompdump` by running:
$ rm -f ~/.zcompdump; compinit ```zsh
rm -f ~/.zcompdump; compinit
```
## Usage
### Usage
* Add warp point to current working directory: * Add warp point to current working directory:
$ wd add foo ```zsh
wd add foo
```
If a warp point with the same name exists, use `add!` to overwrite it. If a warp point with the same name exists, use `wd add! foo` to overwrite it.
Note, a warp point cannot contain colons, or only consist of only spaces and dots. The first will conflict in how `wd` stores the warp points, and the second will conflict with other features, as below. **Note:** a warp point cannot contain colons, or consist of only spaces and dots. The first will conflict in how `wd` stores the warp points, and the second will conflict with other features, as below.
You can omit point name to use the current directory's name instead. You can omit point name to automatically use the current directory's name instead.
* From an other directory (not necessarily), warp to `foo` with: * From any directory, warp to `foo` with:
$ wd foo ```zsh
wd foo
```
* You can warp back to previous directory, and so on, with this dot syntax: * You can also warp to a directory within foo, with autocompletion:
$ wd .. ```zsh
$ wd ... wd foo some/inner/path
```
This is a wrapper for the zsh `dirs` function. * You can warp back to previous directory and higher, with this dot syntax:
(You might need `setopt AUTO_PUSHD` in your `.zshrc` if you hare not using [oh-my-zshell](https://github.com/ohmyzsh/ohmyzsh)).
* Remove warp point test point: ```zsh
wd ..
wd ...
```
$ wd rm foo This is a wrapper for the zsh's `dirs` function.
_You might need to add `setopt AUTO_PUSHD` to your `.zshrc` if you are not using [oh-my-zsh](https://github.com/ohmyzsh/ohmyzsh))._
* Remove warp point:
```zsh
wd rm foo
```
You can omit point name to use the current directory's name instead. You can omit point name to use the current directory's name instead.
* List all warp points (stored in `~/.warprc`): * List all warp points (stored in `~/.warprc`):
$ wd list ```zsh
wd list
```
* List files in given warp point: * List files in given warp point:
$ wd ls foo ```zsh
wd ls foo
```
* Show path of given warp point: * Show path of given warp point:
$ wd path foo ```zsh
wd path foo
```
* List warp points to current directory, or optionally, path to given warp point: * List warp points to current directory, or optionally, path to given warp point:
$ wd show ```zsh
wd show
```
* Remove warp points to non-existent directories. * Remove warp points to non-existent directories.
$ wd clean ```zsh
wd clean
```
Use `clean!` to not be prompted with confirmation (force). Use `wd clean!` to not be prompted with confirmation (force).
* Print usage with no opts or the `help` argument: * Print usage info:
$ wd help ```zsh
wd help
```
The usage will be printed also if you call `wd` with no command
* Print the running version of `wd`: * Print the running version of `wd`:
$ wd --version ```zsh
wd --version
```
* Specifically set the config file (default `~/.warprc`), which is useful when testing: * Specifically set the config file (default being `~/.warprc`), which is useful for testing:
$ wd --config ./file <action> ```zsh
wd --config ./file <command>
```
* Force `exit` with return code after running. This is not default, as it will *exit your terminal*, though required when testing/debugging. * Force `exit` with return code after running. This is not default, as it will *exit your terminal*, though required for testing/debugging.
$ wd --debug <action> ```zsh
wd --debug <command>
```
* Silence all output: * Silence all output:
$ wd --quiet <action> ```zsh
wd --quiet <command>
```
## Configuration
### Testing You can configure `wd` with the following environment variables:
`wd` comes with a small test suite, run with [shunit2](https://code.google.com/p/shunit2/). This can be used to confirm that things are working as it should on your setup, or to demonstrate an issue. ### `WD_CONFIG`
Defines the path where warp points get stored. Defaults to `$HOME/.warprc`.
## Testing
`wd` comes with a small test suite, run with [shunit2](https://code.google.com/p/shunit2/). This can be used to confirm that things are working as they should on your setup, or to demonstrate an issue.
To run, simply `cd` into the `test` directory and run the `tests.sh`. To run, simply `cd` into the `test` directory and run the `tests.sh`.
$ ./tests.sh ```zsh
cd ./test
./tests.sh
```
## License
### License The project is licensed under the [MIT license](https://github.com/mfaerevaag/wd/blob/master/LICENSE).
The project is licensed under the [MIT-license](https://github.com/mfaerevaag/wd/blob/master/LICENSE). ## Contributing
If you have issues, feedback or improvements, don't hesitate to report it or submit a pull request. In the case of an issue, we would much appreciate if you would include a failing test in `test/tests.sh`. For an explanation on how to run the tests, read the section "Testing" in this README.
### Finally ----
If you have issues, feedback or improvements, don't hesitate to report it or submit a pull-request. In the case of an issue, we would much appreciate if you would include a failing test in `test/tests.sh`. For an explanation on how to run the tests, read the section "Testing" in this README.
Credit to [altschuler](https://github.com/altschuler) for an awesome idea. Credit to [altschuler](https://github.com/altschuler) for an awesome idea.

View File

@ -1,6 +1,6 @@
#compdef wd #compdef wd
zstyle ':completion:*:descriptions' format '%B%d%b' zstyle ':completion::complete:wd:*:descriptions' format '%B%d%b'
zstyle ':completion::complete:wd:*:commands' group-name commands zstyle ':completion::complete:wd:*:commands' group-name commands
zstyle ':completion::complete:wd:*:warp_points' group-name warp_points zstyle ':completion::complete:wd:*:warp_points' group-name warp_points
zstyle ':completion::complete:wd::' list-grouped zstyle ':completion::complete:wd::' list-grouped
@ -8,13 +8,13 @@ zstyle ':completion::complete:wd::' list-grouped
zmodload zsh/mapfile zmodload zsh/mapfile
function _wd() { function _wd() {
local CONFIG=$HOME/.warprc local WD_CONFIG=${WD_CONFIG:-$HOME/.warprc}
local ret=1 local ret=1
local -a commands local -a commands
local -a warp_points local -a warp_points
warp_points=( "${(f)mapfile[$CONFIG]//$HOME/~}" ) warp_points=( "${(f)mapfile[$WD_CONFIG]//$HOME/~}" )
typeset -A points typeset -A points
while read -r line while read -r line
@ -27,11 +27,12 @@ function _wd() {
target_path=${target_path/#\~/$HOME} target_path=${target_path/#\~/$HOME}
points[$name]=$target_path points[$name]=$target_path
done < $CONFIG done < $WD_CONFIG
commands=( commands=(
'add:Adds the current working directory to your warp points' 'add:Adds the current working directory to your warp points'
'add!:Overwrites existing warp point' 'add!:Overwrites existing warp point'
'export:Export warp points as static named directories'
'rm:Removes the given warp point' 'rm:Removes the given warp point'
'list:Outputs all stored warp points' 'list:Outputs all stored warp points'
'ls:Show files from given warp point' 'ls:Show files from given warp point'
@ -72,8 +73,12 @@ function _wd() {
_describe -t points "Warp points" warp_points && ret=0 _describe -t points "Warp points" warp_points && ret=0
;; ;;
*) *)
if [[ -v points[$target] ]]; then
# complete sub directories from the warp point # complete sub directories from the warp point
_path_files -W "(${points[$target]})" -/ && ret=0 _path_files -W "(${points[$target]})" -/ && ret=0
fi
# don't complete anything if warp point is not valid
;; ;;
esac esac
;; ;;

View File

@ -1,6 +1,9 @@
#!/bin/zsh
# WARP DIRECTORY # WARP DIRECTORY
# ============== # ==============
# oh-my-zsh plugin # Jump to custom directories in terminal
# because `cd` takes too long...
# #
# @github.com/mfaerevaag/wd # @github.com/mfaerevaag/wd

View File

@ -36,11 +36,11 @@ wd_yesorno()
read -r answer read -r answer
case ${answer:=${default}} in case ${answer:=${default}} in
Y|y|YES|yes|Yes ) "Y"|"y"|"YES"|"yes"|"Yes" )
RETVAL=${yes_RETVAL} && \ RETVAL=${yes_RETVAL} && \
break break
;; ;;
N|n|NO|no|No ) "N"|"n"|"NO"|"no"|"No" )
RETVAL=${no_RETVAL} && \ RETVAL=${no_RETVAL} && \
break break
;; ;;
@ -75,6 +75,8 @@ wd_print_usage()
Usage: wd [command] [point] Usage: wd [command] [point]
Commands: Commands:
<point> Warps to the directory specified by the warp point
<point> <path> Warps to the directory specified by the warp point with path appended
add <point> Adds the current working directory to your warp points add <point> Adds the current working directory to your warp points
add Adds the current working directory to your warp points with current directory's name add Adds the current working directory to your warp points with current directory's name
add! <point> Overwrites existing warp point add! <point> Overwrites existing warp point
@ -182,6 +184,8 @@ wd_add()
wd_remove $point > /dev/null wd_remove $point > /dev/null
printf "%q:%s\n" "${point}" "${PWD/#$HOME/~}" >> $WD_CONFIG printf "%q:%s\n" "${point}" "${PWD/#$HOME/~}" >> $WD_CONFIG
wd_export_static_named_directories
wd_print_msg $WD_GREEN "Warp point added" wd_print_msg $WD_GREEN "Warp point added"
# override exit code in case wd_remove did not remove any points # override exit code in case wd_remove did not remove any points
@ -203,8 +207,9 @@ wd_remove()
if [[ ${points[$point]} != "" ]] if [[ ${points[$point]} != "" ]]
then then
local config_tmp=$WD_CONFIG.tmp local config_tmp=$(mktemp "${TMPDIR:-/tmp}/wd.XXXXXXXXXX")
if sed -n "/^${point}:.*$/!p" $WD_CONFIG > $config_tmp && mv $config_tmp $WD_CONFIG # Copy and delete in two steps in order to preserve symlinks
if sed -n "/^${point}:.*$/!p" $WD_CONFIG > $config_tmp && cp $config_tmp $WD_CONFIG && rm $config_tmp
then then
wd_print_msg $WD_GREEN "Warp point removed" wd_print_msg $WD_GREEN "Warp point removed"
else else
@ -334,7 +339,16 @@ wd_clean() {
fi fi
} }
local WD_CONFIG=$HOME/.warprc wd_export_static_named_directories() {
if [[ -z $WD_SKIP_EXPORT ]]
then
grep '^[0-9a-zA-Z_-]\+:' "$WD_CONFIG" | sed -e "s,~,$HOME," -e 's/:/=/' | while read warpdir ; do
hash -d "$warpdir"
done
fi
}
local WD_CONFIG=${WD_CONFIG:-$HOME/.warprc}
local WD_QUIET=0 local WD_QUIET=0
local WD_EXIT_CODE=0 local WD_EXIT_CODE=0
local WD_DEBUG=0 local WD_DEBUG=0
@ -364,6 +378,8 @@ if [ ! -e $WD_CONFIG ]
then then
# if not, create config file # if not, create config file
touch $WD_CONFIG touch $WD_CONFIG
else
wd_export_static_named_directories
fi fi
# load warp points # load warp points
@ -396,52 +412,57 @@ then
else else
# parse rest of options # parse rest of options
for o local wd_o
for wd_o
do do
case "$o" case "$wd_o"
in in
-a|--add|add) "-a"|"--add"|"add")
wd_add false $2 wd_add false $2
break break
;; ;;
-a!|--add!|add!) "-a!"|"--add!"|"add!")
wd_add true $2 wd_add true $2
break break
;; ;;
-r|--remove|rm) "-e"|"export")
wd_export_static_named_directories
break
;;
"-r"|"--remove"|"rm")
wd_remove $2 wd_remove $2
break break
;; ;;
-l|list) "-l"|"list")
wd_list_all wd_list_all
break break
;; ;;
-ls|ls) "-ls"|"ls")
wd_ls $2 wd_ls $2
break break
;; ;;
-p|--path|path) "-p"|"--path"|"path")
wd_path $2 wd_path $2
break break
;; ;;
-h|--help|help) "-h"|"--help"|"help")
wd_print_usage wd_print_usage
break break
;; ;;
-s|--show|show) "-s"|"--show"|"show")
wd_show $2 wd_show $2
break break
;; ;;
-c|--clean|clean) "-c"|"--clean"|"clean")
wd_clean false wd_clean false
break break
;; ;;
-c!|--clean!|clean!) "-c!"|"--clean!"|"clean!")
wd_clean true wd_clean true
break break
;; ;;
*) *)
wd_warp $o $2 wd_warp $wd_o $2
break break
;; ;;
--) --)
@ -466,6 +487,8 @@ unset wd_print_usage
unset wd_alt_config unset wd_alt_config
unset wd_quiet_mode unset wd_quiet_mode
unset wd_print_version unset wd_print_version
unset wd_export_static_named_directories
unset wd_o
unset args unset args
unset points unset points