GNU bug report logs - #19940
25.0.50; Infinite loop in `studlify-word' with Subword mode

Previous Next

Package: emacs;

Reported by: Simen Heggestøyl <simenheg <at> gmail.com>

Date: Tue, 24 Feb 2015 21:20:01 UTC

Severity: normal

Found in version 25.0.50

Done: Marcin Borkowski <mbork <at> mbork.pl>

Bug is archived. No further changes may be made.

To add a comment to this bug, you must first unarchive it, by sending
a message to control AT debbugs.gnu.org, with unarchive 19940 in the body.
You can then email your comments to 19940 AT debbugs.gnu.org in the normal way.

Toggle the display of automated, internal messages from the tracker.

View this report as an mbox folder, status mbox, maintainer mbox


Report forwarded to bug-gnu-emacs <at> gnu.org:
bug#19940; Package emacs. (Tue, 24 Feb 2015 21:20:01 GMT) Full text and rfc822 format available.

Acknowledgement sent to Simen Heggestøyl <simenheg <at> gmail.com>:
New bug report received and forwarded. Copy sent to bug-gnu-emacs <at> gnu.org. (Tue, 24 Feb 2015 21:20:02 GMT) Full text and rfc822 format available.

Message #5 received at submit <at> debbugs.gnu.org (full text, mbox):

From: Simen Heggestøyl <simenheg <at> gmail.com>
To: bug-gnu-emacs <at> gnu.org
Subject: 25.0.50; Infinite loop in `studlify-word' with Subword mode
Date: Tue, 24 Feb 2015 22:19:04 +0100
[Message part 1 (text/plain, inline)]
An infinite loop occurs when Subword mode is active and
`studlify-word' is run on a word with more than one subword. The bug
seems to have been introduced by changes made to subword.el in commit
6ddc44225e743e2b2a0d5c192f50aefd7a4a915b.

Here is a recipe that triggers the bug, starting from emacs -Q:

 1. Open a new buffer, and type in "subWord".
 2. Activate Subword mode by `M-x subword-mode'.
 3. Move point to the beginning of the line, and run `M-x
    studlify-word'.


In GNU Emacs 25.0.50.2 (x86_64-unknown-linux-gnu, GTK+ Version 3.14.5)
of 2015-02-24 on x240
Repository revision: 450bebaec94611f0958e13e35faf494e17931f8e
Windowing system distributor `The X.Org Foundation', version 
11.0.11604000
System Description:	Debian GNU/Linux 8.0 (jessie)

Configured using:
`configure --without-makeinfo'

Configured features:
XPM JPEG TIFF GIF PNG SOUND DBUS GSETTINGS NOTIFY LIBXML2 FREETYPE XFT
ZLIB

Important settings:
 value of $LANG: en_US.UTF-8
 locale-coding-system: utf-8-unix

Major mode: Lisp Interaction

Minor modes in effect:
 tooltip-mode: t
 global-eldoc-mode: t
 electric-indent-mode: t
 mouse-wheel-mode: t
 tool-bar-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-encryption-mode: t
 auto-compression-mode: t
 line-number-mode: t

Recent messages:
For information about GNU Emacs and the GNU system, type C-h C-a.

Load-path shadows:
None found.

Features:
(shadow sort gnus-util mail-extr emacsbug message dired format-spec
rfc822 mml easymenu mml-sec mm-decode mm-bodies mm-encode mail-parse
rfc2231 mailabbrev gmm-utils mailheader sendmail rfc2047 rfc2045
ietf-drums mm-util help-fns mail-prsvr mail-utils time-date tooltip
eldoc electric uniquify ediff-hook vc-hooks lisp-float-type mwheel x-win
x-dnd tool-bar dnd fontset image regexp-opt fringe tabulated-list
newcomment elisp-mode lisp-mode prog-mode register page menu-bar
rfn-eshadow timer select scroll-bar mouse jit-lock font-lock syntax
facemenu font-core frame cham georgian utf-8-lang misc-lang vietnamese
tibetan thai tai-viet lao korean japanese hebrew greek romanian slovak
czech european ethiopic indian cyrillic chinese case-table epa-hook
jka-cmpr-hook help simple abbrev 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 make-network-process dbusbind
gfilenotify dynamic-setting system-font-setting font-render-setting
move-toolbar gtk x-toolkit x multi-tty emacs)

Memory information:
((conses 16 74956 6410)
(symbols 48 18012 0)
(miscs 40 43 124)
(strings 32 10961 5159)
(string-bytes 1 296944)
(vectors 16 9377)
(vector-slots 8 386766 15535)
(floats 8 70 63)
(intervals 56 175 0)
(buffers 976 11)
(heap 1024 31954 1039))
[Message part 2 (text/html, inline)]

Information forwarded to bug-gnu-emacs <at> gnu.org:
bug#19940; Package emacs. (Sun, 03 Apr 2016 03:50:02 GMT) Full text and rfc822 format available.

Message #8 received at 19940 <at> debbugs.gnu.org (full text, mbox):

From: Marcin Borkowski <mbork <at> mbork.pl>
To: Simen Heggestøyl <simenheg <at> gmail.com>
Cc: 19940 <at> debbugs.gnu.org
Subject: Re: bug#19940: 25.0.50;
 Infinite loop in `studlify-word' with Subword mode
Date: Sun, 03 Apr 2016 05:49:10 +0200
On 2015-02-24, at 21:19, Simen Heggestøyl <simenheg <at> gmail.com> wrote:

> An infinite loop occurs when Subword mode is active and
>
> `studlify-word' is run on a word with more than one subword. The bug
>
>
> seems to have been introduced by changes made to subword.el in commit
>
>
> 6ddc44225e743e2b2a0d5c192f50aefd7a4a915b.
>
>
> Here is a recipe that triggers the bug, starting from emacs -Q:
>
>
> 1. Open a new buffer, and type in "subWord".
>
>
> 2. Activate Subword mode by `M-x subword-mode'.
>
>
> 3. Move point to the beginning of the line, and run `M-x
>
>
> studlify-word'.

Hi,

I can confirm this behavior on GNU Emacs 25.1.50.7 (commit 7570b35).
The problem seems to be that `studlify-region' assumes that
`forward-word' and `backward-word' will stop at non-word characters (in
the sense of the regex `\W').

One possible solution would be to temporarily switch `subword-mode' off
in `studlify-region'.  Given the nonsensicality of the latter, and the
fact that it breaks studlyCapsIdentifiers anyway, this might be the
preferred solution.  If nobody proposes anything better, I'll tryto
prepare such a patch within a few days.

-- 
Marcin Borkowski




Information forwarded to bug-gnu-emacs <at> gnu.org:
bug#19940; Package emacs. (Sun, 03 Apr 2016 14:44:01 GMT) Full text and rfc822 format available.

Message #11 received at 19940 <at> debbugs.gnu.org (full text, mbox):

From: Eli Zaretskii <eliz <at> gnu.org>
To: Marcin Borkowski <mbork <at> mbork.pl>
Cc: 19940 <at> debbugs.gnu.org, simenheg <at> gmail.com
Subject: Re: bug#19940: 25.0.50;
 Infinite loop in `studlify-word' with Subword mode
Date: Sun, 03 Apr 2016 17:43:06 +0300
> From: Marcin Borkowski <mbork <at> mbork.pl>
> Date: Sun, 03 Apr 2016 05:49:10 +0200
> Cc: 19940 <at> debbugs.gnu.org
> 
> One possible solution would be to temporarily switch `subword-mode' off
> in `studlify-region'.  Given the nonsensicality of the latter, and the
> fact that it breaks studlyCapsIdentifiers anyway, this might be the
> preferred solution.  If nobody proposes anything better, I'll tryto
> prepare such a patch within a few days.

Actually, the right solution is described in this NEWS entry:

  ** The new implementation of Subword mode affects word movement everywhere.
  When Subword mode is turned on, 'forward-word', 'backward-word', and
  everything that uses them will move by sub-words, effectively
  overriding the buffer's syntax table.  Lisp programs that shouldn't be
  affected by Subword mode should call the new functions
  'forward-word-strictly' and 'backward-word-strictly' instead.

At the time I wrote this NEWS entry, I reviewed all the callers of
forward/backward-word and changed those which I thought needed that; I
guess I missed studly.el at that time.  Sorry about that.

Thanks.




Information forwarded to bug-gnu-emacs <at> gnu.org:
bug#19940; Package emacs. (Sun, 03 Apr 2016 16:09:01 GMT) Full text and rfc822 format available.

Message #14 received at 19940 <at> debbugs.gnu.org (full text, mbox):

From: Marcin Borkowski <mbork <at> mbork.pl>
To: Eli Zaretskii <eliz <at> gnu.org>
Cc: 19940 <at> debbugs.gnu.org, simenheg <at> gmail.com
Subject: Re: bug#19940: 25.0.50;
 Infinite loop in `studlify-word' with Subword mode
Date: Sun, 03 Apr 2016 18:07:54 +0200
On 2016-04-03, at 16:43, Eli Zaretskii <eliz <at> gnu.org> wrote:

>> From: Marcin Borkowski <mbork <at> mbork.pl>
>> Date: Sun, 03 Apr 2016 05:49:10 +0200
>> Cc: 19940 <at> debbugs.gnu.org
>> 
>> One possible solution would be to temporarily switch `subword-mode' off
>> in `studlify-region'.  Given the nonsensicality of the latter, and the
>> fact that it breaks studlyCapsIdentifiers anyway, this might be the
>> preferred solution.  If nobody proposes anything better, I'll tryto
>> prepare such a patch within a few days.
>
> Actually, the right solution is described in this NEWS entry:
>
>   ** The new implementation of Subword mode affects word movement everywhere.
>   When Subword mode is turned on, 'forward-word', 'backward-word', and
>   everything that uses them will move by sub-words, effectively
>   overriding the buffer's syntax table.  Lisp programs that shouldn't be
>   affected by Subword mode should call the new functions
>   'forward-word-strictly' and 'backward-word-strictly' instead.
>
> At the time I wrote this NEWS entry, I reviewed all the callers of
> forward/backward-word and changed those which I thought needed that; I
> guess I missed studly.el at that time.  Sorry about that.

Ah, good to know.  I suspected that such function would exist, but was
too lazy to actually find out - sorry!

I'll make a patch tomorrow.

> Thanks.

Best,

-- 
Marcin Borkowski
http://octd.wmi.amu.edu.pl/en/Marcin_Borkowski
Faculty of Mathematics and Computer Science
Adam Mickiewicz University




Reply sent to Marcin Borkowski <mbork <at> mbork.pl>:
You have taken responsibility. (Wed, 06 Apr 2016 11:50:01 GMT) Full text and rfc822 format available.

Notification sent to Simen Heggestøyl <simenheg <at> gmail.com>:
bug acknowledged by developer. (Wed, 06 Apr 2016 11:50:02 GMT) Full text and rfc822 format available.

Message #19 received at 19940-done <at> debbugs.gnu.org (full text, mbox):

From: Marcin Borkowski <mbork <at> mbork.pl>
To: Eli Zaretskii <eliz <at> gnu.org>
Cc: 19940-done <at> debbugs.gnu.org, simenheg <at> gmail.com
Subject: Re: bug#19940: 25.0.50;
 Infinite loop in `studlify-word' with Subword mode
Date: Wed, 06 Apr 2016 13:49:23 +0200
[Message part 1 (text/plain, inline)]
On 2016-04-03, at 18:07, Marcin Borkowski <mbork <at> mbork.pl> wrote:

> I'll make a patch tomorrow.

Sorry it took me so long, here's the patch.  I'm also closing this bug.

Best,

--
Marcin
[0001-Fix-bug-19940.patch (text/x-patch, attachment)]

Information forwarded to bug-gnu-emacs <at> gnu.org:
bug#19940; Package emacs. (Fri, 08 Apr 2016 08:01:02 GMT) Full text and rfc822 format available.

Message #22 received at 19940 <at> debbugs.gnu.org (full text, mbox):

From: Eli Zaretskii <eliz <at> gnu.org>
To: Marcin Borkowski <mbork <at> mbork.pl>
Cc: 19940 <at> debbugs.gnu.org
Subject: Re: bug#19940: 25.0.50;
 Infinite loop in `studlify-word' with Subword mode
Date: Fri, 08 Apr 2016 10:59:56 +0300
> From: Marcin Borkowski <mbork <at> mbork.pl>
> Cc: 19940-done <at> debbugs.gnu.org,  simenheg <at> gmail.com
> Date: Wed, 06 Apr 2016 13:49:23 +0200
> 
> Sorry it took me so long, here's the patch.  I'm also closing this bug.

Thanks, I pushed it to the emacs-25 branch.

In the future, please don't use Sed-like expressions in the log
entries, use plain English instead.  And we usually close bugs only
after the changes are committed to the repository.




Information forwarded to bug-gnu-emacs <at> gnu.org:
bug#19940; Package emacs. (Fri, 08 Apr 2016 18:15:01 GMT) Full text and rfc822 format available.

Message #25 received at 19940 <at> debbugs.gnu.org (full text, mbox):

From: Marcin Borkowski <mbork <at> mbork.pl>
To: Eli Zaretskii <eliz <at> gnu.org>
Cc: 19940 <at> debbugs.gnu.org
Subject: Re: bug#19940: 25.0.50;
 Infinite loop in `studlify-word' with Subword mode
Date: Fri, 08 Apr 2016 20:14:20 +0200
On 2016-04-08, at 07:59, Eli Zaretskii <eliz <at> gnu.org> wrote:

>> From: Marcin Borkowski <mbork <at> mbork.pl>
>> Cc: 19940-done <at> debbugs.gnu.org,  simenheg <at> gmail.com
>> Date: Wed, 06 Apr 2016 13:49:23 +0200
>> 
>> Sorry it took me so long, here's the patch.  I'm also closing this bug.
>
> Thanks, I pushed it to the emacs-25 branch.
>
> In the future, please don't use Sed-like expressions in the log
> entries, use plain English instead.  And we usually close bugs only
> after the changes are committed to the repository.

Sorry, I'm still learning to write commit messages for Emacs.  I'll also
remember your remark about closing.

Best,

-- 
Marcin Borkowski
http://octd.wmi.amu.edu.pl/en/Marcin_Borkowski
Faculty of Mathematics and Computer Science
Adam Mickiewicz University




bug archived. Request was from Debbugs Internal Request <help-debbugs <at> gnu.org> to internal_control <at> debbugs.gnu.org. (Sat, 07 May 2016 11:24:04 GMT) Full text and rfc822 format available.

This bug report was last modified 9 years and 138 days ago.

Previous Next


GNU bug tracking system
Copyright (C) 1999 Darren O. Benham, 1997,2003 nCipher Corporation Ltd, 1994-97 Ian Jackson.