* bug#70594: 30.0.50; Error when tabbing with only one active widget
@ 2024-04-26 12:43 Stephen Berman via Bug reports for GNU Emacs, the Swiss army knife of text editors
2024-04-26 15:02 ` Eli Zaretskii
0 siblings, 1 reply; 7+ messages in thread
From: Stephen Berman via Bug reports for GNU Emacs, the Swiss army knife of text editors @ 2024-04-26 12:43 UTC (permalink / raw)
To: 70594
[-- Attachment #1: Type: text/plain, Size: 2185 bytes --]
Commit 91333dacfa1, which adds the feature of optionally skipping over
inactive widgets when tabbing (bug#70413), fails to handle buffers that
contain only one active widget; in that case, pressing TAB or S-TAB
raises the error "No buttons or fields found". To reproduce:
0. emacs -Q
1. Load the attached file widget-test.el and then type `M-x
my-widget-test'.
2. In the buffer "*My Widget Test*" repeatedly press TAB and S-TAB and
observe that point moves successively between the active radio
buttons labelled "One" and "Two" and the active push button "Submit",
but skips the inactive push button "Reset", since the user option
widget-skip-inactive is enabled.
3. Now press (via RET or mouse-click) the "Submit" button, which makes
the radio buttons and the "Submit" button inactive and the "Reset"
button active.
4. Pressing TAB once moves point to the "Reset" button, then pressing
TAB again moves point to BOB and raises the error "No buttons or
fields found". Likewise, pressing S-TAB once moves point to "Reset",
then pressing S-TAB again moves to EOB and raises the same error.
The attached patched fixes this bug. In addition, when only one widget
is active and point is on it, since pressing TAB or S-TAB does not move
point, the informational message "Only one tabable widget" is displayed.
The original code in widget-move contained separate loops to handle
forward and backward movement and this involved some code duplication.
The changes to this code to fix the bug would have required further
duplication, so I took the opportunity to parameterize the
directionality, allowing handling both directions in a single loop.
This shortens the code and IMO makes the similarities and differences in
the handling easier to see.
Configured using:
'configure 'CFLAGS=-Og -g3' PKG_CONFIG_PATH=/opt/qt5/lib/pkgconfig'
Configured features:
ACL CAIRO DBUS FREETYPE GIF GLIB GMP GNUTLS GPM GSETTINGS HARFBUZZ JPEG
LCMS2 LIBSYSTEMD LIBXML2 MODULES NATIVE_COMP NOTIFY INOTIFY PDUMPER PNG
RSVG SECCOMP SOUND SQLITE3 THREADS TIFF TOOLKIT_SCROLL_BARS TREE_SITTER
WEBP X11 XDBE XIM XINPUT2 XPM GTK3 ZLIB
[-- Attachment #2: widget-test.el --]
[-- Type: application/emacs-lisp, Size: 1044 bytes --]
[-- Warning: decoded text below may be mangled, UTF-8 assumed --]
[-- Attachment #3: widget-move patch --]
[-- Type: text/x-patch, Size: 2675 bytes --]
diff --git a/lisp/wid-edit.el b/lisp/wid-edit.el
index dc481d4d0a5..407309c3429 100644
--- a/lisp/wid-edit.el
+++ b/lisp/wid-edit.el
@@ -1263,42 +1263,40 @@ widget-move
ARG may be negative to move backward.
When the second optional argument is non-nil,
nothing is shown in the echo area."
- (let ((wrapped 0)
- (number arg)
- (old (widget-tabable-at)))
- ;; Forward.
- (while (> arg 0)
- (cond ((eobp)
- (goto-char (point-min))
- (setq wrapped (1+ wrapped)))
- (widget-use-overlay-change
- (goto-char (next-overlay-change (point))))
- (t
- (forward-char 1)))
- (and (= wrapped 2)
- (eq arg number)
- (error "No buttons or fields found"))
- (let ((new (widget-tabable-at)))
- (when new
- (unless (eq new old)
- (setq arg (1- arg))
- (setq old new)))))
- ;; Backward.
- (while (< arg 0)
- (cond ((bobp)
- (goto-char (point-max))
- (setq wrapped (1+ wrapped)))
- (widget-use-overlay-change
- (goto-char (previous-overlay-change (point))))
- (t
- (backward-char 1)))
- (and (= wrapped 2)
- (eq arg number)
- (error "No buttons or fields found"))
- (let ((new (widget-tabable-at)))
- (when new
- (unless (eq new old)
- (setq arg (1+ arg))))))
+ (let* ((wrapped 0)
+ (number arg)
+ (fwd (> arg 0)) ; widget-forward is caller.
+ (bwd (< arg 0)) ; widget-backward is caller.
+ (old (widget-tabable-at))
+ (tabable (if old 1 0))
+ pos)
+ (catch 'one
+ (while (> (abs arg) 0)
+ (cond ((or (and fwd (eobp)) (and bwd (bobp)))
+ (goto-char (cond (fwd (point-min))
+ (bwd (point-max))))
+ (setq wrapped (1+ wrapped)))
+ (widget-use-overlay-change
+ (goto-char (cond (fwd (next-overlay-change (point)))
+ (bwd (previous-overlay-change (point))))))
+ (t
+ (cond (fwd (forward-char 1))
+ (bwd (backward-char 1)))))
+ (and (= wrapped 2)
+ (eq arg number)
+ (if (= tabable 1)
+ (progn
+ (goto-char pos)
+ (throw 'one (message "Only one tabable widget")))
+ (error "No buttons or fields found")))
+ (let ((new (widget-tabable-at)))
+ (when new
+ (if (eq new old)
+ (setq pos (point))
+ (cl-incf tabable)
+ (setq arg (cond (fwd (1- arg))
+ (bwd (1+ arg))))
+ (setq old new))))))
(let ((new (widget-tabable-at)))
(while (and (eq (widget-tabable-at) new) (not (bobp)))
(backward-char)))
^ permalink raw reply related [flat|nested] 7+ messages in thread
* bug#70594: 30.0.50; Error when tabbing with only one active widget
2024-04-26 12:43 bug#70594: 30.0.50; Error when tabbing with only one active widget Stephen Berman via Bug reports for GNU Emacs, the Swiss army knife of text editors
@ 2024-04-26 15:02 ` Eli Zaretskii
2024-05-09 7:23 ` Eli Zaretskii
0 siblings, 1 reply; 7+ messages in thread
From: Eli Zaretskii @ 2024-04-26 15:02 UTC (permalink / raw)
To: Stephen Berman, Mauro Aranda; +Cc: 70594
> Date: Fri, 26 Apr 2024 14:43:42 +0200
> From: Stephen Berman via "Bug reports for GNU Emacs,
> the Swiss army knife of text editors" <bug-gnu-emacs@gnu.org>
>
> Commit 91333dacfa1, which adds the feature of optionally skipping over
> inactive widgets when tabbing (bug#70413), fails to handle buffers that
> contain only one active widget; in that case, pressing TAB or S-TAB
> raises the error "No buttons or fields found". To reproduce:
>
> 0. emacs -Q
> 1. Load the attached file widget-test.el and then type `M-x
> my-widget-test'.
> 2. In the buffer "*My Widget Test*" repeatedly press TAB and S-TAB and
> observe that point moves successively between the active radio
> buttons labelled "One" and "Two" and the active push button "Submit",
> but skips the inactive push button "Reset", since the user option
> widget-skip-inactive is enabled.
> 3. Now press (via RET or mouse-click) the "Submit" button, which makes
> the radio buttons and the "Submit" button inactive and the "Reset"
> button active.
> 4. Pressing TAB once moves point to the "Reset" button, then pressing
> TAB again moves point to BOB and raises the error "No buttons or
> fields found". Likewise, pressing S-TAB once moves point to "Reset",
> then pressing S-TAB again moves to EOB and raises the same error.
>
> The attached patched fixes this bug. In addition, when only one widget
> is active and point is on it, since pressing TAB or S-TAB does not move
> point, the informational message "Only one tabable widget" is displayed.
>
> The original code in widget-move contained separate loops to handle
> forward and backward movement and this involved some code duplication.
> The changes to this code to fix the bug would have required further
> duplication, so I took the opportunity to parameterize the
> directionality, allowing handling both directions in a single loop.
> This shortens the code and IMO makes the similarities and differences in
> the handling easier to see.
Adding Mauro to the discussion.
^ permalink raw reply [flat|nested] 7+ messages in thread
* bug#70594: 30.0.50; Error when tabbing with only one active widget
2024-04-26 15:02 ` Eli Zaretskii
@ 2024-05-09 7:23 ` Eli Zaretskii
2024-05-25 7:42 ` Eli Zaretskii
0 siblings, 1 reply; 7+ messages in thread
From: Eli Zaretskii @ 2024-05-09 7:23 UTC (permalink / raw)
To: stephen.berman, maurooaranda; +Cc: 70594
Ping!
> Cc: 70594@debbugs.gnu.org
> Date: Fri, 26 Apr 2024 18:02:13 +0300
> From: Eli Zaretskii <eliz@gnu.org>
>
> > Date: Fri, 26 Apr 2024 14:43:42 +0200
> > From: Stephen Berman via "Bug reports for GNU Emacs,
> > the Swiss army knife of text editors" <bug-gnu-emacs@gnu.org>
> >
> > Commit 91333dacfa1, which adds the feature of optionally skipping over
> > inactive widgets when tabbing (bug#70413), fails to handle buffers that
> > contain only one active widget; in that case, pressing TAB or S-TAB
> > raises the error "No buttons or fields found". To reproduce:
> >
> > 0. emacs -Q
> > 1. Load the attached file widget-test.el and then type `M-x
> > my-widget-test'.
> > 2. In the buffer "*My Widget Test*" repeatedly press TAB and S-TAB and
> > observe that point moves successively between the active radio
> > buttons labelled "One" and "Two" and the active push button "Submit",
> > but skips the inactive push button "Reset", since the user option
> > widget-skip-inactive is enabled.
> > 3. Now press (via RET or mouse-click) the "Submit" button, which makes
> > the radio buttons and the "Submit" button inactive and the "Reset"
> > button active.
> > 4. Pressing TAB once moves point to the "Reset" button, then pressing
> > TAB again moves point to BOB and raises the error "No buttons or
> > fields found". Likewise, pressing S-TAB once moves point to "Reset",
> > then pressing S-TAB again moves to EOB and raises the same error.
> >
> > The attached patched fixes this bug. In addition, when only one widget
> > is active and point is on it, since pressing TAB or S-TAB does not move
> > point, the informational message "Only one tabable widget" is displayed.
> >
> > The original code in widget-move contained separate loops to handle
> > forward and backward movement and this involved some code duplication.
> > The changes to this code to fix the bug would have required further
> > duplication, so I took the opportunity to parameterize the
> > directionality, allowing handling both directions in a single loop.
> > This shortens the code and IMO makes the similarities and differences in
> > the handling easier to see.
>
> Adding Mauro to the discussion.
>
>
>
>
^ permalink raw reply [flat|nested] 7+ messages in thread
* bug#70594: 30.0.50; Error when tabbing with only one active widget
2024-05-09 7:23 ` Eli Zaretskii
@ 2024-05-25 7:42 ` Eli Zaretskii
2024-05-25 9:30 ` Stephen Berman via Bug reports for GNU Emacs, the Swiss army knife of text editors
0 siblings, 1 reply; 7+ messages in thread
From: Eli Zaretskii @ 2024-05-25 7:42 UTC (permalink / raw)
To: stephen.berman, maurooaranda; +Cc: 70594
Ping! Ping! Can we please make some progress here?
> Cc: 70594@debbugs.gnu.org
> Date: Thu, 09 May 2024 10:23:13 +0300
> From: Eli Zaretskii <eliz@gnu.org>
>
> Ping!
>
> > Cc: 70594@debbugs.gnu.org
> > Date: Fri, 26 Apr 2024 18:02:13 +0300
> > From: Eli Zaretskii <eliz@gnu.org>
> >
> > > Date: Fri, 26 Apr 2024 14:43:42 +0200
> > > From: Stephen Berman via "Bug reports for GNU Emacs,
> > > the Swiss army knife of text editors" <bug-gnu-emacs@gnu.org>
> > >
> > > Commit 91333dacfa1, which adds the feature of optionally skipping over
> > > inactive widgets when tabbing (bug#70413), fails to handle buffers that
> > > contain only one active widget; in that case, pressing TAB or S-TAB
> > > raises the error "No buttons or fields found". To reproduce:
> > >
> > > 0. emacs -Q
> > > 1. Load the attached file widget-test.el and then type `M-x
> > > my-widget-test'.
> > > 2. In the buffer "*My Widget Test*" repeatedly press TAB and S-TAB and
> > > observe that point moves successively between the active radio
> > > buttons labelled "One" and "Two" and the active push button "Submit",
> > > but skips the inactive push button "Reset", since the user option
> > > widget-skip-inactive is enabled.
> > > 3. Now press (via RET or mouse-click) the "Submit" button, which makes
> > > the radio buttons and the "Submit" button inactive and the "Reset"
> > > button active.
> > > 4. Pressing TAB once moves point to the "Reset" button, then pressing
> > > TAB again moves point to BOB and raises the error "No buttons or
> > > fields found". Likewise, pressing S-TAB once moves point to "Reset",
> > > then pressing S-TAB again moves to EOB and raises the same error.
> > >
> > > The attached patched fixes this bug. In addition, when only one widget
> > > is active and point is on it, since pressing TAB or S-TAB does not move
> > > point, the informational message "Only one tabable widget" is displayed.
> > >
> > > The original code in widget-move contained separate loops to handle
> > > forward and backward movement and this involved some code duplication.
> > > The changes to this code to fix the bug would have required further
> > > duplication, so I took the opportunity to parameterize the
> > > directionality, allowing handling both directions in a single loop.
> > > This shortens the code and IMO makes the similarities and differences in
> > > the handling easier to see.
> >
> > Adding Mauro to the discussion.
> >
> >
> >
> >
>
>
>
>
^ permalink raw reply [flat|nested] 7+ messages in thread
* bug#70594: 30.0.50; Error when tabbing with only one active widget
2024-05-25 7:42 ` Eli Zaretskii
@ 2024-05-25 9:30 ` Stephen Berman via Bug reports for GNU Emacs, the Swiss army knife of text editors
2024-06-08 11:49 ` Eli Zaretskii
0 siblings, 1 reply; 7+ messages in thread
From: Stephen Berman via Bug reports for GNU Emacs, the Swiss army knife of text editors @ 2024-05-25 9:30 UTC (permalink / raw)
To: Eli Zaretskii; +Cc: maurooaranda, 70594
On Sat, 25 May 2024 10:42:33 +0300 Eli Zaretskii <eliz@gnu.org> wrote:
> Ping! Ping! Can we please make some progress here?
Since the patch fixes (according to me testing) a clear bug, either the
patch should be installed (or a better one, if someone comes up with
one) or commit 91333dacfa1, which introduced the bug, should be
reverted; my preference is to install the patch.
Steve Berman
>> Cc: 70594@debbugs.gnu.org
>> Date: Thu, 09 May 2024 10:23:13 +0300
>> From: Eli Zaretskii <eliz@gnu.org>
>>
>> Ping!
>>
>> > Cc: 70594@debbugs.gnu.org
>> > Date: Fri, 26 Apr 2024 18:02:13 +0300
>> > From: Eli Zaretskii <eliz@gnu.org>
>> >
>> > > Date: Fri, 26 Apr 2024 14:43:42 +0200
>> > > From: Stephen Berman via "Bug reports for GNU Emacs,
>> > > the Swiss army knife of text editors" <bug-gnu-emacs@gnu.org>
>> > >
>> > > Commit 91333dacfa1, which adds the feature of optionally skipping over
>> > > inactive widgets when tabbing (bug#70413), fails to handle buffers that
>> > > contain only one active widget; in that case, pressing TAB or S-TAB
>> > > raises the error "No buttons or fields found". To reproduce:
>> > >
>> > > 0. emacs -Q
>> > > 1. Load the attached file widget-test.el and then type `M-x
>> > > my-widget-test'.
>> > > 2. In the buffer "*My Widget Test*" repeatedly press TAB and S-TAB and
>> > > observe that point moves successively between the active radio
>> > > buttons labelled "One" and "Two" and the active push button "Submit",
>> > > but skips the inactive push button "Reset", since the user option
>> > > widget-skip-inactive is enabled.
>> > > 3. Now press (via RET or mouse-click) the "Submit" button, which makes
>> > > the radio buttons and the "Submit" button inactive and the "Reset"
>> > > button active.
>> > > 4. Pressing TAB once moves point to the "Reset" button, then pressing
>> > > TAB again moves point to BOB and raises the error "No buttons or
>> > > fields found". Likewise, pressing S-TAB once moves point to "Reset",
>> > > then pressing S-TAB again moves to EOB and raises the same error.
>> > >
>> > > The attached patched fixes this bug. In addition, when only one widget
>> > > is active and point is on it, since pressing TAB or S-TAB does not move
>> > > point, the informational message "Only one tabable widget" is displayed.
>> > >
>> > > The original code in widget-move contained separate loops to handle
>> > > forward and backward movement and this involved some code duplication.
>> > > The changes to this code to fix the bug would have required further
>> > > duplication, so I took the opportunity to parameterize the
>> > > directionality, allowing handling both directions in a single loop.
>> > > This shortens the code and IMO makes the similarities and differences in
>> > > the handling easier to see.
>> >
>> > Adding Mauro to the discussion.
>> >
>> >
>> >
>> >
>>
>>
>>
>>
^ permalink raw reply [flat|nested] 7+ messages in thread
* bug#70594: 30.0.50; Error when tabbing with only one active widget
2024-05-25 9:30 ` Stephen Berman via Bug reports for GNU Emacs, the Swiss army knife of text editors
@ 2024-06-08 11:49 ` Eli Zaretskii
2024-06-25 10:43 ` Stephen Berman via Bug reports for GNU Emacs, the Swiss army knife of text editors
0 siblings, 1 reply; 7+ messages in thread
From: Eli Zaretskii @ 2024-06-08 11:49 UTC (permalink / raw)
To: maurooaranda, Stephen Berman; +Cc: 70594
> From: Stephen Berman <stephen.berman@gmx.net>
> Cc: maurooaranda@gmail.com, 70594@debbugs.gnu.org
> Date: Sat, 25 May 2024 11:30:01 +0200
>
> On Sat, 25 May 2024 10:42:33 +0300 Eli Zaretskii <eliz@gnu.org> wrote:
>
> > Ping! Ping! Can we please make some progress here?
>
> Since the patch fixes (according to me testing) a clear bug, either the
> patch should be installed (or a better one, if someone comes up with
> one) or commit 91333dacfa1, which introduced the bug, should be
> reverted; my preference is to install the patch.
Mauro, what do you prefer?
> >> Cc: 70594@debbugs.gnu.org
> >> Date: Thu, 09 May 2024 10:23:13 +0300
> >> From: Eli Zaretskii <eliz@gnu.org>
> >>
> >> Ping!
> >>
> >> > Cc: 70594@debbugs.gnu.org
> >> > Date: Fri, 26 Apr 2024 18:02:13 +0300
> >> > From: Eli Zaretskii <eliz@gnu.org>
> >> >
> >> > > Date: Fri, 26 Apr 2024 14:43:42 +0200
> >> > > From: Stephen Berman via "Bug reports for GNU Emacs,
> >> > > the Swiss army knife of text editors" <bug-gnu-emacs@gnu.org>
> >> > >
> >> > > Commit 91333dacfa1, which adds the feature of optionally skipping over
> >> > > inactive widgets when tabbing (bug#70413), fails to handle buffers that
> >> > > contain only one active widget; in that case, pressing TAB or S-TAB
> >> > > raises the error "No buttons or fields found". To reproduce:
> >> > >
> >> > > 0. emacs -Q
> >> > > 1. Load the attached file widget-test.el and then type `M-x
> >> > > my-widget-test'.
> >> > > 2. In the buffer "*My Widget Test*" repeatedly press TAB and S-TAB and
> >> > > observe that point moves successively between the active radio
> >> > > buttons labelled "One" and "Two" and the active push button "Submit",
> >> > > but skips the inactive push button "Reset", since the user option
> >> > > widget-skip-inactive is enabled.
> >> > > 3. Now press (via RET or mouse-click) the "Submit" button, which makes
> >> > > the radio buttons and the "Submit" button inactive and the "Reset"
> >> > > button active.
> >> > > 4. Pressing TAB once moves point to the "Reset" button, then pressing
> >> > > TAB again moves point to BOB and raises the error "No buttons or
> >> > > fields found". Likewise, pressing S-TAB once moves point to "Reset",
> >> > > then pressing S-TAB again moves to EOB and raises the same error.
> >> > >
> >> > > The attached patched fixes this bug. In addition, when only one widget
> >> > > is active and point is on it, since pressing TAB or S-TAB does not move
> >> > > point, the informational message "Only one tabable widget" is displayed.
> >> > >
> >> > > The original code in widget-move contained separate loops to handle
> >> > > forward and backward movement and this involved some code duplication.
> >> > > The changes to this code to fix the bug would have required further
> >> > > duplication, so I took the opportunity to parameterize the
> >> > > directionality, allowing handling both directions in a single loop.
> >> > > This shortens the code and IMO makes the similarities and differences in
> >> > > the handling easier to see.
> >> >
> >> > Adding Mauro to the discussion.
> >> >
> >> >
> >> >
> >> >
> >>
> >>
> >>
> >>
>
^ permalink raw reply [flat|nested] 7+ messages in thread
* bug#70594: 30.0.50; Error when tabbing with only one active widget
2024-06-08 11:49 ` Eli Zaretskii
@ 2024-06-25 10:43 ` Stephen Berman via Bug reports for GNU Emacs, the Swiss army knife of text editors
0 siblings, 0 replies; 7+ messages in thread
From: Stephen Berman via Bug reports for GNU Emacs, the Swiss army knife of text editors @ 2024-06-25 10:43 UTC (permalink / raw)
To: Eli Zaretskii; +Cc: maurooaranda, 70594-done
Fixed in commit 2f18929319a to emacs-30 and closing.
Steve Berman
On Sat, 08 Jun 2024 14:49:20 +0300 Eli Zaretskii <eliz@gnu.org> wrote:
>> From: Stephen Berman <stephen.berman@gmx.net>
>> Cc: maurooaranda@gmail.com, 70594@debbugs.gnu.org
>> Date: Sat, 25 May 2024 11:30:01 +0200
>>
>> On Sat, 25 May 2024 10:42:33 +0300 Eli Zaretskii <eliz@gnu.org> wrote:
>>
>> > Ping! Ping! Can we please make some progress here?
>>
>> Since the patch fixes (according to me testing) a clear bug, either the
>> patch should be installed (or a better one, if someone comes up with
>> one) or commit 91333dacfa1, which introduced the bug, should be
>> reverted; my preference is to install the patch.
>
> Mauro, what do you prefer?
>
>> >> Cc: 70594@debbugs.gnu.org
>> >> Date: Thu, 09 May 2024 10:23:13 +0300
>> >> From: Eli Zaretskii <eliz@gnu.org>
>> >>
>> >> Ping!
>> >>
>> >> > Cc: 70594@debbugs.gnu.org
>> >> > Date: Fri, 26 Apr 2024 18:02:13 +0300
>> >> > From: Eli Zaretskii <eliz@gnu.org>
>> >> >
>> >> > > Date: Fri, 26 Apr 2024 14:43:42 +0200
>> >> > > From: Stephen Berman via "Bug reports for GNU Emacs,
>> >> > > the Swiss army knife of text editors" <bug-gnu-emacs@gnu.org>
>> >> > >
>> >> > > Commit 91333dacfa1, which adds the feature of optionally skipping over
>> >> > > inactive widgets when tabbing (bug#70413), fails to handle buffers that
>> >> > > contain only one active widget; in that case, pressing TAB or S-TAB
>> >> > > raises the error "No buttons or fields found". To reproduce:
>> >> > >
>> >> > > 0. emacs -Q
>> >> > > 1. Load the attached file widget-test.el and then type `M-x
>> >> > > my-widget-test'.
>> >> > > 2. In the buffer "*My Widget Test*" repeatedly press TAB and S-TAB and
>> >> > > observe that point moves successively between the active radio
>> >> > > buttons labelled "One" and "Two" and the active push button "Submit",
>> >> > > but skips the inactive push button "Reset", since the user option
>> >> > > widget-skip-inactive is enabled.
>> >> > > 3. Now press (via RET or mouse-click) the "Submit" button, which makes
>> >> > > the radio buttons and the "Submit" button inactive and the "Reset"
>> >> > > button active.
>> >> > > 4. Pressing TAB once moves point to the "Reset" button, then pressing
>> >> > > TAB again moves point to BOB and raises the error "No buttons or
>> >> > > fields found". Likewise, pressing S-TAB once moves point to "Reset",
>> >> > > then pressing S-TAB again moves to EOB and raises the same error.
>> >> > >
>> >> > > The attached patched fixes this bug. In addition, when only one widget
>> >> > > is active and point is on it, since pressing TAB or S-TAB does not move
>> >> > > point, the informational message "Only one tabable widget" is displayed.
>> >> > >
>> >> > > The original code in widget-move contained separate loops to handle
>> >> > > forward and backward movement and this involved some code duplication.
>> >> > > The changes to this code to fix the bug would have required further
>> >> > > duplication, so I took the opportunity to parameterize the
>> >> > > directionality, allowing handling both directions in a single loop.
>> >> > > This shortens the code and IMO makes the similarities and differences in
>> >> > > the handling easier to see.
>> >> >
>> >> > Adding Mauro to the discussion.
>> >> >
>> >> >
>> >> >
>> >> >
>> >>
>> >>
>> >>
>> >>
>>
^ permalink raw reply [flat|nested] 7+ messages in thread
end of thread, other threads:[~2024-06-25 10:43 UTC | newest]
Thread overview: 7+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2024-04-26 12:43 bug#70594: 30.0.50; Error when tabbing with only one active widget Stephen Berman via Bug reports for GNU Emacs, the Swiss army knife of text editors
2024-04-26 15:02 ` Eli Zaretskii
2024-05-09 7:23 ` Eli Zaretskii
2024-05-25 7:42 ` Eli Zaretskii
2024-05-25 9:30 ` Stephen Berman via Bug reports for GNU Emacs, the Swiss army knife of text editors
2024-06-08 11:49 ` Eli Zaretskii
2024-06-25 10:43 ` Stephen Berman via Bug reports for GNU Emacs, the Swiss army knife of text editors
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.