unofficial mirror of bug-gnu-emacs@gnu.org 
 help / color / mirror / code / Atom feed
* bug#32225: 27.0.50; [PATCH] avoid calling vc backend if vc-display-status is nil
@ 2018-07-20 16:45 Andy Moreton
  2018-07-27  7:07 ` Eli Zaretskii
  2018-08-11 10:05 ` Eli Zaretskii
  0 siblings, 2 replies; 4+ messages in thread
From: Andy Moreton @ 2018-07-20 16:45 UTC (permalink / raw)
  To: 32225

If the user sets `vc-display-status' to nil then the VC backend is still
called to get a revision number, even though it will not be displayed.

The following patch avoids this unneeded work.


Do not call VC backend to update mode line if vc-display-status is nil

2018-07-20  Andy Moreton  <andrewjmoreton@gmail.com>

	* lisp/vc/vc-hooks.el (vc-mode-line): Avoid calling VC backend if
	vc-display-status is nil.

diff --git a/lisp/vc/vc-hooks.el b/lisp/vc/vc-hooks.el
index 55c0132bf2..f1b622b54a 100644
--- a/lisp/vc/vc-hooks.el
+++ b/lisp/vc/vc-hooks.el
@@ -692,24 +692,26 @@ vc-mode-line
  If BACKEND is passed use it as the VC backend when computing the result."
    (interactive (list buffer-file-name))
    (setq backend (or backend (vc-backend file)))
-  (if (not backend)
-      (setq vc-mode nil)
+  (cond
+   ((not backend)
+    (setq vc-mode nil))
+   ((null vc-display-status)
+    (setq vc-mode (concat " " (symbol-name backend))))
+   (t
      (let* ((ml-string (vc-call-backend backend 'mode-line-string file))
  	   (ml-echo (get-text-property 0 'help-echo ml-string)))
        (setq vc-mode
  	    (concat
  	     " "
-	     (if (null vc-display-status)
-		 (symbol-name backend)
-	       (propertize
-		ml-string
-		'mouse-face 'mode-line-highlight
-		'help-echo
-		(concat (or ml-echo
-			    (format "File under the %s version control system"
-				    backend))
-			"\nmouse-1: Version Control menu")
-		'local-map vc-mode-line-map)))))
+	     (propertize
+	      ml-string
+	      'mouse-face 'mode-line-highlight
+	      'help-echo
+	      (concat (or ml-echo
+			  (format "File under the %s version control system"
+				  backend))
+		      "\nmouse-1: Version Control menu")
+	      'local-map vc-mode-line-map))))
      ;; If the user is root, and the file is not owner-writable,
      ;; then pretend that we can't write it
      ;; even though we can (because root can write anything).
@@ -718,7 +720,7 @@ vc-mode-line
  	 (not buffer-read-only)
  	 (zerop (user-real-uid))
  	 (zerop (logand (file-modes buffer-file-name) 128))
-	 (setq buffer-read-only t)))
+	 (setq buffer-read-only t))))
    (force-mode-line-update)
    backend)




In GNU Emacs 27.0.50 (build 21, x86_64-w64-mingw32)
  of 2018-07-20 built on AJM-DESKTOP2
Repository revision: 249606fb539bd1a7dc95129277c1684826fc068f
Windowing system distributor 'Microsoft Corp.', version 10.0.16299
Recent messages:
Finding changes in c:/emacs/git/emacs/master/lisp/vc/vc-hooks.el...
Running in foreground: git --no-pager diff-index --exit-code -p HEAD  -- 
vc-hooks.el
Done (status=1): git --no-pager diff-index --exit-code -p HEAD  -- vc-hooks.el
Finding changes in c:/emacs/git/emacs/master/lisp/vc/vc-hooks.el...done
Mark activated
Mark set
Saved text from "diff --git a/lisp/vc/vc-hooks.el b/lisp/"
Mark set
Saving file c:/home/ajm/sandbox/emacs/vc-mode-line.patch...
Wrote c:/home/ajm/sandbox/emacs/vc-mode-line.patch

Configured using:
  'configure --prefix=/c/emacs/emacs-master --without-dbus --with-gif
  --with-gnutls --without-imagemagick --with-jpeg --with-json
  --with-lcms2 --with-modules --with-png --without-pop --with-rsvg
  --with-tiff --with-xml2 --with-xpm --enable-checking 'CFLAGS= -Og -g3
  -gdwarf-4 -fdiagnostics-color=never'
  PKG_CONFIG_PATH=/mingw64/lib/pkgconfig:/mingw64/share/pkgconfig'

Configured features:
XPM JPEG TIFF GIF PNG RSVG SOUND NOTIFY ACL GNUTLS LIBXML2 ZLIB
TOOLKIT_SCROLL_BARS MODULES THREADS JSON LCMS2

Important settings:
   value of $LANG: ENG
   locale-coding-system: cp1252

Major mode: Diff

Minor modes in effect:
   whitespace-mode: t
   bug-reference-prog-mode: t
   shell-dirtrack-mode: t
   which-function-mode: t
   fci-mode: t
   desktop-save-mode: t
   show-paren-mode: t
   auto-image-file-mode: t
   minibuffer-electric-default-mode: t
   override-global-mode: t
   tooltip-mode: t
   global-eldoc-mode: t
   mouse-wheel-mode: t
   menu-bar-mode: t
   file-name-shadow-mode: t
   global-font-lock-mode: t
   font-lock-mode: t
   blink-cursor-mode: t
   auto-composition-mode: t
   auto-compression-mode: t
   column-number-mode: t
   line-number-mode: t
   transient-mark-mode: t

Load-path shadows:
None found.

Features:
(shadow emacsbug sendmail whitespace vc-dir ewoc vc-filewise log-view
pcvs-util vc-annotate vc arc-mode archive-mode vc-git eieio-opt speedbar
sb-image ezimage dframe cl-print cc-langs help-fns radix-tree sh-script
smie executable find-dired grep url-http url-gw url-auth url-queue
url-cache url url-proxy url-privacy url-expand url-methods url-history
url-cookie url-domsuf shr text-property-search svg xml dom thingatpt qp
flow-fill mm-archive browse-url misearch multi-isearch add-log sort
mail-extr gnus-async gnus-bcklg gnus-ml gnus-topic nndraft nnmh
network-stream nnml nnnil gnus-cite gnus-agent gnus-srvr gnus-score
score-mode nnvirtual gnus-msg gnus-art mm-uu mml2015 mm-view mml-smime
smime dig mailcap nntp gnus-cache ibuf-ext ibuf-macs ibuffer
ibuffer-loaddefs time face-remap dired-aux url-util elec-pair org-rmail
org-mhe org-irc org-info org-gnus nnir gnus-sum gnus-group gnus-undo
gnus-start gnus-cloud nnimap nnmail mail-source utf7 netrc nnoo
gnus-spec gnus-int gnus-range message rfc822 mml mml-sec epa mm-decode
mm-bodies mm-encode mail-parse rfc2231 mailabbrev gmm-utils mailheader
gnus-win gnus nnheader gnus-util rmail rmail-loaddefs rfc2047 rfc2045
ietf-drums mail-utils mm-util mail-prsvr org-docview doc-view jka-compr
image-mode org-bibtex bibtex org-bbdb org-w3m org-element avl-tree
generator org org-macro org-footnote org-pcomplete org-list org-faces
org-entities noutline outline org-version ob-plantuml ob-dot ob-ditaa
ob-shell ob-emacs-lisp ob ob-tangle org-src ob-ref ob-lob ob-table
ob-keys ob-exp ob-comint ob-core ob-eval org-compat org-macs
org-loaddefs find-func cal-menu calendar cal-loaddefs dired
dired-loaddefs macrostep-c cmacexp macrostep pp cc-mode cc-fonts
cc-guess cc-menus cc-cmds cc-styles cc-align cc-engine cc-vars cc-defs
vc-dispatcher vc-hg bug-reference xcscope diff-mode python tramp-sh
tramp trampver tramp-compat tramp-loaddefs ucs-normalize parse-time
format-spec cap-words superword subword etags xref project compile
htmlize cl info-look man shell pcomplete which-func imenu
fill-column-indicator rx edmacro kmacro desktop frameset cygwin-mount
ange-ftp comint ansi-color ring hl-line paren image-file minibuf-eldef
cus-edit cus-start cus-load wid-edit warnings delight advice use-package
use-package-ensure use-package-delight use-package-diminish
use-package-bind-key bind-key easy-mmode use-package-core nsm rmc gnutls
puny time-date mule-util info finder-inf package let-alist derived pcase
cl-extra help-mode easymenu url-handlers url-parse auth-source cl-seq
eieio eieio-core cl-macs eieio-loaddefs password-cache json map url-vars
seq byte-opt gv bytecomp byte-compile cconv epg epg-config subr-x
cl-loaddefs cl-lib tooltip eldoc electric uniquify ediff-hook vc-hooks
lisp-float-type mwheel dos-w32 ls-lisp disp-table term/w32-win w32-win
w32-vars term/common-win tool-bar dnd fontset image regexp-opt fringe
tabulated-list replace newcomment text-mode elisp-mode lisp-mode
prog-mode register page menu-bar rfn-eshadow isearch timer select
scroll-bar mouse jit-lock font-lock syntax facemenu font-core
term/tty-colors frame cl-generic cham georgian utf-8-lang misc-lang
vietnamese tibetan thai tai-viet lao korean japanese eucjp-ms cp51932
hebrew greek romanian slovak czech european ethiopic indian cyrillic
chinese composite charscript charprop case-table epa-hook jka-cmpr-hook
help simple abbrev obarray minibuffer cl-preloaded nadvice loaddefs
button faces cus-face macroexp files text-properties overlay sha1 md5
base64 format env code-pages mule custom widget hashtable-print-readable
backquote threads w32notify w32 lcms2 multi-tty make-network-process
emacs)

Memory information:
((conses 16 1030451 701809)
  (symbols 56 51267 49)
  (miscs 48 8386 7418)
  (strings 32 133014 56086)
  (string-bytes 1 4364350)
  (vectors 16 80615)
  (vector-slots 8 2109657 426454)
  (floats 8 406 1933)
  (intervals 56 77681 13720)
  (buffers 992 105))






^ permalink raw reply related	[flat|nested] 4+ messages in thread

* bug#32225: 27.0.50; [PATCH] avoid calling vc backend if vc-display-status is nil
  2018-07-20 16:45 bug#32225: 27.0.50; [PATCH] avoid calling vc backend if vc-display-status is nil Andy Moreton
@ 2018-07-27  7:07 ` Eli Zaretskii
  2018-07-28 10:04   ` Dmitry Gutov
  2018-08-11 10:05 ` Eli Zaretskii
  1 sibling, 1 reply; 4+ messages in thread
From: Eli Zaretskii @ 2018-07-27  7:07 UTC (permalink / raw)
  To: Andy Moreton; +Cc: 32225

> From: Andy Moreton <andrewjmoreton@gmail.com>
> Date: Fri, 20 Jul 2018 17:45:09 +0100
> 
> If the user sets `vc-display-status' to nil then the VC backend is still
> called to get a revision number, even though it will not be displayed.
> 
> The following patch avoids this unneeded work.
> 
> 
> Do not call VC backend to update mode line if vc-display-status is nil
> 
> 2018-07-20  Andy Moreton  <andrewjmoreton@gmail.com>
> 
> 	* lisp/vc/vc-hooks.el (vc-mode-line): Avoid calling VC backend if
> 	vc-display-status is nil.

LGTM, please push to the master branch.

Thanks.





^ permalink raw reply	[flat|nested] 4+ messages in thread

* bug#32225: 27.0.50; [PATCH] avoid calling vc backend if vc-display-status is nil
  2018-07-27  7:07 ` Eli Zaretskii
@ 2018-07-28 10:04   ` Dmitry Gutov
  0 siblings, 0 replies; 4+ messages in thread
From: Dmitry Gutov @ 2018-07-28 10:04 UTC (permalink / raw)
  To: Eli Zaretskii, Andy Moreton; +Cc: 32225

On 7/27/18 10:07 AM, Eli Zaretskii wrote:
>> From: Andy Moreton <andrewjmoreton@gmail.com>
>> Date: Fri, 20 Jul 2018 17:45:09 +0100
>>
>> If the user sets `vc-display-status' to nil then the VC backend is still
>> called to get a revision number, even though it will not be displayed.
>>
>> The following patch avoids this unneeded work.
>>
>>
>> Do not call VC backend to update mode line if vc-display-status is nil
>>
>> 2018-07-20  Andy Moreton  <andrewjmoreton@gmail.com>
>>
>> 	* lisp/vc/vc-hooks.el (vc-mode-line): Avoid calling VC backend if
>> 	vc-display-status is nil.
> 
> LGTM, please push to the master branch.

+1





^ permalink raw reply	[flat|nested] 4+ messages in thread

* bug#32225: 27.0.50; [PATCH] avoid calling vc backend if vc-display-status is nil
  2018-07-20 16:45 bug#32225: 27.0.50; [PATCH] avoid calling vc backend if vc-display-status is nil Andy Moreton
  2018-07-27  7:07 ` Eli Zaretskii
@ 2018-08-11 10:05 ` Eli Zaretskii
  1 sibling, 0 replies; 4+ messages in thread
From: Eli Zaretskii @ 2018-08-11 10:05 UTC (permalink / raw)
  To: Andy Moreton; +Cc: 32225-done

> From: Andy Moreton <andrewjmoreton@gmail.com>
> Date: Fri, 20 Jul 2018 17:45:09 +0100
> 
> If the user sets `vc-display-status' to nil then the VC backend is still
> called to get a revision number, even though it will not be displayed.
> 
> The following patch avoids this unneeded work.

Thanks, pushed to the master branch.





^ permalink raw reply	[flat|nested] 4+ messages in thread

end of thread, other threads:[~2018-08-11 10:05 UTC | newest]

Thread overview: 4+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2018-07-20 16:45 bug#32225: 27.0.50; [PATCH] avoid calling vc backend if vc-display-status is nil Andy Moreton
2018-07-27  7:07 ` Eli Zaretskii
2018-07-28 10:04   ` Dmitry Gutov
2018-08-11 10:05 ` Eli Zaretskii

Code repositories for project(s) associated with this public inbox

	https://git.savannah.gnu.org/cgit/emacs.git

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).