Update modules/feature/version-control

This commit is contained in:
Henrik Lissner 2017-02-19 18:39:54 -05:00
parent 9b32c8b95e
commit 2f75a81716
4 changed files with 37 additions and 27 deletions

View file

@ -6,32 +6,19 @@
:init (add-hook 'gitconfig-mode-hook 'flyspell-mode)) :init (add-hook 'gitconfig-mode-hook 'flyspell-mode))
(@def-package gitignore-mode (@def-package gitignore-mode
:mode "/\\.?git/?config$" :mode "/\\.gitignore$")
:mode "/\\.gitmodules$")
(@def-package git-gutter-fringe (@def-package git-gutter-fringe
:commands git-gutter-mode :commands git-gutter-mode
:init (@add-hook (text-mode prog-mode conf-mode) 'git-gutter-mode) :init
(@add-hook (text-mode prog-mode conf-mode) 'git-gutter-mode)
:config :config
(@set :popup "^\\*git-gutter.+\\*$" :regexp t :size 15 :noselect t) (@set :popup "^\\*git-gutter.+\\*$" :regexp t :size 15 :noselect t)
;; Update git-gutter on focus (in case I was using git externally) ;; Update git-gutter on focus (in case I was using git externally)
(add-hook 'focus-in-hook 'git-gutter:update-all-windows) (add-hook 'focus-in-hook 'git-gutter:update-all-windows)
;; places the git gutter outside the margins.
(setq-default fringes-outside-margins t)
;; thin fringe bitmaps
(define-fringe-bitmap 'git-gutter-fr:added
[224 224 224 224 224 224 224 224 224 224 224 224 224 224 224 224 224 224 224 224 224 224 224 224 224]
nil nil 'center)
(define-fringe-bitmap 'git-gutter-fr:modified
[224 224 224 224 224 224 224 224 224 224 224 224 224 224 224 224 224 224 224 224 224 224 224 224 224]
nil nil 'center)
(define-fringe-bitmap 'git-gutter-fr:deleted
[0 0 0 0 0 0 0 0 0 0 0 0 0 128 192 224 240 248]
nil nil 'center)
(@after evil (@after evil
;; Refreshing git-gutter on ESC ;; Refreshing git-gutter on ESC
(advice-add 'evil-force-normal-state :after 'git-gutter))) (advice-add 'evil-force-normal-state :after 'git-gutter)))
@ -44,10 +31,16 @@
(@def-package magit (@def-package magit
:commands magit-status :commands magit-status
:config :config
(@set :popup "^\\*magit.+" :regexp t) (@set :popup "^\\*magit" :regexp t)
(@map :map magit-mode-map
;; Don't interfere with window movement keys
:nv "C-j" nil
:nv "C-k" nil))
(@after evil
(require 'evil-magit) (@def-package evil-magit
;; evil-snipe conflicts with magit :after magit
(add-hook 'magit-mode-hook 'turn-off-evil-snipe-override-mode))) :config
;; evil-snipe conflicts with magit
(add-hook 'magit-mode-hook 'turn-off-evil-snipe-override-mode))

View file

@ -3,7 +3,7 @@
;;;###autoload ;;;###autoload
(defun +vcs-root () (defun +vcs-root ()
"Get git url root." "Get git url root."
(-when-let (url (car-safe (browse-at-remote--remote-ref buffer-file-name))) (when-let (url (car-safe (browse-at-remote--remote-ref buffer-file-name)))
(cdr (browse-at-remote--get-url-from-remote url)))) (cdr (browse-at-remote--get-url-from-remote url))))
;;;###autoload ;;;###autoload
@ -17,10 +17,13 @@ Fallback to repository root."
(error (error
(setq url (shell-command-to-string "hub browse -u --")) (setq url (shell-command-to-string "hub browse -u --"))
(setq url (if url (setq url (if url
(concat (s-trim url) "/" (f-relative (buffer-file-name) (doom-project-root)) (concat (string-trim url) "/"
(when (use-region-p) (format "#L%s-L%s" (file-relative-name (buffer-file-name)
(line-number-at-pos (region-beginning)) (doom-project-root))
(line-number-at-pos (region-end))))))))) (when (use-region-p)
(format "#L%s-L%s"
(line-number-at-pos (region-beginning))
(line-number-at-pos (region-end)))))))))
(when url (browse-url url)))) (when url (browse-url url))))
;;;###autoload ;;;###autoload

View file

@ -10,7 +10,6 @@
(@package gitconfig-mode) (@package gitconfig-mode)
(@package gitignore-mode) (@package gitignore-mode)
(@package magit) (@package magit)
(when (@featurep :feature evil) (when (@featurep :feature evil)
(@package evil-magit)) (@package evil-magit))

View file

@ -87,3 +87,18 @@
(overlay-put (overlay-put
ov 'display (propertize " [...] " 'face 'doom-folded-face)))))) ov 'display (propertize " [...] " 'face 'doom-folded-face))))))
;; subtle diff indicators in the fringe
(@after git-gutter-fringe
;; places the git gutter outside the margins.
(setq-default fringes-outside-margins t)
;; thin fringe bitmaps
(define-fringe-bitmap 'git-gutter-fr:added
[224 224 224 224 224 224 224 224 224 224 224 224 224 224 224 224 224 224 224 224 224 224 224 224 224]
nil nil 'center)
(define-fringe-bitmap 'git-gutter-fr:modified
[224 224 224 224 224 224 224 224 224 224 224 224 224 224 224 224 224 224 224 224 224 224 224 224 224]
nil nil 'center)
(define-fringe-bitmap 'git-gutter-fr:deleted
[0 0 0 0 0 0 0 0 0 0 0 0 0 128 192 224 240 248]
nil nil 'center))