diff --git a/shell/key-bindings.bash b/shell/key-bindings.bash index a290e4ca..b132b179 100644 --- a/shell/key-bindings.bash +++ b/shell/key-bindings.bash @@ -41,7 +41,7 @@ __fzf_cd__() { opts="--height ${FZF_TMUX_HEIGHT:-40%} --bind=ctrl-z:ignore --reverse --walker=dir,follow,hidden --scheme=path ${FZF_DEFAULT_OPTS-} ${FZF_ALT_C_OPTS-} +m" dir=$( FZF_DEFAULT_COMMAND=${FZF_ALT_C_COMMAND:-} FZF_DEFAULT_OPTS="$opts" $(__fzfcmd) - ) && printf 'builtin cd -- %q' "$dir" + ) && printf 'builtin cd -- %q' "$(builtin unset CDPATH && builtin cd -- "$dir" && builtin pwd)" } if command -v perl > /dev/null; then diff --git a/shell/key-bindings.zsh b/shell/key-bindings.zsh index 51aa6ea0..3614dd43 100644 --- a/shell/key-bindings.zsh +++ b/shell/key-bindings.zsh @@ -78,7 +78,7 @@ fzf-cd-widget() { return 0 fi zle push-line # Clear buffer. Auto-restored on next prompt. - BUFFER="builtin cd -- ${(q)dir}" + BUFFER="builtin cd -- ${(q)dir:a}" zle accept-line local ret=$? unset dir # ensure this doesn't end up appearing in prompt expansion