Mercurial > emacs
annotate src/textprop.c @ 37467:342409bb6b91
(modify-face): Add compatibility for non-interactive use.
author | Stefan Monnier <monnier@iro.umontreal.ca> |
---|---|
date | Wed, 25 Apr 2001 15:22:44 +0000 |
parents | df19dee0cf24 |
children | 96abf5ad6f42 |
rev | line source |
---|---|
1029 | 1 /* Interface code for dealing with text properties. |
30699
f886557e4b2a
(Fget_char_property): Update call to overlays_at.
Miles Bader <miles@gnu.org>
parents:
30678
diff
changeset
|
2 Copyright (C) 1993, 1994, 1995, 1997, 1999, 2000 Free Software Foundation, Inc. |
1029 | 3 |
4 This file is part of GNU Emacs. | |
5 | |
6 GNU Emacs is free software; you can redistribute it and/or modify | |
7 it under the terms of the GNU General Public License as published by | |
3698 | 8 the Free Software Foundation; either version 2, or (at your option) |
1029 | 9 any later version. |
10 | |
11 GNU Emacs is distributed in the hope that it will be useful, | |
12 but WITHOUT ANY WARRANTY; without even the implied warranty of | |
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
14 GNU General Public License for more details. | |
15 | |
16 You should have received a copy of the GNU General Public License | |
17 along with GNU Emacs; see the file COPYING. If not, write to | |
14186
ee40177f6c68
Update FSF's address in the preamble.
Erik Naggum <erik@naggum.no>
parents:
14088
diff
changeset
|
18 the Free Software Foundation, Inc., 59 Temple Place - Suite 330, |
ee40177f6c68
Update FSF's address in the preamble.
Erik Naggum <erik@naggum.no>
parents:
14088
diff
changeset
|
19 Boston, MA 02111-1307, USA. */ |
1029 | 20 |
4696
1fc792473491
Include <config.h> instead of "config.h".
Roland McGrath <roland@gnu.org>
parents:
4649
diff
changeset
|
21 #include <config.h> |
1029 | 22 #include "lisp.h" |
23 #include "intervals.h" | |
24 #include "buffer.h" | |
6063
233fffcfb6c8
(Fget_char_property): New function.
Karl Heuer <kwzh@gnu.org>
parents:
5646
diff
changeset
|
25 #include "window.h" |
8962
722763fed8ce
(Fget_char_property): Pass new arg to overlays_at.
Richard M. Stallman <rms@gnu.org>
parents:
8907
diff
changeset
|
26 |
722763fed8ce
(Fget_char_property): Pass new arg to overlays_at.
Richard M. Stallman <rms@gnu.org>
parents:
8907
diff
changeset
|
27 #ifndef NULL |
722763fed8ce
(Fget_char_property): Pass new arg to overlays_at.
Richard M. Stallman <rms@gnu.org>
parents:
8907
diff
changeset
|
28 #define NULL (void *)0 |
722763fed8ce
(Fget_char_property): Pass new arg to overlays_at.
Richard M. Stallman <rms@gnu.org>
parents:
8907
diff
changeset
|
29 #endif |
13027
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
30 |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
31 /* Test for membership, allowing for t (actually any non-cons) to mean the |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
32 universal set. */ |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
33 |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
34 #define TMEM(sym, set) (CONSP (set) ? ! NILP (Fmemq (sym, set)) : ! NILP (set)) |
1029 | 35 |
36 | |
37 /* NOTES: previous- and next- property change will have to skip | |
38 zero-length intervals if they are implemented. This could be done | |
39 inside next_interval and previous_interval. | |
40 | |
1211 | 41 set_properties needs to deal with the interval property cache. |
42 | |
1029 | 43 It is assumed that for any interval plist, a property appears |
1965
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
44 only once on the list. Although some code i.e., remove_properties, |
1029 | 45 handles the more general case, the uniqueness of properties is |
3591
507f64624555
Apply typo patches from Paul Eggert.
Jim Blandy <jimb@redhat.com>
parents:
3553
diff
changeset
|
46 necessary for the system to remain consistent. This requirement |
17467
98c47e7857f3
Style of comments corrected.
Richard M. Stallman <rms@gnu.org>
parents:
16679
diff
changeset
|
47 is enforced by the subrs installing properties onto the intervals. */ |
1029 | 48 |
49 | |
17467
98c47e7857f3
Style of comments corrected.
Richard M. Stallman <rms@gnu.org>
parents:
16679
diff
changeset
|
50 /* Types of hooks. */ |
1029 | 51 Lisp_Object Qmouse_left; |
52 Lisp_Object Qmouse_entered; | |
53 Lisp_Object Qpoint_left; | |
54 Lisp_Object Qpoint_entered; | |
2058
a43d0bb1b7d8
(Fget_text_property): Use textget.
Richard M. Stallman <rms@gnu.org>
parents:
2053
diff
changeset
|
55 Lisp_Object Qcategory; |
a43d0bb1b7d8
(Fget_text_property): Use textget.
Richard M. Stallman <rms@gnu.org>
parents:
2053
diff
changeset
|
56 Lisp_Object Qlocal_map; |
1029 | 57 |
17467
98c47e7857f3
Style of comments corrected.
Richard M. Stallman <rms@gnu.org>
parents:
16679
diff
changeset
|
58 /* Visual properties text (including strings) may have. */ |
1029 | 59 Lisp_Object Qforeground, Qbackground, Qfont, Qunderline, Qstipple; |
23729
cf1cbb0e5d5b
(Qmouse_face): Variable definition moved here.
Richard M. Stallman <rms@gnu.org>
parents:
22344
diff
changeset
|
60 Lisp_Object Qinvisible, Qread_only, Qintangible, Qmouse_face; |
4381
b0556af4d680
(Qfront_sticky, Qrear_nonsticky): New variables.
Richard M. Stallman <rms@gnu.org>
parents:
4242
diff
changeset
|
61 |
b0556af4d680
(Qfront_sticky, Qrear_nonsticky): New variables.
Richard M. Stallman <rms@gnu.org>
parents:
4242
diff
changeset
|
62 /* Sticky properties */ |
b0556af4d680
(Qfront_sticky, Qrear_nonsticky): New variables.
Richard M. Stallman <rms@gnu.org>
parents:
4242
diff
changeset
|
63 Lisp_Object Qfront_sticky, Qrear_nonsticky; |
3960
7be89f84a882
* textprop.c (set_properties): Add undo records to remove entirely
Jim Blandy <jimb@redhat.com>
parents:
3858
diff
changeset
|
64 |
7be89f84a882
* textprop.c (set_properties): Add undo records to remove entirely
Jim Blandy <jimb@redhat.com>
parents:
3858
diff
changeset
|
65 /* If o1 is a cons whose cdr is a cons, return non-zero and set o2 to |
7be89f84a882
* textprop.c (set_properties): Add undo records to remove entirely
Jim Blandy <jimb@redhat.com>
parents:
3858
diff
changeset
|
66 the o1's cdr. Otherwise, return zero. This is handy for |
7be89f84a882
* textprop.c (set_properties): Add undo records to remove entirely
Jim Blandy <jimb@redhat.com>
parents:
3858
diff
changeset
|
67 traversing plists. */ |
25645
a14111a2a100
Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents:
25000
diff
changeset
|
68 #define PLIST_ELT_P(o1, o2) (CONSP (o1) && ((o2)=XCDR (o1), CONSP (o2))) |
3960
7be89f84a882
* textprop.c (set_properties): Add undo records to remove entirely
Jim Blandy <jimb@redhat.com>
parents:
3858
diff
changeset
|
69 |
4242
49007dbbec4c
(syms_of_textprop): Set up Lisp var Vinhibit_point_motion_hooks.
Richard M. Stallman <rms@gnu.org>
parents:
4214
diff
changeset
|
70 Lisp_Object Vinhibit_point_motion_hooks; |
11131
5db8a01b22cb
(Vdefault_text_properties): name changed from Vdefault_properties.
Boris Goldowsky <boris@gnu.org>
parents:
11116
diff
changeset
|
71 Lisp_Object Vdefault_text_properties; |
26872
ea588757e607
(Vtext_property_default_nonsticky): New variable
Kenichi Handa <handa@m17n.org>
parents:
26605
diff
changeset
|
72 Lisp_Object Vtext_property_default_nonsticky; |
4242
49007dbbec4c
(syms_of_textprop): Set up Lisp var Vinhibit_point_motion_hooks.
Richard M. Stallman <rms@gnu.org>
parents:
4214
diff
changeset
|
73 |
13027
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
74 /* verify_interval_modification saves insertion hooks here |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
75 to be run later by report_interval_modification. */ |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
76 Lisp_Object interval_insert_behind_hooks; |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
77 Lisp_Object interval_insert_in_front_hooks; |
33952
ca22422634ac
(text_read_only): New function.
Gerd Moellmann <gerd@gnu.org>
parents:
32849
diff
changeset
|
78 |
ca22422634ac
(text_read_only): New function.
Gerd Moellmann <gerd@gnu.org>
parents:
32849
diff
changeset
|
79 |
ca22422634ac
(text_read_only): New function.
Gerd Moellmann <gerd@gnu.org>
parents:
32849
diff
changeset
|
80 /* Signal a `text-read-only' error. This function makes it easier |
ca22422634ac
(text_read_only): New function.
Gerd Moellmann <gerd@gnu.org>
parents:
32849
diff
changeset
|
81 to capture that error in GDB by putting a breakpoint on it. */ |
ca22422634ac
(text_read_only): New function.
Gerd Moellmann <gerd@gnu.org>
parents:
32849
diff
changeset
|
82 |
ca22422634ac
(text_read_only): New function.
Gerd Moellmann <gerd@gnu.org>
parents:
32849
diff
changeset
|
83 static void |
ca22422634ac
(text_read_only): New function.
Gerd Moellmann <gerd@gnu.org>
parents:
32849
diff
changeset
|
84 text_read_only () |
ca22422634ac
(text_read_only): New function.
Gerd Moellmann <gerd@gnu.org>
parents:
32849
diff
changeset
|
85 { |
ca22422634ac
(text_read_only): New function.
Gerd Moellmann <gerd@gnu.org>
parents:
32849
diff
changeset
|
86 Fsignal (Qtext_read_only, Qnil); |
ca22422634ac
(text_read_only): New function.
Gerd Moellmann <gerd@gnu.org>
parents:
32849
diff
changeset
|
87 } |
ca22422634ac
(text_read_only): New function.
Gerd Moellmann <gerd@gnu.org>
parents:
32849
diff
changeset
|
88 |
ca22422634ac
(text_read_only): New function.
Gerd Moellmann <gerd@gnu.org>
parents:
32849
diff
changeset
|
89 |
1029 | 90 |
1055 | 91 /* Extract the interval at the position pointed to by BEGIN from |
92 OBJECT, a string or buffer. Additionally, check that the positions | |
93 pointed to by BEGIN and END are within the bounds of OBJECT, and | |
94 reverse them if *BEGIN is greater than *END. The objects pointed | |
95 to by BEGIN and END may be integers or markers; if the latter, they | |
96 are coerced to integers. | |
1029 | 97 |
1965
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
98 When OBJECT is a string, we increment *BEGIN and *END |
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
99 to make them origin-one. |
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
100 |
1029 | 101 Note that buffer points don't correspond to interval indices. |
102 For example, point-max is 1 greater than the index of the last | |
103 character. This difference is handled in the caller, which uses | |
104 the validated points to determine a length, and operates on that. | |
105 Exceptions are Ftext_properties_at, Fnext_property_change, and | |
106 Fprevious_property_change which call this function with BEGIN == END. | |
107 Handle this case specially. | |
108 | |
109 If FORCE is soft (0), it's OK to return NULL_INTERVAL. Otherwise, | |
1055 | 110 create an interval tree for OBJECT if one doesn't exist, provided |
111 the object actually contains text. In the current design, if there | |
1965
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
112 is no text, there can be no text properties. */ |
1029 | 113 |
114 #define soft 0 | |
115 #define hard 1 | |
116 | |
25000 | 117 INTERVAL |
1029 | 118 validate_interval_range (object, begin, end, force) |
119 Lisp_Object object, *begin, *end; | |
120 int force; | |
121 { | |
122 register INTERVAL i; | |
1965
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
123 int searchpos; |
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
124 |
1029 | 125 CHECK_STRING_OR_BUFFER (object, 0); |
126 CHECK_NUMBER_COERCE_MARKER (*begin, 0); | |
127 CHECK_NUMBER_COERCE_MARKER (*end, 0); | |
128 | |
129 /* If we are asked for a point, but from a subr which operates | |
17467
98c47e7857f3
Style of comments corrected.
Richard M. Stallman <rms@gnu.org>
parents:
16679
diff
changeset
|
130 on a range, then return nothing. */ |
8907
f7de8b4cb1b8
(validate_interval_range, property_value, Fget_char_property,
Karl Heuer <kwzh@gnu.org>
parents:
8856
diff
changeset
|
131 if (EQ (*begin, *end) && begin != end) |
1029 | 132 return NULL_INTERVAL; |
133 | |
134 if (XINT (*begin) > XINT (*end)) | |
135 { | |
1965
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
136 Lisp_Object n; |
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
137 n = *begin; |
1029 | 138 *begin = *end; |
1965
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
139 *end = n; |
1029 | 140 } |
141 | |
9109
6e44ddc40153
(validate_interval_range, add_properties, remove_properties,
Karl Heuer <kwzh@gnu.org>
parents:
9071
diff
changeset
|
142 if (BUFFERP (object)) |
1029 | 143 { |
144 register struct buffer *b = XBUFFER (object); | |
145 | |
146 if (!(BUF_BEGV (b) <= XINT (*begin) && XINT (*begin) <= XINT (*end) | |
147 && XINT (*end) <= BUF_ZV (b))) | |
148 args_out_of_range (*begin, *end); | |
10312
4bf079c613c6
(validate_interval_range): Use BUF_INTERVALS.
Richard M. Stallman <rms@gnu.org>
parents:
10159
diff
changeset
|
149 i = BUF_INTERVALS (b); |
1029 | 150 |
17467
98c47e7857f3
Style of comments corrected.
Richard M. Stallman <rms@gnu.org>
parents:
16679
diff
changeset
|
151 /* If there's no text, there are no properties. */ |
1965
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
152 if (BUF_BEGV (b) == BUF_ZV (b)) |
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
153 return NULL_INTERVAL; |
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
154 |
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
155 searchpos = XINT (*begin); |
1029 | 156 } |
157 else | |
158 { | |
159 register struct Lisp_String *s = XSTRING (object); | |
160 | |
1965
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
161 if (! (0 <= XINT (*begin) && XINT (*begin) <= XINT (*end) |
1029 | 162 && XINT (*end) <= s->size)) |
163 args_out_of_range (*begin, *end); | |
22344
2ec50b4767ed
Handle the new convention that `position' values
Karl Heuer <kwzh@gnu.org>
parents:
22280
diff
changeset
|
164 XSETFASTINT (*begin, XFASTINT (*begin)); |
3996
b9bdcf862c67
* textprop.c (validate_interval_range): Don't increment both
Jim Blandy <jimb@redhat.com>
parents:
3960
diff
changeset
|
165 if (begin != end) |
22344
2ec50b4767ed
Handle the new convention that `position' values
Karl Heuer <kwzh@gnu.org>
parents:
22280
diff
changeset
|
166 XSETFASTINT (*end, XFASTINT (*end)); |
1029 | 167 i = s->intervals; |
1965
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
168 |
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
169 if (s->size == 0) |
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
170 return NULL_INTERVAL; |
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
171 |
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
172 searchpos = XINT (*begin); |
1029 | 173 } |
174 | |
175 if (NULL_INTERVAL_P (i)) | |
176 return (force ? create_root_interval (object) : i); | |
177 | |
1965
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
178 return find_interval (i, searchpos); |
1029 | 179 } |
180 | |
181 /* Validate LIST as a property list. If LIST is not a list, then | |
182 make one consisting of (LIST nil). Otherwise, verify that LIST | |
17467
98c47e7857f3
Style of comments corrected.
Richard M. Stallman <rms@gnu.org>
parents:
16679
diff
changeset
|
183 is even numbered and thus suitable as a plist. */ |
1029 | 184 |
185 static Lisp_Object | |
186 validate_plist (list) | |
4797
4dd43e41207a
(validate_plist): Add argument declaration for `list'.
Brian Fox <bfox@gnu.org>
parents:
4696
diff
changeset
|
187 Lisp_Object list; |
1029 | 188 { |
189 if (NILP (list)) | |
190 return Qnil; | |
191 | |
192 if (CONSP (list)) | |
193 { | |
194 register int i; | |
195 register Lisp_Object tail; | |
196 for (i = 0, tail = list; !NILP (tail); i++) | |
3996
b9bdcf862c67
* textprop.c (validate_interval_range): Don't increment both
Jim Blandy <jimb@redhat.com>
parents:
3960
diff
changeset
|
197 { |
b9bdcf862c67
* textprop.c (validate_interval_range): Don't increment both
Jim Blandy <jimb@redhat.com>
parents:
3960
diff
changeset
|
198 tail = Fcdr (tail); |
b9bdcf862c67
* textprop.c (validate_interval_range): Don't increment both
Jim Blandy <jimb@redhat.com>
parents:
3960
diff
changeset
|
199 QUIT; |
b9bdcf862c67
* textprop.c (validate_interval_range): Don't increment both
Jim Blandy <jimb@redhat.com>
parents:
3960
diff
changeset
|
200 } |
1029 | 201 if (i & 1) |
202 error ("Odd length text property list"); | |
203 return list; | |
204 } | |
205 | |
206 return Fcons (list, Fcons (Qnil, Qnil)); | |
207 } | |
208 | |
209 /* Return nonzero if interval I has all the properties, | |
17467
98c47e7857f3
Style of comments corrected.
Richard M. Stallman <rms@gnu.org>
parents:
16679
diff
changeset
|
210 with the same values, of list PLIST. */ |
1029 | 211 |
212 static int | |
213 interval_has_all_properties (plist, i) | |
214 Lisp_Object plist; | |
215 INTERVAL i; | |
216 { | |
25772
1902e7e63fa7
(Fset_text_properties): Remove unused variables.
Gerd Moellmann <gerd@gnu.org>
parents:
25645
diff
changeset
|
217 register Lisp_Object tail1, tail2, sym1; |
1029 | 218 register int found; |
219 | |
17467
98c47e7857f3
Style of comments corrected.
Richard M. Stallman <rms@gnu.org>
parents:
16679
diff
changeset
|
220 /* Go through each element of PLIST. */ |
1029 | 221 for (tail1 = plist; ! NILP (tail1); tail1 = Fcdr (Fcdr (tail1))) |
222 { | |
223 sym1 = Fcar (tail1); | |
224 found = 0; | |
225 | |
226 /* Go through I's plist, looking for sym1 */ | |
227 for (tail2 = i->plist; ! NILP (tail2); tail2 = Fcdr (Fcdr (tail2))) | |
228 if (EQ (sym1, Fcar (tail2))) | |
229 { | |
230 /* Found the same property on both lists. If the | |
17467
98c47e7857f3
Style of comments corrected.
Richard M. Stallman <rms@gnu.org>
parents:
16679
diff
changeset
|
231 values are unequal, return zero. */ |
3998
c0560357c84e
Compare the values of text properties using EQ, not Fequal.
Jim Blandy <jimb@redhat.com>
parents:
3996
diff
changeset
|
232 if (! EQ (Fcar (Fcdr (tail1)), Fcar (Fcdr (tail2)))) |
1029 | 233 return 0; |
234 | |
17467
98c47e7857f3
Style of comments corrected.
Richard M. Stallman <rms@gnu.org>
parents:
16679
diff
changeset
|
235 /* Property has same value on both lists; go to next one. */ |
1029 | 236 found = 1; |
237 break; | |
238 } | |
239 | |
240 if (! found) | |
241 return 0; | |
242 } | |
243 | |
244 return 1; | |
245 } | |
246 | |
247 /* Return nonzero if the plist of interval I has any of the | |
17467
98c47e7857f3
Style of comments corrected.
Richard M. Stallman <rms@gnu.org>
parents:
16679
diff
changeset
|
248 properties of PLIST, regardless of their values. */ |
1029 | 249 |
250 static INLINE int | |
251 interval_has_some_properties (plist, i) | |
252 Lisp_Object plist; | |
253 INTERVAL i; | |
254 { | |
255 register Lisp_Object tail1, tail2, sym; | |
256 | |
17467
98c47e7857f3
Style of comments corrected.
Richard M. Stallman <rms@gnu.org>
parents:
16679
diff
changeset
|
257 /* Go through each element of PLIST. */ |
1029 | 258 for (tail1 = plist; ! NILP (tail1); tail1 = Fcdr (Fcdr (tail1))) |
259 { | |
260 sym = Fcar (tail1); | |
261 | |
262 /* Go through i's plist, looking for tail1 */ | |
263 for (tail2 = i->plist; ! NILP (tail2); tail2 = Fcdr (Fcdr (tail2))) | |
264 if (EQ (sym, Fcar (tail2))) | |
265 return 1; | |
266 } | |
267 | |
268 return 0; | |
269 } | |
1965
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
270 |
3960
7be89f84a882
* textprop.c (set_properties): Add undo records to remove entirely
Jim Blandy <jimb@redhat.com>
parents:
3858
diff
changeset
|
271 /* Changing the plists of individual intervals. */ |
7be89f84a882
* textprop.c (set_properties): Add undo records to remove entirely
Jim Blandy <jimb@redhat.com>
parents:
3858
diff
changeset
|
272 |
7be89f84a882
* textprop.c (set_properties): Add undo records to remove entirely
Jim Blandy <jimb@redhat.com>
parents:
3858
diff
changeset
|
273 /* Return the value of PROP in property-list PLIST, or Qunbound if it |
7be89f84a882
* textprop.c (set_properties): Add undo records to remove entirely
Jim Blandy <jimb@redhat.com>
parents:
3858
diff
changeset
|
274 has none. */ |
8907
f7de8b4cb1b8
(validate_interval_range, property_value, Fget_char_property,
Karl Heuer <kwzh@gnu.org>
parents:
8856
diff
changeset
|
275 static Lisp_Object |
3960
7be89f84a882
* textprop.c (set_properties): Add undo records to remove entirely
Jim Blandy <jimb@redhat.com>
parents:
3858
diff
changeset
|
276 property_value (plist, prop) |
8856
7e9547af43e8
(property_value): Declare args plist, prop.
Richard M. Stallman <rms@gnu.org>
parents:
8762
diff
changeset
|
277 Lisp_Object plist, prop; |
3960
7be89f84a882
* textprop.c (set_properties): Add undo records to remove entirely
Jim Blandy <jimb@redhat.com>
parents:
3858
diff
changeset
|
278 { |
7be89f84a882
* textprop.c (set_properties): Add undo records to remove entirely
Jim Blandy <jimb@redhat.com>
parents:
3858
diff
changeset
|
279 Lisp_Object value; |
7be89f84a882
* textprop.c (set_properties): Add undo records to remove entirely
Jim Blandy <jimb@redhat.com>
parents:
3858
diff
changeset
|
280 |
7be89f84a882
* textprop.c (set_properties): Add undo records to remove entirely
Jim Blandy <jimb@redhat.com>
parents:
3858
diff
changeset
|
281 while (PLIST_ELT_P (plist, value)) |
25645
a14111a2a100
Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents:
25000
diff
changeset
|
282 if (EQ (XCAR (plist), prop)) |
a14111a2a100
Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents:
25000
diff
changeset
|
283 return XCAR (value); |
3960
7be89f84a882
* textprop.c (set_properties): Add undo records to remove entirely
Jim Blandy <jimb@redhat.com>
parents:
3858
diff
changeset
|
284 else |
25645
a14111a2a100
Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents:
25000
diff
changeset
|
285 plist = XCDR (value); |
3960
7be89f84a882
* textprop.c (set_properties): Add undo records to remove entirely
Jim Blandy <jimb@redhat.com>
parents:
3858
diff
changeset
|
286 |
7be89f84a882
* textprop.c (set_properties): Add undo records to remove entirely
Jim Blandy <jimb@redhat.com>
parents:
3858
diff
changeset
|
287 return Qunbound; |
7be89f84a882
* textprop.c (set_properties): Add undo records to remove entirely
Jim Blandy <jimb@redhat.com>
parents:
3858
diff
changeset
|
288 } |
7be89f84a882
* textprop.c (set_properties): Add undo records to remove entirely
Jim Blandy <jimb@redhat.com>
parents:
3858
diff
changeset
|
289 |
1965
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
290 /* Set the properties of INTERVAL to PROPERTIES, |
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
291 and record undo info for the previous values. |
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
292 OBJECT is the string or buffer that INTERVAL belongs to. */ |
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
293 |
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
294 static void |
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
295 set_properties (properties, interval, object) |
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
296 Lisp_Object properties, object; |
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
297 INTERVAL interval; |
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
298 { |
3960
7be89f84a882
* textprop.c (set_properties): Add undo records to remove entirely
Jim Blandy <jimb@redhat.com>
parents:
3858
diff
changeset
|
299 Lisp_Object sym, value; |
1965
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
300 |
3960
7be89f84a882
* textprop.c (set_properties): Add undo records to remove entirely
Jim Blandy <jimb@redhat.com>
parents:
3858
diff
changeset
|
301 if (BUFFERP (object)) |
1965
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
302 { |
3960
7be89f84a882
* textprop.c (set_properties): Add undo records to remove entirely
Jim Blandy <jimb@redhat.com>
parents:
3858
diff
changeset
|
303 /* For each property in the old plist which is missing from PROPERTIES, |
7be89f84a882
* textprop.c (set_properties): Add undo records to remove entirely
Jim Blandy <jimb@redhat.com>
parents:
3858
diff
changeset
|
304 or has a different value in PROPERTIES, make an undo record. */ |
7be89f84a882
* textprop.c (set_properties): Add undo records to remove entirely
Jim Blandy <jimb@redhat.com>
parents:
3858
diff
changeset
|
305 for (sym = interval->plist; |
7be89f84a882
* textprop.c (set_properties): Add undo records to remove entirely
Jim Blandy <jimb@redhat.com>
parents:
3858
diff
changeset
|
306 PLIST_ELT_P (sym, value); |
25645
a14111a2a100
Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents:
25000
diff
changeset
|
307 sym = XCDR (value)) |
a14111a2a100
Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents:
25000
diff
changeset
|
308 if (! EQ (property_value (properties, XCAR (sym)), |
a14111a2a100
Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents:
25000
diff
changeset
|
309 XCAR (value))) |
4076
9fd5ecacfbbb
(Qinsert_in_front_hooks, Qinsert_behind_hooks): New vars.
Richard M. Stallman <rms@gnu.org>
parents:
4007
diff
changeset
|
310 { |
9fd5ecacfbbb
(Qinsert_in_front_hooks, Qinsert_behind_hooks): New vars.
Richard M. Stallman <rms@gnu.org>
parents:
4007
diff
changeset
|
311 record_property_change (interval->position, LENGTH (interval), |
25645
a14111a2a100
Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents:
25000
diff
changeset
|
312 XCAR (sym), XCAR (value), |
4076
9fd5ecacfbbb
(Qinsert_in_front_hooks, Qinsert_behind_hooks): New vars.
Richard M. Stallman <rms@gnu.org>
parents:
4007
diff
changeset
|
313 object); |
9fd5ecacfbbb
(Qinsert_in_front_hooks, Qinsert_behind_hooks): New vars.
Richard M. Stallman <rms@gnu.org>
parents:
4007
diff
changeset
|
314 } |
3960
7be89f84a882
* textprop.c (set_properties): Add undo records to remove entirely
Jim Blandy <jimb@redhat.com>
parents:
3858
diff
changeset
|
315 |
7be89f84a882
* textprop.c (set_properties): Add undo records to remove entirely
Jim Blandy <jimb@redhat.com>
parents:
3858
diff
changeset
|
316 /* For each new property that has no value at all in the old plist, |
7be89f84a882
* textprop.c (set_properties): Add undo records to remove entirely
Jim Blandy <jimb@redhat.com>
parents:
3858
diff
changeset
|
317 make an undo record binding it to nil, so it will be removed. */ |
7be89f84a882
* textprop.c (set_properties): Add undo records to remove entirely
Jim Blandy <jimb@redhat.com>
parents:
3858
diff
changeset
|
318 for (sym = properties; |
7be89f84a882
* textprop.c (set_properties): Add undo records to remove entirely
Jim Blandy <jimb@redhat.com>
parents:
3858
diff
changeset
|
319 PLIST_ELT_P (sym, value); |
25645
a14111a2a100
Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents:
25000
diff
changeset
|
320 sym = XCDR (value)) |
a14111a2a100
Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents:
25000
diff
changeset
|
321 if (EQ (property_value (interval->plist, XCAR (sym)), Qunbound)) |
4076
9fd5ecacfbbb
(Qinsert_in_front_hooks, Qinsert_behind_hooks): New vars.
Richard M. Stallman <rms@gnu.org>
parents:
4007
diff
changeset
|
322 { |
9fd5ecacfbbb
(Qinsert_in_front_hooks, Qinsert_behind_hooks): New vars.
Richard M. Stallman <rms@gnu.org>
parents:
4007
diff
changeset
|
323 record_property_change (interval->position, LENGTH (interval), |
25645
a14111a2a100
Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents:
25000
diff
changeset
|
324 XCAR (sym), Qnil, |
4076
9fd5ecacfbbb
(Qinsert_in_front_hooks, Qinsert_behind_hooks): New vars.
Richard M. Stallman <rms@gnu.org>
parents:
4007
diff
changeset
|
325 object); |
9fd5ecacfbbb
(Qinsert_in_front_hooks, Qinsert_behind_hooks): New vars.
Richard M. Stallman <rms@gnu.org>
parents:
4007
diff
changeset
|
326 } |
1965
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
327 } |
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
328 |
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
329 /* Store new properties. */ |
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
330 interval->plist = Fcopy_sequence (properties); |
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
331 } |
1029 | 332 |
333 /* Add the properties of PLIST to the interval I, or set | |
334 the value of I's property to the value of the property on PLIST | |
335 if they are different. | |
336 | |
1965
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
337 OBJECT should be the string or buffer the interval is in. |
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
338 |
1029 | 339 Return nonzero if this changes I (i.e., if any members of PLIST |
340 are actually added to I's plist) */ | |
341 | |
1965
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
342 static int |
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
343 add_properties (plist, i, object) |
1029 | 344 Lisp_Object plist; |
345 INTERVAL i; | |
1965
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
346 Lisp_Object object; |
1029 | 347 { |
10159
1299d37b51bb
(add_properties): Add gcpro's.
Richard M. Stallman <rms@gnu.org>
parents:
9945
diff
changeset
|
348 Lisp_Object tail1, tail2, sym1, val1; |
1029 | 349 register int changed = 0; |
350 register int found; | |
10159
1299d37b51bb
(add_properties): Add gcpro's.
Richard M. Stallman <rms@gnu.org>
parents:
9945
diff
changeset
|
351 struct gcpro gcpro1, gcpro2, gcpro3; |
1299d37b51bb
(add_properties): Add gcpro's.
Richard M. Stallman <rms@gnu.org>
parents:
9945
diff
changeset
|
352 |
1299d37b51bb
(add_properties): Add gcpro's.
Richard M. Stallman <rms@gnu.org>
parents:
9945
diff
changeset
|
353 tail1 = plist; |
1299d37b51bb
(add_properties): Add gcpro's.
Richard M. Stallman <rms@gnu.org>
parents:
9945
diff
changeset
|
354 sym1 = Qnil; |
1299d37b51bb
(add_properties): Add gcpro's.
Richard M. Stallman <rms@gnu.org>
parents:
9945
diff
changeset
|
355 val1 = Qnil; |
1299d37b51bb
(add_properties): Add gcpro's.
Richard M. Stallman <rms@gnu.org>
parents:
9945
diff
changeset
|
356 /* No need to protect OBJECT, because we can GC only in the case |
1299d37b51bb
(add_properties): Add gcpro's.
Richard M. Stallman <rms@gnu.org>
parents:
9945
diff
changeset
|
357 where it is a buffer, and live buffers are always protected. |
1299d37b51bb
(add_properties): Add gcpro's.
Richard M. Stallman <rms@gnu.org>
parents:
9945
diff
changeset
|
358 I and its plist are also protected, via OBJECT. */ |
1299d37b51bb
(add_properties): Add gcpro's.
Richard M. Stallman <rms@gnu.org>
parents:
9945
diff
changeset
|
359 GCPRO3 (tail1, sym1, val1); |
1029 | 360 |
17467
98c47e7857f3
Style of comments corrected.
Richard M. Stallman <rms@gnu.org>
parents:
16679
diff
changeset
|
361 /* Go through each element of PLIST. */ |
1029 | 362 for (tail1 = plist; ! NILP (tail1); tail1 = Fcdr (Fcdr (tail1))) |
363 { | |
364 sym1 = Fcar (tail1); | |
365 val1 = Fcar (Fcdr (tail1)); | |
366 found = 0; | |
367 | |
368 /* Go through I's plist, looking for sym1 */ | |
369 for (tail2 = i->plist; ! NILP (tail2); tail2 = Fcdr (Fcdr (tail2))) | |
370 if (EQ (sym1, Fcar (tail2))) | |
371 { | |
10159
1299d37b51bb
(add_properties): Add gcpro's.
Richard M. Stallman <rms@gnu.org>
parents:
9945
diff
changeset
|
372 /* No need to gcpro, because tail2 protects this |
1299d37b51bb
(add_properties): Add gcpro's.
Richard M. Stallman <rms@gnu.org>
parents:
9945
diff
changeset
|
373 and it must be a cons cell (we get an error otherwise). */ |
6516
8278049ee7a7
(add_properties, remove_properties): Use assignment, not initialization.
Karl Heuer <kwzh@gnu.org>
parents:
6064
diff
changeset
|
374 register Lisp_Object this_cdr; |
1029 | 375 |
6516
8278049ee7a7
(add_properties, remove_properties): Use assignment, not initialization.
Karl Heuer <kwzh@gnu.org>
parents:
6064
diff
changeset
|
376 this_cdr = Fcdr (tail2); |
17467
98c47e7857f3
Style of comments corrected.
Richard M. Stallman <rms@gnu.org>
parents:
16679
diff
changeset
|
377 /* Found the property. Now check its value. */ |
1029 | 378 found = 1; |
379 | |
380 /* The properties have the same value on both lists. | |
17467
98c47e7857f3
Style of comments corrected.
Richard M. Stallman <rms@gnu.org>
parents:
16679
diff
changeset
|
381 Continue to the next property. */ |
3998
c0560357c84e
Compare the values of text properties using EQ, not Fequal.
Jim Blandy <jimb@redhat.com>
parents:
3996
diff
changeset
|
382 if (EQ (val1, Fcar (this_cdr))) |
1029 | 383 break; |
384 | |
1965
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
385 /* Record this change in the buffer, for undo purposes. */ |
9109
6e44ddc40153
(validate_interval_range, add_properties, remove_properties,
Karl Heuer <kwzh@gnu.org>
parents:
9071
diff
changeset
|
386 if (BUFFERP (object)) |
1965
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
387 { |
4076
9fd5ecacfbbb
(Qinsert_in_front_hooks, Qinsert_behind_hooks): New vars.
Richard M. Stallman <rms@gnu.org>
parents:
4007
diff
changeset
|
388 record_property_change (i->position, LENGTH (i), |
9fd5ecacfbbb
(Qinsert_in_front_hooks, Qinsert_behind_hooks): New vars.
Richard M. Stallman <rms@gnu.org>
parents:
4007
diff
changeset
|
389 sym1, Fcar (this_cdr), object); |
1965
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
390 } |
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
391 |
1029 | 392 /* I's property has a different value -- change it */ |
393 Fsetcar (this_cdr, val1); | |
394 changed++; | |
395 break; | |
396 } | |
397 | |
398 if (! found) | |
399 { | |
1965
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
400 /* Record this change in the buffer, for undo purposes. */ |
9109
6e44ddc40153
(validate_interval_range, add_properties, remove_properties,
Karl Heuer <kwzh@gnu.org>
parents:
9071
diff
changeset
|
401 if (BUFFERP (object)) |
1965
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
402 { |
4076
9fd5ecacfbbb
(Qinsert_in_front_hooks, Qinsert_behind_hooks): New vars.
Richard M. Stallman <rms@gnu.org>
parents:
4007
diff
changeset
|
403 record_property_change (i->position, LENGTH (i), |
9fd5ecacfbbb
(Qinsert_in_front_hooks, Qinsert_behind_hooks): New vars.
Richard M. Stallman <rms@gnu.org>
parents:
4007
diff
changeset
|
404 sym1, Qnil, object); |
1965
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
405 } |
1029 | 406 i->plist = Fcons (sym1, Fcons (val1, i->plist)); |
407 changed++; | |
408 } | |
409 } | |
410 | |
10159
1299d37b51bb
(add_properties): Add gcpro's.
Richard M. Stallman <rms@gnu.org>
parents:
9945
diff
changeset
|
411 UNGCPRO; |
1299d37b51bb
(add_properties): Add gcpro's.
Richard M. Stallman <rms@gnu.org>
parents:
9945
diff
changeset
|
412 |
1029 | 413 return changed; |
414 } | |
415 | |
416 /* For any members of PLIST which are properties of I, remove them | |
1965
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
417 from I's plist. |
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
418 OBJECT is the string or buffer containing I. */ |
1029 | 419 |
1965
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
420 static int |
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
421 remove_properties (plist, i, object) |
1029 | 422 Lisp_Object plist; |
423 INTERVAL i; | |
1965
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
424 Lisp_Object object; |
1029 | 425 { |
6516
8278049ee7a7
(add_properties, remove_properties): Use assignment, not initialization.
Karl Heuer <kwzh@gnu.org>
parents:
6064
diff
changeset
|
426 register Lisp_Object tail1, tail2, sym, current_plist; |
1029 | 427 register int changed = 0; |
428 | |
6516
8278049ee7a7
(add_properties, remove_properties): Use assignment, not initialization.
Karl Heuer <kwzh@gnu.org>
parents:
6064
diff
changeset
|
429 current_plist = i->plist; |
17467
98c47e7857f3
Style of comments corrected.
Richard M. Stallman <rms@gnu.org>
parents:
16679
diff
changeset
|
430 /* Go through each element of plist. */ |
1029 | 431 for (tail1 = plist; ! NILP (tail1); tail1 = Fcdr (Fcdr (tail1))) |
432 { | |
433 sym = Fcar (tail1); | |
434 | |
435 /* First, remove the symbol if its at the head of the list */ | |
436 while (! NILP (current_plist) && EQ (sym, Fcar (current_plist))) | |
437 { | |
9109
6e44ddc40153
(validate_interval_range, add_properties, remove_properties,
Karl Heuer <kwzh@gnu.org>
parents:
9071
diff
changeset
|
438 if (BUFFERP (object)) |
1965
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
439 { |
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
440 record_property_change (i->position, LENGTH (i), |
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
441 sym, Fcar (Fcdr (current_plist)), |
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
442 object); |
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
443 } |
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
444 |
1029 | 445 current_plist = Fcdr (Fcdr (current_plist)); |
446 changed++; | |
447 } | |
448 | |
449 /* Go through i's plist, looking for sym */ | |
450 tail2 = current_plist; | |
451 while (! NILP (tail2)) | |
452 { | |
6516
8278049ee7a7
(add_properties, remove_properties): Use assignment, not initialization.
Karl Heuer <kwzh@gnu.org>
parents:
6064
diff
changeset
|
453 register Lisp_Object this; |
8278049ee7a7
(add_properties, remove_properties): Use assignment, not initialization.
Karl Heuer <kwzh@gnu.org>
parents:
6064
diff
changeset
|
454 this = Fcdr (Fcdr (tail2)); |
1029 | 455 if (EQ (sym, Fcar (this))) |
456 { | |
9109
6e44ddc40153
(validate_interval_range, add_properties, remove_properties,
Karl Heuer <kwzh@gnu.org>
parents:
9071
diff
changeset
|
457 if (BUFFERP (object)) |
1965
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
458 { |
4076
9fd5ecacfbbb
(Qinsert_in_front_hooks, Qinsert_behind_hooks): New vars.
Richard M. Stallman <rms@gnu.org>
parents:
4007
diff
changeset
|
459 record_property_change (i->position, LENGTH (i), |
9fd5ecacfbbb
(Qinsert_in_front_hooks, Qinsert_behind_hooks): New vars.
Richard M. Stallman <rms@gnu.org>
parents:
4007
diff
changeset
|
460 sym, Fcar (Fcdr (this)), object); |
1965
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
461 } |
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
462 |
1029 | 463 Fsetcdr (Fcdr (tail2), Fcdr (Fcdr (this))); |
464 changed++; | |
465 } | |
466 tail2 = this; | |
467 } | |
468 } | |
469 | |
470 if (changed) | |
471 i->plist = current_plist; | |
472 return changed; | |
473 } | |
474 | |
1965
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
475 #if 0 |
1029 | 476 /* Remove all properties from interval I. Return non-zero |
17467
98c47e7857f3
Style of comments corrected.
Richard M. Stallman <rms@gnu.org>
parents:
16679
diff
changeset
|
477 if this changes the interval. */ |
1029 | 478 |
479 static INLINE int | |
480 erase_properties (i) | |
481 INTERVAL i; | |
482 { | |
483 if (NILP (i->plist)) | |
484 return 0; | |
485 | |
486 i->plist = Qnil; | |
487 return 1; | |
488 } | |
1965
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
489 #endif |
1029 | 490 |
22344
2ec50b4767ed
Handle the new convention that `position' values
Karl Heuer <kwzh@gnu.org>
parents:
22280
diff
changeset
|
491 /* Returns the interval of POSITION in OBJECT. |
17467
98c47e7857f3
Style of comments corrected.
Richard M. Stallman <rms@gnu.org>
parents:
16679
diff
changeset
|
492 POSITION is BEG-based. */ |
98c47e7857f3
Style of comments corrected.
Richard M. Stallman <rms@gnu.org>
parents:
16679
diff
changeset
|
493 |
98c47e7857f3
Style of comments corrected.
Richard M. Stallman <rms@gnu.org>
parents:
16679
diff
changeset
|
494 INTERVAL |
98c47e7857f3
Style of comments corrected.
Richard M. Stallman <rms@gnu.org>
parents:
16679
diff
changeset
|
495 interval_of (position, object) |
98c47e7857f3
Style of comments corrected.
Richard M. Stallman <rms@gnu.org>
parents:
16679
diff
changeset
|
496 int position; |
98c47e7857f3
Style of comments corrected.
Richard M. Stallman <rms@gnu.org>
parents:
16679
diff
changeset
|
497 Lisp_Object object; |
98c47e7857f3
Style of comments corrected.
Richard M. Stallman <rms@gnu.org>
parents:
16679
diff
changeset
|
498 { |
98c47e7857f3
Style of comments corrected.
Richard M. Stallman <rms@gnu.org>
parents:
16679
diff
changeset
|
499 register INTERVAL i; |
98c47e7857f3
Style of comments corrected.
Richard M. Stallman <rms@gnu.org>
parents:
16679
diff
changeset
|
500 int beg, end; |
98c47e7857f3
Style of comments corrected.
Richard M. Stallman <rms@gnu.org>
parents:
16679
diff
changeset
|
501 |
98c47e7857f3
Style of comments corrected.
Richard M. Stallman <rms@gnu.org>
parents:
16679
diff
changeset
|
502 if (NILP (object)) |
98c47e7857f3
Style of comments corrected.
Richard M. Stallman <rms@gnu.org>
parents:
16679
diff
changeset
|
503 XSETBUFFER (object, current_buffer); |
20955 | 504 else if (EQ (object, Qt)) |
505 return NULL_INTERVAL; | |
17467
98c47e7857f3
Style of comments corrected.
Richard M. Stallman <rms@gnu.org>
parents:
16679
diff
changeset
|
506 |
98c47e7857f3
Style of comments corrected.
Richard M. Stallman <rms@gnu.org>
parents:
16679
diff
changeset
|
507 CHECK_STRING_OR_BUFFER (object, 0); |
98c47e7857f3
Style of comments corrected.
Richard M. Stallman <rms@gnu.org>
parents:
16679
diff
changeset
|
508 |
98c47e7857f3
Style of comments corrected.
Richard M. Stallman <rms@gnu.org>
parents:
16679
diff
changeset
|
509 if (BUFFERP (object)) |
98c47e7857f3
Style of comments corrected.
Richard M. Stallman <rms@gnu.org>
parents:
16679
diff
changeset
|
510 { |
98c47e7857f3
Style of comments corrected.
Richard M. Stallman <rms@gnu.org>
parents:
16679
diff
changeset
|
511 register struct buffer *b = XBUFFER (object); |
98c47e7857f3
Style of comments corrected.
Richard M. Stallman <rms@gnu.org>
parents:
16679
diff
changeset
|
512 |
98c47e7857f3
Style of comments corrected.
Richard M. Stallman <rms@gnu.org>
parents:
16679
diff
changeset
|
513 beg = BUF_BEGV (b); |
98c47e7857f3
Style of comments corrected.
Richard M. Stallman <rms@gnu.org>
parents:
16679
diff
changeset
|
514 end = BUF_ZV (b); |
98c47e7857f3
Style of comments corrected.
Richard M. Stallman <rms@gnu.org>
parents:
16679
diff
changeset
|
515 i = BUF_INTERVALS (b); |
98c47e7857f3
Style of comments corrected.
Richard M. Stallman <rms@gnu.org>
parents:
16679
diff
changeset
|
516 } |
98c47e7857f3
Style of comments corrected.
Richard M. Stallman <rms@gnu.org>
parents:
16679
diff
changeset
|
517 else |
98c47e7857f3
Style of comments corrected.
Richard M. Stallman <rms@gnu.org>
parents:
16679
diff
changeset
|
518 { |
98c47e7857f3
Style of comments corrected.
Richard M. Stallman <rms@gnu.org>
parents:
16679
diff
changeset
|
519 register struct Lisp_String *s = XSTRING (object); |
98c47e7857f3
Style of comments corrected.
Richard M. Stallman <rms@gnu.org>
parents:
16679
diff
changeset
|
520 |
22344
2ec50b4767ed
Handle the new convention that `position' values
Karl Heuer <kwzh@gnu.org>
parents:
22280
diff
changeset
|
521 beg = 0; |
2ec50b4767ed
Handle the new convention that `position' values
Karl Heuer <kwzh@gnu.org>
parents:
22280
diff
changeset
|
522 end = s->size; |
17467
98c47e7857f3
Style of comments corrected.
Richard M. Stallman <rms@gnu.org>
parents:
16679
diff
changeset
|
523 i = s->intervals; |
98c47e7857f3
Style of comments corrected.
Richard M. Stallman <rms@gnu.org>
parents:
16679
diff
changeset
|
524 } |
98c47e7857f3
Style of comments corrected.
Richard M. Stallman <rms@gnu.org>
parents:
16679
diff
changeset
|
525 |
98c47e7857f3
Style of comments corrected.
Richard M. Stallman <rms@gnu.org>
parents:
16679
diff
changeset
|
526 if (!(beg <= position && position <= end)) |
18736
e5e6647d4883
(interval_of): Convert args_out_of_range arguments to Lisp_Integer.
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
527 args_out_of_range (make_number (position), make_number (position)); |
17467
98c47e7857f3
Style of comments corrected.
Richard M. Stallman <rms@gnu.org>
parents:
16679
diff
changeset
|
528 if (beg == end || NULL_INTERVAL_P (i)) |
98c47e7857f3
Style of comments corrected.
Richard M. Stallman <rms@gnu.org>
parents:
16679
diff
changeset
|
529 return NULL_INTERVAL; |
98c47e7857f3
Style of comments corrected.
Richard M. Stallman <rms@gnu.org>
parents:
16679
diff
changeset
|
530 |
98c47e7857f3
Style of comments corrected.
Richard M. Stallman <rms@gnu.org>
parents:
16679
diff
changeset
|
531 return find_interval (i, position); |
98c47e7857f3
Style of comments corrected.
Richard M. Stallman <rms@gnu.org>
parents:
16679
diff
changeset
|
532 } |
98c47e7857f3
Style of comments corrected.
Richard M. Stallman <rms@gnu.org>
parents:
16679
diff
changeset
|
533 |
1029 | 534 DEFUN ("text-properties-at", Ftext_properties_at, |
535 Stext_properties_at, 1, 2, 0, | |
20522
4409f95651d1
(Ftext_properties_at): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
18736
diff
changeset
|
536 "Return the list of properties of the character at POSITION in OBJECT.\n\ |
4409f95651d1
(Ftext_properties_at): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
18736
diff
changeset
|
537 OBJECT is the string or buffer to look for the properties in;\n\ |
4409f95651d1
(Ftext_properties_at): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
18736
diff
changeset
|
538 nil means the current buffer.\n\ |
1965
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
539 If POSITION is at the end of OBJECT, the value is nil.") |
14088
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
540 (position, object) |
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
541 Lisp_Object position, object; |
1029 | 542 { |
543 register INTERVAL i; | |
544 | |
545 if (NILP (object)) | |
9280
4b238c43e59f
(Ftext_properties_at, Fget_char_property, Fnext_property_change,
Karl Heuer <kwzh@gnu.org>
parents:
9109
diff
changeset
|
546 XSETBUFFER (object, current_buffer); |
1029 | 547 |
14088
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
548 i = validate_interval_range (object, &position, &position, soft); |
1029 | 549 if (NULL_INTERVAL_P (i)) |
550 return Qnil; | |
14088
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
551 /* If POSITION is at the end of the interval, |
1965
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
552 it means it's the end of OBJECT. |
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
553 There are no properties at the very end, |
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
554 since no character follows. */ |
14088
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
555 if (XINT (position) == LENGTH (i) + i->position) |
1965
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
556 return Qnil; |
1029 | 557 |
558 return i->plist; | |
559 } | |
560 | |
1857
9d65dfc7bdb7
(Fadd_text_properties): Put OBJECT arg last. Make it optional.
Richard M. Stallman <rms@gnu.org>
parents:
1715
diff
changeset
|
561 DEFUN ("get-text-property", Fget_text_property, Sget_text_property, 2, 3, 0, |
14088
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
562 "Return the value of POSITION's property PROP, in OBJECT.\n\ |
1965
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
563 OBJECT is optional and defaults to the current buffer.\n\ |
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
564 If POSITION is at the end of OBJECT, the value is nil.") |
14088
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
565 (position, prop, object) |
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
566 Lisp_Object position, object; |
8271
e8556db1b7f3
(Fget_text_property): Simplify using Ftext_properties_at.
Richard M. Stallman <rms@gnu.org>
parents:
7773
diff
changeset
|
567 Lisp_Object prop; |
1857
9d65dfc7bdb7
(Fadd_text_properties): Put OBJECT arg last. Make it optional.
Richard M. Stallman <rms@gnu.org>
parents:
1715
diff
changeset
|
568 { |
14088
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
569 return textget (Ftext_properties_at (position, object), prop); |
1857
9d65dfc7bdb7
(Fadd_text_properties): Put OBJECT arg last. Make it optional.
Richard M. Stallman <rms@gnu.org>
parents:
1715
diff
changeset
|
570 } |
9d65dfc7bdb7
(Fadd_text_properties): Put OBJECT arg last. Make it optional.
Richard M. Stallman <rms@gnu.org>
parents:
1715
diff
changeset
|
571 |
32849
e1dec7e5a57c
(get_char_property_and_overlay): New function.
Miles Bader <miles@gnu.org>
parents:
30699
diff
changeset
|
572 /* Return the value of POSITION's property PROP, in OBJECT. |
e1dec7e5a57c
(get_char_property_and_overlay): New function.
Miles Bader <miles@gnu.org>
parents:
30699
diff
changeset
|
573 OBJECT is optional and defaults to the current buffer. |
e1dec7e5a57c
(get_char_property_and_overlay): New function.
Miles Bader <miles@gnu.org>
parents:
30699
diff
changeset
|
574 If OVERLAY is non-0, then in the case that the returned property is from |
e1dec7e5a57c
(get_char_property_and_overlay): New function.
Miles Bader <miles@gnu.org>
parents:
30699
diff
changeset
|
575 an overlay, the overlay found is returned in *OVERLAY, otherwise nil is |
e1dec7e5a57c
(get_char_property_and_overlay): New function.
Miles Bader <miles@gnu.org>
parents:
30699
diff
changeset
|
576 returned in *OVERLAY. |
e1dec7e5a57c
(get_char_property_and_overlay): New function.
Miles Bader <miles@gnu.org>
parents:
30699
diff
changeset
|
577 If POSITION is at the end of OBJECT, the value is nil. |
e1dec7e5a57c
(get_char_property_and_overlay): New function.
Miles Bader <miles@gnu.org>
parents:
30699
diff
changeset
|
578 If OBJECT is a buffer, then overlay properties are considered as well as |
e1dec7e5a57c
(get_char_property_and_overlay): New function.
Miles Bader <miles@gnu.org>
parents:
30699
diff
changeset
|
579 text properties. |
e1dec7e5a57c
(get_char_property_and_overlay): New function.
Miles Bader <miles@gnu.org>
parents:
30699
diff
changeset
|
580 If OBJECT is a window, then that window's buffer is used, but |
e1dec7e5a57c
(get_char_property_and_overlay): New function.
Miles Bader <miles@gnu.org>
parents:
30699
diff
changeset
|
581 window-specific overlays are considered only if they are associated |
e1dec7e5a57c
(get_char_property_and_overlay): New function.
Miles Bader <miles@gnu.org>
parents:
30699
diff
changeset
|
582 with OBJECT. */ |
e1dec7e5a57c
(get_char_property_and_overlay): New function.
Miles Bader <miles@gnu.org>
parents:
30699
diff
changeset
|
583 Lisp_Object |
e1dec7e5a57c
(get_char_property_and_overlay): New function.
Miles Bader <miles@gnu.org>
parents:
30699
diff
changeset
|
584 get_char_property_and_overlay (position, prop, object, overlay) |
14088
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
585 Lisp_Object position, object; |
6063
233fffcfb6c8
(Fget_char_property): New function.
Karl Heuer <kwzh@gnu.org>
parents:
5646
diff
changeset
|
586 register Lisp_Object prop; |
32849
e1dec7e5a57c
(get_char_property_and_overlay): New function.
Miles Bader <miles@gnu.org>
parents:
30699
diff
changeset
|
587 Lisp_Object *overlay; |
6063
233fffcfb6c8
(Fget_char_property): New function.
Karl Heuer <kwzh@gnu.org>
parents:
5646
diff
changeset
|
588 { |
233fffcfb6c8
(Fget_char_property): New function.
Karl Heuer <kwzh@gnu.org>
parents:
5646
diff
changeset
|
589 struct window *w = 0; |
233fffcfb6c8
(Fget_char_property): New function.
Karl Heuer <kwzh@gnu.org>
parents:
5646
diff
changeset
|
590 |
14088
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
591 CHECK_NUMBER_COERCE_MARKER (position, 0); |
6063
233fffcfb6c8
(Fget_char_property): New function.
Karl Heuer <kwzh@gnu.org>
parents:
5646
diff
changeset
|
592 |
233fffcfb6c8
(Fget_char_property): New function.
Karl Heuer <kwzh@gnu.org>
parents:
5646
diff
changeset
|
593 if (NILP (object)) |
9280
4b238c43e59f
(Ftext_properties_at, Fget_char_property, Fnext_property_change,
Karl Heuer <kwzh@gnu.org>
parents:
9109
diff
changeset
|
594 XSETBUFFER (object, current_buffer); |
6063
233fffcfb6c8
(Fget_char_property): New function.
Karl Heuer <kwzh@gnu.org>
parents:
5646
diff
changeset
|
595 |
233fffcfb6c8
(Fget_char_property): New function.
Karl Heuer <kwzh@gnu.org>
parents:
5646
diff
changeset
|
596 if (WINDOWP (object)) |
233fffcfb6c8
(Fget_char_property): New function.
Karl Heuer <kwzh@gnu.org>
parents:
5646
diff
changeset
|
597 { |
233fffcfb6c8
(Fget_char_property): New function.
Karl Heuer <kwzh@gnu.org>
parents:
5646
diff
changeset
|
598 w = XWINDOW (object); |
8907
f7de8b4cb1b8
(validate_interval_range, property_value, Fget_char_property,
Karl Heuer <kwzh@gnu.org>
parents:
8856
diff
changeset
|
599 object = w->buffer; |
6063
233fffcfb6c8
(Fget_char_property): New function.
Karl Heuer <kwzh@gnu.org>
parents:
5646
diff
changeset
|
600 } |
233fffcfb6c8
(Fget_char_property): New function.
Karl Heuer <kwzh@gnu.org>
parents:
5646
diff
changeset
|
601 if (BUFFERP (object)) |
233fffcfb6c8
(Fget_char_property): New function.
Karl Heuer <kwzh@gnu.org>
parents:
5646
diff
changeset
|
602 { |
14088
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
603 int posn = XINT (position); |
6063
233fffcfb6c8
(Fget_char_property): New function.
Karl Heuer <kwzh@gnu.org>
parents:
5646
diff
changeset
|
604 int noverlays; |
233fffcfb6c8
(Fget_char_property): New function.
Karl Heuer <kwzh@gnu.org>
parents:
5646
diff
changeset
|
605 Lisp_Object *overlay_vec, tem; |
233fffcfb6c8
(Fget_char_property): New function.
Karl Heuer <kwzh@gnu.org>
parents:
5646
diff
changeset
|
606 int next_overlay; |
233fffcfb6c8
(Fget_char_property): New function.
Karl Heuer <kwzh@gnu.org>
parents:
5646
diff
changeset
|
607 int len; |
12641
aadec66110fd
(Fget_char_property): If OBJECT is non-current buffer,
Richard M. Stallman <rms@gnu.org>
parents:
11131
diff
changeset
|
608 struct buffer *obuf = current_buffer; |
aadec66110fd
(Fget_char_property): If OBJECT is non-current buffer,
Richard M. Stallman <rms@gnu.org>
parents:
11131
diff
changeset
|
609 |
aadec66110fd
(Fget_char_property): If OBJECT is non-current buffer,
Richard M. Stallman <rms@gnu.org>
parents:
11131
diff
changeset
|
610 set_buffer_temp (XBUFFER (object)); |
6063
233fffcfb6c8
(Fget_char_property): New function.
Karl Heuer <kwzh@gnu.org>
parents:
5646
diff
changeset
|
611 |
233fffcfb6c8
(Fget_char_property): New function.
Karl Heuer <kwzh@gnu.org>
parents:
5646
diff
changeset
|
612 /* First try with room for 40 overlays. */ |
233fffcfb6c8
(Fget_char_property): New function.
Karl Heuer <kwzh@gnu.org>
parents:
5646
diff
changeset
|
613 len = 40; |
233fffcfb6c8
(Fget_char_property): New function.
Karl Heuer <kwzh@gnu.org>
parents:
5646
diff
changeset
|
614 overlay_vec = (Lisp_Object *) alloca (len * sizeof (Lisp_Object)); |
233fffcfb6c8
(Fget_char_property): New function.
Karl Heuer <kwzh@gnu.org>
parents:
5646
diff
changeset
|
615 |
8962
722763fed8ce
(Fget_char_property): Pass new arg to overlays_at.
Richard M. Stallman <rms@gnu.org>
parents:
8907
diff
changeset
|
616 noverlays = overlays_at (posn, 0, &overlay_vec, &len, |
30699
f886557e4b2a
(Fget_char_property): Update call to overlays_at.
Miles Bader <miles@gnu.org>
parents:
30678
diff
changeset
|
617 &next_overlay, NULL, 0); |
6063
233fffcfb6c8
(Fget_char_property): New function.
Karl Heuer <kwzh@gnu.org>
parents:
5646
diff
changeset
|
618 |
233fffcfb6c8
(Fget_char_property): New function.
Karl Heuer <kwzh@gnu.org>
parents:
5646
diff
changeset
|
619 /* If there are more than 40, |
233fffcfb6c8
(Fget_char_property): New function.
Karl Heuer <kwzh@gnu.org>
parents:
5646
diff
changeset
|
620 make enough space for all, and try again. */ |
233fffcfb6c8
(Fget_char_property): New function.
Karl Heuer <kwzh@gnu.org>
parents:
5646
diff
changeset
|
621 if (noverlays > len) |
233fffcfb6c8
(Fget_char_property): New function.
Karl Heuer <kwzh@gnu.org>
parents:
5646
diff
changeset
|
622 { |
233fffcfb6c8
(Fget_char_property): New function.
Karl Heuer <kwzh@gnu.org>
parents:
5646
diff
changeset
|
623 len = noverlays; |
233fffcfb6c8
(Fget_char_property): New function.
Karl Heuer <kwzh@gnu.org>
parents:
5646
diff
changeset
|
624 overlay_vec = (Lisp_Object *) alloca (len * sizeof (Lisp_Object)); |
8962
722763fed8ce
(Fget_char_property): Pass new arg to overlays_at.
Richard M. Stallman <rms@gnu.org>
parents:
8907
diff
changeset
|
625 noverlays = overlays_at (posn, 0, &overlay_vec, &len, |
30699
f886557e4b2a
(Fget_char_property): Update call to overlays_at.
Miles Bader <miles@gnu.org>
parents:
30678
diff
changeset
|
626 &next_overlay, NULL, 0); |
6063
233fffcfb6c8
(Fget_char_property): New function.
Karl Heuer <kwzh@gnu.org>
parents:
5646
diff
changeset
|
627 } |
233fffcfb6c8
(Fget_char_property): New function.
Karl Heuer <kwzh@gnu.org>
parents:
5646
diff
changeset
|
628 noverlays = sort_overlays (overlay_vec, noverlays, w); |
233fffcfb6c8
(Fget_char_property): New function.
Karl Heuer <kwzh@gnu.org>
parents:
5646
diff
changeset
|
629 |
12641
aadec66110fd
(Fget_char_property): If OBJECT is non-current buffer,
Richard M. Stallman <rms@gnu.org>
parents:
11131
diff
changeset
|
630 set_buffer_temp (obuf); |
aadec66110fd
(Fget_char_property): If OBJECT is non-current buffer,
Richard M. Stallman <rms@gnu.org>
parents:
11131
diff
changeset
|
631 |
6063
233fffcfb6c8
(Fget_char_property): New function.
Karl Heuer <kwzh@gnu.org>
parents:
5646
diff
changeset
|
632 /* Now check the overlays in order of decreasing priority. */ |
233fffcfb6c8
(Fget_char_property): New function.
Karl Heuer <kwzh@gnu.org>
parents:
5646
diff
changeset
|
633 while (--noverlays >= 0) |
233fffcfb6c8
(Fget_char_property): New function.
Karl Heuer <kwzh@gnu.org>
parents:
5646
diff
changeset
|
634 { |
233fffcfb6c8
(Fget_char_property): New function.
Karl Heuer <kwzh@gnu.org>
parents:
5646
diff
changeset
|
635 tem = Foverlay_get (overlay_vec[noverlays], prop); |
233fffcfb6c8
(Fget_char_property): New function.
Karl Heuer <kwzh@gnu.org>
parents:
5646
diff
changeset
|
636 if (!NILP (tem)) |
32849
e1dec7e5a57c
(get_char_property_and_overlay): New function.
Miles Bader <miles@gnu.org>
parents:
30699
diff
changeset
|
637 { |
e1dec7e5a57c
(get_char_property_and_overlay): New function.
Miles Bader <miles@gnu.org>
parents:
30699
diff
changeset
|
638 if (overlay) |
e1dec7e5a57c
(get_char_property_and_overlay): New function.
Miles Bader <miles@gnu.org>
parents:
30699
diff
changeset
|
639 /* Return the overlay we got the property from. */ |
e1dec7e5a57c
(get_char_property_and_overlay): New function.
Miles Bader <miles@gnu.org>
parents:
30699
diff
changeset
|
640 *overlay = overlay_vec[noverlays]; |
e1dec7e5a57c
(get_char_property_and_overlay): New function.
Miles Bader <miles@gnu.org>
parents:
30699
diff
changeset
|
641 return tem; |
e1dec7e5a57c
(get_char_property_and_overlay): New function.
Miles Bader <miles@gnu.org>
parents:
30699
diff
changeset
|
642 } |
6063
233fffcfb6c8
(Fget_char_property): New function.
Karl Heuer <kwzh@gnu.org>
parents:
5646
diff
changeset
|
643 } |
233fffcfb6c8
(Fget_char_property): New function.
Karl Heuer <kwzh@gnu.org>
parents:
5646
diff
changeset
|
644 } |
32849
e1dec7e5a57c
(get_char_property_and_overlay): New function.
Miles Bader <miles@gnu.org>
parents:
30699
diff
changeset
|
645 |
e1dec7e5a57c
(get_char_property_and_overlay): New function.
Miles Bader <miles@gnu.org>
parents:
30699
diff
changeset
|
646 if (overlay) |
e1dec7e5a57c
(get_char_property_and_overlay): New function.
Miles Bader <miles@gnu.org>
parents:
30699
diff
changeset
|
647 /* Indicate that the return value is not from an overlay. */ |
e1dec7e5a57c
(get_char_property_and_overlay): New function.
Miles Bader <miles@gnu.org>
parents:
30699
diff
changeset
|
648 *overlay = Qnil; |
e1dec7e5a57c
(get_char_property_and_overlay): New function.
Miles Bader <miles@gnu.org>
parents:
30699
diff
changeset
|
649 |
6063
233fffcfb6c8
(Fget_char_property): New function.
Karl Heuer <kwzh@gnu.org>
parents:
5646
diff
changeset
|
650 /* Not a buffer, or no appropriate overlay, so fall through to the |
233fffcfb6c8
(Fget_char_property): New function.
Karl Heuer <kwzh@gnu.org>
parents:
5646
diff
changeset
|
651 simpler case. */ |
32849
e1dec7e5a57c
(get_char_property_and_overlay): New function.
Miles Bader <miles@gnu.org>
parents:
30699
diff
changeset
|
652 return Fget_text_property (position, prop, object); |
e1dec7e5a57c
(get_char_property_and_overlay): New function.
Miles Bader <miles@gnu.org>
parents:
30699
diff
changeset
|
653 } |
e1dec7e5a57c
(get_char_property_and_overlay): New function.
Miles Bader <miles@gnu.org>
parents:
30699
diff
changeset
|
654 |
e1dec7e5a57c
(get_char_property_and_overlay): New function.
Miles Bader <miles@gnu.org>
parents:
30699
diff
changeset
|
655 DEFUN ("get-char-property", Fget_char_property, Sget_char_property, 2, 3, 0, |
e1dec7e5a57c
(get_char_property_and_overlay): New function.
Miles Bader <miles@gnu.org>
parents:
30699
diff
changeset
|
656 "Return the value of POSITION's property PROP, in OBJECT.\n\ |
e1dec7e5a57c
(get_char_property_and_overlay): New function.
Miles Bader <miles@gnu.org>
parents:
30699
diff
changeset
|
657 OBJECT is optional and defaults to the current buffer.\n\ |
e1dec7e5a57c
(get_char_property_and_overlay): New function.
Miles Bader <miles@gnu.org>
parents:
30699
diff
changeset
|
658 If POSITION is at the end of OBJECT, the value is nil.\n\ |
e1dec7e5a57c
(get_char_property_and_overlay): New function.
Miles Bader <miles@gnu.org>
parents:
30699
diff
changeset
|
659 If OBJECT is a buffer, then overlay properties are considered as well as\n\ |
e1dec7e5a57c
(get_char_property_and_overlay): New function.
Miles Bader <miles@gnu.org>
parents:
30699
diff
changeset
|
660 text properties.\n\ |
e1dec7e5a57c
(get_char_property_and_overlay): New function.
Miles Bader <miles@gnu.org>
parents:
30699
diff
changeset
|
661 If OBJECT is a window, then that window's buffer is used, but window-specific\n\ |
e1dec7e5a57c
(get_char_property_and_overlay): New function.
Miles Bader <miles@gnu.org>
parents:
30699
diff
changeset
|
662 overlays are considered only if they are associated with OBJECT.") |
e1dec7e5a57c
(get_char_property_and_overlay): New function.
Miles Bader <miles@gnu.org>
parents:
30699
diff
changeset
|
663 (position, prop, object) |
e1dec7e5a57c
(get_char_property_and_overlay): New function.
Miles Bader <miles@gnu.org>
parents:
30699
diff
changeset
|
664 Lisp_Object position, object; |
e1dec7e5a57c
(get_char_property_and_overlay): New function.
Miles Bader <miles@gnu.org>
parents:
30699
diff
changeset
|
665 register Lisp_Object prop; |
e1dec7e5a57c
(get_char_property_and_overlay): New function.
Miles Bader <miles@gnu.org>
parents:
30699
diff
changeset
|
666 { |
e1dec7e5a57c
(get_char_property_and_overlay): New function.
Miles Bader <miles@gnu.org>
parents:
30699
diff
changeset
|
667 return get_char_property_and_overlay (position, prop, object, 0); |
6063
233fffcfb6c8
(Fget_char_property): New function.
Karl Heuer <kwzh@gnu.org>
parents:
5646
diff
changeset
|
668 } |
16679
38c158927e6f
(Fnext_char_property_change): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16339
diff
changeset
|
669 |
38c158927e6f
(Fnext_char_property_change): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16339
diff
changeset
|
670 DEFUN ("next-char-property-change", Fnext_char_property_change, |
38c158927e6f
(Fnext_char_property_change): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16339
diff
changeset
|
671 Snext_char_property_change, 1, 2, 0, |
38c158927e6f
(Fnext_char_property_change): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16339
diff
changeset
|
672 "Return the position of next text property or overlay change.\n\ |
38c158927e6f
(Fnext_char_property_change): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16339
diff
changeset
|
673 This scans characters forward from POSITION in OBJECT till it finds\n\ |
38c158927e6f
(Fnext_char_property_change): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16339
diff
changeset
|
674 a change in some text property, or the beginning or end of an overlay,\n\ |
38c158927e6f
(Fnext_char_property_change): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16339
diff
changeset
|
675 and returns the position of that.\n\ |
38c158927e6f
(Fnext_char_property_change): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16339
diff
changeset
|
676 If none is found, the function returns (point-max).\n\ |
38c158927e6f
(Fnext_char_property_change): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16339
diff
changeset
|
677 \n\ |
38c158927e6f
(Fnext_char_property_change): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16339
diff
changeset
|
678 If the optional third argument LIMIT is non-nil, don't search\n\ |
38c158927e6f
(Fnext_char_property_change): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16339
diff
changeset
|
679 past position LIMIT; return LIMIT if nothing is found before LIMIT.") |
38c158927e6f
(Fnext_char_property_change): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16339
diff
changeset
|
680 (position, limit) |
38c158927e6f
(Fnext_char_property_change): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16339
diff
changeset
|
681 Lisp_Object position, limit; |
38c158927e6f
(Fnext_char_property_change): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16339
diff
changeset
|
682 { |
38c158927e6f
(Fnext_char_property_change): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16339
diff
changeset
|
683 Lisp_Object temp; |
6063
233fffcfb6c8
(Fget_char_property): New function.
Karl Heuer <kwzh@gnu.org>
parents:
5646
diff
changeset
|
684 |
16679
38c158927e6f
(Fnext_char_property_change): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16339
diff
changeset
|
685 temp = Fnext_overlay_change (position); |
38c158927e6f
(Fnext_char_property_change): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16339
diff
changeset
|
686 if (! NILP (limit)) |
38c158927e6f
(Fnext_char_property_change): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16339
diff
changeset
|
687 { |
38c158927e6f
(Fnext_char_property_change): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16339
diff
changeset
|
688 CHECK_NUMBER (limit, 2); |
38c158927e6f
(Fnext_char_property_change): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16339
diff
changeset
|
689 if (XINT (limit) < XINT (temp)) |
38c158927e6f
(Fnext_char_property_change): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16339
diff
changeset
|
690 temp = limit; |
38c158927e6f
(Fnext_char_property_change): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16339
diff
changeset
|
691 } |
38c158927e6f
(Fnext_char_property_change): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16339
diff
changeset
|
692 return Fnext_property_change (position, Qnil, temp); |
38c158927e6f
(Fnext_char_property_change): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16339
diff
changeset
|
693 } |
38c158927e6f
(Fnext_char_property_change): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16339
diff
changeset
|
694 |
38c158927e6f
(Fnext_char_property_change): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16339
diff
changeset
|
695 DEFUN ("previous-char-property-change", Fprevious_char_property_change, |
38c158927e6f
(Fnext_char_property_change): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16339
diff
changeset
|
696 Sprevious_char_property_change, 1, 2, 0, |
38c158927e6f
(Fnext_char_property_change): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16339
diff
changeset
|
697 "Return the position of previous text property or overlay change.\n\ |
38c158927e6f
(Fnext_char_property_change): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16339
diff
changeset
|
698 Scans characters backward from POSITION in OBJECT till it finds\n\ |
38c158927e6f
(Fnext_char_property_change): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16339
diff
changeset
|
699 a change in some text property, or the beginning or end of an overlay,\n\ |
38c158927e6f
(Fnext_char_property_change): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16339
diff
changeset
|
700 and returns the position of that.\n\ |
38c158927e6f
(Fnext_char_property_change): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16339
diff
changeset
|
701 If none is found, the function returns (point-max).\n\ |
38c158927e6f
(Fnext_char_property_change): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16339
diff
changeset
|
702 \n\ |
38c158927e6f
(Fnext_char_property_change): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16339
diff
changeset
|
703 If the optional third argument LIMIT is non-nil, don't search\n\ |
38c158927e6f
(Fnext_char_property_change): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16339
diff
changeset
|
704 past position LIMIT; return LIMIT if nothing is found before LIMIT.") |
38c158927e6f
(Fnext_char_property_change): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16339
diff
changeset
|
705 (position, limit) |
38c158927e6f
(Fnext_char_property_change): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16339
diff
changeset
|
706 Lisp_Object position, limit; |
38c158927e6f
(Fnext_char_property_change): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16339
diff
changeset
|
707 { |
38c158927e6f
(Fnext_char_property_change): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16339
diff
changeset
|
708 Lisp_Object temp; |
38c158927e6f
(Fnext_char_property_change): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16339
diff
changeset
|
709 |
38c158927e6f
(Fnext_char_property_change): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16339
diff
changeset
|
710 temp = Fprevious_overlay_change (position); |
38c158927e6f
(Fnext_char_property_change): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16339
diff
changeset
|
711 if (! NILP (limit)) |
38c158927e6f
(Fnext_char_property_change): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16339
diff
changeset
|
712 { |
38c158927e6f
(Fnext_char_property_change): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16339
diff
changeset
|
713 CHECK_NUMBER (limit, 2); |
38c158927e6f
(Fnext_char_property_change): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16339
diff
changeset
|
714 if (XINT (limit) > XINT (temp)) |
38c158927e6f
(Fnext_char_property_change): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16339
diff
changeset
|
715 temp = limit; |
38c158927e6f
(Fnext_char_property_change): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16339
diff
changeset
|
716 } |
38c158927e6f
(Fnext_char_property_change): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16339
diff
changeset
|
717 return Fprevious_property_change (position, Qnil, temp); |
38c158927e6f
(Fnext_char_property_change): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16339
diff
changeset
|
718 } |
25819
c2163b0bac24
(next_single_char_property_change): New.
Gerd Moellmann <gerd@gnu.org>
parents:
25772
diff
changeset
|
719 |
c2163b0bac24
(next_single_char_property_change): New.
Gerd Moellmann <gerd@gnu.org>
parents:
25772
diff
changeset
|
720 |
30242
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
721 DEFUN ("next-single-char-property-change", Fnext_single_char_property_change, |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
722 Snext_single_char_property_change, 2, 4, 0, |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
723 "Return the position of next text property or overlay change for a specific property.\n\ |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
724 Scans characters forward from POSITION till it finds\n\ |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
725 a change in the PROP property, then returns the position of the change.\n\ |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
726 The optional third argument OBJECT is the string or buffer to scan.\n\ |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
727 The property values are compared with `eq'.\n\ |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
728 Return nil if the property is constant all the way to the end of OBJECT.\n\ |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
729 If the value is non-nil, it is a position greater than POSITION, never equal.\n\n\ |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
730 If the optional fourth argument LIMIT is non-nil, don't search\n\ |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
731 past position LIMIT; return LIMIT if nothing is found before LIMIT.") |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
732 (position, prop, object, limit) |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
733 Lisp_Object prop, position, object, limit; |
25819
c2163b0bac24
(next_single_char_property_change): New.
Gerd Moellmann <gerd@gnu.org>
parents:
25772
diff
changeset
|
734 { |
c2163b0bac24
(next_single_char_property_change): New.
Gerd Moellmann <gerd@gnu.org>
parents:
25772
diff
changeset
|
735 if (STRINGP (object)) |
c2163b0bac24
(next_single_char_property_change): New.
Gerd Moellmann <gerd@gnu.org>
parents:
25772
diff
changeset
|
736 { |
30242
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
737 position = Fnext_single_property_change (position, prop, object, limit); |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
738 if (NILP (position)) |
25819
c2163b0bac24
(next_single_char_property_change): New.
Gerd Moellmann <gerd@gnu.org>
parents:
25772
diff
changeset
|
739 { |
c2163b0bac24
(next_single_char_property_change): New.
Gerd Moellmann <gerd@gnu.org>
parents:
25772
diff
changeset
|
740 if (NILP (limit)) |
30242
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
741 position = make_number (XSTRING (object)->size); |
25819
c2163b0bac24
(next_single_char_property_change): New.
Gerd Moellmann <gerd@gnu.org>
parents:
25772
diff
changeset
|
742 else |
30242
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
743 position = limit; |
25819
c2163b0bac24
(next_single_char_property_change): New.
Gerd Moellmann <gerd@gnu.org>
parents:
25772
diff
changeset
|
744 } |
c2163b0bac24
(next_single_char_property_change): New.
Gerd Moellmann <gerd@gnu.org>
parents:
25772
diff
changeset
|
745 } |
c2163b0bac24
(next_single_char_property_change): New.
Gerd Moellmann <gerd@gnu.org>
parents:
25772
diff
changeset
|
746 else |
c2163b0bac24
(next_single_char_property_change): New.
Gerd Moellmann <gerd@gnu.org>
parents:
25772
diff
changeset
|
747 { |
c2163b0bac24
(next_single_char_property_change): New.
Gerd Moellmann <gerd@gnu.org>
parents:
25772
diff
changeset
|
748 Lisp_Object initial_value, value; |
c2163b0bac24
(next_single_char_property_change): New.
Gerd Moellmann <gerd@gnu.org>
parents:
25772
diff
changeset
|
749 int count = specpdl_ptr - specpdl; |
c2163b0bac24
(next_single_char_property_change): New.
Gerd Moellmann <gerd@gnu.org>
parents:
25772
diff
changeset
|
750 |
30242
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
751 if (! NILP (object)) |
25819
c2163b0bac24
(next_single_char_property_change): New.
Gerd Moellmann <gerd@gnu.org>
parents:
25772
diff
changeset
|
752 CHECK_BUFFER (object, 0); |
c2163b0bac24
(next_single_char_property_change): New.
Gerd Moellmann <gerd@gnu.org>
parents:
25772
diff
changeset
|
753 |
c2163b0bac24
(next_single_char_property_change): New.
Gerd Moellmann <gerd@gnu.org>
parents:
25772
diff
changeset
|
754 if (BUFFERP (object) && current_buffer != XBUFFER (object)) |
c2163b0bac24
(next_single_char_property_change): New.
Gerd Moellmann <gerd@gnu.org>
parents:
25772
diff
changeset
|
755 { |
c2163b0bac24
(next_single_char_property_change): New.
Gerd Moellmann <gerd@gnu.org>
parents:
25772
diff
changeset
|
756 record_unwind_protect (Fset_buffer, Fcurrent_buffer ()); |
c2163b0bac24
(next_single_char_property_change): New.
Gerd Moellmann <gerd@gnu.org>
parents:
25772
diff
changeset
|
757 Fset_buffer (object); |
c2163b0bac24
(next_single_char_property_change): New.
Gerd Moellmann <gerd@gnu.org>
parents:
25772
diff
changeset
|
758 } |
c2163b0bac24
(next_single_char_property_change): New.
Gerd Moellmann <gerd@gnu.org>
parents:
25772
diff
changeset
|
759 |
30242
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
760 initial_value = Fget_char_property (position, prop, object); |
25819
c2163b0bac24
(next_single_char_property_change): New.
Gerd Moellmann <gerd@gnu.org>
parents:
25772
diff
changeset
|
761 |
30242
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
762 if (NILP (limit)) |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
763 XSETFASTINT (limit, BUF_ZV (current_buffer)); |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
764 else |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
765 CHECK_NUMBER_COERCE_MARKER (limit, 0); |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
766 |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
767 for (;;) |
25819
c2163b0bac24
(next_single_char_property_change): New.
Gerd Moellmann <gerd@gnu.org>
parents:
25772
diff
changeset
|
768 { |
30242
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
769 position = Fnext_char_property_change (position, limit); |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
770 if (XFASTINT (position) >= XFASTINT (limit)) { |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
771 position = limit; |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
772 break; |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
773 } |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
774 |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
775 value = Fget_char_property (position, prop, object); |
25819
c2163b0bac24
(next_single_char_property_change): New.
Gerd Moellmann <gerd@gnu.org>
parents:
25772
diff
changeset
|
776 if (!EQ (value, initial_value)) |
c2163b0bac24
(next_single_char_property_change): New.
Gerd Moellmann <gerd@gnu.org>
parents:
25772
diff
changeset
|
777 break; |
c2163b0bac24
(next_single_char_property_change): New.
Gerd Moellmann <gerd@gnu.org>
parents:
25772
diff
changeset
|
778 } |
c2163b0bac24
(next_single_char_property_change): New.
Gerd Moellmann <gerd@gnu.org>
parents:
25772
diff
changeset
|
779 |
c2163b0bac24
(next_single_char_property_change): New.
Gerd Moellmann <gerd@gnu.org>
parents:
25772
diff
changeset
|
780 unbind_to (count, Qnil); |
c2163b0bac24
(next_single_char_property_change): New.
Gerd Moellmann <gerd@gnu.org>
parents:
25772
diff
changeset
|
781 } |
c2163b0bac24
(next_single_char_property_change): New.
Gerd Moellmann <gerd@gnu.org>
parents:
25772
diff
changeset
|
782 |
30242
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
783 return position; |
25819
c2163b0bac24
(next_single_char_property_change): New.
Gerd Moellmann <gerd@gnu.org>
parents:
25772
diff
changeset
|
784 } |
c2163b0bac24
(next_single_char_property_change): New.
Gerd Moellmann <gerd@gnu.org>
parents:
25772
diff
changeset
|
785 |
30242
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
786 DEFUN ("previous-single-char-property-change", |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
787 Fprevious_single_char_property_change, |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
788 Sprevious_single_char_property_change, 2, 4, 0, |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
789 "Return the position of previous text property or overlay change for a specific property.\n\ |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
790 Scans characters backward from POSITION till it finds\n\ |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
791 a change in the PROP property, then returns the position of the change.\n\ |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
792 The optional third argument OBJECT is the string or buffer to scan.\n\ |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
793 The property values are compared with `eq'.\n\ |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
794 Return nil if the property is constant all the way to the start of OBJECT.\n\ |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
795 If the value is non-nil, it is a position less than POSITION, never equal.\n\n\ |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
796 If the optional fourth argument LIMIT is non-nil, don't search\n\ |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
797 back past position LIMIT; return LIMIT if nothing is found before LIMIT.") |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
798 (position, prop, object, limit) |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
799 Lisp_Object prop, position, object, limit; |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
800 { |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
801 if (STRINGP (object)) |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
802 { |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
803 position = Fprevious_single_property_change (position, prop, object, limit); |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
804 if (NILP (position)) |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
805 { |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
806 if (NILP (limit)) |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
807 position = make_number (XSTRING (object)->size); |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
808 else |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
809 position = limit; |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
810 } |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
811 } |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
812 else |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
813 { |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
814 int count = specpdl_ptr - specpdl; |
25819
c2163b0bac24
(next_single_char_property_change): New.
Gerd Moellmann <gerd@gnu.org>
parents:
25772
diff
changeset
|
815 |
30242
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
816 if (! NILP (object)) |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
817 CHECK_BUFFER (object, 0); |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
818 |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
819 if (BUFFERP (object) && current_buffer != XBUFFER (object)) |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
820 { |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
821 record_unwind_protect (Fset_buffer, Fcurrent_buffer ()); |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
822 Fset_buffer (object); |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
823 } |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
824 |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
825 if (NILP (limit)) |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
826 XSETFASTINT (limit, BUF_BEGV (current_buffer)); |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
827 else |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
828 CHECK_NUMBER_COERCE_MARKER (limit, 0); |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
829 |
30379
836d2e058c70
(Fprevious_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
30242
diff
changeset
|
830 if (XFASTINT (position) <= XFASTINT (limit)) |
836d2e058c70
(Fprevious_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
30242
diff
changeset
|
831 position = limit; |
836d2e058c70
(Fprevious_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
30242
diff
changeset
|
832 else |
30242
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
833 { |
30379
836d2e058c70
(Fprevious_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
30242
diff
changeset
|
834 Lisp_Object initial_value = |
30678
1137a24ee515
(Fprevious_single_char_property_change): Don't do arithmetic directly on lisp
Ken Raeburn <raeburn@raeburn.org>
parents:
30379
diff
changeset
|
835 Fget_char_property (make_number (XFASTINT (position) - 1), |
1137a24ee515
(Fprevious_single_char_property_change): Don't do arithmetic directly on lisp
Ken Raeburn <raeburn@raeburn.org>
parents:
30379
diff
changeset
|
836 prop, object); |
30379
836d2e058c70
(Fprevious_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
30242
diff
changeset
|
837 |
836d2e058c70
(Fprevious_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
30242
diff
changeset
|
838 for (;;) |
836d2e058c70
(Fprevious_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
30242
diff
changeset
|
839 { |
836d2e058c70
(Fprevious_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
30242
diff
changeset
|
840 position = Fprevious_char_property_change (position, limit); |
30242
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
841 |
30379
836d2e058c70
(Fprevious_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
30242
diff
changeset
|
842 if (XFASTINT (position) <= XFASTINT (limit)) |
836d2e058c70
(Fprevious_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
30242
diff
changeset
|
843 { |
836d2e058c70
(Fprevious_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
30242
diff
changeset
|
844 position = limit; |
836d2e058c70
(Fprevious_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
30242
diff
changeset
|
845 break; |
836d2e058c70
(Fprevious_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
30242
diff
changeset
|
846 } |
836d2e058c70
(Fprevious_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
30242
diff
changeset
|
847 else |
836d2e058c70
(Fprevious_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
30242
diff
changeset
|
848 { |
836d2e058c70
(Fprevious_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
30242
diff
changeset
|
849 Lisp_Object value = |
30678
1137a24ee515
(Fprevious_single_char_property_change): Don't do arithmetic directly on lisp
Ken Raeburn <raeburn@raeburn.org>
parents:
30379
diff
changeset
|
850 Fget_char_property (make_number (XFASTINT (position) - 1), |
1137a24ee515
(Fprevious_single_char_property_change): Don't do arithmetic directly on lisp
Ken Raeburn <raeburn@raeburn.org>
parents:
30379
diff
changeset
|
851 prop, object); |
30379
836d2e058c70
(Fprevious_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
30242
diff
changeset
|
852 |
836d2e058c70
(Fprevious_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
30242
diff
changeset
|
853 if (!EQ (value, initial_value)) |
836d2e058c70
(Fprevious_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
30242
diff
changeset
|
854 break; |
836d2e058c70
(Fprevious_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
30242
diff
changeset
|
855 } |
836d2e058c70
(Fprevious_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
30242
diff
changeset
|
856 } |
30242
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
857 } |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
858 |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
859 unbind_to (count, Qnil); |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
860 } |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
861 |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
862 return position; |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
863 } |
16679
38c158927e6f
(Fnext_char_property_change): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16339
diff
changeset
|
864 |
1029 | 865 DEFUN ("next-property-change", Fnext_property_change, |
5086
6e9634463e93
(Ftext_property_not_all): Swap t and nil values in
Richard M. Stallman <rms@gnu.org>
parents:
5020
diff
changeset
|
866 Snext_property_change, 1, 3, 0, |
1857
9d65dfc7bdb7
(Fadd_text_properties): Put OBJECT arg last. Make it optional.
Richard M. Stallman <rms@gnu.org>
parents:
1715
diff
changeset
|
867 "Return the position of next property change.\n\ |
14088
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
868 Scans characters forward from POSITION in OBJECT till it finds\n\ |
1857
9d65dfc7bdb7
(Fadd_text_properties): Put OBJECT arg last. Make it optional.
Richard M. Stallman <rms@gnu.org>
parents:
1715
diff
changeset
|
869 a change in some text property, then returns the position of the change.\n\ |
9d65dfc7bdb7
(Fadd_text_properties): Put OBJECT arg last. Make it optional.
Richard M. Stallman <rms@gnu.org>
parents:
1715
diff
changeset
|
870 The optional second argument OBJECT is the string or buffer to scan.\n\ |
9d65dfc7bdb7
(Fadd_text_properties): Put OBJECT arg last. Make it optional.
Richard M. Stallman <rms@gnu.org>
parents:
1715
diff
changeset
|
871 Return nil if the property is constant all the way to the end of OBJECT.\n\ |
14088
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
872 If the value is non-nil, it is a position greater than POSITION, never equal.\n\n\ |
5086
6e9634463e93
(Ftext_property_not_all): Swap t and nil values in
Richard M. Stallman <rms@gnu.org>
parents:
5020
diff
changeset
|
873 If the optional third argument LIMIT is non-nil, don't search\n\ |
6e9634463e93
(Ftext_property_not_all): Swap t and nil values in
Richard M. Stallman <rms@gnu.org>
parents:
5020
diff
changeset
|
874 past position LIMIT; return LIMIT if nothing is found before LIMIT.") |
14088
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
875 (position, object, limit) |
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
876 Lisp_Object position, object, limit; |
1029 | 877 { |
878 register INTERVAL i, next; | |
879 | |
1857
9d65dfc7bdb7
(Fadd_text_properties): Put OBJECT arg last. Make it optional.
Richard M. Stallman <rms@gnu.org>
parents:
1715
diff
changeset
|
880 if (NILP (object)) |
9280
4b238c43e59f
(Ftext_properties_at, Fget_char_property, Fnext_property_change,
Karl Heuer <kwzh@gnu.org>
parents:
9109
diff
changeset
|
881 XSETBUFFER (object, current_buffer); |
1857
9d65dfc7bdb7
(Fadd_text_properties): Put OBJECT arg last. Make it optional.
Richard M. Stallman <rms@gnu.org>
parents:
1715
diff
changeset
|
882 |
10962
7f0bc7bcf1f3
(Fnext_property_change): Handle LIMIT = t.
Richard M. Stallman <rms@gnu.org>
parents:
10925
diff
changeset
|
883 if (! NILP (limit) && ! EQ (limit, Qt)) |
7092
b6b93953cc83
(F*_property_change): Typecheck limit argument.
Karl Heuer <kwzh@gnu.org>
parents:
6755
diff
changeset
|
884 CHECK_NUMBER_COERCE_MARKER (limit, 0); |
b6b93953cc83
(F*_property_change): Typecheck limit argument.
Karl Heuer <kwzh@gnu.org>
parents:
6755
diff
changeset
|
885 |
14088
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
886 i = validate_interval_range (object, &position, &position, soft); |
1029 | 887 |
10962
7f0bc7bcf1f3
(Fnext_property_change): Handle LIMIT = t.
Richard M. Stallman <rms@gnu.org>
parents:
10925
diff
changeset
|
888 /* If LIMIT is t, return start of next interval--don't |
7f0bc7bcf1f3
(Fnext_property_change): Handle LIMIT = t.
Richard M. Stallman <rms@gnu.org>
parents:
10925
diff
changeset
|
889 bother checking further intervals. */ |
7f0bc7bcf1f3
(Fnext_property_change): Handle LIMIT = t.
Richard M. Stallman <rms@gnu.org>
parents:
10925
diff
changeset
|
890 if (EQ (limit, Qt)) |
7f0bc7bcf1f3
(Fnext_property_change): Handle LIMIT = t.
Richard M. Stallman <rms@gnu.org>
parents:
10925
diff
changeset
|
891 { |
13265
dbc038e66ea6
(Fnext_single_property_change): Rearrange handling of
Richard M. Stallman <rms@gnu.org>
parents:
13027
diff
changeset
|
892 if (NULL_INTERVAL_P (i)) |
dbc038e66ea6
(Fnext_single_property_change): Rearrange handling of
Richard M. Stallman <rms@gnu.org>
parents:
13027
diff
changeset
|
893 next = i; |
dbc038e66ea6
(Fnext_single_property_change): Rearrange handling of
Richard M. Stallman <rms@gnu.org>
parents:
13027
diff
changeset
|
894 else |
dbc038e66ea6
(Fnext_single_property_change): Rearrange handling of
Richard M. Stallman <rms@gnu.org>
parents:
13027
diff
changeset
|
895 next = next_interval (i); |
dbc038e66ea6
(Fnext_single_property_change): Rearrange handling of
Richard M. Stallman <rms@gnu.org>
parents:
13027
diff
changeset
|
896 |
11116
73b51ad289e3
(Fnext_property_change): Fix previous change.
Karl Heuer <kwzh@gnu.org>
parents:
10962
diff
changeset
|
897 if (NULL_INTERVAL_P (next)) |
14088
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
898 XSETFASTINT (position, (STRINGP (object) |
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
899 ? XSTRING (object)->size |
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
900 : BUF_ZV (XBUFFER (object)))); |
11116
73b51ad289e3
(Fnext_property_change): Fix previous change.
Karl Heuer <kwzh@gnu.org>
parents:
10962
diff
changeset
|
901 else |
22344
2ec50b4767ed
Handle the new convention that `position' values
Karl Heuer <kwzh@gnu.org>
parents:
22280
diff
changeset
|
902 XSETFASTINT (position, next->position); |
14088
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
903 return position; |
10962
7f0bc7bcf1f3
(Fnext_property_change): Handle LIMIT = t.
Richard M. Stallman <rms@gnu.org>
parents:
10925
diff
changeset
|
904 } |
7f0bc7bcf1f3
(Fnext_property_change): Handle LIMIT = t.
Richard M. Stallman <rms@gnu.org>
parents:
10925
diff
changeset
|
905 |
13265
dbc038e66ea6
(Fnext_single_property_change): Rearrange handling of
Richard M. Stallman <rms@gnu.org>
parents:
13027
diff
changeset
|
906 if (NULL_INTERVAL_P (i)) |
dbc038e66ea6
(Fnext_single_property_change): Rearrange handling of
Richard M. Stallman <rms@gnu.org>
parents:
13027
diff
changeset
|
907 return limit; |
dbc038e66ea6
(Fnext_single_property_change): Rearrange handling of
Richard M. Stallman <rms@gnu.org>
parents:
13027
diff
changeset
|
908 |
dbc038e66ea6
(Fnext_single_property_change): Rearrange handling of
Richard M. Stallman <rms@gnu.org>
parents:
13027
diff
changeset
|
909 next = next_interval (i); |
dbc038e66ea6
(Fnext_single_property_change): Rearrange handling of
Richard M. Stallman <rms@gnu.org>
parents:
13027
diff
changeset
|
910 |
5086
6e9634463e93
(Ftext_property_not_all): Swap t and nil values in
Richard M. Stallman <rms@gnu.org>
parents:
5020
diff
changeset
|
911 while (! NULL_INTERVAL_P (next) && intervals_equal (i, next) |
22344
2ec50b4767ed
Handle the new convention that `position' values
Karl Heuer <kwzh@gnu.org>
parents:
22280
diff
changeset
|
912 && (NILP (limit) || next->position < XFASTINT (limit))) |
1029 | 913 next = next_interval (next); |
914 | |
915 if (NULL_INTERVAL_P (next)) | |
5086
6e9634463e93
(Ftext_property_not_all): Swap t and nil values in
Richard M. Stallman <rms@gnu.org>
parents:
5020
diff
changeset
|
916 return limit; |
22344
2ec50b4767ed
Handle the new convention that `position' values
Karl Heuer <kwzh@gnu.org>
parents:
22280
diff
changeset
|
917 if (! NILP (limit) && !(next->position < XFASTINT (limit))) |
5086
6e9634463e93
(Ftext_property_not_all): Swap t and nil values in
Richard M. Stallman <rms@gnu.org>
parents:
5020
diff
changeset
|
918 return limit; |
1029 | 919 |
22344
2ec50b4767ed
Handle the new convention that `position' values
Karl Heuer <kwzh@gnu.org>
parents:
22280
diff
changeset
|
920 XSETFASTINT (position, next->position); |
14088
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
921 return position; |
4381
b0556af4d680
(Qfront_sticky, Qrear_nonsticky): New variables.
Richard M. Stallman <rms@gnu.org>
parents:
4242
diff
changeset
|
922 } |
b0556af4d680
(Qfront_sticky, Qrear_nonsticky): New variables.
Richard M. Stallman <rms@gnu.org>
parents:
4242
diff
changeset
|
923 |
b0556af4d680
(Qfront_sticky, Qrear_nonsticky): New variables.
Richard M. Stallman <rms@gnu.org>
parents:
4242
diff
changeset
|
924 /* Return 1 if there's a change in some property between BEG and END. */ |
b0556af4d680
(Qfront_sticky, Qrear_nonsticky): New variables.
Richard M. Stallman <rms@gnu.org>
parents:
4242
diff
changeset
|
925 |
b0556af4d680
(Qfront_sticky, Qrear_nonsticky): New variables.
Richard M. Stallman <rms@gnu.org>
parents:
4242
diff
changeset
|
926 int |
b0556af4d680
(Qfront_sticky, Qrear_nonsticky): New variables.
Richard M. Stallman <rms@gnu.org>
parents:
4242
diff
changeset
|
927 property_change_between_p (beg, end) |
b0556af4d680
(Qfront_sticky, Qrear_nonsticky): New variables.
Richard M. Stallman <rms@gnu.org>
parents:
4242
diff
changeset
|
928 int beg, end; |
b0556af4d680
(Qfront_sticky, Qrear_nonsticky): New variables.
Richard M. Stallman <rms@gnu.org>
parents:
4242
diff
changeset
|
929 { |
b0556af4d680
(Qfront_sticky, Qrear_nonsticky): New variables.
Richard M. Stallman <rms@gnu.org>
parents:
4242
diff
changeset
|
930 register INTERVAL i, next; |
b0556af4d680
(Qfront_sticky, Qrear_nonsticky): New variables.
Richard M. Stallman <rms@gnu.org>
parents:
4242
diff
changeset
|
931 Lisp_Object object, pos; |
b0556af4d680
(Qfront_sticky, Qrear_nonsticky): New variables.
Richard M. Stallman <rms@gnu.org>
parents:
4242
diff
changeset
|
932 |
9280
4b238c43e59f
(Ftext_properties_at, Fget_char_property, Fnext_property_change,
Karl Heuer <kwzh@gnu.org>
parents:
9109
diff
changeset
|
933 XSETBUFFER (object, current_buffer); |
9321
e6759002383c
(Fnext_property_change, property_change_between_p,
Karl Heuer <kwzh@gnu.org>
parents:
9280
diff
changeset
|
934 XSETFASTINT (pos, beg); |
4381
b0556af4d680
(Qfront_sticky, Qrear_nonsticky): New variables.
Richard M. Stallman <rms@gnu.org>
parents:
4242
diff
changeset
|
935 |
b0556af4d680
(Qfront_sticky, Qrear_nonsticky): New variables.
Richard M. Stallman <rms@gnu.org>
parents:
4242
diff
changeset
|
936 i = validate_interval_range (object, &pos, &pos, soft); |
b0556af4d680
(Qfront_sticky, Qrear_nonsticky): New variables.
Richard M. Stallman <rms@gnu.org>
parents:
4242
diff
changeset
|
937 if (NULL_INTERVAL_P (i)) |
b0556af4d680
(Qfront_sticky, Qrear_nonsticky): New variables.
Richard M. Stallman <rms@gnu.org>
parents:
4242
diff
changeset
|
938 return 0; |
b0556af4d680
(Qfront_sticky, Qrear_nonsticky): New variables.
Richard M. Stallman <rms@gnu.org>
parents:
4242
diff
changeset
|
939 |
b0556af4d680
(Qfront_sticky, Qrear_nonsticky): New variables.
Richard M. Stallman <rms@gnu.org>
parents:
4242
diff
changeset
|
940 next = next_interval (i); |
b0556af4d680
(Qfront_sticky, Qrear_nonsticky): New variables.
Richard M. Stallman <rms@gnu.org>
parents:
4242
diff
changeset
|
941 while (! NULL_INTERVAL_P (next) && intervals_equal (i, next)) |
b0556af4d680
(Qfront_sticky, Qrear_nonsticky): New variables.
Richard M. Stallman <rms@gnu.org>
parents:
4242
diff
changeset
|
942 { |
b0556af4d680
(Qfront_sticky, Qrear_nonsticky): New variables.
Richard M. Stallman <rms@gnu.org>
parents:
4242
diff
changeset
|
943 next = next_interval (next); |
4614
2c5557903994
(property_change_between_p): Test NULL_INTERVAL_P
Richard M. Stallman <rms@gnu.org>
parents:
4381
diff
changeset
|
944 if (NULL_INTERVAL_P (next)) |
2c5557903994
(property_change_between_p): Test NULL_INTERVAL_P
Richard M. Stallman <rms@gnu.org>
parents:
4381
diff
changeset
|
945 return 0; |
22344
2ec50b4767ed
Handle the new convention that `position' values
Karl Heuer <kwzh@gnu.org>
parents:
22280
diff
changeset
|
946 if (next->position >= end) |
4381
b0556af4d680
(Qfront_sticky, Qrear_nonsticky): New variables.
Richard M. Stallman <rms@gnu.org>
parents:
4242
diff
changeset
|
947 return 0; |
b0556af4d680
(Qfront_sticky, Qrear_nonsticky): New variables.
Richard M. Stallman <rms@gnu.org>
parents:
4242
diff
changeset
|
948 } |
b0556af4d680
(Qfront_sticky, Qrear_nonsticky): New variables.
Richard M. Stallman <rms@gnu.org>
parents:
4242
diff
changeset
|
949 |
b0556af4d680
(Qfront_sticky, Qrear_nonsticky): New variables.
Richard M. Stallman <rms@gnu.org>
parents:
4242
diff
changeset
|
950 if (NULL_INTERVAL_P (next)) |
b0556af4d680
(Qfront_sticky, Qrear_nonsticky): New variables.
Richard M. Stallman <rms@gnu.org>
parents:
4242
diff
changeset
|
951 return 0; |
b0556af4d680
(Qfront_sticky, Qrear_nonsticky): New variables.
Richard M. Stallman <rms@gnu.org>
parents:
4242
diff
changeset
|
952 |
b0556af4d680
(Qfront_sticky, Qrear_nonsticky): New variables.
Richard M. Stallman <rms@gnu.org>
parents:
4242
diff
changeset
|
953 return 1; |
1029 | 954 } |
955 | |
1211 | 956 DEFUN ("next-single-property-change", Fnext_single_property_change, |
5086
6e9634463e93
(Ftext_property_not_all): Swap t and nil values in
Richard M. Stallman <rms@gnu.org>
parents:
5020
diff
changeset
|
957 Snext_single_property_change, 2, 4, 0, |
1857
9d65dfc7bdb7
(Fadd_text_properties): Put OBJECT arg last. Make it optional.
Richard M. Stallman <rms@gnu.org>
parents:
1715
diff
changeset
|
958 "Return the position of next property change for a specific property.\n\ |
14088
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
959 Scans characters forward from POSITION till it finds\n\ |
1857
9d65dfc7bdb7
(Fadd_text_properties): Put OBJECT arg last. Make it optional.
Richard M. Stallman <rms@gnu.org>
parents:
1715
diff
changeset
|
960 a change in the PROP property, then returns the position of the change.\n\ |
9d65dfc7bdb7
(Fadd_text_properties): Put OBJECT arg last. Make it optional.
Richard M. Stallman <rms@gnu.org>
parents:
1715
diff
changeset
|
961 The optional third argument OBJECT is the string or buffer to scan.\n\ |
5020
94de08fd8a7c
(Fnext_single_property_change): Fix missing \n\.
Richard M. Stallman <rms@gnu.org>
parents:
4986
diff
changeset
|
962 The property values are compared with `eq'.\n\ |
1857
9d65dfc7bdb7
(Fadd_text_properties): Put OBJECT arg last. Make it optional.
Richard M. Stallman <rms@gnu.org>
parents:
1715
diff
changeset
|
963 Return nil if the property is constant all the way to the end of OBJECT.\n\ |
14088
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
964 If the value is non-nil, it is a position greater than POSITION, never equal.\n\n\ |
5086
6e9634463e93
(Ftext_property_not_all): Swap t and nil values in
Richard M. Stallman <rms@gnu.org>
parents:
5020
diff
changeset
|
965 If the optional fourth argument LIMIT is non-nil, don't search\n\ |
5645 | 966 past position LIMIT; return LIMIT if nothing is found before LIMIT.") |
14088
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
967 (position, prop, object, limit) |
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
968 Lisp_Object position, prop, object, limit; |
1211 | 969 { |
970 register INTERVAL i, next; | |
971 register Lisp_Object here_val; | |
972 | |
1857
9d65dfc7bdb7
(Fadd_text_properties): Put OBJECT arg last. Make it optional.
Richard M. Stallman <rms@gnu.org>
parents:
1715
diff
changeset
|
973 if (NILP (object)) |
9280
4b238c43e59f
(Ftext_properties_at, Fget_char_property, Fnext_property_change,
Karl Heuer <kwzh@gnu.org>
parents:
9109
diff
changeset
|
974 XSETBUFFER (object, current_buffer); |
1857
9d65dfc7bdb7
(Fadd_text_properties): Put OBJECT arg last. Make it optional.
Richard M. Stallman <rms@gnu.org>
parents:
1715
diff
changeset
|
975 |
7092
b6b93953cc83
(F*_property_change): Typecheck limit argument.
Karl Heuer <kwzh@gnu.org>
parents:
6755
diff
changeset
|
976 if (!NILP (limit)) |
b6b93953cc83
(F*_property_change): Typecheck limit argument.
Karl Heuer <kwzh@gnu.org>
parents:
6755
diff
changeset
|
977 CHECK_NUMBER_COERCE_MARKER (limit, 0); |
b6b93953cc83
(F*_property_change): Typecheck limit argument.
Karl Heuer <kwzh@gnu.org>
parents:
6755
diff
changeset
|
978 |
14088
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
979 i = validate_interval_range (object, &position, &position, soft); |
1211 | 980 if (NULL_INTERVAL_P (i)) |
5086
6e9634463e93
(Ftext_property_not_all): Swap t and nil values in
Richard M. Stallman <rms@gnu.org>
parents:
5020
diff
changeset
|
981 return limit; |
1211 | 982 |
2762
dd28ed1e1928
* textprop.c (Fnext_single_property_change,
Jim Blandy <jimb@redhat.com>
parents:
2124
diff
changeset
|
983 here_val = textget (i->plist, prop); |
1211 | 984 next = next_interval (i); |
2762
dd28ed1e1928
* textprop.c (Fnext_single_property_change,
Jim Blandy <jimb@redhat.com>
parents:
2124
diff
changeset
|
985 while (! NULL_INTERVAL_P (next) |
5086
6e9634463e93
(Ftext_property_not_all): Swap t and nil values in
Richard M. Stallman <rms@gnu.org>
parents:
5020
diff
changeset
|
986 && EQ (here_val, textget (next->plist, prop)) |
22344
2ec50b4767ed
Handle the new convention that `position' values
Karl Heuer <kwzh@gnu.org>
parents:
22280
diff
changeset
|
987 && (NILP (limit) || next->position < XFASTINT (limit))) |
1211 | 988 next = next_interval (next); |
989 | |
990 if (NULL_INTERVAL_P (next)) | |
5086
6e9634463e93
(Ftext_property_not_all): Swap t and nil values in
Richard M. Stallman <rms@gnu.org>
parents:
5020
diff
changeset
|
991 return limit; |
22344
2ec50b4767ed
Handle the new convention that `position' values
Karl Heuer <kwzh@gnu.org>
parents:
22280
diff
changeset
|
992 if (! NILP (limit) && !(next->position < XFASTINT (limit))) |
5086
6e9634463e93
(Ftext_property_not_all): Swap t and nil values in
Richard M. Stallman <rms@gnu.org>
parents:
5020
diff
changeset
|
993 return limit; |
1211 | 994 |
22344
2ec50b4767ed
Handle the new convention that `position' values
Karl Heuer <kwzh@gnu.org>
parents:
22280
diff
changeset
|
995 return make_number (next->position); |
1211 | 996 } |
997 | |
1029 | 998 DEFUN ("previous-property-change", Fprevious_property_change, |
5086
6e9634463e93
(Ftext_property_not_all): Swap t and nil values in
Richard M. Stallman <rms@gnu.org>
parents:
5020
diff
changeset
|
999 Sprevious_property_change, 1, 3, 0, |
1857
9d65dfc7bdb7
(Fadd_text_properties): Put OBJECT arg last. Make it optional.
Richard M. Stallman <rms@gnu.org>
parents:
1715
diff
changeset
|
1000 "Return the position of previous property change.\n\ |
14088
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
1001 Scans characters backwards from POSITION in OBJECT till it finds\n\ |
1857
9d65dfc7bdb7
(Fadd_text_properties): Put OBJECT arg last. Make it optional.
Richard M. Stallman <rms@gnu.org>
parents:
1715
diff
changeset
|
1002 a change in some text property, then returns the position of the change.\n\ |
9d65dfc7bdb7
(Fadd_text_properties): Put OBJECT arg last. Make it optional.
Richard M. Stallman <rms@gnu.org>
parents:
1715
diff
changeset
|
1003 The optional second argument OBJECT is the string or buffer to scan.\n\ |
9d65dfc7bdb7
(Fadd_text_properties): Put OBJECT arg last. Make it optional.
Richard M. Stallman <rms@gnu.org>
parents:
1715
diff
changeset
|
1004 Return nil if the property is constant all the way to the start of OBJECT.\n\ |
14088
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
1005 If the value is non-nil, it is a position less than POSITION, never equal.\n\n\ |
5086
6e9634463e93
(Ftext_property_not_all): Swap t and nil values in
Richard M. Stallman <rms@gnu.org>
parents:
5020
diff
changeset
|
1006 If the optional third argument LIMIT is non-nil, don't search\n\ |
5645 | 1007 back past position LIMIT; return LIMIT if nothing is found until LIMIT.") |
14088
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
1008 (position, object, limit) |
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
1009 Lisp_Object position, object, limit; |
1029 | 1010 { |
1011 register INTERVAL i, previous; | |
1012 | |
1857
9d65dfc7bdb7
(Fadd_text_properties): Put OBJECT arg last. Make it optional.
Richard M. Stallman <rms@gnu.org>
parents:
1715
diff
changeset
|
1013 if (NILP (object)) |
9280
4b238c43e59f
(Ftext_properties_at, Fget_char_property, Fnext_property_change,
Karl Heuer <kwzh@gnu.org>
parents:
9109
diff
changeset
|
1014 XSETBUFFER (object, current_buffer); |
1857
9d65dfc7bdb7
(Fadd_text_properties): Put OBJECT arg last. Make it optional.
Richard M. Stallman <rms@gnu.org>
parents:
1715
diff
changeset
|
1015 |
7092
b6b93953cc83
(F*_property_change): Typecheck limit argument.
Karl Heuer <kwzh@gnu.org>
parents:
6755
diff
changeset
|
1016 if (!NILP (limit)) |
b6b93953cc83
(F*_property_change): Typecheck limit argument.
Karl Heuer <kwzh@gnu.org>
parents:
6755
diff
changeset
|
1017 CHECK_NUMBER_COERCE_MARKER (limit, 0); |
b6b93953cc83
(F*_property_change): Typecheck limit argument.
Karl Heuer <kwzh@gnu.org>
parents:
6755
diff
changeset
|
1018 |
14088
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
1019 i = validate_interval_range (object, &position, &position, soft); |
1029 | 1020 if (NULL_INTERVAL_P (i)) |
5086
6e9634463e93
(Ftext_property_not_all): Swap t and nil values in
Richard M. Stallman <rms@gnu.org>
parents:
5020
diff
changeset
|
1021 return limit; |
1029 | 1022 |
5644
2abe67658895
(Fprevious_property_change): Move back at least 1 char.
Richard M. Stallman <rms@gnu.org>
parents:
5114
diff
changeset
|
1023 /* Start with the interval containing the char before point. */ |
14088
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
1024 if (i->position == XFASTINT (position)) |
5644
2abe67658895
(Fprevious_property_change): Move back at least 1 char.
Richard M. Stallman <rms@gnu.org>
parents:
5114
diff
changeset
|
1025 i = previous_interval (i); |
2abe67658895
(Fprevious_property_change): Move back at least 1 char.
Richard M. Stallman <rms@gnu.org>
parents:
5114
diff
changeset
|
1026 |
1029 | 1027 previous = previous_interval (i); |
5086
6e9634463e93
(Ftext_property_not_all): Swap t and nil values in
Richard M. Stallman <rms@gnu.org>
parents:
5020
diff
changeset
|
1028 while (! NULL_INTERVAL_P (previous) && intervals_equal (previous, i) |
6e9634463e93
(Ftext_property_not_all): Swap t and nil values in
Richard M. Stallman <rms@gnu.org>
parents:
5020
diff
changeset
|
1029 && (NILP (limit) |
22344
2ec50b4767ed
Handle the new convention that `position' values
Karl Heuer <kwzh@gnu.org>
parents:
22280
diff
changeset
|
1030 || (previous->position + LENGTH (previous) > XFASTINT (limit)))) |
1029 | 1031 previous = previous_interval (previous); |
1032 if (NULL_INTERVAL_P (previous)) | |
5086
6e9634463e93
(Ftext_property_not_all): Swap t and nil values in
Richard M. Stallman <rms@gnu.org>
parents:
5020
diff
changeset
|
1033 return limit; |
6e9634463e93
(Ftext_property_not_all): Swap t and nil values in
Richard M. Stallman <rms@gnu.org>
parents:
5020
diff
changeset
|
1034 if (!NILP (limit) |
22344
2ec50b4767ed
Handle the new convention that `position' values
Karl Heuer <kwzh@gnu.org>
parents:
22280
diff
changeset
|
1035 && !(previous->position + LENGTH (previous) > XFASTINT (limit))) |
5086
6e9634463e93
(Ftext_property_not_all): Swap t and nil values in
Richard M. Stallman <rms@gnu.org>
parents:
5020
diff
changeset
|
1036 return limit; |
1029 | 1037 |
22344
2ec50b4767ed
Handle the new convention that `position' values
Karl Heuer <kwzh@gnu.org>
parents:
22280
diff
changeset
|
1038 return make_number (previous->position + LENGTH (previous)); |
1029 | 1039 } |
1040 | |
1211 | 1041 DEFUN ("previous-single-property-change", Fprevious_single_property_change, |
5086
6e9634463e93
(Ftext_property_not_all): Swap t and nil values in
Richard M. Stallman <rms@gnu.org>
parents:
5020
diff
changeset
|
1042 Sprevious_single_property_change, 2, 4, 0, |
1857
9d65dfc7bdb7
(Fadd_text_properties): Put OBJECT arg last. Make it optional.
Richard M. Stallman <rms@gnu.org>
parents:
1715
diff
changeset
|
1043 "Return the position of previous property change for a specific property.\n\ |
14088
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
1044 Scans characters backward from POSITION till it finds\n\ |
1857
9d65dfc7bdb7
(Fadd_text_properties): Put OBJECT arg last. Make it optional.
Richard M. Stallman <rms@gnu.org>
parents:
1715
diff
changeset
|
1045 a change in the PROP property, then returns the position of the change.\n\ |
9d65dfc7bdb7
(Fadd_text_properties): Put OBJECT arg last. Make it optional.
Richard M. Stallman <rms@gnu.org>
parents:
1715
diff
changeset
|
1046 The optional third argument OBJECT is the string or buffer to scan.\n\ |
4986
31b1545319dc
(Fprevious_single_property_change): Fix missing \n\.
Richard M. Stallman <rms@gnu.org>
parents:
4797
diff
changeset
|
1047 The property values are compared with `eq'.\n\ |
1857
9d65dfc7bdb7
(Fadd_text_properties): Put OBJECT arg last. Make it optional.
Richard M. Stallman <rms@gnu.org>
parents:
1715
diff
changeset
|
1048 Return nil if the property is constant all the way to the start of OBJECT.\n\ |
14088
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
1049 If the value is non-nil, it is a position less than POSITION, never equal.\n\n\ |
5086
6e9634463e93
(Ftext_property_not_all): Swap t and nil values in
Richard M. Stallman <rms@gnu.org>
parents:
5020
diff
changeset
|
1050 If the optional fourth argument LIMIT is non-nil, don't search\n\ |
5645 | 1051 back past position LIMIT; return LIMIT if nothing is found until LIMIT.") |
14088
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
1052 (position, prop, object, limit) |
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
1053 Lisp_Object position, prop, object, limit; |
1211 | 1054 { |
1055 register INTERVAL i, previous; | |
1056 register Lisp_Object here_val; | |
1057 | |
1857
9d65dfc7bdb7
(Fadd_text_properties): Put OBJECT arg last. Make it optional.
Richard M. Stallman <rms@gnu.org>
parents:
1715
diff
changeset
|
1058 if (NILP (object)) |
9280
4b238c43e59f
(Ftext_properties_at, Fget_char_property, Fnext_property_change,
Karl Heuer <kwzh@gnu.org>
parents:
9109
diff
changeset
|
1059 XSETBUFFER (object, current_buffer); |
1857
9d65dfc7bdb7
(Fadd_text_properties): Put OBJECT arg last. Make it optional.
Richard M. Stallman <rms@gnu.org>
parents:
1715
diff
changeset
|
1060 |
7092
b6b93953cc83
(F*_property_change): Typecheck limit argument.
Karl Heuer <kwzh@gnu.org>
parents:
6755
diff
changeset
|
1061 if (!NILP (limit)) |
b6b93953cc83
(F*_property_change): Typecheck limit argument.
Karl Heuer <kwzh@gnu.org>
parents:
6755
diff
changeset
|
1062 CHECK_NUMBER_COERCE_MARKER (limit, 0); |
b6b93953cc83
(F*_property_change): Typecheck limit argument.
Karl Heuer <kwzh@gnu.org>
parents:
6755
diff
changeset
|
1063 |
14088
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
1064 i = validate_interval_range (object, &position, &position, soft); |
7773
2226c7efb3da
(Fprevious_single_property_change): Check for null interval after correcting
Karl Heuer <kwzh@gnu.org>
parents:
7582
diff
changeset
|
1065 |
2226c7efb3da
(Fprevious_single_property_change): Check for null interval after correcting
Karl Heuer <kwzh@gnu.org>
parents:
7582
diff
changeset
|
1066 /* Start with the interval containing the char before point. */ |
14088
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
1067 if (! NULL_INTERVAL_P (i) && i->position == XFASTINT (position)) |
7773
2226c7efb3da
(Fprevious_single_property_change): Check for null interval after correcting
Karl Heuer <kwzh@gnu.org>
parents:
7582
diff
changeset
|
1068 i = previous_interval (i); |
2226c7efb3da
(Fprevious_single_property_change): Check for null interval after correcting
Karl Heuer <kwzh@gnu.org>
parents:
7582
diff
changeset
|
1069 |
1211 | 1070 if (NULL_INTERVAL_P (i)) |
5086
6e9634463e93
(Ftext_property_not_all): Swap t and nil values in
Richard M. Stallman <rms@gnu.org>
parents:
5020
diff
changeset
|
1071 return limit; |
1211 | 1072 |
2762
dd28ed1e1928
* textprop.c (Fnext_single_property_change,
Jim Blandy <jimb@redhat.com>
parents:
2124
diff
changeset
|
1073 here_val = textget (i->plist, prop); |
1211 | 1074 previous = previous_interval (i); |
1075 while (! NULL_INTERVAL_P (previous) | |
5086
6e9634463e93
(Ftext_property_not_all): Swap t and nil values in
Richard M. Stallman <rms@gnu.org>
parents:
5020
diff
changeset
|
1076 && EQ (here_val, textget (previous->plist, prop)) |
6e9634463e93
(Ftext_property_not_all): Swap t and nil values in
Richard M. Stallman <rms@gnu.org>
parents:
5020
diff
changeset
|
1077 && (NILP (limit) |
22344
2ec50b4767ed
Handle the new convention that `position' values
Karl Heuer <kwzh@gnu.org>
parents:
22280
diff
changeset
|
1078 || (previous->position + LENGTH (previous) > XFASTINT (limit)))) |
1211 | 1079 previous = previous_interval (previous); |
1080 if (NULL_INTERVAL_P (previous)) | |
5086
6e9634463e93
(Ftext_property_not_all): Swap t and nil values in
Richard M. Stallman <rms@gnu.org>
parents:
5020
diff
changeset
|
1081 return limit; |
6e9634463e93
(Ftext_property_not_all): Swap t and nil values in
Richard M. Stallman <rms@gnu.org>
parents:
5020
diff
changeset
|
1082 if (!NILP (limit) |
22344
2ec50b4767ed
Handle the new convention that `position' values
Karl Heuer <kwzh@gnu.org>
parents:
22280
diff
changeset
|
1083 && !(previous->position + LENGTH (previous) > XFASTINT (limit))) |
5086
6e9634463e93
(Ftext_property_not_all): Swap t and nil values in
Richard M. Stallman <rms@gnu.org>
parents:
5020
diff
changeset
|
1084 return limit; |
1211 | 1085 |
22344
2ec50b4767ed
Handle the new convention that `position' values
Karl Heuer <kwzh@gnu.org>
parents:
22280
diff
changeset
|
1086 return make_number (previous->position + LENGTH (previous)); |
1211 | 1087 } |
16679
38c158927e6f
(Fnext_char_property_change): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16339
diff
changeset
|
1088 |
10159
1299d37b51bb
(add_properties): Add gcpro's.
Richard M. Stallman <rms@gnu.org>
parents:
9945
diff
changeset
|
1089 /* Callers note, this can GC when OBJECT is a buffer (or nil). */ |
1299d37b51bb
(add_properties): Add gcpro's.
Richard M. Stallman <rms@gnu.org>
parents:
9945
diff
changeset
|
1090 |
1029 | 1091 DEFUN ("add-text-properties", Fadd_text_properties, |
1857
9d65dfc7bdb7
(Fadd_text_properties): Put OBJECT arg last. Make it optional.
Richard M. Stallman <rms@gnu.org>
parents:
1715
diff
changeset
|
1092 Sadd_text_properties, 3, 4, 0, |
9d65dfc7bdb7
(Fadd_text_properties): Put OBJECT arg last. Make it optional.
Richard M. Stallman <rms@gnu.org>
parents:
1715
diff
changeset
|
1093 "Add properties to the text from START to END.\n\ |
14088
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
1094 The third argument PROPERTIES is a property list\n\ |
1857
9d65dfc7bdb7
(Fadd_text_properties): Put OBJECT arg last. Make it optional.
Richard M. Stallman <rms@gnu.org>
parents:
1715
diff
changeset
|
1095 specifying the property values to add.\n\ |
9d65dfc7bdb7
(Fadd_text_properties): Put OBJECT arg last. Make it optional.
Richard M. Stallman <rms@gnu.org>
parents:
1715
diff
changeset
|
1096 The optional fourth argument, OBJECT,\n\ |
9d65dfc7bdb7
(Fadd_text_properties): Put OBJECT arg last. Make it optional.
Richard M. Stallman <rms@gnu.org>
parents:
1715
diff
changeset
|
1097 is the string or buffer containing the text.\n\ |
9d65dfc7bdb7
(Fadd_text_properties): Put OBJECT arg last. Make it optional.
Richard M. Stallman <rms@gnu.org>
parents:
1715
diff
changeset
|
1098 Return t if any property value actually changed, nil otherwise.") |
9d65dfc7bdb7
(Fadd_text_properties): Put OBJECT arg last. Make it optional.
Richard M. Stallman <rms@gnu.org>
parents:
1715
diff
changeset
|
1099 (start, end, properties, object) |
9d65dfc7bdb7
(Fadd_text_properties): Put OBJECT arg last. Make it optional.
Richard M. Stallman <rms@gnu.org>
parents:
1715
diff
changeset
|
1100 Lisp_Object start, end, properties, object; |
1029 | 1101 { |
1102 register INTERVAL i, unchanged; | |
2124
54179ef9ce35
* textprop.c (Fadd_text_properties): Initialize the modified flag.
Jim Blandy <jimb@redhat.com>
parents:
2058
diff
changeset
|
1103 register int s, len, modified = 0; |
10159
1299d37b51bb
(add_properties): Add gcpro's.
Richard M. Stallman <rms@gnu.org>
parents:
9945
diff
changeset
|
1104 struct gcpro gcpro1; |
1029 | 1105 |
1106 properties = validate_plist (properties); | |
1107 if (NILP (properties)) | |
1108 return Qnil; | |
1109 | |
1857
9d65dfc7bdb7
(Fadd_text_properties): Put OBJECT arg last. Make it optional.
Richard M. Stallman <rms@gnu.org>
parents:
1715
diff
changeset
|
1110 if (NILP (object)) |
9280
4b238c43e59f
(Ftext_properties_at, Fget_char_property, Fnext_property_change,
Karl Heuer <kwzh@gnu.org>
parents:
9109
diff
changeset
|
1111 XSETBUFFER (object, current_buffer); |
1857
9d65dfc7bdb7
(Fadd_text_properties): Put OBJECT arg last. Make it optional.
Richard M. Stallman <rms@gnu.org>
parents:
1715
diff
changeset
|
1112 |
1029 | 1113 i = validate_interval_range (object, &start, &end, hard); |
1114 if (NULL_INTERVAL_P (i)) | |
1115 return Qnil; | |
1116 | |
1117 s = XINT (start); | |
1118 len = XINT (end) - s; | |
1119 | |
10159
1299d37b51bb
(add_properties): Add gcpro's.
Richard M. Stallman <rms@gnu.org>
parents:
9945
diff
changeset
|
1120 /* No need to protect OBJECT, because we GC only if it's a buffer, |
1299d37b51bb
(add_properties): Add gcpro's.
Richard M. Stallman <rms@gnu.org>
parents:
9945
diff
changeset
|
1121 and live buffers are always protected. */ |
1299d37b51bb
(add_properties): Add gcpro's.
Richard M. Stallman <rms@gnu.org>
parents:
9945
diff
changeset
|
1122 GCPRO1 (properties); |
1299d37b51bb
(add_properties): Add gcpro's.
Richard M. Stallman <rms@gnu.org>
parents:
9945
diff
changeset
|
1123 |
1029 | 1124 /* If we're not starting on an interval boundary, we have to |
17467
98c47e7857f3
Style of comments corrected.
Richard M. Stallman <rms@gnu.org>
parents:
16679
diff
changeset
|
1125 split this interval. */ |
1029 | 1126 if (i->position != s) |
1127 { | |
1128 /* If this interval already has the properties, we can | |
17467
98c47e7857f3
Style of comments corrected.
Richard M. Stallman <rms@gnu.org>
parents:
16679
diff
changeset
|
1129 skip it. */ |
1029 | 1130 if (interval_has_all_properties (properties, i)) |
1131 { | |
1132 int got = (LENGTH (i) - (s - i->position)); | |
1133 if (got >= len) | |
14538
a17752d2b0c0
(Fadd_text_properties): Don't return without ungcpro.
Richard M. Stallman <rms@gnu.org>
parents:
14186
diff
changeset
|
1134 RETURN_UNGCPRO (Qnil); |
1029 | 1135 len -= got; |
3858
e07d474bdba9
(Fremove_text_properties, Fadd_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
3698
diff
changeset
|
1136 i = next_interval (i); |
1029 | 1137 } |
1138 else | |
1139 { | |
1140 unchanged = i; | |
4144
8f5545cf9774
* intervals.c (split_interval_left, split_interval_right): Change
Jim Blandy <jimb@redhat.com>
parents:
4076
diff
changeset
|
1141 i = split_interval_right (unchanged, s - unchanged->position); |
1029 | 1142 copy_properties (unchanged, i); |
1143 } | |
1144 } | |
1145 | |
16339
abcd50093b4e
(Fset_text_properties, Fadd_text_properties)
Richard M. Stallman <rms@gnu.org>
parents:
16331
diff
changeset
|
1146 if (BUFFERP (object)) |
abcd50093b4e
(Fset_text_properties, Fadd_text_properties)
Richard M. Stallman <rms@gnu.org>
parents:
16331
diff
changeset
|
1147 modify_region (XBUFFER (object), XINT (start), XINT (end)); |
16331
32a51f7ba384
(set_properties, add_properties, remove_properties):
Richard M. Stallman <rms@gnu.org>
parents:
16103
diff
changeset
|
1148 |
3553
5f9688c0b704
(Fadd_text_properties): Don't treat the initial
Richard M. Stallman <rms@gnu.org>
parents:
2783
diff
changeset
|
1149 /* We are at the beginning of interval I, with LEN chars to scan. */ |
2124
54179ef9ce35
* textprop.c (Fadd_text_properties): Initialize the modified flag.
Jim Blandy <jimb@redhat.com>
parents:
2058
diff
changeset
|
1150 for (;;) |
1029 | 1151 { |
1965
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
1152 if (i == 0) |
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
1153 abort (); |
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
1154 |
1029 | 1155 if (LENGTH (i) >= len) |
1156 { | |
10159
1299d37b51bb
(add_properties): Add gcpro's.
Richard M. Stallman <rms@gnu.org>
parents:
9945
diff
changeset
|
1157 /* We can UNGCPRO safely here, because there will be just |
1299d37b51bb
(add_properties): Add gcpro's.
Richard M. Stallman <rms@gnu.org>
parents:
9945
diff
changeset
|
1158 one more chance to gc, in the next call to add_properties, |
1299d37b51bb
(add_properties): Add gcpro's.
Richard M. Stallman <rms@gnu.org>
parents:
9945
diff
changeset
|
1159 and after that we will not need PROPERTIES or OBJECT again. */ |
1299d37b51bb
(add_properties): Add gcpro's.
Richard M. Stallman <rms@gnu.org>
parents:
9945
diff
changeset
|
1160 UNGCPRO; |
1299d37b51bb
(add_properties): Add gcpro's.
Richard M. Stallman <rms@gnu.org>
parents:
9945
diff
changeset
|
1161 |
1029 | 1162 if (interval_has_all_properties (properties, i)) |
16331
32a51f7ba384
(set_properties, add_properties, remove_properties):
Richard M. Stallman <rms@gnu.org>
parents:
16103
diff
changeset
|
1163 { |
16339
abcd50093b4e
(Fset_text_properties, Fadd_text_properties)
Richard M. Stallman <rms@gnu.org>
parents:
16331
diff
changeset
|
1164 if (BUFFERP (object)) |
abcd50093b4e
(Fset_text_properties, Fadd_text_properties)
Richard M. Stallman <rms@gnu.org>
parents:
16331
diff
changeset
|
1165 signal_after_change (XINT (start), XINT (end) - XINT (start), |
abcd50093b4e
(Fset_text_properties, Fadd_text_properties)
Richard M. Stallman <rms@gnu.org>
parents:
16331
diff
changeset
|
1166 XINT (end) - XINT (start)); |
16331
32a51f7ba384
(set_properties, add_properties, remove_properties):
Richard M. Stallman <rms@gnu.org>
parents:
16103
diff
changeset
|
1167 |
32a51f7ba384
(set_properties, add_properties, remove_properties):
Richard M. Stallman <rms@gnu.org>
parents:
16103
diff
changeset
|
1168 return modified ? Qt : Qnil; |
32a51f7ba384
(set_properties, add_properties, remove_properties):
Richard M. Stallman <rms@gnu.org>
parents:
16103
diff
changeset
|
1169 } |
1029 | 1170 |
1171 if (LENGTH (i) == len) | |
1172 { | |
1965
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
1173 add_properties (properties, i, object); |
16339
abcd50093b4e
(Fset_text_properties, Fadd_text_properties)
Richard M. Stallman <rms@gnu.org>
parents:
16331
diff
changeset
|
1174 if (BUFFERP (object)) |
abcd50093b4e
(Fset_text_properties, Fadd_text_properties)
Richard M. Stallman <rms@gnu.org>
parents:
16331
diff
changeset
|
1175 signal_after_change (XINT (start), XINT (end) - XINT (start), |
abcd50093b4e
(Fset_text_properties, Fadd_text_properties)
Richard M. Stallman <rms@gnu.org>
parents:
16331
diff
changeset
|
1176 XINT (end) - XINT (start)); |
1029 | 1177 return Qt; |
1178 } | |
1179 | |
1180 /* i doesn't have the properties, and goes past the change limit */ | |
1181 unchanged = i; | |
4144
8f5545cf9774
* intervals.c (split_interval_left, split_interval_right): Change
Jim Blandy <jimb@redhat.com>
parents:
4076
diff
changeset
|
1182 i = split_interval_left (unchanged, len); |
1029 | 1183 copy_properties (unchanged, i); |
1965
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
1184 add_properties (properties, i, object); |
16339
abcd50093b4e
(Fset_text_properties, Fadd_text_properties)
Richard M. Stallman <rms@gnu.org>
parents:
16331
diff
changeset
|
1185 if (BUFFERP (object)) |
abcd50093b4e
(Fset_text_properties, Fadd_text_properties)
Richard M. Stallman <rms@gnu.org>
parents:
16331
diff
changeset
|
1186 signal_after_change (XINT (start), XINT (end) - XINT (start), |
abcd50093b4e
(Fset_text_properties, Fadd_text_properties)
Richard M. Stallman <rms@gnu.org>
parents:
16331
diff
changeset
|
1187 XINT (end) - XINT (start)); |
1029 | 1188 return Qt; |
1189 } | |
1190 | |
1191 len -= LENGTH (i); | |
1965
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
1192 modified += add_properties (properties, i, object); |
1029 | 1193 i = next_interval (i); |
1194 } | |
1195 } | |
1196 | |
10159
1299d37b51bb
(add_properties): Add gcpro's.
Richard M. Stallman <rms@gnu.org>
parents:
9945
diff
changeset
|
1197 /* Callers note, this can GC when OBJECT is a buffer (or nil). */ |
1299d37b51bb
(add_properties): Add gcpro's.
Richard M. Stallman <rms@gnu.org>
parents:
9945
diff
changeset
|
1198 |
1965
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
1199 DEFUN ("put-text-property", Fput_text_property, |
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
1200 Sput_text_property, 4, 5, 0, |
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
1201 "Set one property of the text from START to END.\n\ |
14088
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
1202 The third and fourth arguments PROPERTY and VALUE\n\ |
1965
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
1203 specify the property to add.\n\ |
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
1204 The optional fifth argument, OBJECT,\n\ |
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
1205 is the string or buffer containing the text.") |
14088
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
1206 (start, end, property, value, object) |
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
1207 Lisp_Object start, end, property, value, object; |
1965
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
1208 { |
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
1209 Fadd_text_properties (start, end, |
14088
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
1210 Fcons (property, Fcons (value, Qnil)), |
1965
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
1211 object); |
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
1212 return Qnil; |
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
1213 } |
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
1214 |
1029 | 1215 DEFUN ("set-text-properties", Fset_text_properties, |
1857
9d65dfc7bdb7
(Fadd_text_properties): Put OBJECT arg last. Make it optional.
Richard M. Stallman <rms@gnu.org>
parents:
1715
diff
changeset
|
1216 Sset_text_properties, 3, 4, 0, |
9d65dfc7bdb7
(Fadd_text_properties): Put OBJECT arg last. Make it optional.
Richard M. Stallman <rms@gnu.org>
parents:
1715
diff
changeset
|
1217 "Completely replace properties of text from START to END.\n\ |
14088
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
1218 The third argument PROPERTIES is the new property list.\n\ |
1857
9d65dfc7bdb7
(Fadd_text_properties): Put OBJECT arg last. Make it optional.
Richard M. Stallman <rms@gnu.org>
parents:
1715
diff
changeset
|
1219 The optional fourth argument, OBJECT,\n\ |
35751
c3efe58b6405
(Fset_text_properties): Fix newline in doc string.
Dave Love <fx@gnu.org>
parents:
35694
diff
changeset
|
1220 is the string or buffer containing the text.\n\ |
36099
df19dee0cf24
(Fset_text_properties): Doc fix.
Eli Zaretskii <eliz@gnu.org>
parents:
35751
diff
changeset
|
1221 If OBJECT is omitted or nil, it defaults to the current buffer.\n\ |
df19dee0cf24
(Fset_text_properties): Doc fix.
Eli Zaretskii <eliz@gnu.org>
parents:
35751
diff
changeset
|
1222 If PROPERTIES is nil, the effect is to remove all properties from\n\ |
df19dee0cf24
(Fset_text_properties): Doc fix.
Eli Zaretskii <eliz@gnu.org>
parents:
35751
diff
changeset
|
1223 the designated part of OBJECT.") |
14088
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
1224 (start, end, properties, object) |
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
1225 Lisp_Object start, end, properties, object; |
1029 | 1226 { |
26605
46168cb41ba0
(set_text_properties): New function. Like
Gerd Moellmann <gerd@gnu.org>
parents:
26404
diff
changeset
|
1227 return set_text_properties (start, end, properties, object, Qt); |
46168cb41ba0
(set_text_properties): New function. Like
Gerd Moellmann <gerd@gnu.org>
parents:
26404
diff
changeset
|
1228 } |
46168cb41ba0
(set_text_properties): New function. Like
Gerd Moellmann <gerd@gnu.org>
parents:
26404
diff
changeset
|
1229 |
46168cb41ba0
(set_text_properties): New function. Like
Gerd Moellmann <gerd@gnu.org>
parents:
26404
diff
changeset
|
1230 |
46168cb41ba0
(set_text_properties): New function. Like
Gerd Moellmann <gerd@gnu.org>
parents:
26404
diff
changeset
|
1231 /* Replace properties of text from START to END with new list of |
46168cb41ba0
(set_text_properties): New function. Like
Gerd Moellmann <gerd@gnu.org>
parents:
26404
diff
changeset
|
1232 properties PROPERTIES. OBJECT is the buffer or string containing |
46168cb41ba0
(set_text_properties): New function. Like
Gerd Moellmann <gerd@gnu.org>
parents:
26404
diff
changeset
|
1233 the text. OBJECT nil means use the current buffer. |
46168cb41ba0
(set_text_properties): New function. Like
Gerd Moellmann <gerd@gnu.org>
parents:
26404
diff
changeset
|
1234 SIGNAL_AFTER_CHANGE_P nil means don't signal after changes. Value |
46168cb41ba0
(set_text_properties): New function. Like
Gerd Moellmann <gerd@gnu.org>
parents:
26404
diff
changeset
|
1235 is non-nil if properties were replaced; it is nil if there weren't |
46168cb41ba0
(set_text_properties): New function. Like
Gerd Moellmann <gerd@gnu.org>
parents:
26404
diff
changeset
|
1236 any properties to replace. */ |
46168cb41ba0
(set_text_properties): New function. Like
Gerd Moellmann <gerd@gnu.org>
parents:
26404
diff
changeset
|
1237 |
46168cb41ba0
(set_text_properties): New function. Like
Gerd Moellmann <gerd@gnu.org>
parents:
26404
diff
changeset
|
1238 Lisp_Object |
46168cb41ba0
(set_text_properties): New function. Like
Gerd Moellmann <gerd@gnu.org>
parents:
26404
diff
changeset
|
1239 set_text_properties (start, end, properties, object, signal_after_change_p) |
46168cb41ba0
(set_text_properties): New function. Like
Gerd Moellmann <gerd@gnu.org>
parents:
26404
diff
changeset
|
1240 Lisp_Object start, end, properties, object, signal_after_change_p; |
46168cb41ba0
(set_text_properties): New function. Like
Gerd Moellmann <gerd@gnu.org>
parents:
26404
diff
changeset
|
1241 { |
1029 | 1242 register INTERVAL i, unchanged; |
1211 | 1243 register INTERVAL prev_changed = NULL_INTERVAL; |
1029 | 1244 register int s, len; |
9071
2d4d0f6e7be0
(syms_of_textprop): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
8962
diff
changeset
|
1245 Lisp_Object ostart, oend; |
2d4d0f6e7be0
(syms_of_textprop): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
8962
diff
changeset
|
1246 |
2d4d0f6e7be0
(syms_of_textprop): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
8962
diff
changeset
|
1247 ostart = start; |
2d4d0f6e7be0
(syms_of_textprop): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
8962
diff
changeset
|
1248 oend = end; |
1029 | 1249 |
14088
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
1250 properties = validate_plist (properties); |
1029 | 1251 |
1857
9d65dfc7bdb7
(Fadd_text_properties): Put OBJECT arg last. Make it optional.
Richard M. Stallman <rms@gnu.org>
parents:
1715
diff
changeset
|
1252 if (NILP (object)) |
9280
4b238c43e59f
(Ftext_properties_at, Fget_char_property, Fnext_property_change,
Karl Heuer <kwzh@gnu.org>
parents:
9109
diff
changeset
|
1253 XSETBUFFER (object, current_buffer); |
1857
9d65dfc7bdb7
(Fadd_text_properties): Put OBJECT arg last. Make it optional.
Richard M. Stallman <rms@gnu.org>
parents:
1715
diff
changeset
|
1254 |
9541
449e024f13be
(Fset_text_properties): Special case for getting
Richard M. Stallman <rms@gnu.org>
parents:
9331
diff
changeset
|
1255 /* If we want no properties for a whole string, |
449e024f13be
(Fset_text_properties): Special case for getting
Richard M. Stallman <rms@gnu.org>
parents:
9331
diff
changeset
|
1256 get rid of its intervals. */ |
14088
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
1257 if (NILP (properties) && STRINGP (object) |
9541
449e024f13be
(Fset_text_properties): Special case for getting
Richard M. Stallman <rms@gnu.org>
parents:
9331
diff
changeset
|
1258 && XFASTINT (start) == 0 |
449e024f13be
(Fset_text_properties): Special case for getting
Richard M. Stallman <rms@gnu.org>
parents:
9331
diff
changeset
|
1259 && XFASTINT (end) == XSTRING (object)->size) |
449e024f13be
(Fset_text_properties): Special case for getting
Richard M. Stallman <rms@gnu.org>
parents:
9331
diff
changeset
|
1260 { |
16331
32a51f7ba384
(set_properties, add_properties, remove_properties):
Richard M. Stallman <rms@gnu.org>
parents:
16103
diff
changeset
|
1261 if (! XSTRING (object)->intervals) |
32a51f7ba384
(set_properties, add_properties, remove_properties):
Richard M. Stallman <rms@gnu.org>
parents:
16103
diff
changeset
|
1262 return Qt; |
32a51f7ba384
(set_properties, add_properties, remove_properties):
Richard M. Stallman <rms@gnu.org>
parents:
16103
diff
changeset
|
1263 |
9541
449e024f13be
(Fset_text_properties): Special case for getting
Richard M. Stallman <rms@gnu.org>
parents:
9331
diff
changeset
|
1264 XSTRING (object)->intervals = 0; |
449e024f13be
(Fset_text_properties): Special case for getting
Richard M. Stallman <rms@gnu.org>
parents:
9331
diff
changeset
|
1265 return Qt; |
449e024f13be
(Fset_text_properties): Special case for getting
Richard M. Stallman <rms@gnu.org>
parents:
9331
diff
changeset
|
1266 } |
449e024f13be
(Fset_text_properties): Special case for getting
Richard M. Stallman <rms@gnu.org>
parents:
9331
diff
changeset
|
1267 |
8686 | 1268 i = validate_interval_range (object, &start, &end, soft); |
9541
449e024f13be
(Fset_text_properties): Special case for getting
Richard M. Stallman <rms@gnu.org>
parents:
9331
diff
changeset
|
1269 |
1029 | 1270 if (NULL_INTERVAL_P (i)) |
8686 | 1271 { |
14088
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
1272 /* If buffer has no properties, and we want none, return now. */ |
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
1273 if (NILP (properties)) |
8686 | 1274 return Qnil; |
1275 | |
9071
2d4d0f6e7be0
(syms_of_textprop): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
8962
diff
changeset
|
1276 /* Restore the original START and END values |
2d4d0f6e7be0
(syms_of_textprop): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
8962
diff
changeset
|
1277 because validate_interval_range increments them for strings. */ |
2d4d0f6e7be0
(syms_of_textprop): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
8962
diff
changeset
|
1278 start = ostart; |
2d4d0f6e7be0
(syms_of_textprop): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
8962
diff
changeset
|
1279 end = oend; |
2d4d0f6e7be0
(syms_of_textprop): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
8962
diff
changeset
|
1280 |
8686 | 1281 i = validate_interval_range (object, &start, &end, hard); |
1282 /* This can return if start == end. */ | |
1283 if (NULL_INTERVAL_P (i)) | |
1284 return Qnil; | |
1285 } | |
1029 | 1286 |
1287 s = XINT (start); | |
1288 len = XINT (end) - s; | |
1289 | |
16339
abcd50093b4e
(Fset_text_properties, Fadd_text_properties)
Richard M. Stallman <rms@gnu.org>
parents:
16331
diff
changeset
|
1290 if (BUFFERP (object)) |
abcd50093b4e
(Fset_text_properties, Fadd_text_properties)
Richard M. Stallman <rms@gnu.org>
parents:
16331
diff
changeset
|
1291 modify_region (XBUFFER (object), XINT (start), XINT (end)); |
16331
32a51f7ba384
(set_properties, add_properties, remove_properties):
Richard M. Stallman <rms@gnu.org>
parents:
16103
diff
changeset
|
1292 |
1029 | 1293 if (i->position != s) |
1294 { | |
1295 unchanged = i; | |
4144
8f5545cf9774
* intervals.c (split_interval_left, split_interval_right): Change
Jim Blandy <jimb@redhat.com>
parents:
4076
diff
changeset
|
1296 i = split_interval_right (unchanged, s - unchanged->position); |
1272
bfd04f61eb16
Mods to Ferase_text_properties
Joseph Arceneaux <jla@gnu.org>
parents:
1211
diff
changeset
|
1297 |
1029 | 1298 if (LENGTH (i) > len) |
1299 { | |
1211 | 1300 copy_properties (unchanged, i); |
4144
8f5545cf9774
* intervals.c (split_interval_left, split_interval_right): Change
Jim Blandy <jimb@redhat.com>
parents:
4076
diff
changeset
|
1301 i = split_interval_left (i, len); |
14088
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
1302 set_properties (properties, i, object); |
26605
46168cb41ba0
(set_text_properties): New function. Like
Gerd Moellmann <gerd@gnu.org>
parents:
26404
diff
changeset
|
1303 if (BUFFERP (object) && !NILP (signal_after_change_p)) |
16339
abcd50093b4e
(Fset_text_properties, Fadd_text_properties)
Richard M. Stallman <rms@gnu.org>
parents:
16331
diff
changeset
|
1304 signal_after_change (XINT (start), XINT (end) - XINT (start), |
abcd50093b4e
(Fset_text_properties, Fadd_text_properties)
Richard M. Stallman <rms@gnu.org>
parents:
16331
diff
changeset
|
1305 XINT (end) - XINT (start)); |
16331
32a51f7ba384
(set_properties, add_properties, remove_properties):
Richard M. Stallman <rms@gnu.org>
parents:
16103
diff
changeset
|
1306 |
1029 | 1307 return Qt; |
1308 } | |
1309 | |
14088
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
1310 set_properties (properties, i, object); |
3553
5f9688c0b704
(Fadd_text_properties): Don't treat the initial
Richard M. Stallman <rms@gnu.org>
parents:
2783
diff
changeset
|
1311 |
1211 | 1312 if (LENGTH (i) == len) |
16331
32a51f7ba384
(set_properties, add_properties, remove_properties):
Richard M. Stallman <rms@gnu.org>
parents:
16103
diff
changeset
|
1313 { |
26605
46168cb41ba0
(set_text_properties): New function. Like
Gerd Moellmann <gerd@gnu.org>
parents:
26404
diff
changeset
|
1314 if (BUFFERP (object) && !NILP (signal_after_change_p)) |
16339
abcd50093b4e
(Fset_text_properties, Fadd_text_properties)
Richard M. Stallman <rms@gnu.org>
parents:
16331
diff
changeset
|
1315 signal_after_change (XINT (start), XINT (end) - XINT (start), |
abcd50093b4e
(Fset_text_properties, Fadd_text_properties)
Richard M. Stallman <rms@gnu.org>
parents:
16331
diff
changeset
|
1316 XINT (end) - XINT (start)); |
16331
32a51f7ba384
(set_properties, add_properties, remove_properties):
Richard M. Stallman <rms@gnu.org>
parents:
16103
diff
changeset
|
1317 |
32a51f7ba384
(set_properties, add_properties, remove_properties):
Richard M. Stallman <rms@gnu.org>
parents:
16103
diff
changeset
|
1318 return Qt; |
32a51f7ba384
(set_properties, add_properties, remove_properties):
Richard M. Stallman <rms@gnu.org>
parents:
16103
diff
changeset
|
1319 } |
1211 | 1320 |
1321 prev_changed = i; | |
1029 | 1322 len -= LENGTH (i); |
1323 i = next_interval (i); | |
1324 } | |
1325 | |
1283
6f4cbcc62eba
Minor optimizations of Fset_text_properties and Ferase_text_properties.
Joseph Arceneaux <jla@gnu.org>
parents:
1272
diff
changeset
|
1326 /* We are starting at the beginning of an interval, I */ |
1272
bfd04f61eb16
Mods to Ferase_text_properties
Joseph Arceneaux <jla@gnu.org>
parents:
1211
diff
changeset
|
1327 while (len > 0) |
1029 | 1328 { |
1965
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
1329 if (i == 0) |
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
1330 abort (); |
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
1331 |
1029 | 1332 if (LENGTH (i) >= len) |
1333 { | |
1283
6f4cbcc62eba
Minor optimizations of Fset_text_properties and Ferase_text_properties.
Joseph Arceneaux <jla@gnu.org>
parents:
1272
diff
changeset
|
1334 if (LENGTH (i) > len) |
4144
8f5545cf9774
* intervals.c (split_interval_left, split_interval_right): Change
Jim Blandy <jimb@redhat.com>
parents:
4076
diff
changeset
|
1335 i = split_interval_left (i, len); |
1029 | 1336 |
13585
dc00b7be6593
(Fset_text_properties): Call set_properties
Richard M. Stallman <rms@gnu.org>
parents:
13265
diff
changeset
|
1337 /* We have to call set_properties even if we are going to |
dc00b7be6593
(Fset_text_properties): Call set_properties
Richard M. Stallman <rms@gnu.org>
parents:
13265
diff
changeset
|
1338 merge the intervals, so as to make the undo records |
dc00b7be6593
(Fset_text_properties): Call set_properties
Richard M. Stallman <rms@gnu.org>
parents:
13265
diff
changeset
|
1339 and cause redisplay to happen. */ |
14088
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
1340 set_properties (properties, i, object); |
13585
dc00b7be6593
(Fset_text_properties): Call set_properties
Richard M. Stallman <rms@gnu.org>
parents:
13265
diff
changeset
|
1341 if (!NULL_INTERVAL_P (prev_changed)) |
1211 | 1342 merge_interval_left (i); |
26605
46168cb41ba0
(set_text_properties): New function. Like
Gerd Moellmann <gerd@gnu.org>
parents:
26404
diff
changeset
|
1343 if (BUFFERP (object) && !NILP (signal_after_change_p)) |
16339
abcd50093b4e
(Fset_text_properties, Fadd_text_properties)
Richard M. Stallman <rms@gnu.org>
parents:
16331
diff
changeset
|
1344 signal_after_change (XINT (start), XINT (end) - XINT (start), |
abcd50093b4e
(Fset_text_properties, Fadd_text_properties)
Richard M. Stallman <rms@gnu.org>
parents:
16331
diff
changeset
|
1345 XINT (end) - XINT (start)); |
1029 | 1346 return Qt; |
1347 } | |
1348 | |
1349 len -= LENGTH (i); | |
13585
dc00b7be6593
(Fset_text_properties): Call set_properties
Richard M. Stallman <rms@gnu.org>
parents:
13265
diff
changeset
|
1350 |
dc00b7be6593
(Fset_text_properties): Call set_properties
Richard M. Stallman <rms@gnu.org>
parents:
13265
diff
changeset
|
1351 /* We have to call set_properties even if we are going to |
dc00b7be6593
(Fset_text_properties): Call set_properties
Richard M. Stallman <rms@gnu.org>
parents:
13265
diff
changeset
|
1352 merge the intervals, so as to make the undo records |
dc00b7be6593
(Fset_text_properties): Call set_properties
Richard M. Stallman <rms@gnu.org>
parents:
13265
diff
changeset
|
1353 and cause redisplay to happen. */ |
14088
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
1354 set_properties (properties, i, object); |
1211 | 1355 if (NULL_INTERVAL_P (prev_changed)) |
13585
dc00b7be6593
(Fset_text_properties): Call set_properties
Richard M. Stallman <rms@gnu.org>
parents:
13265
diff
changeset
|
1356 prev_changed = i; |
1211 | 1357 else |
1358 prev_changed = i = merge_interval_left (i); | |
1359 | |
1029 | 1360 i = next_interval (i); |
1361 } | |
1362 | |
26605
46168cb41ba0
(set_text_properties): New function. Like
Gerd Moellmann <gerd@gnu.org>
parents:
26404
diff
changeset
|
1363 if (BUFFERP (object) && !NILP (signal_after_change_p)) |
16339
abcd50093b4e
(Fset_text_properties, Fadd_text_properties)
Richard M. Stallman <rms@gnu.org>
parents:
16331
diff
changeset
|
1364 signal_after_change (XINT (start), XINT (end) - XINT (start), |
abcd50093b4e
(Fset_text_properties, Fadd_text_properties)
Richard M. Stallman <rms@gnu.org>
parents:
16331
diff
changeset
|
1365 XINT (end) - XINT (start)); |
1029 | 1366 return Qt; |
1367 } | |
1368 | |
1369 DEFUN ("remove-text-properties", Fremove_text_properties, | |
1857
9d65dfc7bdb7
(Fadd_text_properties): Put OBJECT arg last. Make it optional.
Richard M. Stallman <rms@gnu.org>
parents:
1715
diff
changeset
|
1370 Sremove_text_properties, 3, 4, 0, |
9d65dfc7bdb7
(Fadd_text_properties): Put OBJECT arg last. Make it optional.
Richard M. Stallman <rms@gnu.org>
parents:
1715
diff
changeset
|
1371 "Remove some properties from text from START to END.\n\ |
14088
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
1372 The third argument PROPERTIES is a property list\n\ |
1857
9d65dfc7bdb7
(Fadd_text_properties): Put OBJECT arg last. Make it optional.
Richard M. Stallman <rms@gnu.org>
parents:
1715
diff
changeset
|
1373 whose property names specify the properties to remove.\n\ |
14088
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
1374 \(The values stored in PROPERTIES are ignored.)\n\ |
1857
9d65dfc7bdb7
(Fadd_text_properties): Put OBJECT arg last. Make it optional.
Richard M. Stallman <rms@gnu.org>
parents:
1715
diff
changeset
|
1375 The optional fourth argument, OBJECT,\n\ |
9d65dfc7bdb7
(Fadd_text_properties): Put OBJECT arg last. Make it optional.
Richard M. Stallman <rms@gnu.org>
parents:
1715
diff
changeset
|
1376 is the string or buffer containing the text.\n\ |
9d65dfc7bdb7
(Fadd_text_properties): Put OBJECT arg last. Make it optional.
Richard M. Stallman <rms@gnu.org>
parents:
1715
diff
changeset
|
1377 Return t if any property was actually removed, nil otherwise.") |
14088
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
1378 (start, end, properties, object) |
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
1379 Lisp_Object start, end, properties, object; |
1029 | 1380 { |
1381 register INTERVAL i, unchanged; | |
2124
54179ef9ce35
* textprop.c (Fadd_text_properties): Initialize the modified flag.
Jim Blandy <jimb@redhat.com>
parents:
2058
diff
changeset
|
1382 register int s, len, modified = 0; |
1029 | 1383 |
1857
9d65dfc7bdb7
(Fadd_text_properties): Put OBJECT arg last. Make it optional.
Richard M. Stallman <rms@gnu.org>
parents:
1715
diff
changeset
|
1384 if (NILP (object)) |
9280
4b238c43e59f
(Ftext_properties_at, Fget_char_property, Fnext_property_change,
Karl Heuer <kwzh@gnu.org>
parents:
9109
diff
changeset
|
1385 XSETBUFFER (object, current_buffer); |
1857
9d65dfc7bdb7
(Fadd_text_properties): Put OBJECT arg last. Make it optional.
Richard M. Stallman <rms@gnu.org>
parents:
1715
diff
changeset
|
1386 |
1029 | 1387 i = validate_interval_range (object, &start, &end, soft); |
1388 if (NULL_INTERVAL_P (i)) | |
1389 return Qnil; | |
1390 | |
1391 s = XINT (start); | |
1392 len = XINT (end) - s; | |
1211 | 1393 |
1029 | 1394 if (i->position != s) |
1395 { | |
1396 /* No properties on this first interval -- return if | |
17467
98c47e7857f3
Style of comments corrected.
Richard M. Stallman <rms@gnu.org>
parents:
16679
diff
changeset
|
1397 it covers the entire region. */ |
14088
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
1398 if (! interval_has_some_properties (properties, i)) |
1029 | 1399 { |
1400 int got = (LENGTH (i) - (s - i->position)); | |
1401 if (got >= len) | |
1402 return Qnil; | |
1403 len -= got; | |
3858
e07d474bdba9
(Fremove_text_properties, Fadd_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
3698
diff
changeset
|
1404 i = next_interval (i); |
1029 | 1405 } |
3553
5f9688c0b704
(Fadd_text_properties): Don't treat the initial
Richard M. Stallman <rms@gnu.org>
parents:
2783
diff
changeset
|
1406 /* Split away the beginning of this interval; what we don't |
5f9688c0b704
(Fadd_text_properties): Don't treat the initial
Richard M. Stallman <rms@gnu.org>
parents:
2783
diff
changeset
|
1407 want to modify. */ |
1029 | 1408 else |
1409 { | |
1410 unchanged = i; | |
4144
8f5545cf9774
* intervals.c (split_interval_left, split_interval_right): Change
Jim Blandy <jimb@redhat.com>
parents:
4076
diff
changeset
|
1411 i = split_interval_right (unchanged, s - unchanged->position); |
1029 | 1412 copy_properties (unchanged, i); |
1413 } | |
1414 } | |
1415 | |
16339
abcd50093b4e
(Fset_text_properties, Fadd_text_properties)
Richard M. Stallman <rms@gnu.org>
parents:
16331
diff
changeset
|
1416 if (BUFFERP (object)) |
abcd50093b4e
(Fset_text_properties, Fadd_text_properties)
Richard M. Stallman <rms@gnu.org>
parents:
16331
diff
changeset
|
1417 modify_region (XBUFFER (object), XINT (start), XINT (end)); |
16331
32a51f7ba384
(set_properties, add_properties, remove_properties):
Richard M. Stallman <rms@gnu.org>
parents:
16103
diff
changeset
|
1418 |
1029 | 1419 /* We are at the beginning of an interval, with len to scan */ |
2124
54179ef9ce35
* textprop.c (Fadd_text_properties): Initialize the modified flag.
Jim Blandy <jimb@redhat.com>
parents:
2058
diff
changeset
|
1420 for (;;) |
1029 | 1421 { |
1965
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
1422 if (i == 0) |
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
1423 abort (); |
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
1424 |
1029 | 1425 if (LENGTH (i) >= len) |
1426 { | |
14088
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
1427 if (! interval_has_some_properties (properties, i)) |
1029 | 1428 return modified ? Qt : Qnil; |
1429 | |
1430 if (LENGTH (i) == len) | |
1431 { | |
14088
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
1432 remove_properties (properties, i, object); |
16339
abcd50093b4e
(Fset_text_properties, Fadd_text_properties)
Richard M. Stallman <rms@gnu.org>
parents:
16331
diff
changeset
|
1433 if (BUFFERP (object)) |
abcd50093b4e
(Fset_text_properties, Fadd_text_properties)
Richard M. Stallman <rms@gnu.org>
parents:
16331
diff
changeset
|
1434 signal_after_change (XINT (start), XINT (end) - XINT (start), |
abcd50093b4e
(Fset_text_properties, Fadd_text_properties)
Richard M. Stallman <rms@gnu.org>
parents:
16331
diff
changeset
|
1435 XINT (end) - XINT (start)); |
1029 | 1436 return Qt; |
1437 } | |
1438 | |
1439 /* i has the properties, and goes past the change limit */ | |
3553
5f9688c0b704
(Fadd_text_properties): Don't treat the initial
Richard M. Stallman <rms@gnu.org>
parents:
2783
diff
changeset
|
1440 unchanged = i; |
4144
8f5545cf9774
* intervals.c (split_interval_left, split_interval_right): Change
Jim Blandy <jimb@redhat.com>
parents:
4076
diff
changeset
|
1441 i = split_interval_left (i, len); |
1029 | 1442 copy_properties (unchanged, i); |
14088
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
1443 remove_properties (properties, i, object); |
16339
abcd50093b4e
(Fset_text_properties, Fadd_text_properties)
Richard M. Stallman <rms@gnu.org>
parents:
16331
diff
changeset
|
1444 if (BUFFERP (object)) |
abcd50093b4e
(Fset_text_properties, Fadd_text_properties)
Richard M. Stallman <rms@gnu.org>
parents:
16331
diff
changeset
|
1445 signal_after_change (XINT (start), XINT (end) - XINT (start), |
abcd50093b4e
(Fset_text_properties, Fadd_text_properties)
Richard M. Stallman <rms@gnu.org>
parents:
16331
diff
changeset
|
1446 XINT (end) - XINT (start)); |
1029 | 1447 return Qt; |
1448 } | |
1449 | |
1450 len -= LENGTH (i); | |
14088
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
1451 modified += remove_properties (properties, i, object); |
1029 | 1452 i = next_interval (i); |
1453 } | |
1454 } | |
16679
38c158927e6f
(Fnext_char_property_change): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16339
diff
changeset
|
1455 |
4144
8f5545cf9774
* intervals.c (split_interval_left, split_interval_right): Change
Jim Blandy <jimb@redhat.com>
parents:
4076
diff
changeset
|
1456 DEFUN ("text-property-any", Ftext_property_any, |
8f5545cf9774
* intervals.c (split_interval_left, split_interval_right): Change
Jim Blandy <jimb@redhat.com>
parents:
4076
diff
changeset
|
1457 Stext_property_any, 4, 5, 0, |
14088
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
1458 "Check text from START to END for property PROPERTY equalling VALUE.\n\ |
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
1459 If so, return the position of the first character whose property PROPERTY\n\ |
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
1460 is `eq' to VALUE. Otherwise return nil.\n\ |
4144
8f5545cf9774
* intervals.c (split_interval_left, split_interval_right): Change
Jim Blandy <jimb@redhat.com>
parents:
4076
diff
changeset
|
1461 The optional fifth argument, OBJECT, is the string or buffer\n\ |
8f5545cf9774
* intervals.c (split_interval_left, split_interval_right): Change
Jim Blandy <jimb@redhat.com>
parents:
4076
diff
changeset
|
1462 containing the text.") |
14088
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
1463 (start, end, property, value, object) |
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
1464 Lisp_Object start, end, property, value, object; |
4144
8f5545cf9774
* intervals.c (split_interval_left, split_interval_right): Change
Jim Blandy <jimb@redhat.com>
parents:
4076
diff
changeset
|
1465 { |
8f5545cf9774
* intervals.c (split_interval_left, split_interval_right): Change
Jim Blandy <jimb@redhat.com>
parents:
4076
diff
changeset
|
1466 register INTERVAL i; |
8f5545cf9774
* intervals.c (split_interval_left, split_interval_right): Change
Jim Blandy <jimb@redhat.com>
parents:
4076
diff
changeset
|
1467 register int e, pos; |
8f5545cf9774
* intervals.c (split_interval_left, split_interval_right): Change
Jim Blandy <jimb@redhat.com>
parents:
4076
diff
changeset
|
1468 |
8f5545cf9774
* intervals.c (split_interval_left, split_interval_right): Change
Jim Blandy <jimb@redhat.com>
parents:
4076
diff
changeset
|
1469 if (NILP (object)) |
9280
4b238c43e59f
(Ftext_properties_at, Fget_char_property, Fnext_property_change,
Karl Heuer <kwzh@gnu.org>
parents:
9109
diff
changeset
|
1470 XSETBUFFER (object, current_buffer); |
4144
8f5545cf9774
* intervals.c (split_interval_left, split_interval_right): Change
Jim Blandy <jimb@redhat.com>
parents:
4076
diff
changeset
|
1471 i = validate_interval_range (object, &start, &end, soft); |
10488
701e7acfe885
(Ftext_property_any): Handle the trivial case specially.
Karl Heuer <kwzh@gnu.org>
parents:
10312
diff
changeset
|
1472 if (NULL_INTERVAL_P (i)) |
701e7acfe885
(Ftext_property_any): Handle the trivial case specially.
Karl Heuer <kwzh@gnu.org>
parents:
10312
diff
changeset
|
1473 return (!NILP (value) || EQ (start, end) ? Qnil : start); |
4144
8f5545cf9774
* intervals.c (split_interval_left, split_interval_right): Change
Jim Blandy <jimb@redhat.com>
parents:
4076
diff
changeset
|
1474 e = XINT (end); |
8f5545cf9774
* intervals.c (split_interval_left, split_interval_right): Change
Jim Blandy <jimb@redhat.com>
parents:
4076
diff
changeset
|
1475 |
8f5545cf9774
* intervals.c (split_interval_left, split_interval_right): Change
Jim Blandy <jimb@redhat.com>
parents:
4076
diff
changeset
|
1476 while (! NULL_INTERVAL_P (i)) |
8f5545cf9774
* intervals.c (split_interval_left, split_interval_right): Change
Jim Blandy <jimb@redhat.com>
parents:
4076
diff
changeset
|
1477 { |
8f5545cf9774
* intervals.c (split_interval_left, split_interval_right): Change
Jim Blandy <jimb@redhat.com>
parents:
4076
diff
changeset
|
1478 if (i->position >= e) |
8f5545cf9774
* intervals.c (split_interval_left, split_interval_right): Change
Jim Blandy <jimb@redhat.com>
parents:
4076
diff
changeset
|
1479 break; |
14088
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
1480 if (EQ (textget (i->plist, property), value)) |
4144
8f5545cf9774
* intervals.c (split_interval_left, split_interval_right): Change
Jim Blandy <jimb@redhat.com>
parents:
4076
diff
changeset
|
1481 { |
8f5545cf9774
* intervals.c (split_interval_left, split_interval_right): Change
Jim Blandy <jimb@redhat.com>
parents:
4076
diff
changeset
|
1482 pos = i->position; |
8f5545cf9774
* intervals.c (split_interval_left, split_interval_right): Change
Jim Blandy <jimb@redhat.com>
parents:
4076
diff
changeset
|
1483 if (pos < XINT (start)) |
8f5545cf9774
* intervals.c (split_interval_left, split_interval_right): Change
Jim Blandy <jimb@redhat.com>
parents:
4076
diff
changeset
|
1484 pos = XINT (start); |
22344
2ec50b4767ed
Handle the new convention that `position' values
Karl Heuer <kwzh@gnu.org>
parents:
22280
diff
changeset
|
1485 return make_number (pos); |
4144
8f5545cf9774
* intervals.c (split_interval_left, split_interval_right): Change
Jim Blandy <jimb@redhat.com>
parents:
4076
diff
changeset
|
1486 } |
8f5545cf9774
* intervals.c (split_interval_left, split_interval_right): Change
Jim Blandy <jimb@redhat.com>
parents:
4076
diff
changeset
|
1487 i = next_interval (i); |
8f5545cf9774
* intervals.c (split_interval_left, split_interval_right): Change
Jim Blandy <jimb@redhat.com>
parents:
4076
diff
changeset
|
1488 } |
8f5545cf9774
* intervals.c (split_interval_left, split_interval_right): Change
Jim Blandy <jimb@redhat.com>
parents:
4076
diff
changeset
|
1489 return Qnil; |
8f5545cf9774
* intervals.c (split_interval_left, split_interval_right): Change
Jim Blandy <jimb@redhat.com>
parents:
4076
diff
changeset
|
1490 } |
8f5545cf9774
* intervals.c (split_interval_left, split_interval_right): Change
Jim Blandy <jimb@redhat.com>
parents:
4076
diff
changeset
|
1491 |
8f5545cf9774
* intervals.c (split_interval_left, split_interval_right): Change
Jim Blandy <jimb@redhat.com>
parents:
4076
diff
changeset
|
1492 DEFUN ("text-property-not-all", Ftext_property_not_all, |
8f5545cf9774
* intervals.c (split_interval_left, split_interval_right): Change
Jim Blandy <jimb@redhat.com>
parents:
4076
diff
changeset
|
1493 Stext_property_not_all, 4, 5, 0, |
14088
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
1494 "Check text from START to END for property PROPERTY not equalling VALUE.\n\ |
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
1495 If so, return the position of the first character whose property PROPERTY\n\ |
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
1496 is not `eq' to VALUE. Otherwise, return nil.\n\ |
4144
8f5545cf9774
* intervals.c (split_interval_left, split_interval_right): Change
Jim Blandy <jimb@redhat.com>
parents:
4076
diff
changeset
|
1497 The optional fifth argument, OBJECT, is the string or buffer\n\ |
8f5545cf9774
* intervals.c (split_interval_left, split_interval_right): Change
Jim Blandy <jimb@redhat.com>
parents:
4076
diff
changeset
|
1498 containing the text.") |
14088
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
1499 (start, end, property, value, object) |
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
1500 Lisp_Object start, end, property, value, object; |
4144
8f5545cf9774
* intervals.c (split_interval_left, split_interval_right): Change
Jim Blandy <jimb@redhat.com>
parents:
4076
diff
changeset
|
1501 { |
8f5545cf9774
* intervals.c (split_interval_left, split_interval_right): Change
Jim Blandy <jimb@redhat.com>
parents:
4076
diff
changeset
|
1502 register INTERVAL i; |
8f5545cf9774
* intervals.c (split_interval_left, split_interval_right): Change
Jim Blandy <jimb@redhat.com>
parents:
4076
diff
changeset
|
1503 register int s, e; |
8f5545cf9774
* intervals.c (split_interval_left, split_interval_right): Change
Jim Blandy <jimb@redhat.com>
parents:
4076
diff
changeset
|
1504 |
8f5545cf9774
* intervals.c (split_interval_left, split_interval_right): Change
Jim Blandy <jimb@redhat.com>
parents:
4076
diff
changeset
|
1505 if (NILP (object)) |
9280
4b238c43e59f
(Ftext_properties_at, Fget_char_property, Fnext_property_change,
Karl Heuer <kwzh@gnu.org>
parents:
9109
diff
changeset
|
1506 XSETBUFFER (object, current_buffer); |
4144
8f5545cf9774
* intervals.c (split_interval_left, split_interval_right): Change
Jim Blandy <jimb@redhat.com>
parents:
4076
diff
changeset
|
1507 i = validate_interval_range (object, &start, &end, soft); |
8f5545cf9774
* intervals.c (split_interval_left, split_interval_right): Change
Jim Blandy <jimb@redhat.com>
parents:
4076
diff
changeset
|
1508 if (NULL_INTERVAL_P (i)) |
5114
b37f62d72049
(Ftext_property_not_all): For trivial yes, return start, not Qt.
Richard M. Stallman <rms@gnu.org>
parents:
5086
diff
changeset
|
1509 return (NILP (value) || EQ (start, end)) ? Qnil : start; |
4144
8f5545cf9774
* intervals.c (split_interval_left, split_interval_right): Change
Jim Blandy <jimb@redhat.com>
parents:
4076
diff
changeset
|
1510 s = XINT (start); |
8f5545cf9774
* intervals.c (split_interval_left, split_interval_right): Change
Jim Blandy <jimb@redhat.com>
parents:
4076
diff
changeset
|
1511 e = XINT (end); |
8f5545cf9774
* intervals.c (split_interval_left, split_interval_right): Change
Jim Blandy <jimb@redhat.com>
parents:
4076
diff
changeset
|
1512 |
8f5545cf9774
* intervals.c (split_interval_left, split_interval_right): Change
Jim Blandy <jimb@redhat.com>
parents:
4076
diff
changeset
|
1513 while (! NULL_INTERVAL_P (i)) |
8f5545cf9774
* intervals.c (split_interval_left, split_interval_right): Change
Jim Blandy <jimb@redhat.com>
parents:
4076
diff
changeset
|
1514 { |
8f5545cf9774
* intervals.c (split_interval_left, split_interval_right): Change
Jim Blandy <jimb@redhat.com>
parents:
4076
diff
changeset
|
1515 if (i->position >= e) |
8f5545cf9774
* intervals.c (split_interval_left, split_interval_right): Change
Jim Blandy <jimb@redhat.com>
parents:
4076
diff
changeset
|
1516 break; |
14088
dc754f92a2a4
(Ftext_properties_at, Fget_text_property, Fget_char_property,
Erik Naggum <erik@naggum.no>
parents:
14036
diff
changeset
|
1517 if (! EQ (textget (i->plist, property), value)) |
4144
8f5545cf9774
* intervals.c (split_interval_left, split_interval_right): Change
Jim Blandy <jimb@redhat.com>
parents:
4076
diff
changeset
|
1518 { |
8f5545cf9774
* intervals.c (split_interval_left, split_interval_right): Change
Jim Blandy <jimb@redhat.com>
parents:
4076
diff
changeset
|
1519 if (i->position > s) |
8f5545cf9774
* intervals.c (split_interval_left, split_interval_right): Change
Jim Blandy <jimb@redhat.com>
parents:
4076
diff
changeset
|
1520 s = i->position; |
22344
2ec50b4767ed
Handle the new convention that `position' values
Karl Heuer <kwzh@gnu.org>
parents:
22280
diff
changeset
|
1521 return make_number (s); |
4144
8f5545cf9774
* intervals.c (split_interval_left, split_interval_right): Change
Jim Blandy <jimb@redhat.com>
parents:
4076
diff
changeset
|
1522 } |
8f5545cf9774
* intervals.c (split_interval_left, split_interval_right): Change
Jim Blandy <jimb@redhat.com>
parents:
4076
diff
changeset
|
1523 i = next_interval (i); |
8f5545cf9774
* intervals.c (split_interval_left, split_interval_right): Change
Jim Blandy <jimb@redhat.com>
parents:
4076
diff
changeset
|
1524 } |
8f5545cf9774
* intervals.c (split_interval_left, split_interval_right): Change
Jim Blandy <jimb@redhat.com>
parents:
4076
diff
changeset
|
1525 return Qnil; |
8f5545cf9774
* intervals.c (split_interval_left, split_interval_right): Change
Jim Blandy <jimb@redhat.com>
parents:
4076
diff
changeset
|
1526 } |
16679
38c158927e6f
(Fnext_char_property_change): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16339
diff
changeset
|
1527 |
4007
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1528 /* I don't think this is the right interface to export; how often do you |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1529 want to do something like this, other than when you're copying objects |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1530 around? |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1531 |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1532 I think it would be better to have a pair of functions, one which |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1533 returns the text properties of a region as a list of ranges and |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1534 plists, and another which applies such a list to another object. */ |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1535 |
10159
1299d37b51bb
(add_properties): Add gcpro's.
Richard M. Stallman <rms@gnu.org>
parents:
9945
diff
changeset
|
1536 /* Add properties from SRC to SRC of SRC, starting at POS in DEST. |
1299d37b51bb
(add_properties): Add gcpro's.
Richard M. Stallman <rms@gnu.org>
parents:
9945
diff
changeset
|
1537 SRC and DEST may each refer to strings or buffers. |
1299d37b51bb
(add_properties): Add gcpro's.
Richard M. Stallman <rms@gnu.org>
parents:
9945
diff
changeset
|
1538 Optional sixth argument PROP causes only that property to be copied. |
1299d37b51bb
(add_properties): Add gcpro's.
Richard M. Stallman <rms@gnu.org>
parents:
9945
diff
changeset
|
1539 Properties are copied to DEST as if by `add-text-properties'. |
1299d37b51bb
(add_properties): Add gcpro's.
Richard M. Stallman <rms@gnu.org>
parents:
9945
diff
changeset
|
1540 Return t if any property value actually changed, nil otherwise. */ |
1299d37b51bb
(add_properties): Add gcpro's.
Richard M. Stallman <rms@gnu.org>
parents:
9945
diff
changeset
|
1541 |
1299d37b51bb
(add_properties): Add gcpro's.
Richard M. Stallman <rms@gnu.org>
parents:
9945
diff
changeset
|
1542 /* Note this can GC when DEST is a buffer. */ |
22344
2ec50b4767ed
Handle the new convention that `position' values
Karl Heuer <kwzh@gnu.org>
parents:
22280
diff
changeset
|
1543 |
4007
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1544 Lisp_Object |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1545 copy_text_properties (start, end, src, pos, dest, prop) |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1546 Lisp_Object start, end, src, pos, dest, prop; |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1547 { |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1548 INTERVAL i; |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1549 Lisp_Object res; |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1550 Lisp_Object stuff; |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1551 Lisp_Object plist; |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1552 int s, e, e2, p, len, modified = 0; |
10159
1299d37b51bb
(add_properties): Add gcpro's.
Richard M. Stallman <rms@gnu.org>
parents:
9945
diff
changeset
|
1553 struct gcpro gcpro1, gcpro2; |
4007
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1554 |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1555 i = validate_interval_range (src, &start, &end, soft); |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1556 if (NULL_INTERVAL_P (i)) |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1557 return Qnil; |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1558 |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1559 CHECK_NUMBER_COERCE_MARKER (pos, 0); |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1560 { |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1561 Lisp_Object dest_start, dest_end; |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1562 |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1563 dest_start = pos; |
9321
e6759002383c
(Fnext_property_change, property_change_between_p,
Karl Heuer <kwzh@gnu.org>
parents:
9280
diff
changeset
|
1564 XSETFASTINT (dest_end, XINT (dest_start) + (XINT (end) - XINT (start))); |
4007
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1565 /* Apply this to a copy of pos; it will try to increment its arguments, |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1566 which we don't want. */ |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1567 validate_interval_range (dest, &dest_start, &dest_end, soft); |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1568 } |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1569 |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1570 s = XINT (start); |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1571 e = XINT (end); |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1572 p = XINT (pos); |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1573 |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1574 stuff = Qnil; |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1575 |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1576 while (s < e) |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1577 { |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1578 e2 = i->position + LENGTH (i); |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1579 if (e2 > e) |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1580 e2 = e; |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1581 len = e2 - s; |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1582 |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1583 plist = i->plist; |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1584 if (! NILP (prop)) |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1585 while (! NILP (plist)) |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1586 { |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1587 if (EQ (Fcar (plist), prop)) |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1588 { |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1589 plist = Fcons (prop, Fcons (Fcar (Fcdr (plist)), Qnil)); |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1590 break; |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1591 } |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1592 plist = Fcdr (Fcdr (plist)); |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1593 } |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1594 if (! NILP (plist)) |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1595 { |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1596 /* Must defer modifications to the interval tree in case src |
17467
98c47e7857f3
Style of comments corrected.
Richard M. Stallman <rms@gnu.org>
parents:
16679
diff
changeset
|
1597 and dest refer to the same string or buffer. */ |
4007
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1598 stuff = Fcons (Fcons (make_number (p), |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1599 Fcons (make_number (p + len), |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1600 Fcons (plist, Qnil))), |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1601 stuff); |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1602 } |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1603 |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1604 i = next_interval (i); |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1605 if (NULL_INTERVAL_P (i)) |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1606 break; |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1607 |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1608 p += len; |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1609 s = i->position; |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1610 } |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1611 |
10159
1299d37b51bb
(add_properties): Add gcpro's.
Richard M. Stallman <rms@gnu.org>
parents:
9945
diff
changeset
|
1612 GCPRO2 (stuff, dest); |
1299d37b51bb
(add_properties): Add gcpro's.
Richard M. Stallman <rms@gnu.org>
parents:
9945
diff
changeset
|
1613 |
4007
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1614 while (! NILP (stuff)) |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1615 { |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1616 res = Fcar (stuff); |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1617 res = Fadd_text_properties (Fcar (res), Fcar (Fcdr (res)), |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1618 Fcar (Fcdr (Fcdr (res))), dest); |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1619 if (! NILP (res)) |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1620 modified++; |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1621 stuff = Fcdr (stuff); |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1622 } |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1623 |
10159
1299d37b51bb
(add_properties): Add gcpro's.
Richard M. Stallman <rms@gnu.org>
parents:
9945
diff
changeset
|
1624 UNGCPRO; |
1299d37b51bb
(add_properties): Add gcpro's.
Richard M. Stallman <rms@gnu.org>
parents:
9945
diff
changeset
|
1625 |
4007
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1626 return modified ? Qt : Qnil; |
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1627 } |
25000 | 1628 |
1629 | |
1630 /* Return a list representing the text properties of OBJECT between | |
1631 START and END. if PROP is non-nil, report only on that property. | |
1632 Each result list element has the form (S E PLIST), where S and E | |
1633 are positions in OBJECT and PLIST is a property list containing the | |
1634 text properties of OBJECT between S and E. Value is nil if OBJECT | |
1635 doesn't contain text properties between START and END. */ | |
1636 | |
1637 Lisp_Object | |
1638 text_property_list (object, start, end, prop) | |
1639 Lisp_Object object, start, end, prop; | |
1640 { | |
1641 struct interval *i; | |
1642 Lisp_Object result; | |
1643 | |
1644 result = Qnil; | |
1645 | |
1646 i = validate_interval_range (object, &start, &end, soft); | |
1647 if (!NULL_INTERVAL_P (i)) | |
1648 { | |
1649 int s = XINT (start); | |
1650 int e = XINT (end); | |
1651 | |
1652 while (s < e) | |
1653 { | |
1654 int interval_end, len; | |
1655 Lisp_Object plist; | |
1656 | |
1657 interval_end = i->position + LENGTH (i); | |
1658 if (interval_end > e) | |
1659 interval_end = e; | |
1660 len = interval_end - s; | |
1661 | |
1662 plist = i->plist; | |
1663 | |
1664 if (!NILP (prop)) | |
1665 for (; !NILP (plist); plist = Fcdr (Fcdr (plist))) | |
1666 if (EQ (Fcar (plist), prop)) | |
1667 { | |
1668 plist = Fcons (prop, Fcons (Fcar (Fcdr (plist)), Qnil)); | |
1669 break; | |
1670 } | |
1671 | |
1672 if (!NILP (plist)) | |
1673 result = Fcons (Fcons (make_number (s), | |
1674 Fcons (make_number (s + len), | |
1675 Fcons (plist, Qnil))), | |
1676 result); | |
1677 | |
1678 i = next_interval (i); | |
1679 if (NULL_INTERVAL_P (i)) | |
1680 break; | |
1681 s = i->position; | |
1682 } | |
1683 } | |
1684 | |
1685 return result; | |
1686 } | |
1687 | |
1688 | |
1689 /* Add text properties to OBJECT from LIST. LIST is a list of triples | |
1690 (START END PLIST), where START and END are positions and PLIST is a | |
1691 property list containing the text properties to add. Adjust START | |
1692 and END positions by DELTA before adding properties. Value is | |
1693 non-zero if OBJECT was modified. */ | |
1694 | |
1695 int | |
1696 add_text_properties_from_list (object, list, delta) | |
1697 Lisp_Object object, list, delta; | |
1698 { | |
1699 struct gcpro gcpro1, gcpro2; | |
1700 int modified_p = 0; | |
1701 | |
1702 GCPRO2 (list, object); | |
1703 | |
1704 for (; CONSP (list); list = XCDR (list)) | |
1705 { | |
1706 Lisp_Object item, start, end, plist, tem; | |
1707 | |
1708 item = XCAR (list); | |
1709 start = make_number (XINT (XCAR (item)) + XINT (delta)); | |
1710 end = make_number (XINT (XCAR (XCDR (item))) + XINT (delta)); | |
1711 plist = XCAR (XCDR (XCDR (item))); | |
1712 | |
1713 tem = Fadd_text_properties (start, end, plist, object); | |
1714 if (!NILP (tem)) | |
1715 modified_p = 1; | |
1716 } | |
1717 | |
1718 UNGCPRO; | |
1719 return modified_p; | |
1720 } | |
1721 | |
1722 | |
1723 | |
1724 /* Modify end-points of ranges in LIST destructively. LIST is a list | |
1725 as returned from text_property_list. Change end-points equal to | |
1726 OLD_END to NEW_END. */ | |
1727 | |
1728 void | |
1729 extend_property_ranges (list, old_end, new_end) | |
1730 Lisp_Object list, old_end, new_end; | |
1731 { | |
1732 for (; CONSP (list); list = XCDR (list)) | |
1733 { | |
1734 Lisp_Object item, end; | |
1735 | |
1736 item = XCAR (list); | |
1737 end = XCAR (XCDR (item)); | |
1738 | |
1739 if (EQ (end, old_end)) | |
25645
a14111a2a100
Use XCAR, XCDR, XFLOAT_DATA instead of explicit member access.
Ken Raeburn <raeburn@raeburn.org>
parents:
25000
diff
changeset
|
1740 XCAR (XCDR (item)) = new_end; |
25000 | 1741 } |
1742 } | |
1743 | |
1744 | |
13027
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1745 |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1746 /* Call the modification hook functions in LIST, each with START and END. */ |
4007
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
1747 |
13027
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1748 static void |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1749 call_mod_hooks (list, start, end) |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1750 Lisp_Object list, start, end; |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1751 { |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1752 struct gcpro gcpro1; |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1753 GCPRO1 (list); |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1754 while (!NILP (list)) |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1755 { |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1756 call2 (Fcar (list), start, end); |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1757 list = Fcdr (list); |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1758 } |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1759 UNGCPRO; |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1760 } |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1761 |
20522
4409f95651d1
(Ftext_properties_at): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
18736
diff
changeset
|
1762 /* Check for read-only intervals between character positions START ... END, |
4409f95651d1
(Ftext_properties_at): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
18736
diff
changeset
|
1763 in BUF, and signal an error if we find one. |
4409f95651d1
(Ftext_properties_at): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
18736
diff
changeset
|
1764 |
4409f95651d1
(Ftext_properties_at): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
18736
diff
changeset
|
1765 Then check for any modification hooks in the range. |
4409f95651d1
(Ftext_properties_at): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
18736
diff
changeset
|
1766 Create a list of all these hooks in lexicographic order, |
4409f95651d1
(Ftext_properties_at): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
18736
diff
changeset
|
1767 eliminating consecutive extra copies of the same hook. Then call |
4409f95651d1
(Ftext_properties_at): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
18736
diff
changeset
|
1768 those hooks in order, with START and END - 1 as arguments. */ |
13027
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1769 |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1770 void |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1771 verify_interval_modification (buf, start, end) |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1772 struct buffer *buf; |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1773 int start, end; |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1774 { |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1775 register INTERVAL intervals = BUF_INTERVALS (buf); |
25772
1902e7e63fa7
(Fset_text_properties): Remove unused variables.
Gerd Moellmann <gerd@gnu.org>
parents:
25645
diff
changeset
|
1776 register INTERVAL i; |
13027
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1777 Lisp_Object hooks; |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1778 register Lisp_Object prev_mod_hooks; |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1779 Lisp_Object mod_hooks; |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1780 struct gcpro gcpro1; |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1781 |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1782 hooks = Qnil; |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1783 prev_mod_hooks = Qnil; |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1784 mod_hooks = Qnil; |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1785 |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1786 interval_insert_behind_hooks = Qnil; |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1787 interval_insert_in_front_hooks = Qnil; |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1788 |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1789 if (NULL_INTERVAL_P (intervals)) |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1790 return; |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1791 |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1792 if (start > end) |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1793 { |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1794 int temp = start; |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1795 start = end; |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1796 end = temp; |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1797 } |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1798 |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1799 /* For an insert operation, check the two chars around the position. */ |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1800 if (start == end) |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1801 { |
33952
ca22422634ac
(text_read_only): New function.
Gerd Moellmann <gerd@gnu.org>
parents:
32849
diff
changeset
|
1802 INTERVAL prev = NULL; |
13027
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1803 Lisp_Object before, after; |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1804 |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1805 /* Set I to the interval containing the char after START, |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1806 and PREV to the interval containing the char before START. |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1807 Either one may be null. They may be equal. */ |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1808 i = find_interval (intervals, start); |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1809 |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1810 if (start == BUF_BEGV (buf)) |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1811 prev = 0; |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1812 else if (i->position == start) |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1813 prev = previous_interval (i); |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1814 else if (i->position < start) |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1815 prev = i; |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1816 if (start == BUF_ZV (buf)) |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1817 i = 0; |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1818 |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1819 /* If Vinhibit_read_only is set and is not a list, we can |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1820 skip the read_only checks. */ |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1821 if (NILP (Vinhibit_read_only) || CONSP (Vinhibit_read_only)) |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1822 { |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1823 /* If I and PREV differ we need to check for the read-only |
17467
98c47e7857f3
Style of comments corrected.
Richard M. Stallman <rms@gnu.org>
parents:
16679
diff
changeset
|
1824 property together with its stickiness. If either I or |
13027
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1825 PREV are 0, this check is all we need. |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1826 We have to take special care, since read-only may be |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1827 indirectly defined via the category property. */ |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1828 if (i != prev) |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1829 { |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1830 if (! NULL_INTERVAL_P (i)) |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1831 { |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1832 after = textget (i->plist, Qread_only); |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1833 |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1834 /* If interval I is read-only and read-only is |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1835 front-sticky, inhibit insertion. |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1836 Check for read-only as well as category. */ |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1837 if (! NILP (after) |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1838 && NILP (Fmemq (after, Vinhibit_read_only))) |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1839 { |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1840 Lisp_Object tem; |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1841 |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1842 tem = textget (i->plist, Qfront_sticky); |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1843 if (TMEM (Qread_only, tem) |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1844 || (NILP (Fplist_get (i->plist, Qread_only)) |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1845 && TMEM (Qcategory, tem))) |
33952
ca22422634ac
(text_read_only): New function.
Gerd Moellmann <gerd@gnu.org>
parents:
32849
diff
changeset
|
1846 text_read_only (); |
13027
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1847 } |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1848 } |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1849 |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1850 if (! NULL_INTERVAL_P (prev)) |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1851 { |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1852 before = textget (prev->plist, Qread_only); |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1853 |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1854 /* If interval PREV is read-only and read-only isn't |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1855 rear-nonsticky, inhibit insertion. |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1856 Check for read-only as well as category. */ |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1857 if (! NILP (before) |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1858 && NILP (Fmemq (before, Vinhibit_read_only))) |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1859 { |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1860 Lisp_Object tem; |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1861 |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1862 tem = textget (prev->plist, Qrear_nonsticky); |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1863 if (! TMEM (Qread_only, tem) |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1864 && (! NILP (Fplist_get (prev->plist,Qread_only)) |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1865 || ! TMEM (Qcategory, tem))) |
33952
ca22422634ac
(text_read_only): New function.
Gerd Moellmann <gerd@gnu.org>
parents:
32849
diff
changeset
|
1866 text_read_only (); |
13027
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1867 } |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1868 } |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1869 } |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1870 else if (! NULL_INTERVAL_P (i)) |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1871 { |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1872 after = textget (i->plist, Qread_only); |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1873 |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1874 /* If interval I is read-only and read-only is |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1875 front-sticky, inhibit insertion. |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1876 Check for read-only as well as category. */ |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1877 if (! NILP (after) && NILP (Fmemq (after, Vinhibit_read_only))) |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1878 { |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1879 Lisp_Object tem; |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1880 |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1881 tem = textget (i->plist, Qfront_sticky); |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1882 if (TMEM (Qread_only, tem) |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1883 || (NILP (Fplist_get (i->plist, Qread_only)) |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1884 && TMEM (Qcategory, tem))) |
33952
ca22422634ac
(text_read_only): New function.
Gerd Moellmann <gerd@gnu.org>
parents:
32849
diff
changeset
|
1885 text_read_only (); |
13027
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1886 |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1887 tem = textget (prev->plist, Qrear_nonsticky); |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1888 if (! TMEM (Qread_only, tem) |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1889 && (! NILP (Fplist_get (prev->plist, Qread_only)) |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1890 || ! TMEM (Qcategory, tem))) |
33952
ca22422634ac
(text_read_only): New function.
Gerd Moellmann <gerd@gnu.org>
parents:
32849
diff
changeset
|
1891 text_read_only (); |
13027
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1892 } |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1893 } |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1894 } |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1895 |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1896 /* Run both insert hooks (just once if they're the same). */ |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1897 if (!NULL_INTERVAL_P (prev)) |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1898 interval_insert_behind_hooks |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1899 = textget (prev->plist, Qinsert_behind_hooks); |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1900 if (!NULL_INTERVAL_P (i)) |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1901 interval_insert_in_front_hooks |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1902 = textget (i->plist, Qinsert_in_front_hooks); |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1903 } |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1904 else |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1905 { |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1906 /* Loop over intervals on or next to START...END, |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1907 collecting their hooks. */ |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1908 |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1909 i = find_interval (intervals, start); |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1910 do |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1911 { |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1912 if (! INTERVAL_WRITABLE_P (i)) |
33952
ca22422634ac
(text_read_only): New function.
Gerd Moellmann <gerd@gnu.org>
parents:
32849
diff
changeset
|
1913 text_read_only (); |
13027
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1914 |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1915 mod_hooks = textget (i->plist, Qmodification_hooks); |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1916 if (! NILP (mod_hooks) && ! EQ (mod_hooks, prev_mod_hooks)) |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1917 { |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1918 hooks = Fcons (mod_hooks, hooks); |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1919 prev_mod_hooks = mod_hooks; |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1920 } |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1921 |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1922 i = next_interval (i); |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1923 } |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1924 /* Keep going thru the interval containing the char before END. */ |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1925 while (! NULL_INTERVAL_P (i) && i->position < end); |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1926 |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1927 GCPRO1 (hooks); |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1928 hooks = Fnreverse (hooks); |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1929 while (! EQ (hooks, Qnil)) |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1930 { |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1931 call_mod_hooks (Fcar (hooks), make_number (start), |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1932 make_number (end)); |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1933 hooks = Fcdr (hooks); |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1934 } |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1935 UNGCPRO; |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1936 } |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1937 } |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1938 |
20522
4409f95651d1
(Ftext_properties_at): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
18736
diff
changeset
|
1939 /* Run the interval hooks for an insertion on character range START ... END. |
13027
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1940 verify_interval_modification chose which hooks to run; |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1941 this function is called after the insertion happens |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1942 so it can indicate the range of inserted text. */ |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1943 |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1944 void |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1945 report_interval_modification (start, end) |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1946 Lisp_Object start, end; |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1947 { |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1948 if (! NILP (interval_insert_behind_hooks)) |
18613
614b916ff5bf
Fix bugs with inappropriate mixing of Lisp_Object with int.
Richard M. Stallman <rms@gnu.org>
parents:
17467
diff
changeset
|
1949 call_mod_hooks (interval_insert_behind_hooks, start, end); |
13027
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1950 if (! NILP (interval_insert_in_front_hooks) |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1951 && ! EQ (interval_insert_in_front_hooks, |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1952 interval_insert_behind_hooks)) |
18613
614b916ff5bf
Fix bugs with inappropriate mixing of Lisp_Object with int.
Richard M. Stallman <rms@gnu.org>
parents:
17467
diff
changeset
|
1953 call_mod_hooks (interval_insert_in_front_hooks, start, end); |
13027
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1954 } |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1955 |
1029 | 1956 void |
1957 syms_of_textprop () | |
1958 { | |
11131
5db8a01b22cb
(Vdefault_text_properties): name changed from Vdefault_properties.
Boris Goldowsky <boris@gnu.org>
parents:
11116
diff
changeset
|
1959 DEFVAR_LISP ("default-text-properties", &Vdefault_text_properties, |
10925
0480d65be55d
(Vdefault_properties): New vbl.
Boris Goldowsky <boris@gnu.org>
parents:
10488
diff
changeset
|
1960 "Property-list used as default values.\n\ |
11131
5db8a01b22cb
(Vdefault_text_properties): name changed from Vdefault_properties.
Boris Goldowsky <boris@gnu.org>
parents:
11116
diff
changeset
|
1961 The value of a property in this list is seen as the value for every\n\ |
5db8a01b22cb
(Vdefault_text_properties): name changed from Vdefault_properties.
Boris Goldowsky <boris@gnu.org>
parents:
11116
diff
changeset
|
1962 character that does not have its own value for that property."); |
5db8a01b22cb
(Vdefault_text_properties): name changed from Vdefault_properties.
Boris Goldowsky <boris@gnu.org>
parents:
11116
diff
changeset
|
1963 Vdefault_text_properties = Qnil; |
10925
0480d65be55d
(Vdefault_properties): New vbl.
Boris Goldowsky <boris@gnu.org>
parents:
10488
diff
changeset
|
1964 |
4242
49007dbbec4c
(syms_of_textprop): Set up Lisp var Vinhibit_point_motion_hooks.
Richard M. Stallman <rms@gnu.org>
parents:
4214
diff
changeset
|
1965 DEFVAR_LISP ("inhibit-point-motion-hooks", &Vinhibit_point_motion_hooks, |
9071
2d4d0f6e7be0
(syms_of_textprop): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
8962
diff
changeset
|
1966 "If non-nil, don't run `point-left' and `point-entered' text properties.\n\ |
2d4d0f6e7be0
(syms_of_textprop): Doc fix.
Richard M. Stallman <rms@gnu.org>
parents:
8962
diff
changeset
|
1967 This also inhibits the use of the `intangible' text property."); |
4242
49007dbbec4c
(syms_of_textprop): Set up Lisp var Vinhibit_point_motion_hooks.
Richard M. Stallman <rms@gnu.org>
parents:
4214
diff
changeset
|
1968 Vinhibit_point_motion_hooks = Qnil; |
13027
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1969 |
26872
ea588757e607
(Vtext_property_default_nonsticky): New variable
Kenichi Handa <handa@m17n.org>
parents:
26605
diff
changeset
|
1970 DEFVAR_LISP ("text-property-default-nonsticky", |
ea588757e607
(Vtext_property_default_nonsticky): New variable
Kenichi Handa <handa@m17n.org>
parents:
26605
diff
changeset
|
1971 &Vtext_property_default_nonsticky, |
ea588757e607
(Vtext_property_default_nonsticky): New variable
Kenichi Handa <handa@m17n.org>
parents:
26605
diff
changeset
|
1972 "Alist of properties vs the corresponding non-stickinesses.\n\ |
ea588757e607
(Vtext_property_default_nonsticky): New variable
Kenichi Handa <handa@m17n.org>
parents:
26605
diff
changeset
|
1973 Each element has the form (PROPERTY . NONSTICKINESS).\n\ |
ea588757e607
(Vtext_property_default_nonsticky): New variable
Kenichi Handa <handa@m17n.org>
parents:
26605
diff
changeset
|
1974 \n\ |
ea588757e607
(Vtext_property_default_nonsticky): New variable
Kenichi Handa <handa@m17n.org>
parents:
26605
diff
changeset
|
1975 If a character in a buffer has PROPERTY, new text inserted adjacent to\n\ |
ea588757e607
(Vtext_property_default_nonsticky): New variable
Kenichi Handa <handa@m17n.org>
parents:
26605
diff
changeset
|
1976 the character doesn't inherit PROPERTY if NONSTICKINESS is non-nil,\n\ |
ea588757e607
(Vtext_property_default_nonsticky): New variable
Kenichi Handa <handa@m17n.org>
parents:
26605
diff
changeset
|
1977 inherits it if NONSTICKINESS is nil. The front-sticky and\n\ |
ea588757e607
(Vtext_property_default_nonsticky): New variable
Kenichi Handa <handa@m17n.org>
parents:
26605
diff
changeset
|
1978 rear-nonsticky properties of the character overrides NONSTICKINESS."); |
ea588757e607
(Vtext_property_default_nonsticky): New variable
Kenichi Handa <handa@m17n.org>
parents:
26605
diff
changeset
|
1979 Vtext_property_default_nonsticky = Qnil; |
ea588757e607
(Vtext_property_default_nonsticky): New variable
Kenichi Handa <handa@m17n.org>
parents:
26605
diff
changeset
|
1980 |
13027
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1981 staticpro (&interval_insert_behind_hooks); |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1982 staticpro (&interval_insert_in_front_hooks); |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1983 interval_insert_behind_hooks = Qnil; |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1984 interval_insert_in_front_hooks = Qnil; |
48358e0fa98e
(call_mod_hooks): Moved from intevals.c
Richard M. Stallman <rms@gnu.org>
parents:
12641
diff
changeset
|
1985 |
4242
49007dbbec4c
(syms_of_textprop): Set up Lisp var Vinhibit_point_motion_hooks.
Richard M. Stallman <rms@gnu.org>
parents:
4214
diff
changeset
|
1986 |
1029 | 1987 /* Common attributes one might give text */ |
1988 | |
1989 staticpro (&Qforeground); | |
1990 Qforeground = intern ("foreground"); | |
1991 staticpro (&Qbackground); | |
1992 Qbackground = intern ("background"); | |
1993 staticpro (&Qfont); | |
1994 Qfont = intern ("font"); | |
1995 staticpro (&Qstipple); | |
1996 Qstipple = intern ("stipple"); | |
1997 staticpro (&Qunderline); | |
1998 Qunderline = intern ("underline"); | |
1999 staticpro (&Qread_only); | |
2000 Qread_only = intern ("read-only"); | |
2001 staticpro (&Qinvisible); | |
2002 Qinvisible = intern ("invisible"); | |
6755
a2bccbc870e6
(syms_of_textprop): Initialize Qintangible.
Karl Heuer <kwzh@gnu.org>
parents:
6681
diff
changeset
|
2003 staticpro (&Qintangible); |
a2bccbc870e6
(syms_of_textprop): Initialize Qintangible.
Karl Heuer <kwzh@gnu.org>
parents:
6681
diff
changeset
|
2004 Qintangible = intern ("intangible"); |
2058
a43d0bb1b7d8
(Fget_text_property): Use textget.
Richard M. Stallman <rms@gnu.org>
parents:
2053
diff
changeset
|
2005 staticpro (&Qcategory); |
a43d0bb1b7d8
(Fget_text_property): Use textget.
Richard M. Stallman <rms@gnu.org>
parents:
2053
diff
changeset
|
2006 Qcategory = intern ("category"); |
a43d0bb1b7d8
(Fget_text_property): Use textget.
Richard M. Stallman <rms@gnu.org>
parents:
2053
diff
changeset
|
2007 staticpro (&Qlocal_map); |
a43d0bb1b7d8
(Fget_text_property): Use textget.
Richard M. Stallman <rms@gnu.org>
parents:
2053
diff
changeset
|
2008 Qlocal_map = intern ("local-map"); |
4381
b0556af4d680
(Qfront_sticky, Qrear_nonsticky): New variables.
Richard M. Stallman <rms@gnu.org>
parents:
4242
diff
changeset
|
2009 staticpro (&Qfront_sticky); |
b0556af4d680
(Qfront_sticky, Qrear_nonsticky): New variables.
Richard M. Stallman <rms@gnu.org>
parents:
4242
diff
changeset
|
2010 Qfront_sticky = intern ("front-sticky"); |
b0556af4d680
(Qfront_sticky, Qrear_nonsticky): New variables.
Richard M. Stallman <rms@gnu.org>
parents:
4242
diff
changeset
|
2011 staticpro (&Qrear_nonsticky); |
b0556af4d680
(Qfront_sticky, Qrear_nonsticky): New variables.
Richard M. Stallman <rms@gnu.org>
parents:
4242
diff
changeset
|
2012 Qrear_nonsticky = intern ("rear-nonsticky"); |
23729
cf1cbb0e5d5b
(Qmouse_face): Variable definition moved here.
Richard M. Stallman <rms@gnu.org>
parents:
22344
diff
changeset
|
2013 staticpro (&Qmouse_face); |
cf1cbb0e5d5b
(Qmouse_face): Variable definition moved here.
Richard M. Stallman <rms@gnu.org>
parents:
22344
diff
changeset
|
2014 Qmouse_face = intern ("mouse-face"); |
1029 | 2015 |
2016 /* Properties that text might use to specify certain actions */ | |
2017 | |
2018 staticpro (&Qmouse_left); | |
2019 Qmouse_left = intern ("mouse-left"); | |
2020 staticpro (&Qmouse_entered); | |
2021 Qmouse_entered = intern ("mouse-entered"); | |
2022 staticpro (&Qpoint_left); | |
2023 Qpoint_left = intern ("point-left"); | |
2024 staticpro (&Qpoint_entered); | |
2025 Qpoint_entered = intern ("point-entered"); | |
2026 | |
2027 defsubr (&Stext_properties_at); | |
1857
9d65dfc7bdb7
(Fadd_text_properties): Put OBJECT arg last. Make it optional.
Richard M. Stallman <rms@gnu.org>
parents:
1715
diff
changeset
|
2028 defsubr (&Sget_text_property); |
7582
454c279b6d18
(syms_of_textprop): Set up Lisp fn get-char-property.
Richard M. Stallman <rms@gnu.org>
parents:
7307
diff
changeset
|
2029 defsubr (&Sget_char_property); |
16679
38c158927e6f
(Fnext_char_property_change): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16339
diff
changeset
|
2030 defsubr (&Snext_char_property_change); |
38c158927e6f
(Fnext_char_property_change): New function.
Richard M. Stallman <rms@gnu.org>
parents:
16339
diff
changeset
|
2031 defsubr (&Sprevious_char_property_change); |
30242
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
2032 defsubr (&Snext_single_char_property_change); |
6af73af0f1ef
(Fnext_single_char_property_change):
Miles Bader <miles@gnu.org>
parents:
29342
diff
changeset
|
2033 defsubr (&Sprevious_single_char_property_change); |
1029 | 2034 defsubr (&Snext_property_change); |
1211 | 2035 defsubr (&Snext_single_property_change); |
1029 | 2036 defsubr (&Sprevious_property_change); |
1211 | 2037 defsubr (&Sprevious_single_property_change); |
1029 | 2038 defsubr (&Sadd_text_properties); |
1965
2bdbd6ed2430
(Fadd_text_properties, Fremove_text_properties):
Richard M. Stallman <rms@gnu.org>
parents:
1930
diff
changeset
|
2039 defsubr (&Sput_text_property); |
1029 | 2040 defsubr (&Sset_text_properties); |
2041 defsubr (&Sremove_text_properties); | |
4144
8f5545cf9774
* intervals.c (split_interval_left, split_interval_right): Change
Jim Blandy <jimb@redhat.com>
parents:
4076
diff
changeset
|
2042 defsubr (&Stext_property_any); |
8f5545cf9774
* intervals.c (split_interval_left, split_interval_right): Change
Jim Blandy <jimb@redhat.com>
parents:
4076
diff
changeset
|
2043 defsubr (&Stext_property_not_all); |
1857
9d65dfc7bdb7
(Fadd_text_properties): Put OBJECT arg last. Make it optional.
Richard M. Stallman <rms@gnu.org>
parents:
1715
diff
changeset
|
2044 /* defsubr (&Serase_text_properties); */ |
4007
55da23f04d01
* textprop.c (copy_text_properties): Pass a copy of POS to
Jim Blandy <jimb@redhat.com>
parents:
3998
diff
changeset
|
2045 /* defsubr (&Scopy_text_properties); */ |
1029 | 2046 } |
1302
538cc0cd6d83
* textprop.c: Conditionalize all functions on
Joseph Arceneaux <jla@gnu.org>
parents:
1283
diff
changeset
|
2047 |