(read_escape): For Control modifier, pay attention to
[bpt/emacs.git] / src / lisp.h
CommitLineData
3cfe6dfd 1/* Fundamental definitions for GNU Emacs Lisp interpreter.
4a2f9c6a 2 Copyright (C) 1985,86,87,93,94,95,97,1998 Free Software Foundation, Inc.
3cfe6dfd
JB
3
4This file is part of GNU Emacs.
5
6GNU Emacs is free software; you can redistribute it and/or modify
7it under the terms of the GNU General Public License as published by
4746118a 8the Free Software Foundation; either version 2, or (at your option)
3cfe6dfd
JB
9any later version.
10
11GNU Emacs is distributed in the hope that it will be useful,
12but WITHOUT ANY WARRANTY; without even the implied warranty of
13MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14GNU General Public License for more details.
15
16You should have received a copy of the GNU General Public License
17along with GNU Emacs; see the file COPYING. If not, write to
3b7ad313
EN
18the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
19Boston, MA 02111-1307, USA. */
3cfe6dfd 20
5010d3b8
GM
21/* Declare the prototype for a general external function. */
22#if defined (__STDC__) || defined (WINDOWSNT)
23#define P_(proto) proto
24#else
25#define P_(proto) ()
26#endif
27
3cfe6dfd 28
ce99fd65
RS
29/* These are default choices for the types to use. */
30#ifndef EMACS_INT
31#define EMACS_INT int
1747fb16 32#define BITS_PER_EMACS_INT BITS_PER_INT
ce99fd65
RS
33#endif
34#ifndef EMACS_UINT
35#define EMACS_UINT unsigned int
36#endif
37
99a3d506 38/* Define the fundamental Lisp data structures. */
3cfe6dfd 39
99a3d506 40/* This is the set of Lisp data types. */
3cfe6dfd
JB
41
42enum Lisp_Type
43 {
99a3d506 44 /* Integer. XINT (obj) is the integer value. */
3cfe6dfd
JB
45 Lisp_Int,
46
99a3d506 47 /* Symbol. XSYMBOL (object) points to a struct Lisp_Symbol. */
3cfe6dfd
JB
48 Lisp_Symbol,
49
84d1833e
KH
50 /* Miscellaneous. XMISC (object) points to a union Lisp_Misc,
51 whose first member indicates the subtype. */
52 Lisp_Misc,
3cfe6dfd
JB
53
54 /* String. XSTRING (object) points to a struct Lisp_String.
99a3d506 55 The length of the string, and its contents, are stored therein. */
3cfe6dfd
JB
56 Lisp_String,
57
b5088f80 58 /* Vector of Lisp objects, or something resembling it.
7c06ac2b 59 XVECTOR (object) points to a struct Lisp_Vector, which contains
b5088f80
KH
60 the size and contents. The size field also contains the type
61 information, if it's not a real vector object. */
62 Lisp_Vectorlike,
3cfe6dfd 63
99a3d506 64 /* Cons. XCONS (object) points to a struct Lisp_Cons. */
3cfe6dfd
JB
65 Lisp_Cons,
66
3cfe6dfd 67#ifdef LISP_FLOAT_TYPE
20280af7 68 Lisp_Float,
3cfe6dfd 69#endif /* LISP_FLOAT_TYPE */
4d1207f6
RS
70
71 /* This is not a type code. It is for range checking. */
e2ba196c 72 Lisp_Type_Limit
3cfe6dfd
JB
73 };
74
84d1833e 75/* This is the set of datatypes that share a common structure.
c98adc1b
KH
76 The first member of the structure is a type code from this set.
77 The enum values are arbitrary, but we'll use large numbers to make it
78 more likely that we'll spot the error if a random word in memory is
79 mistakenly interpreted as a Lisp_Misc. */
1c4ca5a3
KH
80enum Lisp_Misc_Type
81 {
c98adc1b 82 Lisp_Misc_Free = 0x5eab,
84d1833e 83 Lisp_Misc_Marker,
ee4c9ce4
KH
84 Lisp_Misc_Intfwd,
85 Lisp_Misc_Boolfwd,
86 Lisp_Misc_Objfwd,
7d65f1c2
KH
87 Lisp_Misc_Buffer_Objfwd,
88 Lisp_Misc_Buffer_Local_Value,
ce7d8eec 89 Lisp_Misc_Some_Buffer_Local_Value,
99a3d506 90 Lisp_Misc_Overlay,
32462604 91 Lisp_Misc_Kboard_Objfwd,
99a3d506
RS
92 /* Currently floats are not a misc type,
93 but let's define this in case we want to change that. */
94 Lisp_Misc_Float,
95 /* This is not a type code. It is for range checking. */
96 Lisp_Misc_Limit
1c4ca5a3
KH
97 };
98
e2ba196c
KH
99/* These values are overridden by the m- file on some machines. */
100#ifndef VALBITS
101#define VALBITS 28
102#endif
103
104#ifndef GCTYPEBITS
105#define GCTYPEBITS 3
106#endif
107
c9ddd39d
KH
108/* Make these values available in GDB, which sees enums but not macros. */
109
110enum gdb_lisp_params
111{
112 gdb_valbits = VALBITS,
113 gdb_gctypebits = GCTYPEBITS,
68be917d 114 gdb_emacs_intbits = sizeof (EMACS_INT) * BITS_PER_CHAR,
c9ddd39d
KH
115#ifdef DATA_SEG_BITS
116 gdb_data_seg_bits = DATA_SEG_BITS
117#else
118 gdb_data_seg_bits = 0
119#endif
120};
121
3cfe6dfd
JB
122#ifndef NO_UNION_TYPE
123
c451d7b1 124#ifndef WORDS_BIG_ENDIAN
3cfe6dfd
JB
125
126/* Definition of Lisp_Object for little-endian machines. */
127
128typedef
129union Lisp_Object
130 {
131 /* Used for comparing two Lisp_Objects;
99a3d506 132 also, positive integers can be accessed fast this way. */
3cfe6dfd
JB
133 int i;
134
135 struct
136 {
e2ba196c
KH
137 int val: VALBITS;
138 int type: GCTYPEBITS+1;
3cfe6dfd
JB
139 } s;
140 struct
141 {
e2ba196c
KH
142 unsigned int val: VALBITS;
143 int type: GCTYPEBITS+1;
3cfe6dfd
JB
144 } u;
145 struct
146 {
e2ba196c
KH
147 unsigned int val: VALBITS;
148 enum Lisp_Type type: GCTYPEBITS;
3cfe6dfd
JB
149 /* The markbit is not really part of the value of a Lisp_Object,
150 and is always zero except during garbage collection. */
151 unsigned int markbit: 1;
152 } gu;
153 }
154Lisp_Object;
155
c451d7b1 156#else /* If WORDS_BIG_ENDIAN */
3cfe6dfd
JB
157
158typedef
159union Lisp_Object
160 {
161 /* Used for comparing two Lisp_Objects;
99a3d506 162 also, positive integers can be accessed fast this way. */
3cfe6dfd
JB
163 int i;
164
165 struct
166 {
e2ba196c
KH
167 int type: GCTYPEBITS+1;
168 int val: VALBITS;
3cfe6dfd
JB
169 } s;
170 struct
171 {
e2ba196c
KH
172 int type: GCTYPEBITS+1;
173 unsigned int val: VALBITS;
3cfe6dfd
JB
174 } u;
175 struct
176 {
177 /* The markbit is not really part of the value of a Lisp_Object,
178 and is always zero except during garbage collection. */
179 unsigned int markbit: 1;
e2ba196c
KH
180 enum Lisp_Type type: GCTYPEBITS;
181 unsigned int val: VALBITS;
3cfe6dfd
JB
182 } gu;
183 }
184Lisp_Object;
185
c451d7b1 186#endif /* WORDS_BIG_ENDIAN */
3cfe6dfd
JB
187
188#endif /* NO_UNION_TYPE */
189
190
1c5ca8b6 191/* If union type is not wanted, define Lisp_Object as just a number. */
3cfe6dfd
JB
192
193#ifdef NO_UNION_TYPE
627a9502 194#define Lisp_Object EMACS_INT
1c5ca8b6 195#endif /* NO_UNION_TYPE */
3cfe6dfd 196
3cfe6dfd 197#ifndef VALMASK
627a9502 198#define VALMASK ((((EMACS_INT) 1)<<VALBITS) - 1)
3cfe6dfd 199#endif
627a9502 200#define GCTYPEMASK ((((EMACS_INT) 1)<<GCTYPEBITS) - 1)
846d69ac
RS
201
202/* Two flags that are set during GC. On some machines, these flags
203 are defined differently by the m- file. */
204
205/* This is set in the car of a cons and in the plist slot of a symbol
206 to indicate it is marked. Likewise in the plist slot of an interval,
207 the chain slot of a marker, the type slot of a float, and the name
208 slot of a buffer.
209
210 In strings, this bit in the size field indicates that the string
211 is a "large" one, one which was separately malloc'd
212 rather than being part of a string block. */
213
627a9502 214#ifndef MARKBIT
8ce6977e 215#define MARKBIT ((int) ((unsigned int) 1 << (VALBITS + GCTYPEBITS)))
627a9502 216#endif /*MARKBIT */
3cfe6dfd 217
846d69ac
RS
218/* In the size word of a vector, this bit means the vector has been marked.
219 In the size word of a large string, likewise. */
220
221#ifndef ARRAY_MARK_FLAG
222#define ARRAY_MARK_FLAG ((MARKBIT >> 1) & ~MARKBIT)
223#endif /* no ARRAY_MARK_FLAG */
224
b5088f80
KH
225/* In the size word of a struct Lisp_Vector, this bit means it's really
226 some other vector-like object. */
227#ifndef PSEUDOVECTOR_FLAG
228#define PSEUDOVECTOR_FLAG ((ARRAY_MARK_FLAG >> 1) & ~ARRAY_MARK_FLAG)
229#endif
230
303a5c93 231/* In a pseudovector, the size field actually contains a word with one
b5088f80
KH
232 PSEUDOVECTOR_FLAG bit set, and exactly one of the following bits to
233 indicate the actual type. */
99a3d506
RS
234enum pvec_type
235{
236 PVEC_NORMAL_VECTOR = 0,
99a3d506
RS
237 PVEC_PROCESS = 0x200,
238 PVEC_FRAME = 0x400,
239 PVEC_COMPILED = 0x800,
240 PVEC_WINDOW = 0x1000,
241 PVEC_WINDOW_CONFIGURATION = 0x2000,
242 PVEC_SUBR = 0x4000,
608ff985
RS
243 PVEC_CHAR_TABLE = 0x8000,
244 PVEC_BOOL_VECTOR = 0x10000,
245 PVEC_BUFFER = 0x20000,
5010d3b8 246 PVEC_HASH_TABLE = 0x40000,
782dad44 247 PVEC_TYPE_MASK = 0x3fe00,
e3d48049 248 PVEC_FLAG = PSEUDOVECTOR_FLAG
99a3d506 249};
b5088f80
KH
250
251/* For convenience, we also store the number of elements in these bits. */
608ff985 252#define PSEUDOVECTOR_SIZE_MASK 0x1ff
3cfe6dfd
JB
253\f
254/* These macros extract various sorts of values from a Lisp_Object.
255 For example, if tem is a Lisp_Object whose type is Lisp_Cons,
99a3d506 256 XCONS (tem) is the struct Lisp_Cons * pointing to the memory for that cons. */
3cfe6dfd
JB
257
258#ifdef NO_UNION_TYPE
259
260/* One need to override this if there must be high bits set in data space
261 (doing the result of the below & ((1 << (GCTYPE + 1)) - 1) would work
262 on all machines, but would penalise machines which don't need it)
263 */
264#ifndef XTYPE
265#define XTYPE(a) ((enum Lisp_Type) ((a) >> VALBITS))
266#endif
267
268#ifndef XSETTYPE
627a9502 269#define XSETTYPE(a, b) ((a) = XUINT (a) | ((EMACS_INT)(b) << VALBITS))
3cfe6dfd
JB
270#endif
271
221f4ef3
KH
272/* For integers known to be positive, XFASTINT provides fast retrieval
273 and XSETFASTINT provides fast storage. This takes advantage of the
274 fact that Lisp_Int is 0. */
e43ec785 275#define XFASTINT(a) ((a) + 0)
221f4ef3 276#define XSETFASTINT(a, b) ((a) = (b))
3cfe6dfd
JB
277
278/* Extract the value of a Lisp_Object as a signed integer. */
279
280#ifndef XINT /* Some machines need to do this differently. */
68be917d 281#define XINT(a) (((a) << (BITS_PER_INT-VALBITS)) >> (BITS_PER_INT-VALBITS))
3cfe6dfd
JB
282#endif
283
284/* Extract the value as an unsigned integer. This is a basis
285 for extracting it as a pointer to a structure in storage. */
286
287#ifndef XUINT
288#define XUINT(a) ((a) & VALMASK)
289#endif
290
291#ifndef XPNTR
292#ifdef HAVE_SHM
293/* In this representation, data is found in two widely separated segments. */
29eab336 294extern int pure_size;
3cfe6dfd 295#define XPNTR(a) \
29eab336 296 (XUINT (a) | (XUINT (a) > pure_size ? DATA_SEG_BITS : PURE_SEG_BITS))
3cfe6dfd
JB
297#else /* not HAVE_SHM */
298#ifdef DATA_SEG_BITS
299/* This case is used for the rt-pc.
300 In the diffs I was given, it checked for ptr = 0
301 and did not adjust it in that case.
302 But I don't think that zero should ever be found
303 in a Lisp object whose data type says it points to something. */
304#define XPNTR(a) (XUINT (a) | DATA_SEG_BITS)
305#else
306#define XPNTR(a) XUINT (a)
307#endif
308#endif /* not HAVE_SHM */
309#endif /* no XPNTR */
310
3cfe6dfd
JB
311#ifndef XSET
312#define XSET(var, type, ptr) \
627a9502 313 ((var) = ((EMACS_INT)(type) << VALBITS) + ((EMACS_INT) (ptr) & VALMASK))
3cfe6dfd
JB
314#endif
315
b7acde90
KH
316/* Convert a C integer into a Lisp_Object integer. */
317
318#define make_number(N) \
319 ((((EMACS_INT) (N)) & VALMASK) | ((EMACS_INT) Lisp_Int) << VALBITS)
320
3cfe6dfd
JB
321/* During garbage collection, XGCTYPE must be used for extracting types
322 so that the mark bit is ignored. XMARKBIT accesses the markbit.
323 Markbits are used only in particular slots of particular structure types.
324 Other markbits are always zero.
325 Outside of garbage collection, all mark bits are always zero. */
326
327#ifndef XGCTYPE
328#define XGCTYPE(a) ((enum Lisp_Type) (((a) >> VALBITS) & GCTYPEMASK))
329#endif
330
1747fb16 331#if VALBITS + GCTYPEBITS == BITS_PER_EMACS_INT - 1
3cfe6dfd
JB
332/* Make XMARKBIT faster if mark bit is sign bit. */
333#ifndef XMARKBIT
334#define XMARKBIT(a) ((a) < 0)
335#endif
336#endif /* markbit is sign bit */
337
338#ifndef XMARKBIT
339#define XMARKBIT(a) ((a) & MARKBIT)
340#endif
341
342#ifndef XSETMARKBIT
343#define XSETMARKBIT(a,b) ((a) = ((a) & ~MARKBIT) | ((b) ? MARKBIT : 0))
344#endif
345
346#ifndef XMARK
347#define XMARK(a) ((a) |= MARKBIT)
348#endif
349
350#ifndef XUNMARK
351#define XUNMARK(a) ((a) &= ~MARKBIT)
352#endif
353
354#endif /* NO_UNION_TYPE */
355
356#ifndef NO_UNION_TYPE
357
358#define XTYPE(a) ((enum Lisp_Type) (a).u.type)
359#define XSETTYPE(a, b) ((a).u.type = (char) (b))
360
221f4ef3
KH
361/* For integers known to be positive, XFASTINT provides fast retrieval
362 and XSETFASTINT provides fast storage. This takes advantage of the
363 fact that Lisp_Int is 0. */
e43ec785 364#define XFASTINT(a) ((a).i + 0)
221f4ef3 365#define XSETFASTINT(a, b) ((a).i = (b))
3cfe6dfd
JB
366
367#ifdef EXPLICIT_SIGN_EXTEND
368/* Make sure we sign-extend; compilers have been known to fail to do so. */
68be917d 369#define XINT(a) (((a).i << (BITS_PER_INT-VALBITS)) >> (BITS_PER_INT-VALBITS))
3cfe6dfd
JB
370#else
371#define XINT(a) ((a).s.val)
372#endif /* EXPLICIT_SIGN_EXTEND */
373
374#define XUINT(a) ((a).u.val)
375#define XPNTR(a) ((a).u.val)
3cfe6dfd
JB
376
377#define XSET(var, vartype, ptr) \
378 (((var).s.type = ((char) (vartype))), ((var).s.val = ((int) (ptr))))
379
e98227af
KH
380extern Lisp_Object make_number ();
381
3cfe6dfd
JB
382/* During garbage collection, XGCTYPE must be used for extracting types
383 so that the mark bit is ignored. XMARKBIT access the markbit.
384 Markbits are used only in particular slots of particular structure types.
385 Other markbits are always zero.
386 Outside of garbage collection, all mark bits are always zero. */
387
388#define XGCTYPE(a) ((a).gu.type)
389#define XMARKBIT(a) ((a).gu.markbit)
390#define XSETMARKBIT(a,b) (XMARKBIT(a) = (b))
391#define XMARK(a) (XMARKBIT(a) = 1)
392#define XUNMARK(a) (XMARKBIT(a) = 0)
393
394#endif /* NO_UNION_TYPE */
395
99a3d506 396/* Extract a value or address from a Lisp_Object. */
3cfe6dfd
JB
397
398#define XCONS(a) ((struct Lisp_Cons *) XPNTR(a))
3cfe6dfd 399#define XVECTOR(a) ((struct Lisp_Vector *) XPNTR(a))
3cfe6dfd
JB
400#define XSTRING(a) ((struct Lisp_String *) XPNTR(a))
401#define XSYMBOL(a) ((struct Lisp_Symbol *) XPNTR(a))
3cfe6dfd 402#define XFLOAT(a) ((struct Lisp_Float *) XPNTR(a))
7c06ac2b
RS
403
404/* Misc types. */
405#define XMISC(a) ((union Lisp_Misc *) XPNTR(a))
a7aa28f6 406#define XMISCTYPE(a) (XMARKER (a)->type)
84d1833e 407#define XMARKER(a) (&(XMISC(a)->u_marker))
ee4c9ce4
KH
408#define XINTFWD(a) (&(XMISC(a)->u_intfwd))
409#define XBOOLFWD(a) (&(XMISC(a)->u_boolfwd))
410#define XOBJFWD(a) (&(XMISC(a)->u_objfwd))
411#define XBUFFER_OBJFWD(a) (&(XMISC(a)->u_buffer_objfwd))
7d65f1c2 412#define XBUFFER_LOCAL_VALUE(a) (&(XMISC(a)->u_buffer_local_value))
ce7d8eec 413#define XOVERLAY(a) (&(XMISC(a)->u_overlay))
32462604 414#define XKBOARD_OBJFWD(a) (&(XMISC(a)->u_kboard_objfwd))
3cfe6dfd 415
7c06ac2b
RS
416/* Pseudovector types. */
417#define XPROCESS(a) ((struct Lisp_Process *) XPNTR(a))
418#define XWINDOW(a) ((struct window *) XPNTR(a))
419#define XSUBR(a) ((struct Lisp_Subr *) XPNTR(a))
99a3d506 420#define XBUFFER(a) ((struct buffer *) XPNTR(a))
608ff985
RS
421#define XCHAR_TABLE(a) ((struct Lisp_Char_Table *) XPNTR(a))
422#define XBOOL_VECTOR(a) ((struct Lisp_Bool_Vector *) XPNTR(a))
99a3d506
RS
423
424
425/* Construct a Lisp_Object from a value or address. */
7c06ac2b 426
a94ef819
KH
427#define XSETINT(a, b) XSET (a, Lisp_Int, b)
428#define XSETCONS(a, b) XSET (a, Lisp_Cons, b)
b5088f80 429#define XSETVECTOR(a, b) XSET (a, Lisp_Vectorlike, b)
a94ef819
KH
430#define XSETSTRING(a, b) XSET (a, Lisp_String, b)
431#define XSETSYMBOL(a, b) XSET (a, Lisp_Symbol, b)
a94ef819 432#define XSETFLOAT(a, b) XSET (a, Lisp_Float, b)
7c06ac2b
RS
433
434/* Misc types. */
435#define XSETMISC(a, b) XSET (a, Lisp_Misc, b)
a7aa28f6 436#define XSETMARKER(a, b) (XSETMISC (a, b), XMISCTYPE (a) = Lisp_Misc_Marker)
7c06ac2b
RS
437
438/* Pseudovector types. */
439#define XSETPSEUDOVECTOR(a, b, code) \
440 (XSETVECTOR (a, b), XVECTOR (a)->size |= PSEUDOVECTOR_FLAG | (code))
441#define XSETWINDOW_CONFIGURATION(a, b) \
442 (XSETPSEUDOVECTOR (a, b, PVEC_WINDOW_CONFIGURATION))
443#define XSETPROCESS(a, b) (XSETPSEUDOVECTOR (a, b, PVEC_PROCESS))
444#define XSETWINDOW(a, b) (XSETPSEUDOVECTOR (a, b, PVEC_WINDOW))
445#define XSETSUBR(a, b) (XSETPSEUDOVECTOR (a, b, PVEC_SUBR))
446#define XSETCOMPILED(a, b) (XSETPSEUDOVECTOR (a, b, PVEC_COMPILED))
99a3d506 447#define XSETBUFFER(a, b) (XSETPSEUDOVECTOR (a, b, PVEC_BUFFER))
608ff985
RS
448#define XSETCHAR_TABLE(a, b) (XSETPSEUDOVECTOR (a, b, PVEC_CHAR_TABLE))
449#define XSETBOOL_VECTOR(a, b) (XSETPSEUDOVECTOR (a, b, PVEC_BOOL_VECTOR))
3cfe6dfd 450\f
e221eae3 451#ifdef USE_TEXT_PROPERTIES
99a3d506 452/* Basic data type for use of intervals. See the macros in intervals.h. */
e221eae3
JA
453
454struct interval
455{
99a3d506 456 /* The first group of entries deal with the tree structure. */
e221eae3 457
99a3d506
RS
458 unsigned int total_length; /* Length of myself and both children. */
459 unsigned int position; /* Cache of interval's character position. */
b4e187e2
RS
460 /* This field is usually updated
461 simultaneously with an interval
462 traversal, there is no guaranty
463 that it is valid for a random
464 interval. */
99a3d506
RS
465 struct interval *left; /* Intervals which precede me. */
466 struct interval *right; /* Intervals which succeed me. */
e8720644
JB
467
468 /* Parent in the tree, or the Lisp_Object containing this interval tree.
469
470 The mark bit on the root interval of an interval tree says
471 whether we have started (and possibly finished) marking the
472 tree. If GC comes across an interval tree whose root's parent
473 field has its markbit set, it leaves the tree alone.
474
475 You'd think we could store this information in the parent object
476 somewhere (after all, that should be visited once and then
477 ignored too, right?), but strings are GC'd strangely. */
478 struct interval *parent;
e221eae3
JA
479
480 /* The remaining components are `properties' of the interval.
481 The first four are duplicates for things which can be on the list,
99a3d506 482 for purposes of speed. */
e221eae3
JA
483
484 unsigned char write_protect; /* Non-zero means can't modify. */
99a3d506 485 unsigned char visible; /* Zero means don't display. */
cde20f41 486 unsigned char front_sticky; /* Non-zero means text inserted just
99a3d506
RS
487 before this interval goes into it. */
488 unsigned char rear_sticky; /* Likewise for just after it. */
e221eae3 489
e8720644
JB
490 /* Properties of this interval.
491 The mark bit on this field says whether this particular interval
492 tree node has been visited. Since intervals should never be
493 shared, GC aborts if it seems to have visited an interval twice. */
494 Lisp_Object plist;
e221eae3
JA
495};
496
497typedef struct interval *INTERVAL;
498
499/* Complain if object is not string or buffer type */
500#define CHECK_STRING_OR_BUFFER(x, i) \
c5af3bb9 501 { if (!STRINGP ((x)) && !BUFFERP ((x))) \
e221eae3
JA
502 x = wrong_type_argument (Qbuffer_or_string_p, (x)); }
503
504/* Macro used to conditionally compile intervals into certain data
99a3d506 505 structures. See, e.g., struct Lisp_String below. */
e221eae3
JA
506#define DECLARE_INTERVALS INTERVAL intervals;
507
eb8c3be9 508/* Macro used to conditionally compile interval initialization into
99a3d506 509 certain code. See, e.g., alloc.c. */
e221eae3
JA
510#define INITIALIZE_INTERVAL(ptr,val) ptr->intervals = val
511
512#else /* No text properties */
513
99a3d506 514/* If no intervals are used, make the above definitions go away. */
e221eae3
JA
515
516#define CHECK_STRING_OR_BUFFER(x, i)
517
518#define INTERVAL
519#define DECLARE_INTERVALS
520#define INITIALIZE_INTERVAL(ptr,val)
521
522#endif /* USE_TEXT_PROPERTIES */
523\f
3cfe6dfd
JB
524/* In a cons, the markbit of the car is the gc mark bit */
525
526struct Lisp_Cons
527 {
528 Lisp_Object car, cdr;
529 };
530
b7acde90
KH
531/* Take the car or cdr of something known to be a cons cell. */
532#define XCAR(c) (XCONS ((c))->car)
533#define XCDR(c) (XCONS ((c))->cdr)
534
535/* Take the car or cdr of something whose type is not known. */
536#define CAR(c) \
537 (CONSP ((c)) ? XCAR ((c)) \
538 : NILP ((c)) ? Qnil \
539 : wrong_type_argument (Qlistp, (c)))
540
541#define CDR(c) \
542 (CONSP ((c)) ? XCDR ((c)) \
543 : NILP ((c)) ? Qnil \
544 : wrong_type_argument (Qlistp, (c)))
545
3cfe6dfd
JB
546/* Like a cons, but records info on where the text lives that it was read from */
547/* This is not really in use now */
548
549struct Lisp_Buffer_Cons
550 {
551 Lisp_Object car, cdr;
552 struct buffer *buffer;
553 int bufpos;
554 };
555
d8fc7ce4
KH
556/* Nonzero if STR is a multibyte string. */
557#define STRING_MULTIBYTE(STR) \
558 (XSTRING (STR)->size_byte >= 0)
559
560/* Return the length in bytes of STR. */
561#define STRING_BYTES(STR) \
562 ((STR)->size_byte < 0 ? (STR)->size : (STR)->size_byte)
563
564/* Set the length in bytes of STR. */
565#define SET_STRING_BYTES(STR, SIZE) ((STR)->size_byte = (SIZE))
566
3cfe6dfd
JB
567/* In a string or vector, the sign bit of the `size' is the gc mark bit */
568
569struct Lisp_String
570 {
627a9502 571 EMACS_INT size;
a1b5012f 572 EMACS_INT size_byte;
99a3d506 573 DECLARE_INTERVALS /* `data' field must be last. */
3cfe6dfd
JB
574 unsigned char data[1];
575 };
576
94225242 577/* If a struct is made to look like a vector, this macro returns the length
4115d3f7
RS
578 of the shortest vector that would hold that struct. */
579#define VECSIZE(type) ((sizeof (type) - (sizeof (struct Lisp_Vector) \
580 - sizeof (Lisp_Object)) \
581 + sizeof(Lisp_Object) - 1) /* round up */ \
94225242
KH
582 / sizeof (Lisp_Object))
583
3cfe6dfd
JB
584struct Lisp_Vector
585 {
627a9502 586 EMACS_INT size;
3cfe6dfd
JB
587 struct Lisp_Vector *next;
588 Lisp_Object contents[1];
589 };
590
ea724a01
KH
591/* A char table is a kind of vectorlike, with contents are like a
592 vector but with a few other slots. For some purposes, it makes
593 sense to handle a chartable with type struct Lisp_Vector. An
594 element of a char table can be any Lisp objects, but if it is a sub
595 char-table, we treat it a table that contains information of a
596 group of characters of the same charsets or a specific character of
597 a charset. A sub char-table has the same structure as a char table
598 except for that the former omits several slots at the tail. A sub
599 char table appears only in an element of a char table, and there's
600 no way to access it directly from Emacs Lisp program. */
e98227af 601
b96656ce
KH
602/* This is the number of slots that apply to characters or character
603 sets. The first 128 are for ASCII, the next 128 are for 8-bit
ea724a01
KH
604 European characters, and the last 128 are for multibyte characters.
605 The first 256 are indexed by the code itself, but the last 128 are
606 indexed by (charset-id + 128). */
b96656ce
KH
607#define CHAR_TABLE_ORDINARY_SLOTS 384
608
609/* This is the number of slots that apply to characters of ASCII and
610 8-bit Europeans only. */
611#define CHAR_TABLE_SINGLE_BYTE_SLOTS 256
608ff985 612
ea724a01
KH
613/* This is the number of slots that every char table must have. This
614 counts the ordinary slots and the top, defalt, parent, and purpose
615 slots. */
616#define CHAR_TABLE_STANDARD_SLOTS (CHAR_TABLE_ORDINARY_SLOTS + 4)
617
618/* This is the number of slots that apply to position-code-1 and
619 position-code-2 of a multibyte character at the 2nd and 3rd level
620 sub char tables respectively. */
621#define SUB_CHAR_TABLE_ORDINARY_SLOTS 128
622
623/* This is the number of slots that every sub char table must have.
624 This counts the ordinary slots and the top and defalt slot. */
e98227af 625#define SUB_CHAR_TABLE_STANDARD_SLOTS (SUB_CHAR_TABLE_ORDINARY_SLOTS + 2)
608ff985
RS
626
627/* Return the number of "extra" slots in the char table CT. */
628
629#define CHAR_TABLE_EXTRA_SLOTS(CT) \
630 (((CT)->size & PSEUDOVECTOR_SIZE_MASK) - CHAR_TABLE_STANDARD_SLOTS)
631
b96656ce 632/* Almost equivalent to Faref (CT, IDX) with optimization for ASCII
8ac90470
KH
633 and 8-bit Europeans characters. For these characters, do not check
634 validity of CT. Do not follow parent. */
635#define CHAR_TABLE_REF(CT, IDX) \
6185c1c0 636 ((IDX) >= 0 && (IDX) < CHAR_TABLE_SINGLE_BYTE_SLOTS \
2e34157c
RS
637 ? (!NILP (XCHAR_TABLE (CT)->contents[IDX]) \
638 ? XCHAR_TABLE (CT)->contents[IDX] \
8ac90470 639 : XCHAR_TABLE (CT)->defalt) \
2e34157c 640 : Faref (CT, make_number (IDX)))
b96656ce 641
29b7163f
RS
642/* Almost equivalent to Faref (CT, IDX) with optimization for ASCII
643 and 8-bit Europeans characters. However, if the result is nil,
644 return IDX.
645
646 For these characters, do not check validity of CT
647 and do not follow parent. */
648#define CHAR_TABLE_TRANSLATE(CT, IDX) \
649 ((IDX) < CHAR_TABLE_SINGLE_BYTE_SLOTS \
650 ? (!NILP (XCHAR_TABLE (CT)->contents[IDX]) \
651 ? XINT (XCHAR_TABLE (CT)->contents[IDX]) \
652 : IDX) \
653 : char_table_translate (CT, IDX))
654
b96656ce 655/* Equivalent to Faset (CT, IDX, VAL) with optimization for ASCII and
8ac90470
KH
656 8-bit Europeans characters. Do not check validity of CT. */
657#define CHAR_TABLE_SET(CT, IDX, VAL) \
658 do { \
659 if (XFASTINT (IDX) < CHAR_TABLE_SINGLE_BYTE_SLOTS) \
660 XCHAR_TABLE (CT)->contents[XFASTINT (IDX)] = VAL; \
661 else \
662 Faset (CT, IDX, VAL); \
b96656ce
KH
663 } while (0)
664
608ff985
RS
665struct Lisp_Char_Table
666 {
667 /* This is the vector's size field, which also holds the
668 pseudovector type information. It holds the size, too.
ea724a01
KH
669 The size counts the top, defalt, purpose, and parent slots.
670 The last three are not counted if this is a sub char table. */
608ff985
RS
671 EMACS_INT size;
672 struct Lisp_Vector *next;
ea724a01
KH
673 /* This holds a flag to tell if this is a top level char table (t)
674 or a sub char table (nil). */
675 Lisp_Object top;
608ff985
RS
676 /* This holds a default value,
677 which is used whenever the value for a specific character is nil. */
678 Lisp_Object defalt;
ea724a01
KH
679 /* This holds an actual value of each element. A sub char table
680 has only SUB_CHAR_TABLE_ORDINARY_SLOTS number of elements. */
681 Lisp_Object contents[CHAR_TABLE_ORDINARY_SLOTS];
682
683 /* A sub char table doesn't has the following slots. */
684
608ff985
RS
685 /* This points to another char table, which we inherit from
686 when the value for a specific character is nil.
687 The `defalt' slot takes precedence over this. */
688 Lisp_Object parent;
7f73dc9d
RS
689 /* This should be a symbol which says what kind of use
690 this char-table is meant for.
691 Typically now the values can be `syntax-table' and `display-table'. */
692 Lisp_Object purpose;
608ff985
RS
693 /* These hold additional data. */
694 Lisp_Object extras[1];
695 };
696
697/* A boolvector is a kind of vectorlike, with contents are like a string. */
698struct Lisp_Bool_Vector
699 {
700 /* This is the vector's size field. It doesn't have the real size,
701 just the subtype information. */
702 EMACS_INT vector_size;
703 struct Lisp_Vector *next;
704 /* This is the size in bits. */
705 EMACS_INT size;
706 /* This contains the actual bits, packed into bytes. */
707 unsigned char data[1];
708 };
709
3cfe6dfd
JB
710/* In a symbol, the markbit of the plist is used as the gc mark bit */
711
712struct Lisp_Symbol
713 {
714 struct Lisp_String *name;
715 Lisp_Object value;
716 Lisp_Object function;
717 Lisp_Object plist;
92a2515a 718 Lisp_Object obarray;
3cfe6dfd
JB
719 struct Lisp_Symbol *next; /* -> next symbol in this obarray bucket */
720 };
721
7c06ac2b
RS
722/* This structure describes a built-in function.
723 It is generated by the DEFUN macro only.
724 defsubr makes it into a Lisp object.
725
726 This type is treated in most respects as a pseudovector,
727 but since we never dynamically allocate or free them,
728 we don't need a next-vector field. */
e98227af 729
3cfe6dfd
JB
730struct Lisp_Subr
731 {
7c06ac2b 732 EMACS_INT size;
3cfe6dfd
JB
733 Lisp_Object (*function) ();
734 short min_args, max_args;
735 char *symbol_name;
736 char *prompt;
737 char *doc;
738 };
5010d3b8
GM
739
740\f
741/***********************************************************************
742 Hash Tables
743 ***********************************************************************/
744
745/* The structure of a Lisp hash table. */
746
747struct Lisp_Hash_Table
748{
749 /* Vector fields. The hash table code doesn't refer to these. */
750 EMACS_INT size;
751 struct Lisp_Vector *vec_next;
752
753 /* Function used to compare keys. */
754 Lisp_Object test;
755
756 /* Nil if table is non-weak. Otherwise a symbol describing the
757 weakness of the table. */
758 Lisp_Object weak;
759
760 /* When the table is resized, and this is an integer, compute the
761 new size by adding this to the old size. If a float, compute the
762 new size by multiplying the old size with this factor. */
763 Lisp_Object rehash_size;
764
765 /* Resize hash table when number of entries/ table size is >= this
766 ratio, a float. */
767 Lisp_Object rehash_threshold;
768
769 /* Number of key/value entries in the table. */
770 Lisp_Object count;
771
772 /* Vector of keys and values. The key of item I is found at index
773 2 * I, the value is found at index 2 * I + 1. */
774 Lisp_Object key_and_value;
775
776 /* Vector of hash codes.. If hash[I] is nil, this means that that
777 entry I is unused. */
778 Lisp_Object hash;
779
780 /* Vector used to chain entries. If entry I is free, next[I] is the
781 entry number of the next free item. If entry I is non-free,
782 next[I] is the index of the next entry in the collision chain. */
783 Lisp_Object next;
784
785 /* Index of first free entry in free list. */
786 Lisp_Object next_free;
787
788 /* Bucket vector. A non-nil entry is the index of the first item in
789 a collision chain. This vector's size can be larger than the
790 hash table size to reduce collisions. */
791 Lisp_Object index;
792
793 /* Next weak hash table if this is a weak hash table. The head
794 of the list is in Vweak_hash_tables. */
795 Lisp_Object next_weak;
796
797 /* User-supplied hash function, or nil. */
798 Lisp_Object user_hash_function;
799
800 /* User-supplied key comparison function, or nil. */
801 Lisp_Object user_cmp_function;
802
803 /* C function to compare two keys. */
804 int (* cmpfn) P_ ((struct Lisp_Hash_Table *, Lisp_Object,
805 unsigned, Lisp_Object, unsigned));
806
807 /* C function to compute hash code. */
808 unsigned (* hashfn) P_ ((struct Lisp_Hash_Table *, Lisp_Object));
809};
810
811
812#define XHASH_TABLE(OBJ) \
813 ((struct Lisp_Hash_Table *) XPNTR (OBJ))
814
815#define XSET_HASH_TABLE(VAR, PTR) \
816 (XSETPSEUDOVECTOR (VAR, PTR, PVEC_HASH_TABLE))
817
818#define HASH_TABLE_P(OBJ) PSEUDOVECTORP (OBJ, PVEC_HASH_TABLE)
819#define GC_HASH_TABLE_P(x) GC_PSEUDOVECTORP (x, PVEC_HASH_TABLE)
820
821#define CHECK_HASH_TABLE(x, i) \
822 do \
823 { \
824 if (!HASH_TABLE_P ((x))) \
825 x = wrong_type_argument (Qhash_table_p, (x)); \
826 } \
827 while (0)
828
829/* Default size for hash tables if not specified. */
830
831#define DEFAULT_HASH_SIZE 65
832
833/* Default threshold specifying when to resize a hash table. The
834 value gives the ratio of current entries in the hash table and the
835 size of the hash table. */
836
837#define DEFAULT_REHASH_THRESHOLD 0.8
838
839/* Default factor by which to increase the size of a hash table. */
840
841#define DEFAULT_REHASH_SIZE 1.5
842
ee4c9ce4 843\f
7c06ac2b
RS
844/* These structures are used for various misc types. */
845
ee4c9ce4
KH
846/* A miscellaneous object, when it's on the free list. */
847struct Lisp_Free
848 {
5bfac5a9
RS
849 int type : 16; /* = Lisp_Misc_Free */
850 int spacer : 16;
ee4c9ce4
KH
851 union Lisp_Misc *chain;
852 };
3cfe6dfd 853
609c36fe 854/* In a marker, the markbit of the chain field is used as the gc mark bit. */
3cfe6dfd 855struct Lisp_Marker
308e97d0
RS
856{
857 int type : 16; /* = Lisp_Misc_Marker */
858 int spacer : 15;
859 /* 1 means normal insertion at the marker's position
860 leaves the marker after the inserted text. */
861 unsigned int insertion_type : 1;
4ed24bf3
RS
862 /* This is the buffer that the marker points into,
863 or 0 if it points nowhere. */
308e97d0 864 struct buffer *buffer;
4ed24bf3
RS
865
866 /* The remaining fields are meaningless in a marker that
867 does not point anywhere. */
868
869 /* For markers that point somewhere,
870 this is used to chain of all the markers in a given buffer. */
308e97d0 871 Lisp_Object chain;
4ed24bf3
RS
872 /* This is the char position where the marker points. */
873 int charpos;
363aa820
RS
874 /* This is the byte position. */
875 int bytepos;
308e97d0 876};
3cfe6dfd 877
ee4c9ce4
KH
878/* Forwarding pointer to an int variable.
879 This is allowed only in the value cell of a symbol,
880 and it means that the symbol's value really lives in the
881 specified int variable. */
882struct Lisp_Intfwd
84d1833e 883 {
5bfac5a9
RS
884 int type : 16; /* = Lisp_Misc_Intfwd */
885 int spacer : 16;
ee4c9ce4
KH
886 int *intvar;
887 };
888
889/* Boolean forwarding pointer to an int variable.
890 This is like Lisp_Intfwd except that the ostensible
891 "value" of the symbol is t if the int variable is nonzero,
892 nil if it is zero. */
893struct Lisp_Boolfwd
894 {
5bfac5a9
RS
895 int type : 16; /* = Lisp_Misc_Boolfwd */
896 int spacer : 16;
ee4c9ce4
KH
897 int *boolvar;
898 };
899
900/* Forwarding pointer to a Lisp_Object variable.
901 This is allowed only in the value cell of a symbol,
902 and it means that the symbol's value really lives in the
903 specified variable. */
904struct Lisp_Objfwd
905 {
5bfac5a9
RS
906 int type : 16; /* = Lisp_Misc_Objfwd */
907 int spacer : 16;
ee4c9ce4
KH
908 Lisp_Object *objvar;
909 };
910
911/* Like Lisp_Objfwd except that value lives in a slot in the
912 current buffer. Value is byte index of slot within buffer. */
913struct Lisp_Buffer_Objfwd
914 {
5bfac5a9
RS
915 int type : 16; /* = Lisp_Misc_Buffer_Objfwd */
916 int spacer : 16;
ee4c9ce4 917 int offset;
84d1833e
KH
918 };
919
7d65f1c2
KH
920/* Used in a symbol value cell when the symbol's value is per-buffer.
921 The actual contents resemble a cons cell which starts a list like this:
922 (REALVALUE BUFFER CURRENT-ALIST-ELEMENT . DEFAULT-VALUE).
923
ce7d8eec
KH
924 The cons-like structure is for historical reasons; it might be better
925 to just put these elements into the struct, now.
926
7d65f1c2
KH
927 BUFFER is the last buffer for which this symbol's value was
928 made up to date.
929
930 CURRENT-ALIST-ELEMENT is a pointer to an element of BUFFER's
931 local_var_alist, that being the element whose car is this
932 variable. Or it can be a pointer to the
933 (CURRENT-ALIST-ELEMENT . DEFAULT-VALUE),
934 if BUFFER does not have an element in its alist for this
935 variable (that is, if BUFFER sees the default value of this
936 variable).
937
938 If we want to examine or set the value and BUFFER is current,
99a3d506 939 we just examine or set REALVALUE. If BUFFER is not current, we
7d65f1c2
KH
940 store the current REALVALUE value into CURRENT-ALIST-ELEMENT,
941 then find the appropriate alist element for the buffer now
942 current and set up CURRENT-ALIST-ELEMENT. Then we set
943 REALVALUE out of that element, and store into BUFFER.
944
945 If we are setting the variable and the current buffer does not
946 have an alist entry for this variable, an alist entry is
947 created.
948
949 Note that REALVALUE can be a forwarding pointer. Each time it
950 is examined or set, forwarding must be done. Each time we
951 switch buffers, buffer-local variables which forward into C
952 variables are swapped immediately, so the C code can assume
953 that they are always up to date.
954
955 Lisp_Misc_Buffer_Local_Value and Lisp_Misc_Some_Buffer_Local_Value
956 use the same substructure. The difference is that with the latter,
957 merely setting the variable while some buffer is current
958 does not cause that buffer to have its own local value of this variable.
959 Only make-local-variable does that. */
960struct Lisp_Buffer_Local_Value
961 {
4bfba59e
RS
962 int type : 16; /* = Lisp_Misc_Buffer_Local_Value
963 or Lisp_Misc_Some_Buffer_Local_Value */
964 int spacer : 13;
965 unsigned int check_frame : 1;
966 unsigned int found_for_buffer : 1;
967 unsigned int found_for_frame : 1;
968 Lisp_Object realvalue;
969 Lisp_Object buffer, frame;
970 Lisp_Object cdr;
7d65f1c2
KH
971 };
972
ce7d8eec
KH
973/* In an overlay object, the mark bit of the plist is used as the GC mark.
974 START and END are markers in the overlay's buffer, and
975 PLIST is the overlay's property list. */
976struct Lisp_Overlay
977 {
5bfac5a9
RS
978 int type : 16; /* = Lisp_Misc_Overlay */
979 int spacer : 16;
ce7d8eec
KH
980 Lisp_Object start, end, plist;
981 };
5bfac5a9 982
f334de0e 983/* Like Lisp_Objfwd except that value lives in a slot in the
32462604
KH
984 current kboard. */
985struct Lisp_Kboard_Objfwd
f334de0e 986 {
32462604 987 int type : 16; /* = Lisp_Misc_Kboard_Objfwd */
f334de0e
KH
988 int spacer : 16;
989 int offset;
990 };
991
5bfac5a9 992
a7aa28f6
RS
993/* To get the type field of a union Lisp_Misc, use XMISCTYPE.
994 It uses one of these struct subtypes to get the type field. */
995
84d1833e
KH
996union Lisp_Misc
997 {
84d1833e
KH
998 struct Lisp_Free u_free;
999 struct Lisp_Marker u_marker;
ee4c9ce4
KH
1000 struct Lisp_Intfwd u_intfwd;
1001 struct Lisp_Boolfwd u_boolfwd;
1002 struct Lisp_Objfwd u_objfwd;
1003 struct Lisp_Buffer_Objfwd u_buffer_objfwd;
7d65f1c2 1004 struct Lisp_Buffer_Local_Value u_buffer_local_value;
ce7d8eec 1005 struct Lisp_Overlay u_overlay;
32462604 1006 struct Lisp_Kboard_Objfwd u_kboard_objfwd;
84d1833e 1007 };
7c06ac2b 1008\f
3cfe6dfd
JB
1009#ifdef LISP_FLOAT_TYPE
1010/* Optional Lisp floating point type */
1011struct Lisp_Float
1012 {
e98227af 1013 Lisp_Object type; /* essentially used for mark-bit
3cfe6dfd 1014 and chaining when on free-list */
e98227af 1015 double data;
3cfe6dfd
JB
1016 };
1017#endif /* LISP_FLOAT_TYPE */
1018
1019/* A character, declared with the following typedef, is a member
99a3d506 1020 of some character set associated with the current buffer. */
b2ba7b00
RS
1021#ifndef _UCHAR_T /* Protect against something in ctab.h on AIX. */
1022#define _UCHAR_T
3cfe6dfd 1023typedef unsigned char UCHAR;
b2ba7b00 1024#endif
3cfe6dfd
JB
1025
1026/* Meanings of slots in a Lisp_Compiled: */
1027
1028#define COMPILED_ARGLIST 0
1029#define COMPILED_BYTECODE 1
1030#define COMPILED_CONSTANTS 2
1031#define COMPILED_STACK_DEPTH 3
1032#define COMPILED_DOC_STRING 4
1033#define COMPILED_INTERACTIVE 5
88dbfee5 1034
d03f79ef
JB
1035/* Flag bits in a character. These also get used in termhooks.h.
1036 Richard Stallman <rms@gnu.ai.mit.edu> thinks that MULE
7c06ac2b
RS
1037 (MUlti-Lingual Emacs) might need 22 bits for the character value
1038 itself, so we probably shouldn't use any bits lower than 0x0400000. */
1039#define CHAR_ALT (0x0400000)
1040#define CHAR_SUPER (0x0800000)
1041#define CHAR_HYPER (0x1000000)
1042#define CHAR_SHIFT (0x2000000)
1043#define CHAR_CTL (0x4000000)
1044#define CHAR_META (0x8000000)
703f2808 1045
6b768554
KH
1046/* Actually, the current Emacs uses 19 bits for the character value
1047 itself. */
1048#define CHARACTERBITS 19
1049
e6faba7f
RS
1050#ifdef USE_X_TOOLKIT
1051#ifdef NO_UNION_TYPE
1052/* Use this for turning a (void *) into a Lisp_Object, as when the
1053 Lisp_Object is passed into a toolkit callback function. */
1054#define VOID_TO_LISP(larg,varg) \
1055 do { ((larg) = ((Lisp_Object) (varg))); } while (0)
1056#define CVOID_TO_LISP VOID_TO_LISP
1057
1058/* Use this for turning a Lisp_Object into a (void *), as when the
1059 Lisp_Object is passed into a toolkit callback function. */
1060#define LISP_TO_VOID(larg) ((void *) (larg))
1061#define LISP_TO_CVOID(varg) ((const void *) (larg))
1062
1063#else /* not NO_UNION_TYPE */
1064/* Use this for turning a (void *) into a Lisp_Object, as when the
1065 Lisp_Object is passed into a toolkit callback function. */
1066#define VOID_TO_LISP(larg,varg) \
1067 do { ((larg).v = (void *) (varg)); } while (0)
1068#define CVOID_TO_LISP(larg,varg) \
1069 do { ((larg).cv = (const void *) (varg)); } while (0)
1070
1071/* Use this for turning a Lisp_Object into a (void *), as when the
1072 Lisp_Object is passed into a toolkit callback function. */
1073#define LISP_TO_VOID(larg) ((larg).v)
1074#define LISP_TO_CVOID(larg) ((larg).cv)
1075#endif /* not NO_UNION_TYPE */
1076#endif /* USE_X_TOOLKIT */
1077
703f2808
JB
1078\f
1079/* The glyph datatype, used to represent characters on the display. */
1080
6b768554
KH
1081/* The low 19 bits (CHARACTERBITS) are the character code, and the
1082 bits above them except for the topmost two bits are the numeric
1083 face ID. If FID is the face ID of a glyph on a frame F, then
1084 F->display.x->faces[FID] contains the description of that face.
1085 This is an int instead of a short, so we can support a good bunch
1086 of face ID's (i.e. 2^(32 - 19 - 2) = 2048 ID's) ; given that we
1087 have no mechanism for tossing unused frame face ID's yet, we'll
1088 probably run out of 255 pretty quickly. */
703f2808
JB
1089#define GLYPH unsigned int
1090
6b768554
KH
1091/* Mask bit for a glyph of a character which should be written from
1092 right to left. */
1093#define GLYPH_MASK_REV_DIR 0x80000000
1094/* Mask bit for a padding glyph of a multi-column character. */
1095#define GLYPH_MASK_PADDING 0x40000000
1096/* Mask bits for face. */
1097#define GLYPH_MASK_FACE 0x3FF80000
1098/* Mask bits for character code. */
1099#define GLYPH_MASK_CHAR 0x0007FFFF /* The lowest 19 bits */
1100
49b0dd75
KH
1101/* The FAST macros assume that we already know we're in an X window. */
1102
703f2808 1103/* Given a character code and a face ID, return the appropriate glyph. */
000f4621 1104#define FAST_MAKE_GLYPH(char, face) ((char) | ((face) << CHARACTERBITS))
703f2808
JB
1105
1106/* Return a glyph's character code. */
6b768554 1107#define FAST_GLYPH_CHAR(glyph) ((glyph) & GLYPH_MASK_CHAR)
703f2808
JB
1108
1109/* Return a glyph's face ID. */
6b768554 1110#define FAST_GLYPH_FACE(glyph) (((glyph) & GLYPH_MASK_FACE) >> CHARACTERBITS)
49b0dd75
KH
1111
1112/* Slower versions that test the frame type first. */
5010d3b8
GM
1113#define MAKE_GLYPH(f, char, face) (FAST_MAKE_GLYPH (char, face))
1114#define GLYPH_CHAR(f, g) (FAST_GLYPH_CHAR (g))
1115#define GLYPH_FACE(f, g) (FAST_GLYPH_FACE (g))
703f2808 1116
b96656ce
KH
1117/* Return 1 iff GLYPH contains valid character code. */
1118#define GLYPH_CHAR_VALID_P(glyph) \
1119 ((GLYPH) (FAST_GLYPH_CHAR (glyph)) <= MAX_CHAR)
1120
4606cc9d
RS
1121/* The ID of the mode line highlighting face. */
1122#define GLYPH_MODE_LINE_FACE 1
3cfe6dfd
JB
1123\f
1124/* Data type checking */
1125
efb859b4 1126#define NILP(x) (XFASTINT (x) == XFASTINT (Qnil))
f498e3b2 1127#define GC_NILP(x) GC_EQ (x, Qnil)
3cfe6dfd 1128
4746118a 1129#ifdef LISP_FLOAT_TYPE
c5af3bb9 1130#define NUMBERP(x) (INTEGERP (x) || FLOATP (x))
c1a2bfad 1131#define GC_NUMBERP(x) (GC_INTEGERP (x) || GC_FLOATP (x))
4746118a 1132#else
c5af3bb9 1133#define NUMBERP(x) (INTEGERP (x))
c1a2bfad 1134#define GC_NUMBERP(x) (GC_INTEGERP (x))
4746118a 1135#endif
a4a9f09f 1136#define NATNUMP(x) (INTEGERP (x) && XINT (x) >= 0)
c1a2bfad 1137#define GC_NATNUMP(x) (GC_INTEGERP (x) && XINT (x) >= 0)
4746118a 1138
edfa9106 1139#define INTEGERP(x) (XTYPE ((x)) == Lisp_Int)
c1a2bfad 1140#define GC_INTEGERP(x) (XGCTYPE ((x)) == Lisp_Int)
edfa9106 1141#define SYMBOLP(x) (XTYPE ((x)) == Lisp_Symbol)
c1a2bfad 1142#define GC_SYMBOLP(x) (XGCTYPE ((x)) == Lisp_Symbol)
84d1833e 1143#define MISCP(x) (XTYPE ((x)) == Lisp_Misc)
c1a2bfad 1144#define GC_MISCP(x) (XGCTYPE ((x)) == Lisp_Misc)
b5088f80
KH
1145#define VECTORLIKEP(x) (XTYPE ((x)) == Lisp_Vectorlike)
1146#define GC_VECTORLIKEP(x) (XGCTYPE ((x)) == Lisp_Vectorlike)
edfa9106 1147#define STRINGP(x) (XTYPE ((x)) == Lisp_String)
c1a2bfad 1148#define GC_STRINGP(x) (XGCTYPE ((x)) == Lisp_String)
3cfe6dfd 1149#define CONSP(x) (XTYPE ((x)) == Lisp_Cons)
c1a2bfad 1150#define GC_CONSP(x) (XGCTYPE ((x)) == Lisp_Cons)
7c06ac2b 1151
20280af7 1152#ifdef LISP_FLOAT_TYPE
edfa9106 1153#define FLOATP(x) (XTYPE ((x)) == Lisp_Float)
c1a2bfad 1154#define GC_FLOATP(x) (XGCTYPE ((x)) == Lisp_Float)
20280af7
JB
1155#else
1156#define FLOATP(x) (0)
c1a2bfad 1157#define GC_FLOATP(x) (0)
20280af7 1158#endif
b5088f80
KH
1159#define VECTORP(x) (VECTORLIKEP (x) && !(XVECTOR (x)->size & PSEUDOVECTOR_FLAG))
1160#define GC_VECTORP(x) (GC_VECTORLIKEP (x) && !(XVECTOR (x)->size & PSEUDOVECTOR_FLAG))
a7aa28f6
RS
1161#define OVERLAYP(x) (MISCP (x) && XMISCTYPE (x) == Lisp_Misc_Overlay)
1162#define GC_OVERLAYP(x) (GC_MISCP (x) && XMISCTYPE (x) == Lisp_Misc_Overlay)
1163#define MARKERP(x) (MISCP (x) && XMISCTYPE (x) == Lisp_Misc_Marker)
1164#define GC_MARKERP(x) (GC_MISCP (x) && XMISCTYPE (x) == Lisp_Misc_Marker)
1165#define INTFWDP(x) (MISCP (x) && XMISCTYPE (x) == Lisp_Misc_Intfwd)
1166#define GC_INTFWDP(x) (GC_MISCP (x) && XMISCTYPE (x) == Lisp_Misc_Intfwd)
1167#define BOOLFWDP(x) (MISCP (x) && XMISCTYPE (x) == Lisp_Misc_Boolfwd)
1168#define GC_BOOLFWDP(x) (GC_MISCP (x) && XMISCTYPE (x) == Lisp_Misc_Boolfwd)
1169#define OBJFWDP(x) (MISCP (x) && XMISCTYPE (x) == Lisp_Misc_Objfwd)
1170#define GC_OBJFWDP(x) (GC_MISCP (x) && XMISCTYPE (x) == Lisp_Misc_Objfwd)
1171#define BUFFER_OBJFWDP(x) (MISCP (x) && XMISCTYPE (x) == Lisp_Misc_Buffer_Objfwd)
1172#define GC_BUFFER_OBJFWDP(x) (GC_MISCP (x) && XMISCTYPE (x) == Lisp_Misc_Buffer_Objfwd)
1173#define BUFFER_LOCAL_VALUEP(x) (MISCP (x) && XMISCTYPE (x) == Lisp_Misc_Buffer_Local_Value)
1174#define GC_BUFFER_LOCAL_VALUEP(x) (GC_MISCP (x) && XMISCTYPE (x) == Lisp_Misc_Buffer_Local_Value)
1175#define SOME_BUFFER_LOCAL_VALUEP(x) (MISCP (x) && XMISCTYPE (x) == Lisp_Misc_Some_Buffer_Local_Value)
1176#define GC_SOME_BUFFER_LOCAL_VALUEP(x) (GC_MISCP (x) && XMISCTYPE (x) == Lisp_Misc_Some_Buffer_Local_Value)
1177#define KBOARD_OBJFWDP(x) (MISCP (x) && XMISCTYPE (x) == Lisp_Misc_Kboard_Objfwd)
1178#define GC_KBOARD_OBJFWDP(x) (GC_MISCP (x) && XMISCTYPE (x) == Lisp_Misc_Kboard_Objfwd)
edfa9106 1179
7c06ac2b 1180
303a5c93 1181/* True if object X is a pseudovector whose code is CODE. */
7c06ac2b
RS
1182#define PSEUDOVECTORP(x, code) \
1183 (VECTORLIKEP (x) \
1184 && (((XVECTOR (x)->size & (PSEUDOVECTOR_FLAG | (code)))) \
1185 == (PSEUDOVECTOR_FLAG | (code))))
1186
303a5c93 1187/* True if object X is a pseudovector whose code is CODE.
7c06ac2b
RS
1188 This one works during GC. */
1189#define GC_PSEUDOVECTORP(x, code) \
1190 (GC_VECTORLIKEP (x) \
1191 && (((XVECTOR (x)->size & (PSEUDOVECTOR_FLAG | (code)))) \
1192 == (PSEUDOVECTOR_FLAG | (code))))
1193
1194/* Test for specific pseudovector types. */
1195#define WINDOW_CONFIGURATIONP(x) PSEUDOVECTORP (x, PVEC_WINDOW_CONFIGURATION)
1196#define GC_WINDOW_CONFIGURATIONP(x) GC_PSEUDOVECTORP (x, PVEC_WINDOW_CONFIGURATION)
1197#define PROCESSP(x) PSEUDOVECTORP (x, PVEC_PROCESS)
1198#define GC_PROCESSP(x) GC_PSEUDOVECTORP (x, PVEC_PROCESS)
1199#define WINDOWP(x) PSEUDOVECTORP (x, PVEC_WINDOW)
1200#define GC_WINDOWP(x) GC_PSEUDOVECTORP (x, PVEC_WINDOW)
1201#define SUBRP(x) PSEUDOVECTORP (x, PVEC_SUBR)
1202#define GC_SUBRP(x) GC_PSEUDOVECTORP (x, PVEC_SUBR)
1203#define COMPILEDP(x) PSEUDOVECTORP (x, PVEC_COMPILED)
1204#define GC_COMPILEDP(x) GC_PSEUDOVECTORP (x, PVEC_COMPILED)
99a3d506
RS
1205#define BUFFERP(x) PSEUDOVECTORP (x, PVEC_BUFFER)
1206#define GC_BUFFERP(x) GC_PSEUDOVECTORP (x, PVEC_BUFFER)
608ff985
RS
1207#define CHAR_TABLE_P(x) PSEUDOVECTORP (x, PVEC_CHAR_TABLE)
1208#define GC_CHAR_TABLE_P(x) GC_PSEUDOVECTORP (x, PVEC_CHAR_TABLE)
1209#define BOOL_VECTOR_P(x) PSEUDOVECTORP (x, PVEC_BOOL_VECTOR)
1210#define GC_BOOL_VECTOR_P(x) GC_PSEUDOVECTORP (x, PVEC_BOOL_VECTOR)
7c06ac2b
RS
1211#define FRAMEP(x) PSEUDOVECTORP (x, PVEC_FRAME)
1212#define GC_FRAMEP(x) GC_PSEUDOVECTORP (x, PVEC_FRAME)
ea724a01
KH
1213
1214#define SUB_CHAR_TABLE_P(x) (CHAR_TABLE_P (x) && NILP (XCHAR_TABLE (x)->top))
7c06ac2b 1215\f
3cfe6dfd 1216#define EQ(x, y) (XFASTINT (x) == XFASTINT (y))
f498e3b2 1217#define GC_EQ(x, y) (XGCTYPE (x) == XGCTYPE (y) && XPNTR (x) == XPNTR (y))
4746118a 1218
3cfe6dfd 1219#define CHECK_LIST(x, i) \
c5af3bb9 1220 do { if (!CONSP ((x)) && !NILP (x)) x = wrong_type_argument (Qlistp, (x)); } while (0)
3cfe6dfd
JB
1221
1222#define CHECK_STRING(x, i) \
c5af3bb9 1223 do { if (!STRINGP ((x))) x = wrong_type_argument (Qstringp, (x)); } while (0)
3cfe6dfd
JB
1224
1225#define CHECK_CONS(x, i) \
c5af3bb9 1226 do { if (!CONSP ((x))) x = wrong_type_argument (Qconsp, (x)); } while (0)
3cfe6dfd
JB
1227
1228#define CHECK_SYMBOL(x, i) \
c5af3bb9 1229 do { if (!SYMBOLP ((x))) x = wrong_type_argument (Qsymbolp, (x)); } while (0)
3cfe6dfd 1230
608ff985 1231#define CHECK_CHAR_TABLE(x, i) \
a97eb3f3 1232 do { if (!CHAR_TABLE_P ((x))) \
608ff985
RS
1233 x = wrong_type_argument (Qchar_table_p, (x)); } while (0)
1234
3cfe6dfd 1235#define CHECK_VECTOR(x, i) \
c5af3bb9 1236 do { if (!VECTORP ((x))) x = wrong_type_argument (Qvectorp, (x)); } while (0)
3cfe6dfd 1237
7f73dc9d
RS
1238#define CHECK_VECTOR_OR_CHAR_TABLE(x, i) \
1239 do { if (!VECTORP ((x)) && !CHAR_TABLE_P ((x))) \
1240 x = wrong_type_argument (Qvector_or_char_table_p, (x)); \
1241 } while (0)
1242
3cfe6dfd 1243#define CHECK_BUFFER(x, i) \
c5af3bb9 1244 do { if (!BUFFERP ((x))) x = wrong_type_argument (Qbufferp, (x)); } while (0)
3cfe6dfd
JB
1245
1246#define CHECK_WINDOW(x, i) \
c5af3bb9 1247 do { if (!WINDOWP ((x))) x = wrong_type_argument (Qwindowp, (x)); } while (0)
3cfe6dfd 1248
03273ec5 1249/* This macro rejects windows on the interior of the window tree as
e98227af 1250 "dead", which is what we want; this is an argument-checking macro, and
03273ec5
JB
1251 the user should never get access to interior windows.
1252
1253 A window of any sort, leaf or interior, is dead iff the buffer,
1254 vchild, and hchild members are all nil. */
1255
1256#define CHECK_LIVE_WINDOW(x, i) \
2ad18bfd 1257 do { \
c5af3bb9 1258 if (!WINDOWP ((x)) \
03273ec5 1259 || NILP (XWINDOW ((x))->buffer)) \
806b4d9b 1260 x = wrong_type_argument (Qwindow_live_p, (x)); \
2ad18bfd 1261 } while (0)
03273ec5 1262
3cfe6dfd 1263#define CHECK_PROCESS(x, i) \
c5af3bb9 1264 do { if (!PROCESSP ((x))) x = wrong_type_argument (Qprocessp, (x)); } while (0)
3cfe6dfd
JB
1265
1266#define CHECK_NUMBER(x, i) \
c5af3bb9 1267 do { if (!INTEGERP ((x))) x = wrong_type_argument (Qintegerp, (x)); } while (0)
3cfe6dfd
JB
1268
1269#define CHECK_NATNUM(x, i) \
a4a9f09f 1270 do { if (!NATNUMP (x)) x = wrong_type_argument (Qwholenump, (x)); } while (0)
3cfe6dfd
JB
1271
1272#define CHECK_MARKER(x, i) \
c5af3bb9 1273 do { if (!MARKERP ((x))) x = wrong_type_argument (Qmarkerp, (x)); } while (0)
3cfe6dfd
JB
1274
1275#define CHECK_NUMBER_COERCE_MARKER(x, i) \
221f4ef3 1276 do { if (MARKERP ((x))) XSETFASTINT (x, marker_position (x)); \
c5af3bb9 1277 else if (!INTEGERP ((x))) x = wrong_type_argument (Qinteger_or_marker_p, (x)); } while (0)
3cfe6dfd
JB
1278
1279#ifdef LISP_FLOAT_TYPE
1280
3cfe6dfd
JB
1281#define XFLOATINT(n) extract_float((n))
1282
1283#define CHECK_FLOAT(x, i) \
c5af3bb9 1284 do { if (!FLOATP (x)) \
2ad18bfd 1285 x = wrong_type_argument (Qfloatp, (x)); } while (0)
3cfe6dfd
JB
1286
1287#define CHECK_NUMBER_OR_FLOAT(x, i) \
c5af3bb9 1288 do { if (!FLOATP (x) && !INTEGERP (x)) \
2ad18bfd 1289 x = wrong_type_argument (Qnumberp, (x)); } while (0)
3cfe6dfd
JB
1290
1291#define CHECK_NUMBER_OR_FLOAT_COERCE_MARKER(x, i) \
221f4ef3 1292 do { if (MARKERP (x)) XSETFASTINT (x, marker_position (x)); \
c5af3bb9 1293 else if (!INTEGERP (x) && !FLOATP (x)) \
2ad18bfd 1294 x = wrong_type_argument (Qnumber_or_marker_p, (x)); } while (0)
3cfe6dfd
JB
1295
1296#else /* Not LISP_FLOAT_TYPE */
1297
1298#define CHECK_NUMBER_OR_FLOAT CHECK_NUMBER
1299
1300#define CHECK_NUMBER_OR_FLOAT_COERCE_MARKER CHECK_NUMBER_COERCE_MARKER
1301
1302#define XFLOATINT(n) XINT((n))
1303#endif /* LISP_FLOAT_TYPE */
1304
20280af7 1305#define CHECK_OVERLAY(x, i) \
c5af3bb9 1306 do { if (!OVERLAYP ((x))) x = wrong_type_argument (Qoverlayp, (x));} while (0)
20280af7 1307
3cfe6dfd
JB
1308/* Cast pointers to this type to compare them. Some machines want int. */
1309#ifndef PNTR_COMPARISON_TYPE
1310#define PNTR_COMPARISON_TYPE unsigned int
1311#endif
1312\f
1313/* Define a built-in function for calling from Lisp.
1314 `lname' should be the name to give the function in Lisp,
1315 as a null-terminated C string.
1316 `fnname' should be the name of the function in C.
1317 By convention, it starts with F.
1318 `sname' should be the name for the C constant structure
1319 that records information on this function for internal use.
1320 By convention, it should be the same as `fnname' but with S instead of F.
1321 It's too bad that C macros can't compute this from `fnname'.
1322 `minargs' should be a number, the minimum number of arguments allowed.
1323 `maxargs' should be a number, the maximum number of arguments allowed,
1324 or else MANY or UNEVALLED.
1325 MANY means pass a vector of evaluated arguments,
1326 in the form of an integer number-of-arguments
1327 followed by the address of a vector of Lisp_Objects
1328 which contains the argument values.
1329 UNEVALLED means pass the list of unevaluated arguments
1330 `prompt' says how to read arguments for an interactive call.
eab9d423 1331 See the doc string for `interactive'.
3cfe6dfd 1332 A null string means call interactively with no arguments.
eab9d423 1333 `doc' is documentation for the user. */
3cfe6dfd 1334
5125ca93 1335#if !defined (__STDC__) || defined (USE_NONANSI_DEFUN)
7c06ac2b
RS
1336#define DEFUN(lname, fnname, sname, minargs, maxargs, prompt, doc) \
1337 Lisp_Object fnname (); \
1338 struct Lisp_Subr sname = \
1339 { PVEC_SUBR | (sizeof (struct Lisp_Subr) / sizeof (EMACS_INT)), \
1340 fnname, minargs, maxargs, lname, prompt, 0}; \
3cfe6dfd
JB
1341 Lisp_Object fnname
1342
c451d7b1
RS
1343#else
1344
1345/* This version of DEFUN declares a function prototype with the right
99a3d506 1346 arguments, so we can catch errors with maxargs at compile-time. */
7c06ac2b
RS
1347#define DEFUN(lname, fnname, sname, minargs, maxargs, prompt, doc) \
1348 Lisp_Object fnname DEFUN_ARGS_ ## maxargs ; \
1349 struct Lisp_Subr sname = \
1350 { PVEC_SUBR | (sizeof (struct Lisp_Subr) / sizeof (EMACS_INT)), \
1351 fnname, minargs, maxargs, lname, prompt, 0}; \
c451d7b1
RS
1352 Lisp_Object fnname
1353
1354/* Note that the weird token-substitution semantics of ANSI C makes
99a3d506 1355 this work for MANY and UNEVALLED. */
c451d7b1
RS
1356#define DEFUN_ARGS_MANY (int, Lisp_Object *)
1357#define DEFUN_ARGS_UNEVALLED (Lisp_Object)
1358#define DEFUN_ARGS_0 (void)
1359#define DEFUN_ARGS_1 (Lisp_Object)
1360#define DEFUN_ARGS_2 (Lisp_Object, Lisp_Object)
1361#define DEFUN_ARGS_3 (Lisp_Object, Lisp_Object, Lisp_Object)
1362#define DEFUN_ARGS_4 (Lisp_Object, Lisp_Object, Lisp_Object, Lisp_Object)
1363#define DEFUN_ARGS_5 (Lisp_Object, Lisp_Object, Lisp_Object, Lisp_Object, \
1364 Lisp_Object)
1365#define DEFUN_ARGS_6 (Lisp_Object, Lisp_Object, Lisp_Object, Lisp_Object, \
1366 Lisp_Object, Lisp_Object)
1367#define DEFUN_ARGS_7 (Lisp_Object, Lisp_Object, Lisp_Object, Lisp_Object, \
1368 Lisp_Object, Lisp_Object, Lisp_Object)
5593f7e3
KH
1369#define DEFUN_ARGS_8 (Lisp_Object, Lisp_Object, Lisp_Object, Lisp_Object, \
1370 Lisp_Object, Lisp_Object, Lisp_Object, Lisp_Object)
c451d7b1
RS
1371#endif
1372
3cfe6dfd 1373/* defsubr (Sname);
99a3d506 1374 is how we define the symbol for function `name' at start-up time. */
526a2be7 1375extern void defsubr P_ ((struct Lisp_Subr *));
3cfe6dfd
JB
1376
1377#define MANY -2
1378#define UNEVALLED -1
1379
526a2be7
AS
1380extern void defvar_lisp P_ ((char *, Lisp_Object *));
1381extern void defvar_lisp_nopro P_ ((char *, Lisp_Object *));
1382extern void defvar_bool P_ ((char *, int *));
1383extern void defvar_int P_ ((char *, int *));
1384extern void defvar_per_buffer P_ ((char *, Lisp_Object *, Lisp_Object, char *));
1385extern void defvar_kboard P_ ((char *, int));
3cfe6dfd
JB
1386
1387/* Macros we use to define forwarded Lisp variables.
1388 These are used in the syms_of_FILENAME functions. */
1389
3cfe6dfd
JB
1390#define DEFVAR_LISP(lname, vname, doc) defvar_lisp (lname, vname)
1391#define DEFVAR_LISP_NOPRO(lname, vname, doc) defvar_lisp_nopro (lname, vname)
1392#define DEFVAR_BOOL(lname, vname, doc) defvar_bool (lname, vname)
1393#define DEFVAR_INT(lname, vname, doc) defvar_int (lname, vname)
ef15f270
JB
1394#define DEFVAR_PER_BUFFER(lname, vname, type, doc) \
1395 defvar_per_buffer (lname, vname, type, 0)
32462604
KH
1396#define DEFVAR_KBOARD(lname, vname, doc) \
1397 defvar_kboard (lname, \
1398 (int)((char *)(&current_kboard->vname) \
1399 - (char *)current_kboard))
3cfe6dfd 1400\f
78ca380c
JB
1401/* Structure for recording Lisp call stack for backtrace purposes. */
1402
1403/* The special binding stack holds the outer values of variables while
1404 they are bound by a function application or a let form, stores the
1405 code to be executed for Lisp unwind-protect forms, and stores the C
1406 functions to be called for record_unwind_protect.
1407
1408 If func is non-zero, undoing this binding applies func to old_value;
1409 This implements record_unwind_protect.
1410 If func is zero and symbol is nil, undoing this binding evaluates
1411 the list of forms in old_value; this implements Lisp's unwind-protect
1412 form.
1413 Otherwise, undoing this binding stores old_value as symbol's value; this
1414 undoes the bindings made by a let form or function call. */
3cfe6dfd
JB
1415struct specbinding
1416 {
1417 Lisp_Object symbol, old_value;
526a2be7 1418 Lisp_Object (*func) P_ ((Lisp_Object));
3cfe6dfd
JB
1419 Lisp_Object unused; /* Dividing by 16 is faster than by 12 */
1420 };
1421
1422extern struct specbinding *specpdl;
1423extern struct specbinding *specpdl_ptr;
1424extern int specpdl_size;
1425
78ca380c 1426/* Everything needed to describe an active condition case. */
3cfe6dfd
JB
1427struct handler
1428 {
78ca380c 1429 /* The handler clauses and variable from the condition-case form. */
3cfe6dfd
JB
1430 Lisp_Object handler;
1431 Lisp_Object var;
22bbbd42
RS
1432 /* Fsignal stores here the condition-case clause that applies,
1433 and Fcondition_case thus knows which clause to run. */
1434 Lisp_Object chosen_clause;
78ca380c
JB
1435
1436 /* Used to effect the longjump out to the handler. */
3cfe6dfd 1437 struct catchtag *tag;
78ca380c
JB
1438
1439 /* The next enclosing handler. */
3cfe6dfd
JB
1440 struct handler *next;
1441 };
1442
1443extern struct handler *handlerlist;
1444
1445extern struct catchtag *catchlist;
1446extern struct backtrace *backtrace_list;
1447
22bbbd42
RS
1448extern Lisp_Object memory_signal_data;
1449
3cfe6dfd
JB
1450/* An address near the bottom of the stack.
1451 Tells GC how to save a copy of the stack. */
1452extern char *stack_bottom;
1453
99a3d506 1454/* Check quit-flag and quit if it is non-nil. */
3cfe6dfd
JB
1455
1456#define QUIT \
efb859b4 1457 if (!NILP (Vquit_flag) && NILP (Vinhibit_quit)) \
3cfe6dfd
JB
1458 { Vquit_flag = Qnil; Fsignal (Qquit, Qnil); }
1459
1460/* Nonzero if ought to quit now. */
1461
efb859b4 1462#define QUITP (!NILP (Vquit_flag) && NILP (Vinhibit_quit))
3cfe6dfd 1463\f
8ac90470 1464/* Variables used locally in the following case handling macros. */
2e34157c
RS
1465extern int case_temp1;
1466extern Lisp_Object case_temp2;
8ac90470 1467
e98227af 1468/* Current buffer's map from characters to lower-case characters. */
3cfe6dfd 1469
8ac90470 1470#define DOWNCASE_TABLE current_buffer->downcase_table
3cfe6dfd 1471
e98227af 1472/* Current buffer's map from characters to upper-case characters. */
3cfe6dfd 1473
8ac90470 1474#define UPCASE_TABLE current_buffer->upcase_table
3cfe6dfd 1475
e98227af 1476/* Downcase a character, or make no change if that cannot be done. */
3cfe6dfd 1477
8ac90470
KH
1478#define DOWNCASE(CH) \
1479 ((case_temp1 = (CH), \
1480 case_temp2 = CHAR_TABLE_REF (DOWNCASE_TABLE, case_temp1), \
1481 NATNUMP (case_temp2)) \
1482 ? XFASTINT (case_temp2) : case_temp1)
3cfe6dfd 1483
e98227af 1484/* 1 if CH is upper case. */
3cfe6dfd 1485
476d47ce 1486#define UPPERCASEP(CH) (DOWNCASE (CH) != (CH))
3cfe6dfd 1487
e98227af 1488/* 1 if CH is neither upper nor lower case. */
3cfe6dfd 1489
8ac90470 1490#define NOCASEP(CH) (UPCASE1 (CH) == (CH))
3cfe6dfd 1491
e98227af 1492/* 1 if CH is lower case. */
3cfe6dfd 1493
e98227af 1494#define LOWERCASEP(CH) (!UPPERCASEP (CH) && !NOCASEP(CH))
3cfe6dfd 1495
e98227af 1496/* Upcase a character, or make no change if that cannot be done. */
3cfe6dfd 1497
e98227af
KH
1498#define UPCASE(CH) (!UPPERCASEP (CH) ? UPCASE1 (CH) : (CH))
1499
1500/* Upcase a character known to be not upper case. */
1501
8ac90470
KH
1502#define UPCASE1(CH) \
1503 ((case_temp1 = (CH), \
1504 case_temp2 = CHAR_TABLE_REF (UPCASE_TABLE, case_temp1), \
1505 NATNUMP (case_temp2)) \
1506 ? XFASTINT (case_temp2) : case_temp1)
3cfe6dfd 1507
c6a3c83c 1508extern Lisp_Object Vascii_downcase_table;
3cfe6dfd 1509\f
99a3d506 1510/* Number of bytes of structure consed since last GC. */
3cfe6dfd
JB
1511
1512extern int consing_since_gc;
1513
99a3d506 1514/* Threshold for doing another gc. */
3cfe6dfd 1515
65deefca 1516extern int gc_cons_threshold;
3cfe6dfd 1517
99a3d506 1518/* Structure for recording stack slots that need marking. */
3cfe6dfd
JB
1519
1520/* This is a chain of structures, each of which points at a Lisp_Object variable
1521 whose value should be marked in garbage collection.
1522 Normally every link of the chain is an automatic variable of a function,
1523 and its `val' points to some argument or local variable of the function.
1524 On exit to the function, the chain is set back to the value it had on entry.
e5f55f07
BF
1525 This way, no link remains in the chain when the stack frame containing the
1526 link disappears.
3cfe6dfd
JB
1527
1528 Every function that can call Feval must protect in this fashion all
99a3d506 1529 Lisp_Object variables whose contents will be used again. */
3cfe6dfd
JB
1530
1531extern struct gcpro *gcprolist;
1532
1533struct gcpro
1534 {
1535 struct gcpro *next;
1536 Lisp_Object *var; /* Address of first protected variable */
1537 int nvars; /* Number of consecutive protected variables */
1538 };
1539
1540#define GCPRO1(varname) \
1541 {gcpro1.next = gcprolist; gcpro1.var = &varname; gcpro1.nvars = 1; \
1542 gcprolist = &gcpro1; }
1543
1544#define GCPRO2(varname1, varname2) \
1545 {gcpro1.next = gcprolist; gcpro1.var = &varname1; gcpro1.nvars = 1; \
1546 gcpro2.next = &gcpro1; gcpro2.var = &varname2; gcpro2.nvars = 1; \
1547 gcprolist = &gcpro2; }
1548
1549#define GCPRO3(varname1, varname2, varname3) \
1550 {gcpro1.next = gcprolist; gcpro1.var = &varname1; gcpro1.nvars = 1; \
1551 gcpro2.next = &gcpro1; gcpro2.var = &varname2; gcpro2.nvars = 1; \
1552 gcpro3.next = &gcpro2; gcpro3.var = &varname3; gcpro3.nvars = 1; \
1553 gcprolist = &gcpro3; }
1554
1555#define GCPRO4(varname1, varname2, varname3, varname4) \
1556 {gcpro1.next = gcprolist; gcpro1.var = &varname1; gcpro1.nvars = 1; \
1557 gcpro2.next = &gcpro1; gcpro2.var = &varname2; gcpro2.nvars = 1; \
1558 gcpro3.next = &gcpro2; gcpro3.var = &varname3; gcpro3.nvars = 1; \
1559 gcpro4.next = &gcpro3; gcpro4.var = &varname4; gcpro4.nvars = 1; \
1560 gcprolist = &gcpro4; }
1561
c47b8d02
RS
1562#define GCPRO5(varname1, varname2, varname3, varname4, varname5) \
1563 {gcpro1.next = gcprolist; gcpro1.var = &varname1; gcpro1.nvars = 1; \
1564 gcpro2.next = &gcpro1; gcpro2.var = &varname2; gcpro2.nvars = 1; \
1565 gcpro3.next = &gcpro2; gcpro3.var = &varname3; gcpro3.nvars = 1; \
1566 gcpro4.next = &gcpro3; gcpro4.var = &varname4; gcpro4.nvars = 1; \
1567 gcpro5.next = &gcpro4; gcpro5.var = &varname5; gcpro5.nvars = 1; \
1568 gcprolist = &gcpro5; }
1569
99a3d506 1570/* Call staticpro (&var) to protect static variable `var'. */
3cfe6dfd 1571
526a2be7 1572void staticpro P_ ((Lisp_Object *));
e98227af 1573
3cfe6dfd
JB
1574#define UNGCPRO (gcprolist = gcpro1.next)
1575
5db82c9d 1576/* Evaluate expr, UNGCPRO, and then return the value of expr. */
c47b8d02 1577#define RETURN_UNGCPRO(expr) \
f3ca341e 1578if (1) \
c47b8d02
RS
1579 { \
1580 Lisp_Object ret_ungc_val; \
1581 ret_ungc_val = (expr); \
1582 UNGCPRO; \
1583 return ret_ungc_val; \
1584 } \
f3ca341e 1585else
3cfe6dfd 1586\f
2f69f2ec
RS
1587/* Declare a Lisp-callable function. The MAXARGS parameter has the same
1588 meaning as in the DEFUN macro, and is used to construct a prototype. */
1589#if !defined (__STDC__) || defined (USE_NONANSI_DEFUN)
1590#define EXFUN(fnname, maxargs) \
1591 extern Lisp_Object fnname ()
1592#else
1593/* We can use the same trick as in the DEFUN macro to generate the
1594 appropriate prototype. */
1595#define EXFUN(fnname, maxargs) \
1596 extern Lisp_Object fnname DEFUN_ARGS_ ## maxargs
1597#endif
1598
526a2be7
AS
1599/* Forward declarations for prototypes. */
1600struct window;
1601struct frame;
2f69f2ec 1602
3cfe6dfd
JB
1603/* Defined in data.c */
1604extern Lisp_Object Qnil, Qt, Qquote, Qlambda, Qsubr, Qunbound;
1605extern Lisp_Object Qerror_conditions, Qerror_message, Qtop_level;
1606extern Lisp_Object Qerror, Qquit, Qwrong_type_argument, Qargs_out_of_range;
1607extern Lisp_Object Qvoid_variable, Qvoid_function;
1608extern Lisp_Object Qsetting_constant, Qinvalid_read_syntax;
1609extern Lisp_Object Qinvalid_function, Qwrong_number_of_arguments, Qno_catch;
1610extern Lisp_Object Qend_of_file, Qarith_error;
1611extern Lisp_Object Qbeginning_of_buffer, Qend_of_buffer, Qbuffer_read_only;
83125cd7 1612extern Lisp_Object Qmark_inactive;
3cfe6dfd 1613
59b4254d
JB
1614extern Lisp_Object Qrange_error, Qdomain_error, Qsingularity_error;
1615extern Lisp_Object Qoverflow_error, Qunderflow_error;
623ed1b0 1616
07a97bf8
RS
1617extern Lisp_Object Qintegerp, Qnumberp, Qnatnump, Qwholenump;
1618extern Lisp_Object Qsymbolp, Qlistp, Qconsp;
3cfe6dfd
JB
1619extern Lisp_Object Qstringp, Qarrayp, Qsequencep, Qbufferp;
1620extern Lisp_Object Qchar_or_string_p, Qmarkerp, Qvectorp;
4de86b16 1621extern Lisp_Object Qinteger_or_marker_p, Qnumber_or_marker_p;
7f73dc9d 1622extern Lisp_Object Qchar_table_p, Qvector_or_char_table_p;
4de86b16 1623extern Lisp_Object Qboundp, Qfboundp;
cde20f41 1624extern Lisp_Object Qbuffer_or_string_p;
3cfe6dfd
JB
1625extern Lisp_Object Qcdr;
1626
1627#ifdef LISP_FLOAT_TYPE
1628extern Lisp_Object Qfloatp, Qinteger_or_floatp, Qinteger_or_float_or_marker_p;
1629#endif /* LISP_FLOAT_TYPE */
1630
ff11dfa1 1631extern Lisp_Object Qframep;
3cfe6dfd 1632
2f69f2ec
RS
1633EXFUN (Feq, 2);
1634EXFUN (Fnull, 1);
1635EXFUN (Flistp, 1);
1636EXFUN (Fconsp, 1);
1637EXFUN (Fatom, 1);
1638EXFUN (Fnlistp, 1);
1639EXFUN (Fintegerp, 1);
1640EXFUN (Fnatnump, 1);
1641EXFUN (Fsymbolp, 1);
1642EXFUN (Fvectorp, 1);
1643EXFUN (Fstringp, 1);
a1b5012f 1644EXFUN (Fmultibyte_string_p, 1);
2f69f2ec
RS
1645EXFUN (Farrayp, 1);
1646EXFUN (Fsequencep, 1);
1647EXFUN (Fbufferp, 1);
1648EXFUN (Fmarkerp, 1);
1649EXFUN (Fsubrp, 1);
1650EXFUN (Fchar_or_string_p, 1);
1651EXFUN (Finteger_or_marker_p, 1);
3cfe6dfd 1652#ifdef LISP_FLOAT_TYPE
2f69f2ec
RS
1653EXFUN (Ffloatp, 1);
1654EXFUN (Finteger_or_floatp, 1);
1655EXFUN (Finteger_or_float_or_marker_p, 1);
3cfe6dfd
JB
1656#endif /* LISP_FLOAT_TYPE */
1657
2f69f2ec
RS
1658EXFUN (Fcar, 1);
1659EXFUN (Fcar_safe, 1);
1660EXFUN (Fcdr, 1);
1661EXFUN (Fcdr_safe, 1);
1662EXFUN (Fsetcar, 2);
1663EXFUN (Fsetcdr, 2);
1664EXFUN (Fboundp, 1);
1665EXFUN (Ffboundp, 1);
1666EXFUN (Fmakunbound, 1);
1667EXFUN (Ffmakunbound, 1);
1668EXFUN (Fsymbol_function, 1);
1669EXFUN (Fsymbol_plist, 1);
1670EXFUN (Fsymbol_name, 1);
1671extern Lisp_Object indirect_function P_ ((Lisp_Object));
1672EXFUN (Findirect_function, 1);
1673EXFUN (Ffset, 2);
1674EXFUN (Fsetplist, 2);
1675EXFUN (Fsymbol_value, 1);
a154f406 1676extern Lisp_Object find_symbol_value P_ ((Lisp_Object));
2f69f2ec
RS
1677EXFUN (Fset, 2);
1678EXFUN (Fdefault_value, 1);
1679EXFUN (Fset_default, 2);
1680EXFUN (Fdefault_boundp, 1);
1681EXFUN (Fmake_local_variable, 1);
a154f406 1682EXFUN (Flocal_variable_p, 2);
2f69f2ec
RS
1683EXFUN (Flocal_variable_if_set_p, 2);
1684
1685EXFUN (Faref, 2);
1686EXFUN (Faset, 3);
1687
1688EXFUN (Fstring_to_number, 2);
1689EXFUN (Fnumber_to_string, 1);
1690EXFUN (Feqlsign, 2);
1691EXFUN (Fgtr, 2);
1692EXFUN (Flss, 2);
1693EXFUN (Fgeq, 2);
1694EXFUN (Fleq, 2);
1695EXFUN (Fneq, 2);
1696EXFUN (Fzerop, 1);
1697EXFUN (Fplus, MANY);
1698EXFUN (Fminus, MANY);
1699EXFUN (Ftimes, MANY);
1700EXFUN (Fquo, MANY);
1701EXFUN (Frem, 2);
1702EXFUN (Fmax, MANY);
1703EXFUN (Fmin, MANY);
1704EXFUN (Flogand, MANY);
1705EXFUN (Flogior, MANY);
1706EXFUN (Flogxor, MANY);
1707EXFUN (Flognot, 1);
1708EXFUN (Flsh, 2);
1709EXFUN (Fash, 2);
1710
1711EXFUN (Fadd1, 1);
1712EXFUN (Fsub1, 1);
1713
1714extern Lisp_Object long_to_cons P_ ((unsigned long));
1715extern unsigned long cons_to_long P_ ((Lisp_Object));
1716extern void args_out_of_range P_ ((Lisp_Object, Lisp_Object));
1717extern void args_out_of_range_3 P_ ((Lisp_Object, Lisp_Object, Lisp_Object));
1718extern Lisp_Object wrong_type_argument P_ ((Lisp_Object, Lisp_Object));
1719extern void store_symval_forwarding P_ ((Lisp_Object, Lisp_Object, Lisp_Object));
1720extern Lisp_Object do_symval_forwarding P_ ((Lisp_Object));
526a2be7 1721extern Lisp_Object set_internal P_ ((Lisp_Object, Lisp_Object, int));
46abf440
AS
1722extern void syms_of_data P_ ((void));
1723extern void init_data P_ ((void));
3cfe6dfd 1724
a37e10f9 1725/* Defined in cmds.c */
2f69f2ec
RS
1726EXFUN (Fend_of_line, 1);
1727EXFUN (Fforward_char, 1);
1728EXFUN (Fforward_line, 1);
526a2be7
AS
1729extern int forward_point P_ ((int));
1730extern int internal_self_insert P_ ((int, int));
46abf440
AS
1731extern void syms_of_cmds P_ ((void));
1732extern void keys_of_cmds P_ ((void));
a37e10f9 1733
6b768554 1734/* Defined in coding.c */
2f69f2ec
RS
1735EXFUN (Fcoding_system_p, 1);
1736EXFUN (Fcheck_coding_system, 1);
34ba1f2e 1737EXFUN (Fread_coding_system, 2);
2f69f2ec 1738EXFUN (Fread_non_nil_coding_system, 1);
a154f406 1739EXFUN (Ffind_operation_coding_system, MANY);
526a2be7
AS
1740EXFUN (Fencode_coding_string, 3);
1741EXFUN (Fdecode_coding_string, 3);
080cb8cd 1742extern Lisp_Object detect_coding_system P_ ((unsigned char *, int, int));
85ef85ae 1743extern void init_coding P_ ((void));
46abf440
AS
1744extern void init_coding_once P_ ((void));
1745extern void syms_of_coding P_ ((void));
6b768554 1746
5e741a41 1747/* Defined in charset.c */
b4e187e2 1748extern int nonascii_insert_offset;
bb9c978a 1749extern Lisp_Object Vnonascii_translation_table;
5e741a41 1750EXFUN (Fchar_bytes, 1);
ec5d8db7 1751EXFUN (Fchar_width, 1);
a1b5012f
RS
1752extern int chars_in_text P_ ((unsigned char *, int));
1753extern int multibyte_chars_in_text P_ ((unsigned char *, int));
4a2f9c6a 1754extern int unibyte_char_to_multibyte P_ ((int));
5666cc6f 1755extern int multibyte_char_to_unibyte P_ ((int, Lisp_Object));
b4e187e2 1756extern Lisp_Object Qcharset;
46abf440
AS
1757extern void init_charset_once P_ ((void));
1758extern void syms_of_charset P_ ((void));
5e741a41 1759
a37e10f9 1760/* Defined in syntax.c */
2f69f2ec
RS
1761EXFUN (Fforward_word, 1);
1762EXFUN (Fskip_chars_forward, 2);
1763EXFUN (Fskip_chars_backward, 2);
526a2be7
AS
1764EXFUN (Fsyntax_table_p, 1);
1765EXFUN (Fsyntax_table, 0);
1766EXFUN (Fset_syntax_table, 1);
46abf440
AS
1767extern void init_syntax_once P_ ((void));
1768extern void syms_of_syntax P_ ((void));
a37e10f9 1769
3cfe6dfd
JB
1770/* Defined in fns.c */
1771extern Lisp_Object Qstring_lessp;
1772extern Lisp_Object Vfeatures;
5010d3b8
GM
1773unsigned sxhash P_ ((Lisp_Object, int));
1774Lisp_Object make_hash_table P_ ((Lisp_Object, Lisp_Object, Lisp_Object,
1775 Lisp_Object, Lisp_Object, Lisp_Object,
1776 Lisp_Object));
1777int hash_lookup P_ ((struct Lisp_Hash_Table *, Lisp_Object, unsigned *));
1778void hash_put P_ ((struct Lisp_Hash_Table *, Lisp_Object, Lisp_Object,
1779 unsigned));
1780void hash_remove P_ ((struct Lisp_Hash_Table *, Lisp_Object));
1781void hash_clear P_ ((struct Lisp_Hash_Table *));
1782void remove_hash_entry P_ ((struct Lisp_Hash_Table *, int));
1783EXFUN (Fsxhash, 1);
1784EXFUN (Fmake_hash_table, MANY);
1785EXFUN (Fhash_table_count, 1);
1786EXFUN (Fhash_table_rehash_size, 1);
1787EXFUN (Fhash_table_rehash_threshold, 1);
1788EXFUN (Fhash_table_size, 1);
1789EXFUN (Fhash_table_test, 1);
1790EXFUN (Fhash_table_weak, 1);
1791EXFUN (Fhash_table_p, 1);
1792EXFUN (Fclrhash, 1);
1793EXFUN (Fgethash, 3);
1794EXFUN (Fputhash, 3);
1795EXFUN (Fremhash, 2);
1796EXFUN (Fmaphash, 2);
1797EXFUN (Fdefine_hash_table_test, 3);
1798
2f69f2ec
RS
1799EXFUN (Fidentity, 1);
1800EXFUN (Frandom, 1);
1801EXFUN (Flength, 1);
1802EXFUN (Fsafe_length, 1);
1803EXFUN (Fappend, MANY);
1804EXFUN (Fconcat, MANY);
1805EXFUN (Fvconcat, MANY);
1806EXFUN (Fcopy_sequence, 1);
b4e187e2
RS
1807EXFUN (Fstring_make_multibyte, 1);
1808EXFUN (Fstring_make_unibyte, 1);
1809EXFUN (Fstring_as_multibyte, 1);
1810EXFUN (Fstring_as_unibyte, 1);
2f69f2ec 1811EXFUN (Fsubstring, 3);
a1b5012f 1812extern Lisp_Object substring_both P_ ((Lisp_Object, int, int, int, int));
2f69f2ec
RS
1813EXFUN (Fnth, 2);
1814EXFUN (Fnthcdr, 2);
1815EXFUN (Fmemq, 2);
1816EXFUN (Fassq, 2);
1817EXFUN (Fassoc, 2);
1818EXFUN (Felt, 2);
1819EXFUN (Fmember, 2);
1820EXFUN (Frassq, 2);
1821EXFUN (Fdelq, 2);
1822EXFUN (Fsort, 2);
1823EXFUN (Freverse, 1);
1824EXFUN (Fnreverse, 1);
1825EXFUN (Fget, 2);
1826EXFUN (Fput, 3);
1827EXFUN (Fequal, 2);
1828EXFUN (Ffillarray, 2);
1829EXFUN (Fnconc, MANY);
1830EXFUN (Fmapcar, 2);
1831EXFUN (Fmapconcat, 3);
1832EXFUN (Fy_or_n_p, 1);
1833extern Lisp_Object do_yes_or_no_p P_ ((Lisp_Object));
1834EXFUN (Ffeaturep, 1);
6f39b7c8 1835EXFUN (Frequire, 3);
2f69f2ec
RS
1836EXFUN (Fprovide, 1);
1837extern Lisp_Object concat2 P_ ((Lisp_Object, Lisp_Object));
1838extern Lisp_Object concat3 P_ ((Lisp_Object, Lisp_Object, Lisp_Object));
1839extern Lisp_Object nconc2 P_ ((Lisp_Object, Lisp_Object));
1840extern Lisp_Object assq_no_quit P_ ((Lisp_Object, Lisp_Object));
1c5c931a 1841extern void clear_string_char_byte_cache P_ (());
a1b5012f
RS
1842extern int string_char_to_byte P_ ((Lisp_Object, int));
1843extern int string_byte_to_char P_ ((Lisp_Object, int));
ec5d8db7
AS
1844extern Lisp_Object string_make_multibyte P_ ((Lisp_Object));
1845extern Lisp_Object string_make_unibyte P_ ((Lisp_Object));
2f69f2ec
RS
1846EXFUN (Fcopy_alist, 1);
1847EXFUN (Fplist_get, 2);
5010d3b8 1848EXFUN (Fplist_put, 3);
2f69f2ec
RS
1849EXFUN (Fset_char_table_parent, 2);
1850EXFUN (Fchar_table_extra_slot, 2);
526a2be7 1851EXFUN (Fset_char_table_extra_slot, 3);
2f69f2ec
RS
1852EXFUN (Frassoc, 2);
1853EXFUN (Fstring_equal, 2);
42d65b5f 1854EXFUN (Fcompare_strings, 7);
2f69f2ec 1855EXFUN (Fstring_lessp, 2);
ec5d8db7 1856extern int char_table_translate P_ ((Lisp_Object, int));
526a2be7
AS
1857extern void map_char_table P_ ((void (*) (Lisp_Object, Lisp_Object, Lisp_Object),
1858 Lisp_Object, Lisp_Object, Lisp_Object, int,
1859 Lisp_Object *));
46abf440 1860extern void syms_of_fns P_ ((void));
2f69f2ec
RS
1861
1862/* Defined in floatfns.c */
1863#ifdef LISP_FLOAT_TYPE
1864extern double extract_float P_ ((Lisp_Object));
1865EXFUN (Ffloat, 1);
1866#endif /* LISP_FLOAT_TYPE */
1867EXFUN (Ftruncate, 2);
46abf440
AS
1868extern void init_floatfns P_ ((void));
1869extern void syms_of_floatfns P_ ((void));
3cfe6dfd 1870
c98adc1b 1871/* Defined in insdel.c */
2f69f2ec 1872extern void move_gap P_ ((int));
4ed24bf3 1873extern void move_gap_both P_ ((int, int));
2f69f2ec 1874extern void make_gap P_ ((int));
a1b5012f
RS
1875extern int copy_text P_ ((unsigned char *, unsigned char *, int, int, int));
1876extern int count_size_as_multibyte P_ ((unsigned char *, int));
ec5d8db7
AS
1877extern int count_combining_before P_ ((unsigned char *, int, int, int));
1878extern int count_combining_after P_ ((unsigned char *, int, int, int));
2f69f2ec
RS
1879extern void insert P_ ((unsigned char *, int));
1880extern void insert_and_inherit P_ ((unsigned char *, int));
4ed24bf3 1881extern void insert_1 P_ ((unsigned char *, int, int, int, int));
a1b5012f
RS
1882extern void insert_1_both P_ ((unsigned char *, int, int, int, int, int));
1883extern void insert_from_string P_ ((Lisp_Object, int, int, int, int, int));
2f69f2ec
RS
1884extern void insert_from_buffer P_ ((struct buffer *, int, int, int));
1885extern void insert_char P_ ((int));
1886extern void insert_string P_ ((char *));
1887extern void insert_before_markers P_ ((unsigned char *, int));
1888extern void insert_before_markers_and_inherit P_ ((unsigned char *, int));
a1b5012f 1889extern void insert_from_string_before_markers P_ ((Lisp_Object, int, int, int, int, int));
2f69f2ec
RS
1890extern void del_range P_ ((int, int));
1891extern void del_range_1 P_ ((int, int, int));
4ed24bf3
RS
1892extern void del_range_byte P_ ((int, int, int));
1893extern void del_range_both P_ ((int, int, int, int, int));
1894extern void del_range_2 P_ ((int, int, int, int));
2f69f2ec
RS
1895extern void modify_region P_ ((struct buffer *, int, int));
1896extern void prepare_to_modify_buffer P_ ((int, int, int *));
1897extern void signal_before_change P_ ((int, int, int *));
1898extern void signal_after_change P_ ((int, int, int));
1e94b998
KH
1899extern void adjust_after_replace P_ ((int, int, Lisp_Object, int, int));
1900extern void adjust_after_insert P_ ((int, int, int, int, int));
d8fc7ce4 1901extern void replace_range P_ ((int, int, Lisp_Object, int, int, int));
46abf440 1902extern void syms_of_insdel P_ ((void));
c98adc1b 1903
1747fb16 1904/* Defined in dispnew.c */
2f69f2ec
RS
1905EXFUN (Fding, 1);
1906EXFUN (Fredraw_display, 0);
1907EXFUN (Fsleep_for, 2);
1908EXFUN (Fsit_for, 3);
526a2be7 1909extern Lisp_Object sit_for P_ ((int, int, int, int, int));
46abf440
AS
1910extern void init_display P_ ((void));
1911extern void syms_of_display P_ ((void));
1747fb16 1912
c98adc1b 1913/* Defined in xdisp.c */
d74347bc 1914extern Lisp_Object Qinhibit_redisplay;
439ae27b 1915extern Lisp_Object Vmessage_log_max;
a1b5012f 1916extern int message_enable_multibyte;
2f69f2ec
RS
1917extern void message P_ ((/* char *, ... */));
1918extern void message_nolog P_ ((/* char *, ... */));
1919extern void message1 P_ ((char *));
1920extern void message1_nolog P_ ((char *));
a1b5012f 1921extern void message2 P_ ((char *, int, int));
3b4490b3 1922extern void message2_nolog P_ ((char *, int, int));
5010d3b8
GM
1923extern void message3 P_ ((Lisp_Object, int, int));
1924extern void message3_nolog P_ ((Lisp_Object, int, int));
a1b5012f
RS
1925extern void message_dolog P_ ((char *, int, int, int));
1926extern void message_with_string P_ ((char *, Lisp_Object, int));
2f69f2ec 1927extern void message_log_maybe_newline P_ ((void));
526a2be7
AS
1928extern void update_echo_area P_ ((void));
1929extern void truncate_echo_area P_ ((int));
1930extern void redisplay P_ ((void));
1931extern void redisplay_preserve_echo_area P_ ((void));
1932extern void mark_window_display_accurate P_ ((Lisp_Object, int));
1933extern int invisible_p P_ ((Lisp_Object, Lisp_Object));
1934extern void prepare_menu_bars P_ ((void));
46abf440
AS
1935extern void syms_of_xdisp P_ ((void));
1936extern void init_xdisp P_ ((void));
c98adc1b 1937
3cfe6dfd 1938/* Defined in alloc.c */
526a2be7
AS
1939extern void malloc_warning P_ ((char *));
1940extern void memory_full P_ ((void));
1941extern void buffer_memory_full P_ ((void));
5010d3b8
GM
1942extern int survives_gc_p P_ ((Lisp_Object));
1943extern void mark_object P_ ((Lisp_Object *));
3cfe6dfd 1944extern Lisp_Object Vpurify_flag;
2f69f2ec 1945EXFUN (Fcons, 2);
b4e187e2
RS
1946EXFUN (list2, 2);
1947EXFUN (list3, 3);
1948EXFUN (list4, 4);
1949EXFUN (list5, 5);
2f69f2ec
RS
1950EXFUN (Flist, MANY);
1951EXFUN (Fmake_list, 2);
1952extern Lisp_Object allocate_misc P_ ((void));
1953EXFUN (Fmake_vector, 2);
1954EXFUN (Fvector, MANY);
1955EXFUN (Fmake_symbol, 1);
1956EXFUN (Fmake_marker, 0);
1957EXFUN (Fmake_string, 2);
1958extern Lisp_Object build_string P_ ((char *));
1959extern Lisp_Object make_string P_ ((char *, int));
ec5d8db7 1960extern Lisp_Object make_unibyte_string P_ ((char *, int));
d8fc7ce4 1961extern Lisp_Object make_multibyte_string P_ ((char *, int, int));
2f69f2ec
RS
1962extern Lisp_Object make_event_array P_ ((int, Lisp_Object *));
1963extern Lisp_Object make_uninit_string P_ ((int));
a1b5012f 1964extern Lisp_Object make_uninit_multibyte_string P_ ((int, int));
d8fc7ce4
KH
1965extern Lisp_Object make_string_from_bytes P_ ((char *, int, int));
1966extern Lisp_Object make_specified_string P_ ((char *, int, int, int));
2f69f2ec 1967EXFUN (Fpurecopy, 1);
d8fc7ce4 1968extern Lisp_Object make_pure_string P_ ((char *, int, int, int));
2f69f2ec
RS
1969extern Lisp_Object pure_cons P_ ((Lisp_Object, Lisp_Object));
1970extern Lisp_Object make_pure_vector P_ ((EMACS_INT));
1971EXFUN (Fgarbage_collect, 0);
1972EXFUN (Fmake_byte_code, MANY);
1973EXFUN (Fmake_bool_vector, 2);
1974EXFUN (Fmake_char_table, 2);
1975extern Lisp_Object make_sub_char_table P_ ((Lisp_Object));
7f73dc9d 1976extern Lisp_Object Qchar_table_extra_slots;
2f69f2ec 1977extern struct Lisp_Vector *allocate_vectorlike P_ ((EMACS_INT));
4d57802e 1978extern int gc_in_progress;
2f69f2ec
RS
1979#ifdef LISP_FLOAT_TYPE
1980extern Lisp_Object make_float P_ ((double));
1981#endif /* LISP_FLOAT_TYPE */
526a2be7
AS
1982extern void display_malloc_warning P_ ((void));
1983extern int inhibit_garbage_collection P_ ((void));
1984extern void free_marker P_ ((Lisp_Object));
1985extern void free_cons P_ ((struct Lisp_Cons *));
46abf440
AS
1986extern void init_alloc_once P_ ((void));
1987extern void init_alloc P_ ((void));
1988extern void syms_of_alloc P_ ((void));
3cfe6dfd
JB
1989
1990/* Defined in print.c */
1991extern Lisp_Object Vprin1_to_string_buffer;
2f69f2ec
RS
1992EXFUN (Fprin1, 2);
1993EXFUN (Fprin1_to_string, 2);
1994EXFUN (Fprinc, 2);
1995EXFUN (Fterpri, 1);
1996EXFUN (Fprint, 2);
1997EXFUN (Ferror_message_string, 1);
3cfe6dfd 1998extern Lisp_Object Vstandard_output, Qstandard_output;
9453ea7b 1999extern Lisp_Object Qexternal_debugging_output;
2f69f2ec 2000extern void temp_output_buffer_setup P_ ((char *));
3cfe6dfd
JB
2001extern int print_level, print_escape_newlines;
2002extern Lisp_Object Qprint_escape_newlines;
526a2be7
AS
2003extern void write_string P_ ((char *, int));
2004extern void write_string_1 P_ ((char *, int, Lisp_Object));
2005extern void print_error_message P_ ((Lisp_Object, Lisp_Object));
2006extern Lisp_Object internal_with_output_to_temp_buffer
ec5d8db7 2007 P_ ((char *, Lisp_Object (*) (Lisp_Object), Lisp_Object));
526a2be7 2008extern void float_to_string P_ ((unsigned char *, double));
46abf440 2009extern void syms_of_print P_ ((void));
526a2be7
AS
2010
2011/* Defined in doprnt.c */
2012extern int doprnt P_ ((char *, int, char *, char *, int, char **));
2013extern int doprnt_lisp P_ ((char *, int, char *, char *, int, char **));
3cfe6dfd
JB
2014
2015/* Defined in lread.c */
2016extern Lisp_Object Qvariable_documentation, Qstandard_input;
393306dd 2017extern Lisp_Object Vobarray, initial_obarray, Vstandard_input;
2f69f2ec
RS
2018EXFUN (Fread, 1);
2019EXFUN (Fread_from_string, 3);
2020EXFUN (Fintern, 2);
2021EXFUN (Fintern_soft, 2);
5d8c7983 2022EXFUN (Fload, 5);
2f69f2ec 2023EXFUN (Fget_file_char, 0);
485bf581
RS
2024EXFUN (Fread_char, 2);
2025EXFUN (Fread_event, 2);
2026extern Lisp_Object read_filtered_event P_ ((int, int, int, int));
eb542c51 2027EXFUN (Feval_region, 4);
2f69f2ec
RS
2028extern Lisp_Object intern P_ ((char *));
2029extern Lisp_Object make_symbol P_ ((char *));
a1b5012f 2030extern Lisp_Object oblookup P_ ((Lisp_Object, char *, int, int));
c5e3de70
RS
2031#define LOADHIST_ATTACH(x) \
2032 if (initialized) Vcurrent_load_list = Fcons (x, Vcurrent_load_list)
2033extern Lisp_Object Vcurrent_load_list;
2034extern Lisp_Object Vload_history;
526a2be7
AS
2035extern int openp P_ ((Lisp_Object, Lisp_Object, char *, Lisp_Object *, int));
2036extern int isfloat_string P_ ((char *));
2037extern void map_obarray P_ ((Lisp_Object, void (*) (Lisp_Object, Lisp_Object),
2038 Lisp_Object));
2039extern void dir_warning P_ ((char *, Lisp_Object));
2040extern void close_load_descs P_ ((void));
46abf440
AS
2041extern void init_obarray P_ ((void));
2042extern void init_lread P_ ((void));
2043extern void syms_of_lread P_ ((void));
3cfe6dfd
JB
2044
2045/* Defined in eval.c */
2046extern Lisp_Object Qautoload, Qexit, Qinteractive, Qcommandp, Qdefun, Qmacro;
ad236261 2047extern Lisp_Object Vinhibit_quit, Qinhibit_quit, Vquit_flag;
3cfe6dfd
JB
2048extern Lisp_Object Vmocklisp_arguments, Qmocklisp, Qmocklisp_arguments;
2049extern Lisp_Object Vautoload_queue;
973e8873 2050extern Lisp_Object Vdebug_on_error;
f1b6e5fc
SM
2051/* To run a normal hook, use the appropriate function from the list below.
2052 The calling convention:
2053
846d69ac 2054 if (!NILP (Vrun_hooks))
f1b6e5fc
SM
2055 call1 (Vrun_hooks, Qmy_funny_hook);
2056
2057 should no longer be used. */
3cfe6dfd 2058extern Lisp_Object Vrun_hooks;
2f69f2ec
RS
2059EXFUN (Frun_hooks, MANY);
2060EXFUN (Frun_hook_with_args, MANY);
2061EXFUN (Frun_hook_with_args_until_success, MANY);
2062EXFUN (Frun_hook_with_args_until_failure, MANY);
526a2be7
AS
2063extern Lisp_Object run_hook_list_with_args P_ ((Lisp_Object, int, Lisp_Object *));
2064extern void run_hook_with_args_2 P_ ((Lisp_Object, Lisp_Object, Lisp_Object));
2f69f2ec
RS
2065EXFUN (Fand, UNEVALLED);
2066EXFUN (For, UNEVALLED);
2067EXFUN (Fif, UNEVALLED);
2068EXFUN (Fprogn, UNEVALLED);
2069EXFUN (Fprog1, UNEVALLED);
2070EXFUN (Fprog2, UNEVALLED);
2071EXFUN (Fsetq, UNEVALLED);
2072EXFUN (Fquote, UNEVALLED);
2073EXFUN (Fuser_variable_p, 1);
2074EXFUN (Finteractive_p, 0);
2075EXFUN (Fdefun, UNEVALLED);
2076EXFUN (Flet, UNEVALLED);
2077EXFUN (FletX, UNEVALLED);
2078EXFUN (Fwhile, UNEVALLED);
2079EXFUN (Fcatch, UNEVALLED);
2080EXFUN (Fthrow, 2);
2081EXFUN (Funwind_protect, UNEVALLED);
2082EXFUN (Fcondition_case, UNEVALLED);
2083EXFUN (Fsignal, 2);
2084EXFUN (Fautoload, 5);
2085EXFUN (Fcommandp, 1);
2086EXFUN (Feval, 1);
2087EXFUN (Fapply, MANY);
2088EXFUN (Ffuncall, MANY);
2089EXFUN (Fbacktrace, 0);
2090extern Lisp_Object apply1 P_ ((Lisp_Object, Lisp_Object));
2091extern Lisp_Object call0 P_ ((Lisp_Object));
2092extern Lisp_Object call1 P_ ((Lisp_Object, Lisp_Object));
2093extern Lisp_Object call2 P_ ((Lisp_Object, Lisp_Object, Lisp_Object));
2094extern Lisp_Object call3 P_ ((Lisp_Object, Lisp_Object, Lisp_Object, Lisp_Object));
2095extern Lisp_Object call4 P_ ((Lisp_Object, Lisp_Object, Lisp_Object, Lisp_Object, Lisp_Object));
2096extern Lisp_Object call5 P_ ((Lisp_Object, Lisp_Object, Lisp_Object, Lisp_Object, Lisp_Object, Lisp_Object));
2097extern Lisp_Object call6 P_ ((Lisp_Object, Lisp_Object, Lisp_Object, Lisp_Object, Lisp_Object, Lisp_Object, Lisp_Object));
2098EXFUN (Fdo_auto_save, 2);
2099extern Lisp_Object apply_lambda P_ ((Lisp_Object, Lisp_Object, int));
2100extern Lisp_Object internal_catch P_ ((Lisp_Object, Lisp_Object (*) (Lisp_Object), Lisp_Object));
2101extern Lisp_Object internal_condition_case P_ ((Lisp_Object (*) (void), Lisp_Object, Lisp_Object (*) (Lisp_Object)));
2102extern Lisp_Object internal_condition_case_1 P_ ((Lisp_Object (*) (Lisp_Object), Lisp_Object, Lisp_Object, Lisp_Object (*) (Lisp_Object)));
526a2be7
AS
2103extern void specbind P_ ((Lisp_Object, Lisp_Object));
2104extern void record_unwind_protect P_ ((Lisp_Object (*) (Lisp_Object), Lisp_Object));
2f69f2ec
RS
2105extern Lisp_Object unbind_to P_ ((int, Lisp_Object));
2106extern void error P_ ((/* char *, ... */));
526a2be7 2107extern void do_autoload P_ ((Lisp_Object, Lisp_Object));
2f69f2ec
RS
2108extern Lisp_Object un_autoload P_ ((Lisp_Object));
2109EXFUN (Ffetch_bytecode, 1);
46abf440
AS
2110extern void init_eval_once P_ ((void));
2111extern void init_eval P_ ((void));
2112extern void syms_of_eval P_ ((void));
3cfe6dfd
JB
2113
2114/* Defined in editfns.c */
2f69f2ec
RS
2115EXFUN (Fgoto_char, 1);
2116EXFUN (Fpoint_min_marker, 0);
2117EXFUN (Fpoint_max_marker, 0);
2118EXFUN (Fpoint_min, 0);
2119EXFUN (Fpoint_max, 0);
2120EXFUN (Fpoint, 0);
2121EXFUN (Fpoint_marker, 0);
2122EXFUN (Fmark_marker, 0);
2123EXFUN (Fline_beginning_position, 1);
2124EXFUN (Fline_end_position, 1);
2125EXFUN (Ffollowing_char, 0);
2126EXFUN (Fprevious_char, 0);
2127EXFUN (Fchar_after, 1);
2128EXFUN (Finsert, MANY);
2129EXFUN (Finsert_and_inherit, MANY);
2130EXFUN (Finsert_before_markers, MANY);
2131EXFUN (Finsert_buffer_substring, 3);
2132EXFUN (Finsert_char, 3);
526a2be7 2133extern void insert1 P_ ((Lisp_Object));
2f69f2ec
RS
2134EXFUN (Feolp, 0);
2135EXFUN (Feobp, 0);
2136EXFUN (Fbolp, 0);
2137EXFUN (Fbobp, 0);
2138EXFUN (Fformat, MANY);
5010d3b8 2139EXFUN (Fmessage, MANY);
2f69f2ec
RS
2140extern Lisp_Object format1 P_ ((/* char *, ... */));
2141extern Lisp_Object make_buffer_string P_ ((int, int, int));
2142EXFUN (Fbuffer_substring, 2);
2143EXFUN (Fbuffer_string, 0);
2144extern Lisp_Object save_excursion_save P_ ((void));
2145extern Lisp_Object save_restriction_save P_ ((void));
2146extern Lisp_Object save_excursion_restore P_ ((Lisp_Object));
2147extern Lisp_Object save_restriction_restore P_ ((Lisp_Object));
2148EXFUN (Fchar_to_string, 1);
2149EXFUN (Fdelete_region, 2);
2150EXFUN (Fnarrow_to_region, 2);
2151EXFUN (Fwiden, 0);
2152EXFUN (Fuser_login_name, 1);
2153EXFUN (Fsystem_name, 0);
526a2be7 2154extern int clip_to_bounds P_ ((int, int, int));
b745ec7d
KH
2155extern Lisp_Object make_buffer_string P_ ((int, int, int));
2156extern Lisp_Object make_buffer_string_both P_ ((int, int, int, int, int));
46abf440
AS
2157extern void init_editfns P_ ((void));
2158extern void syms_of_editfns P_ ((void));
3cfe6dfd
JB
2159
2160/* defined in buffer.c */
526a2be7 2161extern void nsberror P_ ((Lisp_Object));
2f69f2ec
RS
2162EXFUN (Foverlay_start, 1);
2163EXFUN (Foverlay_end, 1);
2164extern void adjust_overlays_for_insert P_ ((int, int));
2165extern void adjust_overlays_for_delete P_ ((int, int));
2166extern void fix_overlays_in_range P_ ((int, int));
526a2be7
AS
2167extern void report_overlay_modification P_ ((Lisp_Object, Lisp_Object, int,
2168 Lisp_Object, Lisp_Object, Lisp_Object));
2f69f2ec 2169extern int overlay_touches_p P_ ((int));
628300ba 2170extern Lisp_Object Vbuffer_alist, Vinhibit_read_only;
2f69f2ec
RS
2171EXFUN (Fget_buffer, 1);
2172EXFUN (Fget_buffer_create, 1);
2173EXFUN (Fset_buffer, 1);
4a2f9c6a 2174EXFUN (set_buffer_if_live, 1);
2f69f2ec
RS
2175EXFUN (Fbarf_if_buffer_read_only, 0);
2176EXFUN (Fcurrent_buffer, 0);
2177EXFUN (Fswitch_to_buffer, 2);
2178EXFUN (Fpop_to_buffer, 3);
dbe7f1ef 2179EXFUN (Fother_buffer, 3);
2f69f2ec
RS
2180EXFUN (Foverlay_get, 2);
2181EXFUN (Fbuffer_modified_p, 1);
2182EXFUN (Fset_buffer_modified_p, 1);
2183EXFUN (Fkill_buffer, 1);
2184EXFUN (Fkill_all_local_variables, 0);
2185EXFUN (Fbuffer_disable_undo, 1);
2186EXFUN (Fbuffer_enable_undo, 1);
2187EXFUN (Ferase_buffer, 0);
20280af7 2188extern Lisp_Object Qoverlayp;
2f69f2ec 2189extern Lisp_Object get_truename_buffer P_ ((Lisp_Object));
3cfe6dfd 2190extern struct buffer *all_buffers;
2f69f2ec 2191EXFUN (Fprevious_overlay_change, 1);
46abf440
AS
2192extern void init_buffer_once P_ ((void));
2193extern void init_buffer P_ ((void));
2194extern void syms_of_buffer P_ ((void));
2195extern void keys_of_buffer P_ ((void));
3cfe6dfd
JB
2196
2197/* defined in marker.c */
2198
2f69f2ec
RS
2199EXFUN (Fmarker_position, 1);
2200EXFUN (Fmarker_buffer, 1);
2201EXFUN (Fcopy_marker, 2);
2202EXFUN (Fset_marker, 3);
526a2be7 2203extern int marker_position P_ ((Lisp_Object));
ec5d8db7
AS
2204extern int marker_byte_position P_ ((Lisp_Object));
2205extern void clear_charpos_cache P_ ((struct buffer *));
2206extern int charpos_to_bytepos P_ ((int));
2207extern int buf_charpos_to_bytepos P_ ((struct buffer *, int));
2208extern int buf_bytepos_to_charpos P_ ((struct buffer *, int));
526a2be7
AS
2209extern void unchain_marker P_ ((Lisp_Object));
2210extern Lisp_Object set_marker_restricted P_ ((Lisp_Object, Lisp_Object, Lisp_Object));
4ed24bf3
RS
2211extern Lisp_Object set_marker_both P_ ((Lisp_Object, Lisp_Object, int, int));
2212extern Lisp_Object set_marker_restricted_both P_ ((Lisp_Object, Lisp_Object,
2213 int, int));
46abf440 2214extern void syms_of_marker P_ ((void));
3cfe6dfd
JB
2215
2216/* Defined in fileio.c */
2217
2218extern Lisp_Object Qfile_error;
2f69f2ec
RS
2219EXFUN (Ffind_file_name_handler, 2);
2220EXFUN (Ffile_name_as_directory, 1);
2221EXFUN (Fexpand_file_name, 2);
2222EXFUN (Ffile_name_nondirectory, 1);
2223EXFUN (Fsubstitute_in_file_name, 1);
2224EXFUN (Ffile_symlink_p, 1);
2225EXFUN (Fverify_visited_file_modtime, 1);
2226EXFUN (Ffile_exists_p, 1);
2227EXFUN (Ffile_name_absolute_p, 1);
2228EXFUN (Fdirectory_file_name, 1);
2229EXFUN (Ffile_name_directory, 1);
2230extern Lisp_Object expand_and_dir_to_file P_ ((Lisp_Object, Lisp_Object));
2231EXFUN (Ffile_accessible_directory_p, 1);
2232EXFUN (Funhandled_file_name_directory, 1);
2233EXFUN (Ffile_directory_p, 1);
b4e187e2 2234EXFUN (Fwrite_region, 7);
2f69f2ec
RS
2235EXFUN (Ffile_readable_p, 1);
2236EXFUN (Ffile_executable_p, 1);
2237EXFUN (Fread_file_name, 5);
526a2be7
AS
2238extern void report_file_error P_ ((char *, Lisp_Object));
2239extern int internal_delete_file P_ ((Lisp_Object));
46abf440 2240extern void syms_of_fileio P_ ((void));
3cfe6dfd
JB
2241
2242/* Defined in abbrev.c */
2243
2244extern Lisp_Object Vfundamental_mode_abbrev_table;
46abf440 2245extern void syms_of_abbrev P_ ((void));
3cfe6dfd
JB
2246
2247/* defined in search.c */
2f69f2ec
RS
2248EXFUN (Fstring_match, 3);
2249extern void restore_match_data P_ ((void));
2250EXFUN (Fmatch_data, 2);
f405b38d 2251EXFUN (Fset_match_data, 1);
2f69f2ec
RS
2252EXFUN (Fmatch_beginning, 1);
2253EXFUN (Fmatch_end, 1);
526a2be7
AS
2254extern int fast_string_match P_ ((Lisp_Object, Lisp_Object));
2255extern int fast_c_string_match_ignore_case P_ ((Lisp_Object, char *));
2256extern int scan_buffer P_ ((int, int, int, int, int *, int));
4ed24bf3 2257extern int scan_newline P_ ((int, int, int, int, int, int));
526a2be7
AS
2258extern int find_next_newline P_ ((int, int));
2259extern int find_next_newline_no_quit P_ ((int, int));
2260extern int find_before_next_newline P_ ((int, int, int));
46abf440 2261extern void syms_of_search P_ ((void));
3cfe6dfd
JB
2262
2263/* defined in minibuf.c */
2264
2265extern Lisp_Object last_minibuf_string;
526a2be7 2266extern void choose_minibuf_frame P_ ((void));
ec5d8db7 2267extern int scmp P_ ((unsigned char *, unsigned char *, int));
5593f7e3
KH
2268EXFUN (Fcompleting_read, 8);
2269EXFUN (Fread_from_minibuffer, 7);
2f69f2ec
RS
2270EXFUN (Fread_variable, 2);
2271EXFUN (Fread_buffer, 3);
2272EXFUN (Fread_minibuffer, 2);
2273EXFUN (Feval_minibuffer, 2);
5593f7e3
KH
2274EXFUN (Fread_string, 5);
2275EXFUN (Fread_no_blanks_input, 3);
2f69f2ec 2276extern Lisp_Object get_minibuffer P_ ((int));
526a2be7 2277extern void temp_echo_area_glyphs P_ ((char *));
46abf440
AS
2278extern void init_minibuf_once P_ ((void));
2279extern void syms_of_minibuf P_ ((void));
2280extern void keys_of_minibuf P_ ((void));
3cfe6dfd
JB
2281
2282/* Defined in callint.c */
2283
de7885bb 2284extern Lisp_Object Qminus, Qplus, Vcurrent_prefix_arg;
3cfe6dfd 2285extern Lisp_Object Vcommand_history;
7fd61057 2286extern Lisp_Object Qcall_interactively, Qmouse_leave_buffer_hook;
2f69f2ec
RS
2287EXFUN (Fcall_interactively, 3);
2288EXFUN (Fprefix_numeric_value, 1);
46abf440 2289extern void syms_of_callint P_ ((void));
3cfe6dfd
JB
2290
2291/* defined in casefiddle.c */
2292
2f69f2ec
RS
2293EXFUN (Fdowncase, 1);
2294EXFUN (Fupcase, 1);
2295EXFUN (Fcapitalize, 1);
2296EXFUN (Fupcase_region, 2);
2297EXFUN (Fupcase_initials, 1);
2298EXFUN (Fupcase_initials_region, 2);
46abf440
AS
2299extern void syms_of_casefiddle P_ ((void));
2300extern void keys_of_casefiddle P_ ((void));
3cfe6dfd 2301
1747fb16
RS
2302/* defined in casetab.c */
2303
2f69f2ec
RS
2304EXFUN (Fset_case_table, 1);
2305EXFUN (Fset_standard_case_table, 1);
46abf440
AS
2306extern void init_casetab_once P_ ((void));
2307extern void syms_of_casetab P_ ((void));
1747fb16 2308
3cfe6dfd
JB
2309/* defined in keyboard.c */
2310
2311extern Lisp_Object Qdisabled;
4b657f72 2312extern Lisp_Object Vtty_erase_char, Vhelp_form, Vtop_level;
2f69f2ec
RS
2313EXFUN (Fdiscard_input, 0);
2314EXFUN (Frecursive_edit, 0);
2315EXFUN (Fcommand_execute, 4);
2316EXFUN (Finput_pending_p, 0);
2317extern Lisp_Object menu_bar_items P_ ((Lisp_Object));
5010d3b8 2318extern Lisp_Object toolbar_items P_ ((Lisp_Object, int *));
f498e3b2 2319extern Lisp_Object Qvertical_scroll_bar;
084cd810 2320extern void discard_mouse_events ();
2f69f2ec 2321EXFUN (Fevent_convert_list, 1);
e271fdb3 2322EXFUN (Fread_key_sequence, 5);
526a2be7
AS
2323EXFUN (Fset_input_mode, 4);
2324extern int detect_input_pending P_ ((void));
2325extern int detect_input_pending_run_timers P_ ((int));
2326extern void safe_run_hooks P_ ((Lisp_Object));
2327extern void cmd_error_internal P_ ((Lisp_Object, char *));
2328extern Lisp_Object command_loop_1 P_ ((void));
2329extern Lisp_Object recursive_edit_1 P_ ((void));
2330extern void record_auto_save P_ ((void));
46abf440
AS
2331extern void init_keyboard P_ ((void));
2332extern void syms_of_keyboard P_ ((void));
2333extern void keys_of_keyboard P_ ((void));
3cfe6dfd
JB
2334
2335/* defined in keymap.c */
2336
c451d7b1 2337extern Lisp_Object Qkeymap, Qmenu_bar;
3cfe6dfd 2338extern Lisp_Object current_global_map;
526a2be7
AS
2339EXFUN (Fmake_sparse_keymap, 1);
2340EXFUN (Fcopy_keymap, 1);
2f69f2ec 2341EXFUN (Fdefine_key, 3);
526a2be7 2342EXFUN (Flookup_key, 3);
2f69f2ec
RS
2343EXFUN (Fkey_binding, 2);
2344EXFUN (Fkey_description, 1);
2345EXFUN (Fsingle_key_description, 1);
2346EXFUN (Fwhere_is_internal, 4);
2347extern Lisp_Object access_keymap P_ ((Lisp_Object, Lisp_Object, int, int));
2348extern Lisp_Object store_in_keymap P_ ((Lisp_Object, Lisp_Object, Lisp_Object));
2349extern Lisp_Object get_keyelt P_ ((Lisp_Object, int));
2350extern Lisp_Object get_keymap P_ ((Lisp_Object));
2351extern Lisp_Object get_keymap_1 P_ ((Lisp_Object, int, int));
526a2be7
AS
2352extern void describe_vector P_ ((Lisp_Object, Lisp_Object,
2353 void (*) (Lisp_Object), int,
2354 Lisp_Object, Lisp_Object, int *, int));
2355extern void describe_map_tree P_ ((Lisp_Object, int, Lisp_Object, Lisp_Object,
2356 char *, int, int, int));
2357extern int current_minor_maps P_ ((Lisp_Object **, Lisp_Object **));
2358extern void initial_define_key P_ ((Lisp_Object, int, char *));
2359extern void initial_define_lispy_key P_ ((Lisp_Object, char *, char *));
2360extern void fix_submap_inheritance P_ ((Lisp_Object, Lisp_Object, Lisp_Object));
46abf440
AS
2361extern void syms_of_keymap P_ ((void));
2362extern void keys_of_keymap P_ ((void));
3cfe6dfd
JB
2363
2364/* defined in indent.c */
2f69f2ec
RS
2365EXFUN (Fvertical_motion, 2);
2366EXFUN (Findent_to, 2);
2367EXFUN (Fcurrent_column, 0);
2368EXFUN (Fmove_to_column, 2);
526a2be7
AS
2369extern int current_column P_ ((void));
2370extern void invalidate_current_column P_ ((void));
4ed24bf3 2371extern int indented_beyond_p P_ ((int, int, int));
46abf440 2372extern void syms_of_indent P_ ((void));
3cfe6dfd
JB
2373
2374/* defined in window.c */
afd0d237 2375extern Lisp_Object Qwindowp, Qwindow_live_p;
5010d3b8 2376EXFUN (Fwindow_end, 2);
2f69f2ec 2377EXFUN (Fselected_window, 0);
526a2be7
AS
2378EXFUN (Fnext_window, 3);
2379EXFUN (Fdelete_window, 1);
2380EXFUN (Fselect_window, 1);
2381EXFUN (Fset_window_buffer, 2);
2f69f2ec
RS
2382EXFUN (Fget_buffer_window, 2);
2383EXFUN (Fsave_window_excursion, UNEVALLED);
526a2be7 2384EXFUN (Fsplit_window, 3);
2f69f2ec
RS
2385EXFUN (Fset_window_configuration, 1);
2386EXFUN (Fcurrent_window_configuration, 1);
b4e187e2 2387extern int compare_window_configurations P_ ((Lisp_Object, Lisp_Object, int));
2f69f2ec
RS
2388EXFUN (Fcoordinates_in_window_p, 2);
2389EXFUN (Fwindow_at, 3);
2390EXFUN (Fpos_visible_in_window_p, 2);
526a2be7
AS
2391extern int window_internal_height P_ ((struct window *));
2392extern int window_internal_width P_ ((struct window *));
2f69f2ec
RS
2393EXFUN (Frecenter, 1);
2394EXFUN (Fscroll_other_window, 1);
2395EXFUN (Fset_window_start, 3);
2396extern void temp_output_buffer_show P_ ((Lisp_Object));
526a2be7 2397extern void replace_buffer_in_all_windows P_ ((Lisp_Object));
46abf440
AS
2398extern void init_window_once P_ ((void));
2399extern void syms_of_window P_ ((void));
2400extern void keys_of_window P_ ((void));
3cfe6dfd 2401
ff11dfa1 2402/* defined in frame.c */
362fb47a 2403extern Lisp_Object Qvisible;
526a2be7 2404extern void store_frame_param P_ ((struct frame *, Lisp_Object, Lisp_Object));
2f69f2ec
RS
2405extern void store_in_alist P_ ((Lisp_Object *, Lisp_Object, Lisp_Object));
2406extern Lisp_Object do_switch_frame P_ ((Lisp_Object, Lisp_Object, int));
526a2be7 2407extern Lisp_Object get_frame_param P_ ((struct frame *, Lisp_Object));
dbe7f1ef 2408extern Lisp_Object frame_buffer_predicate P_ ((Lisp_Object));
2f69f2ec
RS
2409EXFUN (Fframep, 1);
2410EXFUN (Fselect_frame, 2);
2411EXFUN (Fselected_frame, 0);
2412EXFUN (Fwindow_frame, 1);
2413EXFUN (Fframe_root_window, 1);
2414EXFUN (Fframe_first_window, 1);
2415EXFUN (Fframe_selected_window, 1);
2416EXFUN (Fframe_list, 0);
2417EXFUN (Fnext_frame, 2);
2418EXFUN (Fdelete_frame, 2);
2419EXFUN (Fset_mouse_position, 3);
2420EXFUN (Fmake_frame_visible, 1);
2421EXFUN (Fmake_frame_invisible, 2);
2422EXFUN (Ficonify_frame, 1);
2423EXFUN (Fframe_visible_p, 1);
2424EXFUN (Fvisible_frame_list, 0);
2425EXFUN (Fframe_parameters, 1);
2426EXFUN (Fmodify_frame_parameters, 2);
2427EXFUN (Fset_frame_height, 3);
2428EXFUN (Fset_frame_width, 3);
2429EXFUN (Fset_frame_size, 3);
2430EXFUN (Fset_frame_position, 3);
2431EXFUN (Fraise_frame, 1);
2432EXFUN (Fredirect_frame_focus, 2);
526a2be7 2433EXFUN (Fset_frame_selected_window, 2);
dbe7f1ef 2434extern Lisp_Object frame_buffer_list P_ ((Lisp_Object));
526a2be7 2435extern void frames_discard_buffer P_ ((Lisp_Object));
dbe7f1ef 2436extern void set_frame_buffer_list P_ ((Lisp_Object, Lisp_Object));
526a2be7 2437extern void frames_bury_buffer P_ ((Lisp_Object));
46abf440
AS
2438extern void syms_of_frame P_ ((void));
2439extern void keys_of_frame P_ ((void));
3cfe6dfd
JB
2440
2441/* defined in emacs.c */
2f69f2ec 2442extern Lisp_Object decode_env_path P_ ((char *, char *));
3530d534 2443extern Lisp_Object Vinvocation_name, Vinvocation_directory;
e6faba7f 2444extern Lisp_Object Vinstallation_directory;
2f69f2ec
RS
2445EXFUN (Fkill_emacs, 1);
2446void shut_down_emacs P_ ((int, int, Lisp_Object));
3cfe6dfd
JB
2447/* Nonzero means don't do interactive redisplay and don't change tty modes */
2448extern int noninteractive;
2449/* Nonzero means don't do use window-system-specific display code */
2450extern int inhibit_window_system;
99a3d506 2451/* Nonzero means that a filter or a sentinel is running. */
7074fde6 2452extern int running_asynch_code;
3cfe6dfd
JB
2453
2454/* defined in process.c */
2f69f2ec
RS
2455EXFUN (Fget_process, 1);
2456EXFUN (Fget_buffer_process, 1);
2457EXFUN (Fprocessp, 1);
2458EXFUN (Fprocess_status, 1);
2459EXFUN (Fkill_process, 2);
2460EXFUN (Fprocess_send_eof, 1);
2461EXFUN (Fwaiting_for_user_input_p, 0);
6efad63b 2462extern Lisp_Object Qprocessp;
526a2be7
AS
2463extern void kill_buffer_processes P_ ((Lisp_Object));
2464extern int wait_reading_process_input P_ ((int, int, Lisp_Object, int));
2465extern void deactivate_process P_ ((Lisp_Object));
2466extern void add_keyboard_wait_descriptor P_ ((int));
2467extern void delete_keyboard_wait_descriptor P_ ((int));
2468extern void close_process_descs P_ ((void));
2469extern void status_notify P_ ((void));
2470extern int read_process_output P_ ((Lisp_Object, int));
46abf440
AS
2471extern void init_process P_ ((void));
2472extern void syms_of_process P_ ((void));
3cfe6dfd
JB
2473
2474/* defined in callproc.c */
9453ea7b 2475extern Lisp_Object Vexec_path, Vexec_directory, Vdata_directory;
c65be0e1 2476extern Lisp_Object Vdoc_directory;
526a2be7 2477extern int child_setup P_ ((int, int, int, char **, int, Lisp_Object));
46abf440
AS
2478extern void init_callproc_1 P_ ((void));
2479extern void init_callproc P_ ((void));
2480extern void set_process_environment P_ ((void));
2481extern void syms_of_callproc P_ ((void));
3cfe6dfd 2482
3cfe6dfd
JB
2483/* defined in doc.c */
2484extern Lisp_Object Vdoc_file_name;
2f69f2ec
RS
2485EXFUN (Fsubstitute_command_keys, 1);
2486EXFUN (Fdocumentation, 2);
2487EXFUN (Fdocumentation_property, 3);
2488extern Lisp_Object read_doc_string P_ ((Lisp_Object));
3dd00fc3 2489extern Lisp_Object get_doc_string P_ ((Lisp_Object, int, int));
46abf440 2490extern void syms_of_doc P_ ((void));
3cfe6dfd
JB
2491
2492/* defined in bytecode.c */
2493extern Lisp_Object Qbytecode;
2f69f2ec 2494EXFUN (Fbyte_code, 3);
46abf440 2495extern void syms_of_bytecode P_ ((void));
3cfe6dfd
JB
2496
2497/* defined in macros.c */
2498extern Lisp_Object Qexecute_kbd_macro;
2f69f2ec 2499EXFUN (Fexecute_kbd_macro, 2);
46abf440
AS
2500extern void init_macros P_ ((void));
2501extern void syms_of_macros P_ ((void));
2502extern void keys_of_macros P_ ((void));
3cfe6dfd 2503
d20c2151 2504/* defined in undo.c */
a387611b 2505extern Lisp_Object Qinhibit_read_only;
2f69f2ec
RS
2506EXFUN (Fundo_boundary, 0);
2507extern Lisp_Object truncate_undo_list P_ ((Lisp_Object, int, int));
526a2be7
AS
2508extern void record_marker_adjustment P_ ((Lisp_Object, int));
2509extern void record_insert P_ ((int, int));
443de1d7 2510extern void record_delete P_ ((int, Lisp_Object));
526a2be7
AS
2511extern void record_first_change P_ ((void));
2512extern void record_change P_ ((int, int));
2513extern void record_property_change P_ ((int, int, Lisp_Object, Lisp_Object,
2514 Lisp_Object));
46abf440 2515extern void syms_of_undo P_ ((void));
d20c2151 2516
8537f1cb 2517/* defined in textprop.c */
c2d8811c 2518extern Lisp_Object Qmodification_hooks;
23bc39b5 2519extern Lisp_Object Qrear_nonsticky, Qfont;
c2d8811c 2520extern Lisp_Object Qinsert_in_front_hooks, Qinsert_behind_hooks;
2f69f2ec
RS
2521EXFUN (Fnext_property_change, 3);
2522EXFUN (Fnext_single_property_change, 4);
2523EXFUN (Fprevious_single_property_change, 4);
2524EXFUN (Fget_text_property, 3);
2525EXFUN (Fput_text_property, 5);
2526EXFUN (Fset_text_properties, 4);
2527EXFUN (Ftext_property_not_all, 5);
2528EXFUN (Fprevious_char_property_change, 2);
2529EXFUN (Fnext_char_property_change, 2);
526a2be7 2530extern void report_interval_modification P_ ((Lisp_Object, Lisp_Object));
46abf440 2531extern void syms_of_textprop P_ ((void));
8537f1cb 2532
40131ef5 2533/* defined in intervals.c */
2f69f2ec 2534extern Lisp_Object get_local_map P_ ((int, struct buffer *));
40131ef5
KH
2535
2536/* defined in xmenu.c */
2f69f2ec
RS
2537EXFUN (Fx_popup_menu, 2);
2538EXFUN (Fx_popup_dialog, 2);
46abf440 2539extern void syms_of_xmenu P_ ((void));
526a2be7
AS
2540
2541/* defined in sysdep.c */
2542extern void init_sigio P_ ((int));
2543extern void request_sigio P_ ((void));
2544extern void unrequest_sigio P_ ((void));
2545extern void reset_sys_modes P_ ((void));
2546extern void sys_subshell P_ ((void));
2547extern void sys_suspend P_ ((void));
2548extern void discard_tty_input P_ ((void));
2549extern void init_sys_modes P_ ((void));
2550extern void reset_sys_modes P_ ((void));
2551extern void get_frame_size P_ ((int *, int *));
2552extern void wait_for_termination P_ ((int));
2553extern void flush_pending_output P_ ((int));
2554extern void child_setup_tty P_ ((int));
2555extern void setup_pty P_ ((int));
2556extern int set_window_size P_ ((int, int, int));
2557extern void create_process P_ ((Lisp_Object, char **, Lisp_Object));
2558extern int tabs_safe_p P_ ((void));
2559extern void init_baud_rate P_ ((void));
2560
2561/* defined in filelock.c */
2562EXFUN (Funlock_buffer, 0);
9ae8d912 2563EXFUN (Ffile_locked_p, 1);
526a2be7
AS
2564extern void unlock_all_files P_ ((void));
2565extern void lock_file P_ ((Lisp_Object));
2566extern void unlock_file P_ ((Lisp_Object));
2567extern void unlock_buffer P_ ((struct buffer *));
46abf440
AS
2568extern void syms_of_filelock P_ ((void));
2569
2570/* Defined in category.c */
2571extern void init_category_once P_ ((void));
2572extern void syms_of_category P_ ((void));
2573
2574/* Defined in ccl.c */
2575extern void syms_of_ccl P_ ((void));
2576
2577/* Defined in dired.c */
2578extern void syms_of_dired P_ ((void));
2579
2580/* Defined in mocklisp.c */
2581extern void syms_of_mocklisp P_ ((void));
2582
2583/* Defined in term.c */
2584extern void syms_of_term P_ ((void));
2585
2586#ifdef HAVE_X_WINDOWS
2587/* Defined in fontset.c */
2588extern void syms_of_fontset P_ ((void));
5010d3b8 2589EXFUN (Fset_fontset_font, 4);
46abf440
AS
2590#endif
2591
2592/* Defined in xfaces.c */
2593extern void syms_of_xfaces P_ ((void));
2594
2595#ifdef HAVE_X_WINDOWS
2596/* Defined in xfns.c */
2597extern void syms_of_xfns P_ ((void));
2598#endif
2599
2600/* Defined in xselect.c */
2601extern void syms_of_xselect P_ ((void));
2602
2603/* Defined in xterm.c */
2604extern void syms_of_xterm P_ ((void));
40131ef5 2605\f
3cfe6dfd
JB
2606/* Nonzero means Emacs has already been initialized.
2607 Used during startup to detect startup of dumped Emacs. */
2608extern int initialized;
2609
2610extern int immediate_quit; /* Nonzero means ^G can quit instantly */
2611
339747e4 2612extern char *getenv (), *ctime (), *getwd ();
3cfe6dfd 2613extern long *xmalloc (), *xrealloc ();
9ac0d9e0 2614extern void xfree ();
3cfe6dfd 2615
526a2be7 2616extern char *egetenv P_ ((char *));
e98227af 2617
5d6be39f 2618/* Set up the name of the machine we're running on. */
526a2be7 2619extern void init_system_name P_ ((void));
881a5a80
RS
2620
2621/* Some systems (e.g., NT) use a different path separator than Unix,
2622 in addition to a device separator. Default the path separator
2623 to '/', and don't test for a device separator in IS_ANY_SEP. */
2624
e0c07012
RS
2625#ifdef WINDOWSNT
2626extern Lisp_Object Vdirectory_sep_char;
2627#endif
2628
881a5a80
RS
2629#ifndef DIRECTORY_SEP
2630#define DIRECTORY_SEP '/'
2631#endif
881a5a80
RS
2632#ifndef IS_DIRECTORY_SEP
2633#define IS_DIRECTORY_SEP(_c_) ((_c_) == DIRECTORY_SEP)
2634#endif
2635#ifndef IS_DEVICE_SEP
2636#ifndef DEVICE_SEP
2637#define IS_DEVICE_SEP(_c_) 0
2638#else
2639#define IS_DEVICE_SEP(_c_) ((_c_) == DEVICE_SEP)
2640#endif
2641#endif
2642#ifndef IS_ANY_SEP
2643#define IS_ANY_SEP(_c_) (IS_DIRECTORY_SEP (_c_))
2644#endif
51bd4610
KH
2645
2646#ifdef SWITCH_ENUM_BUG
2647#define SWITCH_ENUM_CAST(x) ((int)(x))
2648#else
2649#define SWITCH_ENUM_CAST(x) (x)
2650#endif