* Info bug
@ 2008-04-21 20:01 Chong Yidong
2008-04-21 23:16 ` Juri Linkov
0 siblings, 1 reply; 10+ messages in thread
From: Chong Yidong @ 2008-04-21 20:01 UTC (permalink / raw)
To: emacs-devel
Due to a recent change to Info, I see the following bug:
emacs -Q
M-x info RET -> Point is on the last info link, instead of point-min.
Could anyone who changed Info in the last few days please double-check
your work and see if you introduced this bug?
^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: Info bug
2008-04-21 20:01 Info bug Chong Yidong
@ 2008-04-21 23:16 ` Juri Linkov
2008-04-21 23:31 ` Nick Roberts
` (3 more replies)
0 siblings, 4 replies; 10+ messages in thread
From: Juri Linkov @ 2008-04-21 23:16 UTC (permalink / raw)
To: Chong Yidong; +Cc: emacs-devel
> Due to a recent change to Info, I see the following bug:
>
> emacs -Q
> M-x info RET -> Point is on the last info link, instead of point-min.
>
> Could anyone who changed Info in the last few days please double-check
> your work and see if you introduced this bug?
This is caused by the following change in `Info-complete-menu-item':
@@ -2271,8 +2262,7 @@
;; Note that `Info-complete-menu-buffer' could be current already,
;; so we want to save point.
- (save-excursion
- (set-buffer Info-complete-menu-buffer)
+ (with-current-buffer Info-complete-menu-buffer
(let ((completion-ignore-case t)
(case-fold-search t)
(orignode Info-current-node)
In theory, these constructs should be equivalent, but they are not.
--
Juri Linkov
http://www.jurta.org/emacs/
^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: Info bug
2008-04-21 23:16 ` Juri Linkov
@ 2008-04-21 23:31 ` Nick Roberts
2008-04-22 20:57 ` Compilation auto-jump bug (was: Info bug) Juri Linkov
2008-04-22 3:02 ` Info bug Chong Yidong
` (2 subsequent siblings)
3 siblings, 1 reply; 10+ messages in thread
From: Nick Roberts @ 2008-04-21 23:31 UTC (permalink / raw)
To: Juri Linkov; +Cc: Chong Yidong, emacs-devel
> This is caused by the following change in `Info-complete-menu-item':
>
> @@ -2271,8 +2262,7 @@
> ;; Note that `Info-complete-menu-buffer' could be current already,
> ;; so we want to save point.
> - (save-excursion
> - (set-buffer Info-complete-menu-buffer)
> + (with-current-buffer Info-complete-menu-buffer
> (let ((completion-ignore-case t)
> (case-fold-search t)
> (orignode Info-current-node)
>
> In theory, these constructs should be equivalent, but they are not.
with-current-buffer is equivalent to
(save-current-buffer
(set-buffer...
but I can't see any mention of Info-complete-menu-item in the ChangeLog.
--
Nick http://www.inet.net.nz/~nickrob
^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: Info bug
2008-04-21 23:16 ` Juri Linkov
2008-04-21 23:31 ` Nick Roberts
@ 2008-04-22 3:02 ` Chong Yidong
2008-04-22 3:08 ` Stefan Monnier
2008-04-22 5:59 ` David Kastrup
3 siblings, 0 replies; 10+ messages in thread
From: Chong Yidong @ 2008-04-22 3:02 UTC (permalink / raw)
To: Juri Linkov; +Cc: emacs-devel
Juri Linkov <juri@jurta.org> writes:
>> Due to a recent change to Info, I see the following bug:
>>
>> emacs -Q
>> M-x info RET -> Point is on the last info link, instead of point-min.
>
> This is caused by the following change in `Info-complete-menu-item':
>
> @@ -2271,8 +2262,7 @@
> ;; Note that `Info-complete-menu-buffer' could be current already,
> ;; so we want to save point.
> - (save-excursion
> - (set-buffer Info-complete-menu-buffer)
> + (with-current-buffer Info-complete-menu-buffer
> (let ((completion-ignore-case t)
> (case-fold-search t)
> (orignode Info-current-node)
Could you revert it? Thanks.
^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: Info bug
2008-04-21 23:16 ` Juri Linkov
2008-04-21 23:31 ` Nick Roberts
2008-04-22 3:02 ` Info bug Chong Yidong
@ 2008-04-22 3:08 ` Stefan Monnier
2008-04-22 5:59 ` David Kastrup
3 siblings, 0 replies; 10+ messages in thread
From: Stefan Monnier @ 2008-04-22 3:08 UTC (permalink / raw)
To: Juri Linkov; +Cc: Chong Yidong, emacs-devel
>> Due to a recent change to Info, I see the following bug:
>>
>> emacs -Q
>> M-x info RET -> Point is on the last info link, instead of point-min.
>>
>> Could anyone who changed Info in the last few days please double-check
>> your work and see if you introduced this bug?
> This is caused by the following change in `Info-complete-menu-item':
> @@ -2271,8 +2262,7 @@
> ;; Note that `Info-complete-menu-buffer' could be current already,
> ;; so we want to save point.
> - (save-excursion
> - (set-buffer Info-complete-menu-buffer)
> + (with-current-buffer Info-complete-menu-buffer
> (let ((completion-ignore-case t)
> (case-fold-search t)
> (orignode Info-current-node)
> In theory, these constructs should be equivalent, but they are not.
I'll take care of it,
Stefan
^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: Info bug
2008-04-21 23:16 ` Juri Linkov
` (2 preceding siblings ...)
2008-04-22 3:08 ` Stefan Monnier
@ 2008-04-22 5:59 ` David Kastrup
3 siblings, 0 replies; 10+ messages in thread
From: David Kastrup @ 2008-04-22 5:59 UTC (permalink / raw)
To: Juri Linkov; +Cc: Chong Yidong, emacs-devel
Juri Linkov <juri@jurta.org> writes:
>> Due to a recent change to Info, I see the following bug:
>>
>> emacs -Q
>> M-x info RET -> Point is on the last info link, instead of point-min.
>>
>> Could anyone who changed Info in the last few days please double-check
>> your work and see if you introduced this bug?
>
> This is caused by the following change in `Info-complete-menu-item':
>
> @@ -2271,8 +2262,7 @@
> ;; Note that `Info-complete-menu-buffer' could be current already,
> ;; so we want to save point.
> - (save-excursion
> - (set-buffer Info-complete-menu-buffer)
> + (with-current-buffer Info-complete-menu-buffer
> (let ((completion-ignore-case t)
> (case-fold-search t)
> (orignode Info-current-node)
>
> In theory, these constructs should be equivalent, but they are not.
Read the comment above the change. It describes the rationale for the
original code and does not jibe with the new code.
You are probably thinking of save-current-buffer rather than
save-excursion.
--
David Kastrup, Kriemhildstr. 15, 44793 Bochum
^ permalink raw reply [flat|nested] 10+ messages in thread
* Compilation auto-jump bug (was: Info bug)
2008-04-21 23:31 ` Nick Roberts
@ 2008-04-22 20:57 ` Juri Linkov
2008-04-23 1:51 ` Compilation auto-jump bug Stefan Monnier
0 siblings, 1 reply; 10+ messages in thread
From: Juri Linkov @ 2008-04-22 20:57 UTC (permalink / raw)
To: Nick Roberts; +Cc: emacs-devel
> > @@ -2271,8 +2262,7 @@
> > ;; Note that `Info-complete-menu-buffer' could be current already,
> > ;; so we want to save point.
> > - (save-excursion
> > - (set-buffer Info-complete-menu-buffer)
> > + (with-current-buffer Info-complete-menu-buffer
> > (let ((completion-ignore-case t)
> > (case-fold-search t)
> > (orignode Info-current-node)
> >
> > In theory, these constructs should be equivalent, but they are not.
>
> with-current-buffer is equivalent to
>
> (save-current-buffer
> (set-buffer...
BTW, there is also the opposite bug: when `compilation-scroll-output' is
`first-error', but `compilation-auto-jump-to-first-error' is nil, when
the current buffer is not the *compilation* buffer, then it doesn't keep
point on the first error. This means when I switch to the *compilation*
buffer, point is at the beginning of the *compilation* buffer instead of
the position of the first error. But when the current buffer is the
*compilation* buffer at the time when compilation moves point, then it
keeps the correct position of the first error. This is due to the code:
(defun compilation-auto-jump (buffer pos)
(with-current-buffer buffer
(goto-char pos)
(if compilation-auto-jump-to-first-error
(compile-goto-error))))
It doesn't use `save-excursion', so it is strange that it doesn't keep
point on the new position after `goto-char'.
But when `compilation-auto-jump-to-first-error' is t, then
after calling `compile-goto-error' and switching to the source buffer,
point keeps its new position on the first error in the *compilation* buffer.
--
Juri Linkov
http://www.jurta.org/emacs/
^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: Compilation auto-jump bug
2008-04-22 20:57 ` Compilation auto-jump bug (was: Info bug) Juri Linkov
@ 2008-04-23 1:51 ` Stefan Monnier
2008-04-23 8:54 ` Juri Linkov
0 siblings, 1 reply; 10+ messages in thread
From: Stefan Monnier @ 2008-04-23 1:51 UTC (permalink / raw)
To: Juri Linkov; +Cc: Nick Roberts, emacs-devel
> BTW, there is also the opposite bug: when `compilation-scroll-output' is
> `first-error', but `compilation-auto-jump-to-first-error' is nil, when
> the current buffer is not the *compilation* buffer, then it doesn't keep
> point on the first error. This means when I switch to the *compilation*
> buffer, point is at the beginning of the *compilation* buffer instead of
> the position of the first error. But when the current buffer is the
> *compilation* buffer at the time when compilation moves point, then it
> keeps the correct position of the first error. This is due to the code:
> (defun compilation-auto-jump (buffer pos)
> (with-current-buffer buffer
> (goto-char pos)
> (if compilation-auto-jump-to-first-error
> (compile-goto-error))))
> It doesn't use `save-excursion', so it is strange that it doesn't keep
> point on the new position after `goto-char'.
I guess the problem is that we need to affect the window-point of the
window that's showing the compilation buffer and this only happens when
we do `goto-char' if that window is the selected one.
So maybe something like:
(defun compilation-auto-jump (buffer pos)
(with-current-buffer buffer
(goto-char pos)
(let ((win (get-buffer-window buffer 0)))
(if win (set-window-point win pos)))
(if compilation-auto-jump-to-first-error
(compile-goto-error))))
-- Stefan
^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: Compilation auto-jump bug
2008-04-23 1:51 ` Compilation auto-jump bug Stefan Monnier
@ 2008-04-23 8:54 ` Juri Linkov
2008-04-23 15:40 ` Stefan Monnier
0 siblings, 1 reply; 10+ messages in thread
From: Juri Linkov @ 2008-04-23 8:54 UTC (permalink / raw)
To: Stefan Monnier; +Cc: Nick Roberts, emacs-devel
>> BTW, there is also the opposite bug: when `compilation-scroll-output' is
>> `first-error', but `compilation-auto-jump-to-first-error' is nil, when
>> the current buffer is not the *compilation* buffer, then it doesn't keep
>> point on the first error. This means when I switch to the *compilation*
>> buffer, point is at the beginning of the *compilation* buffer instead of
>> the position of the first error. But when the current buffer is the
>> *compilation* buffer at the time when compilation moves point, then it
>> keeps the correct position of the first error. This is due to the code:
>
>> (defun compilation-auto-jump (buffer pos)
>> (with-current-buffer buffer
>> (goto-char pos)
>> (if compilation-auto-jump-to-first-error
>> (compile-goto-error))))
>
>> It doesn't use `save-excursion', so it is strange that it doesn't keep
>> point on the new position after `goto-char'.
>
> I guess the problem is that we need to affect the window-point of the
> window that's showing the compilation buffer and this only happens when
> we do `goto-char' if that window is the selected one.
> So maybe something like:
>
> (defun compilation-auto-jump (buffer pos)
> (with-current-buffer buffer
> (goto-char pos)
> (let ((win (get-buffer-window buffer 0)))
> (if win (set-window-point win pos)))
> (if compilation-auto-jump-to-first-error
> (compile-goto-error))))
Yes, it works. Maybe we should add a primitive for this additional code
with a name like `save-window-point'? If this name can be confused with
a function that keeps the old window point before entering its body, then
maybe some other name would be more clear.
--
Juri Linkov
http://www.jurta.org/emacs/
^ permalink raw reply [flat|nested] 10+ messages in thread
* Re: Compilation auto-jump bug
2008-04-23 8:54 ` Juri Linkov
@ 2008-04-23 15:40 ` Stefan Monnier
0 siblings, 0 replies; 10+ messages in thread
From: Stefan Monnier @ 2008-04-23 15:40 UTC (permalink / raw)
To: Juri Linkov; +Cc: Nick Roberts, emacs-devel
>> (defun compilation-auto-jump (buffer pos)
>> (with-current-buffer buffer
>> (goto-char pos)
>> (let ((win (get-buffer-window buffer 0)))
>> (if win (set-window-point win pos)))
>> (if compilation-auto-jump-to-first-error
>> (compile-goto-error))))
> Yes, it works. Maybe we should add a primitive for this additional code
> with a name like `save-window-point'? If this name can be confused with
> a function that keeps the old window point before entering its body, then
> maybe some other name would be more clear.
We could provide
(defun goto-char-window (pos)
"Like `goto-char' but also moves `window-point'."
(goto-char pos)
(let ((win (get-buffer-window (current-buffer) 0)))
(if win (set-window-point win pos))))
This kind of thing is needed at various places, so it might be
a good idea. If someone could grep through the Elisp code to try and
find the various places where we do something similar and try to see if
the above function is a good fit, that would be helpful,
Stefan
^ permalink raw reply [flat|nested] 10+ messages in thread
end of thread, other threads:[~2008-04-23 15:40 UTC | newest]
Thread overview: 10+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2008-04-21 20:01 Info bug Chong Yidong
2008-04-21 23:16 ` Juri Linkov
2008-04-21 23:31 ` Nick Roberts
2008-04-22 20:57 ` Compilation auto-jump bug (was: Info bug) Juri Linkov
2008-04-23 1:51 ` Compilation auto-jump bug Stefan Monnier
2008-04-23 8:54 ` Juri Linkov
2008-04-23 15:40 ` Stefan Monnier
2008-04-22 3:02 ` Info bug Chong Yidong
2008-04-22 3:08 ` Stefan Monnier
2008-04-22 5:59 ` David Kastrup
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.