Skip to content

Latest commit

 

History

History
136 lines (91 loc) · 5.14 KB

README.md

File metadata and controls

136 lines (91 loc) · 5.14 KB

More Pleasant Editing on Commit Message

When you type git commit, Vim starts and opens a commit buffer. This plugin improves the commit buffer.

committia.vim splits the buffer into 3 windows; edit window, status window and diff window. You no longer need to repeat moving to another window, scrolling and backing to the former position in order to see a long commit diff.

If the width of Vim window is too narrow (the threshold is 160 characters by default), committia.vim falls back to the single column mode, which has 2 windows; edit window and diff window.

For a wide window:

double column mode

For a narrow window:

single column mode

Hooks

You can hook on opening the windows.

Available hooks are:

  • edit_open: When opening a commit message window, this hook is called from the window.
  • diff_open: When opening a diff window, this hook is called from the window.
  • status_open: When opening a status window, this hook is called from the window. Please note that this hook is not called on single-column mode since it does not have a dedicated window for status.

A vimrc example is below.

" You can get the information about the windows with first argument as a dictionary.
"
"   KEY              VALUE                      AVAILABILITY
"-----------------------------------------------------------------------------------
"   vcs            : vcs type (e.g. 'git')   -> all hooks
"   edit_winnr     : winnr of edit window    -> ditto
"   edit_bufnr     : bufnr of edit window    -> ditto
"   diff_winnr     : winnr of diff window    -> ditto
"   diff_bufnr     : bufnr of diff window    -> ditto
"   status_winnr   : winnr of status window  -> all hooks except for 'diff_open' hook
"   status_bufnr   : bufnr of status window  -> ditto

let g:committia_hooks = {}
function! g:committia_hooks.edit_open(info)
    " Additional settings
    setlocal spell

    " If no commit message, start with insert mode
    if a:info.vcs ==# 'git' && getline(1) ==# ''
        startinsert
    endif

    " Scroll the diff window from insert mode
    " Map <C-n> and <C-p>
    imap <buffer><C-n> <Plug>(committia-scroll-diff-down-half)
    imap <buffer><C-p> <Plug>(committia-scroll-diff-up-half)
endfunction

Mappings

Mappings to scroll diff window for insert mode are available.

Mapping Description
<Plug>(committia-scroll-diff-down-half) Scroll down the diff window by half a screen.
<Plug>(committia-scroll-diff-up-half) Scroll up the diff window by half a screen.
<Plug>(committia-scroll-diff-down-page) Scroll down the diff window by a screen.
<Plug>(committia-scroll-diff-up-page) Scroll up the diff window by a screen.
<Plug>(committia-scroll-diff-down) Scroll down the diff window by one line.
<Plug>(committia-scroll-diff-up) Scroll up the diff window by one line.

Variables

Some variables are available to control the behavior of committia.vim.

g:committia_open_only_vim_starting (default: 1)

If the value is 0, committia.vim always attempts to open committia's buffer when COMMIT_EDITMSG buffer is opened. If you use vim-fugitive, I recommend to set this value to 1.

g:committia_use_singlecolumn (default: 'fallback')

If the value is 'always', committia.vim always employs single column mode.

g:committia_min_window_width (default: 160)

If the width of window is narrower than the value, committia.vim employs single column mode.

g:committia_status_window_opencmd (default: 'belowright split')

Vim command which opens a status window in multi-columns mode.

g:committia_diff_window_opencmd (default: 'botright vsplit')

Vim command which opens a diff window in multi-columns mode.

g:committia_singlecolumn_diff_window_opencmd (default: 'belowright split')

Vim command which opens a diff window in single-column mode.

g:committia_edit_window_width (default: 80)

If committia.vim is in multi-columns mode, specifies the width of the edit window.

g:committia_status_window_min_height (default: 0)

Minimum height of a status window.

g:committia#git#use_verbose (default: 0)

If the value is 1, extract the diff and status from COMMIT_EDITMSG when the verbose option is used with git commit, e.g. git commit --verbose or git config --global commit.verbose=true.

Future work

  • Cooperate with vim-fugitive.
  • Add more VCS supports
  • Test all features

Thanks to the contributions

License

Distributed under the MIT license