GNU bug report logs -
#34769
Bug in emacs 26.1 gdb-send match-string applied after non-matching string-match
Previous Next
Full log
Message #11 received at 34769 <at> debbugs.gnu.org (full text, mbox):
Dear Eli,
thanks for looking into this.
> > It is wrong to call (match-string 3 string) if (string-match gdb-control-commands-regexp string) returned nil.
> ...
> That is true, and a cleanup is a good idea. But please note that the
> undefined results are not used if control-command-p is nil, so the
> issue is not that serious.
The match data is that one of the previous successful matching operation.
One gets an args-out-of-range signal if the indexes in the match data are larger than the width of the string argument to match-string. That is how I discovered the error.
A reconstruction with gdb-send is too involved.
Instead I demonstrate the effect with the following orgmode source code block inclusive results:
#+BEGIN_SRC emacs-lisp
(string-match "\\(1\\) *\\(2\\)" "1 2")
(string-match "\\(3 \\(4\\)\\)" "1 2")
(append
(match-data)
(condition-case err
(match-string 2 "1 2")
(error (list err))))
#+END_SRC
#+RESULTS:
| 0 | 12 | 0 | 1 | 11 | 12 | (args-out-of-range 1 2 11 12) |
Best regards,
Tobias
This bug report was last modified 6 years and 82 days ago.
Previous Next
GNU bug tracking system
Copyright (C) 1999 Darren O. Benham,
1997,2003 nCipher Corporation Ltd,
1994-97 Ian Jackson.