diff options
author | Stefan Kangas <stefankangas@gmail.com> | 2022-11-01 10:30:09 +0100 |
---|---|---|
committer | Stefan Kangas <stefankangas@gmail.com> | 2022-11-01 10:30:09 +0100 |
commit | 123baf3772e71a33eabc1b1169a9b778e2fe3877 (patch) | |
tree | 816a3397bbf33328c31d14c20ec599b2e686d421 /src/search.c | |
parent | e7c105fd73dbede4d00c1f26ad2273d49fabd0da (diff) | |
parent | 1862df834c29197cdd339ee369c0ef21694db851 (diff) | |
download | emacs-123baf3772e71a33eabc1b1169a9b778e2fe3877.tar.gz emacs-123baf3772e71a33eabc1b1169a9b778e2fe3877.tar.bz2 emacs-123baf3772e71a33eabc1b1169a9b778e2fe3877.zip |
Merge from origin/emacs-28
1862df834c ; * src/search.c (Fmatch_data): Doc fix.
15fc5225b1 ; * lisp/whitespace.el (whitespace-trailing): Fix a typo.
9f3c896f7c ; * doc/emacs/text.texi (Quotation Marks): Typo fix. (Bug...
# Conflicts:
# src/search.c
Diffstat (limited to 'src/search.c')
-rw-r--r-- | src/search.c | 35 |
1 files changed, 21 insertions, 14 deletions
diff --git a/src/search.c b/src/search.c index b5d6a442c0f..a7f958c362b 100644 --- a/src/search.c +++ b/src/search.c @@ -2824,11 +2824,21 @@ Return value is undefined if the last search failed. */) } DEFUN ("match-data", Fmatch_data, Smatch_data, 0, 3, 0, - doc: /* Return a list describing what the last search matched. -Element 2N is `(match-beginning N)'; element 2N + 1 is `(match-end N)'. -All the elements are markers or nil (nil if the Nth pair didn't match) -if the last match was on a buffer; integers or nil if a string was matched. -Use `set-match-data' to reinstate the data in this list. + doc: /* Return a list of positions that record text matched by the last search. +Element 2N of the returned list is the position of the beginning of the +match of the Nth subexpression; it corresponds to `(match-beginning N)'; +element 2N + 1 is the position of the end of the match of the Nth +subexpression; it corresponds to `(match-end N)'. See `match-beginning' +and `match-end'. +If the last search was on a buffer, all the elements are by default +markers or nil (nil when the Nth pair didn't match); they are integers +or nil if the search was on a string. But if the optional argument +INTEGERS is non-nil, the elements that represent buffer positions are +always integers, not markers, and (if the search was on a buffer) the +buffer itself is appended to the list as one additional element. + +Use `set-match-data' to reinstate the match data from the elements of +this list. Note that non-matching optional groups at the end of the regexp are elided instead of being represented with two `nil's each. For instance: @@ -2838,16 +2848,13 @@ elided instead of being represented with two `nil's each. For instance: (match-data)) => (0 1 nil nil 0 1) -If INTEGERS (the optional first argument) is non-nil, always use -integers (rather than markers) to represent buffer positions. In -this case, and if the last match was in a buffer, the buffer will get -stored as one additional element at the end of the list. +If REUSE is a list, store the value in REUSE by destructively modifying it. +If REUSE is long enough to hold all the values, its length remains the +same, and any unused elements are set to nil. If REUSE is not long +enough, it is extended. Note that if REUSE is long enough and INTEGERS +is non-nil, no consing is done to make the return value; this minimizes GC. -If REUSE is a list, reuse it as part of the value. If REUSE is long -enough to hold all the values, and if INTEGERS is non-nil, no consing -is done. - -If optional third arg RESEAT is non-nil, any previous markers on the +If optional third argument RESEAT is non-nil, any previous markers on the REUSE list will be modified to point to nowhere. Return value is undefined if the last search failed. */) |