spacemacs/layers/+source-control/version-control/funcs.el
Miciah Masters ec0a535b27 Show conflicts in smerge ts hint
Use a dynamic hint for the smerge transient state in order to show the
current and total numbers of conflicts, and make the full hint toggleable.

* CHANGELOG.develop: Add an entry for this change.
* layers/+source-control/version-control/config.el
(spacemacs--smerge-ts-full-hint-toggle): New variable.
* layers/+source-control/version-control/funcs.el
(spacemacs//smerge-ts-hint): New function.  Return a string indicating the
index of the current conflict and the total number of conflicts detected by
smerge-mode.  If spacemacs--smerge-ts-full-hint-toggle is true, append the
smerge transient state's full hint.
(spacemacs//smerge-ts-toggle-hint): Toggle showing the full hint for the
smerge transient state.
* layers/+source-control/version-control/packages.el
(version-control/init-smerge-mode): Define the transient state in :init so
we can use spacemacs|transient-state-format-hint.  Use
spacemacs//smerge-ts-hint to display a dynamic hint.  Bind the ? key to
spacemacs//smerge-ts-toggle-hint.
2019-10-13 10:09:42 +02:00

155 lines
4.9 KiB
EmacsLisp

;;; funcs.el --- Version control functions File
;;
;; 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
(defun spacemacs/diff-mode-revert-hunk ()
(interactive)
(diff-apply-hunk t))
(defun spacemacs/vcs-next-hunk ()
(interactive)
(let ((current-prefix-arg t))
(call-interactively
(cl-case version-control-diff-tool
(diff-hl 'diff-hl-next-hunk)
(git-gutter 'git-gutter:next-hunk)
(git-gutter+ 'git-gutter+-next-hunk)))))
(defun spacemacs/vcs-previous-hunk ()
(interactive)
(let ((current-prefix-arg t))
(call-interactively
(cl-case version-control-diff-tool
(diff-hl 'diff-hl-previous-hunk)
(git-gutter 'git-gutter:previous-hunk)
(git-gutter+ 'git-gutter+-previous-hunk)))))
(defun spacemacs/vcs-revert-hunk ()
(interactive)
(let ((current-prefix-arg t)
(inhibit-modification-hooks t))
(call-interactively
(cl-case version-control-diff-tool
(diff-hl 'diff-hl-revert-hunk)
(git-gutter 'git-gutter:revert-hunk)
(git-gutter+ 'git-gutter+-revert-hunks)))))
(defun spacemacs/vcs-stage-hunk ()
(interactive)
(if (eq 'diff-hl version-control-diff-tool)
(message "Staging not available")
(let ((current-prefix-arg t))
(call-interactively
(cl-case version-control-diff-tool
(git-gutter 'git-gutter:stage-hunk)
(git-gutter+ 'git-gutter+-stage-hunks))))))
(defun spacemacs/vcs-show-hunk ()
(interactive)
(let ((current-prefix-arg t))
(call-interactively
(cl-case version-control-diff-tool
(diff-hl 'diff-hl-diff-goto-hunk)
(git-gutter 'git-gutter:popup-hunk)
(git-gutter+ 'git-gutter+-show-hunk-inline-at-point)))))
(defun spacemacs/vcs-enable-margin ()
(interactive)
(let ((current-prefix-arg t))
(call-interactively
(cl-case version-control-diff-tool
(diff-hl 'diff-hl-mode)
(git-gutter 'git-gutter-mode)
(git-gutter+ 'git-gutter+-mode)))))
(defun spacemacs/vcs-disable-margin ()
(interactive)
(let ((current-prefix-arg nil))
(call-interactively
(cl-case version-control-diff-tool
(diff-hl 'diff-hl-mode)
(git-gutter 'git-gutter-mode)
(git-gutter+ 'git-gutter+-mode)))))
(defun spacemacs/vcs-enable-margin-globally ()
(interactive)
(let ((current-prefix-arg t))
(call-interactively
(cl-case version-control-diff-tool
(diff-hl 'global-diff-hl-mode)
(git-gutter 'global-git-gutter-mode)
(git-gutter+ 'global-git-gutter+-mode)))))
(defun spacemacs/vcs-disable-margin-globally ()
(interactive)
(let ((current-prefix-arg nil))
(call-interactively
(cl-case version-control-diff-tool
(diff-hl 'global-diff-hl-mode)
(git-gutter 'global-git-gutter-mode)
(git-gutter+ 'global-git-gutter+-mode)))))
(defun spacemacs/vcs-show-help ()
(interactive)
(setq version-control--ms-doc-toggle
(logxor version-control--ms-doc-toggle 1)))
(defun spacemacs/vcs-margin-p ()
(interactive)
(cl-case version-control-diff-tool
(diff-hl diff-hl-mode)
(git-gutter (bound-and-true-p git-gutter-mode))
(git-gutter+ (bound-and-true-p git-gutter+-mode))))
(defun spacemacs/vcs-margin-global-p ()
(interactive)
(cl-case version-control-diff-tool
(diff-hl global-diff-hl-mode)
(git-gutter global-git-gutter-mode)
(git-gutter+ global-git-gutter+-mode)))
(spacemacs|add-toggle version-control-margin
:status (spacemacs/vcs-margin-p)
:on (spacemacs/vcs-enable-margin)
:off (spacemacs/vcs-disable-margin)
:documentation "Enable diff margins."
:evil-leader "Td")
(spacemacs|add-toggle version-control-margin-globally
:status (spacemacs/vcs-margin-global-p)
:on (spacemacs/vcs-enable-margin-globally)
:off (spacemacs/vcs-disable-margin-globally)
:documentation "Enable diff margins globally."
:evil-leader "T C-d")
(defun spacemacs//smerge-ts-hint ()
"Return a hint for the smerge transient state.
Return a string indicating the index of the current conflict and
the number of conflicts detected by `smerge-mode'."
(concat
(cl-loop for ol being the overlays
with pos = (point)
if (eq (overlay-get ol 'smerge) 'conflict)
count ol into total
and if (<= (overlay-start ol) pos)
count ol into idx
finally return (format "conflict [%d/%d]" idx total))
(if spacemacs--smerge-ts-full-hint-toggle
spacemacs--smerge-ts-full-hint
(concat " (["
(propertize "?" 'face 'hydra-face-red)
"] help)"))))
(defun spacemacs//smerge-ts-toggle-hint ()
"Toggle the full hint docstring for the smerge transient state."
(interactive)
(setq spacemacs--smerge-ts-full-hint-toggle
(not spacemacs--smerge-ts-full-hint-toggle)))