* bug#57534: 29.0.50; Highlighting lost after auto-revert-mode triggers
@ 2022-09-01 22:40 Dima Kogan
2022-09-02 6:10 ` Eli Zaretskii
2024-06-25 6:52 ` Juri Linkov
0 siblings, 2 replies; 7+ messages in thread
From: Dima Kogan @ 2022-09-01 22:40 UTC (permalink / raw)
To: 57534
Hi. I'm seeing this:
1. seq 10 > /tmp/file
2. emacs -Q /tmp/file
3. (highlight-lines-matching-regexp "3")
This is bound to "M-s h l". I see the line containing "3" highlighted
in yellow, as expected
4. M-x auto-revert-mode
5. Back in the shell: seq 20 > /tmp/file
auto-revert-mode kicks in, updating the buffer with the results of 'seq
20' (possibly updating to an empty buffer first, if we react immediately
to the file truncation). At this point I would expect either:
1. The buffer being fully reverted, with all the highlighting
disappearing. This is what happens if we did M-x revert buffer
2. The buffer contents being reverted, but the highlighting being
reapplied
In this auto-revert scenario, we get something in-between: after the
auto-revert hi-lock-interactive-patterns still contains the highlighting
regex, but no highlighting actually happens. It'd be really nice and
useful if the highlighting stayed.
Thanks!
^ permalink raw reply [flat|nested] 7+ messages in thread
* bug#57534: 29.0.50; Highlighting lost after auto-revert-mode triggers
2022-09-01 22:40 bug#57534: 29.0.50; Highlighting lost after auto-revert-mode triggers Dima Kogan
@ 2022-09-02 6:10 ` Eli Zaretskii
2022-09-02 7:04 ` Juri Linkov
2024-06-25 6:52 ` Juri Linkov
1 sibling, 1 reply; 7+ messages in thread
From: Eli Zaretskii @ 2022-09-02 6:10 UTC (permalink / raw)
To: Dima Kogan; +Cc: 57534
> From: Dima Kogan <dima@secretsauce.net>
> Date: Thu, 01 Sep 2022 15:40:01 -0700
>
> Hi. I'm seeing this:
>
> 1. seq 10 > /tmp/file
>
> 2. emacs -Q /tmp/file
This "file" is in Fundamental mode, yes? If not, which major mode is
used, and does that major mode turns on Font Lock?
> 3. (highlight-lines-matching-regexp "3")
>
> This is bound to "M-s h l". I see the line containing "3" highlighted
> in yellow, as expected
>
> 4. M-x auto-revert-mode
>
> 5. Back in the shell: seq 20 > /tmp/file
>
>
> auto-revert-mode kicks in, updating the buffer with the results of 'seq
> 20' (possibly updating to an empty buffer first, if we react immediately
> to the file truncation). At this point I would expect either:
>
> 1. The buffer being fully reverted, with all the highlighting
> disappearing. This is what happens if we did M-x revert buffer
>
> 2. The buffer contents being reverted, but the highlighting being
> reapplied
>
> In this auto-revert scenario, we get something in-between: after the
> auto-revert hi-lock-interactive-patterns still contains the highlighting
> regex, but no highlighting actually happens. It'd be really nice and
> useful if the highlighting stayed.
The documentation of hi-lock-mode says:
In buffers where Font Lock mode is enabled, patterns are
highlighted using font lock. In buffers where Font Lock mode is
disabled, patterns are applied using overlays; in this case, the
highlighting will not be updated as you type. The Font Lock mode
is considered \"enabled\" in a buffer if its `major-mode'
causes `font-lock-specified-p' to return non-nil, which means
the major mode specifies support for Font Lock.
If I use your recipe in a file visited with C Mode, which does use
Font Lock, the auto-revert doesn't lose the highlighted lines.
^ permalink raw reply [flat|nested] 7+ messages in thread
* bug#57534: 29.0.50; Highlighting lost after auto-revert-mode triggers
2022-09-02 6:10 ` Eli Zaretskii
@ 2022-09-02 7:04 ` Juri Linkov
2022-09-02 7:22 ` Eli Zaretskii
0 siblings, 1 reply; 7+ messages in thread
From: Juri Linkov @ 2022-09-02 7:04 UTC (permalink / raw)
To: Eli Zaretskii; +Cc: Dima Kogan, 57534
>> 3. (highlight-lines-matching-regexp "3")
>>
>> This is bound to "M-s h l". I see the line containing "3" highlighted
>> in yellow, as expected
>>
>> 4. M-x auto-revert-mode
>
> If I use your recipe in a file visited with C Mode, which does use
> Font Lock, the auto-revert doesn't lose the highlighted lines.
However, after manual revert with 'C-x x g' highlighting is still lost.
But this is bug#50431 where 'C-x x g' should be fixed to restore minor modes.
^ permalink raw reply [flat|nested] 7+ messages in thread
* bug#57534: 29.0.50; Highlighting lost after auto-revert-mode triggers
2022-09-02 7:04 ` Juri Linkov
@ 2022-09-02 7:22 ` Eli Zaretskii
2022-09-02 14:27 ` Drew Adams
0 siblings, 1 reply; 7+ messages in thread
From: Eli Zaretskii @ 2022-09-02 7:22 UTC (permalink / raw)
To: Juri Linkov; +Cc: dima, 57534
> From: Juri Linkov <juri@linkov.net>
> Cc: Dima Kogan <dima@secretsauce.net>, 57534@debbugs.gnu.org
> Date: Fri, 02 Sep 2022 10:04:25 +0300
>
> >> 3. (highlight-lines-matching-regexp "3")
> >>
> >> This is bound to "M-s h l". I see the line containing "3" highlighted
> >> in yellow, as expected
> >>
> >> 4. M-x auto-revert-mode
> >
> > If I use your recipe in a file visited with C Mode, which does use
> > Font Lock, the auto-revert doesn't lose the highlighted lines.
>
> However, after manual revert with 'C-x x g' highlighting is still lost.
That's not the same revert as in auto-revert-mode.
> But this is bug#50431 where 'C-x x g' should be fixed to restore minor modes.
I'm not sure this is one of the minor modes to be restored. Maybe
optionally, but not unconditionally. See the discussion in that bug.
^ permalink raw reply [flat|nested] 7+ messages in thread
* bug#57534: 29.0.50; Highlighting lost after auto-revert-mode triggers
2022-09-02 7:22 ` Eli Zaretskii
@ 2022-09-02 14:27 ` Drew Adams
0 siblings, 0 replies; 7+ messages in thread
From: Drew Adams @ 2022-09-02 14:27 UTC (permalink / raw)
To: Eli Zaretskii, Juri Linkov; +Cc: dima@secretsauce.net, 57534@debbugs.gnu.org
> > But this is bug#50431 where 'C-x x g' should be fixed
> > to restore minor modes.
>
> I'm not sure this is one of the minor modes to be restored. Maybe
> optionally, but not unconditionally. See the discussion in that bug.
+2.
Reverting is not about restoring minor modes.
Certainly not blindly so. Not at all.
Reverting is specific to the major mode.
The major mode gets to decide what reverting
means/does. The major mode can decide to
restore whatever it likes, including this or
that minor mode. Nothing should "restore the
minor modes" by default.
My crystal ball whispers that calls for
reverting to "restore minor modes" are trying
to use a sledge hammer where at most a pair
of tweezers might be needed in some uncommon
scenario.
^ permalink raw reply [flat|nested] 7+ messages in thread
* bug#57534: 29.0.50; Highlighting lost after auto-revert-mode triggers
2022-09-01 22:40 bug#57534: 29.0.50; Highlighting lost after auto-revert-mode triggers Dima Kogan
2022-09-02 6:10 ` Eli Zaretskii
@ 2024-06-25 6:52 ` Juri Linkov
2024-06-27 6:52 ` Juri Linkov
1 sibling, 1 reply; 7+ messages in thread
From: Juri Linkov @ 2024-06-25 6:52 UTC (permalink / raw)
To: Dima Kogan; +Cc: 57534
[-- Attachment #1: Type: text/plain, Size: 1275 bytes --]
> 1. seq 10 > /tmp/file
>
> 2. emacs -Q /tmp/file
>
> 3. (highlight-lines-matching-regexp "3")
>
> This is bound to "M-s h l". I see the line containing "3" highlighted
> in yellow, as expected
>
> 4. M-x auto-revert-mode
>
> 5. Back in the shell: seq 20 > /tmp/file
>
> auto-revert-mode kicks in, updating the buffer with the results of 'seq
> 20' (possibly updating to an empty buffer first, if we react immediately
> to the file truncation). At this point I would expect either:
>
> 1. The buffer being fully reverted, with all the highlighting
> disappearing. This is what happens if we did M-x revert buffer
>
> 2. The buffer contents being reverted, but the highlighting being
> reapplied
>
> In this auto-revert scenario, we get something in-between: after the
> auto-revert hi-lock-interactive-patterns still contains the highlighting
> regex, but no highlighting actually happens. It'd be really nice and
> useful if the highlighting stayed.
Now re-highlighting after revert is implemented in Emacs 30.
However, I noticed one problem that makes this feature unusable:
when a file contains file patterns, then after every revert it asks
again and again. This is because hi-lock-file-patterns-policy
missed the value `always', now added in this patch:
[-- Warning: decoded text below may be mangled, UTF-8 assumed --]
[-- Attachment #2: hi-lock-file-patterns-policy.patch --]
[-- Type: text/x-diff, Size: 2918 bytes --]
diff --git a/lisp/hi-lock.el b/lisp/hi-lock.el
index 64b84cdf859..de4384054ef 100644
--- a/lisp/hi-lock.el
+++ b/lisp/hi-lock.el
@@ -122,9 +122,10 @@ hi-lock-file-patterns-policy
"Specify when hi-lock should use patterns found in file.
If `ask', prompt when patterns found in buffer; if bound to a function,
use patterns when function returns t (function is called with patterns
-as first argument); if nil or `never' or anything else, don't use file
-patterns."
+as first argument); if `always', use file patterns without prompt;
+if nil or `never' or anything else, don't use file patterns."
:type '(choice (const :tag "Do not use file patterns" never)
+ (const :tag "Always use file patterns" always)
(const :tag "Ask about file patterns" ask)
(function :tag "Function to check file patterns"))
:group 'hi-lock
@@ -334,8 +335,8 @@ hi-lock-mode
(See `font-lock-keywords'.) They may be edited and re-loaded with \\[hi-lock-find-patterns],
any valid `font-lock-keywords' form is acceptable. When a file is
loaded the patterns are read if `hi-lock-file-patterns-policy' is
- `ask' and the user responds y to the prompt, or if
- `hi-lock-file-patterns-policy' is bound to a function and that
+ `always' or if it's `ask' and the user responds y to the prompt,
+ or if `hi-lock-file-patterns-policy' is bound to a function and that
function returns t.
\\[hi-lock-find-patterns]
@@ -852,6 +853,7 @@ hi-lock-find-patterns
(funcall hi-lock-file-patterns-policy all-patterns))
((eq hi-lock-file-patterns-policy 'ask)
(y-or-n-p "Add patterns from this buffer to hi-lock? "))
+ ((eq hi-lock-file-patterns-policy 'always) t)
(t nil)))
(hi-lock-set-file-patterns all-patterns)
(if (called-interactively-p 'interactive)
@@ -866,12 +868,16 @@ hi-lock-font-lock-hook
(defun hi-lock-revert-buffer-rehighlight ()
"Rehighlight hi-lock patterns after `revert-buffer'.
Apply the previous patterns after reverting the buffer."
- (when-let ((patterns hi-lock-interactive-lighters))
- (lambda ()
- (when hi-lock-interactive-lighters
- (hi-lock-unface-buffer t))
- (dolist (pattern (reverse patterns))
- (highlight-regexp (car pattern) (cadr (nth 1 (caddr pattern))))))))
+ (let ((policy (if hi-lock-file-patterns 'always 'never))
+ (patterns hi-lock-interactive-lighters))
+ (when patterns
+ (lambda ()
+ (unless hi-lock-mode
+ (let ((hi-lock-file-patterns-policy policy))
+ (when hi-lock-interactive-lighters
+ (hi-lock-unface-buffer t))
+ (dolist (pattern (reverse patterns))
+ (highlight-regexp (car pattern) (cadr (nth 1 (caddr pattern)))))))))))
(defvar hi-lock--hashcons-hash
(make-hash-table :test 'equal :weakness t)
^ permalink raw reply related [flat|nested] 7+ messages in thread
* bug#57534: 29.0.50; Highlighting lost after auto-revert-mode triggers
2024-06-25 6:52 ` Juri Linkov
@ 2024-06-27 6:52 ` Juri Linkov
0 siblings, 0 replies; 7+ messages in thread
From: Juri Linkov @ 2024-06-27 6:52 UTC (permalink / raw)
To: Dima Kogan; +Cc: 57534
close 57534 30.0.60
thanks
>> It'd be really nice and useful if the highlighting stayed.
>
> Now re-highlighting after revert is implemented in Emacs 30.
>
> However, I noticed one problem that makes this feature unusable:
> when a file contains file patterns, then after every revert it asks
> again and again. This is because hi-lock-file-patterns-policy
> missed the value `always', now added in this patch:
This is fixed now as well. So this request can be closed now.
Thanks for the request.
^ permalink raw reply [flat|nested] 7+ messages in thread
end of thread, other threads:[~2024-06-27 6:52 UTC | newest]
Thread overview: 7+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2022-09-01 22:40 bug#57534: 29.0.50; Highlighting lost after auto-revert-mode triggers Dima Kogan
2022-09-02 6:10 ` Eli Zaretskii
2022-09-02 7:04 ` Juri Linkov
2022-09-02 7:22 ` Eli Zaretskii
2022-09-02 14:27 ` Drew Adams
2024-06-25 6:52 ` Juri Linkov
2024-06-27 6:52 ` Juri Linkov
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.