zoxide/templates/bash.txt

138 lines
3.5 KiB
Plaintext
Raw Normal View History

2021-04-08 18:35:42 +00:00
{%- let section = "# =============================================================================\n#" -%}
{%- let not_configured = "# -- not configured --" -%}
2020-10-18 09:22:13 +00:00
2021-04-08 18:35:42 +00:00
{{ section }}
2020-10-18 09:22:13 +00:00
# Utility functions for zoxide.
#
# pwd based on the value of _ZO_RESOLVE_SYMLINKS.
function __zoxide_pwd() {
{%- if resolve_symlinks %}
2021-01-28 19:42:31 +00:00
\builtin pwd -P
2020-10-18 09:22:13 +00:00
{%- else %}
2021-01-28 19:42:31 +00:00
\builtin pwd -L
2020-10-18 09:22:13 +00:00
{%- endif %}
}
# cd + custom logic based on the value of _ZO_ECHO.
function __zoxide_cd() {
# shellcheck disable=SC2164
2021-01-28 19:42:31 +00:00
\builtin cd "$@" {%- if echo %} && __zoxide_pwd {%- endif %}
2020-10-18 09:22:13 +00:00
}
2021-04-08 18:35:42 +00:00
{{ section }}
2020-10-18 09:22:13 +00:00
# Hook configuration for zoxide.
#
2021-04-28 19:53:43 +00:00
{# Custom prompts often use "$?" to show the exit status of the previous
# command. Adding __zoxide_hook to the front of $PROMPT_COMMAND would change
# the exit status, so we must capture it and return it manually instead. -#}
2020-10-18 09:22:13 +00:00
# Hook to add new entries to the database.
{%- match hook %}
{%- when Hook::None %}
2021-04-08 18:35:42 +00:00
{{ not_configured }}
2020-10-18 09:22:13 +00:00
{%- when Hook::Prompt %}
function __zoxide_hook() {
2021-04-28 19:53:43 +00:00
\builtin local -r __zoxide_retval="$?"
zoxide add -- "$(__zoxide_pwd)"
2021-04-28 19:53:43 +00:00
return "${__zoxide_retval}"
2020-10-18 09:22:13 +00:00
}
{%- when Hook::Pwd %}
function __zoxide_hook() {
2021-04-28 19:53:43 +00:00
\builtin local -r __zoxide_retval="$?"
2021-01-28 19:42:31 +00:00
\builtin local -r __zoxide_pwd_tmp="$(__zoxide_pwd)"
2020-11-11 12:53:37 +00:00
if [ -z "${__zoxide_pwd_old}" ]; then
__zoxide_pwd_old="${__zoxide_pwd_tmp}"
elif [ "${__zoxide_pwd_old}" != "${__zoxide_pwd_tmp}" ]; then
__zoxide_pwd_old="${__zoxide_pwd_tmp}"
zoxide add -- "${__zoxide_pwd_old}"
2020-10-18 09:22:13 +00:00
fi
2021-04-28 19:53:43 +00:00
return "${__zoxide_retval}"
2020-10-18 09:22:13 +00:00
}
2021-04-08 18:35:42 +00:00
2020-10-18 09:22:13 +00:00
{%- endmatch %}
2021-04-28 19:53:43 +00:00
{# bash throws an error if $PROMPT_COMMAND contains two semicolons in sequence.
# This is hard to avoid perfectly, but adding __zoxide_hook to the front of
# $PROMPT_COMMAND rather than the back makes this scenario unlikely. -#}
2020-10-18 09:22:13 +00:00
# Initialize hook.
if [ "${__zoxide_hooked}" != '1' ]; then
__zoxide_hooked='1'
2021-04-08 18:35:42 +00:00
{%- if hook == Hook::None %}
{{ not_configured }}
{%- else %}
PROMPT_COMMAND="__zoxide_hook;${PROMPT_COMMAND:+${PROMPT_COMMAND}}"
2021-04-08 18:35:42 +00:00
{%- endif %}
fi
2020-10-18 09:22:13 +00:00
2021-04-08 18:35:42 +00:00
{{ section }}
2020-10-18 09:22:13 +00:00
# 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
2020-11-11 12:53:37 +00:00
if [ -n "${OLDPWD}" ]; then
__zoxide_cd "${OLDPWD}"
2020-10-18 09:22:13 +00:00
else
2020-11-11 12:53:37 +00:00
# shellcheck disable=SC2016
\builtin printf 'zoxide: $OLDPWD is not set\n'
2020-10-18 09:22:13 +00:00
return 1
fi
2020-11-10 19:11:26 +00:00
elif [ "$#" -eq 1 ] && [ -d "$1" ]; then
__zoxide_cd "$1"
2020-10-18 09:22:13 +00:00
else
2021-01-28 19:42:31 +00:00
\builtin local __zoxide_result
__zoxide_result="$(zoxide query --exclude "$(__zoxide_pwd)" -- "$@")" && __zoxide_cd "${__zoxide_result}"
2020-10-18 09:22:13 +00:00
fi
}
# Jump to a directory using interactive search.
function __zoxide_zi() {
2021-01-28 19:42:31 +00:00
\builtin local __zoxide_result
2020-11-11 12:53:37 +00:00
__zoxide_result="$(zoxide query -i -- "$@")" && __zoxide_cd "${__zoxide_result}"
2020-10-18 09:22:13 +00:00
}
2021-04-08 18:35:42 +00:00
{{ section }}
2020-10-18 09:22:13 +00:00
# Convenient aliases for zoxide. Disable these using --no-aliases.
#
{%- match cmd %}
{%- when Some with (cmd) %}
# Remove definitions.
function __zoxide_unset() {
# shellcheck disable=SC1001
2021-03-01 06:10:10 +00:00
\builtin unset -f "$@" &>/dev/null
# shellcheck disable=SC1001
2021-03-01 06:10:10 +00:00
\builtin unset -v "$@" &>/dev/null
}
__zoxide_unset '{{cmd}}'
function {{cmd}}() {
__zoxide_z "$@"
}
__zoxide_unset '{{cmd}}i'
function {{cmd}}i() {
__zoxide_zi "$@"
}
2020-10-18 09:22:13 +00:00
{%- when None %}
2021-04-08 18:35:42 +00:00
{{ not_configured }}
2020-10-18 09:22:13 +00:00
{%- endmatch %}
2021-04-08 18:35:42 +00:00
{{ section }}
2021-04-27 12:07:38 +00:00
# To initialize zoxide, add this to your configuration (usually ~/.bashrc):
2020-10-18 09:22:13 +00:00
#
# eval "$(zoxide init bash)"