00f9ab19ac
The script used to identify and update the change is added into the GitHub workflows script directory. A workflow action can be created to trigger the script to update the headers on the first of every new year. Possibly a task for a consequent PR.
169 lines
5.6 KiB
EmacsLisp
169 lines
5.6 KiB
EmacsLisp
;;; funcs.el --- Version control functions File
|
|
;;
|
|
;; Copyright (c) 2012-2022 Sylvain Benner & Contributors
|
|
;;
|
|
;; Author: Sylvain Benner <sylvain.benner@gmail.com>
|
|
;; URL: https://github.com/syl20bnr/spacemacs
|
|
;;
|
|
;; This file is not part of GNU Emacs.
|
|
;;
|
|
;; This program is free software; you can redistribute it and/or modify
|
|
;; it under the terms of the GNU General Public License as published by
|
|
;; the Free Software Foundation, either version 3 of the License, or
|
|
;; (at your option) any later version.
|
|
;;
|
|
;; This program is distributed in the hope that it will be useful,
|
|
;; but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
;; GNU General Public License for more details.
|
|
;;
|
|
;; You should have received a copy of the GNU General Public License
|
|
;; along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
|
|
(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)))
|
|
|
|
(defun spacemacs//git-gutter+-refresh-in-all-buffers ()
|
|
(git-gutter+-in-all-buffers (when git-gutter+-mode (git-gutter+-refresh))))
|