GNU bug report logs -
#23949
25.0.95; Regression in handling error caused by (string-match-p "." nil)
Previous Next
Reported by: Kaushal Modi <kaushal.modi <at> gmail.com>
Date: Mon, 11 Jul 2016 20:13:02 UTC
Severity: normal
Tags: fixed
Merged with 16294,
24166
Found in versions 25.0.95, 24.3.50
Fixed in version 26.1
Done: npostavs <at> users.sourceforge.net
Bug is archived. No further changes may be made.
Full log
View this message in rfc822 format
> From: Stefan Monnier <monnier <at> iro.umontreal.ca>
> Cc: kaushal.modi <at> gmail.com, schwab <at> suse.de, 23949 <at> debbugs.gnu.org
> Date: Wed, 13 Jul 2016 10:48:15 -0400
>
> > I also think that the "breaks a lot of Elisp code" part is at least a
> > tad exaggerated.
>
> Binding inhibit-changing-match-data to t will pretty much break any
> function that uses match-beginning or match-end.
But those functions aren't supposed to run when string-match is
called.
> > (defsubst string-match-p (regexp string &optional start)
> > "\
> > Same as `string-match' except this function does not change the match data."
> > (condition-case err
> > (let ((inhibit-changing-match-data t))
> > (string-match regexp string start))
> > (error (signal (car err) (cdr err)))))
>
> That will still cause the same problems when debug-on-signal is non-nil.
So you don't consider this an improvement that should be installed?
This bug report was last modified 8 years and 167 days ago.
Previous Next
GNU bug tracking system
Copyright (C) 1999 Darren O. Benham,
1997,2003 nCipher Corporation Ltd,
1994-97 Ian Jackson.