Suepr vim diff viewer!

This commit is contained in:
Daniel Flanagan 2020-02-12 11:13:46 -06:00
parent 0851642315
commit 88284235da
Signed by: lytedev
GPG key ID: 5B2020A0F9921EF4
7 changed files with 43 additions and 42 deletions

View file

@ -4,11 +4,11 @@ NUM_DESKTOPS="$(xrq bspwm.num_desktops)"
REVERSE_DESKTOP_ORDERING="$(xrq bspwm.reverse_desktop_ordering)" REVERSE_DESKTOP_ORDERING="$(xrq bspwm.reverse_desktop_ordering)"
REVERSE_MONITOR_DESKTOPS="$(xrq bspwm.reverse_monitor_desktops)" REVERSE_MONITOR_DESKTOPS="$(xrq bspwm.reverse_monitor_desktops)"
BSPWM_MONITORS=$(bspc query -M) BSPWM_MONITORS=$(bspc query -M)
MONITOR_COUNT=$(<<< "$BSPWM_MONITORS" wc -w | awk '{ printf $1 }') MONITOR_COUNT=$(echo "$BSPWM_MONITORS" | wc -w | awk '{ printf $1 }')
PER_MONITOR=$((NUM_DESKTOPS / MONITOR_COUNT)) PER_MONITOR=$((NUM_DESKTOPS / MONITOR_COUNT))
DESKTOPS=$(seq "$NUM_DESKTOPS") DESKTOPS=$(seq "$NUM_DESKTOPS")
[ "$REVERSE_MONITOR_DESKTOPS" -eq 1 ] && BSPWM_MONITORS=$(<<< "$BSPWM_MONITORS" tac) [ "$REVERSE_MONITOR_DESKTOPS" -eq 1 ] && BSPWM_MONITORS=$(echo "$BSPWM_MONITORS" | tac)
bspc config normal_border_color "$(xrq bspwm.normal_border_color)" bspc config normal_border_color "$(xrq bspwm.normal_border_color)"
bspc config focused_border_color "$(xrq bspwm.focused_border_color)" bspc config focused_border_color "$(xrq bspwm.focused_border_color)"
@ -28,7 +28,7 @@ bspc rule -a "*" split_dir=right
i=1 i=1
for mon in $BSPWM_MONITORS; do for mon in $BSPWM_MONITORS; do
max=$((i + PER_MONITOR - 1)) max=$((i + PER_MONITOR - 1))
screens= screens=""
for j in $(seq $i $max); do for j in $(seq $i $max); do
screens="${screens}${j} " screens="${screens}${j} "
done done

View file

@ -19,14 +19,11 @@
followRedirects = true followRedirects = true
[diff] [diff]
tool = cat tool = nvimdiff
[difftool] [difftool]
prompt = false prompt = false
[multidiff]
tool = nvimdiff -f
[alias] [alias]
d = difftool d = difftool
s = status s = status
@ -52,20 +49,10 @@
[mergetool "nvimdiff"] [mergetool "nvimdiff"]
cmd = nvimdiff $BASE $LOCAL $REMOTE $MERGED -c '$wincmd w' -c '$wincmd J' cmd = nvimdiff $BASE $LOCAL $REMOTE $MERGED -c '$wincmd w' -c '$wincmd J'
[mergetool "cat"]
cmd = cat $BASE $LOCAL $REMOTE $MERGED
[mergetool "echo"]
cmd = echo $BASE $LOCAL $REMOTE $MERGED
[mergetool "vimmultidiff"]
cmd = vim-multi-diff-builder $BASE $LOCAL $REMOTE $MERGED
[pager] [pager]
branch = false branch = false
# remove ansi codes, pad each file's diff with newlines, show as diff, remove top padding # remove ansi codes, pad each file's diff with newlines, show as diff, remove top padding
# diff = vimpager -c 'silent %sm/\\e[^mK]*[mK]//g' -c 'silent %s/^diff/\\r\\rdiff/' -c 'silent set ft=diff' -c 'silent execute \"normal gg2dd\"' diff = vimpager -c 'silent %sm/\\e[^mK]*[mK]//g' -c 'silent %s/^diff/\\r\\rdiff/' -c 'silent set ft=diff' -c 'silent execute \"normal gg2dd\"'
diff = less
[url "git@github.com:postmates"] [url "git@github.com:postmates"]
insteadOf = https://github.com/postmates insteadOf = https://github.com/postmates

View file

@ -43,7 +43,7 @@ let g:polyglot_disabled = ['cue', 'cuesheet']
" let g:fzf_layout = { 'window': 'enew' } " let g:fzf_layout = { 'window': 'enew' }
" check if we're using vim as the manpage viewer before loading session plugins " check if we're using vim as the manpage viewer before loading session plugins
if exists('asmanviewer') if exists('asmanviewer') || exists('nosession')
let g:prosession_dir = '/dev/null' let g:prosession_dir = '/dev/null'
else else
Plug 'tpope/vim-obsession' " session ease-of-use Plug 'tpope/vim-obsession' " session ease-of-use

View file

@ -110,7 +110,7 @@ function g
end end
end end
alias gs "git status" alias gs "git status"
alias gd "git d" alias gd "git diff"
alias gds "gd --staged" alias gds "gd --staged"
# alias gdv "git dv" # TODO: what is this? # alias gdv "git dv" # TODO: what is this?
alias gpl "git pull" alias gpl "git pull"
@ -156,6 +156,7 @@ alias wifi "sudo nmtui"
alias year 'cal (date +%Y)' alias year 'cal (date +%Y)'
alias y year alias y year
alias pa pulsemixer alias pa pulsemixer
alias vd vdiff
# games aliases # games aliases
# this sometimes fixes steam dynamic library issues? # this sometimes fixes steam dynamic library issues?

34
bin/vdiff Executable file
View file

@ -0,0 +1,34 @@
#!/usr/bin/env bash
repo_root="$(git rev-parse --show-toplevel)"
pushd "$repo_root" &> /dev/null || ( echo "Repo doesn't exist!"; exit 2 )
td="$(mktemp -p "$pdir" -d "vdiff.XXXXXXXX")"
trap "rm -rf \"$td\"" EXIT
files="$(git diff --name-only "$@")"
args=()
vcmd=""
for f in $files; do
d="$(dirname "$td/$f")"
rfn="$(basename "$f")"
fn="$rfn._@HEAD"
cfn="$rfn"
mkdir -p "$d"
git --no-pager show HEAD:"$f" > "$d/$fn" 2>/dev/null || \
echo "<FILE CREATED>" > "$d/$fn"
cp "$f" "$d/$cfn" 2>/dev/null || echo "<FILE DELETED>" > "$d/$cfn"
if [ -z "$args" ]; then
args+=($d/$fn -c)
vcmd="vert diffsplit $d/$cfn"
else
vcmd="$vcmd | tabnew | e $d/$fn | vert diffsplit $d/$cfn"
fi
done
remaps="nnoremap <leader>k :tabnext<CR> | nnoremap <leader>j :tabprev<CR>"
nvim "${args[@]}" "$vcmd | tabnext | $remaps"
rm -rf "$td"
popd &> /dev/null || ( echo "Could not return to original directory" && exit 4 )

View file

@ -1,22 +0,0 @@
#!/usr/bin/env sh
td="$(mktemp -p "$pdir" -d "tmp_vim_git_multi_diff.XXXXXXXX")"
trap "rm -rf \"$td\"" EXIT
files="$(git diff --name-only "$@")"
for f in $files; do
d="$(dirname "$td/$f")"
rfn="$(basename "$f")"
fn="$rfn._@HEAD"
cfn="$rfn._@DISK"
mkdir -p "$d"
git --no-pager show HEAD:"$f" > "$d/$fn" 2>/dev/null || \
echo "<NO FILE>" > "$d/$fn"
cp "$f" "$d/$cfn"
nvim -d "$d/$fn" "$d/$cfn"
exit 3
done
ls -R "$td"
rm -rf "$td"

View file

@ -1,6 +1,7 @@
#!/usr/bin/env sh #!/usr/bin/env sh
nvim \ nvim \
-c 'let nosession=1' \
-c 'silent setlocal nobuflisted buftype=nofile bufhidden=wipe noswapfile' \ -c 'silent setlocal nobuflisted buftype=nofile bufhidden=wipe noswapfile' \
"$@" \ "$@" \
- -