2013-03-28 10:25:24 +01:00
|
|
|
vim-signify
|
|
|
|
-----------
|
2013-03-05 20:07:37 +01:00
|
|
|
|
2013-07-09 07:04:25 +02:00
|
|
|
Or just: __Sy__.
|
2013-03-06 23:40:57 +01:00
|
|
|
|
2013-03-10 11:29:19 +01:00
|
|
|
Sy shows all added, deleted and modified lines since the last commit via Vim its
|
2013-03-15 13:52:57 +01:00
|
|
|
sign column. It __supports several version control systems__.
|
2013-03-06 00:30:30 +01:00
|
|
|
|
2013-03-15 13:52:57 +01:00
|
|
|
It's __fast__, __highly configurable__ and __well documented__.
|
2013-03-05 20:07:37 +01:00
|
|
|
|
|
|
|
Features:
|
|
|
|
|
2013-07-30 01:27:05 +02:00
|
|
|
- supports git, mercurial, darcs, bazaar, subversion, cvs, rcs, fossil, accurev,
|
|
|
|
perforce
|
2013-07-09 07:28:03 +02:00
|
|
|
- quick jumping between blocks of changed lines
|
2013-03-05 20:12:24 +01:00
|
|
|
- apart from signs there is also optional line highlighting
|
2013-03-12 15:05:09 +01:00
|
|
|
- fully configurable through global variables (options and mappings)
|
2013-03-07 12:56:25 +01:00
|
|
|
- optional preserving of signs from other plugins
|
|
|
|
- you can toggle the plugin per buffer
|
2013-03-26 10:34:29 +01:00
|
|
|
- skip certain filetypes and filenames
|
2013-03-05 20:07:37 +01:00
|
|
|
- good documentation
|
|
|
|
|
2013-03-05 20:12:24 +01:00
|
|
|
- quick developer response! :-)
|
2013-03-05 20:07:37 +01:00
|
|
|
|
2013-06-07 19:54:50 +02:00
|
|
|
![Example:signify in action](https://github.com/mhinz/vim-signify/raw/master/signify.gif)
|
2013-03-07 13:29:54 +01:00
|
|
|
|
2013-03-15 13:52:57 +01:00
|
|
|
Limits exist only in your mind!
|
|
|
|
|
2013-03-28 10:25:24 +01:00
|
|
|
Feedback, please!
|
|
|
|
-----------------
|
2013-03-15 13:52:57 +01:00
|
|
|
|
|
|
|
If you use any of my plugins, star it on github. This is a great way of getting
|
|
|
|
feedback! Same for issues or feature requests.
|
|
|
|
|
|
|
|
Thank you for flying mhi airlines. Get the Vim on!
|
2013-03-05 20:07:37 +01:00
|
|
|
|
2013-07-22 20:39:35 +02:00
|
|
|
You can also follow me on Twitter: [@_mhinz_](https://twitter.com/_mhinz_)
|
|
|
|
|
2013-03-28 10:25:24 +01:00
|
|
|
What about vim-gitgutter?
|
|
|
|
-------------------------
|
2013-03-14 12:51:19 +01:00
|
|
|
|
|
|
|
To be honest, I don't understand why people always compare plugins like Sy to
|
|
|
|
vim-gitgutter. I understand that it is by far the most known one, but primarily
|
|
|
|
because it was featured on the Hacker News frontpage.
|
|
|
|
|
|
|
|
Don't get me wrong, I don't intend to badmouth gitgutter, I even contributed to
|
|
|
|
it once. (Granted, it was only a small fix.) And I'm glad about everyone
|
|
|
|
contributing to the Vim community, but there are two important facts one should
|
|
|
|
consider:
|
|
|
|
|
|
|
|
1. There were other plugins providing the same functionality as gitgutter years
|
|
|
|
before its creation.
|
|
|
|
|
|
|
|
1. Sy provides a superset of gitgutter.
|
|
|
|
|
|
|
|
So here is the short answer: The main difference is Sy its support for version
|
|
|
|
control systems other than git. Moreover, two of its design goals are speed and
|
|
|
|
high configurability.
|
|
|
|
|
2013-03-28 10:25:24 +01:00
|
|
|
Sign explanation
|
|
|
|
----------------
|
2013-03-14 11:13:25 +01:00
|
|
|
|
2013-03-22 19:00:05 +01:00
|
|
|
`+`
|
2013-03-14 11:13:25 +01:00
|
|
|
|
2013-07-09 07:04:25 +02:00
|
|
|
This indicates a new line.
|
2013-03-14 11:13:25 +01:00
|
|
|
|
2013-06-07 11:37:21 +02:00
|
|
|
`_1`
|
2013-03-14 11:13:25 +01:00
|
|
|
|
2013-07-09 07:04:25 +02:00
|
|
|
This indicates the number of deleted lines. If the number is larger than 9, a
|
|
|
|
`>` will be shown instead.
|
2013-03-14 11:13:25 +01:00
|
|
|
|
2013-03-22 19:00:05 +01:00
|
|
|
`!`
|
2013-03-14 11:13:25 +01:00
|
|
|
|
2013-07-09 07:04:25 +02:00
|
|
|
This indicates a changed line.
|
2013-03-14 11:13:25 +01:00
|
|
|
|
2013-07-08 12:06:54 +02:00
|
|
|
`!1`
|
2013-03-14 11:13:25 +01:00
|
|
|
|
2013-07-09 07:04:25 +02:00
|
|
|
This indicates a changed line and a number of lines below that were deleted. It
|
|
|
|
is a combination of `!` and `_`. If the number is larger than 9, a `>` will be
|
|
|
|
shown instead.
|
2013-04-12 11:56:23 +02:00
|
|
|
|
|
|
|
`‾`
|
|
|
|
|
2013-07-09 07:04:25 +02:00
|
|
|
This is used instead of `_` in the special case of the first line being removed.
|
2013-04-12 11:56:23 +02:00
|
|
|
|
2013-03-28 10:25:24 +01:00
|
|
|
Longer introduction
|
|
|
|
-------------------
|
2013-03-12 15:05:09 +01:00
|
|
|
|
2013-03-15 13:08:56 +01:00
|
|
|
#### supports several version control systems
|
2013-03-12 15:05:09 +01:00
|
|
|
|
|
|
|
This plugin is based on the diffing features of the supported version control
|
|
|
|
systems. Since not all VCS support the same options, sometimes we have to fall
|
|
|
|
back to the 'diff' executable.
|
|
|
|
|
2013-04-19 23:18:26 +02:00
|
|
|
Currently the following VCS are supported:
|
2013-03-12 15:05:09 +01:00
|
|
|
|
|
|
|
- git
|
|
|
|
- mercurial (hg)
|
|
|
|
- bazaar (bzr)
|
|
|
|
- darcs
|
|
|
|
- subversion (svn)
|
|
|
|
- cvs
|
2013-03-15 13:08:56 +01:00
|
|
|
- rcs
|
2013-04-16 11:37:57 +02:00
|
|
|
- fossil
|
2013-07-10 23:12:13 +02:00
|
|
|
- accurev
|
2013-07-30 01:27:05 +02:00
|
|
|
- perforce
|
2013-03-12 15:05:09 +01:00
|
|
|
|
2013-03-12 15:08:27 +01:00
|
|
|
#### quick jumping between changed lines
|
2013-03-12 15:05:09 +01:00
|
|
|
|
2013-07-04 11:52:28 +02:00
|
|
|
There are mappings for jumping forth and back between blocks of changes
|
|
|
|
(so-called hunks). The following example shows the default mappings and how to
|
|
|
|
change them:
|
2013-03-12 15:05:09 +01:00
|
|
|
|
2013-03-21 15:04:08 +01:00
|
|
|
```vim
|
|
|
|
let g:signify_mapping_next_hunk = '<leader>gj'
|
|
|
|
let g:signify_mapping_prev_hunk = '<leader>gk'
|
|
|
|
```
|
2013-03-12 15:05:09 +01:00
|
|
|
|
|
|
|
Note: In case you don't know about the mapleader, have a look at `:h mapleader`.
|
|
|
|
The default is the '\' button.
|
|
|
|
|
2013-03-26 18:51:49 +01:00
|
|
|
Following Vim conventions you can also use __]c__ and __[c__.
|
2013-03-26 14:25:45 +01:00
|
|
|
|
2013-03-12 15:08:27 +01:00
|
|
|
#### apart from signs there is also optional line highlighting
|
2013-03-12 15:05:09 +01:00
|
|
|
|
|
|
|
Sy shows you signs for changed lines. Moveover, you can enable highlighting of
|
|
|
|
the concerned lines:
|
|
|
|
|
2013-03-21 15:04:08 +01:00
|
|
|
```vim
|
|
|
|
let g:signify_mapping_toggle_highlight = '<leader>gh'
|
|
|
|
```
|
2013-03-12 15:05:09 +01:00
|
|
|
|
2013-03-12 15:08:27 +01:00
|
|
|
#### you can toggle the plugin per buffer
|
2013-03-12 15:05:09 +01:00
|
|
|
|
|
|
|
In case you want to disable the plugin for the current buffer, you can toggle
|
|
|
|
it:
|
|
|
|
|
2013-03-21 15:04:08 +01:00
|
|
|
```vim
|
|
|
|
let g:signify_mapping_toggle = '<leader>gt'
|
|
|
|
```
|
2013-03-12 15:05:09 +01:00
|
|
|
|
2013-03-26 10:34:29 +01:00
|
|
|
#### skip certain filetypes and filenames
|
2013-03-12 15:05:09 +01:00
|
|
|
|
|
|
|
If you want to disable Sy for certain kinds of filename or file types,
|
2013-03-26 10:34:29 +01:00
|
|
|
you explicitely have to create "skip dicts":
|
2013-03-12 15:05:09 +01:00
|
|
|
|
|
|
|
Example:
|
|
|
|
|
2013-03-21 15:04:08 +01:00
|
|
|
```vim
|
2013-03-26 10:34:29 +01:00
|
|
|
let g:signify_skip_filetype = { 'vim': 1, 'c': 1 }
|
|
|
|
let g:signify_skip_filename = { '/home/user/.vimrc': 1 }
|
2013-03-21 15:04:08 +01:00
|
|
|
```
|
2013-03-12 15:05:09 +01:00
|
|
|
|
2013-03-29 13:31:23 +01:00
|
|
|
__NOTE__: Filenames have to be absolute paths!
|
|
|
|
|
2013-03-12 15:08:27 +01:00
|
|
|
#### good documentation
|
2013-03-12 15:05:09 +01:00
|
|
|
|
|
|
|
You should know by now!
|
|
|
|
|
2013-03-28 10:25:24 +01:00
|
|
|
Installation
|
|
|
|
------------
|
2013-03-05 20:07:37 +01:00
|
|
|
|
2013-03-29 13:23:49 +01:00
|
|
|
If you have no preferred installation method, I suggest using tpope's pathogen:
|
2013-03-06 13:51:23 +01:00
|
|
|
|
2013-03-29 13:23:49 +01:00
|
|
|
1. git clone https://github.com/tpope/vim-pathogen ~/.vim/bundle/vim-pathogen
|
|
|
|
1. mkdir -p ~/.vim/autoload && cd ~/.vim/autoload
|
|
|
|
1. ln -s ../bundle/vim-pathogen/autoload/pathogen.vim
|
2013-09-29 22:21:56 -04:00
|
|
|
1. Add this to the top of your vimrc: `execute pathogen#infect()`
|
2013-03-06 13:51:23 +01:00
|
|
|
|
2013-03-29 13:23:49 +01:00
|
|
|
Afterwards installing Sy is as easy as pie:
|
|
|
|
|
|
|
|
2. git clone https://github.com/mhinz/vim-signify ~/.vim/bundle/vim-signify
|
|
|
|
2. start Vim
|
|
|
|
2. :Helptags
|
|
|
|
2. :h signify
|
2013-03-05 20:07:37 +01:00
|
|
|
|
2013-03-28 10:25:24 +01:00
|
|
|
Documentation
|
|
|
|
-------------
|
2013-03-05 20:07:37 +01:00
|
|
|
|
|
|
|
`:h signify`
|
|
|
|
|
2013-03-28 10:25:24 +01:00
|
|
|
Configuration
|
|
|
|
-------------
|
2013-03-07 13:55:18 +01:00
|
|
|
|
2013-06-22 15:17:39 +02:00
|
|
|
__NOTE__: The shown assignments are only examples. You can find the default
|
|
|
|
values in the help.
|
|
|
|
|
2013-03-07 13:55:18 +01:00
|
|
|
For more info: `:h signify-options`
|
|
|
|
|
2013-03-25 15:46:12 +01:00
|
|
|
|
2013-03-21 15:04:08 +01:00
|
|
|
```vim
|
2013-03-25 16:12:31 +01:00
|
|
|
let g:signify_vcs_list = [ 'git', 'hg' ]
|
|
|
|
|
2013-06-07 08:56:47 +02:00
|
|
|
let g:signify_difftool = 'gnudiff'
|
|
|
|
|
2013-03-26 18:44:11 +01:00
|
|
|
let g:signify_mapping_next_hunk = '<leader>gj'
|
|
|
|
let g:signify_mapping_prev_hunk = '<leader>gk'
|
2013-03-07 13:55:18 +01:00
|
|
|
|
2013-03-21 15:04:08 +01:00
|
|
|
let g:signify_mapping_toggle_highlight = '<leader>gh'
|
|
|
|
let g:signify_mapping_toggle = '<leader>gt'
|
2013-03-07 13:55:18 +01:00
|
|
|
|
2013-03-26 10:34:29 +01:00
|
|
|
let g:signify_skip_filetype = { 'vim': 1, 'c': 1 }
|
|
|
|
let g:signify_skip_filename = { '/home/user/.vimrc': 1 }
|
2013-03-10 10:59:52 +01:00
|
|
|
|
2013-03-21 15:04:08 +01:00
|
|
|
let g:signify_sign_overwrite = 1
|
2013-03-10 10:59:52 +01:00
|
|
|
|
2013-04-03 10:38:32 +02:00
|
|
|
let g:signify_update_on_bufenter = 1
|
2013-08-13 08:09:02 +02:00
|
|
|
let g:signify_update_on_focusgained = 0
|
2013-04-03 10:38:32 +02:00
|
|
|
|
2013-04-04 11:14:07 +02:00
|
|
|
let g:signify_line_highlight = 1
|
|
|
|
|
2013-03-21 15:04:08 +01:00
|
|
|
let g:signify_sign_add = '+'
|
2013-07-08 12:19:34 +02:00
|
|
|
let g:signify_sign_change = '!'
|
|
|
|
let g:signify_sign_delete = '_'
|
2013-03-21 15:04:08 +01:00
|
|
|
let g:signify_sign_delete_first_line = '‾'
|
2013-03-07 13:55:18 +01:00
|
|
|
|
2013-03-21 15:04:08 +01:00
|
|
|
let g:signify_cursorhold_normal = 1
|
|
|
|
let g:signify_cursorhold_insert = 1
|
|
|
|
```
|
2013-03-12 12:25:22 +01:00
|
|
|
|
2013-03-28 10:25:24 +01:00
|
|
|
Author
|
|
|
|
------
|
2013-03-05 20:07:37 +01:00
|
|
|
|
|
|
|
Marco Hinz `<mh.codebro@gmail.com>`
|
|
|
|
|
2013-03-28 10:25:24 +01:00
|
|
|
License
|
|
|
|
-------
|
2013-03-05 20:07:37 +01:00
|
|
|
|
2013-08-02 12:43:22 +02:00
|
|
|
MIT license. Copyright (c) 2013 Marco Hinz.
|