This repository has been archived on 2024-10-22. You can view files and clone it, but cannot push or open issues or pull requests.
spacemacs/layers/+source-control/version-control/packages.el

294 lines
9.4 KiB
EmacsLisp
Raw Normal View History

;;; packages.el --- Source Control Layer packages File for Spacemacs
;;
2018-01-04 07:00:25 +00:00
;; Copyright (c) 2012-2018 Sylvain Benner & Contributors
;;
;; Author: Sylvain Benner <sylvain.benner@gmail.com>
;; URL: https://github.com/syl20bnr/spacemacs
;;
;; This file is not part of GNU Emacs.
;;
;;; License: GPLv3
(setq version-control-packages
'(
2017-03-29 11:29:22 +00:00
browse-at-remote
2016-02-22 18:18:48 +00:00
(vc :location built-in)
diff-mode
diff-hl
evil-unimpaired
git-gutter
git-gutter+
git-gutter-fringe
git-gutter-fringe+
2017-03-12 13:22:03 +00:00
(smerge-mode :location built-in)
))
2016-02-22 18:18:48 +00:00
(defun version-control/init-vc ()
(use-package vc
:defer t
2016-02-22 18:18:48 +00:00
:init
(spacemacs/declare-prefix "gv" "version-control")
:config
(progn
(spacemacs/set-leader-keys
"gvv" 'vc-next-action
"gvg" 'vc-annotate
"gvD" 'vc-root-diff
"gve" 'vc-ediff
"gvd" 'vc-dir
"gv+" 'vc-update
"gvi" 'vc-register
"gvu" 'vc-revert
"gvl" 'vc-print-log
"gvL" 'vc-print-root-log
"gvI" 'vc-ignore
"gvr" 'vc-resolve-conflicts)
(evilified-state-evilify vc-dir-mode vc-dir-mode-map
"j" 'vc-dir-next-line
(kbd "M-n") 'vc-dir-next-line
"k" 'vc-dir-previous-line
(kbd "M-p") 'vc-dir-previous-line
"gj" 'vc-dir-next-directory
(kbd "<tab>") 'vc-dir-next-directory
"gk" 'vc-dir-previous-directory
(kbd "<backtab>") 'vc-dir-previous-directory
"l" 'vc-print-log
"c" 'vc-next-action
"a" 'vc-annotate
"r" 'vc-dir-refresh
"E" 'vc-dir-ignore)
(evilified-state-evilify log-view-mode log-view-mode-map
(kbd "M-n") 'log-view-msg-next
(kbd "M-p") 'log-view-msg-prev
(kbd "C-j") 'log-view-msg-next
(kbd "C-k") 'log-view-msg-prev
"J" 'log-view-file-next
(kbd "<tab>") 'log-view-file-next
"gj" 'log-view-file-next
"K" 'log-view-file-prev
"gk" 'log-view-file-prev
(kbd "<backtab>") 'log-view-file-prev
(kbd "<return>") 'log-view-find-revision
"H" 'log-view-toggle-entry-display
"o" 'ace-link-woman)
(evilified-state-evilify vc-svn-log-view-mode vc-svn-log-view-mode-map)
(evilified-state-evilify vc-git-log-view-mode vc-git-log-view-mode-map)
(evilified-state-evilify vc-hg-log-view-mode vc-git-log-view-mode-map)
(evilified-state-evilify vc-annotate-mode vc-annotate-mode-map
"J" 'vc-annotate-next-revision
"K" 'vc-annotate-prev-revision
"L" 'vc-annotate-show-log-revision-at-line
"H" 'vc-annotate-toggle-annotation-visibility
"a" 'vc-annotate-revision-at-line
"p" 'vc-annotate-revision-previous-to-line))))
(defun version-control/init-diff-mode ()
(use-package diff-mode
:defer t
2016-02-22 18:18:48 +00:00
:config
(evilified-state-evilify diff-mode diff-mode-map
(kbd "C-j") 'diff-hunk-next
(kbd "C-k") 'diff-hunk-prev
(kbd "M-n") 'diff-hunk-next
(kbd "M-p") 'diff-hunk-prev
"J" 'diff-file-next
(kbd "<tab>") 'diff-file-next
"gj" 'diff-file-next
"K" 'diff-file-prev
(kbd "<backtab>") 'diff-file-prev
"gk" 'diff-file-prev
"a" 'diff-apply-hunk
"r" 'spacemacs/diff-mode-revert-hunk
"S" 'diff-split-hunk
"D" 'diff-hunk-kill
"u" 'diff-undo)))
(defun version-control/init-diff-hl ()
(use-package diff-hl
2018-06-11 03:30:48 +00:00
:defer 1
:init
(progn
2016-02-22 18:18:48 +00:00
(spacemacs/set-leader-keys "gv=" 'diff-hl-diff-goto-hunk)
(setq diff-hl-side 'left)
(when (eq version-control-diff-tool 'diff-hl)
(when (configuration-layer/package-used-p 'magit)
2018-06-11 03:30:48 +00:00
(add-hook 'magit-post-refresh-hook 'diff-hl-magit-post-refresh))))
:config
(when (eq version-control-diff-tool 'diff-hl)
(if version-control-global-margin
(run-with-idle-timer 1 nil 'global-diff-hl-mode)
(run-with-idle-timer 1 nil 'diff-hl-margin-mode))
(spacemacs|do-after-display-system-init
(setq diff-hl-side (if (eq version-control-diff-side 'left)
'left 'right))
(diff-hl-margin-mode -1)))))
(defun version-control/post-init-evil-unimpaired ()
(define-key evil-normal-state-map (kbd "[ h") 'spacemacs/vcs-previous-hunk)
(define-key evil-normal-state-map (kbd "] h") 'spacemacs/vcs-next-hunk))
(defun version-control/init-git-gutter ()
(use-package git-gutter
:commands (global-git-gutter-mode git-gutter-mode)
:init
(progn
;; If you enable global minor mode
(when (and (eq version-control-diff-tool 'git-gutter)
version-control-global-margin)
(run-with-idle-timer 1 nil 'global-git-gutter-mode))
(setq git-gutter:update-interval 2
git-gutter:modified-sign " "
git-gutter:added-sign "+"
git-gutter:deleted-sign "-"
git-gutter:diff-option "-w"
git-gutter:hide-gutter t
git-gutter:ask-p nil
git-gutter:verbosity 0
git-gutter:handled-backends '(git hg bzr svn)
git-gutter:hide-gutter t))
:config
(spacemacs|hide-lighter git-gutter-mode)))
(defun version-control/init-git-gutter-fringe ()
(use-package git-gutter-fringe
:commands git-gutter-mode
:init
(progn
(spacemacs|do-after-display-system-init
(with-eval-after-load 'git-gutter
(require 'git-gutter-fringe)))
(setq git-gutter-fr:side (if (eq version-control-diff-side 'left)
'left-fringe 'right-fringe)))
:config
(progn
;; custom graphics that works nice with half-width fringes
(fringe-helper-define 'git-gutter-fr:added nil
"..X...."
"..X...."
"XXXXX.."
"..X...."
"..X...."
)
(fringe-helper-define 'git-gutter-fr:deleted nil
"......."
"......."
"XXXXX.."
"......."
"......."
)
(fringe-helper-define 'git-gutter-fr:modified nil
"..X...."
".XXX..."
"XX.XX.."
".XXX..."
"..X...."
))))
(defun version-control/init-git-gutter+ ()
(use-package git-gutter+
:commands (global-git-gutter+-mode git-gutter+-mode git-gutter+-refresh)
:init
(progn
;; If you enable global minor mode
(when (and (eq version-control-diff-tool 'git-gutter+)
version-control-global-margin)
(add-hook 'magit-pre-refresh-hook 'git-gutter+-refresh)
(run-with-idle-timer 1 nil 'global-git-gutter+-mode))
(setq
git-gutter+-modified-sign " "
git-gutter+-added-sign "+"
git-gutter+-deleted-sign "-"
git-gutter+-diff-option "-w"
git-gutter+-hide-gutter t))
;; identify magit changes
:config
(spacemacs|hide-lighter git-gutter+-mode)
;; (set-face-foreground 'git-gutter+-modified "black")
;; (set-face-foreground 'git-gutter+-added "black")
;; (set-face-foreground 'git-gutter+-deleted "black")
;; (set-face-background 'git-gutter+-modified "orange1")
;; (set-face-background 'git-gutter+-added "green4")
;; (set-face-background 'git-gutter+-deleted "red3")
))
(defun version-control/init-git-gutter-fringe+ ()
(use-package git-gutter-fringe+
:commands git-gutter+-mode
:init
(progn
(spacemacs|do-after-display-system-init
(with-eval-after-load 'git-gutter+
(require 'git-gutter-fringe+)))
(setq git-gutter-fr+-side (if (eq version-control-diff-side 'left)
'left-fringe 'right-fringe)))
:config
(progn
;; custom graphics that works nice with half-width fringes
(fringe-helper-define 'git-gutter-fr+-added nil
"..X...."
"..X...."
"XXXXX.."
"..X...."
"..X...."
)
(fringe-helper-define 'git-gutter-fr+-deleted nil
"......."
"......."
"XXXXX.."
"......."
"......."
)
(fringe-helper-define 'git-gutter-fr+-modified nil
"..X...."
".XXX..."
"XX.XX.."
".XXX..."
"..X...."
))))
2017-03-12 13:22:03 +00:00
(defun version-control/init-smerge-mode ()
(use-package smerge-mode
:defer t
2017-03-12 13:22:03 +00:00
:diminish smerge-mode
:commands spacemacs/smerge-transient-state/body
:init
(spacemacs/set-leader-keys
"gr" 'spacemacs/smerge-transient-state/body)
:config
(progn
(spacemacs|define-transient-state smerge
:title "smerge transient state"
:doc "
movement^^^^ merge action^^ other
---------------------^^^^ -------------------^^ -----------
[_n_]^^ next hunk [_b_] keep base [_u_] undo
[_N_/_p_] prev hunk [_m_] keep mine [_r_] refine
[_j_/_k_] move up/down [_a_] keep all [_q_] quit
^^^^ [_o_] keep other
^^^^ [_c_] keep current
^^^^ [_C_] combine with next"
:bindings
("n" smerge-next)
("p" smerge-prev)
("N" smerge-prev)
("j" evil-next-line)
("k" evil-previous-line)
("a" smerge-keep-all)
("b" smerge-keep-base)
("m" smerge-keep-mine)
("o" smerge-keep-other)
("c" smerge-keep-current)
("C" smerge-combine-with-next)
("r" smerge-refine)
("u" undo-tree-undo)
("q" nil :exit t)))))
2017-03-29 11:29:22 +00:00
(defun version-control/init-browse-at-remote ()
(use-package browse-at-remote
:defer t
2017-03-29 11:29:22 +00:00
:init (spacemacs/set-leader-keys "gho" 'browse-at-remote)))