all messages for Emacs-related lists mirrored at yhetil.org
 help / color / mirror / code / Atom feed
* Locking/unlocking file inside with-silent-modifications
@ 2017-12-27 16:27 Eli Zaretskii
  2017-12-28 17:26 ` Eli Zaretskii
  0 siblings, 1 reply; 2+ messages in thread
From: Eli Zaretskii @ 2017-12-27 16:27 UTC (permalink / raw)
  To: emacs-devel

This is a spin-off from bug#29846, where a user complained about very
slow scrolling due to JIT font-lock, when the buffer visits a file
that resides on a very slow networked volume.

The reason for that is that JIT font-lock repeatedly calls
with-silent-modifications, which calls restore-buffer-modified-p,
which calls unlock_file.  It does that even if the user disabled
file-locking (presumably because some other Emacs session could
have locked the file).

After thinking about this, I concluded that it makes little sense to
lock and unlock files in the body run by with-silent-modifications.
After all, with-silent-modifications is meant to pretend that no
modifications happened in the first place, so why would we want to
lock and unlock the buffer's file while performing modifications that
"never happened"?  Am I missing something?

There is a way, albeit an undocumented one, of disabling lock/unlock
inside restore-buffer-modified-p.  So if we agree that it's TRT, the
change to implement that is easy.

Comments?



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

end of thread, other threads:[~2017-12-28 17:26 UTC | newest]

Thread overview: 2+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2017-12-27 16:27 Locking/unlocking file inside with-silent-modifications Eli Zaretskii
2017-12-28 17:26 ` Eli Zaretskii

Code repositories for project(s) associated with this external index

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

This is an external index of several public inboxes,
see mirroring instructions on how to clone and mirror
all data and code used by this external index.