zoxide/templates/zsh.txt
2020-10-27 00:11:40 +05:30

160 lines
3.2 KiB
Plaintext

{%- let SECTION = "# =============================================================================\n#" -%}
{%- let NOT_CONFIGURED = "# -- not configured --" -%}
{{ SECTION }}
# Utility functions for zoxide.
#
# pwd based on the value of _ZO_RESOLVE_SYMLINKS.
function __zoxide_pwd() {
{%- if resolve_symlinks %}
pwd -P
{%- else %}
pwd -L
{%- endif %}
}
# cd + custom logic based on the value of _ZO_ECHO.
function __zoxide_cd() {
cd "$@" {%- if echo %} && __zoxide_pwd {%- endif %}
}
{{ SECTION }}
# Hook configuration for zoxide.
#
# Hook to add new entries to the database.
function __zoxide_hook() {
zoxide add "$(__zoxide_pwd)"
}
# Initialize hook.
{%- match hook %}
{%- when Hook::None %}
{{ NOT_CONFIGURED }}
{%- when Hook::Prompt %}
[[ -n "${precmd_functions[(r)__zoxide_hook]}" ]] || {
precmd_functions+=(__zoxide_hook)
}
{%- when Hook::Pwd %}
chpwd_functions=(${chpwd_functions[@]} "__zoxide_hook")
{%- endmatch %}
{{ SECTION }}
# When using zoxide with --no-aliases, alias these internal functions as
# desired.
#
# Jump to a directory using only keywords.
function __zoxide_z() {
if [ "$#" -eq 0 ]; then
__zoxide_cd ~
elif [ "$#" -eq 1 ] && [ "$1" = '-' ]; then
if [ -n "$OLDPWD" ]; then
__zoxide_cd "$OLDPWD"
else
echo "zoxide: \\$OLDPWD is not set"
return 1
fi
elif [ "$#" -eq 1 ] && [ -d "$1" ]; then
__zoxide_cd "$1"
else
local __zoxide_result
__zoxide_result="$(zoxide query -- "$@")" && __zoxide_cd "$__zoxide_result"
fi
}
# Jump to a directory using interactive search.
function __zoxide_zi() {
local __zoxide_result
__zoxide_result="$(zoxide query -i -- "$@")" && __zoxide_cd "$__zoxide_result"
}
# Add a new entry to the database.
function __zoxide_za() {
zoxide add "$@"
}
# Query an entry from the database using only keywords.
function __zoxide_zq() {
zoxide query "$@"
}
# Query an entry from the database using interactive selection.
function __zoxide_zqi() {
zoxide query -i "$@"
}
# Remove an entry from the database using the exact path.
function __zoxide_zr() {
zoxide remove "$@"
}
# Remove an entry from the database using interactive selection.
function __zoxide_zri() {
zoxide remove -i "$@"
}
{{ SECTION }}
# Convenient aliases for zoxide. Disable these using --no-aliases.
#
{%- match cmd %}
{%- when Some with (cmd) %}
# Remove definitions.
function __zoxide_unset() {
\unalias "$@" &>{{ Opts::DEVNULL }}
\unfunction "$@" &>{{ Opts::DEVNULL }}
\unset "$@" &>{{ Opts::DEVNULL }}
}
__zoxide_unset '{{cmd}}'
function {{cmd}}() {
__zoxide_z "$@"
}
__zoxide_unset '{{cmd}}i'
function {{cmd}}i() {
__zoxide_zi "$@"
}
__zoxide_unset '{{cmd}}a'
function {{cmd}}a() {
__zoxide_za "$@"
}
__zoxide_unset '{{cmd}}q'
function {{cmd}}q() {
__zoxide_zq "$@"
}
__zoxide_unset '{{cmd}}qi'
function {{cmd}}qi() {
__zoxide_zqi "$@"
}
__zoxide_unset '{{cmd}}r'
function {{cmd}}r() {
__zoxide_zr "$@"
}
__zoxide_unset '{{cmd}}ri'
function {{cmd}}ri() {
__zoxide_zri "$@"
}
{%- when None %}
{{ NOT_CONFIGURED }}
{%- endmatch %}
{{ SECTION }}
# To initialize zoxide with zsh, add the following line to your zsh
# configuration file (usually ~/.zshrc):
#
# eval "$(zoxide init zsh)"