From 7a3e6bb7da0321f19b141442739ab8d40ad00df2 Mon Sep 17 00:00:00 2001 From: Alpha Chen Date: Wed, 30 Dec 2020 12:23:34 -0800 Subject: [PATCH] fzf additions - `z` for fasd support - `CTRL-G` for git changed files --- runcoms/zshrc | 31 ++++++++++++++++++++++++++++++- 1 file changed, 30 insertions(+), 1 deletion(-) diff --git a/runcoms/zshrc b/runcoms/zshrc index 1a43127..62d93ca 100644 --- a/runcoms/zshrc +++ b/runcoms/zshrc @@ -43,10 +43,39 @@ if [ -e /usr/local/opt/fzf/shell/completion.zsh ]; then fi if [ $commands[fzf] ]; then + export FZF_DEFAULT_OPTS='--height 40% --layout=reverse --border' export FZF_DEFAULT_COMMAND="rg --files" export FZF_CTRL_T_COMMAND="$FZF_DEFAULT_COMMAND" export FZF_ALT_C_COMMAND="find . -type d" - alias fzf=fzf-tmux + # alias fzf=fzf-tmux + + z() { + [ $# -gt 0 ] && fasd_cd -d "$*" && return + local dir + dir="$(fasd -Rdl "$1" | fzf -1 -0 --no-sort +m)" && cd "${dir}" || return 1 + } + + # CTRL-G + __fgit() { + local cmd="git status --porcelain | awk '{ print \$2 }'" + setopt localoptions pipefail no_aliases 2> /dev/null + local item + eval "$cmd" | FZF_DEFAULT_OPTS="--height ${FZF_TMUX_HEIGHT:-40%} --reverse $FZF_DEFAULT_OPTS" $(__fzfcmd) -m "$@" | while read item; do + echo -n "${(q)item} " + done + local ret=$? + echo + return $ret + } + + fzf-git-widget() { + LBUFFER="${LBUFFER}$(__fgit)" + local ret=$? + zle reset-prompt + return $ret + } + zle -N fzf-git-widget + bindkey '^G' fzf-git-widget fi [[ -s "$HOME/.zshrc.local" ]] && . "$HOME/.zshrc.local"