I mostly use git from the command line, but there are some vim-git integrations that I really like, listed below.
For the repository where I spend the majority of my working time, I use git worktree
s to manage several ongoing items:
main
- worktree that tracks the main branch (readonly intention)feature
- current feature workreview
- for code reviewtmp
hack
The worktrees are added from the primary worktree with git worktree add ../feature
and they let me have several branches checked out at the same time. I don't create new worktrees, I reuse the ones I have.
To work on a new feature I cd
to feature/
, create a new branch and launch my editor from there.
These worktrees share one .git
(only need to fetch once, and saves disk space compared to having several full clones) and they also share one stash (which means I can git stash
in one worktree and git stash pop
in another).
git branch -vv
lists all my local branches and in what worktree they are checked out in.
To review a branch I use git switch -d origin/feature_A_from_coworker
to avoid creating a local copy of the branch.
The git source contains several peripheral tools, git-jump is one of them. It can be used to start vim with a bunch of location loaded into quickfix list:
git jump grep banana
quickly find all bananas in the repogit jump merge
quickly fix all merge conflicts (e.g. when rebasing)git jump diff
revisit all positions of unstaged changesgit jump diff HEAD~
The parts of vim-fugitive I use the most:
:Ggrep banana
- find all bananas in the repo:Git blame
, mappings:P
reblame atcommit~
o
view the patch
:Gvsplit main:%
- inspect the current file's state at branch "main":Gdiffsplit main:%
compare with main branch
Related config:
Plug 'tpope/vim-fugitive'
nnoremap <leader>g :Ggrep -q <c-r><c-w>
nnoremap gb <cmd>Git blame<cr>
fzf's vim plugin has the handy command :Gfiles
to quickly find files in a git repo.
I also have :Files %:h
mapped to quickly find other files in the same folder as the current file.
Related [config] (https://github.com/kaddkaka/dotfiles/blob/main/dot_config/nvim/small.vim#L47):
Plug 'junegunn/fzf', { 'do': { -> fzf#install() } }
Plug 'junegunn/fzf.vim'
map <leader>f <cmd>GFiles<cr>
map <leader>F <cmd>Files<cr>
map <leader>l <cmd>Files %:h<cr>
I use tig to get an overview the commit history. It has builtin mapping for pressing e
at a change in a
diff to immediately open vim at that locaiton.
I have some bindings for quickly rebasing the top of my commit history:
bind main R !git rebase -i %(commit) --keep-empty
bind diff R !git rebase -i %(commit) --keep-empty
bind main S !git rebase -i %(commit) --autosquash
bind diff S !git rebase -i %(commit) --autosquash
When I want to fix comments from a Merge Review I have a custom script bound to E
that starts a rebase edit session
with all changes of that commit in quickfix list with git-jump.
bind main E <tig_edit %(commit)
bind diff E <tig_edit %(commit)
#!/bin/bash
echo "Editing: $1"
GIT_EDITOR='sed -i 1s/pick/edit/' git rebase -i "$1"~
git jump diff HEAD~
git commit -a --fixup=HEAD --no-edit