mirror of https://git.xinb.cc/xinb/ohmyzsh.git
feat(wd): update to v0.9.2 (#12820)
Co-authored-by: ohmyzsh[bot] <54982679+ohmyzsh[bot]@users.noreply.github.com>
This commit is contained in:
parent
ccbe504f22
commit
366d254352
|
@ -28,7 +28,7 @@ dependencies:
|
||||||
plugins/wd:
|
plugins/wd:
|
||||||
repo: mfaerevaag/wd
|
repo: mfaerevaag/wd
|
||||||
branch: master
|
branch: master
|
||||||
version: tag:v0.9.1
|
version: tag:v0.9.2
|
||||||
precopy: |
|
precopy: |
|
||||||
set -e
|
set -e
|
||||||
rm -r test
|
rm -r test
|
||||||
|
|
|
@ -8,7 +8,7 @@
|
||||||
# @github.com/mfaerevaag/wd
|
# @github.com/mfaerevaag/wd
|
||||||
|
|
||||||
# version
|
# version
|
||||||
readonly WD_VERSION=0.9.1
|
readonly WD_VERSION=0.9.2
|
||||||
|
|
||||||
# colors
|
# colors
|
||||||
readonly WD_BLUE="\033[96m"
|
readonly WD_BLUE="\033[96m"
|
||||||
|
@ -145,14 +145,17 @@ wd_warp()
|
||||||
else
|
else
|
||||||
(( n = $#1 - 1 ))
|
(( n = $#1 - 1 ))
|
||||||
cd -$n > /dev/null
|
cd -$n > /dev/null
|
||||||
|
WD_EXIT_CODE=$?
|
||||||
fi
|
fi
|
||||||
elif [[ ${points[$point]} != "" ]]
|
elif [[ ${points[$point]} != "" ]]
|
||||||
then
|
then
|
||||||
if [[ $sub != "" ]]
|
if [[ $sub != "" ]]
|
||||||
then
|
then
|
||||||
cd ${points[$point]/#\~/$HOME}/$sub
|
cd ${points[$point]/#\~/$HOME}/$sub
|
||||||
|
WD_EXIT_CODE=$?
|
||||||
else
|
else
|
||||||
cd ${points[$point]/#\~/$HOME}
|
cd ${points[$point]/#\~/$HOME}
|
||||||
|
WD_EXIT_CODE=$?
|
||||||
fi
|
fi
|
||||||
else
|
else
|
||||||
wd_exit_fail "Unknown warp point '${point}'"
|
wd_exit_fail "Unknown warp point '${point}'"
|
||||||
|
@ -185,11 +188,11 @@ wd_add()
|
||||||
elif [[ ${points[$point]} == "" ]] || [ ! -z "$force" ]
|
elif [[ ${points[$point]} == "" ]] || [ ! -z "$force" ]
|
||||||
then
|
then
|
||||||
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_file"
|
||||||
if (whence sort >/dev/null); then
|
if (whence sort >/dev/null); then
|
||||||
local config_tmp=$(mktemp "${TMPDIR:-/tmp}/wd.XXXXXXXXXX")
|
local config_tmp=$(mktemp "${TMPDIR:-/tmp}/wd.XXXXXXXXXX")
|
||||||
# use 'cat' below to ensure we respect $WD_CONFIG as a symlink
|
# use 'cat' below to ensure we respect $wd_config_file as a symlink
|
||||||
command sort -o "${config_tmp}" "$WD_CONFIG" && command cat "${config_tmp}" >| "$WD_CONFIG" && command rm "${config_tmp}"
|
command sort -o "${config_tmp}" "$wd_config_file" && command cat "${config_tmp}" >| "$wd_config_file" && command rm "${config_tmp}"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
wd_export_static_named_directories
|
wd_export_static_named_directories
|
||||||
|
@ -240,7 +243,7 @@ wd_remove()
|
||||||
then
|
then
|
||||||
local config_tmp=$(mktemp "${TMPDIR:-/tmp}/wd.XXXXXXXXXX")
|
local config_tmp=$(mktemp "${TMPDIR:-/tmp}/wd.XXXXXXXXXX")
|
||||||
# Copy and delete in two steps in order to preserve symlinks
|
# Copy and delete in two steps in order to preserve symlinks
|
||||||
if sed -n "/^${point_name}:.*$/!p" "$WD_CONFIG" >| "$config_tmp" && command cp "$config_tmp" "$WD_CONFIG" && command rm "$config_tmp"
|
if sed -n "/^${point_name}:.*$/!p" "$wd_config_file" >| "$config_tmp" && command cp "$config_tmp" "$wd_config_file" && command rm "$config_tmp"
|
||||||
then
|
then
|
||||||
wd_print_msg "$WD_GREEN" "Warp point removed"
|
wd_print_msg "$WD_GREEN" "Warp point removed"
|
||||||
else
|
else
|
||||||
|
@ -257,7 +260,7 @@ wd_browse() {
|
||||||
echo "This functionality requires fzf. Please install fzf first."
|
echo "This functionality requires fzf. Please install fzf first."
|
||||||
return 1
|
return 1
|
||||||
fi
|
fi
|
||||||
local entries=("${(@f)$(sed "s:${HOME}:~:g" "$WD_CONFIG" | awk -F ':' '{print $1 " -> " $2}')}")
|
local entries=("${(@f)$(sed "s:${HOME}:~:g" "$wd_config_file" | awk -F ':' '{print $1 " -> " $2}')}")
|
||||||
local script_path="${${(%):-%x}:h}"
|
local script_path="${${(%):-%x}:h}"
|
||||||
local wd_remove_output=$(mktemp "${TMPDIR:-/tmp}/wd.XXXXXXXXXX")
|
local wd_remove_output=$(mktemp "${TMPDIR:-/tmp}/wd.XXXXXXXXXX")
|
||||||
entries=("All warp points:" "Press enter to select. Press delete to remove" "${entries[@]}")
|
entries=("All warp points:" "Press enter to select. Press delete to remove" "${entries[@]}")
|
||||||
|
@ -275,7 +278,7 @@ wd_browse() {
|
||||||
}
|
}
|
||||||
|
|
||||||
wd_browse_widget() {
|
wd_browse_widget() {
|
||||||
if [[ -e $WD_CONFIG ]]; then
|
if [[ -e $wd_config_file ]]; then
|
||||||
wd_browse
|
wd_browse
|
||||||
saved_buffer=$BUFFER
|
saved_buffer=$BUFFER
|
||||||
saved_cursor=$CURSOR
|
saved_cursor=$CURSOR
|
||||||
|
@ -298,7 +301,7 @@ wd_list_all()
|
||||||
{
|
{
|
||||||
wd_print_msg "$WD_BLUE" "All warp points:"
|
wd_print_msg "$WD_BLUE" "All warp points:"
|
||||||
|
|
||||||
entries=$(sed "s:${HOME}:~:g" "$WD_CONFIG")
|
entries=$(sed "s:${HOME}:~:g" "$wd_config_file")
|
||||||
|
|
||||||
max_warp_point_length=0
|
max_warp_point_length=0
|
||||||
while IFS= read -r line
|
while IFS= read -r line
|
||||||
|
@ -398,7 +401,7 @@ wd_clean() {
|
||||||
count=$((count+1))
|
count=$((count+1))
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
done < "$WD_CONFIG"
|
done < "$wd_config_file"
|
||||||
|
|
||||||
if [[ $count -eq 0 ]]
|
if [[ $count -eq 0 ]]
|
||||||
then
|
then
|
||||||
|
@ -406,7 +409,7 @@ wd_clean() {
|
||||||
else
|
else
|
||||||
if [ ! -z "$force" ] || wd_yesorno "Removing ${count} warp points. Continue? (y/n)"
|
if [ ! -z "$force" ] || wd_yesorno "Removing ${count} warp points. Continue? (y/n)"
|
||||||
then
|
then
|
||||||
echo "$wd_tmp" >! "$WD_CONFIG"
|
echo "$wd_tmp" >! "$wd_config_file"
|
||||||
wd_print_msg "$WD_GREEN" "Cleanup complete. ${count} warp point(s) removed"
|
wd_print_msg "$WD_GREEN" "Cleanup complete. ${count} warp point(s) removed"
|
||||||
else
|
else
|
||||||
wd_print_msg "$WD_BLUE" "Cleanup aborted"
|
wd_print_msg "$WD_BLUE" "Cleanup aborted"
|
||||||
|
@ -417,7 +420,7 @@ wd_clean() {
|
||||||
wd_export_static_named_directories() {
|
wd_export_static_named_directories() {
|
||||||
if [[ ! -z $WD_EXPORT ]]
|
if [[ ! -z $WD_EXPORT ]]
|
||||||
then
|
then
|
||||||
command grep '^[0-9a-zA-Z_-]\+:' "$WD_CONFIG" | sed -e "s,~,$HOME," -e 's/:/=/' | while read -r warpdir ; do
|
command grep '^[0-9a-zA-Z_-]\+:' "$wd_config_file" | sed -e "s,~,$HOME," -e 's/:/=/' | while read -r warpdir ; do
|
||||||
hash -d "$warpdir"
|
hash -d "$warpdir"
|
||||||
done
|
done
|
||||||
fi
|
fi
|
||||||
|
@ -442,16 +445,19 @@ then
|
||||||
echo "wd version $WD_VERSION"
|
echo "wd version $WD_VERSION"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
# set the config file from variable or default
|
||||||
|
typeset wd_config_file=${WD_CONFIG:-$HOME/.warprc}
|
||||||
if [[ ! -z $wd_alt_config ]]
|
if [[ ! -z $wd_alt_config ]]
|
||||||
then
|
then
|
||||||
WD_CONFIG=$wd_alt_config[2]
|
# prefer the flag if provided
|
||||||
|
wd_config_file=$wd_alt_config[2]
|
||||||
fi
|
fi
|
||||||
|
|
||||||
# check if config file exists
|
# check if config file exists
|
||||||
if [ ! -e "$WD_CONFIG" ]
|
if [ ! -e "$wd_config_file" ]
|
||||||
then
|
then
|
||||||
# if not, create config file
|
# if not, create config file
|
||||||
touch "$WD_CONFIG"
|
touch "$wd_config_file"
|
||||||
else
|
else
|
||||||
wd_export_static_named_directories
|
wd_export_static_named_directories
|
||||||
fi
|
fi
|
||||||
|
@ -473,7 +479,7 @@ do
|
||||||
val=${(j,:,)arr[2,-1]}
|
val=${(j,:,)arr[2,-1]}
|
||||||
|
|
||||||
points[$key]=$val
|
points[$key]=$val
|
||||||
done < "$WD_CONFIG"
|
done < "$wd_config_file"
|
||||||
|
|
||||||
# get opts
|
# get opts
|
||||||
args=$(getopt -o a:r:c:lhs -l add:,rm:,clean,list,ls:,path:,help,show -- $*)
|
args=$(getopt -o a:r:c:lhs -l add:,rm:,clean,list,ls:,path:,help,show -- $*)
|
||||||
|
@ -484,11 +490,11 @@ then
|
||||||
wd_print_usage
|
wd_print_usage
|
||||||
|
|
||||||
# check if config file is writeable
|
# check if config file is writeable
|
||||||
elif [ ! -w "$WD_CONFIG" ]
|
elif [ ! -w "$wd_config_file" ]
|
||||||
then
|
then
|
||||||
# do nothing
|
# do nothing
|
||||||
# can't run `exit`, as this would exit the executing shell
|
# can't run `exit`, as this would exit the executing shell
|
||||||
wd_exit_fail "\'$WD_CONFIG\' is not writeable."
|
wd_exit_fail "\'$wd_config_file\' is not writeable."
|
||||||
|
|
||||||
else
|
else
|
||||||
# parse rest of options
|
# parse rest of options
|
||||||
|
@ -572,8 +578,10 @@ unset wd_print_msg
|
||||||
unset wd_yesorno
|
unset wd_yesorno
|
||||||
unset wd_print_usage
|
unset wd_print_usage
|
||||||
unset wd_alt_config
|
unset wd_alt_config
|
||||||
|
unset wd_config_file
|
||||||
unset wd_quiet_mode
|
unset wd_quiet_mode
|
||||||
unset wd_print_version
|
unset wd_print_version
|
||||||
|
unset wd_force_mode
|
||||||
unset wd_export_static_named_directories
|
unset wd_export_static_named_directories
|
||||||
unset wd_o
|
unset wd_o
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue