diff options
author | Eli Zaretskii <eliz@gnu.org> | 2021-05-11 16:24:30 +0300 |
---|---|---|
committer | Eli Zaretskii <eliz@gnu.org> | 2021-05-11 16:24:30 +0300 |
commit | 2db8a3257cad5a0b95a4754f8709cf93a5c49bd0 (patch) | |
tree | f734707ad9061d61136e5c1f96d6b9f6ce157ea0 | |
parent | f3f1947e5b5beeef9c004cfa2bf591dc0c0331b8 (diff) | |
parent | 6d225d82c8b472ff23525e9047d8a2dc8c363a43 (diff) | |
download | emacs-2db8a3257cad5a0b95a4754f8709cf93a5c49bd0.tar.gz |
Merge branch 'master' of git.savannah.gnu.org:/srv/git/emacs
-rw-r--r-- | lisp/emacs-lisp/text-property-search.el | 35 |
1 files changed, 22 insertions, 13 deletions
diff --git a/lisp/emacs-lisp/text-property-search.el b/lisp/emacs-lisp/text-property-search.el index 69943a83f1c..49e196d3bfc 100644 --- a/lisp/emacs-lisp/text-property-search.el +++ b/lisp/emacs-lisp/text-property-search.el @@ -32,27 +32,36 @@ (defun text-property-search-forward (property &optional value predicate not-current) "Search for the next region of text whose PROPERTY matches VALUE. - -If not found, return nil and don't move point. -If found, move point to the start of the region and return a -`prop-match' object describing the match. To access the details -of the match, use `prop-match-beginning' and `prop-match-end' for -the buffer positions that limit the region, and -`prop-match-value' for the value of PROPERTY in the region. - PREDICATE is used to decide whether a value of PROPERTY should be considered as matching VALUE. -If PREDICATE is t, that means a value must `equal' VALUE to be -considered a match. -If PREDICATE is nil, a value will match if it is non-nil and -is NOT `equal' to VALUE. + If PREDICATE is a function, it will be called with two arguments: VALUE and the value of PROPERTY. The function should return non-nil if these two values are to be considered a match. +Two special values of PREDICATE can also be used: +If PREDICATE is t, that means a value must `equal' VALUE to be +considered a match. +If PREDICATE is nil, a value will match if is not `equal' to +VALUE. Furthermore, the match region is ended if the value +changes. For instance, this means that if you loop with + + (while (text-property-search-forward 'face) + ...) + +you will get all distinct regions with different `face' values in +the buffer. + If NOT-CURRENT is non-nil, the function will search for the first region that doesn't include point and has a value of PROPERTY -that matches VALUE." +that matches VALUE. + +If no matches can be found, return nil and don't move point. +If found, move point to the start of the region and return a +`prop-match' object describing the match. To access the details +of the match, use `prop-match-beginning' and `prop-match-end' for +the buffer positions that limit the region, and +`prop-match-value' for the value of PROPERTY in the region." (interactive (list (let ((string (completing-read "Search for property: " obarray))) |