{%- 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 %} \builtin pwd -P {%- else %} \builtin pwd -L {%- endif %} } # cd + custom logic based on the value of _ZO_ECHO. function __zoxide_cd() { \builtin 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. if [ "${__zoxide_hooked}" != '1' ]; then __zoxide_hooked='1' {%- match hook %} {%- when Hook::None %} {{ NOT_CONFIGURED }} {%- when Hook::Prompt %} precmd_functions+=(__zoxide_hook) {%- when Hook::Pwd %} chpwd_functions=(${chpwd_functions[@]} "__zoxide_hook") {%- endmatch %} fi {{ 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 \builtin printf 'zoxide: $OLDPWD is not set' return 1 fi elif [ "$#" -eq 1 ] && [ -d "$1" ]; then __zoxide_cd "$1" else \builtin local __zoxide_result __zoxide_result="$(zoxide query -- "$@")" && __zoxide_cd "$__zoxide_result" fi } # Jump to a directory using interactive search. function __zoxide_zi() { \builtin 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() { \builtin unalias "$@" &>/dev/null \builtin unfunction "$@" &>/dev/null \builtin unset "$@" &>/dev/null } __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)"