From b2da4438084d40faa9ad6d45393c3d86a37cb5cb Mon Sep 17 00:00:00 2001 From: ryoya ito <30540303+ry-itto@users.noreply.github.com> Date: Thu, 13 Mar 2025 16:00:42 +0900 Subject: [PATCH] update --- .config/nvim/autoload/plugins/nvim_lsp.vim | 111 +++++++ .config/nvim/coc-settings.json | 10 - .gitconfig | 2 +- .vim/rc/dein.toml | 5 +- .vim/rc/dein_lazy.toml | 21 ++ .zsh/env.zsh | 13 +- .zsh/functions/functions.zsh | 1 + .zsh/functions/fzf-git.sh | 329 +++++++++++++++++++++ .zsh/functions/git.zsh | 6 +- 9 files changed, 475 insertions(+), 23 deletions(-) create mode 100644 .config/nvim/autoload/plugins/nvim_lsp.vim delete mode 100644 .config/nvim/coc-settings.json create mode 100644 .zsh/functions/fzf-git.sh diff --git a/.config/nvim/autoload/plugins/nvim_lsp.vim b/.config/nvim/autoload/plugins/nvim_lsp.vim new file mode 100644 index 0000000..3c7f856 --- /dev/null +++ b/.config/nvim/autoload/plugins/nvim_lsp.vim @@ -0,0 +1,111 @@ +function! plugins#nvim_lsp#load() +lua << EOF + local lsp_status = require('lsp-status') + + lsp_status.config({ + current_function = false, + show_filename = false, + select_symbol = function(cursor_pos, document_symbol) + return false + end, + spinner_frames = {'', '', '', '', ''}, + indicator_errors = '', + indicator_warnings = '', + indicator_info = '', + indicator_hint = '', + indicator_ok = '', + update_interval = 100, + }) + + lsp_status.register_progress() + + local mason = require("mason") + + mason.setup({}) + + local on_attach = function(client, bufnr) + local function buf_set_keymap(...) vim.api.nvim_buf_set_keymap(bufnr, ...) end + local function buf_set_option(...) vim.api.nvim_buf_set_option(bufnr, ...) end + + local opts = { noremap=true, silent=true } + + buf_set_keymap('n', 'gD', 'lua vim.lsp.buf.declaration()', opts) + buf_set_keymap('n', 'K', 'lua vim.lsp.buf.hover()', opts) + buf_set_keymap('n', 'gi', 'lua vim.lsp.buf.implementation()', opts) + buf_set_keymap('n', ',r', 'lua vim.lsp.buf.rename()', opts) + buf_set_keymap('n', '', 'lua vim.diagnostic.goto_prev()', opts) + buf_set_keymap('n', '', 'lua vim.diagnostic.goto_next()', opts) + buf_set_keymap("n", "f", "lua vim.lsp.buf.format()", opts) + + lsp_status.on_attach(client) + end + + local capabilities = require('cmp_nvim_lsp').default_capabilities(vim.lsp.protocol.make_client_capabilities()) + capabilities = vim.tbl_extend('keep', capabilities, lsp_status.capabilities) + capabilities.offsetEncoding = { "utf-16" } + + local util = require("lspconfig/util") + + require("flutter-tools").setup { + ui = { + border = "none", + }, + decorations = { + statusline = { + app_version = false, + device = false, + } + }, + debugger = { + enabled = false, + run_via_dap = false, + }, + widget_guides = { + enabled = true, + }, + closing_tags = { + highlight = "ClosingTags", + prefix = " ", + enabled = true + }, + dev_log = { + enabled = true, + open_cmd = "tabedit", + }, + dev_tools = { + autostart = false, + auto_open_browser = false, + }, + outline = { + open_cmd = "30vnew", + auto_open = false + }, + flutter_lookup_cmd = "asdf where flutter", + lsp = { + on_attach = function(client, bufnr) + vim.cmd [[hi FlutterWidgetGuides ctermfg=237 guifg=#33374c]] + vim.cmd [[hi ClosingTags ctermfg=244 guifg=#8389a3]] + on_attach(client, bufnr) + end, + capabilities = capabilities, + settings = { + showTodos = false, + completeFunctionCalls = true, + analysisExcludedFolders = { + vim.fn.expand("$HOME/.pub-cache"), + vim.fn.expand("$HOME/fvm"), + } + } + } + } + + vim.diagnostic.config({ + virtual_text = { + prefix = '✔︎', + }, + signs = false, + underline = false, + }) +EOF + +endfunction diff --git a/.config/nvim/coc-settings.json b/.config/nvim/coc-settings.json deleted file mode 100644 index 6724d5b..0000000 --- a/.config/nvim/coc-settings.json +++ /dev/null @@ -1,10 +0,0 @@ -{ - "coc.preferences.formatOnSaveFiletypes" : [ - "dart", - "rust" - ], - "flutter.openDevLogSplitCommand" : "botright 10split", - "flutter.autoOpenDevLog" : true, - "flutter.autoHideDevLog" : true, - "dart.lineLength" : 100 -} diff --git a/.gitconfig b/.gitconfig index 2a64851..262b85e 100644 --- a/.gitconfig +++ b/.gitconfig @@ -1,7 +1,7 @@ [commit] template=~/.commit_template [user] - email = ry.itto.github@gmail.com + email = 30540303+ry-itto@users.noreply.github.com name = ryoya ito [core] excludesfile = ~/.gitignore_global diff --git a/.vim/rc/dein.toml b/.vim/rc/dein.toml index 8822159..d2a2e12 100644 --- a/.vim/rc/dein.toml +++ b/.vim/rc/dein.toml @@ -43,8 +43,7 @@ hook_add = ''' # Dev unitilities [[plugins]] -repo = 'neoclide/coc.nvim' -rev = 'release' +repo = 'airblade/vim-gitgutter' [[plugins]] -repo = 'airblade/vim-gitgutter' +repo = 'github/copilot.vim' diff --git a/.vim/rc/dein_lazy.toml b/.vim/rc/dein_lazy.toml index bb268ec..02f6576 100644 --- a/.vim/rc/dein_lazy.toml +++ b/.vim/rc/dein_lazy.toml @@ -16,3 +16,24 @@ on_ft = ['toml'] [[plugins]] repo = 'dart-lang/dart-vim-plugin' on_ft = ['dart'] + +[[plugins]] +repo = 'nvim-treesitter/nvim-treesitter' +on_ft = ['pkl'] + +[[plugins]] +repo = 'apple/pkl-neovim' +on_ft = ['pkl'] + +# Flutter +[[plugins]] +repo = 'akinsho/flutter-tools.nvim' +on_ft = ['dart'] +depends = ['plenary.nvim', 'dressing.nvim'] + +[[plugins]] +repo = 'nvim-lua/plenary.nvim' + +[[plugins]] +repo = 'stevearc/dressing.nvim' + diff --git a/.zsh/env.zsh b/.zsh/env.zsh index 851ba53..78a68e6 100644 --- a/.zsh/env.zsh +++ b/.zsh/env.zsh @@ -38,10 +38,6 @@ CFLAGS="-I$(brew --prefix readline)/include -I$(brew --prefix openssl)/include - LDFLAGS="-L$(brew --prefix readline)/lib -L$(brew --prefix openssl)/lib" PYTHON_CONFIGURE_OPTS=--enable-unicode=ucs2 -# flutter sdk -export PATH=$PATH:$HOME/fvm/default/bin -export FLUTTER_ROOT=$HOME/fvm/default/bin - # mysql path export PATH=$PATH:/usr/local/mysql/bin @@ -69,6 +65,9 @@ export FZF_DEFAULT_COMMAND='ag -g ""' # Visual Studio Code (code) export PATH="$PATH:/Applications/Visual\ Studio\ Code.app/Contents/Resources/app/bin" +# nest +export PATH="$PATH:$HOME/.nest/bin" + # Starship eval "$(starship init zsh)" export STARSHIP_CONFIG="$HOME/.config/starship.toml" @@ -115,5 +114,11 @@ eval "$(pyenv init -)" . "$HOME/.asdf/asdf.sh" fpath=(${ASDF_DIR}/completions $fpath) +# flutter sdk +export FLUTTER_ROOT="$(asdf where flutter)" + # emacs風キーバインドの復活 bindkey -e + +# Android environment variables +export ANDROID_SDK_ROOT=$HOME/Library/Android/sdk diff --git a/.zsh/functions/functions.zsh b/.zsh/functions/functions.zsh index 298388e..64dc70a 100644 --- a/.zsh/functions/functions.zsh +++ b/.zsh/functions/functions.zsh @@ -1,3 +1,4 @@ +source $HOME/.zsh/functions/fzf-git.sh source $HOME/.zsh/functions/git.zsh source $HOME/.zsh/functions/github.zsh source $HOME/.zsh/functions/ghq.zsh diff --git a/.zsh/functions/fzf-git.sh b/.zsh/functions/fzf-git.sh new file mode 100644 index 0000000..a394849 --- /dev/null +++ b/.zsh/functions/fzf-git.sh @@ -0,0 +1,329 @@ +# The MIT License (MIT) +# +# Copyright (c) 2024 Junegunn Choi +# +# Permission is hereby granted, free of charge, to any person obtaining a copy +# of this software and associated documentation files (the "Software"), to deal +# in the Software without restriction, including without limitation the rights +# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell +# copies of the Software, and to permit persons to whom the Software is +# furnished to do so, subject to the following conditions: +# +# The above copyright notice and this permission notice shall be included in +# all copies or substantial portions of the Software. +# +# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR +# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, +# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE +# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER +# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, +# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN +# THE SOFTWARE. + +# shellcheck disable=SC2039 +[[ $0 = - ]] && return + +__fzf_git_color() { + if [[ -n $NO_COLOR ]]; then + echo never + elif [[ $# -gt 0 ]] && [[ -n $FZF_GIT_PREVIEW_COLOR ]]; then + echo "$FZF_GIT_PREVIEW_COLOR" + else + echo "${FZF_GIT_COLOR:-always}" + fi +} + +__fzf_git_cat() { + if [[ -n $FZF_GIT_CAT ]]; then + echo "$FZF_GIT_CAT" + return + fi + + # Sometimes bat is installed as batcat + _fzf_git_bat_options="--style='${BAT_STYLE:-full}' --color=$(__fzf_git_color .) --pager=never" + if command -v batcat > /dev/null; then + echo "batcat $_fzf_git_bat_options" + elif command -v bat > /dev/null; then + echo "bat $_fzf_git_bat_options" + else + echo cat + fi +} + +__fzf_git_pager() { + local pager + pager="${FZF_GIT_PAGER:-${GIT_PAGER:-$(git config --get core.pager 2>/dev/null)}}" + echo "${pager:-cat}" +} + +if [[ $# -eq 1 ]]; then + branches() { + git branch "$@" --sort=-committerdate --sort=-HEAD --format=$'%(HEAD) %(color:yellow)%(refname:short) %(color:green)(%(committerdate:relative))\t%(color:blue)%(subject)%(color:reset)' --color=$(__fzf_git_color) | column -ts$'\t' + } + refs() { + git for-each-ref "$@" --sort=-creatordate --sort=-HEAD --color=$(__fzf_git_color) --format=$'%(if:equals=refs/remotes)%(refname:rstrip=-2)%(then)%(color:magenta)remote-branch%(else)%(if:equals=refs/heads)%(refname:rstrip=-2)%(then)%(color:brightgreen)branch%(else)%(if:equals=refs/tags)%(refname:rstrip=-2)%(then)%(color:brightcyan)tag%(else)%(if:equals=refs/stash)%(refname:rstrip=-2)%(then)%(color:brightred)stash%(else)%(color:white)%(refname:rstrip=-2)%(end)%(end)%(end)%(end)\t%(color:yellow)%(refname:short) %(color:green)(%(creatordate:relative))\t%(color:blue)%(subject)%(color:reset)' | column -ts$'\t' + } + hashes() { + git log --date=short --format="%C(green)%C(bold)%cd %C(auto)%h%d %s (%an)" --graph --color=$(__fzf_git_color) "$@" + } + case "$1" in + branches) + echo $'CTRL-O (open in browser) ╱ ALT-A (show all branches)\n' + branches + ;; + all-branches) + echo $'CTRL-O (open in browser)\n' + branches -a + ;; + hashes) + echo $'CTRL-O (open in browser) ╱ CTRL-D (diff)\nCTRL-S (toggle sort) ╱ ALT-A (show all hashes)\n' + hashes + ;; + all-hashes) + echo $'CTRL-O (open in browser) ╱ CTRL-D (diff)\nCTRL-S (toggle sort)\n' + hashes --all + ;; + refs) + echo $'CTRL-O (open in browser) ╱ ALT-E (examine in editor) ╱ ALT-A (show all refs)\n' + refs --exclude='refs/remotes' + ;; + all-refs) + echo $'CTRL-O (open in browser) ╱ ALT-E (examine in editor)\n' + refs + ;; + nobeep) ;; + *) exit 1 ;; + esac +elif [[ $# -gt 1 ]]; then + set -e + + branch=$(git rev-parse --abbrev-ref HEAD 2> /dev/null) + if [[ $branch = HEAD ]]; then + branch=$(git describe --exact-match --tags 2> /dev/null || git rev-parse --short HEAD) + fi + + # Only supports GitHub for now + case "$1" in + commit) + hash=$(grep -o "[a-f0-9]\{7,\}" <<< "$2") + path=/commit/$hash + ;; + branch|remote-branch) + branch=$(sed 's/^[* ]*//' <<< "$2" | cut -d' ' -f1) + remote=$(git config branch."${branch}".remote || echo 'origin') + branch=${branch#$remote/} + path=/tree/$branch + ;; + remote) + remote=$2 + path=/tree/$branch + ;; + file) path=/blob/$branch/$(git rev-parse --show-prefix)$2 ;; + tag) path=/releases/tag/$2 ;; + *) exit 1 ;; + esac + + remote=${remote:-$(git config branch."${branch}".remote || echo 'origin')} + remote_url=$(git remote get-url "$remote" 2> /dev/null || echo "$remote") + + if [[ $remote_url =~ ^git@ ]]; then + url=${remote_url%.git} + url=${url#git@} + url=https://${url/://} + elif [[ $remote_url =~ ^http ]]; then + url=${remote_url%.git} + fi + + case "$(uname -s)" in + Darwin) open "$url$path" ;; + *) xdg-open "$url$path" ;; + esac + exit 0 +fi + +if [[ $- =~ i ]]; then +# ----------------------------------------------------------------------------- + +# Redefine this function to change the options +_fzf_git_fzf() { + fzf --height=50% --tmux 90%,70% \ + --layout=reverse --multi --min-height=20 --border \ + --border-label-pos=2 \ + --color='header:italic:underline,label:blue' \ + --preview-window='right,50%,border-left' \ + --bind='ctrl-/:change-preview-window(down,50%,border-top|hidden|)' "$@" +} + +_fzf_git_check() { + git rev-parse HEAD > /dev/null 2>&1 && return + + [[ -n $TMUX ]] && tmux display-message "Not in a git repository" + return 1 +} + +__fzf_git=${BASH_SOURCE[0]:-${(%):-%x}} +__fzf_git=$(readlink -f "$__fzf_git" 2> /dev/null || /usr/bin/ruby --disable-gems -e 'puts File.expand_path(ARGV.first)' "$__fzf_git" 2> /dev/null) + +_fzf_git_files() { + _fzf_git_check || return + local root query + root=$(git rev-parse --show-toplevel) + [[ $root != "$PWD" ]] && query='!../ ' + + (git -c color.status=$(__fzf_git_color) status --short --no-branch + git ls-files "$root" | grep -vxFf <(git status -s | grep '^[^?]' | cut -c4-; echo :) | sed 's/^/ /') | + _fzf_git_fzf -m --ansi --nth 2..,.. \ + --border-label '📁 Files' \ + --header $'CTRL-O (open in browser) ╱ ALT-E (open in editor)\n\n' \ + --bind "ctrl-o:execute-silent:bash $__fzf_git file {-1}" \ + --bind "alt-e:execute:${EDITOR:-vim} {-1} > /dev/tty" \ + --query "$query" \ + --preview "git diff --no-ext-diff --color=$(__fzf_git_color .) -- {-1} | $(__fzf_git_pager); $(__fzf_git_cat) {-1}" "$@" | + cut -c4- | sed 's/.* -> //' +} + +_fzf_git_branches() { + _fzf_git_check || return + bash "$__fzf_git" branches | + _fzf_git_fzf --ansi \ + --border-label '🌲 Branches' \ + --header-lines 2 \ + --tiebreak begin \ + --preview-window down,border-top,40% \ + --color hl:underline,hl+:underline \ + --no-hscroll \ + --bind 'ctrl-/:change-preview-window(down,70%|hidden|)' \ + --bind "ctrl-o:execute-silent:bash $__fzf_git branch {}" \ + --bind "alt-a:change-border-label(🌳 All branches)+reload:bash \"$__fzf_git\" all-branches" \ + --preview "git log --oneline --graph --date=short --color=$(__fzf_git_color .) --pretty='format:%C(auto)%cd %h%d %s' \$(sed s/^..// <<< {} | cut -d' ' -f1) --" "$@" | + sed 's/^..//' | cut -d' ' -f1 +} + +_fzf_git_tags() { + _fzf_git_check || return + git tag --sort -version:refname | + _fzf_git_fzf --preview-window right,70% \ + --border-label '📛 Tags' \ + --header $'CTRL-O (open in browser)\n\n' \ + --bind "ctrl-o:execute-silent:bash $__fzf_git tag {}" \ + --preview "git show --color=$(__fzf_git_color .) {} | $(__fzf_git_pager)" "$@" +} + +_fzf_git_hashes() { + _fzf_git_check || return + bash "$__fzf_git" hashes | + _fzf_git_fzf --ansi --no-sort --bind 'ctrl-s:toggle-sort' \ + --border-label '🍡 Hashes' \ + --header-lines 3 \ + --bind "ctrl-o:execute-silent:bash $__fzf_git commit {}" \ + --bind "ctrl-d:execute:grep -o '[a-f0-9]\{7,\}' <<< {} | head -n 1 | xargs git diff --color=$(__fzf_git_color) > /dev/tty" \ + --bind "alt-a:change-border-label(🍇 All hashes)+reload:bash \"$__fzf_git\" all-hashes" \ + --color hl:underline,hl+:underline \ + --preview "grep -o '[a-f0-9]\{7,\}' <<< {} | head -n 1 | xargs git show --color=$(__fzf_git_color .) | $(__fzf_git_pager)" "$@" | + awk 'match($0, /[a-f0-9][a-f0-9][a-f0-9][a-f0-9][a-f0-9][a-f0-9][a-f0-9][a-f0-9]*/) { print substr($0, RSTART, RLENGTH) }' +} + +_fzf_git_remotes() { + _fzf_git_check || return + git remote -v | awk '{print $1 "\t" $2}' | uniq | + _fzf_git_fzf --tac \ + --border-label '📡 Remotes' \ + --header $'CTRL-O (open in browser)\n\n' \ + --bind "ctrl-o:execute-silent:bash $__fzf_git remote {1}" \ + --preview-window right,70% \ + --preview "git log --oneline --graph --date=short --color=$(__fzf_git_color .) --pretty='format:%C(auto)%cd %h%d %s' '{1}/$(git rev-parse --abbrev-ref HEAD)' --" "$@" | + cut -d$'\t' -f1 +} + +_fzf_git_stashes() { + _fzf_git_check || return + git stash list | _fzf_git_fzf \ + --border-label '🥡 Stashes' \ + --header $'CTRL-X (drop stash)\n\n' \ + --bind 'ctrl-x:reload(git stash drop -q {1}; git stash list)' \ + -d: --preview "git show --color=$(__fzf_git_color .) {1} | $(__fzf_git_pager)" "$@" | + cut -d: -f1 +} + +_fzf_git_lreflogs() { + _fzf_git_check || return + git reflog --color=$(__fzf_git_color) --format="%C(blue)%gD %C(yellow)%h%C(auto)%d %gs" | _fzf_git_fzf --ansi \ + --border-label '📒 Reflogs' \ + --preview "git show --color=$(__fzf_git_color .) {1} | $(__fzf_git_pager)" "$@" | + awk '{print $1}' +} + +_fzf_git_each_ref() { + _fzf_git_check || return + bash "$__fzf_git" refs | _fzf_git_fzf --ansi \ + --nth 2,2.. \ + --tiebreak begin \ + --border-label '☘️ Each ref' \ + --header-lines 2 \ + --preview-window down,border-top,40% \ + --color hl:underline,hl+:underline \ + --no-hscroll \ + --bind 'ctrl-/:change-preview-window(down,70%|hidden|)' \ + --bind "ctrl-o:execute-silent:bash $__fzf_git {1} {2}" \ + --bind "alt-e:execute:${EDITOR:-vim} <(git show {2}) > /dev/tty" \ + --bind "alt-a:change-border-label(🍀 Every ref)+reload:bash \"$__fzf_git\" all-refs" \ + --preview "git log --oneline --graph --date=short --color=$(__fzf_git_color .) --pretty='format:%C(auto)%cd %h%d %s' {2} --" "$@" | + awk '{print $2}' +} + +_fzf_git_worktrees() { + _fzf_git_check || return + git worktree list | _fzf_git_fzf \ + --border-label '🌴 Worktrees' \ + --header $'CTRL-X (remove worktree)\n\n' \ + --bind 'ctrl-x:reload(git worktree remove {1} > /dev/null; git worktree list)' \ + --preview " + git -c color.status=$(__fzf_git_color .) -C {1} status --short --branch + echo + git log --oneline --graph --date=short --color=$(__fzf_git_color .) --pretty='format:%C(auto)%cd %h%d %s' {2} -- + " "$@" | + awk '{print $1}' +} + +if [[ -n "${BASH_VERSION:-}" ]]; then + __fzf_git_init() { + bind -m emacs-standard '"\er": redraw-current-line' + bind -m emacs-standard '"\C-z": vi-editing-mode' + bind -m vi-command '"\C-z": emacs-editing-mode' + bind -m vi-insert '"\C-z": emacs-editing-mode' + + local o c + for o in "$@"; do + c=${o:0:1} + bind -m emacs-standard '"\C-g\C-'$c'": " \C-u \C-a\C-k`_fzf_git_'$o'`\e\C-e\C-y\C-a\C-y\ey\C-h\C-e\er \C-h"' + bind -m vi-command '"\C-g\C-'$c'": "\C-z\C-g\C-'$c'\C-z"' + bind -m vi-insert '"\C-g\C-'$c'": "\C-z\C-g\C-'$c'\C-z"' + bind -m emacs-standard '"\C-g'$c'": " \C-u \C-a\C-k`_fzf_git_'$o'`\e\C-e\C-y\C-a\C-y\ey\C-h\C-e\er \C-h"' + bind -m vi-command '"\C-g'$c'": "\C-z\C-g'$c'\C-z"' + bind -m vi-insert '"\C-g'$c'": "\C-z\C-g'$c'\C-z"' + done + } +elif [[ -n "${ZSH_VERSION:-}" ]]; then + __fzf_git_join() { + local item + while read item; do + echo -n "${(q)item} " + done + } + + __fzf_git_init() { + local m o + for o in "$@"; do + eval "fzf-git-$o-widget() { local result=\$(_fzf_git_$o | __fzf_git_join); zle reset-prompt; LBUFFER+=\$result }" + eval "zle -N fzf-git-$o-widget" + for m in emacs vicmd viins; do + eval "bindkey -M $m '^g^${o[1]}' fzf-git-$o-widget" + eval "bindkey -M $m '^g${o[1]}' fzf-git-$o-widget" + done + done + } +fi +__fzf_git_init files branches tags remotes hashes stashes lreflogs each_ref worktrees + +# ----------------------------------------------------------------------------- +fi diff --git a/.zsh/functions/git.zsh b/.zsh/functions/git.zsh index 8303ca5..097f6b7 100644 --- a/.zsh/functions/git.zsh +++ b/.zsh/functions/git.zsh @@ -1,8 +1,4 @@ # fbr - checkout git branch (including remote branches), sorted by most recent commit, limit 30 last branches fbr() { - local branches branch - branches=$(git for-each-ref --count=30 --sort=-committerdate refs/heads/ --format="%(refname:short)") && - branch=$(echo "$branches" | - fzf-tmux -d $(( 2 + $(wc -l <<< "$branches") )) +m) && - git checkout $(echo "$branch" | sed "s/.* //" | sed "s#remotes/[^/]*/##") + _fzf_git_each_ref --no-multi | xargs git checkout }