From: Tom Tromey Date: Wed, 19 Aug 2020 11:38:44 +0000 (+0200) Subject: Add a variable to control VC completion over branch names X-Git-Tag: emacs-28.0.90~6513 X-Git-Url: http://git.eshelyaron.com/gitweb/?a=commitdiff_plain;h=ed96a2121de61390d7acce6f2f03521b47b7d978;p=emacs.git Add a variable to control VC completion over branch names * lisp/vc/vc-git.el (vc-git-revision-complete-only-branches): New variable (bug#25710). (vc-git-revision-table): Use it. --- diff --git a/etc/NEWS b/etc/NEWS index 14101b41d96..a1255a6f423 100644 --- a/etc/NEWS +++ b/etc/NEWS @@ -259,6 +259,10 @@ invoke 'C-u C-x v s' ('vc-create-tag'). --- *** 'vc-hg' now uses 'hg summary' to populate extra 'vc-dir' headers. +--- +*** New variable 'vc-git-revision-complete-only-branches' +If non-nil, only branches and remotes are considered when doing +completion over branch names. ** Gnus diff --git a/lisp/vc/vc-git.el b/lisp/vc/vc-git.el index 78a2fa08795..84aeb0a1105 100644 --- a/lisp/vc/vc-git.el +++ b/lisp/vc/vc-git.el @@ -210,6 +210,16 @@ toggle display of the entire list." widget)))) :version "27.1") +(defcustom vc-git-revision-complete-only-branches nil + "Control whether tags are returned by revision completion for Git. + +When non-nil, only branches and remotes will be returned by +`vc-git-revision-completion-table'. This is used by various VC +commands when completing branch names. When nil, tags are also +included in the completions." + :type 'boolean + :version "28.1") + ;; History of Git commands. (defvar vc-git-history nil) @@ -1415,9 +1425,11 @@ This requires git 1.8.4 or later, for the \"-L\" option of \"git log\"." (with-temp-buffer (vc-git-command t nil nil "for-each-ref" "--format=%(refname)") (goto-char (point-min)) - (while (re-search-forward "^refs/\\(heads\\|tags\\|remotes\\)/\\(.*\\)$" - nil t) - (push (match-string 2) table))) + (let ((regexp (if vc-git-revision-complete-only-branches + "^refs/\\(heads\\|remotes\\)/\\(.*\\)$" + "^refs/\\(heads\\|tags\\|remotes\\)/\\(.*\\)$"))) + (while (re-search-forward regexp nil t) + (push (match-string 2) table)))) table)) (defun vc-git-revision-completion-table (files)