*signify.txt* Indicate changed lines within a file using a VCS. *signify* ___ __ __ /'___\ ____/\_\ __ ___ /\_\/\ \__/ __ __ /',__\/\ \ /'_ `\ /' _ `\/\ \ \ ,__\/\ \/\ \ /\__, `\ \ \/\ \L\ \/\ \/\ \ \ \ \ \_/\ \ \_\ \ \/\____/\ \_\ \____ \ \_\ \_\ \_\ \_\ \/`____ \ \/___/ \/_/\/___L\ \/_/\/_/\/_/\/_/ `/___/> \ /\____/ /\___/ \_/__/ \/__/ by Marco Hinz~ Twitter: https://twitter.com/_mhinz_ Github: http://github.com/mhinz IRC: mhi^ (Freenode) > If you use any of my plugins, please star them on github. It's a great way of getting feedback and gives me the kick to put more time into their development. If you encounter any bugs or have feature requests, just open an issue report on Github. Thank you for flying mhi^ airlines. Get the Vim on! < ============================================================================== TOC *signify-section-contents* INTRO .......................... |signify-section-intro| USAGE .......................... |signify-section-usage| OPTIONS ........................ |signify-section-options| COMMANDS ....................... |signify-section-commands| MAPPINGS ....................... |signify-section-mappings| COLORS ......................... |signify-section-colors| ============================================================================== INTRO *signify-section-intro* Signify (or just Sy) is a quite unobtrusive plugin. It uses signs to indicate added, modified and removed lines based on data of an underlying version control system. ============================================================================== USAGE *signify-section-usage* The usage is pretty straight-forward. By default you should only notice a difference, if you're working in a directory that is managed by a supported version control system and the current file was changed since the last commit. Supported VCS:~ > git mercurial darcs bzr subversion cvs rcs fossil accurev < Sign explanation:~ `+` This line was added. `!` This line was modified. `_1` The number of deleted lines below this sign. If the number is larger `_>` than 9, `_>` will be shown instead. `!1` This line was modified and a number of lines below were deleted. `!>` It is a combination of `!` and `_`. If the number is larger than 9, `!>` will be shown instead. `‾` The first line was removed. It's a special case of the `_` sign. ============================================================================== OPTIONS *signify-section-options* Put these variables into your vimrc. The provided examples also indicate the default values, as long as no "Default:" section is given. All available options:~ |signify-option-vcs_list| |signify-option-disable_by_default| |signify-option-mapping_next_hunk| |signify-option-mapping_prev_hunk| |signify-option-mapping_toggle_highlight| |signify-option-mapping_toggle| |signify-option-skip_filetype| |signify-option-skip_filename| |signify-option-sign_overwrite| |signify-option-update_on_bufenter| |signify-option-update_on_focusgained| |signify-option-line_highlight| |signify-option-sign_delete_first_line| |signify-option-sign_delete| |signify-option-sign_change| |signify-option-sign_add| |signify-option-cursorhold_normal| |signify-option-cursorhold_insert| |signify-option-difftool| |signify-option-diffoptions| ------------------------------------------------------------------------------ *signify-option-vcs_list* > let g:signify_vcs_list = [ 'git', 'hg' ] < Default: empty NOTE: This is the most important variable, so read closely. It determines the VCS to check for and in what order. If you only use git and mercurial, you can shorten the list to the shown example. If you use mostly mercurial and only sometimes git, put 'hg' in the front of the list. It's basically a priority list. This can improve buffer loading time since by default all supported and installed VCS will be checked for, so you are advised to change this variable to your needs. NOTE: This plugin improves execution speed by avoiding certain checks. Some VCS rely on a an external diff tool to work properly (svn, darcs, bzr, fossil), thus you have to make sure that Vim can find a valid diff tool. So either the one you set through |g:signify-option-difftool| or "diff" by default. NOTE: This only happens once at the first time the signs get updated. Afterwards, the VCS will be remembered anyway. NOTE: If you don't change this list and Sy is activated, updating signs for a non-VCS file can lead to significant delay since all supported and installed VCS will be tested for. ------------------------------------------------------------------------------ *signify-option-disable_by_default* > let g:signify_disable_by_default = 0 < Don't run Sy by default. You can toggle it anytime via :SignifyToggle. ------------------------------------------------------------------------------ *signify-option-mapping_next_hunk* *signify-option-mapping_prev_hunk* > let g:signify_mapping_next_hunk = 'gj' let g:signify_mapping_prev_hunk = 'gk' < Mapping for jumping to the start of the next or previous hunk. Alternatively, you can also map it yourself: > nmap gj (signify-next-hunk) nmap gk (signify-prev-hunk) < There is no difference between both variants. ------------------------------------------------------------------------------ *signify-option-mapping_toggle_highlight* > let g:signify_mapping_toggle_highlight = 'gh' < Mapping for toggling line highlighting for lines containing changes. ------------------------------------------------------------------------------ *signify-option-mapping_toggle* > let g:signify_mapping_toggle = 'gt' < Mapping for toggling the plugin for the current buffer only. ------------------------------------------------------------------------------ *signify-option-skip_filetype* *signify-option-skip_filename* > let g:signify_skip_filetype = { 'vim': 1, 'c': 1 } let g:signify_skip_filename = { '/home/user/.vimrc': 1 } < Don't activate the plugin for these filetypes and/or filenames. NOTE: Filenames have to be absolute paths. Default: Both are empty. ------------------------------------------------------------------------------ *signify-option-sign_overwrite* > let g:signify_sign_overwrite = 0 < Setting this to 1 means that Sy doesn't have to manage its signs and just removes ALL signs before adding its own signs. This typically results in a tad more performance, especially when a lot of signs are in use. If you need plugin compatibility though, you should set this to 0. In this case Sy will remember which signs it set last and only removes those at the next update. NOTE: This feature needs at least Vim 7.3.596! ------------------------------------------------------------------------------ *signify-option-update_on_bufenter* > let g:signify_update_on_bufenter = 0 < Update signs when entering a buffer that was modified. NOTE: This also saves the buffer to disk! ------------------------------------------------------------------------------ *signify-option-update_on_focusgained* > let g:signify_update_on_focusgained = 0 < Update signs when Vim gains focus. NOTE: This also saves the buffer to disk! ------------------------------------------------------------------------------ *signify-option-line_highlight* > let g:signify_line_highlight = 0 < Enable line highlighting in addition to using signs by default. ------------------------------------------------------------------------------ *signify-option-sign_delete_first_line* *signify-option-sign_delete* *signify-option-sign_change* *signify-option-sign_add* > let g:signify_sign_add = '+' let g:signify_sign_change = '!' let g:signify_sign_delete = '_' let g:signify_sign_delete_first_line = '‾' < The sign to use if a line was added, deleted or changed or a combination of these. ------------------------------------------------------------------------------ *signify-option-cursorhold_normal* *signify-option-cursorhold_insert* > let g:signify_cursorhold_normal = 0 let g:signify_cursorhold_insert = 0 < Additionally trigger sign updates in normal or insert mode after 'updatetime' miliseconds without any keypresses. This fires only once between keypresses, thus not every 'updatetime' miliseconds. NOTE: This also saves the buffer to disk! ------------------------------------------------------------------------------ *signify-option-difftool* > let g:signify_difftool = 'gnudiff' < This will avoid the attempt to find the proper diff tool for version control systems that rely on an external diff tool that supports the -U0 flag. These are: svn, bzr, darcs, fossil. Default: "diff" ------------------------------------------------------------------------------ *signify-option-diffoptions* > let g:signify_diffoptions = { 'git': '-w', 'hg': '-w' } < This will pass the given additional options to the selected VCS diff command. Default: Does not exist. ============================================================================== COMMAND *signify-section-commands* MAPPINGS *signify-section-mappings* > :SignifyToggle < Toggle the plugin for the current buffer only. Default mapping: gt ------------------------------------------------------------------------------ > :SignifyToggleHighlight < Toggle line highlighting for lines containing changes. Default mapping: gh ============================================================================== COLORS *signify-section-colors* This plugin defines highlighting groups for two different places: for lines and signs. Per default these don't really exist but are linked to the standard highlighting groups: DiffAdd, DiffChange, DiffDelete: > highlight link SignifyLineAdd DiffAdd highlight link SignifyLineChange DiffChange highlight link SignifyLineDelete DiffDelete highlight link SignifySignAdd DiffAdd highlight link SignifySignChange DiffChange highlight link SignifySignDelete DiffDelete < Thus if you do not want to change the standard highlighting groups, but want different colors for either your signs or lines, you can define one of these 6 Signify groups yourself in your vimrc. Personally I use (256 colors terminal): > " highlight lines in Sy and vimdiff etc.) highlight DiffAdd cterm=bold ctermbg=none ctermfg=119 highlight DiffDelete cterm=bold ctermbg=none ctermfg=167 highlight DiffChange cterm=bold ctermbg=none ctermfg=227 " highlight signs in Sy highlight SignifySignAdd cterm=bold ctermbg=237 ctermfg=119 highlight SignifySignDelete cterm=bold ctermbg=237 ctermfg=167 highlight SignifySignChange cterm=bold ctermbg=237 ctermfg=227 < For Unix people there is a small script, showcolors.bash, in the repo that shows all 256 colors available to the terminal. That makes picking the right numbers much easier. ============================================================================== vim: tw=78