193
|
1 /* Header file for the buffer manipulation primitives.
|
26057
|
2 Copyright (C) 1985, 86, 93, 94, 95, 97, 1998, 1999 Free Software Foundation, Inc.
|
193
|
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
|
998
|
8 the Free Software Foundation; either version 2, or (at your option)
|
193
|
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
|
18 the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
|
|
19 Boston, MA 02111-1307, USA. */
|
193
|
20
|
|
21
|
20553
|
22 /* Accessing the parameters of the current buffer. */
|
1286
|
23
|
20553
|
24 /* These macros come in pairs, one for the char position
|
|
25 and one for the byte position. */
|
1286
|
26
|
20553
|
27 /* Position of beginning of buffer. */
|
|
28 #define BEG (1)
|
|
29 #define BEG_BYTE (1)
|
193
|
30
|
20553
|
31 /* Position of beginning of accessible range of buffer. */
|
|
32 #define BEGV (current_buffer->begv)
|
|
33 #define BEGV_BYTE (current_buffer->begv_byte)
|
193
|
34
|
20553
|
35 /* Position of point in buffer. The "+ 0" makes this
|
193
|
36 not an l-value, so you can't assign to it. Use SET_PT instead. */
|
10310
|
37 #define PT (current_buffer->pt + 0)
|
20553
|
38 #define PT_BYTE (current_buffer->pt_byte + 0)
|
193
|
39
|
20553
|
40 /* Position of gap in buffer. */
|
10310
|
41 #define GPT (current_buffer->text->gpt)
|
20553
|
42 #define GPT_BYTE (current_buffer->text->gpt_byte)
|
193
|
43
|
20553
|
44 /* Position of end of accessible range of buffer. */
|
10310
|
45 #define ZV (current_buffer->zv)
|
20553
|
46 #define ZV_BYTE (current_buffer->zv_byte)
|
193
|
47
|
20553
|
48 /* Position of end of buffer. */
|
10310
|
49 #define Z (current_buffer->text->z)
|
20553
|
50 #define Z_BYTE (current_buffer->text->z_byte)
|
193
|
51
|
20553
|
52 /* Macros for the addresses of places in the buffer. */
|
|
53
|
|
54 /* Address of beginning of buffer. */
|
|
55 #define BEG_ADDR (current_buffer->text->beg)
|
|
56
|
|
57 /* Address of beginning of accessible range of buffer. */
|
|
58 #define BEGV_ADDR (BYTE_POS_ADDR (current_buffer->begv_byte))
|
|
59
|
|
60 /* Address of point in buffer. */
|
|
61 #define PT_ADDR (BYTE_POS_ADDR (current_buffer->pt_byte))
|
|
62
|
|
63 /* Address of beginning of gap in buffer. */
|
|
64 #define GPT_ADDR (current_buffer->text->beg + current_buffer->text->gpt_byte - 1)
|
|
65
|
|
66 /* Address of end of gap in buffer. */
|
|
67 #define GAP_END_ADDR (current_buffer->text->beg + current_buffer->text->gpt_byte + current_buffer->text->gap_size - 1)
|
|
68
|
|
69 /* Address of end of accessible range of buffer. */
|
|
70 #define ZV_ADDR (BYTE_POS_ADDR (current_buffer->zv_byte))
|
|
71
|
|
72 /* Address of end of buffer. */
|
|
73 #define Z_ADDR (current_buffer->text->beg + current_buffer->text->gap_size + current_buffer->text->z_byte - 1)
|
|
74
|
|
75 /* Size of gap. */
|
|
76 #define GAP_SIZE (current_buffer->text->gap_size)
|
|
77
|
|
78 /* Is the current buffer narrowed? */
|
2564
6fee7500fabd
(BUF_NARROWED, NARROWED): New macros to test whether a region
Eric S. Raymond <esr@snark.thyrsus.com>
diff
changeset
|
79 #define NARROWED ((BEGV != BEG) || (ZV != Z))
|
6fee7500fabd
(BUF_NARROWED, NARROWED): New macros to test whether a region
Eric S. Raymond <esr@snark.thyrsus.com>
diff
changeset
|
80
|
193
|
81 /* Modification count. */
|
10310
|
82 #define MODIFF (current_buffer->text->modiff)
|
|
83
|
16190
|
84 /* Overlay modification count. */
|
16191
|
85 #define OVERLAY_MODIFF (current_buffer->text->overlay_modiff)
|
16190
|
86
|
10310
|
87 /* Modification count as of last visit or save. */
|
|
88 #define SAVE_MODIFF (current_buffer->text->save_modiff)
|
193
|
89
|
20553
|
90 /* BUFFER_CEILING_OF (resp. BUFFER_FLOOR_OF), when applied to n, return
|
|
91 the max (resp. min) p such that
|
|
92
|
|
93 BYTE_POS_ADDR (p) - BYTE_POS_ADDR (n) == p - n */
|
193
|
94
|
20553
|
95 #define BUFFER_CEILING_OF(BYTEPOS) \
|
|
96 (((BYTEPOS) < GPT_BYTE && GPT < ZV ? GPT_BYTE : ZV_BYTE) - 1)
|
|
97 #define BUFFER_FLOOR_OF(BYTEPOS) \
|
|
98 (BEGV <= GPT && GPT_BYTE <= (BYTEPOS) ? GPT_BYTE : BEGV_BYTE)
|
|
99
|
|
100 /* Similar macros to operate on a specified buffer.
|
|
101 Note that many of these evaluate the buffer argument more than once. */
|
|
102
|
|
103 /* Position of beginning of buffer. */
|
|
104 #define BUF_BEG(buf) (1)
|
|
105 #define BUF_BEG_BYTE(buf) (1)
|
|
106
|
|
107 /* Position of beginning of accessible range of buffer. */
|
|
108 #define BUF_BEGV(buf) ((buf)->begv)
|
|
109 #define BUF_BEGV_BYTE(buf) ((buf)->begv_byte)
|
193
|
110
|
20553
|
111 /* Position of point in buffer. */
|
|
112 #define BUF_PT(buf) ((buf)->pt)
|
|
113 #define BUF_PT_BYTE(buf) ((buf)->pt_byte)
|
|
114
|
|
115 /* Position of gap in buffer. */
|
|
116 #define BUF_GPT(buf) ((buf)->text->gpt)
|
|
117 #define BUF_GPT_BYTE(buf) ((buf)->text->gpt_byte)
|
|
118
|
|
119 /* Position of end of accessible range of buffer. */
|
|
120 #define BUF_ZV(buf) ((buf)->zv)
|
|
121 #define BUF_ZV_BYTE(buf) ((buf)->zv_byte)
|
193
|
122
|
20553
|
123 /* Position of end of buffer. */
|
|
124 #define BUF_Z(buf) ((buf)->text->z)
|
|
125 #define BUF_Z_BYTE(buf) ((buf)->text->z_byte)
|
|
126
|
|
127 /* Address of beginning of buffer. */
|
|
128 #define BUF_BEG_ADDR(buf) ((buf)->text->beg)
|
|
129
|
|
130 /* Address of beginning of gap of buffer. */
|
|
131 #define BUF_GPT_ADDR(buf) ((buf)->text->beg + (buf)->text->gpt_byte - 1)
|
|
132
|
|
133 /* Address of end of buffer. */
|
|
134 #define BUF_Z_ADDR(buf) ((buf)->text->beg + (buf)->text->gap_size + (buf)->text->z_byte - 1)
|
193
|
135
|
|
136 /* Address of end of gap in buffer. */
|
20553
|
137 #define BUF_GAP_END_ADDR(buf) ((buf)->text->beg + (buf)->text->gpt_byte + (buf)->text->gap_size - 1)
|
193
|
138
|
|
139 /* Size of gap. */
|
20553
|
140 #define BUF_GAP_SIZE(buf) ((buf)->text->gap_size)
|
193
|
141
|
20553
|
142 /* Is this buffer narrowed? */
|
10310
|
143 #define BUF_NARROWED(buf) ((BUF_BEGV (buf) != BUF_BEG (buf)) \
|
|
144 || (BUF_ZV (buf) != BUF_Z (buf)))
|
2564
6fee7500fabd
(BUF_NARROWED, NARROWED): New macros to test whether a region
Eric S. Raymond <esr@snark.thyrsus.com>
diff
changeset
|
145
|
193
|
146 /* Modification count. */
|
10310
|
147 #define BUF_MODIFF(buf) ((buf)->text->modiff)
|
|
148
|
|
149 /* Modification count as of last visit or save. */
|
|
150 #define BUF_SAVE_MODIFF(buf) ((buf)->text->save_modiff)
|
|
151
|
16190
|
152 /* Overlay modification count. */
|
|
153 #define BUF_OVERLAY_MODIFF(buf) ((buf)->text->overlay_modiff)
|
|
154
|
10310
|
155 /* Interval tree of buffer. */
|
|
156 #define BUF_INTERVALS(buf) ((buf)->text->intervals)
|
|
157
|
|
158 /* Marker chain of buffer. */
|
|
159 #define BUF_MARKERS(buf) ((buf)->text->markers)
|
25369
|
160
|
|
161 #define BUF_UNCHANGED_MODIFIED(buf) \
|
|
162 ((buf)->text->unchanged_modified)
|
|
163
|
|
164 #define BUF_OVERLAY_UNCHANGED_MODIFIED(buf) \
|
|
165 ((buf)->text->overlay_unchanged_modified)
|
|
166 #define BUF_BEG_UNCHANGED(buf) ((buf)->text->beg_unchanged)
|
|
167 #define BUF_END_UNCHANGED(buf) ((buf)->text->end_unchanged)
|
|
168
|
|
169 #define UNCHANGED_MODIFIED \
|
|
170 BUF_UNCHANGED_MODIFIED (current_buffer)
|
|
171 #define OVERLAY_UNCHANGED_MODIFIED \
|
|
172 BUF_OVERLAY_UNCHANGED_MODIFIED (current_buffer)
|
|
173 #define BEG_UNCHANGED BUF_BEG_UNCHANGED (current_buffer)
|
|
174 #define END_UNCHANGED BUF_END_UNCHANGED (current_buffer)
|
|
175
|
|
176 /* Compute how many characters at the top and bottom of BUF are
|
|
177 unchanged when the range START..END is modified. This computation
|
|
178 must be done each time BUF is modified. */
|
|
179
|
|
180 #define BUF_COMPUTE_UNCHANGED(buf, start, end) \
|
|
181 do \
|
|
182 { \
|
|
183 if (BUF_UNCHANGED_MODIFIED (buf) == MODIFF \
|
|
184 && BUF_OVERLAY_UNCHANGED_MODIFIED (buf) == OVERLAY_MODIFF) \
|
|
185 { \
|
|
186 BUF_BEG_UNCHANGED (buf) = (start) - BUF_BEG (buf); \
|
|
187 BUF_END_UNCHANGED (buf) = BUF_Z (buf) - (end); \
|
|
188 } \
|
|
189 else \
|
|
190 { \
|
|
191 if (BUF_Z (buf) - (end) < BUF_END_UNCHANGED (buf)) \
|
|
192 BUF_END_UNCHANGED (buf) = BUF_Z (buf) - (end); \
|
|
193 if ((start) - BUF_BEG (buf) < BUF_BEG_UNCHANGED (buf)) \
|
|
194 BUF_BEG_UNCHANGED (buf) = (start) - BUF_BEG (buf); \
|
|
195 } \
|
|
196 } \
|
|
197 while (0)
|
|
198
|
20553
|
199
|
|
200 /* Macros to set PT in the current buffer, or another buffer.. */
|
193
|
201
|
20553
|
202 #define SET_PT(position) (set_point (current_buffer, (position)))
|
|
203 #define TEMP_SET_PT(position) (temp_set_point (current_buffer, (position)))
|
|
204
|
|
205 #define SET_PT_BOTH(position, byte) \
|
|
206 (set_point_both (current_buffer, (position), (byte)))
|
|
207 #define TEMP_SET_PT_BOTH(position, byte) \
|
|
208 (temp_set_point_both (current_buffer, (position), (byte)))
|
|
209
|
|
210 #define BUF_SET_PT(buffer, position) \
|
|
211 (set_point ((buffer), (position)))
|
|
212 #define BUF_TEMP_SET_PT(buffer, position) \
|
|
213 (temp_set_point ((buffer), (position)))
|
|
214
|
|
215 extern void set_point P_ ((struct buffer *, int));
|
|
216 extern INLINE void temp_set_point P_ ((struct buffer *, int));
|
|
217 extern void set_point_both P_ ((struct buffer *, int, int));
|
|
218 extern INLINE void temp_set_point_both P_ ((struct buffer *, int, int));
|
|
219
|
|
220
|
|
221 /* Macros for setting the BEGV, ZV or PT of a given buffer.
|
|
222
|
|
223 SET_BUF_PT* seet to be redundant. Get rid of them?
|
|
224
|
|
225 The ..._BOTH macros take both a charpos and a bytepos,
|
|
226 which must correspond to each other.
|
|
227
|
|
228 The macros without ..._BOTH take just a charpos,
|
|
229 and compute the bytepos from it. */
|
|
230
|
|
231 #define SET_BUF_BEGV(buf, charpos) \
|
|
232 ((buf)->begv_byte = buf_charpos_to_bytepos ((buf), (charpos)), \
|
|
233 (buf)->begv = (charpos))
|
17023
|
234
|
20553
|
235 #define SET_BUF_ZV(buf, charpos) \
|
|
236 ((buf)->zv_byte = buf_charpos_to_bytepos ((buf), (charpos)), \
|
|
237 (buf)->zv = (charpos))
|
|
238
|
|
239 #define SET_BUF_BEGV_BOTH(buf, charpos, byte) \
|
|
240 ((buf)->begv = (charpos), \
|
|
241 (buf)->begv_byte = (byte))
|
|
242
|
|
243 #define SET_BUF_ZV_BOTH(buf, charpos, byte) \
|
|
244 ((buf)->zv = (charpos), \
|
|
245 (buf)->zv_byte = (byte))
|
|
246
|
|
247 #define SET_BUF_PT_BOTH(buf, charpos, byte) \
|
|
248 ((buf)->pt = (charpos), \
|
|
249 (buf)->pt_byte = (byte))
|
|
250
|
|
251 /* Macros to access a character or byte in the current buffer,
|
|
252 or convert between a byte position and an address.
|
|
253 These macros do not check that the position is in range. */
|
|
254
|
|
255 /* Access a Lisp position value in POS,
|
|
256 and store the charpos in CHARPOS and the bypepos in BYPEPOS. */
|
17023
|
257
|
20553
|
258 #define DECODE_POSITION(charpos, bytepos, pos) \
|
|
259 if (1) \
|
|
260 { \
|
|
261 Lisp_Object __pos = (pos); \
|
|
262 if (NUMBERP (__pos)) \
|
|
263 { \
|
|
264 charpos = __pos; \
|
|
265 bytepos = buf_charpos_to_bytepos (current_buffer, __pos); \
|
|
266 } \
|
|
267 else if (MARKERP (__pos)) \
|
|
268 { \
|
|
269 charpos = marker_position (__pos); \
|
|
270 bytepos = marker_byte_position (__pos); \
|
|
271 } \
|
|
272 else \
|
|
273 wrong_type_argument (Qinteger_or_marker_p, __pos); \
|
|
274 } \
|
|
275 else
|
|
276
|
|
277 /* Return the address of byte position N in current buffer. */
|
|
278
|
|
279 #define BYTE_POS_ADDR(n) \
|
|
280 (((n) >= GPT_BYTE ? GAP_SIZE : 0) + (n) + BEG_ADDR - 1)
|
|
281
|
|
282 /* Return the address of char position N. */
|
|
283
|
|
284 #define CHAR_POS_ADDR(n) \
|
|
285 (((n) >= GPT ? GAP_SIZE : 0) \
|
|
286 + buf_charpos_to_bytepos (current_buffer, n) \
|
|
287 + BEG_ADDR - 1)
|
|
288
|
|
289 /* Convert a character position to a byte position. */
|
|
290
|
|
291 #define CHAR_TO_BYTE(charpos) \
|
|
292 (buf_charpos_to_bytepos (current_buffer, charpos))
|
|
293
|
|
294 /* Convert a byte position to a character position. */
|
|
295
|
|
296 #define BYTE_TO_CHAR(bytepos) \
|
|
297 (buf_bytepos_to_charpos (current_buffer, bytepos))
|
|
298
|
|
299 /* Convert PTR, the address of a byte in the buffer, into a byte position. */
|
193
|
300
|
20553
|
301 #define PTR_BYTE_POS(ptr) \
|
|
302 ((ptr) - (current_buffer)->text->beg \
|
|
303 - (ptr - (current_buffer)->text->beg < (unsigned) GPT_BYTE ? 0 : GAP_SIZE) \
|
|
304 + 1)
|
|
305
|
|
306 /* Return character at position POS. */
|
|
307
|
|
308 #define FETCH_CHAR(pos) \
|
|
309 (!NILP (current_buffer->enable_multibyte_characters) \
|
|
310 ? FETCH_MULTIBYTE_CHAR ((pos)) \
|
|
311 : FETCH_BYTE ((pos)))
|
|
312
|
|
313 /* Return the byte at byte position N. */
|
|
314
|
|
315 #define FETCH_BYTE(n) *(BYTE_POS_ADDR ((n)))
|
|
316
|
|
317 /* Variables used locally in FETCH_MULTIBYTE_CHAR. */
|
|
318 extern unsigned char *_fetch_multibyte_char_p;
|
|
319 extern int _fetch_multibyte_char_len;
|
|
320
|
|
321 /* Return character code of multi-byte form at position POS. If POS
|
|
322 doesn't point the head of valid multi-byte form, only the byte at
|
|
323 POS is returned. No range checking. */
|
193
|
324
|
20553
|
325 #define FETCH_MULTIBYTE_CHAR(pos) \
|
|
326 (_fetch_multibyte_char_p = (((pos) >= GPT_BYTE ? GAP_SIZE : 0) \
|
|
327 + (pos) + BEG_ADDR - 1), \
|
|
328 _fetch_multibyte_char_len \
|
|
329 = ((pos) >= GPT_BYTE ? ZV_BYTE : GPT_BYTE) - (pos), \
|
|
330 STRING_CHAR (_fetch_multibyte_char_p, _fetch_multibyte_char_len))
|
|
331
|
|
332 /* Macros for accessing a character or byte,
|
|
333 or converting between byte positions and addresses,
|
|
334 in a specified buffer. */
|
|
335
|
|
336 /* Return the address of character at byte position POS in buffer BUF.
|
193
|
337 Note that both arguments can be computed more than once. */
|
20553
|
338
|
|
339 #define BUF_BYTE_ADDRESS(buf, pos) \
|
|
340 ((buf)->text->beg + (pos) - 1 \
|
|
341 + ((pos) >= (buf)->text->gpt_byte ? (buf)->text->gap_size : 0))
|
|
342
|
|
343 /* Return the address of character at char position POS in buffer BUF.
|
|
344 Note that both arguments can be computed more than once. */
|
|
345
|
193
|
346 #define BUF_CHAR_ADDRESS(buf, pos) \
|
20553
|
347 ((buf)->text->beg + buf_charpos_to_bytepos ((buf), (pos)) - 1 \
|
10310
|
348 + ((pos) >= (buf)->text->gpt ? (buf)->text->gap_size : 0))
|
193
|
349
|
20553
|
350 /* Convert PTR, the address of a char in buffer BUF,
|
|
351 into a character position. */
|
|
352
|
|
353 #define BUF_PTR_BYTE_POS(buf, ptr) \
|
|
354 ((ptr) - (buf)->text->beg \
|
|
355 - (ptr - (buf)->text->beg < (unsigned) BUF_GPT_BYTE ((buf)) \
|
|
356 ? 0 : BUF_GAP_SIZE ((buf))) \
|
193
|
357 + 1)
|
8061
|
358
|
20553
|
359 /* Return the character at byte position POS in buffer BUF. */
|
|
360
|
|
361 #define BUF_FETCH_CHAR(buf, pos) \
|
|
362 (!NILP (buf->enable_multibyte_characters) \
|
|
363 ? BUF_FETCH_MULTIBYTE_CHAR ((buf), (pos)) \
|
|
364 : BUF_FETCH_BYTE ((buf), (pos)))
|
|
365
|
|
366 /* Return the byte at byte position N in buffer BUF. */
|
|
367
|
|
368 #define BUF_FETCH_BYTE(buf, n) \
|
|
369 *(BUF_BYTE_ADDRESS ((buf), (n)))
|
|
370
|
|
371 /* Return character code of multi-byte form at byte position POS in BUF.
|
|
372 If POS doesn't point the head of valid multi-byte form, only the byte at
|
|
373 POS is returned. No range checking. */
|
|
374
|
|
375 #define BUF_FETCH_MULTIBYTE_CHAR(buf, pos) \
|
|
376 (_fetch_multibyte_char_p \
|
|
377 = (((pos) >= BUF_GPT_BYTE (buf) ? BUF_GAP_SIZE (buf) : 0) \
|
|
378 + (pos) + BUF_BEG_ADDR (buf) - 1), \
|
|
379 _fetch_multibyte_char_len \
|
|
380 = (((pos) >= BUF_GPT_BYTE (buf) ? BUF_ZV_BYTE (buf) : BUF_GPT_BYTE (buf)) \
|
|
381 - (pos)), \
|
|
382 STRING_CHAR (_fetch_multibyte_char_p, _fetch_multibyte_char_len))
|
193
|
383
|
20553
|
384 /* Define the actual buffer data structures. */
|
|
385
|
|
386 /* This data structure describes the actual text contents of a buffer.
|
|
387 It is shared between indirect buffers and their base buffer. */
|
|
388
|
193
|
389 struct buffer_text
|
|
390 {
|
26486
|
391 /* Actual address of buffer contents. If REL_ALLOC is defined,
|
|
392 this address might change when blocks are relocated which can
|
|
393 e.g. happen when malloc is called. So, don't pass a pointer
|
|
394 into a buffer's text to functions that malloc. */
|
|
395 unsigned char *beg;
|
|
396
|
20553
|
397 int gpt; /* Char pos of gap in buffer. */
|
|
398 int z; /* Char pos of end of buffer. */
|
|
399 int gpt_byte; /* Byte pos of gap in buffer. */
|
|
400 int z_byte; /* Byte pos of end of buffer. */
|
10310
|
401 int gap_size; /* Size of buffer's gap. */
|
193
|
402 int modiff; /* This counts buffer-modification events
|
|
403 for this buffer. It is incremented for
|
|
404 each such event, and never otherwise
|
|
405 changed. */
|
10310
|
406 int save_modiff; /* Previous value of modiff, as of last
|
|
407 time buffer visited or saved a file. */
|
|
408
|
16190
|
409 int overlay_modiff; /* Counts modifications to overlays. */
|
|
410
|
25369
|
411 /* Minimum value of GPT - BEG since last redisplay that finished. */
|
|
412 int beg_unchanged;
|
|
413
|
|
414 /* Minimum value of Z - GPT since last redisplay that finished. */
|
|
415 int end_unchanged;
|
|
416
|
|
417 /* MODIFF as of last redisplay that finished; if it matches MODIFF,
|
|
418 beg_unchanged and end_unchanged contain no useful information. */
|
|
419 int unchanged_modified;
|
|
420
|
|
421 /* BUF_OVERLAY_MODIFF of current buffer, as of last redisplay that
|
|
422 finished; if it matches BUF_OVERLAY_MODIFF, beg_unchanged and
|
|
423 end_unchanged contain no useful information. */
|
|
424 int overlay_unchanged_modified;
|
|
425
|
10310
|
426 /* Properties of this buffer's text -- conditionally compiled. */
|
|
427 DECLARE_INTERVALS
|
|
428
|
|
429 /* The markers that refer to this buffer.
|
|
430 This is actually a single marker ---
|
|
431 successive elements in its marker `chain'
|
|
432 are the other markers referring to this buffer. */
|
|
433 Lisp_Object markers;
|
193
|
434 };
|
|
435
|
20553
|
436 /* This is the structure that the buffer Lisp object points to. */
|
|
437
|
193
|
438 struct buffer
|
28687
|
439 {
|
|
440 /* Everything before the `name' slot must be of a non-Lisp_Object type,
|
|
441 and every slot after `name' must be a Lisp_Object.
|
|
442
|
|
443 Check out mark_buffer (alloc.c) to see why. */
|
193
|
444
|
28687
|
445 EMACS_INT size;
|
193
|
446
|
28687
|
447 /* Next buffer, in chain of all buffers including killed buffers.
|
|
448 This chain is used only for garbage collection, in order to
|
|
449 collect killed buffers properly.
|
|
450 Note that vectors and most pseudovectors are all on one chain,
|
|
451 but buffers are on a separate chain of their own. */
|
|
452 struct buffer *next;
|
10310
|
453
|
28687
|
454 /* This structure holds the coordinates of the buffer contents
|
|
455 in ordinary buffers. In indirect buffers, this is not used. */
|
|
456 struct buffer_text own_text;
|
|
457
|
|
458 /* This points to the `struct buffer_text' that used for this buffer.
|
|
459 In an ordinary buffer, this is the own_text field above.
|
|
460 In an indirect buffer, this is the own_text field of another buffer. */
|
|
461 struct buffer_text *text;
|
10310
|
462
|
28687
|
463 /* Char position of point in buffer. */
|
|
464 int pt;
|
|
465 /* Byte position of point in buffer. */
|
|
466 int pt_byte;
|
|
467 /* Char position of beginning of accessible range. */
|
|
468 int begv;
|
|
469 /* Byte position of beginning of accessible range. */
|
|
470 int begv_byte;
|
|
471 /* Char position of end of accessible range. */
|
|
472 int zv;
|
|
473 /* Byte position of end of accessible range. */
|
|
474 int zv_byte;
|
10310
|
475
|
28687
|
476 /* In an indirect buffer, this points to the base buffer.
|
|
477 In an ordinary buffer, it is 0. */
|
|
478 struct buffer *base_buffer;
|
10310
|
479
|
28687
|
480 /* A non-zero value in slot IDX means that per-buffer variable
|
|
481 with index IDX has a local value in this buffer. The index IDX
|
|
482 for a buffer-local variable is stored in that variable's slot
|
|
483 in buffer_local_flags as a Lisp integer. If the index is -1,
|
|
484 this means the variable is always local in all buffers. */
|
28350
|
485 #define MAX_PER_BUFFER_VARS 50
|
28687
|
486 char local_flags[MAX_PER_BUFFER_VARS];
|
28317
|
487
|
28687
|
488 /* Set to the modtime of the visited file when read or written.
|
|
489 -1 means visited file was nonexistent.
|
|
490 0 means visited file modtime unknown; in no case complain
|
|
491 about any mismatch on next save attempt. */
|
|
492 int modtime;
|
|
493 /* the value of text->modiff at the last auto-save. */
|
|
494 int auto_save_modified;
|
|
495 /* The time at which we detected a failure to auto-save,
|
|
496 Or -1 if we didn't have a failure. */
|
|
497 int auto_save_failure_time;
|
|
498 /* Position in buffer at which display started
|
|
499 the last time this buffer was displayed. */
|
|
500 int last_window_start;
|
193
|
501
|
28687
|
502 /* Set nonzero whenever the narrowing is changed in this buffer. */
|
|
503 int clip_changed;
|
12471
|
504
|
28687
|
505 /* If the long line scan cache is enabled (i.e. the buffer-local
|
|
506 variable cache-long-line-scans is non-nil), newline_cache
|
|
507 points to the newline cache, and width_run_cache points to the
|
|
508 width run cache.
|
|
509
|
|
510 The newline cache records which stretches of the buffer are
|
|
511 known *not* to contain newlines, so that they can be skipped
|
|
512 quickly when we search for newlines.
|
9404
|
513
|
28687
|
514 The width run cache records which stretches of the buffer are
|
|
515 known to contain characters whose widths are all the same. If
|
|
516 the width run cache maps a character to a value > 0, that value is
|
|
517 the character's width; if it maps a character to zero, we don't
|
|
518 know what its width is. This allows compute_motion to process
|
|
519 such regions very quickly, using algebra instead of inspecting
|
|
520 each character. See also width_table, below. */
|
|
521 struct region_cache *newline_cache;
|
|
522 struct region_cache *width_run_cache;
|
9404
|
523
|
28687
|
524 /* Non-zero means don't use redisplay optimizations for
|
|
525 displaying this buffer. */
|
|
526 unsigned prevent_redisplay_optimizations_p : 1;
|
193
|
527
|
28687
|
528 /* Changes in the buffer are recorded here for undo.
|
|
529 t means don't record anything.
|
|
530 This information belongs to the base buffer of an indirect buffer,
|
|
531 But we can't store it in the struct buffer_text
|
|
532 because local variables have to be right in the struct buffer.
|
|
533 So we copy it around in set_buffer_internal.
|
|
534 This comes before `name' because it is marked in a special way. */
|
|
535 Lisp_Object undo_list;
|
25369
|
536
|
28687
|
537 /* Everything from here down must be a Lisp_Object */
|
21305
|
538
|
28687
|
539 /* The name of this buffer. */
|
|
540 Lisp_Object name;
|
25019
|
541
|
28687
|
542 /* The name of the file visited in this buffer, or nil. */
|
|
543 Lisp_Object filename;
|
|
544 /* Dir for expanding relative file names. */
|
|
545 Lisp_Object directory;
|
|
546 /* True iff this buffer has been backed up (if you write to the
|
|
547 visited file and it hasn't been backed up, then a backup will
|
|
548 be made). */
|
|
549 /* This isn't really used by the C code, so could be deleted. */
|
|
550 Lisp_Object backed_up;
|
|
551 /* Length of file when last read or saved.
|
|
552 This is not in the struct buffer_text
|
|
553 because it's not used in indirect buffers at all. */
|
|
554 Lisp_Object save_length;
|
|
555 /* File name used for auto-saving this buffer.
|
|
556 This is not in the struct buffer_text
|
|
557 because it's not used in indirect buffers at all. */
|
|
558 Lisp_Object auto_save_file_name;
|
|
559
|
|
560 /* Non-nil if buffer read-only. */
|
|
561 Lisp_Object read_only;
|
|
562 /* "The mark". This is a marker which may
|
|
563 point into this buffer or may point nowhere. */
|
|
564 Lisp_Object mark;
|
10310
|
565
|
28687
|
566 /* Alist of elements (SYMBOL . VALUE-IN-THIS-BUFFER)
|
|
567 for all per-buffer variables of this buffer. */
|
|
568 Lisp_Object local_var_alist;
|
193
|
569
|
28687
|
570 /* Symbol naming major mode (eg, lisp-mode). */
|
|
571 Lisp_Object major_mode;
|
|
572 /* Pretty name of major mode (eg, "Lisp"). */
|
|
573 Lisp_Object mode_name;
|
|
574 /* Mode line element that controls format of mode line. */
|
|
575 Lisp_Object mode_line_format;
|
25019
|
576
|
28687
|
577 /* Analogous to mode_line_format for the line displayed at the top
|
|
578 of windows. Nil means don't display that line. */
|
|
579 Lisp_Object header_line_format;
|
|
580
|
|
581 /* Keys that are bound local to this buffer. */
|
|
582 Lisp_Object keymap;
|
|
583 /* This buffer's local abbrev table. */
|
|
584 Lisp_Object abbrev_table;
|
|
585 /* This buffer's syntax table. */
|
|
586 Lisp_Object syntax_table;
|
|
587 /* This buffer's category table. */
|
|
588 Lisp_Object category_table;
|
193
|
589
|
28687
|
590 /* Values of several buffer-local variables */
|
|
591 /* tab-width is buffer-local so that redisplay can find it
|
|
592 in buffers that are not current */
|
|
593 Lisp_Object case_fold_search;
|
|
594 Lisp_Object tab_width;
|
|
595 Lisp_Object fill_column;
|
|
596 Lisp_Object left_margin;
|
|
597 /* Function to call when insert space past fill column. */
|
|
598 Lisp_Object auto_fill_function;
|
|
599 /* nil: text, t: binary.
|
|
600 This value is meaningful only on certain operating systems. */
|
|
601 /* Actually, we don't need this flag any more because end-of-line
|
|
602 is handled correctly according to the buffer-file-coding-system
|
|
603 of the buffer. Just keeping it for backward compatibility. */
|
|
604 Lisp_Object buffer_file_type;
|
193
|
605
|
28687
|
606 /* Case table for case-conversion in this buffer.
|
|
607 This char-table maps each char into its lower-case version. */
|
|
608 Lisp_Object downcase_table;
|
|
609 /* Char-table mapping each char to its upper-case version. */
|
|
610 Lisp_Object upcase_table;
|
|
611 /* Char-table for conversion for case-folding search. */
|
|
612 Lisp_Object case_canon_table;
|
|
613 /* Char-table of equivalences for case-folding search. */
|
|
614 Lisp_Object case_eqv_table;
|
193
|
615
|
28687
|
616 /* Non-nil means do not display continuation lines. */
|
|
617 Lisp_Object truncate_lines;
|
|
618 /* Non-nil means display ctl chars with uparrow. */
|
|
619 Lisp_Object ctl_arrow;
|
|
620 /* Non-nil means display text from right to left. */
|
|
621 Lisp_Object direction_reversed;
|
|
622 /* Non-nil means do selective display;
|
|
623 see doc string in syms_of_buffer (buffer.c) for details. */
|
|
624 Lisp_Object selective_display;
|
193
|
625 #ifndef old
|
28687
|
626 /* Non-nil means show ... at end of line followed by invisible lines. */
|
|
627 Lisp_Object selective_display_ellipses;
|
193
|
628 #endif
|
28687
|
629 /* Alist of (FUNCTION . STRING) for each minor mode enabled in buffer. */
|
|
630 Lisp_Object minor_modes;
|
|
631 /* t if "self-insertion" should overwrite; `binary' if it should also
|
|
632 overwrite newlines and tabs - for editing executables and the like. */
|
|
633 Lisp_Object overwrite_mode;
|
|
634 /* non-nil means abbrev mode is on. Expand abbrevs automatically. */
|
|
635 Lisp_Object abbrev_mode;
|
|
636 /* Display table to use for text in this buffer. */
|
|
637 Lisp_Object display_table;
|
|
638 /* t means the mark and region are currently active. */
|
|
639 Lisp_Object mark_active;
|
|
640
|
|
641 /* List of overlays that end at or before the current center,
|
|
642 in order of end-position. */
|
|
643 Lisp_Object overlays_before;
|
193
|
644
|
28687
|
645 /* List of overlays that end after the current center,
|
|
646 in order of start-position. */
|
|
647 Lisp_Object overlays_after;
|
2390
|
648
|
28687
|
649 /* Position where the overlay lists are centered. */
|
|
650 Lisp_Object overlay_center;
|
2390
|
651
|
28687
|
652 /* Non-nil means the buffer contents are regarded as multi-byte
|
|
653 form of characters, not a binary code. */
|
|
654 Lisp_Object enable_multibyte_characters;
|
9404
|
655
|
28687
|
656 /* Coding system to be used for encoding the buffer contents on
|
|
657 saving. */
|
|
658 Lisp_Object buffer_file_coding_system;
|
17023
|
659
|
28687
|
660 /* List of symbols naming the file format used for visited file. */
|
|
661 Lisp_Object file_format;
|
18179
|
662
|
28687
|
663 /* True if the newline position cache and width run cache are
|
|
664 enabled. See search.c and indent.c. */
|
|
665 Lisp_Object cache_long_line_scans;
|
9404
|
666
|
28687
|
667 /* If the width run cache is enabled, this table contains the
|
|
668 character widths width_run_cache (see above) assumes. When we
|
|
669 do a thorough redisplay, we compare this against the buffer's
|
|
670 current display table to see whether the display table has
|
|
671 affected the widths of any characters. If it has, we
|
|
672 invalidate the width run cache, and re-initialize width_table. */
|
|
673 Lisp_Object width_table;
|
|
674
|
|
675 /* In an indirect buffer, or a buffer that is the base of an
|
|
676 indirect buffer, this holds a marker that records
|
|
677 PT for this buffer when the buffer is not current. */
|
|
678 Lisp_Object pt_marker;
|
10310
|
679
|
28687
|
680 /* In an indirect buffer, or a buffer that is the base of an
|
|
681 indirect buffer, this holds a marker that records
|
|
682 BEGV for this buffer when the buffer is not current. */
|
|
683 Lisp_Object begv_marker;
|
10310
|
684
|
28687
|
685 /* In an indirect buffer, or a buffer that is the base of an
|
|
686 indirect buffer, this holds a marker that records
|
|
687 ZV for this buffer when the buffer is not current. */
|
|
688 Lisp_Object zv_marker;
|
10310
|
689
|
28687
|
690 /* This holds the point value before the last scroll operation.
|
|
691 Explicitly setting point sets this to nil. */
|
|
692 Lisp_Object point_before_scroll;
|
10562
|
693
|
28687
|
694 /* Truename of the visited file, or nil. */
|
|
695 Lisp_Object file_truename;
|
10750
|
696
|
28687
|
697 /* Invisibility spec of this buffer.
|
|
698 t => any non-nil `invisible' property means invisible.
|
|
699 A list => `invisible' property means invisible
|
|
700 if it is memq in that list. */
|
|
701 Lisp_Object invisibility_spec;
|
10966
|
702
|
28687
|
703 /* This is the last window that was selected with this buffer in it,
|
|
704 or nil if that window no longer displays this buffer. */
|
|
705 Lisp_Object last_selected_window;
|
16066
|
706
|
28687
|
707 /* Incremented each time the buffer is displayed in a window. */
|
|
708 Lisp_Object display_count;
|
17219
|
709
|
28687
|
710 /* Widths of left and right marginal areas for windows displaying
|
|
711 this buffer. */
|
|
712 Lisp_Object left_margin_width, right_margin_width;
|
25019
|
713
|
28687
|
714 /* Non-nil means indicate lines not displaying text (in a style
|
|
715 like vi). */
|
|
716 Lisp_Object indicate_empty_lines;
|
|
717
|
|
718 /* Time stamp updated each time this buffer is displayed in a window. */
|
|
719 Lisp_Object display_time;
|
25019
|
720
|
28687
|
721 /* If scrolling the display because point is below the bottom of a
|
|
722 window showing this buffer, try to choose a window start so
|
|
723 that point ends up this number of lines from the top of the
|
|
724 window. Nil means that scrolling method isn't used. */
|
|
725 Lisp_Object scroll_up_aggressively;
|
25019
|
726
|
28687
|
727 /* If scrolling the display because point is above the top of a
|
|
728 window showing this buffer, try to choose a window start so
|
|
729 that point ends up this number of lines from the bottom of the
|
|
730 window. Nil means that scrolling method isn't used. */
|
|
731 Lisp_Object scroll_down_aggressively;
|
25019
|
732
|
28687
|
733 /* Desired cursor type in this buffer. See the doc string of
|
|
734 per-buffer variable `cursor-type'. */
|
|
735 Lisp_Object cursor_type;
|
28345
|
736
|
28687
|
737 /* An integer > 0 means put that number of pixels below text lines
|
|
738 in the display of this buffer. */
|
|
739 Lisp_Object extra_line_spacing;
|
|
740 };
|
|
741
|
2390
|
742
|
|
743 /* This points to the current buffer. */
|
193
|
744
|
|
745 extern struct buffer *current_buffer;
|
|
746
|
|
747 /* This structure holds the default values of the buffer-local variables
|
2390
|
748 that have special slots in each buffer.
|
193
|
749 The default value occupies the same slot in this structure
|
|
750 as an individual buffer's value occupies in that buffer.
|
|
751 Setting the default value also goes through the alist of buffers
|
|
752 and stores into each buffer that does not say it has a local value. */
|
|
753
|
|
754 extern struct buffer buffer_defaults;
|
|
755
|
|
756 /* This structure marks which slots in a buffer have corresponding
|
|
757 default values in buffer_defaults.
|
|
758 Each such slot has a nonzero value in this structure.
|
|
759 The value has only one nonzero bit.
|
|
760
|
|
761 When a buffer has its own local value for a slot,
|
28317
|
762 the entry for that slot (found in the same slot in this structure)
|
|
763 is turned on in the buffer's local_flags array.
|
193
|
764
|
|
765 If a slot in this structure is zero, then even though there may
|
2390
|
766 be a Lisp-level local variable for the slot, it has no default value,
|
193
|
767 and the corresponding slot in buffer_defaults is not used. */
|
|
768
|
|
769 extern struct buffer buffer_local_flags;
|
|
770
|
|
771 /* For each buffer slot, this points to the Lisp symbol name
|
|
772 for that slot in the current buffer. It is 0 for slots
|
|
773 that don't have such names. */
|
|
774
|
|
775 extern struct buffer buffer_local_symbols;
|
|
776
|
998
|
777 /* This structure holds the required types for the values in the
|
|
778 buffer-local slots. If a slot contains Qnil, then the
|
|
779 corresponding buffer slot may contain a value of any type. If a
|
|
780 slot contains an integer, then prospective values' tags must be
|
20994
|
781 equal to that integer (except nil is always allowed).
|
|
782 When a tag does not match, the function
|
|
783 buffer_slot_type_mismatch will signal an error.
|
|
784
|
|
785 If a slot here contains -1, the corresponding variable is read-only. */
|
|
786
|
1502
|
787 extern struct buffer buffer_local_types;
|
2390
|
788
|
20304
|
789 extern void reset_buffer P_ ((struct buffer *));
|
|
790 extern void evaporate_overlays P_ ((int));
|
|
791 extern int overlays_at P_ ((int, int, Lisp_Object **, int *, int *, int *));
|
|
792 extern int sort_overlays P_ ((Lisp_Object *, int, struct window *));
|
|
793 extern void recenter_overlay_lists P_ ((struct buffer *, int));
|
|
794 extern int overlay_strings P_ ((int, struct window *, unsigned char **));
|
|
795 extern void validate_region P_ ((Lisp_Object *, Lisp_Object *));
|
|
796 extern void set_buffer_internal P_ ((struct buffer *));
|
|
797 extern void set_buffer_internal_1 P_ ((struct buffer *));
|
|
798 extern void set_buffer_temp P_ ((struct buffer *));
|
|
799 extern void record_buffer P_ ((Lisp_Object));
|
|
800 extern void buffer_slot_type_mismatch P_ ((int));
|
|
801 extern void fix_overlays_before P_ ((struct buffer *, int, int));
|
193
|
802
|
20304
|
803
|
|
804 EXFUN (Fbuffer_name, 1);
|
|
805 EXFUN (Fget_file_buffer, 1);
|
|
806 EXFUN (Fnext_overlay_change, 1);
|
|
807 EXFUN (Fdelete_overlay, 1);
|
2390
|
808
|
10310
|
809 /* Functions to call before and after each text change. */
|
6786
|
810 extern Lisp_Object Vbefore_change_functions;
|
|
811 extern Lisp_Object Vafter_change_functions;
|
1821
|
812 extern Lisp_Object Vfirst_change_hook;
|
12786
|
813 extern Lisp_Object Qbefore_change_functions;
|
|
814 extern Lisp_Object Qafter_change_functions;
|
1821
|
815 extern Lisp_Object Qfirst_change_hook;
|
193
|
816
|
23398
|
817 /* If nonzero, all modification hooks are suppressed. */
|
|
818 extern int inhibit_modification_hooks;
|
|
819
|
2051
|
820 extern Lisp_Object Vdeactivate_mark;
|
|
821 extern Lisp_Object Vtransient_mark_mode;
|
2390
|
822
|
|
823 /* Overlays */
|
2051
|
824
|
6098
|
825 /* 1 if the OV is an overlay object. */
|
2782
|
826 #define OVERLAY_VALID(OV) (OVERLAYP (OV))
|
193
|
827
|
2390
|
828 /* Return the marker that stands for where OV starts in the buffer. */
|
9925
|
829 #define OVERLAY_START(OV) (XOVERLAY (OV)->start)
|
193
|
830
|
2390
|
831 /* Return the marker that stands for where OV ends in the buffer. */
|
9925
|
832 #define OVERLAY_END(OV) (XOVERLAY (OV)->end)
|
193
|
833
|
6098
|
834 /* Return the actual buffer position for the marker P.
|
|
835 We assume you know which buffer it's pointing into. */
|
193
|
836
|
9951
|
837 #define OVERLAY_POSITION(P) \
|
|
838 (GC_MARKERP (P) ? marker_position (P) : (abort (), 0))
|
193
|
839
|
2390
|
840 /* Allocation of buffer text. */
|
|
841
|
193
|
842 #ifdef REL_ALLOC
|
25745
|
843
|
|
844 extern char *r_alloc P_ ((char **, unsigned long));
|
|
845 extern void r_alloc_free P_ ((char **ptr));
|
25763
|
846 extern char *r_re_alloc P_ ((char **, unsigned long));
|
25745
|
847
|
|
848 #define BUFFER_ALLOC(data,size) \
|
|
849 ((unsigned char *) r_alloc ((char **)&data, (size)))
|
|
850 #define BUFFER_REALLOC(data,size) \
|
|
851 ((unsigned char *) r_re_alloc ((char **) &data, (size)))
|
|
852 #define BUFFER_FREE(data) (r_alloc_free ((char **) &data))
|
193
|
853 #define R_ALLOC_DECLARE(var,data) (r_alloc_declare (&var, (data)))
|
|
854 #else
|
|
855 #define BUFFER_ALLOC(data,size) (data = (unsigned char *) malloc ((size)))
|
|
856 #define BUFFER_REALLOC(data,size) ((unsigned char *) realloc ((data), (size)))
|
|
857 #define BUFFER_FREE(data) (free ((data)))
|
|
858 #define R_ALLOC_DECLARE(var,data)
|
|
859 #endif
|
25019
|
860
|
28317
|
861 /***********************************************************************
|
|
862 Buffer-local Variables
|
|
863 ***********************************************************************/
|
|
864
|
|
865 /* Number of per-buffer variables used. */
|
|
866
|
28350
|
867 extern int last_per_buffer_idx;
|
28317
|
868
|
|
869 /* Return the offset in bytes of member VAR of struct buffer
|
|
870 from the start of a buffer structure. */
|
|
871
|
28350
|
872 #define PER_BUFFER_VAR_OFFSET(VAR) \
|
28317
|
873 ((char *) &buffer_local_flags.VAR - (char *) &buffer_local_flags)
|
|
874
|
|
875 /* Return the index of buffer-local variable VAR. Each per-buffer
|
|
876 variable has an index > 0 associated with it, except when it always
|
|
877 has buffer-local values, in which case the index is -1. If this is
|
|
878 0, this is a bug and means that the slot of VAR in
|
|
879 buffer_local_flags wasn't intiialized. */
|
|
880
|
28350
|
881 #define PER_BUFFER_VAR_IDX(VAR) \
|
|
882 PER_BUFFER_IDX (PER_BUFFER_VAR_OFFSET (VAR))
|
28317
|
883
|
|
884 /* Value is non-zero if the variable with index IDX has a local value
|
|
885 in buffer B. */
|
|
886
|
28350
|
887 #define PER_BUFFER_VALUE_P(B, IDX) \
|
|
888 (((IDX) < 0 || IDX >= last_per_buffer_idx) \
|
28317
|
889 ? (abort (), 0) \
|
|
890 : ((B)->local_flags[IDX] != 0))
|
|
891
|
|
892 /* Set whether per-buffer variable with index IDX has a buffer-local
|
|
893 value in buffer B. VAL zero means it hasn't. */
|
|
894
|
28350
|
895 #define SET_PER_BUFFER_VALUE_P(B, IDX, VAL) \
|
28317
|
896 do { \
|
28350
|
897 if ((IDX) < 0 || (IDX) >= last_per_buffer_idx) \
|
28317
|
898 abort (); \
|
|
899 (B)->local_flags[IDX] = (VAL); \
|
|
900 } while (0)
|
|
901
|
|
902 /* Return the index of the per-buffer variable at offset OFFSET in the
|
|
903 buffer structure. */
|
|
904
|
28350
|
905 #define PER_BUFFER_IDX(OFFSET) \
|
28317
|
906 XINT (*(Lisp_Object *)((OFFSET) + (char *) &buffer_local_flags))
|
|
907
|
|
908 /* Return the default value of the per-buffer variable at offset
|
|
909 OFFSET in the buffer structure. */
|
|
910
|
28350
|
911 #define PER_BUFFER_DEFAULT(OFFSET) \
|
28317
|
912 (*(Lisp_Object *)((OFFSET) + (char *) &buffer_defaults))
|
|
913
|
|
914 /* Return the buffer-local value of the per-buffer variable at offset
|
|
915 OFFSET in the buffer structure. */
|
|
916
|
28350
|
917 #define PER_BUFFER_VALUE(BUFFER, OFFSET) \
|
28317
|
918 (*(Lisp_Object *)((OFFSET) + (char *) (BUFFER)))
|
|
919
|
|
920 /* Return the symbol of the per-buffer variable at offset OFFSET in
|
|
921 the buffer structure. */
|
|
922
|
28350
|
923 #define PER_BUFFER_SYMBOL(OFFSET) \
|
28317
|
924 (*(Lisp_Object *)((OFFSET) + (char *) &buffer_local_symbols))
|
|
925
|
|
926 /* Return the type of the per-buffer variable at offset OFFSET in the
|
|
927 buffer structure. */
|
|
928
|
28350
|
929 #define PER_BUFFER_TYPE(OFFSET) \
|
28317
|
930 (*(Lisp_Object *)((OFFSET) + (char *) &buffer_local_types))
|