2015-12-02 14:23:39 +00:00
#+TITLE : Version-Control layer
2015-06-10 16:44:30 +00:00
2016-03-31 02:59:55 +00:00
* Table of Contents :TOC_4_gh:noexport:
2017-05-22 14:16:12 +00:00
- [[#description ][Description ]]
2017-08-28 21:58:10 +00:00
- [[#features ][Features: ]]
2017-05-22 14:16:12 +00:00
- [[#install ][Install ]]
- [[#layer ][Layer ]]
- [[#configuration ][Configuration ]]
- [[#differences-between-margin-programs ][Differences between margin programs ]]
- [[#key-bindings ][Key Bindings ]]
- [[#version-control-transient-state ][Version Control Transient-state ]]
- [[#smerge-mode-transient-state ][Smerge Mode Transient-state ]]
2015-06-10 16:44:30 +00:00
* Description
This layers adds general configuration for [[http://www.gnu.org/software/emacs/manual/html_node/emacs/Version-Control.html ][Emacs VC ]].
It should work with all VC backends such as Git, Mercurial, Bazaar, SVN, etc...
2017-08-28 21:58:10 +00:00
** Features:
- highlights uncommitted changes in the fringe or margin with [[https://github.com/dgutov/diff-hl ][diff-hl ]], [[https://github.com/syohex/emacs-git-gutter ][git-gutter ]], or [[https://github.com/nonsequitur/git-gutter-plus ][git-gutter+ ]]
- adds vcs transient-state ~SPC g.~ to allow quick navigation and modification of buffer hunks.
2015-11-15 19:01:58 +00:00
2015-06-10 16:44:30 +00:00
* Install
** Layer
2016-01-06 05:21:55 +00:00
To use this configuration layer, add it to your =~/.spacemacs= . You will need to
add =version-control= to the existing =dotspacemacs-configuration-layers= list in this
file.
2015-06-10 16:44:30 +00:00
2015-11-15 19:01:58 +00:00
* Configuration
2016-01-30 11:32:53 +00:00
You can choose the package to facilitate the diff transient-state and show margins
2015-11-15 19:01:58 +00:00
by setting =version-control-diff-tool=
#+BEGIN_SRC emacs-lisp
'(version-control :variables
version-control-diff-tool 'diff-hl)
#+END_SRC
2016-11-01 09:27:45 +00:00
You can choose the side on which the diff appears (by default it's the right side)
#+BEGIN_SRC emacs-lisp
'(version-control :variables
2016-11-05 11:03:23 +00:00
version-control-diff-side 'left)
2016-11-01 09:27:45 +00:00
#+END_SRC
2015-11-30 04:00:57 +00:00
To automatically enable diff margins in all buffers, set
=version-control-global-margin=
2015-11-15 19:01:58 +00:00
#+BEGIN_SRC emacs-lisp
'(version-control :variables
2015-12-03 12:49:09 +00:00
version-control-global-margin t)
2015-11-15 19:01:58 +00:00
#+END_SRC
2015-12-07 18:46:48 +00:00
** Differences between margin programs
2015-11-30 04:00:57 +00:00
This layer contains generalized mappings for three diff margin packages:
diff-hl, git-gutter, and git-gutter+.
2015-11-15 19:01:58 +00:00
2015-11-30 04:00:57 +00:00
There are some differences between packages that might have some people prefer
one over the other:
2015-11-15 19:01:58 +00:00
| Feature | diff-hl | git-gutter | git-gutter+ |
|-------------------------------------+---------+------------+-------------|
| Show in fringe | X | X | X |
| Extended VCS support (e.g. hg, svn) | X | X | |
| Stage hunks from buffer | | X | X |
| Dired support | X | | |
2015-06-10 16:44:30 +00:00
* Key Bindings
2016-04-13 03:31:38 +00:00
| Key Binding | Description |
|-------------+---------------------------------|
| ~SPC g .~ | version control transient-state |
2017-03-12 13:22:03 +00:00
| ~SPC g r~ | smerge mode transient-state |
2016-04-13 03:31:38 +00:00
| ~SPC T d~ | toggle diff margins |
| ~SPC T C-d~ | toggle diff margins globally |
2017-03-29 11:29:22 +00:00
| ~SPC g h o~ | browser at remote |
2015-11-15 19:01:58 +00:00
2016-01-30 11:32:53 +00:00
** Version Control Transient-state
2015-11-15 19:01:58 +00:00
| Key Binding | Description |
|-------------+------------------------------|
| ~SPC g . h~ | Show diff of hunk |
| ~SPC g . n~ | Next hunk |
| ~SPC g . N~ | Previous hunk |
2015-12-07 18:46:48 +00:00
| ~SPC g . p~ | Previous hunk |
2015-11-15 19:01:58 +00:00
| ~SPC g . r~ | Revert hunk |
| ~SPC g . s~ | Stage hunk |
| ~SPC g . t~ | Toggle margin indicators |
| ~SPC g . w~ | Stage file |
| ~SPC g . u~ | Unstage file |
| ~SPC g . d~ | Repo diff popup |
| ~SPC g . D~ | Show diffs of unstaged hunks |
| ~SPC g . c~ | Commit with popup |
| ~SPC g . C~ | Commit |
| ~SPC g . P~ | Push repo with popup |
| ~SPC g . f~ | Fetch for repo with popup |
| ~SPC g . F~ | Pull repo with popup |
| ~SPC g . l~ | Show repo log |
2017-03-12 13:22:03 +00:00
** Smerge Mode Transient-state
| Key Binding | Description |
|-------------+--------------------------|
| ~SPC g r n~ | Next hunk |
| ~SPC g r N~ | Previous hunk |
| ~SPC g r p~ | Previous hunk |
| ~SPC g r j~ | Go to next line |
| ~SPC g r k~ | Go to previous line |
| ~SPC g r b~ | Smerge keep base |
| ~SPC g r m~ | Smerge keep mine |
| ~SPC g r a~ | Smerge keep all |
| ~SPC g r o~ | Smerge keep other |
| ~SPC g r c~ | Smerge keep current |
| ~SPC g r C~ | Smerge combine with next |
| ~SPC g r u~ | Undo |
| ~SPC g r r~ | Smerge refine |
| ~SPC g r q~ | Quit transient state |