diff options
-rw-r--r-- | lisp/init-git.el | 32 |
1 files changed, 32 insertions, 0 deletions
diff --git a/lisp/init-git.el b/lisp/init-git.el index 62b6513..225330b 100644 --- a/lisp/init-git.el +++ b/lisp/init-git.el @@ -368,4 +368,36 @@ the file name if NO-DIRECTORY is non-nil." (setq magit-annex-all-action-arguments (delete "--auto" magit-annex-all-action-arguments))) + +;;; Other git + +(defun km/git-shorten-hash-at-point (&optional n) + "Shorten hash at point to N characters. +N defaults to 10 and can be controlled by a numeric prefix +argument." + (interactive (list (or (and current-prefix-arg + (prefix-numeric-value current-prefix-arg)) + 10))) + (cond + ((< n 4) + (user-error "Hash must be at least 4 characters")) + ((>= n 40) + (user-error "Full hashes are 40 characters")) + ((> n 30) + (message "That doesn't seem incredibly useful, but OK"))) + (let ((offset (- (skip-chars-backward "A-z0-9")))) + (if (looking-at "\\b[A-z0-9]\\{5,40\\}\\b") + (let ((hash-len (- (match-end 0) (match-beginning 0))) + (hash (match-string 0))) + (when (< hash-len n) + (user-error "Desired hash length is greater than current")) + (replace-match (substring hash 0 n) 'fixedcase) + (when (< offset n) + (skip-chars-backward "A-z0-9") + (goto-char (+ (point) offset)))) + (goto-char (+ (point) offset)) + (user-error "No hash found at point")))) + +(define-key km/git-map "n" 'km/git-shorten-hash-at-point) + (provide 'init-git) |