Add prototype for copy_hash_table and Fcopy_hash_table.
[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
048151c1
KH
1046#define CHAR_MODIFIER_MASK \
1047 (CHAR_ALT | CHAR_SUPER | CHAR_HYPER | CHAR_SHIFT | CHAR_CTL | CHAR_META)
1048
1049
6b768554
KH
1050/* Actually, the current Emacs uses 19 bits for the character value
1051 itself. */
1052#define CHARACTERBITS 19
1053
e6faba7f
RS
1054#ifdef USE_X_TOOLKIT
1055#ifdef NO_UNION_TYPE
1056/* Use this for turning a (void *) into a Lisp_Object, as when the
1057 Lisp_Object is passed into a toolkit callback function. */
1058#define VOID_TO_LISP(larg,varg) \
1059 do { ((larg) = ((Lisp_Object) (varg))); } while (0)
1060#define CVOID_TO_LISP VOID_TO_LISP
1061
1062/* Use this for turning a Lisp_Object into a (void *), as when the
1063 Lisp_Object is passed into a toolkit callback function. */
1064#define LISP_TO_VOID(larg) ((void *) (larg))
1065#define LISP_TO_CVOID(varg) ((const void *) (larg))
1066
1067#else /* not NO_UNION_TYPE */
1068/* Use this for turning a (void *) into a Lisp_Object, as when the
1069 Lisp_Object is passed into a toolkit callback function. */
1070#define VOID_TO_LISP(larg,varg) \
1071 do { ((larg).v = (void *) (varg)); } while (0)
1072#define CVOID_TO_LISP(larg,varg) \
1073 do { ((larg).cv = (const void *) (varg)); } while (0)
1074
1075/* Use this for turning a Lisp_Object into a (void *), as when the
1076 Lisp_Object is passed into a toolkit callback function. */
1077#define LISP_TO_VOID(larg) ((larg).v)
1078#define LISP_TO_CVOID(larg) ((larg).cv)
1079#endif /* not NO_UNION_TYPE */
1080#endif /* USE_X_TOOLKIT */
1081
703f2808
JB
1082\f
1083/* The glyph datatype, used to represent characters on the display. */
1084
6b768554
KH
1085/* The low 19 bits (CHARACTERBITS) are the character code, and the
1086 bits above them except for the topmost two bits are the numeric
1087 face ID. If FID is the face ID of a glyph on a frame F, then
1088 F->display.x->faces[FID] contains the description of that face.
1089 This is an int instead of a short, so we can support a good bunch
1090 of face ID's (i.e. 2^(32 - 19 - 2) = 2048 ID's) ; given that we
1091 have no mechanism for tossing unused frame face ID's yet, we'll
1092 probably run out of 255 pretty quickly. */
703f2808
JB
1093#define GLYPH unsigned int
1094
6b768554
KH
1095/* Mask bit for a glyph of a character which should be written from
1096 right to left. */
1097#define GLYPH_MASK_REV_DIR 0x80000000
1098/* Mask bit for a padding glyph of a multi-column character. */
1099#define GLYPH_MASK_PADDING 0x40000000
1100/* Mask bits for face. */
1101#define GLYPH_MASK_FACE 0x3FF80000
1102/* Mask bits for character code. */
1103#define GLYPH_MASK_CHAR 0x0007FFFF /* The lowest 19 bits */
1104
49b0dd75
KH
1105/* The FAST macros assume that we already know we're in an X window. */
1106
703f2808 1107/* Given a character code and a face ID, return the appropriate glyph. */
000f4621 1108#define FAST_MAKE_GLYPH(char, face) ((char) | ((face) << CHARACTERBITS))
703f2808
JB
1109
1110/* Return a glyph's character code. */
6b768554 1111#define FAST_GLYPH_CHAR(glyph) ((glyph) & GLYPH_MASK_CHAR)
703f2808
JB
1112
1113/* Return a glyph's face ID. */
6b768554 1114#define FAST_GLYPH_FACE(glyph) (((glyph) & GLYPH_MASK_FACE) >> CHARACTERBITS)
49b0dd75
KH
1115
1116/* Slower versions that test the frame type first. */
5010d3b8
GM
1117#define MAKE_GLYPH(f, char, face) (FAST_MAKE_GLYPH (char, face))
1118#define GLYPH_CHAR(f, g) (FAST_GLYPH_CHAR (g))
1119#define GLYPH_FACE(f, g) (FAST_GLYPH_FACE (g))
703f2808 1120
b96656ce
KH
1121/* Return 1 iff GLYPH contains valid character code. */
1122#define GLYPH_CHAR_VALID_P(glyph) \
1123 ((GLYPH) (FAST_GLYPH_CHAR (glyph)) <= MAX_CHAR)
1124
4606cc9d
RS
1125/* The ID of the mode line highlighting face. */
1126#define GLYPH_MODE_LINE_FACE 1
3cfe6dfd
JB
1127\f
1128/* Data type checking */
1129
efb859b4 1130#define NILP(x) (XFASTINT (x) == XFASTINT (Qnil))
f498e3b2 1131#define GC_NILP(x) GC_EQ (x, Qnil)
3cfe6dfd 1132
4746118a 1133#ifdef LISP_FLOAT_TYPE
c5af3bb9 1134#define NUMBERP(x) (INTEGERP (x) || FLOATP (x))
c1a2bfad 1135#define GC_NUMBERP(x) (GC_INTEGERP (x) || GC_FLOATP (x))
4746118a 1136#else
c5af3bb9 1137#define NUMBERP(x) (INTEGERP (x))
c1a2bfad 1138#define GC_NUMBERP(x) (GC_INTEGERP (x))
4746118a 1139#endif
a4a9f09f 1140#define NATNUMP(x) (INTEGERP (x) && XINT (x) >= 0)
c1a2bfad 1141#define GC_NATNUMP(x) (GC_INTEGERP (x) && XINT (x) >= 0)
4746118a 1142
edfa9106 1143#define INTEGERP(x) (XTYPE ((x)) == Lisp_Int)
c1a2bfad 1144#define GC_INTEGERP(x) (XGCTYPE ((x)) == Lisp_Int)
edfa9106 1145#define SYMBOLP(x) (XTYPE ((x)) == Lisp_Symbol)
c1a2bfad 1146#define GC_SYMBOLP(x) (XGCTYPE ((x)) == Lisp_Symbol)
84d1833e 1147#define MISCP(x) (XTYPE ((x)) == Lisp_Misc)
c1a2bfad 1148#define GC_MISCP(x) (XGCTYPE ((x)) == Lisp_Misc)
b5088f80
KH
1149#define VECTORLIKEP(x) (XTYPE ((x)) == Lisp_Vectorlike)
1150#define GC_VECTORLIKEP(x) (XGCTYPE ((x)) == Lisp_Vectorlike)
edfa9106 1151#define STRINGP(x) (XTYPE ((x)) == Lisp_String)
c1a2bfad 1152#define GC_STRINGP(x) (XGCTYPE ((x)) == Lisp_String)
3cfe6dfd 1153#define CONSP(x) (XTYPE ((x)) == Lisp_Cons)
c1a2bfad 1154#define GC_CONSP(x) (XGCTYPE ((x)) == Lisp_Cons)
7c06ac2b 1155
20280af7 1156#ifdef LISP_FLOAT_TYPE
edfa9106 1157#define FLOATP(x) (XTYPE ((x)) == Lisp_Float)
c1a2bfad 1158#define GC_FLOATP(x) (XGCTYPE ((x)) == Lisp_Float)
20280af7
JB
1159#else
1160#define FLOATP(x) (0)
c1a2bfad 1161#define GC_FLOATP(x) (0)
20280af7 1162#endif
b5088f80
KH
1163#define VECTORP(x) (VECTORLIKEP (x) && !(XVECTOR (x)->size & PSEUDOVECTOR_FLAG))
1164#define GC_VECTORP(x) (GC_VECTORLIKEP (x) && !(XVECTOR (x)->size & PSEUDOVECTOR_FLAG))
a7aa28f6
RS
1165#define OVERLAYP(x) (MISCP (x) && XMISCTYPE (x) == Lisp_Misc_Overlay)
1166#define GC_OVERLAYP(x) (GC_MISCP (x) && XMISCTYPE (x) == Lisp_Misc_Overlay)
1167#define MARKERP(x) (MISCP (x) && XMISCTYPE (x) == Lisp_Misc_Marker)
1168#define GC_MARKERP(x) (GC_MISCP (x) && XMISCTYPE (x) == Lisp_Misc_Marker)
1169#define INTFWDP(x) (MISCP (x) && XMISCTYPE (x) == Lisp_Misc_Intfwd)
1170#define GC_INTFWDP(x) (GC_MISCP (x) && XMISCTYPE (x) == Lisp_Misc_Intfwd)
1171#define BOOLFWDP(x) (MISCP (x) && XMISCTYPE (x) == Lisp_Misc_Boolfwd)
1172#define GC_BOOLFWDP(x) (GC_MISCP (x) && XMISCTYPE (x) == Lisp_Misc_Boolfwd)
1173#define OBJFWDP(x) (MISCP (x) && XMISCTYPE (x) == Lisp_Misc_Objfwd)
1174#define GC_OBJFWDP(x) (GC_MISCP (x) && XMISCTYPE (x) == Lisp_Misc_Objfwd)
1175#define BUFFER_OBJFWDP(x) (MISCP (x) && XMISCTYPE (x) == Lisp_Misc_Buffer_Objfwd)
1176#define GC_BUFFER_OBJFWDP(x) (GC_MISCP (x) && XMISCTYPE (x) == Lisp_Misc_Buffer_Objfwd)
1177#define BUFFER_LOCAL_VALUEP(x) (MISCP (x) && XMISCTYPE (x) == Lisp_Misc_Buffer_Local_Value)
1178#define GC_BUFFER_LOCAL_VALUEP(x) (GC_MISCP (x) && XMISCTYPE (x) == Lisp_Misc_Buffer_Local_Value)
1179#define SOME_BUFFER_LOCAL_VALUEP(x) (MISCP (x) && XMISCTYPE (x) == Lisp_Misc_Some_Buffer_Local_Value)
1180#define GC_SOME_BUFFER_LOCAL_VALUEP(x) (GC_MISCP (x) && XMISCTYPE (x) == Lisp_Misc_Some_Buffer_Local_Value)
1181#define KBOARD_OBJFWDP(x) (MISCP (x) && XMISCTYPE (x) == Lisp_Misc_Kboard_Objfwd)
1182#define GC_KBOARD_OBJFWDP(x) (GC_MISCP (x) && XMISCTYPE (x) == Lisp_Misc_Kboard_Objfwd)
edfa9106 1183
7c06ac2b 1184
303a5c93 1185/* True if object X is a pseudovector whose code is CODE. */
7c06ac2b
RS
1186#define PSEUDOVECTORP(x, code) \
1187 (VECTORLIKEP (x) \
1188 && (((XVECTOR (x)->size & (PSEUDOVECTOR_FLAG | (code)))) \
1189 == (PSEUDOVECTOR_FLAG | (code))))
1190
303a5c93 1191/* True if object X is a pseudovector whose code is CODE.
7c06ac2b
RS
1192 This one works during GC. */
1193#define GC_PSEUDOVECTORP(x, code) \
1194 (GC_VECTORLIKEP (x) \
1195 && (((XVECTOR (x)->size & (PSEUDOVECTOR_FLAG | (code)))) \
1196 == (PSEUDOVECTOR_FLAG | (code))))
1197
1198/* Test for specific pseudovector types. */
1199#define WINDOW_CONFIGURATIONP(x) PSEUDOVECTORP (x, PVEC_WINDOW_CONFIGURATION)
1200#define GC_WINDOW_CONFIGURATIONP(x) GC_PSEUDOVECTORP (x, PVEC_WINDOW_CONFIGURATION)
1201#define PROCESSP(x) PSEUDOVECTORP (x, PVEC_PROCESS)
1202#define GC_PROCESSP(x) GC_PSEUDOVECTORP (x, PVEC_PROCESS)
1203#define WINDOWP(x) PSEUDOVECTORP (x, PVEC_WINDOW)
1204#define GC_WINDOWP(x) GC_PSEUDOVECTORP (x, PVEC_WINDOW)
1205#define SUBRP(x) PSEUDOVECTORP (x, PVEC_SUBR)
1206#define GC_SUBRP(x) GC_PSEUDOVECTORP (x, PVEC_SUBR)
1207#define COMPILEDP(x) PSEUDOVECTORP (x, PVEC_COMPILED)
1208#define GC_COMPILEDP(x) GC_PSEUDOVECTORP (x, PVEC_COMPILED)
99a3d506
RS
1209#define BUFFERP(x) PSEUDOVECTORP (x, PVEC_BUFFER)
1210#define GC_BUFFERP(x) GC_PSEUDOVECTORP (x, PVEC_BUFFER)
608ff985
RS
1211#define CHAR_TABLE_P(x) PSEUDOVECTORP (x, PVEC_CHAR_TABLE)
1212#define GC_CHAR_TABLE_P(x) GC_PSEUDOVECTORP (x, PVEC_CHAR_TABLE)
1213#define BOOL_VECTOR_P(x) PSEUDOVECTORP (x, PVEC_BOOL_VECTOR)
1214#define GC_BOOL_VECTOR_P(x) GC_PSEUDOVECTORP (x, PVEC_BOOL_VECTOR)
7c06ac2b
RS
1215#define FRAMEP(x) PSEUDOVECTORP (x, PVEC_FRAME)
1216#define GC_FRAMEP(x) GC_PSEUDOVECTORP (x, PVEC_FRAME)
ea724a01
KH
1217
1218#define SUB_CHAR_TABLE_P(x) (CHAR_TABLE_P (x) && NILP (XCHAR_TABLE (x)->top))
7c06ac2b 1219\f
3cfe6dfd 1220#define EQ(x, y) (XFASTINT (x) == XFASTINT (y))
f498e3b2 1221#define GC_EQ(x, y) (XGCTYPE (x) == XGCTYPE (y) && XPNTR (x) == XPNTR (y))
4746118a 1222
3cfe6dfd 1223#define CHECK_LIST(x, i) \
c5af3bb9 1224 do { if (!CONSP ((x)) && !NILP (x)) x = wrong_type_argument (Qlistp, (x)); } while (0)
3cfe6dfd
JB
1225
1226#define CHECK_STRING(x, i) \
c5af3bb9 1227 do { if (!STRINGP ((x))) x = wrong_type_argument (Qstringp, (x)); } while (0)
3cfe6dfd
JB
1228
1229#define CHECK_CONS(x, i) \
c5af3bb9 1230 do { if (!CONSP ((x))) x = wrong_type_argument (Qconsp, (x)); } while (0)
3cfe6dfd
JB
1231
1232#define CHECK_SYMBOL(x, i) \
c5af3bb9 1233 do { if (!SYMBOLP ((x))) x = wrong_type_argument (Qsymbolp, (x)); } while (0)
3cfe6dfd 1234
608ff985 1235#define CHECK_CHAR_TABLE(x, i) \
a97eb3f3 1236 do { if (!CHAR_TABLE_P ((x))) \
608ff985
RS
1237 x = wrong_type_argument (Qchar_table_p, (x)); } while (0)
1238
3cfe6dfd 1239#define CHECK_VECTOR(x, i) \
c5af3bb9 1240 do { if (!VECTORP ((x))) x = wrong_type_argument (Qvectorp, (x)); } while (0)
3cfe6dfd 1241
7f73dc9d
RS
1242#define CHECK_VECTOR_OR_CHAR_TABLE(x, i) \
1243 do { if (!VECTORP ((x)) && !CHAR_TABLE_P ((x))) \
1244 x = wrong_type_argument (Qvector_or_char_table_p, (x)); \
1245 } while (0)
1246
3cfe6dfd 1247#define CHECK_BUFFER(x, i) \
c5af3bb9 1248 do { if (!BUFFERP ((x))) x = wrong_type_argument (Qbufferp, (x)); } while (0)
3cfe6dfd
JB
1249
1250#define CHECK_WINDOW(x, i) \
c5af3bb9 1251 do { if (!WINDOWP ((x))) x = wrong_type_argument (Qwindowp, (x)); } while (0)
3cfe6dfd 1252
03273ec5 1253/* This macro rejects windows on the interior of the window tree as
e98227af 1254 "dead", which is what we want; this is an argument-checking macro, and
03273ec5
JB
1255 the user should never get access to interior windows.
1256
1257 A window of any sort, leaf or interior, is dead iff the buffer,
1258 vchild, and hchild members are all nil. */
1259
1260#define CHECK_LIVE_WINDOW(x, i) \
2ad18bfd 1261 do { \
c5af3bb9 1262 if (!WINDOWP ((x)) \
03273ec5 1263 || NILP (XWINDOW ((x))->buffer)) \
806b4d9b 1264 x = wrong_type_argument (Qwindow_live_p, (x)); \
2ad18bfd 1265 } while (0)
03273ec5 1266
3cfe6dfd 1267#define CHECK_PROCESS(x, i) \
c5af3bb9 1268 do { if (!PROCESSP ((x))) x = wrong_type_argument (Qprocessp, (x)); } while (0)
3cfe6dfd
JB
1269
1270#define CHECK_NUMBER(x, i) \
c5af3bb9 1271 do { if (!INTEGERP ((x))) x = wrong_type_argument (Qintegerp, (x)); } while (0)
3cfe6dfd
JB
1272
1273#define CHECK_NATNUM(x, i) \
a4a9f09f 1274 do { if (!NATNUMP (x)) x = wrong_type_argument (Qwholenump, (x)); } while (0)
3cfe6dfd
JB
1275
1276#define CHECK_MARKER(x, i) \
c5af3bb9 1277 do { if (!MARKERP ((x))) x = wrong_type_argument (Qmarkerp, (x)); } while (0)
3cfe6dfd
JB
1278
1279#define CHECK_NUMBER_COERCE_MARKER(x, i) \
221f4ef3 1280 do { if (MARKERP ((x))) XSETFASTINT (x, marker_position (x)); \
c5af3bb9 1281 else if (!INTEGERP ((x))) x = wrong_type_argument (Qinteger_or_marker_p, (x)); } while (0)
3cfe6dfd
JB
1282
1283#ifdef LISP_FLOAT_TYPE
1284
3cfe6dfd
JB
1285#define XFLOATINT(n) extract_float((n))
1286
1287#define CHECK_FLOAT(x, i) \
c5af3bb9 1288 do { if (!FLOATP (x)) \
2ad18bfd 1289 x = wrong_type_argument (Qfloatp, (x)); } while (0)
3cfe6dfd
JB
1290
1291#define CHECK_NUMBER_OR_FLOAT(x, i) \
c5af3bb9 1292 do { if (!FLOATP (x) && !INTEGERP (x)) \
2ad18bfd 1293 x = wrong_type_argument (Qnumberp, (x)); } while (0)
3cfe6dfd
JB
1294
1295#define CHECK_NUMBER_OR_FLOAT_COERCE_MARKER(x, i) \
221f4ef3 1296 do { if (MARKERP (x)) XSETFASTINT (x, marker_position (x)); \
c5af3bb9 1297 else if (!INTEGERP (x) && !FLOATP (x)) \
2ad18bfd 1298 x = wrong_type_argument (Qnumber_or_marker_p, (x)); } while (0)
3cfe6dfd
JB
1299
1300#else /* Not LISP_FLOAT_TYPE */
1301
1302#define CHECK_NUMBER_OR_FLOAT CHECK_NUMBER
1303
1304#define CHECK_NUMBER_OR_FLOAT_COERCE_MARKER CHECK_NUMBER_COERCE_MARKER
1305
1306#define XFLOATINT(n) XINT((n))
1307#endif /* LISP_FLOAT_TYPE */
1308
20280af7 1309#define CHECK_OVERLAY(x, i) \
c5af3bb9 1310 do { if (!OVERLAYP ((x))) x = wrong_type_argument (Qoverlayp, (x));} while (0)
20280af7 1311
3cfe6dfd
JB
1312/* Cast pointers to this type to compare them. Some machines want int. */
1313#ifndef PNTR_COMPARISON_TYPE
1314#define PNTR_COMPARISON_TYPE unsigned int
1315#endif
1316\f
1317/* Define a built-in function for calling from Lisp.
1318 `lname' should be the name to give the function in Lisp,
1319 as a null-terminated C string.
1320 `fnname' should be the name of the function in C.
1321 By convention, it starts with F.
1322 `sname' should be the name for the C constant structure
1323 that records information on this function for internal use.
1324 By convention, it should be the same as `fnname' but with S instead of F.
1325 It's too bad that C macros can't compute this from `fnname'.
1326 `minargs' should be a number, the minimum number of arguments allowed.
1327 `maxargs' should be a number, the maximum number of arguments allowed,
1328 or else MANY or UNEVALLED.
1329 MANY means pass a vector of evaluated arguments,
1330 in the form of an integer number-of-arguments
1331 followed by the address of a vector of Lisp_Objects
1332 which contains the argument values.
1333 UNEVALLED means pass the list of unevaluated arguments
1334 `prompt' says how to read arguments for an interactive call.
eab9d423 1335 See the doc string for `interactive'.
3cfe6dfd 1336 A null string means call interactively with no arguments.
eab9d423 1337 `doc' is documentation for the user. */
3cfe6dfd 1338
5125ca93 1339#if !defined (__STDC__) || defined (USE_NONANSI_DEFUN)
7c06ac2b
RS
1340#define DEFUN(lname, fnname, sname, minargs, maxargs, prompt, doc) \
1341 Lisp_Object fnname (); \
1342 struct Lisp_Subr sname = \
1343 { PVEC_SUBR | (sizeof (struct Lisp_Subr) / sizeof (EMACS_INT)), \
1344 fnname, minargs, maxargs, lname, prompt, 0}; \
3cfe6dfd
JB
1345 Lisp_Object fnname
1346
c451d7b1
RS
1347#else
1348
1349/* This version of DEFUN declares a function prototype with the right
99a3d506 1350 arguments, so we can catch errors with maxargs at compile-time. */
7c06ac2b
RS
1351#define DEFUN(lname, fnname, sname, minargs, maxargs, prompt, doc) \
1352 Lisp_Object fnname DEFUN_ARGS_ ## maxargs ; \
1353 struct Lisp_Subr sname = \
1354 { PVEC_SUBR | (sizeof (struct Lisp_Subr) / sizeof (EMACS_INT)), \
1355 fnname, minargs, maxargs, lname, prompt, 0}; \
c451d7b1
RS
1356 Lisp_Object fnname
1357
1358/* Note that the weird token-substitution semantics of ANSI C makes
99a3d506 1359 this work for MANY and UNEVALLED. */
c451d7b1
RS
1360#define DEFUN_ARGS_MANY (int, Lisp_Object *)
1361#define DEFUN_ARGS_UNEVALLED (Lisp_Object)
1362#define DEFUN_ARGS_0 (void)
1363#define DEFUN_ARGS_1 (Lisp_Object)
1364#define DEFUN_ARGS_2 (Lisp_Object, Lisp_Object)
1365#define DEFUN_ARGS_3 (Lisp_Object, Lisp_Object, Lisp_Object)
1366#define DEFUN_ARGS_4 (Lisp_Object, Lisp_Object, Lisp_Object, Lisp_Object)
1367#define DEFUN_ARGS_5 (Lisp_Object, Lisp_Object, Lisp_Object, Lisp_Object, \
1368 Lisp_Object)
1369#define DEFUN_ARGS_6 (Lisp_Object, Lisp_Object, Lisp_Object, Lisp_Object, \
1370 Lisp_Object, Lisp_Object)
1371#define DEFUN_ARGS_7 (Lisp_Object, Lisp_Object, Lisp_Object, Lisp_Object, \
1372 Lisp_Object, Lisp_Object, Lisp_Object)
5593f7e3
KH
1373#define DEFUN_ARGS_8 (Lisp_Object, Lisp_Object, Lisp_Object, Lisp_Object, \
1374 Lisp_Object, Lisp_Object, Lisp_Object, Lisp_Object)
c451d7b1
RS
1375#endif
1376
3cfe6dfd 1377/* defsubr (Sname);
99a3d506 1378 is how we define the symbol for function `name' at start-up time. */
526a2be7 1379extern void defsubr P_ ((struct Lisp_Subr *));
3cfe6dfd
JB
1380
1381#define MANY -2
1382#define UNEVALLED -1
1383
526a2be7
AS
1384extern void defvar_lisp P_ ((char *, Lisp_Object *));
1385extern void defvar_lisp_nopro P_ ((char *, Lisp_Object *));
1386extern void defvar_bool P_ ((char *, int *));
1387extern void defvar_int P_ ((char *, int *));
1388extern void defvar_per_buffer P_ ((char *, Lisp_Object *, Lisp_Object, char *));
1389extern void defvar_kboard P_ ((char *, int));
3cfe6dfd
JB
1390
1391/* Macros we use to define forwarded Lisp variables.
1392 These are used in the syms_of_FILENAME functions. */
1393
3cfe6dfd
JB
1394#define DEFVAR_LISP(lname, vname, doc) defvar_lisp (lname, vname)
1395#define DEFVAR_LISP_NOPRO(lname, vname, doc) defvar_lisp_nopro (lname, vname)
1396#define DEFVAR_BOOL(lname, vname, doc) defvar_bool (lname, vname)
1397#define DEFVAR_INT(lname, vname, doc) defvar_int (lname, vname)
ef15f270
JB
1398#define DEFVAR_PER_BUFFER(lname, vname, type, doc) \
1399 defvar_per_buffer (lname, vname, type, 0)
32462604
KH
1400#define DEFVAR_KBOARD(lname, vname, doc) \
1401 defvar_kboard (lname, \
1402 (int)((char *)(&current_kboard->vname) \
1403 - (char *)current_kboard))
3cfe6dfd 1404\f
78ca380c
JB
1405/* Structure for recording Lisp call stack for backtrace purposes. */
1406
1407/* The special binding stack holds the outer values of variables while
1408 they are bound by a function application or a let form, stores the
1409 code to be executed for Lisp unwind-protect forms, and stores the C
1410 functions to be called for record_unwind_protect.
1411
1412 If func is non-zero, undoing this binding applies func to old_value;
1413 This implements record_unwind_protect.
1414 If func is zero and symbol is nil, undoing this binding evaluates
1415 the list of forms in old_value; this implements Lisp's unwind-protect
1416 form.
1417 Otherwise, undoing this binding stores old_value as symbol's value; this
1418 undoes the bindings made by a let form or function call. */
3cfe6dfd
JB
1419struct specbinding
1420 {
1421 Lisp_Object symbol, old_value;
526a2be7 1422 Lisp_Object (*func) P_ ((Lisp_Object));
3cfe6dfd
JB
1423 Lisp_Object unused; /* Dividing by 16 is faster than by 12 */
1424 };
1425
1426extern struct specbinding *specpdl;
1427extern struct specbinding *specpdl_ptr;
1428extern int specpdl_size;
1429
78ca380c 1430/* Everything needed to describe an active condition case. */
3cfe6dfd
JB
1431struct handler
1432 {
78ca380c 1433 /* The handler clauses and variable from the condition-case form. */
3cfe6dfd
JB
1434 Lisp_Object handler;
1435 Lisp_Object var;
22bbbd42
RS
1436 /* Fsignal stores here the condition-case clause that applies,
1437 and Fcondition_case thus knows which clause to run. */
1438 Lisp_Object chosen_clause;
78ca380c
JB
1439
1440 /* Used to effect the longjump out to the handler. */
3cfe6dfd 1441 struct catchtag *tag;
78ca380c
JB
1442
1443 /* The next enclosing handler. */
3cfe6dfd
JB
1444 struct handler *next;
1445 };
1446
1447extern struct handler *handlerlist;
1448
1449extern struct catchtag *catchlist;
1450extern struct backtrace *backtrace_list;
1451
22bbbd42
RS
1452extern Lisp_Object memory_signal_data;
1453
3cfe6dfd
JB
1454/* An address near the bottom of the stack.
1455 Tells GC how to save a copy of the stack. */
1456extern char *stack_bottom;
1457
99a3d506 1458/* Check quit-flag and quit if it is non-nil. */
3cfe6dfd
JB
1459
1460#define QUIT \
efb859b4 1461 if (!NILP (Vquit_flag) && NILP (Vinhibit_quit)) \
3cfe6dfd
JB
1462 { Vquit_flag = Qnil; Fsignal (Qquit, Qnil); }
1463
1464/* Nonzero if ought to quit now. */
1465
efb859b4 1466#define QUITP (!NILP (Vquit_flag) && NILP (Vinhibit_quit))
3cfe6dfd 1467\f
8ac90470 1468/* Variables used locally in the following case handling macros. */
2e34157c
RS
1469extern int case_temp1;
1470extern Lisp_Object case_temp2;
8ac90470 1471
e98227af 1472/* Current buffer's map from characters to lower-case characters. */
3cfe6dfd 1473
8ac90470 1474#define DOWNCASE_TABLE current_buffer->downcase_table
3cfe6dfd 1475
e98227af 1476/* Current buffer's map from characters to upper-case characters. */
3cfe6dfd 1477
8ac90470 1478#define UPCASE_TABLE current_buffer->upcase_table
3cfe6dfd 1479
e98227af 1480/* Downcase a character, or make no change if that cannot be done. */
3cfe6dfd 1481
8ac90470
KH
1482#define DOWNCASE(CH) \
1483 ((case_temp1 = (CH), \
1484 case_temp2 = CHAR_TABLE_REF (DOWNCASE_TABLE, case_temp1), \
1485 NATNUMP (case_temp2)) \
1486 ? XFASTINT (case_temp2) : case_temp1)
3cfe6dfd 1487
e98227af 1488/* 1 if CH is upper case. */
3cfe6dfd 1489
476d47ce 1490#define UPPERCASEP(CH) (DOWNCASE (CH) != (CH))
3cfe6dfd 1491
e98227af 1492/* 1 if CH is neither upper nor lower case. */
3cfe6dfd 1493
8ac90470 1494#define NOCASEP(CH) (UPCASE1 (CH) == (CH))
3cfe6dfd 1495
e98227af 1496/* 1 if CH is lower case. */
3cfe6dfd 1497
e98227af 1498#define LOWERCASEP(CH) (!UPPERCASEP (CH) && !NOCASEP(CH))
3cfe6dfd 1499
e98227af 1500/* Upcase a character, or make no change if that cannot be done. */
3cfe6dfd 1501
e98227af
KH
1502#define UPCASE(CH) (!UPPERCASEP (CH) ? UPCASE1 (CH) : (CH))
1503
1504/* Upcase a character known to be not upper case. */
1505
8ac90470
KH
1506#define UPCASE1(CH) \
1507 ((case_temp1 = (CH), \
1508 case_temp2 = CHAR_TABLE_REF (UPCASE_TABLE, case_temp1), \
1509 NATNUMP (case_temp2)) \
1510 ? XFASTINT (case_temp2) : case_temp1)
3cfe6dfd 1511
c6a3c83c 1512extern Lisp_Object Vascii_downcase_table;
3cfe6dfd 1513\f
99a3d506 1514/* Number of bytes of structure consed since last GC. */
3cfe6dfd
JB
1515
1516extern int consing_since_gc;
1517
99a3d506 1518/* Threshold for doing another gc. */
3cfe6dfd 1519
65deefca 1520extern int gc_cons_threshold;
3cfe6dfd 1521
99a3d506 1522/* Structure for recording stack slots that need marking. */
3cfe6dfd
JB
1523
1524/* This is a chain of structures, each of which points at a Lisp_Object variable
1525 whose value should be marked in garbage collection.
1526 Normally every link of the chain is an automatic variable of a function,
1527 and its `val' points to some argument or local variable of the function.
1528 On exit to the function, the chain is set back to the value it had on entry.
e5f55f07
BF
1529 This way, no link remains in the chain when the stack frame containing the
1530 link disappears.
3cfe6dfd
JB
1531
1532 Every function that can call Feval must protect in this fashion all
99a3d506 1533 Lisp_Object variables whose contents will be used again. */
3cfe6dfd
JB
1534
1535extern struct gcpro *gcprolist;
1536
1537struct gcpro
1538 {
1539 struct gcpro *next;
1540 Lisp_Object *var; /* Address of first protected variable */
1541 int nvars; /* Number of consecutive protected variables */
1542 };
1543
1544#define GCPRO1(varname) \
1545 {gcpro1.next = gcprolist; gcpro1.var = &varname; gcpro1.nvars = 1; \
1546 gcprolist = &gcpro1; }
1547
1548#define GCPRO2(varname1, varname2) \
1549 {gcpro1.next = gcprolist; gcpro1.var = &varname1; gcpro1.nvars = 1; \
1550 gcpro2.next = &gcpro1; gcpro2.var = &varname2; gcpro2.nvars = 1; \
1551 gcprolist = &gcpro2; }
1552
1553#define GCPRO3(varname1, varname2, varname3) \
1554 {gcpro1.next = gcprolist; gcpro1.var = &varname1; gcpro1.nvars = 1; \
1555 gcpro2.next = &gcpro1; gcpro2.var = &varname2; gcpro2.nvars = 1; \
1556 gcpro3.next = &gcpro2; gcpro3.var = &varname3; gcpro3.nvars = 1; \
1557 gcprolist = &gcpro3; }
1558
1559#define GCPRO4(varname1, varname2, varname3, varname4) \
1560 {gcpro1.next = gcprolist; gcpro1.var = &varname1; gcpro1.nvars = 1; \
1561 gcpro2.next = &gcpro1; gcpro2.var = &varname2; gcpro2.nvars = 1; \
1562 gcpro3.next = &gcpro2; gcpro3.var = &varname3; gcpro3.nvars = 1; \
1563 gcpro4.next = &gcpro3; gcpro4.var = &varname4; gcpro4.nvars = 1; \
1564 gcprolist = &gcpro4; }
1565
c47b8d02
RS
1566#define GCPRO5(varname1, varname2, varname3, varname4, varname5) \
1567 {gcpro1.next = gcprolist; gcpro1.var = &varname1; gcpro1.nvars = 1; \
1568 gcpro2.next = &gcpro1; gcpro2.var = &varname2; gcpro2.nvars = 1; \
1569 gcpro3.next = &gcpro2; gcpro3.var = &varname3; gcpro3.nvars = 1; \
1570 gcpro4.next = &gcpro3; gcpro4.var = &varname4; gcpro4.nvars = 1; \
1571 gcpro5.next = &gcpro4; gcpro5.var = &varname5; gcpro5.nvars = 1; \
1572 gcprolist = &gcpro5; }
1573
99a3d506 1574/* Call staticpro (&var) to protect static variable `var'. */
3cfe6dfd 1575
526a2be7 1576void staticpro P_ ((Lisp_Object *));
e98227af 1577
3cfe6dfd
JB
1578#define UNGCPRO (gcprolist = gcpro1.next)
1579
5db82c9d 1580/* Evaluate expr, UNGCPRO, and then return the value of expr. */
c47b8d02 1581#define RETURN_UNGCPRO(expr) \
f3ca341e 1582if (1) \
c47b8d02
RS
1583 { \
1584 Lisp_Object ret_ungc_val; \
1585 ret_ungc_val = (expr); \
1586 UNGCPRO; \
1587 return ret_ungc_val; \
1588 } \
f3ca341e 1589else
3cfe6dfd 1590\f
2f69f2ec
RS
1591/* Declare a Lisp-callable function. The MAXARGS parameter has the same
1592 meaning as in the DEFUN macro, and is used to construct a prototype. */
1593#if !defined (__STDC__) || defined (USE_NONANSI_DEFUN)
1594#define EXFUN(fnname, maxargs) \
1595 extern Lisp_Object fnname ()
1596#else
1597/* We can use the same trick as in the DEFUN macro to generate the
1598 appropriate prototype. */
1599#define EXFUN(fnname, maxargs) \
1600 extern Lisp_Object fnname DEFUN_ARGS_ ## maxargs
1601#endif
1602
526a2be7
AS
1603/* Forward declarations for prototypes. */
1604struct window;
1605struct frame;
2f69f2ec 1606
3cfe6dfd
JB
1607/* Defined in data.c */
1608extern Lisp_Object Qnil, Qt, Qquote, Qlambda, Qsubr, Qunbound;
1609extern Lisp_Object Qerror_conditions, Qerror_message, Qtop_level;
1610extern Lisp_Object Qerror, Qquit, Qwrong_type_argument, Qargs_out_of_range;
1611extern Lisp_Object Qvoid_variable, Qvoid_function;
1612extern Lisp_Object Qsetting_constant, Qinvalid_read_syntax;
1613extern Lisp_Object Qinvalid_function, Qwrong_number_of_arguments, Qno_catch;
1614extern Lisp_Object Qend_of_file, Qarith_error;
1615extern Lisp_Object Qbeginning_of_buffer, Qend_of_buffer, Qbuffer_read_only;
83125cd7 1616extern Lisp_Object Qmark_inactive;
3cfe6dfd 1617
59b4254d
JB
1618extern Lisp_Object Qrange_error, Qdomain_error, Qsingularity_error;
1619extern Lisp_Object Qoverflow_error, Qunderflow_error;
623ed1b0 1620
07a97bf8
RS
1621extern Lisp_Object Qintegerp, Qnumberp, Qnatnump, Qwholenump;
1622extern Lisp_Object Qsymbolp, Qlistp, Qconsp;
3cfe6dfd
JB
1623extern Lisp_Object Qstringp, Qarrayp, Qsequencep, Qbufferp;
1624extern Lisp_Object Qchar_or_string_p, Qmarkerp, Qvectorp;
4de86b16 1625extern Lisp_Object Qinteger_or_marker_p, Qnumber_or_marker_p;
7f73dc9d 1626extern Lisp_Object Qchar_table_p, Qvector_or_char_table_p;
4de86b16 1627extern Lisp_Object Qboundp, Qfboundp;
cde20f41 1628extern Lisp_Object Qbuffer_or_string_p;
3cfe6dfd
JB
1629extern Lisp_Object Qcdr;
1630
1631#ifdef LISP_FLOAT_TYPE
1632extern Lisp_Object Qfloatp, Qinteger_or_floatp, Qinteger_or_float_or_marker_p;
1633#endif /* LISP_FLOAT_TYPE */
1634
ff11dfa1 1635extern Lisp_Object Qframep;
3cfe6dfd 1636
2f69f2ec
RS
1637EXFUN (Feq, 2);
1638EXFUN (Fnull, 1);
1639EXFUN (Flistp, 1);
1640EXFUN (Fconsp, 1);
1641EXFUN (Fatom, 1);
1642EXFUN (Fnlistp, 1);
1643EXFUN (Fintegerp, 1);
1644EXFUN (Fnatnump, 1);
1645EXFUN (Fsymbolp, 1);
1646EXFUN (Fvectorp, 1);
1647EXFUN (Fstringp, 1);
a1b5012f 1648EXFUN (Fmultibyte_string_p, 1);
2f69f2ec
RS
1649EXFUN (Farrayp, 1);
1650EXFUN (Fsequencep, 1);
1651EXFUN (Fbufferp, 1);
1652EXFUN (Fmarkerp, 1);
1653EXFUN (Fsubrp, 1);
1654EXFUN (Fchar_or_string_p, 1);
1655EXFUN (Finteger_or_marker_p, 1);
3cfe6dfd 1656#ifdef LISP_FLOAT_TYPE
2f69f2ec
RS
1657EXFUN (Ffloatp, 1);
1658EXFUN (Finteger_or_floatp, 1);
1659EXFUN (Finteger_or_float_or_marker_p, 1);
3cfe6dfd
JB
1660#endif /* LISP_FLOAT_TYPE */
1661
2f69f2ec
RS
1662EXFUN (Fcar, 1);
1663EXFUN (Fcar_safe, 1);
1664EXFUN (Fcdr, 1);
1665EXFUN (Fcdr_safe, 1);
1666EXFUN (Fsetcar, 2);
1667EXFUN (Fsetcdr, 2);
1668EXFUN (Fboundp, 1);
1669EXFUN (Ffboundp, 1);
1670EXFUN (Fmakunbound, 1);
1671EXFUN (Ffmakunbound, 1);
1672EXFUN (Fsymbol_function, 1);
1673EXFUN (Fsymbol_plist, 1);
1674EXFUN (Fsymbol_name, 1);
1675extern Lisp_Object indirect_function P_ ((Lisp_Object));
1676EXFUN (Findirect_function, 1);
1677EXFUN (Ffset, 2);
1678EXFUN (Fsetplist, 2);
1679EXFUN (Fsymbol_value, 1);
a154f406 1680extern Lisp_Object find_symbol_value P_ ((Lisp_Object));
2f69f2ec
RS
1681EXFUN (Fset, 2);
1682EXFUN (Fdefault_value, 1);
1683EXFUN (Fset_default, 2);
1684EXFUN (Fdefault_boundp, 1);
1685EXFUN (Fmake_local_variable, 1);
a154f406 1686EXFUN (Flocal_variable_p, 2);
2f69f2ec
RS
1687EXFUN (Flocal_variable_if_set_p, 2);
1688
1689EXFUN (Faref, 2);
1690EXFUN (Faset, 3);
1691
1692EXFUN (Fstring_to_number, 2);
1693EXFUN (Fnumber_to_string, 1);
1694EXFUN (Feqlsign, 2);
1695EXFUN (Fgtr, 2);
1696EXFUN (Flss, 2);
1697EXFUN (Fgeq, 2);
1698EXFUN (Fleq, 2);
1699EXFUN (Fneq, 2);
1700EXFUN (Fzerop, 1);
1701EXFUN (Fplus, MANY);
1702EXFUN (Fminus, MANY);
1703EXFUN (Ftimes, MANY);
1704EXFUN (Fquo, MANY);
1705EXFUN (Frem, 2);
1706EXFUN (Fmax, MANY);
1707EXFUN (Fmin, MANY);
1708EXFUN (Flogand, MANY);
1709EXFUN (Flogior, MANY);
1710EXFUN (Flogxor, MANY);
1711EXFUN (Flognot, 1);
1712EXFUN (Flsh, 2);
1713EXFUN (Fash, 2);
1714
1715EXFUN (Fadd1, 1);
1716EXFUN (Fsub1, 1);
1717
1718extern Lisp_Object long_to_cons P_ ((unsigned long));
1719extern unsigned long cons_to_long P_ ((Lisp_Object));
1720extern void args_out_of_range P_ ((Lisp_Object, Lisp_Object));
1721extern void args_out_of_range_3 P_ ((Lisp_Object, Lisp_Object, Lisp_Object));
1722extern Lisp_Object wrong_type_argument P_ ((Lisp_Object, Lisp_Object));
1723extern void store_symval_forwarding P_ ((Lisp_Object, Lisp_Object, Lisp_Object));
1724extern Lisp_Object do_symval_forwarding P_ ((Lisp_Object));
526a2be7 1725extern Lisp_Object set_internal P_ ((Lisp_Object, Lisp_Object, int));
46abf440
AS
1726extern void syms_of_data P_ ((void));
1727extern void init_data P_ ((void));
3cfe6dfd 1728
a37e10f9 1729/* Defined in cmds.c */
2f69f2ec
RS
1730EXFUN (Fend_of_line, 1);
1731EXFUN (Fforward_char, 1);
1732EXFUN (Fforward_line, 1);
526a2be7
AS
1733extern int forward_point P_ ((int));
1734extern int internal_self_insert P_ ((int, int));
46abf440
AS
1735extern void syms_of_cmds P_ ((void));
1736extern void keys_of_cmds P_ ((void));
a37e10f9 1737
6b768554 1738/* Defined in coding.c */
2f69f2ec
RS
1739EXFUN (Fcoding_system_p, 1);
1740EXFUN (Fcheck_coding_system, 1);
34ba1f2e 1741EXFUN (Fread_coding_system, 2);
2f69f2ec 1742EXFUN (Fread_non_nil_coding_system, 1);
a154f406 1743EXFUN (Ffind_operation_coding_system, MANY);
526a2be7
AS
1744EXFUN (Fencode_coding_string, 3);
1745EXFUN (Fdecode_coding_string, 3);
080cb8cd 1746extern Lisp_Object detect_coding_system P_ ((unsigned char *, int, int));
85ef85ae 1747extern void init_coding P_ ((void));
46abf440
AS
1748extern void init_coding_once P_ ((void));
1749extern void syms_of_coding P_ ((void));
6b768554 1750
5e741a41 1751/* Defined in charset.c */
b4e187e2 1752extern int nonascii_insert_offset;
bb9c978a 1753extern Lisp_Object Vnonascii_translation_table;
5e741a41 1754EXFUN (Fchar_bytes, 1);
ec5d8db7 1755EXFUN (Fchar_width, 1);
a1b5012f
RS
1756extern int chars_in_text P_ ((unsigned char *, int));
1757extern int multibyte_chars_in_text P_ ((unsigned char *, int));
4a2f9c6a 1758extern int unibyte_char_to_multibyte P_ ((int));
5666cc6f 1759extern int multibyte_char_to_unibyte P_ ((int, Lisp_Object));
b4e187e2 1760extern Lisp_Object Qcharset;
46abf440
AS
1761extern void init_charset_once P_ ((void));
1762extern void syms_of_charset P_ ((void));
5e741a41 1763
a37e10f9 1764/* Defined in syntax.c */
2f69f2ec
RS
1765EXFUN (Fforward_word, 1);
1766EXFUN (Fskip_chars_forward, 2);
1767EXFUN (Fskip_chars_backward, 2);
526a2be7
AS
1768EXFUN (Fsyntax_table_p, 1);
1769EXFUN (Fsyntax_table, 0);
1770EXFUN (Fset_syntax_table, 1);
46abf440
AS
1771extern void init_syntax_once P_ ((void));
1772extern void syms_of_syntax P_ ((void));
a37e10f9 1773
3cfe6dfd
JB
1774/* Defined in fns.c */
1775extern Lisp_Object Qstring_lessp;
1776extern Lisp_Object Vfeatures;
5010d3b8
GM
1777unsigned sxhash P_ ((Lisp_Object, int));
1778Lisp_Object make_hash_table P_ ((Lisp_Object, Lisp_Object, Lisp_Object,
1779 Lisp_Object, Lisp_Object, Lisp_Object,
1780 Lisp_Object));
d9138d5d 1781Lisp_Object copy_hash_table P_ ((struct Lisp_Hash_Table *));
5010d3b8
GM
1782int hash_lookup P_ ((struct Lisp_Hash_Table *, Lisp_Object, unsigned *));
1783void hash_put P_ ((struct Lisp_Hash_Table *, Lisp_Object, Lisp_Object,
1784 unsigned));
1785void hash_remove P_ ((struct Lisp_Hash_Table *, Lisp_Object));
1786void hash_clear P_ ((struct Lisp_Hash_Table *));
1787void remove_hash_entry P_ ((struct Lisp_Hash_Table *, int));
1788EXFUN (Fsxhash, 1);
1789EXFUN (Fmake_hash_table, MANY);
d9138d5d 1790EXFUN (Fcopy_hash_table, 1);
5010d3b8
GM
1791EXFUN (Fhash_table_count, 1);
1792EXFUN (Fhash_table_rehash_size, 1);
1793EXFUN (Fhash_table_rehash_threshold, 1);
1794EXFUN (Fhash_table_size, 1);
1795EXFUN (Fhash_table_test, 1);
1796EXFUN (Fhash_table_weak, 1);
1797EXFUN (Fhash_table_p, 1);
1798EXFUN (Fclrhash, 1);
1799EXFUN (Fgethash, 3);
1800EXFUN (Fputhash, 3);
1801EXFUN (Fremhash, 2);
1802EXFUN (Fmaphash, 2);
1803EXFUN (Fdefine_hash_table_test, 3);
1804
2f69f2ec
RS
1805EXFUN (Fidentity, 1);
1806EXFUN (Frandom, 1);
1807EXFUN (Flength, 1);
1808EXFUN (Fsafe_length, 1);
1809EXFUN (Fappend, MANY);
1810EXFUN (Fconcat, MANY);
1811EXFUN (Fvconcat, MANY);
1812EXFUN (Fcopy_sequence, 1);
b4e187e2
RS
1813EXFUN (Fstring_make_multibyte, 1);
1814EXFUN (Fstring_make_unibyte, 1);
1815EXFUN (Fstring_as_multibyte, 1);
1816EXFUN (Fstring_as_unibyte, 1);
2f69f2ec 1817EXFUN (Fsubstring, 3);
a1b5012f 1818extern Lisp_Object substring_both P_ ((Lisp_Object, int, int, int, int));
2f69f2ec
RS
1819EXFUN (Fnth, 2);
1820EXFUN (Fnthcdr, 2);
1821EXFUN (Fmemq, 2);
1822EXFUN (Fassq, 2);
1823EXFUN (Fassoc, 2);
1824EXFUN (Felt, 2);
1825EXFUN (Fmember, 2);
1826EXFUN (Frassq, 2);
1827EXFUN (Fdelq, 2);
1828EXFUN (Fsort, 2);
1829EXFUN (Freverse, 1);
1830EXFUN (Fnreverse, 1);
1831EXFUN (Fget, 2);
1832EXFUN (Fput, 3);
1833EXFUN (Fequal, 2);
1834EXFUN (Ffillarray, 2);
1835EXFUN (Fnconc, MANY);
1836EXFUN (Fmapcar, 2);
1837EXFUN (Fmapconcat, 3);
1838EXFUN (Fy_or_n_p, 1);
1839extern Lisp_Object do_yes_or_no_p P_ ((Lisp_Object));
1840EXFUN (Ffeaturep, 1);
6f39b7c8 1841EXFUN (Frequire, 3);
2f69f2ec
RS
1842EXFUN (Fprovide, 1);
1843extern Lisp_Object concat2 P_ ((Lisp_Object, Lisp_Object));
1844extern Lisp_Object concat3 P_ ((Lisp_Object, Lisp_Object, Lisp_Object));
1845extern Lisp_Object nconc2 P_ ((Lisp_Object, Lisp_Object));
1846extern Lisp_Object assq_no_quit P_ ((Lisp_Object, Lisp_Object));
1c5c931a 1847extern void clear_string_char_byte_cache P_ (());
a1b5012f
RS
1848extern int string_char_to_byte P_ ((Lisp_Object, int));
1849extern int string_byte_to_char P_ ((Lisp_Object, int));
ec5d8db7
AS
1850extern Lisp_Object string_make_multibyte P_ ((Lisp_Object));
1851extern Lisp_Object string_make_unibyte P_ ((Lisp_Object));
2f69f2ec
RS
1852EXFUN (Fcopy_alist, 1);
1853EXFUN (Fplist_get, 2);
5010d3b8 1854EXFUN (Fplist_put, 3);
2f69f2ec
RS
1855EXFUN (Fset_char_table_parent, 2);
1856EXFUN (Fchar_table_extra_slot, 2);
526a2be7 1857EXFUN (Fset_char_table_extra_slot, 3);
2f69f2ec
RS
1858EXFUN (Frassoc, 2);
1859EXFUN (Fstring_equal, 2);
42d65b5f 1860EXFUN (Fcompare_strings, 7);
2f69f2ec 1861EXFUN (Fstring_lessp, 2);
ec5d8db7 1862extern int char_table_translate P_ ((Lisp_Object, int));
526a2be7
AS
1863extern void map_char_table P_ ((void (*) (Lisp_Object, Lisp_Object, Lisp_Object),
1864 Lisp_Object, Lisp_Object, Lisp_Object, int,
1865 Lisp_Object *));
46abf440 1866extern void syms_of_fns P_ ((void));
2f69f2ec
RS
1867
1868/* Defined in floatfns.c */
1869#ifdef LISP_FLOAT_TYPE
1870extern double extract_float P_ ((Lisp_Object));
1871EXFUN (Ffloat, 1);
1872#endif /* LISP_FLOAT_TYPE */
1873EXFUN (Ftruncate, 2);
46abf440
AS
1874extern void init_floatfns P_ ((void));
1875extern void syms_of_floatfns P_ ((void));
3cfe6dfd 1876
c98adc1b 1877/* Defined in insdel.c */
2f69f2ec 1878extern void move_gap P_ ((int));
4ed24bf3 1879extern void move_gap_both P_ ((int, int));
2f69f2ec 1880extern void make_gap P_ ((int));
a1b5012f
RS
1881extern int copy_text P_ ((unsigned char *, unsigned char *, int, int, int));
1882extern int count_size_as_multibyte P_ ((unsigned char *, int));
ec5d8db7
AS
1883extern int count_combining_before P_ ((unsigned char *, int, int, int));
1884extern int count_combining_after P_ ((unsigned char *, int, int, int));
2f69f2ec
RS
1885extern void insert P_ ((unsigned char *, int));
1886extern void insert_and_inherit P_ ((unsigned char *, int));
4ed24bf3 1887extern void insert_1 P_ ((unsigned char *, int, int, int, int));
a1b5012f
RS
1888extern void insert_1_both P_ ((unsigned char *, int, int, int, int, int));
1889extern void insert_from_string P_ ((Lisp_Object, int, int, int, int, int));
2f69f2ec
RS
1890extern void insert_from_buffer P_ ((struct buffer *, int, int, int));
1891extern void insert_char P_ ((int));
1892extern void insert_string P_ ((char *));
1893extern void insert_before_markers P_ ((unsigned char *, int));
1894extern void insert_before_markers_and_inherit P_ ((unsigned char *, int));
a1b5012f 1895extern void insert_from_string_before_markers P_ ((Lisp_Object, int, int, int, int, int));
2f69f2ec
RS
1896extern void del_range P_ ((int, int));
1897extern void del_range_1 P_ ((int, int, int));
4ed24bf3
RS
1898extern void del_range_byte P_ ((int, int, int));
1899extern void del_range_both P_ ((int, int, int, int, int));
1900extern void del_range_2 P_ ((int, int, int, int));
2f69f2ec
RS
1901extern void modify_region P_ ((struct buffer *, int, int));
1902extern void prepare_to_modify_buffer P_ ((int, int, int *));
1903extern void signal_before_change P_ ((int, int, int *));
1904extern void signal_after_change P_ ((int, int, int));
1e94b998
KH
1905extern void adjust_after_replace P_ ((int, int, Lisp_Object, int, int));
1906extern void adjust_after_insert P_ ((int, int, int, int, int));
d8fc7ce4 1907extern void replace_range P_ ((int, int, Lisp_Object, int, int, int));
46abf440 1908extern void syms_of_insdel P_ ((void));
c98adc1b 1909
1747fb16 1910/* Defined in dispnew.c */
2f69f2ec
RS
1911EXFUN (Fding, 1);
1912EXFUN (Fredraw_display, 0);
1913EXFUN (Fsleep_for, 2);
1914EXFUN (Fsit_for, 3);
526a2be7 1915extern Lisp_Object sit_for P_ ((int, int, int, int, int));
46abf440
AS
1916extern void init_display P_ ((void));
1917extern void syms_of_display P_ ((void));
1747fb16 1918
c98adc1b 1919/* Defined in xdisp.c */
d74347bc 1920extern Lisp_Object Qinhibit_redisplay;
439ae27b 1921extern Lisp_Object Vmessage_log_max;
a1b5012f 1922extern int message_enable_multibyte;
986113df
GM
1923extern Lisp_Object echo_area_buffer[2];
1924extern void setup_echo_area_for_printing P_ ((int));
1925extern int push_message P_ ((void));
1926extern void pop_message P_ ((void));
1927extern void restore_message P_ ((void));
1928extern Lisp_Object current_message P_ ((void));
1929extern void set_message P_ ((char *s, Lisp_Object, int, int));
1930extern void clear_message P_ ((int, int));
2f69f2ec
RS
1931extern void message P_ ((/* char *, ... */));
1932extern void message_nolog P_ ((/* char *, ... */));
1933extern void message1 P_ ((char *));
1934extern void message1_nolog P_ ((char *));
a1b5012f 1935extern void message2 P_ ((char *, int, int));
3b4490b3 1936extern void message2_nolog P_ ((char *, int, int));
5010d3b8
GM
1937extern void message3 P_ ((Lisp_Object, int, int));
1938extern void message3_nolog P_ ((Lisp_Object, int, int));
a1b5012f
RS
1939extern void message_dolog P_ ((char *, int, int, int));
1940extern void message_with_string P_ ((char *, Lisp_Object, int));
2f69f2ec 1941extern void message_log_maybe_newline P_ ((void));
526a2be7
AS
1942extern void update_echo_area P_ ((void));
1943extern void truncate_echo_area P_ ((int));
1944extern void redisplay P_ ((void));
1945extern void redisplay_preserve_echo_area P_ ((void));
1946extern void mark_window_display_accurate P_ ((Lisp_Object, int));
1947extern int invisible_p P_ ((Lisp_Object, Lisp_Object));
1948extern void prepare_menu_bars P_ ((void));
46abf440
AS
1949extern void syms_of_xdisp P_ ((void));
1950extern void init_xdisp P_ ((void));
c98adc1b 1951
3cfe6dfd 1952/* Defined in alloc.c */
526a2be7
AS
1953extern void malloc_warning P_ ((char *));
1954extern void memory_full P_ ((void));
1955extern void buffer_memory_full P_ ((void));
5010d3b8
GM
1956extern int survives_gc_p P_ ((Lisp_Object));
1957extern void mark_object P_ ((Lisp_Object *));
3cfe6dfd 1958extern Lisp_Object Vpurify_flag;
2f69f2ec 1959EXFUN (Fcons, 2);
b4e187e2
RS
1960EXFUN (list2, 2);
1961EXFUN (list3, 3);
1962EXFUN (list4, 4);
1963EXFUN (list5, 5);
2f69f2ec
RS
1964EXFUN (Flist, MANY);
1965EXFUN (Fmake_list, 2);
1966extern Lisp_Object allocate_misc P_ ((void));
1967EXFUN (Fmake_vector, 2);
1968EXFUN (Fvector, MANY);
1969EXFUN (Fmake_symbol, 1);
1970EXFUN (Fmake_marker, 0);
1971EXFUN (Fmake_string, 2);
1972extern Lisp_Object build_string P_ ((char *));
1973extern Lisp_Object make_string P_ ((char *, int));
ec5d8db7 1974extern Lisp_Object make_unibyte_string P_ ((char *, int));
d8fc7ce4 1975extern Lisp_Object make_multibyte_string P_ ((char *, int, int));
2f69f2ec
RS
1976extern Lisp_Object make_event_array P_ ((int, Lisp_Object *));
1977extern Lisp_Object make_uninit_string P_ ((int));
a1b5012f 1978extern Lisp_Object make_uninit_multibyte_string P_ ((int, int));
d8fc7ce4
KH
1979extern Lisp_Object make_string_from_bytes P_ ((char *, int, int));
1980extern Lisp_Object make_specified_string P_ ((char *, int, int, int));
2f69f2ec 1981EXFUN (Fpurecopy, 1);
d8fc7ce4 1982extern Lisp_Object make_pure_string P_ ((char *, int, int, int));
2f69f2ec
RS
1983extern Lisp_Object pure_cons P_ ((Lisp_Object, Lisp_Object));
1984extern Lisp_Object make_pure_vector P_ ((EMACS_INT));
1985EXFUN (Fgarbage_collect, 0);
1986EXFUN (Fmake_byte_code, MANY);
1987EXFUN (Fmake_bool_vector, 2);
1988EXFUN (Fmake_char_table, 2);
1989extern Lisp_Object make_sub_char_table P_ ((Lisp_Object));
7f73dc9d 1990extern Lisp_Object Qchar_table_extra_slots;
2f69f2ec 1991extern struct Lisp_Vector *allocate_vectorlike P_ ((EMACS_INT));
4d57802e 1992extern int gc_in_progress;
2f69f2ec
RS
1993#ifdef LISP_FLOAT_TYPE
1994extern Lisp_Object make_float P_ ((double));
1995#endif /* LISP_FLOAT_TYPE */
526a2be7
AS
1996extern void display_malloc_warning P_ ((void));
1997extern int inhibit_garbage_collection P_ ((void));
1998extern void free_marker P_ ((Lisp_Object));
1999extern void free_cons P_ ((struct Lisp_Cons *));
46abf440
AS
2000extern void init_alloc_once P_ ((void));
2001extern void init_alloc P_ ((void));
2002extern void syms_of_alloc P_ ((void));
3cfe6dfd
JB
2003
2004/* Defined in print.c */
2005extern Lisp_Object Vprin1_to_string_buffer;
2f69f2ec
RS
2006EXFUN (Fprin1, 2);
2007EXFUN (Fprin1_to_string, 2);
2008EXFUN (Fprinc, 2);
2009EXFUN (Fterpri, 1);
2010EXFUN (Fprint, 2);
2011EXFUN (Ferror_message_string, 1);
3cfe6dfd 2012extern Lisp_Object Vstandard_output, Qstandard_output;
9453ea7b 2013extern Lisp_Object Qexternal_debugging_output;
2f69f2ec 2014extern void temp_output_buffer_setup P_ ((char *));
3cfe6dfd
JB
2015extern int print_level, print_escape_newlines;
2016extern Lisp_Object Qprint_escape_newlines;
526a2be7
AS
2017extern void write_string P_ ((char *, int));
2018extern void write_string_1 P_ ((char *, int, Lisp_Object));
2019extern void print_error_message P_ ((Lisp_Object, Lisp_Object));
2020extern Lisp_Object internal_with_output_to_temp_buffer
ec5d8db7 2021 P_ ((char *, Lisp_Object (*) (Lisp_Object), Lisp_Object));
526a2be7 2022extern void float_to_string P_ ((unsigned char *, double));
46abf440 2023extern void syms_of_print P_ ((void));
526a2be7
AS
2024
2025/* Defined in doprnt.c */
2026extern int doprnt P_ ((char *, int, char *, char *, int, char **));
2027extern int doprnt_lisp P_ ((char *, int, char *, char *, int, char **));
3cfe6dfd
JB
2028
2029/* Defined in lread.c */
2030extern Lisp_Object Qvariable_documentation, Qstandard_input;
393306dd 2031extern Lisp_Object Vobarray, initial_obarray, Vstandard_input;
2f69f2ec
RS
2032EXFUN (Fread, 1);
2033EXFUN (Fread_from_string, 3);
2034EXFUN (Fintern, 2);
2035EXFUN (Fintern_soft, 2);
5d8c7983 2036EXFUN (Fload, 5);
2f69f2ec 2037EXFUN (Fget_file_char, 0);
485bf581
RS
2038EXFUN (Fread_char, 2);
2039EXFUN (Fread_event, 2);
2040extern Lisp_Object read_filtered_event P_ ((int, int, int, int));
eb542c51 2041EXFUN (Feval_region, 4);
2f69f2ec
RS
2042extern Lisp_Object intern P_ ((char *));
2043extern Lisp_Object make_symbol P_ ((char *));
a1b5012f 2044extern Lisp_Object oblookup P_ ((Lisp_Object, char *, int, int));
c5e3de70
RS
2045#define LOADHIST_ATTACH(x) \
2046 if (initialized) Vcurrent_load_list = Fcons (x, Vcurrent_load_list)
2047extern Lisp_Object Vcurrent_load_list;
2048extern Lisp_Object Vload_history;
526a2be7
AS
2049extern int openp P_ ((Lisp_Object, Lisp_Object, char *, Lisp_Object *, int));
2050extern int isfloat_string P_ ((char *));
2051extern void map_obarray P_ ((Lisp_Object, void (*) (Lisp_Object, Lisp_Object),
2052 Lisp_Object));
2053extern void dir_warning P_ ((char *, Lisp_Object));
2054extern void close_load_descs P_ ((void));
46abf440
AS
2055extern void init_obarray P_ ((void));
2056extern void init_lread P_ ((void));
2057extern void syms_of_lread P_ ((void));
3cfe6dfd
JB
2058
2059/* Defined in eval.c */
2060extern Lisp_Object Qautoload, Qexit, Qinteractive, Qcommandp, Qdefun, Qmacro;
ad236261 2061extern Lisp_Object Vinhibit_quit, Qinhibit_quit, Vquit_flag;
3cfe6dfd
JB
2062extern Lisp_Object Vmocklisp_arguments, Qmocklisp, Qmocklisp_arguments;
2063extern Lisp_Object Vautoload_queue;
973e8873 2064extern Lisp_Object Vdebug_on_error;
f1b6e5fc
SM
2065/* To run a normal hook, use the appropriate function from the list below.
2066 The calling convention:
2067
846d69ac 2068 if (!NILP (Vrun_hooks))
f1b6e5fc
SM
2069 call1 (Vrun_hooks, Qmy_funny_hook);
2070
2071 should no longer be used. */
3cfe6dfd 2072extern Lisp_Object Vrun_hooks;
2f69f2ec
RS
2073EXFUN (Frun_hooks, MANY);
2074EXFUN (Frun_hook_with_args, MANY);
2075EXFUN (Frun_hook_with_args_until_success, MANY);
2076EXFUN (Frun_hook_with_args_until_failure, MANY);
526a2be7
AS
2077extern Lisp_Object run_hook_list_with_args P_ ((Lisp_Object, int, Lisp_Object *));
2078extern void run_hook_with_args_2 P_ ((Lisp_Object, Lisp_Object, Lisp_Object));
2f69f2ec
RS
2079EXFUN (Fand, UNEVALLED);
2080EXFUN (For, UNEVALLED);
2081EXFUN (Fif, UNEVALLED);
2082EXFUN (Fprogn, UNEVALLED);
2083EXFUN (Fprog1, UNEVALLED);
2084EXFUN (Fprog2, UNEVALLED);
2085EXFUN (Fsetq, UNEVALLED);
2086EXFUN (Fquote, UNEVALLED);
2087EXFUN (Fuser_variable_p, 1);
2088EXFUN (Finteractive_p, 0);
2089EXFUN (Fdefun, UNEVALLED);
2090EXFUN (Flet, UNEVALLED);
2091EXFUN (FletX, UNEVALLED);
2092EXFUN (Fwhile, UNEVALLED);
2093EXFUN (Fcatch, UNEVALLED);
2094EXFUN (Fthrow, 2);
2095EXFUN (Funwind_protect, UNEVALLED);
2096EXFUN (Fcondition_case, UNEVALLED);
2097EXFUN (Fsignal, 2);
2098EXFUN (Fautoload, 5);
2099EXFUN (Fcommandp, 1);
2100EXFUN (Feval, 1);
2101EXFUN (Fapply, MANY);
2102EXFUN (Ffuncall, MANY);
2103EXFUN (Fbacktrace, 0);
2104extern Lisp_Object apply1 P_ ((Lisp_Object, Lisp_Object));
2105extern Lisp_Object call0 P_ ((Lisp_Object));
2106extern Lisp_Object call1 P_ ((Lisp_Object, Lisp_Object));
2107extern Lisp_Object call2 P_ ((Lisp_Object, Lisp_Object, Lisp_Object));
2108extern Lisp_Object call3 P_ ((Lisp_Object, Lisp_Object, Lisp_Object, Lisp_Object));
2109extern Lisp_Object call4 P_ ((Lisp_Object, Lisp_Object, Lisp_Object, Lisp_Object, Lisp_Object));
2110extern Lisp_Object call5 P_ ((Lisp_Object, Lisp_Object, Lisp_Object, Lisp_Object, Lisp_Object, Lisp_Object));
2111extern Lisp_Object call6 P_ ((Lisp_Object, Lisp_Object, Lisp_Object, Lisp_Object, Lisp_Object, Lisp_Object, Lisp_Object));
2112EXFUN (Fdo_auto_save, 2);
2113extern Lisp_Object apply_lambda P_ ((Lisp_Object, Lisp_Object, int));
2114extern Lisp_Object internal_catch P_ ((Lisp_Object, Lisp_Object (*) (Lisp_Object), Lisp_Object));
2115extern Lisp_Object internal_condition_case P_ ((Lisp_Object (*) (void), Lisp_Object, Lisp_Object (*) (Lisp_Object)));
2116extern Lisp_Object internal_condition_case_1 P_ ((Lisp_Object (*) (Lisp_Object), Lisp_Object, Lisp_Object, Lisp_Object (*) (Lisp_Object)));
526a2be7
AS
2117extern void specbind P_ ((Lisp_Object, Lisp_Object));
2118extern void record_unwind_protect P_ ((Lisp_Object (*) (Lisp_Object), Lisp_Object));
2f69f2ec
RS
2119extern Lisp_Object unbind_to P_ ((int, Lisp_Object));
2120extern void error P_ ((/* char *, ... */));
526a2be7 2121extern void do_autoload P_ ((Lisp_Object, Lisp_Object));
2f69f2ec
RS
2122extern Lisp_Object un_autoload P_ ((Lisp_Object));
2123EXFUN (Ffetch_bytecode, 1);
46abf440
AS
2124extern void init_eval_once P_ ((void));
2125extern void init_eval P_ ((void));
2126extern void syms_of_eval P_ ((void));
3cfe6dfd
JB
2127
2128/* Defined in editfns.c */
986113df 2129EXFUN (Fcurrent_message, 0);
2f69f2ec
RS
2130EXFUN (Fgoto_char, 1);
2131EXFUN (Fpoint_min_marker, 0);
2132EXFUN (Fpoint_max_marker, 0);
2133EXFUN (Fpoint_min, 0);
2134EXFUN (Fpoint_max, 0);
2135EXFUN (Fpoint, 0);
2136EXFUN (Fpoint_marker, 0);
2137EXFUN (Fmark_marker, 0);
2138EXFUN (Fline_beginning_position, 1);
2139EXFUN (Fline_end_position, 1);
2140EXFUN (Ffollowing_char, 0);
2141EXFUN (Fprevious_char, 0);
2142EXFUN (Fchar_after, 1);
2143EXFUN (Finsert, MANY);
2144EXFUN (Finsert_and_inherit, MANY);
2145EXFUN (Finsert_before_markers, MANY);
2146EXFUN (Finsert_buffer_substring, 3);
2147EXFUN (Finsert_char, 3);
526a2be7 2148extern void insert1 P_ ((Lisp_Object));
2f69f2ec
RS
2149EXFUN (Feolp, 0);
2150EXFUN (Feobp, 0);
2151EXFUN (Fbolp, 0);
2152EXFUN (Fbobp, 0);
2153EXFUN (Fformat, MANY);
5010d3b8 2154EXFUN (Fmessage, MANY);
2f69f2ec
RS
2155extern Lisp_Object format1 P_ ((/* char *, ... */));
2156extern Lisp_Object make_buffer_string P_ ((int, int, int));
2157EXFUN (Fbuffer_substring, 2);
2158EXFUN (Fbuffer_string, 0);
2159extern Lisp_Object save_excursion_save P_ ((void));
2160extern Lisp_Object save_restriction_save P_ ((void));
2161extern Lisp_Object save_excursion_restore P_ ((Lisp_Object));
2162extern Lisp_Object save_restriction_restore P_ ((Lisp_Object));
2163EXFUN (Fchar_to_string, 1);
2164EXFUN (Fdelete_region, 2);
2165EXFUN (Fnarrow_to_region, 2);
2166EXFUN (Fwiden, 0);
2167EXFUN (Fuser_login_name, 1);
2168EXFUN (Fsystem_name, 0);
526a2be7 2169extern int clip_to_bounds P_ ((int, int, int));
b745ec7d
KH
2170extern Lisp_Object make_buffer_string P_ ((int, int, int));
2171extern Lisp_Object make_buffer_string_both P_ ((int, int, int, int, int));
46abf440
AS
2172extern void init_editfns P_ ((void));
2173extern void syms_of_editfns P_ ((void));
3cfe6dfd
JB
2174
2175/* defined in buffer.c */
526a2be7 2176extern void nsberror P_ ((Lisp_Object));
986113df 2177EXFUN (Fset_buffer_multibyte, 1);
2f69f2ec
RS
2178EXFUN (Foverlay_start, 1);
2179EXFUN (Foverlay_end, 1);
2180extern void adjust_overlays_for_insert P_ ((int, int));
2181extern void adjust_overlays_for_delete P_ ((int, int));
2182extern void fix_overlays_in_range P_ ((int, int));
526a2be7
AS
2183extern void report_overlay_modification P_ ((Lisp_Object, Lisp_Object, int,
2184 Lisp_Object, Lisp_Object, Lisp_Object));
2f69f2ec 2185extern int overlay_touches_p P_ ((int));
628300ba 2186extern Lisp_Object Vbuffer_alist, Vinhibit_read_only;
2f69f2ec
RS
2187EXFUN (Fget_buffer, 1);
2188EXFUN (Fget_buffer_create, 1);
2189EXFUN (Fset_buffer, 1);
4a2f9c6a 2190EXFUN (set_buffer_if_live, 1);
2f69f2ec
RS
2191EXFUN (Fbarf_if_buffer_read_only, 0);
2192EXFUN (Fcurrent_buffer, 0);
2193EXFUN (Fswitch_to_buffer, 2);
2194EXFUN (Fpop_to_buffer, 3);
dbe7f1ef 2195EXFUN (Fother_buffer, 3);
2f69f2ec
RS
2196EXFUN (Foverlay_get, 2);
2197EXFUN (Fbuffer_modified_p, 1);
2198EXFUN (Fset_buffer_modified_p, 1);
2199EXFUN (Fkill_buffer, 1);
2200EXFUN (Fkill_all_local_variables, 0);
2201EXFUN (Fbuffer_disable_undo, 1);
2202EXFUN (Fbuffer_enable_undo, 1);
2203EXFUN (Ferase_buffer, 0);
20280af7 2204extern Lisp_Object Qoverlayp;
2f69f2ec 2205extern Lisp_Object get_truename_buffer P_ ((Lisp_Object));
3cfe6dfd 2206extern struct buffer *all_buffers;
2f69f2ec 2207EXFUN (Fprevious_overlay_change, 1);
46abf440
AS
2208extern void init_buffer_once P_ ((void));
2209extern void init_buffer P_ ((void));
2210extern void syms_of_buffer P_ ((void));
2211extern void keys_of_buffer P_ ((void));
3cfe6dfd
JB
2212
2213/* defined in marker.c */
2214
2f69f2ec
RS
2215EXFUN (Fmarker_position, 1);
2216EXFUN (Fmarker_buffer, 1);
2217EXFUN (Fcopy_marker, 2);
2218EXFUN (Fset_marker, 3);
526a2be7 2219extern int marker_position P_ ((Lisp_Object));
ec5d8db7
AS
2220extern int marker_byte_position P_ ((Lisp_Object));
2221extern void clear_charpos_cache P_ ((struct buffer *));
2222extern int charpos_to_bytepos P_ ((int));
2223extern int buf_charpos_to_bytepos P_ ((struct buffer *, int));
2224extern int buf_bytepos_to_charpos P_ ((struct buffer *, int));
526a2be7
AS
2225extern void unchain_marker P_ ((Lisp_Object));
2226extern Lisp_Object set_marker_restricted P_ ((Lisp_Object, Lisp_Object, Lisp_Object));
4ed24bf3
RS
2227extern Lisp_Object set_marker_both P_ ((Lisp_Object, Lisp_Object, int, int));
2228extern Lisp_Object set_marker_restricted_both P_ ((Lisp_Object, Lisp_Object,
2229 int, int));
46abf440 2230extern void syms_of_marker P_ ((void));
3cfe6dfd
JB
2231
2232/* Defined in fileio.c */
2233
2234extern Lisp_Object Qfile_error;
2f69f2ec
RS
2235EXFUN (Ffind_file_name_handler, 2);
2236EXFUN (Ffile_name_as_directory, 1);
2237EXFUN (Fexpand_file_name, 2);
2238EXFUN (Ffile_name_nondirectory, 1);
2239EXFUN (Fsubstitute_in_file_name, 1);
2240EXFUN (Ffile_symlink_p, 1);
2241EXFUN (Fverify_visited_file_modtime, 1);
2242EXFUN (Ffile_exists_p, 1);
2243EXFUN (Ffile_name_absolute_p, 1);
2244EXFUN (Fdirectory_file_name, 1);
2245EXFUN (Ffile_name_directory, 1);
2246extern Lisp_Object expand_and_dir_to_file P_ ((Lisp_Object, Lisp_Object));
2247EXFUN (Ffile_accessible_directory_p, 1);
2248EXFUN (Funhandled_file_name_directory, 1);
2249EXFUN (Ffile_directory_p, 1);
b4e187e2 2250EXFUN (Fwrite_region, 7);
2f69f2ec
RS
2251EXFUN (Ffile_readable_p, 1);
2252EXFUN (Ffile_executable_p, 1);
2253EXFUN (Fread_file_name, 5);
526a2be7
AS
2254extern void report_file_error P_ ((char *, Lisp_Object));
2255extern int internal_delete_file P_ ((Lisp_Object));
46abf440 2256extern void syms_of_fileio P_ ((void));
3cfe6dfd
JB
2257
2258/* Defined in abbrev.c */
2259
2260extern Lisp_Object Vfundamental_mode_abbrev_table;
46abf440 2261extern void syms_of_abbrev P_ ((void));
3cfe6dfd
JB
2262
2263/* defined in search.c */
2f69f2ec
RS
2264EXFUN (Fstring_match, 3);
2265extern void restore_match_data P_ ((void));
2266EXFUN (Fmatch_data, 2);
f405b38d 2267EXFUN (Fset_match_data, 1);
2f69f2ec
RS
2268EXFUN (Fmatch_beginning, 1);
2269EXFUN (Fmatch_end, 1);
526a2be7
AS
2270extern int fast_string_match P_ ((Lisp_Object, Lisp_Object));
2271extern int fast_c_string_match_ignore_case P_ ((Lisp_Object, char *));
2272extern int scan_buffer P_ ((int, int, int, int, int *, int));
4ed24bf3 2273extern int scan_newline P_ ((int, int, int, int, int, int));
526a2be7
AS
2274extern int find_next_newline P_ ((int, int));
2275extern int find_next_newline_no_quit P_ ((int, int));
2276extern int find_before_next_newline P_ ((int, int, int));
46abf440 2277extern void syms_of_search P_ ((void));
3cfe6dfd
JB
2278
2279/* defined in minibuf.c */
2280
2281extern Lisp_Object last_minibuf_string;
526a2be7 2282extern void choose_minibuf_frame P_ ((void));
ec5d8db7 2283extern int scmp P_ ((unsigned char *, unsigned char *, int));
5593f7e3
KH
2284EXFUN (Fcompleting_read, 8);
2285EXFUN (Fread_from_minibuffer, 7);
2f69f2ec
RS
2286EXFUN (Fread_variable, 2);
2287EXFUN (Fread_buffer, 3);
2288EXFUN (Fread_minibuffer, 2);
2289EXFUN (Feval_minibuffer, 2);
5593f7e3
KH
2290EXFUN (Fread_string, 5);
2291EXFUN (Fread_no_blanks_input, 3);
2f69f2ec 2292extern Lisp_Object get_minibuffer P_ ((int));
526a2be7 2293extern void temp_echo_area_glyphs P_ ((char *));
46abf440
AS
2294extern void init_minibuf_once P_ ((void));
2295extern void syms_of_minibuf P_ ((void));
2296extern void keys_of_minibuf P_ ((void));
3cfe6dfd
JB
2297
2298/* Defined in callint.c */
2299
de7885bb 2300extern Lisp_Object Qminus, Qplus, Vcurrent_prefix_arg;
3cfe6dfd 2301extern Lisp_Object Vcommand_history;
7fd61057 2302extern Lisp_Object Qcall_interactively, Qmouse_leave_buffer_hook;
2f69f2ec
RS
2303EXFUN (Fcall_interactively, 3);
2304EXFUN (Fprefix_numeric_value, 1);
46abf440 2305extern void syms_of_callint P_ ((void));
3cfe6dfd
JB
2306
2307/* defined in casefiddle.c */
2308
2f69f2ec
RS
2309EXFUN (Fdowncase, 1);
2310EXFUN (Fupcase, 1);
2311EXFUN (Fcapitalize, 1);
2312EXFUN (Fupcase_region, 2);
2313EXFUN (Fupcase_initials, 1);
2314EXFUN (Fupcase_initials_region, 2);
46abf440
AS
2315extern void syms_of_casefiddle P_ ((void));
2316extern void keys_of_casefiddle P_ ((void));
3cfe6dfd 2317
1747fb16
RS
2318/* defined in casetab.c */
2319
2f69f2ec
RS
2320EXFUN (Fset_case_table, 1);
2321EXFUN (Fset_standard_case_table, 1);
46abf440
AS
2322extern void init_casetab_once P_ ((void));
2323extern void syms_of_casetab P_ ((void));
1747fb16 2324
3cfe6dfd
JB
2325/* defined in keyboard.c */
2326
2327extern Lisp_Object Qdisabled;
4b657f72 2328extern Lisp_Object Vtty_erase_char, Vhelp_form, Vtop_level;
2f69f2ec
RS
2329EXFUN (Fdiscard_input, 0);
2330EXFUN (Frecursive_edit, 0);
2331EXFUN (Fcommand_execute, 4);
2332EXFUN (Finput_pending_p, 0);
2333extern Lisp_Object menu_bar_items P_ ((Lisp_Object));
5010d3b8 2334extern Lisp_Object toolbar_items P_ ((Lisp_Object, int *));
f498e3b2 2335extern Lisp_Object Qvertical_scroll_bar;
084cd810 2336extern void discard_mouse_events ();
2f69f2ec 2337EXFUN (Fevent_convert_list, 1);
e271fdb3 2338EXFUN (Fread_key_sequence, 5);
526a2be7
AS
2339EXFUN (Fset_input_mode, 4);
2340extern int detect_input_pending P_ ((void));
2341extern int detect_input_pending_run_timers P_ ((int));
2342extern void safe_run_hooks P_ ((Lisp_Object));
2343extern void cmd_error_internal P_ ((Lisp_Object, char *));
2344extern Lisp_Object command_loop_1 P_ ((void));
2345extern Lisp_Object recursive_edit_1 P_ ((void));
2346extern void record_auto_save P_ ((void));
46abf440
AS
2347extern void init_keyboard P_ ((void));
2348extern void syms_of_keyboard P_ ((void));
2349extern void keys_of_keyboard P_ ((void));
3cfe6dfd
JB
2350
2351/* defined in keymap.c */
2352
c451d7b1 2353extern Lisp_Object Qkeymap, Qmenu_bar;
3cfe6dfd 2354extern Lisp_Object current_global_map;
526a2be7
AS
2355EXFUN (Fmake_sparse_keymap, 1);
2356EXFUN (Fcopy_keymap, 1);
2f69f2ec 2357EXFUN (Fdefine_key, 3);
526a2be7 2358EXFUN (Flookup_key, 3);
2f69f2ec
RS
2359EXFUN (Fkey_binding, 2);
2360EXFUN (Fkey_description, 1);
2361EXFUN (Fsingle_key_description, 1);
2362EXFUN (Fwhere_is_internal, 4);
2363extern Lisp_Object access_keymap P_ ((Lisp_Object, Lisp_Object, int, int));
2364extern Lisp_Object store_in_keymap P_ ((Lisp_Object, Lisp_Object, Lisp_Object));
2365extern Lisp_Object get_keyelt P_ ((Lisp_Object, int));
2366extern Lisp_Object get_keymap P_ ((Lisp_Object));
2367extern Lisp_Object get_keymap_1 P_ ((Lisp_Object, int, int));
526a2be7
AS
2368extern void describe_vector P_ ((Lisp_Object, Lisp_Object,
2369 void (*) (Lisp_Object), int,
2370 Lisp_Object, Lisp_Object, int *, int));
2371extern void describe_map_tree P_ ((Lisp_Object, int, Lisp_Object, Lisp_Object,
2372 char *, int, int, int));
2373extern int current_minor_maps P_ ((Lisp_Object **, Lisp_Object **));
2374extern void initial_define_key P_ ((Lisp_Object, int, char *));
2375extern void initial_define_lispy_key P_ ((Lisp_Object, char *, char *));
2376extern void fix_submap_inheritance P_ ((Lisp_Object, Lisp_Object, Lisp_Object));
46abf440
AS
2377extern void syms_of_keymap P_ ((void));
2378extern void keys_of_keymap P_ ((void));
3cfe6dfd
JB
2379
2380/* defined in indent.c */
2f69f2ec
RS
2381EXFUN (Fvertical_motion, 2);
2382EXFUN (Findent_to, 2);
2383EXFUN (Fcurrent_column, 0);
2384EXFUN (Fmove_to_column, 2);
526a2be7
AS
2385extern int current_column P_ ((void));
2386extern void invalidate_current_column P_ ((void));
4ed24bf3 2387extern int indented_beyond_p P_ ((int, int, int));
46abf440 2388extern void syms_of_indent P_ ((void));
3cfe6dfd
JB
2389
2390/* defined in window.c */
afd0d237 2391extern Lisp_Object Qwindowp, Qwindow_live_p;
5010d3b8 2392EXFUN (Fwindow_end, 2);
2f69f2ec 2393EXFUN (Fselected_window, 0);
526a2be7
AS
2394EXFUN (Fnext_window, 3);
2395EXFUN (Fdelete_window, 1);
2396EXFUN (Fselect_window, 1);
2397EXFUN (Fset_window_buffer, 2);
2f69f2ec
RS
2398EXFUN (Fget_buffer_window, 2);
2399EXFUN (Fsave_window_excursion, UNEVALLED);
526a2be7 2400EXFUN (Fsplit_window, 3);
2f69f2ec
RS
2401EXFUN (Fset_window_configuration, 1);
2402EXFUN (Fcurrent_window_configuration, 1);
b4e187e2 2403extern int compare_window_configurations P_ ((Lisp_Object, Lisp_Object, int));
2f69f2ec
RS
2404EXFUN (Fcoordinates_in_window_p, 2);
2405EXFUN (Fwindow_at, 3);
2406EXFUN (Fpos_visible_in_window_p, 2);
526a2be7
AS
2407extern int window_internal_height P_ ((struct window *));
2408extern int window_internal_width P_ ((struct window *));
2f69f2ec
RS
2409EXFUN (Frecenter, 1);
2410EXFUN (Fscroll_other_window, 1);
2411EXFUN (Fset_window_start, 3);
2412extern void temp_output_buffer_show P_ ((Lisp_Object));
526a2be7 2413extern void replace_buffer_in_all_windows P_ ((Lisp_Object));
46abf440
AS
2414extern void init_window_once P_ ((void));
2415extern void syms_of_window P_ ((void));
2416extern void keys_of_window P_ ((void));
3cfe6dfd 2417
ff11dfa1 2418/* defined in frame.c */
362fb47a 2419extern Lisp_Object Qvisible;
526a2be7 2420extern void store_frame_param P_ ((struct frame *, Lisp_Object, Lisp_Object));
2f69f2ec
RS
2421extern void store_in_alist P_ ((Lisp_Object *, Lisp_Object, Lisp_Object));
2422extern Lisp_Object do_switch_frame P_ ((Lisp_Object, Lisp_Object, int));
526a2be7 2423extern Lisp_Object get_frame_param P_ ((struct frame *, Lisp_Object));
dbe7f1ef 2424extern Lisp_Object frame_buffer_predicate P_ ((Lisp_Object));
2f69f2ec
RS
2425EXFUN (Fframep, 1);
2426EXFUN (Fselect_frame, 2);
2427EXFUN (Fselected_frame, 0);
2428EXFUN (Fwindow_frame, 1);
2429EXFUN (Fframe_root_window, 1);
2430EXFUN (Fframe_first_window, 1);
2431EXFUN (Fframe_selected_window, 1);
2432EXFUN (Fframe_list, 0);
2433EXFUN (Fnext_frame, 2);
2434EXFUN (Fdelete_frame, 2);
2435EXFUN (Fset_mouse_position, 3);
2436EXFUN (Fmake_frame_visible, 1);
2437EXFUN (Fmake_frame_invisible, 2);
2438EXFUN (Ficonify_frame, 1);
2439EXFUN (Fframe_visible_p, 1);
2440EXFUN (Fvisible_frame_list, 0);
2441EXFUN (Fframe_parameters, 1);
2442EXFUN (Fmodify_frame_parameters, 2);
2443EXFUN (Fset_frame_height, 3);
2444EXFUN (Fset_frame_width, 3);
2445EXFUN (Fset_frame_size, 3);
2446EXFUN (Fset_frame_position, 3);
2447EXFUN (Fraise_frame, 1);
2448EXFUN (Fredirect_frame_focus, 2);
526a2be7 2449EXFUN (Fset_frame_selected_window, 2);
dbe7f1ef 2450extern Lisp_Object frame_buffer_list P_ ((Lisp_Object));
526a2be7 2451extern void frames_discard_buffer P_ ((Lisp_Object));
dbe7f1ef 2452extern void set_frame_buffer_list P_ ((Lisp_Object, Lisp_Object));
526a2be7 2453extern void frames_bury_buffer P_ ((Lisp_Object));
46abf440
AS
2454extern void syms_of_frame P_ ((void));
2455extern void keys_of_frame P_ ((void));
3cfe6dfd
JB
2456
2457/* defined in emacs.c */
2f69f2ec 2458extern Lisp_Object decode_env_path P_ ((char *, char *));
3530d534 2459extern Lisp_Object Vinvocation_name, Vinvocation_directory;
e6faba7f 2460extern Lisp_Object Vinstallation_directory;
2f69f2ec
RS
2461EXFUN (Fkill_emacs, 1);
2462void shut_down_emacs P_ ((int, int, Lisp_Object));
3cfe6dfd
JB
2463/* Nonzero means don't do interactive redisplay and don't change tty modes */
2464extern int noninteractive;
2465/* Nonzero means don't do use window-system-specific display code */
2466extern int inhibit_window_system;
99a3d506 2467/* Nonzero means that a filter or a sentinel is running. */
7074fde6 2468extern int running_asynch_code;
3cfe6dfd
JB
2469
2470/* defined in process.c */
2f69f2ec
RS
2471EXFUN (Fget_process, 1);
2472EXFUN (Fget_buffer_process, 1);
2473EXFUN (Fprocessp, 1);
2474EXFUN (Fprocess_status, 1);
2475EXFUN (Fkill_process, 2);
2476EXFUN (Fprocess_send_eof, 1);
2477EXFUN (Fwaiting_for_user_input_p, 0);
6efad63b 2478extern Lisp_Object Qprocessp;
526a2be7
AS
2479extern void kill_buffer_processes P_ ((Lisp_Object));
2480extern int wait_reading_process_input P_ ((int, int, Lisp_Object, int));
2481extern void deactivate_process P_ ((Lisp_Object));
2482extern void add_keyboard_wait_descriptor P_ ((int));
2483extern void delete_keyboard_wait_descriptor P_ ((int));
2484extern void close_process_descs P_ ((void));
2485extern void status_notify P_ ((void));
2486extern int read_process_output P_ ((Lisp_Object, int));
46abf440
AS
2487extern void init_process P_ ((void));
2488extern void syms_of_process P_ ((void));
3cfe6dfd
JB
2489
2490/* defined in callproc.c */
9453ea7b 2491extern Lisp_Object Vexec_path, Vexec_directory, Vdata_directory;
c65be0e1 2492extern Lisp_Object Vdoc_directory;
526a2be7 2493extern int child_setup P_ ((int, int, int, char **, int, Lisp_Object));
46abf440
AS
2494extern void init_callproc_1 P_ ((void));
2495extern void init_callproc P_ ((void));
2496extern void set_process_environment P_ ((void));
2497extern void syms_of_callproc P_ ((void));
3cfe6dfd 2498
3cfe6dfd
JB
2499/* defined in doc.c */
2500extern Lisp_Object Vdoc_file_name;
2f69f2ec
RS
2501EXFUN (Fsubstitute_command_keys, 1);
2502EXFUN (Fdocumentation, 2);
2503EXFUN (Fdocumentation_property, 3);
2504extern Lisp_Object read_doc_string P_ ((Lisp_Object));
3dd00fc3 2505extern Lisp_Object get_doc_string P_ ((Lisp_Object, int, int));
46abf440 2506extern void syms_of_doc P_ ((void));
3cfe6dfd
JB
2507
2508/* defined in bytecode.c */
2509extern Lisp_Object Qbytecode;
2f69f2ec 2510EXFUN (Fbyte_code, 3);
46abf440 2511extern void syms_of_bytecode P_ ((void));
3cfe6dfd
JB
2512
2513/* defined in macros.c */
2514extern Lisp_Object Qexecute_kbd_macro;
2f69f2ec 2515EXFUN (Fexecute_kbd_macro, 2);
46abf440
AS
2516extern void init_macros P_ ((void));
2517extern void syms_of_macros P_ ((void));
2518extern void keys_of_macros P_ ((void));
3cfe6dfd 2519
d20c2151 2520/* defined in undo.c */
a387611b 2521extern Lisp_Object Qinhibit_read_only;
2f69f2ec
RS
2522EXFUN (Fundo_boundary, 0);
2523extern Lisp_Object truncate_undo_list P_ ((Lisp_Object, int, int));
526a2be7
AS
2524extern void record_marker_adjustment P_ ((Lisp_Object, int));
2525extern void record_insert P_ ((int, int));
443de1d7 2526extern void record_delete P_ ((int, Lisp_Object));
526a2be7
AS
2527extern void record_first_change P_ ((void));
2528extern void record_change P_ ((int, int));
2529extern void record_property_change P_ ((int, int, Lisp_Object, Lisp_Object,
2530 Lisp_Object));
46abf440 2531extern void syms_of_undo P_ ((void));
d20c2151 2532
8537f1cb 2533/* defined in textprop.c */
c2d8811c 2534extern Lisp_Object Qmodification_hooks;
23bc39b5 2535extern Lisp_Object Qrear_nonsticky, Qfont;
c2d8811c 2536extern Lisp_Object Qinsert_in_front_hooks, Qinsert_behind_hooks;
2f69f2ec
RS
2537EXFUN (Fnext_property_change, 3);
2538EXFUN (Fnext_single_property_change, 4);
2539EXFUN (Fprevious_single_property_change, 4);
2540EXFUN (Fget_text_property, 3);
2541EXFUN (Fput_text_property, 5);
2542EXFUN (Fset_text_properties, 4);
2543EXFUN (Ftext_property_not_all, 5);
2544EXFUN (Fprevious_char_property_change, 2);
2545EXFUN (Fnext_char_property_change, 2);
526a2be7 2546extern void report_interval_modification P_ ((Lisp_Object, Lisp_Object));
46abf440 2547extern void syms_of_textprop P_ ((void));
8537f1cb 2548
40131ef5 2549/* defined in intervals.c */
2f69f2ec 2550extern Lisp_Object get_local_map P_ ((int, struct buffer *));
40131ef5
KH
2551
2552/* defined in xmenu.c */
2f69f2ec
RS
2553EXFUN (Fx_popup_menu, 2);
2554EXFUN (Fx_popup_dialog, 2);
46abf440 2555extern void syms_of_xmenu P_ ((void));
526a2be7
AS
2556
2557/* defined in sysdep.c */
2558extern void init_sigio P_ ((int));
2559extern void request_sigio P_ ((void));
2560extern void unrequest_sigio P_ ((void));
2561extern void reset_sys_modes P_ ((void));
2562extern void sys_subshell P_ ((void));
2563extern void sys_suspend P_ ((void));
2564extern void discard_tty_input P_ ((void));
2565extern void init_sys_modes P_ ((void));
2566extern void reset_sys_modes P_ ((void));
2567extern void get_frame_size P_ ((int *, int *));
2568extern void wait_for_termination P_ ((int));
2569extern void flush_pending_output P_ ((int));
2570extern void child_setup_tty P_ ((int));
2571extern void setup_pty P_ ((int));
2572extern int set_window_size P_ ((int, int, int));
2573extern void create_process P_ ((Lisp_Object, char **, Lisp_Object));
2574extern int tabs_safe_p P_ ((void));
2575extern void init_baud_rate P_ ((void));
2576
2577/* defined in filelock.c */
2578EXFUN (Funlock_buffer, 0);
9ae8d912 2579EXFUN (Ffile_locked_p, 1);
526a2be7
AS
2580extern void unlock_all_files P_ ((void));
2581extern void lock_file P_ ((Lisp_Object));
2582extern void unlock_file P_ ((Lisp_Object));
2583extern void unlock_buffer P_ ((struct buffer *));
46abf440
AS
2584extern void syms_of_filelock P_ ((void));
2585
2586/* Defined in category.c */
2587extern void init_category_once P_ ((void));
2588extern void syms_of_category P_ ((void));
2589
2590/* Defined in ccl.c */
2591extern void syms_of_ccl P_ ((void));
2592
2593/* Defined in dired.c */
2594extern void syms_of_dired P_ ((void));
2595
2596/* Defined in mocklisp.c */
2597extern void syms_of_mocklisp P_ ((void));
2598
2599/* Defined in term.c */
2600extern void syms_of_term P_ ((void));
2601
2602#ifdef HAVE_X_WINDOWS
2603/* Defined in fontset.c */
2604extern void syms_of_fontset P_ ((void));
5010d3b8 2605EXFUN (Fset_fontset_font, 4);
46abf440
AS
2606#endif
2607
2608/* Defined in xfaces.c */
2609extern void syms_of_xfaces P_ ((void));
2610
2611#ifdef HAVE_X_WINDOWS
2612/* Defined in xfns.c */
2613extern void syms_of_xfns P_ ((void));
2614#endif
2615
2616/* Defined in xselect.c */
2617extern void syms_of_xselect P_ ((void));
2618
2619/* Defined in xterm.c */
2620extern void syms_of_xterm P_ ((void));
40131ef5 2621\f
3cfe6dfd
JB
2622/* Nonzero means Emacs has already been initialized.
2623 Used during startup to detect startup of dumped Emacs. */
2624extern int initialized;
2625
2626extern int immediate_quit; /* Nonzero means ^G can quit instantly */
2627
339747e4 2628extern char *getenv (), *ctime (), *getwd ();
3cfe6dfd 2629extern long *xmalloc (), *xrealloc ();
9ac0d9e0 2630extern void xfree ();
3cfe6dfd 2631
526a2be7 2632extern char *egetenv P_ ((char *));
e98227af 2633
5d6be39f 2634/* Set up the name of the machine we're running on. */
526a2be7 2635extern void init_system_name P_ ((void));
881a5a80
RS
2636
2637/* Some systems (e.g., NT) use a different path separator than Unix,
2638 in addition to a device separator. Default the path separator
2639 to '/', and don't test for a device separator in IS_ANY_SEP. */
2640
e0c07012
RS
2641#ifdef WINDOWSNT
2642extern Lisp_Object Vdirectory_sep_char;
2643#endif
2644
881a5a80
RS
2645#ifndef DIRECTORY_SEP
2646#define DIRECTORY_SEP '/'
2647#endif
881a5a80
RS
2648#ifndef IS_DIRECTORY_SEP
2649#define IS_DIRECTORY_SEP(_c_) ((_c_) == DIRECTORY_SEP)
2650#endif
2651#ifndef IS_DEVICE_SEP
2652#ifndef DEVICE_SEP
2653#define IS_DEVICE_SEP(_c_) 0
2654#else
2655#define IS_DEVICE_SEP(_c_) ((_c_) == DEVICE_SEP)
2656#endif
2657#endif
2658#ifndef IS_ANY_SEP
2659#define IS_ANY_SEP(_c_) (IS_DIRECTORY_SEP (_c_))
2660#endif
51bd4610
KH
2661
2662#ifdef SWITCH_ENUM_BUG
2663#define SWITCH_ENUM_CAST(x) ((int)(x))
2664#else
2665#define SWITCH_ENUM_CAST(x) (x)
2666#endif