Contents of release-21-2 at 1999-07-05-18.
[chise/xemacs-chise.git.1] / src / lisp.h
1 /* Fundamental definitions for XEmacs Lisp interpreter.
2    Copyright (C) 1985-1987, 1992-1995 Free Software Foundation, Inc.
3    Copyright (C) 1993-1996 Richard Mlynarik.
4    Copyright (C) 1995, 1996 Ben Wing.
5
6 This file is part of XEmacs.
7
8 XEmacs is free software; you can redistribute it and/or modify it
9 under the terms of the GNU General Public License as published by the
10 Free Software Foundation; either version 2, or (at your option) any
11 later version.
12
13 XEmacs is distributed in the hope that it will be useful, but WITHOUT
14 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
15 FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
16 for more details.
17
18 You should have received a copy of the GNU General Public License
19 along with XEmacs; see the file COPYING.  If not, write to
20 the Free Software Foundation, Inc., 59 Temple Place - Suite 330,
21 Boston, MA 02111-1307, USA.  */
22
23 /* Synched up with: FSF 19.30. */
24
25 #ifndef _XEMACS_LISP_H_
26 #define _XEMACS_LISP_H_
27
28 /************************************************************************/
29 /*                        general definitions                           */
30 /************************************************************************/
31
32 /* We include the following generally useful header files so that you
33    don't have to worry about prototypes when using the standard C
34    library functions and macros.  These files shouldn't be excessively
35    large so they shouldn't cause that much of a slowdown. */
36
37 #include <stdlib.h>
38 #include <string.h>             /* primarily for memcpy, etc. */
39 #include <stdio.h>              /* NULL, etc. */
40 #include <ctype.h>
41 #include <stdarg.h>
42 #include <stddef.h>             /* offsetof */
43
44 #ifdef __lucid
45 # include <sysent.h>
46 #endif
47
48 /* ---- Dynamic arrays ---- */
49
50 #define Dynarr_declare(type)    \
51   type *base;                   \
52   int elsize;                   \
53   int cur;                      \
54   int largest;                  \
55   int max
56
57 typedef struct dynarr
58 {
59   Dynarr_declare (void);
60 } Dynarr;
61
62 void *Dynarr_newf (int elsize);
63 void Dynarr_resize (void *dy, int size);
64 void Dynarr_insert_many (void *d, CONST void *el, int len, int start);
65 void Dynarr_delete_many (void *d, int start, int len);
66 void Dynarr_free (void *d);
67
68 #define Dynarr_new(type) ((type##_dynarr *) Dynarr_newf (sizeof(type)))
69 #define Dynarr_at(d, pos) ((d)->base[pos])
70 #define Dynarr_atp(d, pos) (&Dynarr_at (d, pos))
71 #define Dynarr_length(d) ((d)->cur)
72 #define Dynarr_largest(d) ((d)->largest)
73 #define Dynarr_reset(d) ((d)->cur = 0)
74 #define Dynarr_add_many(d, el, len) Dynarr_insert_many (d, el, len, (d)->cur)
75 #define Dynarr_insert_many_at_start(d, el, len) \
76   Dynarr_insert_many (d, el, len, 0)
77 #define Dynarr_add_literal_string(d, s) Dynarr_add_many (d, s, sizeof(s) - 1)
78 #define Dynarr_add_lisp_string(d, s) do {               \
79   struct Lisp_String *dyna_ls_s = XSTRING (s);          \
80   Dynarr_add_many (d, (char *) string_data (dyna_ls_s), \
81                    string_length (dyna_ls_s));          \
82 } while (0)
83
84 #define Dynarr_add(d, el) (                                             \
85   (d)->cur >= (d)->max ? Dynarr_resize ((d), (d)->cur+1) : (void) 0,    \
86   ((d)->base)[(d)->cur++] = (el),                                       \
87   (d)->cur > (d)->largest ? (d)->largest = (d)->cur : (int) 0)
88
89 /* The following defines will get you into real trouble if you aren't
90    careful.  But they can save a lot of execution time when used wisely. */
91 #define Dynarr_increment(d) ((d)->cur++)
92 #define Dynarr_set_size(d, n) ((d)->cur = n)
93
94 /* Minimum size in elements for dynamic array when resized; default is 32 */
95 extern int Dynarr_min_size;
96
97 #ifdef MEMORY_USAGE_STATS
98 struct overhead_stats;
99 size_t Dynarr_memory_usage (void *d, struct overhead_stats *stats);
100 #endif
101
102 #include "symsinit.h"           /* compiler warning suppression */
103
104 /* Also define min() and max(). (Some compilers put them in strange
105    places that won't be referenced by the above include files, such
106    as 'macros.h' under Solaris.) */
107
108 #ifndef min
109 #define min(a,b) (((a) <= (b)) ? (a) : (b))
110 #endif
111 #ifndef max
112 #define max(a,b) (((a) > (b)) ? (a) : (b))
113 #endif
114
115 /* Memory allocation */
116 void malloc_warning (CONST char *);
117 void *xmalloc (size_t size);
118 void *xmalloc_and_zero (size_t size);
119 void *xrealloc (void *, size_t size);
120 char *xstrdup (CONST char *);
121 /* generally useful */
122 #define countof(x) ((int) (sizeof(x)/sizeof(x[0])))
123 #define slot_offset(type, slot_name) \
124   ((unsigned) (((char *) (&(((type *)0)->slot_name))) - ((char *)0)))
125 #define xnew(type) ((type *) xmalloc (sizeof (type)))
126 #define xnew_array(type, len) ((type *) xmalloc ((len) * sizeof (type)))
127 #define xnew_and_zero(type) ((type *) xmalloc_and_zero (sizeof (type)))
128 #define xzero(lvalue) ((void) memset (&(lvalue), 0, sizeof (lvalue)))
129 #define xnew_array_and_zero(type, len) ((type *) xmalloc_and_zero ((len) * sizeof (type)))
130 #define XREALLOC_ARRAY(ptr, type, len) ((void) (ptr = (type *) xrealloc (ptr, (len) * sizeof (type))))
131 #define alloca_array(type, len) ((type *) alloca ((len) * sizeof (type)))
132
133 /* also generally useful if you want to avoid arbitrary size limits
134    but don't need a full dynamic array.  Assumes that BASEVAR points
135    to a malloced array of TYPE objects (or possibly a NULL pointer,
136    if SIZEVAR is 0), with the total size stored in SIZEVAR.  This
137    macro will realloc BASEVAR as necessary so that it can hold at
138    least NEEDED_SIZE objects.  The reallocing is done by doubling,
139    which ensures constant amortized time per element. */
140 #define DO_REALLOC(basevar, sizevar, needed_size, type) do      \
141 {                                                               \
142   /* Avoid side-effectualness. */                               \
143   /* Dammit! Macros suffer from dynamic scope! */               \
144   /* We demand inline functions! */                             \
145   size_t do_realloc_needed_size = (needed_size);                \
146   size_t do_realloc_newsize = 0;                                \
147   while ((sizevar) < (do_realloc_needed_size)) {                \
148     do_realloc_newsize = 2*(sizevar);                           \
149     if (do_realloc_newsize < 32)                                \
150       do_realloc_newsize = 32;                                  \
151     (sizevar) = do_realloc_newsize;                             \
152   }                                                             \
153   if (do_realloc_newsize)                                       \
154     XREALLOC_ARRAY (basevar, type, do_realloc_newsize);         \
155 } while (0)
156
157 #ifdef ERROR_CHECK_MALLOC
158 void xfree_1 (void *);
159 #define xfree(lvalue) do                        \
160 {                                               \
161   void **xfree_ptr = (void **) &(lvalue);       \
162   xfree_1 (*xfree_ptr);                         \
163   *xfree_ptr = (void *) 0xDEADBEEF;             \
164 } while (0)
165 #else
166 void xfree (void *);
167 #define xfree_1 xfree
168 #endif /* ERROR_CHECK_MALLOC */
169
170 #ifndef PRINTF_ARGS
171 # if defined (__GNUC__) && (__GNUC__ >= 2)
172 #  define PRINTF_ARGS(string_index,first_to_check) \
173           __attribute__ ((format (printf, string_index, first_to_check)))
174 # else
175 #  define PRINTF_ARGS(string_index,first_to_check)
176 # endif /* GNUC */
177 #endif
178
179 #ifndef DOESNT_RETURN
180 # if defined __GNUC__
181 #  if ((__GNUC__ > 2) || (__GNUC__ == 2) && (__GNUC_MINOR__ >= 5))
182 #   define DOESNT_RETURN void volatile
183 #   define DECLARE_DOESNT_RETURN(decl) \
184            extern void volatile decl __attribute__ ((noreturn))
185 #   define DECLARE_DOESNT_RETURN_GCC_ATTRIBUTE_SYNTAX_SUCKS(decl,str,idx) \
186      /* Should be able to state multiple independent __attribute__s, but  \
187         the losing syntax doesn't work that way, and screws losing cpp */ \
188            extern void volatile decl \
189                   __attribute__ ((noreturn, format (printf, str, idx)))
190 #  else
191 #   define DOESNT_RETURN void volatile
192 #   define DECLARE_DOESNT_RETURN(decl) extern void volatile decl
193 #   define DECLARE_DOESNT_RETURN_GCC_ATTRIBUTE_SYNTAX_SUCKS(decl,str,idx) \
194            extern void volatile decl PRINTF_ARGS(str,idx)
195 #  endif /* GNUC 2.5 */
196 # else
197 #  define DOESNT_RETURN void
198 #  define DECLARE_DOESNT_RETURN(decl) extern void decl
199 #  define DECLARE_DOESNT_RETURN_GCC_ATTRIBUTE_SYNTAX_SUCKS(decl,str,idx) \
200           extern void decl PRINTF_ARGS(str,idx)
201 # endif /* GNUC */
202 #endif
203
204 #ifndef ALIGNOF
205 # if defined (__GNUC__) && (__GNUC__ >= 2)
206 #  define ALIGNOF(x) __alignof (x)
207 # else
208 #  define ALIGNOF(x) sizeof (x)
209 # endif
210 #endif
211
212 #define ALIGN_SIZE(len, unit) \
213   ((((len) + (unit) - 1) / (unit)) * (unit))
214
215 /* #### Yuck, this is kind of evil */
216 #define ALIGN_PTR(ptr, unit) \
217   ((void *) ALIGN_SIZE ((long) (ptr), unit))
218
219 #ifndef DO_NOTHING
220 #define DO_NOTHING do {} while (0)
221 #endif
222
223 #ifndef DECLARE_NOTHING
224 #define DECLARE_NOTHING struct nosuchstruct
225 #endif
226
227 /* We define assert iff USE_ASSERTIONS or DEBUG_XEMACS is defined.
228    Otherwise we define it to be empty.  Quantify has shown that the
229    time the assert checks take is measurable so let's not include them
230    in production binaries. */
231
232 #ifdef USE_ASSERTIONS
233 /* Highly dubious kludge */
234 /*   (thanks, Jamie, I feel better now -- ben) */
235 DECLARE_DOESNT_RETURN (assert_failed (CONST char *, int, CONST char *));
236 # define abort() (assert_failed (__FILE__, __LINE__, "abort()"))
237 # define assert(x) ((x) ? (void) 0 : assert_failed (__FILE__, __LINE__, #x))
238 #else
239 # ifdef DEBUG_XEMACS
240 #  define assert(x) ((x) ? (void) 0 : (void) abort ())
241 # else
242 #  define assert(x)
243 # endif
244 #endif
245
246 /*#ifdef DEBUG_XEMACS*/
247 #define REGISTER
248 #define register
249 /*#else*/
250 /*#define REGISTER register*/
251 /*#endif*/
252
253 \f
254 /************************************************************************/
255 /*                                typedefs                              */
256 /************************************************************************/
257
258 /* We put typedefs here so that prototype declarations don't choke.
259    Note that we don't actually declare the structures here (except
260    maybe for simple structures like Dynarrs); that keeps them private
261    to the routines that actually use them. */
262
263 /* The data representing the text in a buffer is logically a set
264    of Bufbytes, declared as follows. */
265
266 typedef unsigned char Bufbyte;
267
268 /* The data representing a string in "external" format (simple
269    binary format) is logically a set of Extbytes, declared as follows. */
270
271 typedef unsigned char Extbyte;
272
273 /* To the user, a buffer is made up of characters, declared as follows.
274    In the non-Mule world, characters and Bufbytes are equivalent.
275    In the Mule world, a character requires (typically) 1 to 4
276    Bufbytes for its representation in a buffer. */
277
278 typedef int Emchar;
279
280 /* Different ways of referring to a position in a buffer.  We use
281    the typedefs in preference to 'int' to make it clearer what
282    sort of position is being used.  See extents.c for a description
283    of the different positions.  We put them here instead of in
284    buffer.h (where they rightfully belong) to avoid syntax errors
285    in function prototypes. */
286
287 typedef int Bufpos;
288 typedef int Bytind;
289 typedef int Memind;
290
291 /* Counts of bytes or chars */
292
293 typedef int Bytecount;
294 typedef int Charcount;
295
296 /* Length in bytes of a string in external format */
297 typedef int Extcount;
298
299 typedef struct lstream Lstream;
300
301 typedef unsigned int face_index;
302
303 typedef struct
304 {
305   Dynarr_declare (struct face_cachel);
306 } face_cachel_dynarr;
307
308 typedef unsigned int glyph_index;
309
310 /* This is shared by process.h, events.h and others in future.
311    See events.h for description */
312 typedef unsigned int USID;
313
314 typedef struct
315 {
316   Dynarr_declare (struct glyph_cachel);
317 } glyph_cachel_dynarr;
318
319 struct buffer;                  /* "buffer.h" */
320 struct console;                 /* "console.h" */
321 struct device;                  /* "device.h" */
322 struct extent_fragment;
323 struct extent;
324 typedef struct extent *EXTENT;
325 struct frame;                   /* "frame.h" */
326 struct window;                  /* "window.h" */
327 struct Lisp_Event;              /* "events.h" */
328 typedef struct Lisp_Event Lisp_Event;
329 struct Lisp_Face;
330 typedef struct Lisp_Face Lisp_Face;
331 struct Lisp_Process;            /* "process.c" */
332 typedef struct Lisp_Process Lisp_Process;
333 struct stat;                    /* <sys/stat.h> */
334 struct Lisp_Color_Instance;
335 typedef struct Lisp_Color_Instance Lisp_Color_Instance;
336 struct Lisp_Font_Instance;
337 typedef struct Lisp_Font_Instance Lisp_Font_Instance;
338 struct Lisp_Image_Instance;
339 typedef struct Lisp_Image_Instance Lisp_Image_Instance;
340 struct Lisp_Gui_Item;
341 typedef struct Lisp_Gui_Item Lisp_Gui_Item;
342 struct display_line;
343 struct redisplay_info;
344 struct window_mirror;
345 struct scrollbar_instance;
346 struct font_metric_info;
347 struct face_cachel;
348 struct console_type_entry;
349
350 typedef struct
351 {
352   Dynarr_declare (Bufbyte);
353 } Bufbyte_dynarr;
354
355 typedef struct
356 {
357   Dynarr_declare (Extbyte);
358 } Extbyte_dynarr;
359
360 typedef struct
361 {
362   Dynarr_declare (Emchar);
363 } Emchar_dynarr;
364
365 typedef struct
366 {
367   Dynarr_declare (char);
368 } char_dynarr;
369
370 typedef unsigned char unsigned_char;
371 typedef struct
372 {
373   Dynarr_declare (unsigned char);
374 } unsigned_char_dynarr;
375
376 typedef unsigned long unsigned_long;
377 typedef struct
378 {
379   Dynarr_declare (unsigned long);
380 } unsigned_long_dynarr;
381
382 typedef struct
383 {
384   Dynarr_declare (int);
385 } int_dynarr;
386
387 typedef struct
388 {
389   Dynarr_declare (Bufpos);
390 } Bufpos_dynarr;
391
392 typedef struct
393 {
394   Dynarr_declare (Bytind);
395 } Bytind_dynarr;
396
397 typedef struct
398 {
399   Dynarr_declare (Charcount);
400 } Charcount_dynarr;
401
402 typedef struct
403 {
404   Dynarr_declare (Bytecount);
405 } Bytecount_dynarr;
406
407 typedef struct
408 {
409   Dynarr_declare (struct console_type_entry);
410 } console_type_entry_dynarr;
411
412 /* Need to declare this here. */
413 enum external_data_format
414 {
415   /* Binary format.  This is the simplest format and is what we
416      use in the absence of a more appropriate format.  This converts
417      according to the `binary' coding system:
418
419      a) On input, bytes 0 - 255 are converted into characters 0 - 255.
420      b) On output, characters 0 - 255 are converted into bytes 0 - 255
421         and other characters are converted into `X'.
422    */
423   FORMAT_BINARY,
424
425   /* Format used for filenames.  In the original Mule, this is
426      user-definable with the `pathname-coding-system' variable.
427      For the moment, we just use the `binary' coding system. */
428   FORMAT_FILENAME,
429
430   /* Format used for output to the terminal.  This should be controlled
431      by the `terminal-coding-system' variable.  Under kterm, this will
432      be some ISO2022 system.  On some DOS machines, this is Shift-JIS. */
433   FORMAT_TERMINAL,
434
435   /* Format used for input from the terminal.  This should be controlled
436      by the `keyboard-coding-system' variable. */
437   FORMAT_KEYBOARD,
438
439   /* Format used for the external Unix environment -- argv[], stuff
440      from getenv(), stuff from the /etc/passwd file, etc.
441
442      Perhaps should be the same as FORMAT_FILENAME. */
443   FORMAT_OS,
444
445   /* Compound-text format.  This is the standard X format used for
446      data stored in properties, selections, and the like.  This is
447      an 8-bit no-lock-shift ISO2022 coding system. */
448   FORMAT_CTEXT
449 };
450
451 #define FORMAT_NATIVE FORMAT_FILENAME
452
453 enum run_hooks_condition
454 {
455   RUN_HOOKS_TO_COMPLETION,
456   RUN_HOOKS_UNTIL_SUCCESS,
457   RUN_HOOKS_UNTIL_FAILURE
458 };
459
460 #ifdef HAVE_TOOLBARS
461 enum toolbar_pos
462 {
463   TOP_TOOLBAR,
464   BOTTOM_TOOLBAR,
465   LEFT_TOOLBAR,
466   RIGHT_TOOLBAR
467 };
468 #endif
469
470 #ifndef ERROR_CHECK_TYPECHECK
471
472 typedef enum error_behavior
473 {
474   ERROR_ME,
475   ERROR_ME_NOT,
476   ERROR_ME_WARN
477 } Error_behavior;
478
479 #define ERRB_EQ(a, b) ((a) == (b))
480
481 #else
482
483 /* By defining it like this, we provide strict type-checking
484    for code that lazily uses ints. */
485
486 typedef struct _error_behavior_struct_
487 {
488   int really_unlikely_name_to_have_accidentally_in_a_non_errb_structure;
489 } Error_behavior;
490
491 extern Error_behavior ERROR_ME;
492 extern Error_behavior ERROR_ME_NOT;
493 extern Error_behavior ERROR_ME_WARN;
494
495 #define ERRB_EQ(a, b)                                                      \
496  ((a).really_unlikely_name_to_have_accidentally_in_a_non_errb_structure == \
497   (b).really_unlikely_name_to_have_accidentally_in_a_non_errb_structure)
498
499 #endif
500
501 enum munge_me_out_the_door
502 {
503   MUNGE_ME_FUNCTION_KEY,
504   MUNGE_ME_KEY_TRANSLATION
505 };
506
507 \f
508 /************************************************************************/
509 /*                   Definition of Lisp_Object data type                */
510 /************************************************************************/
511
512 /* Define the fundamental Lisp data structures */
513
514 /* This is the set of Lisp data types */
515
516 enum Lisp_Type
517 {
518   Lisp_Type_Record,
519   Lisp_Type_Int_Even,
520   Lisp_Type_Char,
521   Lisp_Type_Int_Odd
522 };
523
524 #define POINTER_TYPE_P(type) ((type) == Lisp_Type_Record)
525
526 /* EMACS_INT is the underlying integral type into which a Lisp_Object must fit.
527    In particular, it must be large enough to contain a pointer.
528    config.h can override this, e.g. to use `long long' for bigger lisp ints. */
529
530 #ifndef SIZEOF_EMACS_INT
531 # define SIZEOF_EMACS_INT SIZEOF_VOID_P
532 #endif
533
534 #ifndef EMACS_INT
535 # if   SIZEOF_EMACS_INT == SIZEOF_LONG
536 #  define EMACS_INT long
537 # elif SIZEOF_EMACS_INT == SIZEOF_INT
538 #  define EMACS_INT int
539 # elif SIZEOF_EMACS_INT == SIZEOF_LONG_LONG
540 #  define EMACS_INT long long
541 # else
542 #  error Unable to determine suitable type for EMACS_INT
543 # endif
544 #endif
545
546 #ifndef EMACS_UINT
547 # define EMACS_UINT unsigned EMACS_INT
548 #endif
549
550 #define BITS_PER_EMACS_INT (SIZEOF_EMACS_INT * BITS_PER_CHAR)
551
552 /* Overridden by m/next.h */
553 #ifndef ASSERT_VALID_POINTER
554 # define ASSERT_VALID_POINTER(pnt) (assert ((((EMACS_UINT) pnt) & 3) == 0))
555 #endif
556
557 #define GCMARKBITS  0
558 #define GCTYPEBITS  2
559 #define GCBITS      2
560 #define INT_GCBITS  1
561
562 #define INT_VALBITS (BITS_PER_EMACS_INT - INT_GCBITS)
563 #define VALBITS (BITS_PER_EMACS_INT - GCBITS)
564 #define EMACS_INT_MAX ((1UL << INT_VALBITS) -1UL)
565
566 #ifdef USE_UNION_TYPE
567 # include "lisp-union.h"
568 #else /* !USE_UNION_TYPE */
569 # include "lisp-disunion.h"
570 #endif /* !USE_UNION_TYPE */
571
572 #define XPNTR(x) ((void *) (XPNTRVAL(x)))
573
574 /* WARNING WARNING WARNING.  You must ensure on your own that proper
575    GC protection is provided for the elements in this array. */
576 typedef struct
577 {
578   Dynarr_declare (Lisp_Object);
579 } Lisp_Object_dynarr;
580
581 /* Close your eyes now lest you vomit or spontaneously combust ... */
582
583 #define HACKEQ_UNSAFE(obj1, obj2)                               \
584   (EQ (obj1, obj2) || (!POINTER_TYPE_P (XGCTYPE (obj1))         \
585                        && !POINTER_TYPE_P (XGCTYPE (obj2))      \
586                        && XCHAR_OR_INT (obj1) == XCHAR_OR_INT (obj2)))
587
588 #ifdef DEBUG_XEMACS
589 extern int debug_issue_ebola_notices;
590 int eq_with_ebola_notice (Lisp_Object, Lisp_Object);
591 #define EQ_WITH_EBOLA_NOTICE(obj1, obj2)                                \
592   (debug_issue_ebola_notices ? eq_with_ebola_notice (obj1, obj2)        \
593    : EQ (obj1, obj2))
594 #else
595 #define EQ_WITH_EBOLA_NOTICE(obj1, obj2) EQ (obj1, obj2)
596 #endif
597
598 /* OK, you can open them again */
599
600 \f
601 /************************************************************************/
602 /*                   Definitions of basic Lisp objects                  */
603 /************************************************************************/
604
605 #include "lrecord.h"
606
607 /*********** unbound ***********/
608
609 /* Qunbound is a special Lisp_Object (actually of type
610    symbol-value-forward), that can never be visible to
611    the Lisp caller and thus can be used in the C code
612    to mean "no such value". */
613
614 #define UNBOUNDP(val) EQ (val, Qunbound)
615 #define GC_UNBOUNDP(val) GC_EQ (val, Qunbound)
616
617 /*********** cons ***********/
618
619 /* In a cons, the markbit of the car is the gc mark bit */
620
621 struct Lisp_Cons
622 {
623   struct lrecord_header lheader;
624   Lisp_Object car, cdr;
625 };
626 typedef struct Lisp_Cons Lisp_Cons;
627
628 #if 0 /* FSFmacs */
629 /* Like a cons, but records info on where the text lives that it was read from */
630 /* This is not really in use now */
631
632 struct Lisp_Buffer_Cons
633 {
634   Lisp_Object car, cdr;
635   struct buffer *buffer;
636   int bufpos;
637 };
638 #endif
639
640 DECLARE_LRECORD (cons, Lisp_Cons);
641 #define XCONS(x) XRECORD (x, cons, Lisp_Cons)
642 #define XSETCONS(x, p) XSETRECORD (x, p, cons)
643 #define CONSP(x) RECORDP (x, cons)
644 #define GC_CONSP(x) GC_RECORDP (x, cons)
645 #define CHECK_CONS(x) CHECK_RECORD (x, cons)
646 #define CONCHECK_CONS(x) CONCHECK_RECORD (x, cons)
647
648 #define CONS_MARKED_P(c) MARKED_RECORD_HEADER_P(&((c)->lheader))
649 #define MARK_CONS(c) MARK_RECORD_HEADER (&((c)->lheader))
650
651 extern Lisp_Object Qnil;
652
653 #define NILP(x)  EQ (x, Qnil)
654 #define GC_NILP(x)  GC_EQ (x, Qnil)
655 #define XCAR(a) (XCONS (a)->car)
656 #define XCDR(a) (XCONS (a)->cdr)
657 #define LISTP(x) (CONSP(x) || NILP(x))
658
659 #define CHECK_LIST(x) do {                      \
660   if (!LISTP (x))                               \
661     dead_wrong_type_argument (Qlistp, x);       \
662 } while (0)
663
664 #define CONCHECK_LIST(x) do {                   \
665   if (!LISTP (x))                               \
666     x = wrong_type_argument (Qlistp, x);        \
667 } while (0)
668
669 /* For a list that's known to be in valid list format --
670    will abort() if the list is not in valid format */
671 #define LIST_LOOP(tail, list)           \
672   for (tail = list;                     \
673        !NILP (tail);                    \
674        tail = XCDR (tail))
675
676 #define LIST_LOOP_2(elt, list)          \
677   Lisp_Object tail##elt;                \
678   LIST_LOOP_3(elt, list, tail##elt)
679
680 #define LIST_LOOP_3(elt, list, tail)    \
681   for (tail = list;                     \
682        NILP (tail) ?                    \
683          0 : (elt = XCAR (tail), 1);    \
684        tail = XCDR (tail))
685
686 #define GET_LIST_LENGTH(list, len) do {         \
687   Lisp_Object GLL_tail;                         \
688   for (GLL_tail = list, len = 0;                \
689        !NILP (GLL_tail);                        \
690        GLL_tail = XCDR (GLL_tail), ++len)       \
691     DO_NOTHING;                                 \
692 } while (0)
693
694 #define GET_EXTERNAL_LIST_LENGTH(list, len)             \
695 do {                                                    \
696   Lisp_Object GELL_elt, GELL_tail;                      \
697   EXTERNAL_LIST_LOOP_4 (GELL_elt, list, GELL_tail, len) \
698     ;                                                   \
699 } while (0)
700
701 /* For a list that's known to be in valid list format, where we may
702    be deleting the current element out of the list --
703    will abort() if the list is not in valid format */
704 #define LIST_LOOP_DELETING(consvar, nextconsvar, list)          \
705   for (consvar = list;                                          \
706        !NILP (consvar) ? (nextconsvar = XCDR (consvar), 1) :0;  \
707        consvar = nextconsvar)
708
709 /* Delete all elements of external list LIST
710    satisfying CONDITION, an expression referring to variable ELT */
711 #define EXTERNAL_LIST_LOOP_DELETE_IF(elt, list, condition) do { \
712   Lisp_Object prev_tail_##list = Qnil;                          \
713   Lisp_Object tail_##list;                                      \
714   int len_##list;                                               \
715   EXTERNAL_LIST_LOOP_4 (elt, list, tail_##list, len_##list)     \
716     {                                                           \
717       if (condition)                                            \
718         {                                                       \
719           if (NILP (prev_tail_##list))                          \
720             list = XCDR (tail_##list);                          \
721           else                                                  \
722             XCDR (prev_tail_##list) = XCDR (tail_##list);       \
723           /* Keep tortoise from ever passing hare. */           \
724           len_##list = 0;                                       \
725         }                                                       \
726       else                                                      \
727         prev_tail_##list = tail_##list;                         \
728     }                                                           \
729 } while (0)
730
731 /* Delete all elements of true non-circular list LIST
732    satisfying CONDITION, an expression referring to variable ELT */
733 #define LIST_LOOP_DELETE_IF(elt, list, condition) do {          \
734   Lisp_Object prev_tail_##list = Qnil;                          \
735   Lisp_Object tail_##list;                                      \
736   LIST_LOOP_3 (elt, list, tail_##list)                          \
737     {                                                           \
738       if (condition)                                            \
739         {                                                       \
740           if (NILP (prev_tail_##list))                          \
741             list = XCDR (tail_##list);                          \
742           else                                                  \
743             XCDR (prev_tail_##list) = XCDR (tail_##list);       \
744         }                                                       \
745       else                                                      \
746         prev_tail_##list = tail_##list;                         \
747     }                                                           \
748 } while (0)
749
750 /* For a list that may not be in valid list format --
751    will signal an error if the list is not in valid format */
752 #define EXTERNAL_LIST_LOOP(tail, list)                  \
753   for (tail = list; !NILP (tail); tail = XCDR (tail))   \
754      if (!CONSP (tail))                                 \
755        signal_malformed_list_error (list);              \
756      else
757
758
759 /* The following macros are for traversing lisp lists.
760    Signal an error if LIST is not properly acyclic and nil-terminated.
761
762    Use tortoise/hare algorithm to check for cycles, but only if it
763    looks like the list is getting too long.  Not only is the hare
764    faster than the tortoise; it even gets a head start! */
765
766 /* Optimized and safe macros for looping over external lists.  */
767 #define CIRCULAR_LIST_SUSPICION_LENGTH 1024
768
769 #define EXTERNAL_LIST_LOOP_1(list)                                      \
770 Lisp_Object ELL1_elt, ELL1_hare, ELL1_tortoise;                         \
771 int ELL1_len;                                                           \
772 EXTERNAL_LIST_LOOP_6(ELL1_elt, list, ELL1_len, ELL1_hare,               \
773                      ELL1_tortoise, CIRCULAR_LIST_SUSPICION_LENGTH)
774
775 #define EXTERNAL_LIST_LOOP_2(elt, list)                                 \
776 Lisp_Object hare_##elt, tortoise_##elt;                                 \
777 int len_##elt;                                                          \
778 EXTERNAL_LIST_LOOP_6(elt, list, len_##elt, hare_##elt,                  \
779                      tortoise_##elt, CIRCULAR_LIST_SUSPICION_LENGTH)
780
781 #define EXTERNAL_LIST_LOOP_3(elt, list, tail)                           \
782 Lisp_Object tortoise_##elt;                                             \
783 int len_##elt;                                                          \
784 EXTERNAL_LIST_LOOP_6(elt, list, len_##elt, tail,                        \
785                      tortoise_##elt, CIRCULAR_LIST_SUSPICION_LENGTH)
786
787 #define EXTERNAL_LIST_LOOP_4(elt, list, tail, len)                      \
788 Lisp_Object tortoise_##elt;                                             \
789 EXTERNAL_LIST_LOOP_6(elt, list, len, tail,                              \
790                      tortoise_##elt, CIRCULAR_LIST_SUSPICION_LENGTH)
791
792
793 #define EXTERNAL_LIST_LOOP_6(elt, list, len, hare,              \
794                              tortoise, suspicion_length)        \
795   for (tortoise = hare = list, len = 0;                         \
796                                                                 \
797        (CONSP (hare) ? ((elt = XCAR (hare)), 1) :               \
798         (NILP (hare) ? 0 :                                      \
799          (signal_malformed_list_error (list), 0)));             \
800                                                                 \
801        hare = XCDR (hare),                                      \
802          ((++len < suspicion_length) ?                          \
803           ((void) 0) :                                          \
804           (((len & 1) ?                                         \
805             ((void) (tortoise = XCDR (tortoise))) :             \
806             ((void) 0))                                         \
807            ,                                                    \
808            (EQ (hare, tortoise) ?                               \
809             ((void) signal_circular_list_error (list)) :        \
810             ((void) 0)))))
811
812
813
814 /* Optimized and safe macros for looping over external alists. */
815 #define EXTERNAL_ALIST_LOOP_4(elt, elt_car, elt_cdr, list)              \
816 Lisp_Object hare_##elt, tortoise_##elt;                                 \
817 int len_##elt;                                                          \
818 EXTERNAL_ALIST_LOOP_8 (elt, elt_car, elt_cdr, list,                     \
819                        len_##elt, hare_##elt, tortoise_##elt,           \
820                        CIRCULAR_LIST_SUSPICION_LENGTH)
821
822 #define EXTERNAL_ALIST_LOOP_5(elt, elt_car, elt_cdr, list, tail)        \
823 Lisp_Object tortoise_##elt;                                             \
824 int len_##elt;                                                          \
825 EXTERNAL_ALIST_LOOP_8(elt, elt_car, elt_cdr, list,                      \
826                       len_##elt, tail, tortoise_##elt,                  \
827                       CIRCULAR_LIST_SUSPICION_LENGTH)
828
829 #define EXTERNAL_ALIST_LOOP_6(elt, elt_car, elt_cdr, list, tail, len)   \
830 Lisp_Object tortoise_##elt;                                             \
831 EXTERNAL_ALIST_LOOP_8(elt, elt_car, elt_cdr, list,                      \
832                       len, tail, tortoise_##elt,                        \
833                       CIRCULAR_LIST_SUSPICION_LENGTH)
834
835
836 #define EXTERNAL_ALIST_LOOP_8(elt, elt_car, elt_cdr, list, len, hare,   \
837                              tortoise, suspicion_length)                \
838 EXTERNAL_LIST_LOOP_6(elt, list, len, hare, tortoise, suspicion_length)  \
839   if (CONSP (elt) ? (elt_car = XCAR (elt), elt_cdr = XCDR (elt), 0) :1) \
840     continue;                                                           \
841   else
842
843
844 /* Optimized and safe macros for looping over external property lists. */
845 #define EXTERNAL_PROPERTY_LIST_LOOP_3(key, value, list)                 \
846 Lisp_Object key, value, hare_##key, tortoise_##key;                     \
847 int len_##key;                                                          \
848 EXTERNAL_PROPERTY_LIST_LOOP_7(key, value, list, len_##key, hare_##key,\
849                      tortoise_##key, CIRCULAR_LIST_SUSPICION_LENGTH)
850
851 #define EXTERNAL_PROPERTY_LIST_LOOP_4(key, value, list, tail)           \
852 Lisp_Object key, value, tail, tortoise_##key;                           \
853 int len_##key;                                                          \
854 EXTERNAL_PROPERTY_LIST_LOOP_7(key, value, list, len_##key, tail,        \
855                      tortoise_##key, CIRCULAR_LIST_SUSPICION_LENGTH)
856
857 #define EXTERNAL_PROPERTY_LIST_LOOP_5(key, value, list, tail, len)      \
858 Lisp_Object key, value, tail, tortoise_##key;                           \
859 int len;                                                                \
860 EXTERNAL_PROPERTY_LIST_LOOP_7(key, value, list, len, tail,              \
861                      tortoise_##key, CIRCULAR_LIST_SUSPICION_LENGTH)
862
863
864 #define EXTERNAL_PROPERTY_LIST_LOOP_7(key, value, list, len, hare,      \
865                              tortoise, suspicion_length)                \
866   for (tortoise = hare = list, len = 0;                                 \
867                                                                         \
868        ((CONSP (hare) &&                                                \
869          (key = XCAR (hare),                                            \
870           hare = XCDR (hare),                                           \
871           CONSP (hare))) ?                                              \
872         (value = XCAR (hare), 1) :                                      \
873         (NILP (hare) ? 0 :                                              \
874          (signal_malformed_property_list_error (list), 0)));            \
875                                                                         \
876        hare = XCDR (hare),                                              \
877          ((++len < suspicion_length) ?                                  \
878           ((void) 0) :                                                  \
879           (((len & 1) ?                                                 \
880             ((void) (tortoise = XCDR (XCDR (tortoise)))) :              \
881             ((void) 0))                                                 \
882            ,                                                            \
883            (EQ (hare, tortoise) ?                                       \
884             ((void) signal_circular_property_list_error (list)) :       \
885             ((void) 0)))))
886
887 /* For a property list (alternating keywords/values) that may not be
888    in valid list format -- will signal an error if the list is not in
889    valid format.  CONSVAR is used to keep track of the iterations
890    without modifying PLIST.
891
892    We have to be tricky to still keep the same C format.*/
893 #define EXTERNAL_PROPERTY_LIST_LOOP(tail, key, value, plist)    \
894   for (tail = plist;                                            \
895        (CONSP (tail) && CONSP (XCDR (tail)) ?                   \
896         (key = XCAR (tail), value = XCAR (XCDR (tail))) :       \
897         (key = Qunbound,    value = Qunbound)),                 \
898        !NILP (tail);                                            \
899        tail = XCDR (XCDR (tail)))                               \
900     if (UNBOUNDP (key))                                         \
901       Fsignal (Qmalformed_property_list, list1 (plist));        \
902     else
903
904 #define PROPERTY_LIST_LOOP(tail, key, value, plist)     \
905   for (tail = plist;                                    \
906        NILP (tail) ? 0 :                                \
907          (key   = XCAR (tail), tail = XCDR (tail),      \
908           value = XCAR (tail), tail = XCDR (tail), 1);  \
909        )
910
911 /* Return 1 if LIST is properly acyclic and nil-terminated, else 0. */
912 INLINE int TRUE_LIST_P (Lisp_Object object);
913 INLINE int
914 TRUE_LIST_P (Lisp_Object object)
915 {
916   Lisp_Object hare, tortoise;
917   int len;
918
919   for (hare = tortoise = object, len = 0;
920        CONSP (hare);
921        hare = XCDR (hare), len++)
922     {
923       if (len < CIRCULAR_LIST_SUSPICION_LENGTH)
924         continue;
925
926       if (len & 1)
927         tortoise = XCDR (tortoise);
928       else if (EQ (hare, tortoise))
929         return 0;
930     }
931
932   return NILP (hare);
933 }
934
935 /* Signal an error if LIST is not properly acyclic and nil-terminated. */
936 #define CHECK_TRUE_LIST(list) do {                      \
937   Lisp_Object CTL_list = (list);                        \
938   Lisp_Object CTL_hare, CTL_tortoise;                   \
939   int CTL_len;                                          \
940                                                         \
941   for (CTL_hare = CTL_tortoise = CTL_list, CTL_len = 0; \
942        CONSP (CTL_hare);                                \
943        CTL_hare = XCDR (CTL_hare), CTL_len++)           \
944     {                                                   \
945       if (CTL_len < CIRCULAR_LIST_SUSPICION_LENGTH)     \
946         continue;                                       \
947                                                         \
948       if (CTL_len & 1)                                  \
949         CTL_tortoise = XCDR (CTL_tortoise);             \
950       else if (EQ (CTL_hare, CTL_tortoise))             \
951         Fsignal (Qcircular_list, list1 (CTL_list));     \
952     }                                                   \
953                                                         \
954   if (! NILP (CTL_hare))                                \
955     signal_malformed_list_error (CTL_list);             \
956 } while (0)
957
958 /*********** string ***********/
959
960 struct Lisp_String
961 {
962   struct lrecord_header lheader;
963   Bytecount size;
964   Bufbyte *data;
965   Lisp_Object plist;
966 };
967 typedef struct Lisp_String Lisp_String;
968
969 DECLARE_LRECORD (string, Lisp_String);
970 #define XSTRING(x) XRECORD (x, string, Lisp_String)
971 #define XSETSTRING(x, p) XSETRECORD (x, p, string)
972 #define STRINGP(x) RECORDP (x, string)
973 #define GC_STRINGP(x) GC_RECORDP (x, string)
974 #define CHECK_STRING(x) CHECK_RECORD (x, string)
975 #define CONCHECK_STRING(x) CONCHECK_RECORD (x, string)
976
977 #ifdef MULE
978
979 Charcount bytecount_to_charcount (CONST Bufbyte *ptr, Bytecount len);
980 Bytecount charcount_to_bytecount (CONST Bufbyte *ptr, Charcount len);
981
982 #else /* not MULE */
983
984 # define bytecount_to_charcount(ptr, len) (len)
985 # define charcount_to_bytecount(ptr, len) (len)
986
987 #endif /* not MULE */
988
989 #define string_length(s) ((s)->size)
990 #define XSTRING_LENGTH(s) string_length (XSTRING (s))
991 #define XSTRING_CHAR_LENGTH(s) string_char_length (XSTRING (s))
992 #define string_data(s) ((s)->data + 0)
993 #define XSTRING_DATA(s) string_data (XSTRING (s))
994 #define string_byte(s, i) ((s)->data[i] + 0)
995 #define XSTRING_BYTE(s, i) string_byte (XSTRING (s), i)
996 #define string_byte_addr(s, i) (&((s)->data[i]))
997 #define set_string_length(s, len) ((void) ((s)->size = (len)))
998 #define set_string_data(s, ptr) ((void) ((s)->data = (ptr)))
999 #define set_string_byte(s, i, c) ((void) ((s)->data[i] = (c)))
1000
1001 void resize_string (Lisp_String *s, Bytecount pos, Bytecount delta);
1002
1003 #ifdef MULE
1004
1005 INLINE Charcount string_char_length (Lisp_String *s);
1006 INLINE Charcount
1007 string_char_length (Lisp_String *s)
1008 {
1009   return bytecount_to_charcount (string_data (s), string_length (s));
1010 }
1011
1012 # define string_char(s, i) charptr_emchar_n (string_data (s), i)
1013 # define string_char_addr(s, i) charptr_n_addr (string_data (s), i)
1014 void set_string_char (Lisp_String *s, Charcount i, Emchar c);
1015
1016 #else /* not MULE */
1017
1018 # define string_char_length(s) string_length (s)
1019 # define string_char(s, i) ((Emchar) string_byte (s, i))
1020 # define string_char_addr(s, i) string_byte_addr (s, i)
1021 # define set_string_char(s, i, c) set_string_byte (s, i, c)
1022
1023 #endif /* not MULE */
1024
1025 /*********** vector ***********/
1026
1027 struct Lisp_Vector
1028 {
1029   struct lcrecord_header header;
1030   long size;
1031   /* next is now chained through v->contents[size], terminated by Qzero.
1032      This means that pure vectors don't need a "next" */
1033   /* struct Lisp_Vector *next; */
1034   Lisp_Object contents[1];
1035 };
1036 typedef struct Lisp_Vector Lisp_Vector;
1037
1038 DECLARE_LRECORD (vector, Lisp_Vector);
1039 #define XVECTOR(x) XRECORD (x, vector, Lisp_Vector)
1040 #define XSETVECTOR(x, p) XSETRECORD (x, p, vector)
1041 #define VECTORP(x) RECORDP (x, vector)
1042 #define GC_VECTORP(x) GC_RECORDP (x, vector)
1043 #define CHECK_VECTOR(x) CHECK_RECORD (x, vector)
1044 #define CONCHECK_VECTOR(x) CONCHECK_RECORD (x, vector)
1045
1046 #define vector_length(v) ((v)->size)
1047 #define XVECTOR_LENGTH(s) vector_length (XVECTOR (s))
1048 #define vector_data(v) ((v)->contents)
1049 #define XVECTOR_DATA(s) vector_data (XVECTOR (s))
1050
1051 /*********** bit vector ***********/
1052
1053 #if (LONGBITS < 16)
1054 #error What the hell?!
1055 #elif (LONGBITS < 32)
1056 # define LONGBITS_LOG2 4
1057 # define LONGBITS_POWER_OF_2 16
1058 #elif (LONGBITS < 64)
1059 # define LONGBITS_LOG2 5
1060 # define LONGBITS_POWER_OF_2 32
1061 #elif (LONGBITS < 128)
1062 # define LONGBITS_LOG2 6
1063 # define LONGBITS_POWER_OF_2 64
1064 #else
1065 #error You really have 128-bit integers?!
1066 #endif
1067
1068 struct Lisp_Bit_Vector
1069 {
1070   struct lrecord_header lheader;
1071   Lisp_Object next;
1072   size_t size;
1073   unsigned long bits[1];
1074 };
1075 typedef struct Lisp_Bit_Vector Lisp_Bit_Vector;
1076
1077 DECLARE_LRECORD (bit_vector, Lisp_Bit_Vector);
1078 #define XBIT_VECTOR(x) XRECORD (x, bit_vector, Lisp_Bit_Vector)
1079 #define XSETBIT_VECTOR(x, p) XSETRECORD (x, p, bit_vector)
1080 #define BIT_VECTORP(x) RECORDP (x, bit_vector)
1081 #define GC_BIT_VECTORP(x) GC_RECORDP (x, bit_vector)
1082 #define CHECK_BIT_VECTOR(x) CHECK_RECORD (x, bit_vector)
1083 #define CONCHECK_BIT_VECTOR(x) CONCHECK_RECORD (x, bit_vector)
1084
1085 #define BITP(x) (INTP (x) && (XINT (x) == 0 || XINT (x) == 1))
1086 #define GC_BITP(x) (GC_INTP (x) && (XINT (x) == 0 || XINT (x) == 1))
1087
1088 #define CHECK_BIT(x) do {               \
1089   if (!BITP (x))                        \
1090     dead_wrong_type_argument (Qbitp, x);\
1091 } while (0)
1092
1093 #define CONCHECK_BIT(x) do {            \
1094   if (!BITP (x))                        \
1095     x = wrong_type_argument (Qbitp, x); \
1096 } while (0)
1097
1098 #define bit_vector_length(v) ((v)->size)
1099 #define bit_vector_next(v) ((v)->next)
1100
1101 INLINE int bit_vector_bit (Lisp_Bit_Vector *v, int i);
1102 INLINE int
1103 bit_vector_bit (Lisp_Bit_Vector *v, int i)
1104 {
1105   unsigned int ui = (unsigned int) i;
1106
1107   return (((v)->bits[ui >> LONGBITS_LOG2] >> (ui & (LONGBITS_POWER_OF_2 - 1)))
1108           & 1);
1109 }
1110
1111 INLINE void set_bit_vector_bit (Lisp_Bit_Vector *v, int i, int value);
1112 INLINE void
1113 set_bit_vector_bit (Lisp_Bit_Vector *v, int i, int value)
1114 {
1115   unsigned int ui = (unsigned int) i;
1116   if (value)
1117     (v)->bits[ui >> LONGBITS_LOG2] |= (1UL << (ui & (LONGBITS_POWER_OF_2 - 1)));
1118   else
1119     (v)->bits[ui >> LONGBITS_LOG2] &= ~(1UL << (ui & (LONGBITS_POWER_OF_2 - 1)));
1120 }
1121
1122 /* Number of longs required to hold LEN bits */
1123 #define BIT_VECTOR_LONG_STORAGE(len) \
1124   ((len + LONGBITS_POWER_OF_2 - 1) >> LONGBITS_LOG2)
1125
1126
1127 /*********** symbol ***********/
1128
1129 struct Lisp_Symbol
1130 {
1131   struct lrecord_header lheader;
1132   /* next symbol in this obarray bucket */
1133   struct Lisp_Symbol *next;
1134   struct Lisp_String *name;
1135   Lisp_Object value;
1136   Lisp_Object function;
1137   Lisp_Object plist;
1138 };
1139 typedef struct Lisp_Symbol Lisp_Symbol;
1140
1141 #define SYMBOL_IS_KEYWORD(sym)                                          \
1142   ((string_byte (symbol_name (XSYMBOL (sym)), 0) == ':')                \
1143    && EQ (sym, oblookup (Vobarray,                                      \
1144                          string_data (symbol_name (XSYMBOL (sym))),     \
1145                          string_length (symbol_name (XSYMBOL (sym))))))
1146 #define KEYWORDP(obj) (SYMBOLP (obj) && SYMBOL_IS_KEYWORD (obj))
1147
1148 DECLARE_LRECORD (symbol, Lisp_Symbol);
1149 #define XSYMBOL(x) XRECORD (x, symbol, Lisp_Symbol)
1150 #define XSETSYMBOL(x, p) XSETRECORD (x, p, symbol)
1151 #define SYMBOLP(x) RECORDP (x, symbol)
1152 #define GC_SYMBOLP(x) GC_RECORDP (x, symbol)
1153 #define CHECK_SYMBOL(x) CHECK_RECORD (x, symbol)
1154 #define CONCHECK_SYMBOL(x) CONCHECK_RECORD (x, symbol)
1155
1156 #define symbol_next(s) ((s)->next)
1157 #define symbol_name(s) ((s)->name)
1158 #define symbol_value(s) ((s)->value)
1159 #define symbol_function(s) ((s)->function)
1160 #define symbol_plist(s) ((s)->plist)
1161
1162 /*********** subr ***********/
1163
1164 typedef Lisp_Object (*lisp_fn_t) (void);
1165
1166 struct Lisp_Subr
1167 {
1168   struct lrecord_header lheader;
1169   short min_args, max_args;
1170   CONST char *prompt;
1171   CONST char *doc;
1172   CONST char *name;
1173   lisp_fn_t subr_fn;
1174 };
1175 typedef struct Lisp_Subr Lisp_Subr;
1176
1177 DECLARE_LRECORD (subr, Lisp_Subr);
1178 #define XSUBR(x) XRECORD (x, subr, Lisp_Subr)
1179 #define XSETSUBR(x, p) XSETRECORD (x, p, subr)
1180 #define SUBRP(x) RECORDP (x, subr)
1181 #define GC_SUBRP(x) GC_RECORDP (x, subr)
1182 #define CHECK_SUBR(x) CHECK_RECORD (x, subr)
1183 #define CONCHECK_SUBR(x) CONCHECK_RECORD (x, subr)
1184
1185 #define subr_function(subr) (subr)->subr_fn
1186 #define subr_name(subr) (subr)->name
1187
1188 /*********** marker ***********/
1189
1190 struct Lisp_Marker
1191 {
1192   struct lrecord_header lheader;
1193   struct Lisp_Marker *next, *prev;
1194   struct buffer *buffer;
1195   Memind memind;
1196   char insertion_type;
1197 };
1198 typedef struct Lisp_Marker Lisp_Marker;
1199
1200 DECLARE_LRECORD (marker, Lisp_Marker);
1201 #define XMARKER(x) XRECORD (x, marker, Lisp_Marker)
1202 #define XSETMARKER(x, p) XSETRECORD (x, p, marker)
1203 #define MARKERP(x) RECORDP (x, marker)
1204 #define GC_MARKERP(x) GC_RECORDP (x, marker)
1205 #define CHECK_MARKER(x) CHECK_RECORD (x, marker)
1206 #define CONCHECK_MARKER(x) CONCHECK_RECORD (x, marker)
1207
1208 /* The second check was looking for GCed markers still in use */
1209 /* if (INTP (XMARKER (x)->lheader.next.v)) abort (); */
1210
1211 #define marker_next(m) ((m)->next)
1212 #define marker_prev(m) ((m)->prev)
1213
1214 /*********** char ***********/
1215
1216 #define CHARP(x) (XTYPE (x) == Lisp_Type_Char)
1217 #define GC_CHARP(x) (XGCTYPE (x) == Lisp_Type_Char)
1218
1219 #ifdef ERROR_CHECK_TYPECHECK
1220
1221 INLINE Emchar XCHAR (Lisp_Object obj);
1222 INLINE Emchar
1223 XCHAR (Lisp_Object obj)
1224 {
1225   assert (CHARP (obj));
1226   return XCHARVAL (obj);
1227 }
1228
1229 #else
1230
1231 #define XCHAR(x) XCHARVAL (x)
1232
1233 #endif
1234
1235 #define CHECK_CHAR(x) CHECK_NONRECORD (x, Lisp_Type_Char, Qcharacterp)
1236 #define CONCHECK_CHAR(x) CONCHECK_NONRECORD (x, Lisp_Type_Char, Qcharacterp)
1237
1238
1239 /*********** float ***********/
1240
1241 #ifdef LISP_FLOAT_TYPE
1242
1243 /* Note: the 'unused_next_' field exists only to ensure that the
1244    `next' pointer fits within the structure, for the purposes of the
1245    free list.  This makes a difference in the unlikely case of
1246    sizeof(double) being smaller than sizeof(void *). */
1247
1248 struct Lisp_Float
1249 {
1250   struct lrecord_header lheader;
1251   union { double d; struct Lisp_Float *unused_next_; } data;
1252 };
1253 typedef struct Lisp_Float Lisp_Float;
1254
1255 DECLARE_LRECORD (float, Lisp_Float);
1256 #define XFLOAT(x) XRECORD (x, float, Lisp_Float)
1257 #define XSETFLOAT(x, p) XSETRECORD (x, p, float)
1258 #define FLOATP(x) RECORDP (x, float)
1259 #define GC_FLOATP(x) GC_RECORDP (x, float)
1260 #define CHECK_FLOAT(x) CHECK_RECORD (x, float)
1261 #define CONCHECK_FLOAT(x) CONCHECK_RECORD (x, float)
1262
1263 #define float_data(f) ((f)->data.d)
1264 #define XFLOAT_DATA(x) float_data (XFLOAT (x))
1265
1266 #define XFLOATINT(n) extract_float (n)
1267
1268 #define CHECK_INT_OR_FLOAT(x) do {              \
1269   if (!INT_OR_FLOATP (x))                       \
1270     dead_wrong_type_argument (Qnumberp, x);     \
1271 } while (0)
1272
1273 #define CONCHECK_INT_OR_FLOAT(x) do {           \
1274   if (!INT_OR_FLOATP (x))                       \
1275     x = wrong_type_argument (Qnumberp, x);      \
1276 } while (0)
1277
1278 # define INT_OR_FLOATP(x) (INTP (x) || FLOATP (x))
1279 # define GC_INT_OR_FLOATP(x) (GC_INTP (x) || GC_FLOATP (x))
1280
1281 #else /* not LISP_FLOAT_TYPE */
1282
1283 #define XFLOAT(x) --- error!  No float support. ---
1284 #define XSETFLOAT(x, p) --- error!  No float support. ---
1285 #define FLOATP(x) 0
1286 #define GC_FLOATP(x) 0
1287 #define CHECK_FLOAT(x) --- error!  No float support. ---
1288 #define CONCHECK_FLOAT(x) --- error!  No float support. ---
1289
1290 #define XFLOATINT(n) XINT(n)
1291 #define CHECK_INT_OR_FLOAT CHECK_INT
1292 #define CONCHECK_INT_OR_FLOAT CONCHECK_INT
1293 #define INT_OR_FLOATP(x) (INTP (x))
1294 # define GC_INT_OR_FLOATP(x) (GC_INTP (x))
1295
1296 #endif /* not LISP_FLOAT_TYPE */
1297
1298 /*********** int ***********/
1299
1300 #define GC_INTP(x) INTP (x)
1301
1302 #define ZEROP(x) EQ (x, Qzero)
1303 #define GC_ZEROP(x) GC_EQ (x, Qzero)
1304
1305 #ifdef ERROR_CHECK_TYPECHECK
1306
1307 INLINE EMACS_INT XINT (Lisp_Object obj);
1308 INLINE EMACS_INT
1309 XINT (Lisp_Object obj)
1310 {
1311   assert (INTP (obj));
1312   return XREALINT (obj);
1313 }
1314
1315 INLINE EMACS_INT XCHAR_OR_INT (Lisp_Object obj);
1316 INLINE EMACS_INT
1317 XCHAR_OR_INT (Lisp_Object obj)
1318 {
1319   assert (INTP (obj) || CHARP (obj));
1320   return CHARP (obj) ? XCHAR (obj) : XINT (obj);
1321 }
1322
1323 #else /* no error checking */
1324
1325 #define XINT(obj) XREALINT (obj)
1326 #define XCHAR_OR_INT(obj) (CHARP (obj) ? XCHAR (obj) : XINT (obj))
1327
1328 #endif /* no error checking */
1329
1330 #define CHECK_INT(x) do {                       \
1331   if (!INTP (x))                                \
1332     dead_wrong_type_argument (Qintegerp, x);    \
1333 } while (0)
1334
1335 #define CONCHECK_INT(x) do {                    \
1336   if (!INTP (x))                                \
1337     x = wrong_type_argument (Qintegerp, x);     \
1338 } while (0)
1339
1340 #define NATNUMP(x) (INTP (x) && XINT (x) >= 0)
1341 #define GC_NATNUMP(x) (GC_INTP (x) && XINT (x) >= 0)
1342
1343 #define CHECK_NATNUM(x) do {                    \
1344   if (!NATNUMP (x))                             \
1345     dead_wrong_type_argument (Qnatnump, x);     \
1346 } while (0)
1347
1348 #define CONCHECK_NATNUM(x) do {                 \
1349   if (!NATNUMP (x))                             \
1350     x = wrong_type_argument (Qnatnump, x);      \
1351 } while (0)
1352
1353 /* next three always continuable because they coerce their arguments. */
1354 #define CHECK_INT_COERCE_CHAR(x) do {                   \
1355   if (INTP (x))                                         \
1356     ;                                                   \
1357   else if (CHARP (x))                                   \
1358     x = make_int (XCHAR (x));                           \
1359   else                                                  \
1360     x = wrong_type_argument (Qinteger_or_char_p, x);    \
1361 } while (0)
1362
1363 #define CHECK_INT_COERCE_MARKER(x) do {                 \
1364   if (INTP (x))                                         \
1365     ;                                                   \
1366   else if (MARKERP (x))                                 \
1367     x = make_int (marker_position (x));                 \
1368   else                                                  \
1369     x = wrong_type_argument (Qinteger_or_marker_p, x);  \
1370 } while (0)
1371
1372 #define CHECK_INT_COERCE_CHAR_OR_MARKER(x) do {                 \
1373   if (INTP (x))                                                 \
1374     ;                                                           \
1375   else if (CHARP (x))                                           \
1376     x = make_int (XCHAR (x));                                   \
1377   else if (MARKERP (x))                                         \
1378     x = make_int (marker_position (x));                         \
1379   else                                                          \
1380     x = wrong_type_argument (Qinteger_char_or_marker_p, x);     \
1381 } while (0)
1382
1383
1384 /*********** readonly objects ***********/
1385     
1386 #define CHECK_C_WRITEABLE(obj)                                  \
1387   do { if (c_readonly (obj)) c_write_error (obj); } while (0)
1388
1389 #define CHECK_LISP_WRITEABLE(obj)                                       \
1390   do { if (lisp_readonly (obj)) lisp_write_error (obj); } while (0)
1391
1392 #define C_READONLY(obj) (C_READONLY_RECORD_HEADER_P(XRECORD_LHEADER (obj)))
1393 #define LISP_READONLY(obj) (LISP_READONLY_RECORD_HEADER_P(XRECORD_LHEADER (obj)))
1394
1395 /*********** structures ***********/
1396
1397 typedef struct structure_keyword_entry structure_keyword_entry;
1398 struct structure_keyword_entry
1399 {
1400   Lisp_Object keyword;
1401   int (*validate) (Lisp_Object keyword, Lisp_Object value,
1402                    Error_behavior errb);
1403 };
1404
1405 typedef struct
1406 {
1407   Dynarr_declare (structure_keyword_entry);
1408 } structure_keyword_entry_dynarr;
1409
1410 typedef struct structure_type structure_type;
1411 struct structure_type
1412 {
1413   Lisp_Object type;
1414   structure_keyword_entry_dynarr *keywords;
1415   int (*validate) (Lisp_Object data, Error_behavior errb);
1416   Lisp_Object (*instantiate) (Lisp_Object data);
1417 };
1418
1419 typedef struct
1420 {
1421   Dynarr_declare (structure_type);
1422 } structure_type_dynarr;
1423
1424 struct structure_type *define_structure_type (Lisp_Object type,
1425                                               int (*validate)
1426                                               (Lisp_Object data,
1427                                                Error_behavior errb),
1428                                               Lisp_Object (*instantiate)
1429                                               (Lisp_Object data));
1430 void define_structure_type_keyword (struct structure_type *st,
1431                                     Lisp_Object keyword,
1432                                     int (*validate) (Lisp_Object keyword,
1433                                                      Lisp_Object value,
1434                                                      Error_behavior errb));
1435
1436 /*********** weak lists ***********/
1437
1438 enum weak_list_type
1439 {
1440   /* element disappears if it's unmarked. */
1441   WEAK_LIST_SIMPLE,
1442   /* element disappears if it's a cons and either its car or
1443      cdr is unmarked. */
1444   WEAK_LIST_ASSOC,
1445   /* element disappears if it's a cons and its car is unmarked. */
1446   WEAK_LIST_KEY_ASSOC,
1447   /* element disappears if it's a cons and its cdr is unmarked. */
1448   WEAK_LIST_VALUE_ASSOC
1449 };
1450
1451 struct weak_list
1452 {
1453   struct lcrecord_header header;
1454   Lisp_Object list; /* don't mark through this! */
1455   enum weak_list_type type;
1456   Lisp_Object next_weak; /* don't mark through this! */
1457 };
1458
1459 DECLARE_LRECORD (weak_list, struct weak_list);
1460 #define XWEAK_LIST(x) XRECORD (x, weak_list, struct weak_list)
1461 #define XSETWEAK_LIST(x, p) XSETRECORD (x, p, weak_list)
1462 #define WEAK_LISTP(x) RECORDP (x, weak_list)
1463 #define GC_WEAK_LISTP(x) GC_RECORDP (x, weak_list)
1464 #define CHECK_WEAK_LIST(x) CHECK_RECORD (x, weak_list)
1465 #define CONCHECK_WEAK_LIST(x) CONCHECK_RECORD (x, weak_list)
1466
1467 #define weak_list_list(w) ((w)->list)
1468 #define XWEAK_LIST_LIST(w) (XWEAK_LIST (w)->list)
1469
1470 Lisp_Object make_weak_list (enum weak_list_type type);
1471 /* The following two are only called by the garbage collector */
1472 int finish_marking_weak_lists (int (*obj_marked_p) (Lisp_Object),
1473                                void (*markobj) (Lisp_Object));
1474 void prune_weak_lists (int (*obj_marked_p) (Lisp_Object));
1475
1476 /*********** lcrecord lists ***********/
1477
1478 struct lcrecord_list
1479 {
1480   struct lcrecord_header header;
1481   Lisp_Object free;
1482   size_t size;
1483   CONST struct lrecord_implementation *implementation;
1484 };
1485
1486 DECLARE_LRECORD (lcrecord_list, struct lcrecord_list);
1487 #define XLCRECORD_LIST(x) XRECORD (x, lcrecord_list, struct lcrecord_list)
1488 #define XSETLCRECORD_LIST(x, p) XSETRECORD (x, p, lcrecord_list)
1489 #define LCRECORD_LISTP(x) RECORDP (x, lcrecord_list)
1490 #define GC_LCRECORD_LISTP(x) GC_RECORDP (x, lcrecord_list)
1491 /* #define CHECK_LCRECORD_LIST(x) CHECK_RECORD (x, lcrecord_list)
1492    Lcrecord lists should never escape to the Lisp level, so
1493    functions should not be doing this. */
1494
1495 Lisp_Object make_lcrecord_list (size_t size,
1496                                 CONST struct lrecord_implementation
1497                                 *implementation);
1498 Lisp_Object allocate_managed_lcrecord (Lisp_Object lcrecord_list);
1499 void free_managed_lcrecord (Lisp_Object lcrecord_list, Lisp_Object lcrecord);
1500
1501 \f
1502 /************************************************************************/
1503 /*         Definitions of primitive Lisp functions and variables        */
1504 /************************************************************************/
1505
1506
1507 /* DEFUN - Define a built-in Lisp-visible C function or `subr'.
1508  `lname' should be the name to give the function in Lisp,
1509     as a null-terminated C string.
1510  `Fname' should be the C equivalent of `lname', using only characters
1511     valid in a C identifier, with an "F" prepended.
1512     The name of the C constant structure that records information
1513     on this function for internal use is "S" concatenated with Fname.
1514  `min_args' should be a number, the minimum number of arguments allowed.
1515  `max_args' should be a number, the maximum number of arguments allowed,
1516     or else MANY or UNEVALLED.
1517     MANY means pass a vector of evaluated arguments,
1518          in the form of an integer number-of-arguments
1519          followed by the address of a vector of Lisp_Objects
1520          which contains the argument values.
1521     UNEVALLED means pass the list of unevaluated arguments.
1522  `prompt' says how to read arguments for an interactive call.
1523     See the doc string for `interactive'.
1524     A null string means call interactively with no arguments.
1525  `arglist' are the comma-separated arguments (always Lisp_Objects) for
1526     the function.
1527   The docstring for the function is placed as a "C" comment between
1528     the prompt and the `args' argument.  make-docfile reads the
1529     comment and creates the DOC file from it.
1530 */
1531
1532 #define EXFUN_0 void
1533 #define EXFUN_1 Lisp_Object
1534 #define EXFUN_2 Lisp_Object,Lisp_Object
1535 #define EXFUN_3 Lisp_Object,Lisp_Object,Lisp_Object
1536 #define EXFUN_4 Lisp_Object,Lisp_Object,Lisp_Object,Lisp_Object
1537 #define EXFUN_5 Lisp_Object,Lisp_Object,Lisp_Object,Lisp_Object,Lisp_Object
1538 #define EXFUN_6 Lisp_Object,Lisp_Object,Lisp_Object,Lisp_Object,Lisp_Object, \
1539 Lisp_Object
1540 #define EXFUN_7 Lisp_Object,Lisp_Object,Lisp_Object,Lisp_Object,Lisp_Object, \
1541 Lisp_Object,Lisp_Object
1542 #define EXFUN_8 Lisp_Object,Lisp_Object,Lisp_Object,Lisp_Object,Lisp_Object, \
1543 Lisp_Object,Lisp_Object,Lisp_Object
1544 #define EXFUN_MANY int, Lisp_Object*
1545 #define EXFUN_UNEVALLED Lisp_Object
1546 #define EXFUN(sym, max_args) Lisp_Object sym (EXFUN_##max_args)
1547
1548 #define SUBR_MAX_ARGS 8
1549 #define MANY -2
1550 #define UNEVALLED -1
1551
1552 /* Can't be const, because then subr->doc is read-only and
1553    Snarf_documentation chokes */
1554
1555 #define subr_lheader_initializer { 0, 0, 0, 0 }
1556
1557 #define DEFUN(lname, Fname, min_args, max_args, prompt, arglist)        \
1558   Lisp_Object Fname (EXFUN_##max_args);                                 \
1559   static struct Lisp_Subr S##Fname = { subr_lheader_initializer,        \
1560         min_args, max_args, prompt, 0, lname, (lisp_fn_t) Fname };      \
1561   Lisp_Object Fname (DEFUN_##max_args arglist)
1562
1563 /* Heavy ANSI C preprocessor hackery to get DEFUN to declare a
1564    prototype that matches max_args, and add the obligatory
1565    `Lisp_Object' type declaration to the formal C arguments.  */
1566
1567 #define DEFUN_MANY(named_int, named_Lisp_Object) named_int, named_Lisp_Object
1568 #define DEFUN_UNEVALLED(args) Lisp_Object args
1569 #define DEFUN_0() void
1570 #define DEFUN_1(a)                                      Lisp_Object a
1571 #define DEFUN_2(a,b)             DEFUN_1(a),            Lisp_Object b
1572 #define DEFUN_3(a,b,c)           DEFUN_2(a,b),          Lisp_Object c
1573 #define DEFUN_4(a,b,c,d)         DEFUN_3(a,b,c),        Lisp_Object d
1574 #define DEFUN_5(a,b,c,d,e)       DEFUN_4(a,b,c,d),      Lisp_Object e
1575 #define DEFUN_6(a,b,c,d,e,f)     DEFUN_5(a,b,c,d,e),    Lisp_Object f
1576 #define DEFUN_7(a,b,c,d,e,f,g)   DEFUN_6(a,b,c,d,e,f),  Lisp_Object g
1577 #define DEFUN_8(a,b,c,d,e,f,g,h) DEFUN_7(a,b,c,d,e,f,g),Lisp_Object h
1578
1579 /* WARNING: If you add defines here for higher values of max_args,
1580    make sure to also fix the clauses in PRIMITIVE_FUNCALL(),
1581    and change the define of SUBR_MAX_ARGS above.  */
1582
1583 #include "symeval.h"
1584
1585 /* `specpdl' is the special binding/unwind-protect stack.
1586
1587    Knuth says (see the Jargon File):
1588    At MIT, `pdl' [abbreviation for `Push Down List'] used to
1589    be a more common synonym for `stack'.
1590    Everywhere else `stack' seems to be the preferred term.
1591
1592    specpdl_depth is the current depth of `specpdl'.
1593    Save this for use later as arg to `unbind_to'.  */
1594 extern int specpdl_depth_counter;
1595 #define specpdl_depth() specpdl_depth_counter
1596
1597 \f
1598 /************************************************************************/
1599 /*                         Checking for QUIT                            */
1600 /************************************************************************/
1601
1602 /* Asynchronous events set something_happened, and then are processed
1603    within the QUIT macro.  At this point, we are guaranteed to not be in
1604    any sensitive code. */
1605
1606 extern volatile int something_happened;
1607 int check_what_happened (void);
1608
1609 extern volatile int quit_check_signal_happened;
1610 extern volatile int quit_check_signal_tick_count;
1611 int check_quit (void);
1612
1613 void signal_quit (void);
1614
1615 /* Nonzero if ought to quit now.  */
1616 #define QUITP                                                   \
1617   ((quit_check_signal_happened ? check_quit () : 0),            \
1618    (!NILP (Vquit_flag) && (NILP (Vinhibit_quit)                 \
1619                            || EQ (Vquit_flag, Qcritical))))
1620
1621 /* QUIT used to call QUITP, but there are some places where QUITP
1622    is called directly, and check_what_happened() should only be called
1623    when Emacs is actually ready to quit because it could do things
1624    like switch threads. */
1625 #define INTERNAL_QUITP                                          \
1626   ((something_happened ? check_what_happened () : 0),           \
1627    (!NILP (Vquit_flag) &&                                       \
1628     (NILP (Vinhibit_quit) || EQ (Vquit_flag, Qcritical))))
1629
1630 #define INTERNAL_REALLY_QUITP                                   \
1631   (check_what_happened (),                                      \
1632    (!NILP (Vquit_flag) &&                                       \
1633     (NILP (Vinhibit_quit) || EQ (Vquit_flag, Qcritical))))
1634
1635 /* Check quit-flag and quit if it is non-nil.  Also do any other things
1636    that might have gotten queued until it was safe. */
1637 #define QUIT do { if (INTERNAL_QUITP) signal_quit (); } while (0)
1638
1639 #define REALLY_QUIT do { if (INTERNAL_REALLY_QUITP) signal_quit (); } while (0)
1640
1641 \f
1642 /************************************************************************/
1643 /*                               hashing                                */
1644 /************************************************************************/
1645
1646 /* #### for a 64-bit machine, we should substitute a prime just over 2^32 */
1647 #define GOOD_HASH 65599 /* prime number just over 2^16; Dragon book, p. 435 */
1648 #define HASH2(a,b)               (GOOD_HASH * (a)                     + (b))
1649 #define HASH3(a,b,c)             (GOOD_HASH * HASH2 (a,b)             + (c))
1650 #define HASH4(a,b,c,d)           (GOOD_HASH * HASH3 (a,b,c)           + (d))
1651 #define HASH5(a,b,c,d,e)         (GOOD_HASH * HASH4 (a,b,c,d)         + (e))
1652 #define HASH6(a,b,c,d,e,f)       (GOOD_HASH * HASH5 (a,b,c,d,e)       + (f))
1653 #define HASH7(a,b,c,d,e,f,g)     (GOOD_HASH * HASH6 (a,b,c,d,e,f)     + (g))
1654 #define HASH8(a,b,c,d,e,f,g,h)   (GOOD_HASH * HASH7 (a,b,c,d,e,f,g)   + (h))
1655 #define HASH9(a,b,c,d,e,f,g,h,i) (GOOD_HASH * HASH8 (a,b,c,d,e,f,g,h) + (i))
1656
1657 #define LISP_HASH(obj) ((unsigned long) LISP_TO_VOID (obj))
1658 unsigned long string_hash (CONST void *xv);
1659 unsigned long memory_hash (CONST void *xv, size_t size);
1660 unsigned long internal_hash (Lisp_Object obj, int depth);
1661 unsigned long internal_array_hash (Lisp_Object *arr, int size, int depth);
1662
1663 \f
1664 /************************************************************************/
1665 /*                       String translation                             */
1666 /************************************************************************/
1667
1668 #ifdef I18N3
1669 #ifdef HAVE_LIBINTL_H
1670 #include <libintl.h>
1671 #else
1672 char *dgettext       (CONST char *, CONST char *);
1673 char *gettext        (CONST char *);
1674 char *textdomain     (CONST char *);
1675 char *bindtextdomain (CONST char *, CONST char *);
1676 #endif /* HAVE_LIBINTL_H */
1677
1678 #define GETTEXT(x)  gettext(x)
1679 #define LISP_GETTEXT(x)  Fgettext (x)
1680 #else /* !I18N3 */
1681 #define GETTEXT(x)  (x)
1682 #define LISP_GETTEXT(x)  (x)
1683 #endif /* !I18N3 */
1684
1685 /* DEFER_GETTEXT is used to identify strings which are translated when
1686    they are referenced instead of when they are defined.
1687    These include Qerror_messages and initialized arrays of strings.
1688 */
1689 #define DEFER_GETTEXT(x) (x)
1690
1691 \f
1692 /************************************************************************/
1693 /*                   Garbage collection / GC-protection                 */
1694 /************************************************************************/
1695
1696 /* number of bytes of structure consed since last GC */
1697
1698 extern EMACS_INT consing_since_gc;
1699
1700 /* threshold for doing another gc */
1701
1702 extern EMACS_INT gc_cons_threshold;
1703
1704 /* Structure for recording stack slots that need marking */
1705
1706 /* This is a chain of structures, each of which points at a Lisp_Object
1707    variable whose value should be marked in garbage collection.
1708    Normally every link of the chain is an automatic variable of a function,
1709    and its `val' points to some argument or local variable of the function.
1710    On exit to the function, the chain is set back to the value it had on
1711    entry.  This way, no link remains in the chain when the stack frame
1712    containing the link disappears.
1713
1714    Every function that can call Feval must protect in this fashion all
1715    Lisp_Object variables whose contents will be used again. */
1716
1717 extern struct gcpro *gcprolist;
1718
1719 struct gcpro
1720 {
1721   struct gcpro *next;
1722   Lisp_Object *var;             /* Address of first protected variable */
1723   int nvars;                    /* Number of consecutive protected variables */
1724 };
1725
1726 /* Normally, you declare variables gcpro1, gcpro2, ... and use the
1727    GCPROn() macros.  However, if you need to have nested gcpro's,
1728    declare ngcpro1, ngcpro2, ... and use NGCPROn().  If you need
1729    to nest another level, use nngcpro1, nngcpro2, ... and use
1730    NNGCPROn().  If you need to nest yet another level, create
1731    the appropriate macros. */
1732
1733 #ifdef DEBUG_GCPRO
1734
1735 void debug_gcpro1 (char *, int, struct gcpro *, Lisp_Object *);
1736 void debug_gcpro2 (char *, int, struct gcpro *, struct gcpro *,
1737                    Lisp_Object *, Lisp_Object *);
1738 void debug_gcpro3 (char *, int, struct gcpro *, struct gcpro *, struct gcpro *,
1739                    Lisp_Object *, Lisp_Object *, Lisp_Object *);
1740 void debug_gcpro4 (char *, int, struct gcpro *, struct gcpro *, struct gcpro *,
1741                    struct gcpro *, Lisp_Object *, Lisp_Object *, Lisp_Object *,
1742                    Lisp_Object *);
1743 void debug_gcpro5 (char *, int, struct gcpro *, struct gcpro *, struct gcpro *,
1744                    struct gcpro *, struct gcpro *, Lisp_Object *, Lisp_Object *,
1745                    Lisp_Object *, Lisp_Object *, Lisp_Object *);
1746 void debug_ungcpro(char *, int, struct gcpro *);
1747
1748 #define GCPRO1(v) \
1749  debug_gcpro1 (__FILE__, __LINE__,&gcpro1,&v)
1750 #define GCPRO2(v1,v2) \
1751  debug_gcpro2 (__FILE__, __LINE__,&gcpro1,&gcpro2,&v1,&v2)
1752 #define GCPRO3(v1,v2,v3) \
1753  debug_gcpro3 (__FILE__, __LINE__,&gcpro1,&gcpro2,&gcpro3,&v1,&v2,&v3)
1754 #define GCPRO4(v1,v2,v3,v4) \
1755  debug_gcpro4 (__FILE__, __LINE__,&gcpro1,&gcpro2,&gcpro3,&gcpro4,\
1756                &v1,&v2,&v3,&v4)
1757 #define GCPRO5(v1,v2,v3,v4,v5) \
1758  debug_gcpro5 (__FILE__, __LINE__,&gcpro1,&gcpro2,&gcpro3,&gcpro4,&gcpro5,\
1759                &v1,&v2,&v3,&v4,&v5)
1760 #define UNGCPRO \
1761  debug_ungcpro(__FILE__, __LINE__,&gcpro1)
1762
1763 #define NGCPRO1(v) \
1764  debug_gcpro1 (__FILE__, __LINE__,&ngcpro1,&v)
1765 #define NGCPRO2(v1,v2) \
1766  debug_gcpro2 (__FILE__, __LINE__,&ngcpro1,&ngcpro2,&v1,&v2)
1767 #define NGCPRO3(v1,v2,v3) \
1768  debug_gcpro3 (__FILE__, __LINE__,&ngcpro1,&ngcpro2,&ngcpro3,&v1,&v2,&v3)
1769 #define NGCPRO4(v1,v2,v3,v4) \
1770  debug_gcpro4 (__FILE__, __LINE__,&ngcpro1,&ngcpro2,&ngcpro3,&ngcpro4,\
1771                &v1,&v2,&v3,&v4)
1772 #define NGCPRO5(v1,v2,v3,v4,v5) \
1773  debug_gcpro5 (__FILE__, __LINE__,&ngcpro1,&ngcpro2,&ngcpro3,&ngcpro4,\
1774                &ngcpro5,&v1,&v2,&v3,&v4,&v5)
1775 #define NUNGCPRO \
1776  debug_ungcpro(__FILE__, __LINE__,&ngcpro1)
1777
1778 #define NNGCPRO1(v) \
1779  debug_gcpro1 (__FILE__, __LINE__,&nngcpro1,&v)
1780 #define NNGCPRO2(v1,v2) \
1781  debug_gcpro2 (__FILE__, __LINE__,&nngcpro1,&nngcpro2,&v1,&v2)
1782 #define NNGCPRO3(v1,v2,v3) \
1783  debug_gcpro3 (__FILE__, __LINE__,&nngcpro1,&nngcpro2,&nngcpro3,&v1,&v2,&v3)
1784 #define NNGCPRO4(v1,v2,v3,v4) \
1785  debug_gcpro4 (__FILE__, __LINE__,&nngcpro1,&nngcpro2,&nngcpro3,&nngcpro4,\
1786                &v1,&v2,&v3,&v4)
1787 #define NNGCPRO5(v1,v2,v3,v4,v5) \
1788  debug_gcpro5 (__FILE__, __LINE__,&nngcpro1,&nngcpro2,&nngcpro3,&nngcpro4,\
1789                &nngcpro5,&v1,&v2,&v3,&v4,&v5)
1790 #define NNUNGCPRO \
1791  debug_ungcpro(__FILE__, __LINE__,&nngcpro1)
1792
1793 #else /* ! DEBUG_GCPRO */
1794
1795 #define GCPRO1(var1) ((void) (                                          \
1796   gcpro1.next = gcprolist, gcpro1.var = &var1, gcpro1.nvars = 1,        \
1797   gcprolist = &gcpro1 ))
1798
1799 #define GCPRO2(var1, var2) ((void) (                                    \
1800   gcpro1.next = gcprolist, gcpro1.var = &var1, gcpro1.nvars = 1,        \
1801   gcpro2.next = &gcpro1,   gcpro2.var = &var2, gcpro2.nvars = 1,        \
1802   gcprolist = &gcpro2 ))
1803
1804 #define GCPRO3(var1, var2, var3) ((void) (                              \
1805   gcpro1.next = gcprolist, gcpro1.var = &var1, gcpro1.nvars = 1,        \
1806   gcpro2.next = &gcpro1,   gcpro2.var = &var2, gcpro2.nvars = 1,        \
1807   gcpro3.next = &gcpro2,   gcpro3.var = &var3, gcpro3.nvars = 1,        \
1808   gcprolist = &gcpro3 ))
1809
1810 #define GCPRO4(var1, var2, var3, var4) ((void) (                        \
1811   gcpro1.next = gcprolist, gcpro1.var = &var1, gcpro1.nvars = 1,        \
1812   gcpro2.next = &gcpro1,   gcpro2.var = &var2, gcpro2.nvars = 1,        \
1813   gcpro3.next = &gcpro2,   gcpro3.var = &var3, gcpro3.nvars = 1,        \
1814   gcpro4.next = &gcpro3,   gcpro4.var = &var4, gcpro4.nvars = 1,        \
1815   gcprolist = &gcpro4 ))
1816
1817 #define GCPRO5(var1, var2, var3, var4, var5)                            \
1818   ((void) (                                                             \
1819   gcpro1.next = gcprolist, gcpro1.var = &var1, gcpro1.nvars = 1,        \
1820   gcpro2.next = &gcpro1,   gcpro2.var = &var2, gcpro2.nvars = 1,        \
1821   gcpro3.next = &gcpro2,   gcpro3.var = &var3, gcpro3.nvars = 1,        \
1822   gcpro4.next = &gcpro3,   gcpro4.var = &var4, gcpro4.nvars = 1,        \
1823   gcpro5.next = &gcpro4,   gcpro5.var = &var5, gcpro5.nvars = 1,        \
1824   gcprolist = &gcpro5 ))
1825
1826 #define UNGCPRO ((void) (gcprolist = gcpro1.next))
1827
1828 #define NGCPRO1(var1) ((void) (                                         \
1829   ngcpro1.next = gcprolist, ngcpro1.var = &var1, ngcpro1.nvars = 1,     \
1830   gcprolist = &ngcpro1 ))
1831
1832 #define NGCPRO2(var1, var2) ((void) (                                   \
1833   ngcpro1.next = gcprolist, ngcpro1.var = &var1, ngcpro1.nvars = 1,     \
1834   ngcpro2.next = &ngcpro1,  ngcpro2.var = &var2, ngcpro2.nvars = 1,     \
1835   gcprolist = &ngcpro2 ))
1836
1837 #define NGCPRO3(var1, var2, var3) ((void) (                             \
1838   ngcpro1.next = gcprolist, ngcpro1.var = &var1, ngcpro1.nvars = 1,     \
1839   ngcpro2.next = &ngcpro1,  ngcpro2.var = &var2, ngcpro2.nvars = 1,     \
1840   ngcpro3.next = &ngcpro2,  ngcpro3.var = &var3, ngcpro3.nvars = 1,     \
1841   gcprolist = &ngcpro3 ))
1842
1843 #define NGCPRO4(var1, var2, var3, var4) ((void) (                       \
1844   ngcpro1.next = gcprolist, ngcpro1.var = &var1, ngcpro1.nvars = 1,     \
1845   ngcpro2.next = &ngcpro1,  ngcpro2.var = &var2, ngcpro2.nvars = 1,     \
1846   ngcpro3.next = &ngcpro2,  ngcpro3.var = &var3, ngcpro3.nvars = 1,     \
1847   ngcpro4.next = &ngcpro3,  ngcpro4.var = &var4, ngcpro4.nvars = 1,     \
1848   gcprolist = &ngcpro4 ))
1849
1850 #define NGCPRO5(var1, var2, var3, var4, var5)                           \
1851   ((void) (                                                             \
1852   ngcpro1.next = gcprolist, ngcpro1.var = &var1, ngcpro1.nvars = 1,     \
1853   ngcpro2.next = &ngcpro1,  ngcpro2.var = &var2, ngcpro2.nvars = 1,     \
1854   ngcpro3.next = &ngcpro2,  ngcpro3.var = &var3, ngcpro3.nvars = 1,     \
1855   ngcpro4.next = &ngcpro3,  ngcpro4.var = &var4, ngcpro4.nvars = 1,     \
1856   ngcpro5.next = &ngcpro4,  ngcpro5.var = &var5, ngcpro5.nvars = 1,     \
1857   gcprolist = &ngcpro5 ))
1858
1859 #define NUNGCPRO ((void) (gcprolist = ngcpro1.next))
1860
1861 #define NNGCPRO1(var1) ((void) (                                        \
1862   nngcpro1.next = gcprolist, nngcpro1.var = &var1, nngcpro1.nvars = 1,  \
1863   gcprolist = &nngcpro1 ))
1864
1865 #define NNGCPRO2(var1, var2) ((void) (                                  \
1866   nngcpro1.next = gcprolist, nngcpro1.var = &var1, nngcpro1.nvars = 1,  \
1867   nngcpro2.next = &nngcpro1, nngcpro2.var = &var2, nngcpro2.nvars = 1,  \
1868   gcprolist = &nngcpro2 ))
1869
1870 #define NNGCPRO3(var1, var2, var3) ((void) (                            \
1871   nngcpro1.next = gcprolist, nngcpro1.var = &var1, nngcpro1.nvars = 1,  \
1872   nngcpro2.next = &nngcpro1, nngcpro2.var = &var2, nngcpro2.nvars = 1,  \
1873   nngcpro3.next = &nngcpro2, nngcpro3.var = &var3, nngcpro3.nvars = 1,  \
1874   gcprolist = &nngcpro3 ))
1875
1876 #define NNGCPRO4(var1, var2, var3, var4)  ((void) (                     \
1877   nngcpro1.next = gcprolist, nngcpro1.var = &var1, nngcpro1.nvars = 1,  \
1878   nngcpro2.next = &nngcpro1, nngcpro2.var = &var2, nngcpro2.nvars = 1,  \
1879   nngcpro3.next = &nngcpro2, nngcpro3.var = &var3, nngcpro3.nvars = 1,  \
1880   nngcpro4.next = &nngcpro3, nngcpro4.var = &var4, nngcpro4.nvars = 1,  \
1881   gcprolist = &nngcpro4 ))
1882
1883 #define NNGCPRO5(var1, var2, var3, var4, var5)                          \
1884   ((void) (                                                             \
1885   nngcpro1.next = gcprolist, nngcpro1.var = &var1, nngcpro1.nvars = 1,  \
1886   nngcpro2.next = &nngcpro1, nngcpro2.var = &var2, nngcpro2.nvars = 1,  \
1887   nngcpro3.next = &nngcpro2, nngcpro3.var = &var3, nngcpro3.nvars = 1,  \
1888   nngcpro4.next = &nngcpro3, nngcpro4.var = &var4, nngcpro4.nvars = 1,  \
1889   nngcpro5.next = &nngcpro4, nngcpro5.var = &var5, nngcpro5.nvars = 1,  \
1890   gcprolist = &nngcpro5 ))
1891
1892 #define NNUNGCPRO ((void) (gcprolist = nngcpro1.next))
1893
1894 #endif /* ! DEBUG_GCPRO */
1895
1896 /* Another try to fix SunPro C compiler warnings */
1897 /* "end-of-loop code not reached" */
1898 /* "statement not reached */
1899 #ifdef __SUNPRO_C
1900 #define RETURN_SANS_WARNINGS if (1) return
1901 #define RETURN_NOT_REACHED(value)
1902 #else
1903 #define RETURN_SANS_WARNINGS return
1904 #define RETURN_NOT_REACHED(value) return value;
1905 #endif
1906
1907 /* Evaluate expr, UNGCPRO, and then return the value of expr.  */
1908 #define RETURN_UNGCPRO(expr) do         \
1909 {                                       \
1910   Lisp_Object ret_ungc_val = (expr);    \
1911   UNGCPRO;                              \
1912   RETURN_SANS_WARNINGS ret_ungc_val;    \
1913 } while (0)
1914
1915 /* Evaluate expr, NUNGCPRO, UNGCPRO, and then return the value of expr.  */
1916 #define RETURN_NUNGCPRO(expr) do        \
1917 {                                       \
1918   Lisp_Object ret_ungc_val = (expr);    \
1919   NUNGCPRO;                             \
1920   UNGCPRO;                              \
1921   RETURN_SANS_WARNINGS ret_ungc_val;    \
1922 } while (0)
1923
1924 /* Evaluate expr, NNUNGCPRO, NUNGCPRO, UNGCPRO, and then return the
1925    value of expr.  */
1926 #define RETURN_NNUNGCPRO(expr) do       \
1927 {                                       \
1928   Lisp_Object ret_ungc_val = (expr);    \
1929   NNUNGCPRO;                            \
1930   NUNGCPRO;                             \
1931   UNGCPRO;                              \
1932   RETURN_SANS_WARNINGS ret_ungc_val;    \
1933 } while (0)
1934
1935 /* Evaluate expr, return it if it's not Qunbound. */
1936 #define RETURN_IF_NOT_UNBOUND(expr) do  \
1937 {                                       \
1938   Lisp_Object ret_nunb_val = (expr);    \
1939   if (!UNBOUNDP (ret_nunb_val))         \
1940     RETURN_SANS_WARNINGS ret_nunb_val;  \
1941 } while (0)
1942
1943 /* Call staticpro (&var) to protect static variable `var'. */
1944 void staticpro (Lisp_Object *);
1945
1946 /* Nonzero means Emacs has already been initialized.
1947    Used during startup to detect startup of dumped Emacs.  */
1948 extern int initialized;
1949
1950 #ifdef MEMORY_USAGE_STATS
1951
1952 /* This structure is used to keep statistics on the amount of memory
1953    in use.
1954
1955    WAS_REQUESTED stores the actual amount of memory that was requested
1956    of the allocation function.  The *_OVERHEAD fields store the
1957    additional amount of memory that was grabbed by the functions to
1958    facilitate allocation, reallocation, etc.  MALLOC_OVERHEAD is for
1959    memory allocated with malloc(); DYNARR_OVERHEAD is for dynamic
1960    arrays; GAP_OVERHEAD is for gap arrays.  Note that for (e.g.)
1961    dynamic arrays, there is both MALLOC_OVERHEAD and DYNARR_OVERHEAD
1962    memory: The dynamic array allocates memory above and beyond what
1963    was asked of it, and when it in turns allocates memory using
1964    malloc(), malloc() allocates memory beyond what it was asked
1965    to allocate.
1966
1967    Functions that accept a structure of this sort do not initialize
1968    the fields to 0, and add any existing values to whatever was there
1969    before; this way, you can get a cumulative effect. */
1970
1971 struct overhead_stats
1972 {
1973   int was_requested;
1974   int malloc_overhead;
1975   int dynarr_overhead;
1976   int gap_overhead;
1977 };
1978
1979 #endif /* MEMORY_USAGE_STATS */
1980
1981 #ifndef DIRECTORY_SEP
1982 #define DIRECTORY_SEP '/'
1983 #endif
1984 #ifndef IS_DIRECTORY_SEP
1985 #define IS_DIRECTORY_SEP(c) ((c) == DIRECTORY_SEP)
1986 #endif
1987 #ifndef IS_DEVICE_SEP
1988 #ifndef DEVICE_SEP
1989 #define IS_DEVICE_SEP(c) 0
1990 #else
1991 #define IS_DEVICE_SEP(c) ((c) == DEVICE_SEP)
1992 #endif
1993 #endif
1994 #ifndef IS_ANY_SEP
1995 #define IS_ANY_SEP(c) (IS_DIRECTORY_SEP (c))
1996 #endif
1997
1998 #ifdef HAVE_INTTYPES_H
1999 #include <inttypes.h>
2000 #elif SIZEOF_VOID_P == SIZEOF_INT
2001 typedef int intptr_t;
2002 typedef unsigned int uintptr_t;
2003 #elif SIZEOF_VOID_P == SIZEOF_LONG
2004 typedef long intptr_t;
2005 typedef unsigned long uintptr_t;
2006 #elif defined(SIZEOF_LONG_LONG) && SIZEOF_VOID_P == SIZEOF_LONG_LONG
2007 typedef long long intptr_t;
2008 typedef unsigned long long uintptr_t;
2009 #else
2010 /* Just pray. May break, may not. */
2011 typedef long intptr_t;
2012 typedef unsigned long uintptr_t;
2013 #endif
2014
2015 /* Defined in alloc.c */
2016 void release_breathing_space (void);
2017 Lisp_Object noseeum_cons (Lisp_Object, Lisp_Object);
2018 Lisp_Object make_vector (size_t, Lisp_Object);
2019 Lisp_Object vector1 (Lisp_Object);
2020 Lisp_Object vector2 (Lisp_Object, Lisp_Object);
2021 Lisp_Object vector3 (Lisp_Object, Lisp_Object, Lisp_Object);
2022 Lisp_Object make_bit_vector (size_t, Lisp_Object);
2023 Lisp_Object make_bit_vector_from_byte_vector (unsigned char *, size_t);
2024 Lisp_Object noseeum_make_marker (void);
2025 void garbage_collect_1 (void);
2026 Lisp_Object acons (Lisp_Object, Lisp_Object, Lisp_Object);
2027 Lisp_Object cons3 (Lisp_Object, Lisp_Object, Lisp_Object);
2028 Lisp_Object list1 (Lisp_Object);
2029 Lisp_Object list2 (Lisp_Object, Lisp_Object);
2030 Lisp_Object list3 (Lisp_Object, Lisp_Object, Lisp_Object);
2031 Lisp_Object list4 (Lisp_Object, Lisp_Object, Lisp_Object, Lisp_Object);
2032 Lisp_Object list5 (Lisp_Object, Lisp_Object, Lisp_Object, Lisp_Object,
2033                    Lisp_Object);
2034 Lisp_Object list6 (Lisp_Object, Lisp_Object, Lisp_Object, Lisp_Object,
2035                    Lisp_Object, Lisp_Object);
2036 DECLARE_DOESNT_RETURN (memory_full (void));
2037 void disksave_object_finalization (void);
2038 extern int purify_flag;
2039 extern int gc_currently_forbidden;
2040 Lisp_Object restore_gc_inhibit (Lisp_Object);
2041 extern EMACS_INT gc_generation_number[1];
2042 int c_readonly (Lisp_Object);
2043 int lisp_readonly (Lisp_Object);
2044 Lisp_Object build_string (CONST char *);
2045 Lisp_Object build_ext_string (CONST char *, enum external_data_format);
2046 Lisp_Object build_translated_string (CONST char *);
2047 Lisp_Object make_string (CONST Bufbyte *, Bytecount);
2048 Lisp_Object make_ext_string (CONST Extbyte *, EMACS_INT,
2049                              enum external_data_format);
2050 Lisp_Object make_uninit_string (Bytecount);
2051 Lisp_Object make_float (double);
2052 Lisp_Object make_string_nocopy (CONST Bufbyte *, Bytecount);
2053 void free_cons (Lisp_Cons *);
2054 void free_list (Lisp_Object);
2055 void free_alist (Lisp_Object);
2056 void mark_conses_in_list (Lisp_Object);
2057 void free_marker (Lisp_Marker *);
2058 int object_dead_p (Lisp_Object);
2059
2060 #ifdef MEMORY_USAGE_STATS
2061 size_t malloced_storage_size (void *, size_t, struct overhead_stats *);
2062 size_t fixed_type_block_overhead (size_t);
2063 #endif
2064
2065 /* Defined in buffer.c */
2066 Lisp_Object make_buffer (struct buffer *);
2067 Lisp_Object get_truename_buffer (Lisp_Object);
2068 void switch_to_buffer (Lisp_Object, Lisp_Object);
2069 extern int find_file_compare_truenames;
2070 extern int find_file_use_truenames;
2071
2072 /* Defined in callproc.c */
2073 char *egetenv (CONST char *);
2074
2075 /* Defined in console.c */
2076 void stuff_buffered_input (Lisp_Object);
2077
2078 /* Defined in data.c */
2079 DECLARE_DOESNT_RETURN (c_write_error (Lisp_Object));
2080 DECLARE_DOESNT_RETURN (lisp_write_error (Lisp_Object));
2081 DECLARE_DOESNT_RETURN (args_out_of_range (Lisp_Object, Lisp_Object));
2082 DECLARE_DOESNT_RETURN (args_out_of_range_3 (Lisp_Object, Lisp_Object,
2083                                             Lisp_Object));
2084 Lisp_Object wrong_type_argument (Lisp_Object, Lisp_Object);
2085 DECLARE_DOESNT_RETURN (dead_wrong_type_argument (Lisp_Object, Lisp_Object));
2086 void check_int_range (int, int, int);
2087
2088 enum arith_comparison {
2089   arith_equal,
2090   arith_notequal,
2091   arith_less,
2092   arith_grtr,
2093   arith_less_or_equal,
2094   arith_grtr_or_equal };
2095 Lisp_Object arithcompare (Lisp_Object, Lisp_Object, enum arith_comparison);
2096
2097 Lisp_Object word_to_lisp (unsigned int);
2098 unsigned int lisp_to_word (Lisp_Object);
2099
2100 /* Defined in dired.c */
2101 Lisp_Object make_directory_hash_table (CONST char *);
2102 Lisp_Object wasteful_word_to_lisp (unsigned int);
2103
2104 /* Defined in doc.c */
2105 Lisp_Object unparesseuxify_doc_string (int, EMACS_INT, char *, Lisp_Object);
2106 Lisp_Object read_doc_string (Lisp_Object);
2107
2108 /* Defined in doprnt.c */
2109 Bytecount emacs_doprnt_c (Lisp_Object, CONST Bufbyte *, Lisp_Object,
2110                           Bytecount, ...);
2111 Bytecount emacs_doprnt_va (Lisp_Object, CONST Bufbyte *, Lisp_Object,
2112                            Bytecount, va_list);
2113 Bytecount emacs_doprnt_lisp (Lisp_Object, CONST Bufbyte *, Lisp_Object,
2114                              Bytecount, int, CONST Lisp_Object *);
2115 Bytecount emacs_doprnt_lisp_2 (Lisp_Object, CONST Bufbyte *, Lisp_Object,
2116                                Bytecount, int, ...);
2117 Lisp_Object emacs_doprnt_string_c (CONST Bufbyte *, Lisp_Object,
2118                                    Bytecount, ...);
2119 Lisp_Object emacs_doprnt_string_va (CONST Bufbyte *, Lisp_Object,
2120                                     Bytecount, va_list);
2121 Lisp_Object emacs_doprnt_string_lisp (CONST Bufbyte *, Lisp_Object,
2122                                       Bytecount, int, CONST Lisp_Object *);
2123 Lisp_Object emacs_doprnt_string_lisp_2 (CONST Bufbyte *, Lisp_Object,
2124                                         Bytecount, int, ...);
2125
2126 /* Defined in editfns.c */
2127 void uncache_home_directory (void);
2128 char *get_home_directory (void);
2129 char *user_login_name (int *);
2130 Bufpos bufpos_clip_to_bounds (Bufpos, Bufpos, Bufpos);
2131 Bytind bytind_clip_to_bounds (Bytind, Bytind, Bytind);
2132 void buffer_insert1 (struct buffer *, Lisp_Object);
2133 Lisp_Object make_string_from_buffer (struct buffer *, int, int);
2134 Lisp_Object make_string_from_buffer_no_extents (struct buffer *, int, int);
2135 Lisp_Object save_excursion_save (void);
2136 Lisp_Object save_restriction_save (void);
2137 Lisp_Object save_excursion_restore (Lisp_Object);
2138 Lisp_Object save_restriction_restore (Lisp_Object);
2139
2140 /* Defined in emacsfns.c */
2141 Lisp_Object save_current_buffer_restore (Lisp_Object);
2142
2143 /* Defined in emacs.c */
2144 DECLARE_DOESNT_RETURN_GCC_ATTRIBUTE_SYNTAX_SUCKS (fatal (CONST char *,
2145                                                            ...), 1, 2);
2146 int stderr_out (CONST char *, ...) PRINTF_ARGS (1, 2);
2147 int stdout_out (CONST char *, ...) PRINTF_ARGS (1, 2);
2148 SIGTYPE fatal_error_signal (int);
2149 Lisp_Object make_arg_list (int, char **);
2150 void make_argc_argv (Lisp_Object, int *, char ***);
2151 void free_argc_argv (char **);
2152 Lisp_Object decode_env_path (CONST char *, CONST char *);
2153 Lisp_Object decode_path (CONST char *);
2154 /* Nonzero means don't do interactive redisplay and don't change tty modes */
2155 extern int noninteractive;
2156 extern int preparing_for_armageddon;
2157 extern int emacs_priority;
2158 extern int running_asynch_code;
2159 extern int suppress_early_error_handler_backtrace;
2160
2161 /* Defined in eval.c */
2162 DECLARE_DOESNT_RETURN (signal_error (Lisp_Object, Lisp_Object));
2163 void maybe_signal_error (Lisp_Object, Lisp_Object, Lisp_Object, Error_behavior);
2164 Lisp_Object maybe_signal_continuable_error (Lisp_Object, Lisp_Object,
2165                                             Lisp_Object, Error_behavior);
2166 DECLARE_DOESNT_RETURN_GCC_ATTRIBUTE_SYNTAX_SUCKS (error (CONST char *,
2167                                                            ...), 1, 2);
2168 void maybe_error (Lisp_Object, Error_behavior, CONST char *,
2169                   ...) PRINTF_ARGS (3, 4);
2170 Lisp_Object continuable_error (CONST char *, ...) PRINTF_ARGS (1, 2);
2171 Lisp_Object maybe_continuable_error (Lisp_Object, Error_behavior,
2172                                      CONST char *, ...) PRINTF_ARGS (3, 4);
2173 DECLARE_DOESNT_RETURN (signal_simple_error (CONST char *, Lisp_Object));
2174 void maybe_signal_simple_error (CONST char *, Lisp_Object,
2175                                 Lisp_Object, Error_behavior);
2176 Lisp_Object signal_simple_continuable_error (CONST char *, Lisp_Object);
2177 Lisp_Object maybe_signal_simple_continuable_error (CONST char *, Lisp_Object,
2178                                                    Lisp_Object, Error_behavior);
2179 DECLARE_DOESNT_RETURN_GCC_ATTRIBUTE_SYNTAX_SUCKS (error_with_frob
2180                                                     (Lisp_Object, CONST char *,
2181                                                      ...), 2, 3);
2182 void maybe_error_with_frob (Lisp_Object, Lisp_Object, Error_behavior,
2183                             CONST char *, ...) PRINTF_ARGS (4, 5);
2184 Lisp_Object continuable_error_with_frob (Lisp_Object, CONST char *,
2185                                          ...) PRINTF_ARGS (2, 3);
2186 Lisp_Object maybe_continuable_error_with_frob
2187 (Lisp_Object, Lisp_Object, Error_behavior, CONST char *, ...) PRINTF_ARGS (4, 5);
2188 DECLARE_DOESNT_RETURN (signal_simple_error_2 (CONST char *,
2189                                               Lisp_Object, Lisp_Object));
2190 void maybe_signal_simple_error_2 (CONST char *, Lisp_Object, Lisp_Object,
2191                                   Lisp_Object, Error_behavior);
2192 Lisp_Object signal_simple_continuable_error_2 (CONST char *,
2193                                                Lisp_Object, Lisp_Object);
2194 Lisp_Object maybe_signal_simple_continuable_error_2 (CONST char *, Lisp_Object,
2195                                                      Lisp_Object, Lisp_Object,
2196                                                      Error_behavior);
2197 void signal_malformed_list_error (Lisp_Object);
2198 void signal_malformed_property_list_error (Lisp_Object);
2199 void signal_circular_list_error (Lisp_Object);
2200 void signal_circular_property_list_error (Lisp_Object);
2201 void signal_void_function_error (Lisp_Object);
2202 Lisp_Object run_hook_with_args_in_buffer (struct buffer *, int, Lisp_Object *,
2203                                           enum run_hooks_condition);
2204 Lisp_Object run_hook_with_args (int, Lisp_Object *, enum run_hooks_condition);
2205 void va_run_hook_with_args (Lisp_Object, int, ...);
2206 void va_run_hook_with_args_in_buffer (struct buffer *, Lisp_Object, int, ...);
2207 Lisp_Object run_hook (Lisp_Object);
2208 Lisp_Object apply1 (Lisp_Object, Lisp_Object);
2209 Lisp_Object call0 (Lisp_Object);
2210 Lisp_Object call1 (Lisp_Object, Lisp_Object);
2211 Lisp_Object call2 (Lisp_Object, Lisp_Object, Lisp_Object);
2212 Lisp_Object call3 (Lisp_Object, Lisp_Object, Lisp_Object, Lisp_Object);
2213 Lisp_Object call4 (Lisp_Object, Lisp_Object, Lisp_Object, Lisp_Object,
2214                    Lisp_Object);
2215 Lisp_Object call5 (Lisp_Object, Lisp_Object, Lisp_Object, Lisp_Object,
2216                    Lisp_Object, Lisp_Object);
2217 Lisp_Object call6 (Lisp_Object, Lisp_Object, Lisp_Object, Lisp_Object,
2218                    Lisp_Object, Lisp_Object, Lisp_Object);
2219 Lisp_Object call7 (Lisp_Object, Lisp_Object, Lisp_Object, Lisp_Object,
2220                    Lisp_Object, Lisp_Object, Lisp_Object, Lisp_Object);
2221 Lisp_Object call8 (Lisp_Object, Lisp_Object, Lisp_Object, Lisp_Object,
2222                    Lisp_Object, Lisp_Object, Lisp_Object, Lisp_Object,
2223                    Lisp_Object);
2224 Lisp_Object call0_in_buffer (struct buffer *, Lisp_Object);
2225 Lisp_Object call1_in_buffer (struct buffer *, Lisp_Object, Lisp_Object);
2226 Lisp_Object call2_in_buffer (struct buffer *, Lisp_Object, Lisp_Object,
2227                              Lisp_Object);
2228 Lisp_Object call3_in_buffer (struct buffer *, Lisp_Object, Lisp_Object,
2229                              Lisp_Object, Lisp_Object);
2230 Lisp_Object call4_in_buffer (struct buffer *, Lisp_Object, Lisp_Object,
2231                              Lisp_Object, Lisp_Object, Lisp_Object);
2232 Lisp_Object call5_in_buffer (struct buffer *, Lisp_Object, Lisp_Object,
2233                              Lisp_Object, Lisp_Object, Lisp_Object,
2234                              Lisp_Object);
2235 Lisp_Object call6_in_buffer (struct buffer *, Lisp_Object, Lisp_Object,
2236                              Lisp_Object, Lisp_Object, Lisp_Object,
2237                              Lisp_Object, Lisp_Object);
2238 Lisp_Object eval_in_buffer (struct buffer *, Lisp_Object);
2239 Lisp_Object call0_with_handler (Lisp_Object, Lisp_Object);
2240 Lisp_Object call1_with_handler (Lisp_Object, Lisp_Object, Lisp_Object);
2241 Lisp_Object eval_in_buffer_trapping_errors (CONST char *, struct buffer *,
2242                                             Lisp_Object);
2243 Lisp_Object run_hook_trapping_errors (CONST char *, Lisp_Object);
2244 Lisp_Object safe_run_hook_trapping_errors (CONST char *, Lisp_Object, int);
2245 Lisp_Object call0_trapping_errors (CONST char *, Lisp_Object);
2246 Lisp_Object call1_trapping_errors (CONST char *, Lisp_Object, Lisp_Object);
2247 Lisp_Object call2_trapping_errors (CONST char *,
2248                                    Lisp_Object, Lisp_Object, Lisp_Object);
2249 Lisp_Object call_with_suspended_errors (lisp_fn_t, volatile Lisp_Object, Lisp_Object,
2250                                         Error_behavior, int, ...);
2251 /* C Code should be using internal_catch, record_unwind_p, condition_case_1 */
2252 Lisp_Object internal_catch (Lisp_Object, Lisp_Object (*) (Lisp_Object),
2253                             Lisp_Object, int * volatile);
2254 Lisp_Object condition_case_1 (Lisp_Object,
2255                               Lisp_Object (*) (Lisp_Object),
2256                               Lisp_Object,
2257                               Lisp_Object (*) (Lisp_Object, Lisp_Object),
2258                               Lisp_Object);
2259 Lisp_Object condition_case_3 (Lisp_Object, Lisp_Object, Lisp_Object);
2260 Lisp_Object unbind_to (int, Lisp_Object);
2261 void specbind (Lisp_Object, Lisp_Object);
2262 void record_unwind_protect (Lisp_Object (*) (Lisp_Object), Lisp_Object);
2263 void do_autoload (Lisp_Object, Lisp_Object);
2264 Lisp_Object un_autoload (Lisp_Object);
2265 void warn_when_safe_lispobj (Lisp_Object, Lisp_Object, Lisp_Object);
2266 void warn_when_safe (Lisp_Object, Lisp_Object, CONST char *,
2267                      ...) PRINTF_ARGS (3, 4);
2268
2269
2270 /* Defined in event-stream.c */
2271 void wait_delaying_user_input (int (*) (void *), void *);
2272 int detect_input_pending (void);
2273 void reset_this_command_keys (Lisp_Object, int);
2274 Lisp_Object enqueue_misc_user_event (Lisp_Object, Lisp_Object, Lisp_Object);
2275 Lisp_Object enqueue_misc_user_event_pos (Lisp_Object, Lisp_Object,
2276                                          Lisp_Object, int, int, int, int);
2277
2278 /* Defined in event-Xt.c */
2279 void signal_special_Xt_user_event (Lisp_Object, Lisp_Object, Lisp_Object);
2280
2281
2282 /* Defined in events.c */
2283 void clear_event_resource (void);
2284 Lisp_Object allocate_event (void);
2285 int event_to_character (Lisp_Event *, int, int, int);
2286
2287 /* Defined in fileio.c */
2288 void record_auto_save (void);
2289 void force_auto_save_soon (void);
2290 DECLARE_DOESNT_RETURN (report_file_error (CONST char *, Lisp_Object));
2291 void maybe_report_file_error (CONST char *, Lisp_Object,
2292                               Lisp_Object, Error_behavior);
2293 DECLARE_DOESNT_RETURN (signal_file_error (CONST char *, Lisp_Object));
2294 void maybe_signal_file_error (CONST char *, Lisp_Object,
2295                               Lisp_Object, Error_behavior);
2296 DECLARE_DOESNT_RETURN (signal_double_file_error (CONST char *, CONST char *,
2297                                                  Lisp_Object));
2298 void maybe_signal_double_file_error (CONST char *, CONST char *,
2299                                      Lisp_Object, Lisp_Object, Error_behavior);
2300 DECLARE_DOESNT_RETURN (signal_double_file_error_2 (CONST char *, CONST char *,
2301                                                    Lisp_Object, Lisp_Object));
2302 void maybe_signal_double_file_error_2 (CONST char *, CONST char *,
2303                                        Lisp_Object, Lisp_Object, Lisp_Object,
2304                                        Error_behavior);
2305 Lisp_Object lisp_strerror (int);
2306 Lisp_Object expand_and_dir_to_file (Lisp_Object, Lisp_Object);
2307 int read_allowing_quit (int, void *, size_t);
2308 int write_allowing_quit (int, CONST void *, size_t);
2309 int internal_delete_file (Lisp_Object);
2310
2311 /* Defined in filelock.c */
2312 void lock_file (Lisp_Object);
2313 void unlock_file (Lisp_Object);
2314 void unlock_all_files (void);
2315 void unlock_buffer (struct buffer *);
2316
2317 /* Defined in filemode.c */
2318 void filemodestring (struct stat *, char *);
2319
2320 /* Defined in floatfns.c */
2321 double extract_float (Lisp_Object);
2322
2323 /* Defined in fns.c */
2324 Lisp_Object list_sort (Lisp_Object, Lisp_Object,
2325                        int (*) (Lisp_Object, Lisp_Object, Lisp_Object));
2326 Lisp_Object merge (Lisp_Object, Lisp_Object, Lisp_Object);
2327
2328 void bump_string_modiff (Lisp_Object);
2329 Lisp_Object memq_no_quit (Lisp_Object, Lisp_Object);
2330 Lisp_Object assoc_no_quit (Lisp_Object, Lisp_Object);
2331 Lisp_Object assq_no_quit (Lisp_Object, Lisp_Object);
2332 Lisp_Object rassq_no_quit (Lisp_Object, Lisp_Object);
2333 Lisp_Object delq_no_quit (Lisp_Object, Lisp_Object);
2334 Lisp_Object delq_no_quit_and_free_cons (Lisp_Object, Lisp_Object);
2335 Lisp_Object remassoc_no_quit (Lisp_Object, Lisp_Object);
2336 Lisp_Object remassq_no_quit (Lisp_Object, Lisp_Object);
2337 Lisp_Object remrassq_no_quit (Lisp_Object, Lisp_Object);
2338
2339 void pure_put (Lisp_Object, Lisp_Object, Lisp_Object);
2340 int plists_differ (Lisp_Object, Lisp_Object, int, int, int);
2341 Lisp_Object internal_plist_get (Lisp_Object, Lisp_Object);
2342 void internal_plist_put (Lisp_Object *, Lisp_Object, Lisp_Object);
2343 int internal_remprop (Lisp_Object *, Lisp_Object);
2344 Lisp_Object external_plist_get (Lisp_Object *, Lisp_Object,
2345                                 int, Error_behavior);
2346 void external_plist_put (Lisp_Object *, Lisp_Object,
2347                          Lisp_Object, int, Error_behavior);
2348 int external_remprop (Lisp_Object *, Lisp_Object, int, Error_behavior);
2349 int internal_equal (Lisp_Object, Lisp_Object, int);
2350 Lisp_Object concat2 (Lisp_Object, Lisp_Object);
2351 Lisp_Object concat3 (Lisp_Object, Lisp_Object, Lisp_Object);
2352 Lisp_Object vconcat2 (Lisp_Object, Lisp_Object);
2353 Lisp_Object vconcat3 (Lisp_Object, Lisp_Object, Lisp_Object);
2354 Lisp_Object nconc2 (Lisp_Object, Lisp_Object);
2355 Lisp_Object bytecode_nconc2 (Lisp_Object *);
2356 void check_losing_bytecode (CONST char *, Lisp_Object);
2357
2358 /* Defined in getloadavg.c */
2359 int getloadavg (double[], int);
2360
2361 /* Defined in glyphs.c */
2362 Error_behavior decode_error_behavior_flag (Lisp_Object);
2363 Lisp_Object encode_error_behavior_flag (Error_behavior);
2364
2365 /* Defined in indent.c */
2366 int bi_spaces_at_point (struct buffer *, Bytind);
2367 int column_at_point (struct buffer *, Bufpos, int);
2368 int current_column (struct buffer *);
2369 void invalidate_current_column (void);
2370 Bufpos vmotion (struct window *, Bufpos, int, int *);
2371 Bufpos vmotion_pixels (Lisp_Object, Bufpos, int, int, int *);
2372
2373 /* Defined in keymap.c */
2374 void where_is_to_char (Lisp_Object, char *);
2375
2376 /* Defined in lread.c */
2377 void ebolify_bytecode_constants (Lisp_Object);
2378 void close_load_descs (void);
2379 int locate_file (Lisp_Object, Lisp_Object, Lisp_Object, Lisp_Object *, int);
2380 EXFUN (Flocate_file_clear_hashing, 1);
2381 int isfloat_string (CONST char *);
2382
2383 /* Well, I've decided to enable this. -- ben */
2384 /* And I've decided to make it work right.  -- sb */
2385 #define LOADHIST
2386 /* Define the following symbol to enable load history of dumped files */
2387 #define LOADHIST_DUMPED
2388 /* Define the following symbol to enable load history of C source */
2389 #define LOADHIST_BUILTIN
2390
2391 #ifdef LOADHIST /* this is just a stupid idea */
2392 #define LOADHIST_ATTACH(x) \
2393  do { if (initialized) Vcurrent_load_list = Fcons (x, Vcurrent_load_list); } \
2394  while (0)
2395 #else /*! LOADHIST */
2396 # define LOADHIST_ATTACH(x)
2397 #endif /*! LOADHIST */
2398
2399 /* Defined in marker.c */
2400 Bytind bi_marker_position (Lisp_Object);
2401 Bufpos marker_position (Lisp_Object);
2402 void set_bi_marker_position (Lisp_Object, Bytind);
2403 void set_marker_position (Lisp_Object, Bufpos);
2404 void unchain_marker (Lisp_Object);
2405 Lisp_Object noseeum_copy_marker (Lisp_Object, Lisp_Object);
2406 Lisp_Object set_marker_restricted (Lisp_Object, Lisp_Object, Lisp_Object);
2407 #ifdef MEMORY_USAGE_STATS
2408 int compute_buffer_marker_usage (struct buffer *, struct overhead_stats *);
2409 #endif
2410
2411 /* Defined in menubar.c */
2412 extern int popup_menu_up_p;
2413 extern int menubar_show_keybindings;
2414 extern int popup_menu_titles;
2415
2416 /* Defined in minibuf.c */
2417 extern int minibuf_level;
2418 Charcount scmp_1 (CONST Bufbyte *, CONST Bufbyte *, Charcount, int);
2419 #define scmp(s1, s2, len) scmp_1 (s1, s2, len, completion_ignore_case)
2420 extern int completion_ignore_case;
2421 int regexp_ignore_completion_p (CONST Bufbyte *, Lisp_Object,
2422                                 Bytecount, Bytecount);
2423 Lisp_Object clear_echo_area (struct frame *, Lisp_Object, int);
2424 Lisp_Object clear_echo_area_from_print (struct frame *, Lisp_Object, int);
2425 void echo_area_append (struct frame *, CONST Bufbyte *, Lisp_Object,
2426                        Bytecount, Bytecount, Lisp_Object);
2427 void echo_area_message (struct frame *, CONST Bufbyte *, Lisp_Object,
2428                         Bytecount, Bytecount, Lisp_Object);
2429 Lisp_Object echo_area_status (struct frame *);
2430 int echo_area_active (struct frame *);
2431 Lisp_Object echo_area_contents (struct frame *);
2432 void message_internal (CONST Bufbyte *, Lisp_Object, Bytecount, Bytecount);
2433 void message_append_internal (CONST Bufbyte *, Lisp_Object,
2434                               Bytecount, Bytecount);
2435 void message (CONST char *, ...) PRINTF_ARGS (1, 2);
2436 void message_append (CONST char *, ...) PRINTF_ARGS (1, 2);
2437 void message_no_translate (CONST char *, ...) PRINTF_ARGS (1, 2);
2438 void clear_message (void);
2439
2440 /* Defined in print.c */
2441 void write_string_to_stdio_stream (FILE *, struct console *,
2442                                    CONST Bufbyte *, Bytecount, Bytecount,
2443                                    enum external_data_format);
2444 void debug_print (Lisp_Object);
2445 void debug_short_backtrace (int);
2446 void temp_output_buffer_setup (Lisp_Object);
2447 void temp_output_buffer_show (Lisp_Object, Lisp_Object);
2448 /* NOTE: Do not call this with the data of a Lisp_String.  Use princ.
2449  * Note: stream should be defaulted before calling
2450  *  (eg Qnil means stdout, not Vstandard_output, etc) */
2451 void write_c_string (CONST char *, Lisp_Object);
2452 /* Same goes for this function. */
2453 void write_string_1 (CONST Bufbyte *, Bytecount, Lisp_Object);
2454 void print_cons (Lisp_Object, Lisp_Object, int);
2455 void print_vector (Lisp_Object, Lisp_Object, int);
2456 void print_string (Lisp_Object, Lisp_Object, int);
2457 void long_to_string (char *, long);
2458 void print_internal (Lisp_Object, Lisp_Object, int);
2459 void print_symbol (Lisp_Object, Lisp_Object, int);
2460 void print_float (Lisp_Object, Lisp_Object, int);
2461 extern int print_escape_newlines;
2462 extern int print_readably;
2463 Lisp_Object internal_with_output_to_temp_buffer (Lisp_Object,
2464                                                  Lisp_Object (*) (Lisp_Object),
2465                                                  Lisp_Object, Lisp_Object);
2466 void float_to_string (char *, double);
2467 void internal_object_printer (Lisp_Object, Lisp_Object, int);
2468
2469 /* Defined in profile.c */
2470 void mark_profiling_info (void (*) (Lisp_Object));
2471 void profile_increase_call_count (Lisp_Object);
2472 extern int profiling_active;
2473 extern int profiling_redisplay_flag;
2474
2475 /* Defined in rangetab.c */
2476 void put_range_table (Lisp_Object, EMACS_INT, EMACS_INT, Lisp_Object);
2477 int unified_range_table_bytes_needed (Lisp_Object);
2478 int unified_range_table_bytes_used (void *);
2479 void unified_range_table_copy_data (Lisp_Object, void *);
2480 Lisp_Object unified_range_table_lookup (void *, EMACS_INT, Lisp_Object);
2481 int unified_range_table_nentries (void *);
2482 void unified_range_table_get_range (void *, int, EMACS_INT *, EMACS_INT *,
2483                                     Lisp_Object *);
2484
2485 /* Defined in search.c */
2486 struct re_pattern_buffer;
2487 struct re_registers;
2488 Bufpos scan_buffer (struct buffer *, Emchar, Bufpos, Bufpos, EMACS_INT, EMACS_INT *, int);
2489 Bufpos find_next_newline (struct buffer *, Bufpos, int);
2490 Bufpos find_next_newline_no_quit (struct buffer *, Bufpos, int);
2491 Bytind bi_find_next_newline_no_quit (struct buffer *, Bytind, int);
2492 Bufpos find_before_next_newline (struct buffer *, Bufpos, Bufpos, int);
2493 struct re_pattern_buffer *compile_pattern (Lisp_Object, struct re_registers *,
2494                                            char *, int, Error_behavior);
2495 Bytecount fast_string_match (Lisp_Object,  CONST Bufbyte *,
2496                              Lisp_Object, Bytecount,
2497                              Bytecount, int, Error_behavior, int);
2498 Bytecount fast_lisp_string_match (Lisp_Object, Lisp_Object);
2499 void restore_match_data (void);
2500
2501 /* Defined in signal.c */
2502 void init_interrupts_late (void);
2503 extern int dont_check_for_quit;
2504 void begin_dont_check_for_quit (void);
2505 void emacs_sleep (int);
2506
2507 /* Defined in sound.c */
2508 void init_device_sound (struct device *);
2509
2510 /* Defined in specifier.c */
2511 Lisp_Object specifier_instance (Lisp_Object, Lisp_Object, Lisp_Object,
2512                                 Error_behavior, int, int, Lisp_Object);
2513 Lisp_Object specifier_instance_no_quit (Lisp_Object, Lisp_Object, Lisp_Object,
2514                                         Error_behavior, int, Lisp_Object);
2515
2516 /* Defined in symbols.c */
2517 int hash_string (CONST Bufbyte *, Bytecount);
2518 Lisp_Object intern (CONST char *);
2519 Lisp_Object oblookup (Lisp_Object, CONST Bufbyte *, Bytecount);
2520 void map_obarray (Lisp_Object, int (*) (Lisp_Object, void *), void *);
2521 Lisp_Object indirect_function (Lisp_Object, int);
2522 Lisp_Object symbol_value_in_buffer (Lisp_Object, Lisp_Object);
2523 void kill_buffer_local_variables (struct buffer *);
2524 int symbol_value_buffer_local_info (Lisp_Object, struct buffer *);
2525 Lisp_Object find_symbol_value (Lisp_Object);
2526 Lisp_Object find_symbol_value_quickly (Lisp_Object, int);
2527 Lisp_Object top_level_value (Lisp_Object);
2528 void reject_constant_symbols (Lisp_Object sym, Lisp_Object newval,
2529                               int function_p,
2530                               Lisp_Object follow_past_lisp_magic);
2531
2532 /* Defined in syntax.c */
2533 int scan_words (struct buffer *, int, int);
2534
2535 /* Defined in undo.c */
2536 Lisp_Object truncate_undo_list (Lisp_Object, int, int);
2537 void record_extent (Lisp_Object, int);
2538 void record_insert (struct buffer *, Bufpos, Charcount);
2539 void record_delete (struct buffer *, Bufpos, Charcount);
2540 void record_change (struct buffer *, Bufpos, Charcount);
2541
2542 /* Defined in unex*.c */
2543 int unexec (char *, char *, uintptr_t, uintptr_t, uintptr_t);
2544 #ifdef RUN_TIME_REMAP
2545 int run_time_remap (char *);
2546 #endif
2547
2548 /* Defined in vm-limit.c */
2549 void memory_warnings (void *, void (*) (CONST char *));
2550
2551 /* Defined in window.c */
2552 Lisp_Object save_window_excursion_unwind (Lisp_Object);
2553 Lisp_Object display_buffer (Lisp_Object, Lisp_Object, Lisp_Object);
2554
2555 /* The following were machine generated 19980312 */
2556
2557
2558 EXFUN (Faccept_process_output, 3);
2559 EXFUN (Fadd1, 1);
2560 EXFUN (Fadd_spec_to_specifier, 5);
2561 EXFUN (Fadd_timeout, 4);
2562 EXFUN (Fappend, MANY);
2563 EXFUN (Fapply, MANY);
2564 EXFUN (Faref, 2);
2565 EXFUN (Faset, 3);
2566 EXFUN (Fassoc, 2);
2567 EXFUN (Fassq, 2);
2568 EXFUN (Fbacktrace, 2);
2569 EXFUN (Fbeginning_of_line, 2);
2570 EXFUN (Fbobp, 1);
2571 EXFUN (Fbolp, 1);
2572 EXFUN (Fboundp, 1);
2573 EXFUN (Fbuffer_substring, 3);
2574 EXFUN (Fbuilt_in_variable_type, 1);
2575 EXFUN (Fbyte_code, 3);
2576 EXFUN (Fcall_interactively, 3);
2577 EXFUN (Fcanonicalize_lax_plist, 2);
2578 EXFUN (Fcanonicalize_plist, 2);
2579 EXFUN (Fcar, 1);
2580 EXFUN (Fcar_safe, 1);
2581 EXFUN (Fcdr, 1);
2582 EXFUN (Fchar_after, 2);
2583 EXFUN (Fchar_to_string, 1);
2584 EXFUN (Fcheck_valid_plist, 1);
2585 EXFUN (Fclear_range_table, 1);
2586 EXFUN (Fcoding_category_list, 0);
2587 EXFUN (Fcoding_category_system, 1);
2588 EXFUN (Fcoding_priority_list, 0);
2589 EXFUN (Fcoding_system_charset, 2);
2590 EXFUN (Fcoding_system_doc_string, 1);
2591 EXFUN (Fcoding_system_list, 0);
2592 EXFUN (Fcoding_system_name, 1);
2593 EXFUN (Fcoding_system_p, 1);
2594 EXFUN (Fcoding_system_property, 2);
2595 EXFUN (Fcoding_system_type, 1);
2596 EXFUN (Fcommand_execute, 3);
2597 EXFUN (Fcommandp, 1);
2598 EXFUN (Fconcat, MANY);
2599 EXFUN (Fcons, 2);
2600 EXFUN (Fcopy_alist, 1);
2601 EXFUN (Fcopy_coding_system, 2);
2602 EXFUN (Fcopy_event, 2);
2603 EXFUN (Fcopy_list, 1);
2604 EXFUN (Fcopy_marker, 2);
2605 EXFUN (Fcopy_sequence, 1);
2606 EXFUN (Fcopy_tree, 2);
2607 EXFUN (Fcurrent_window_configuration, 1);
2608 EXFUN (Fdecode_big5_char, 1);
2609 EXFUN (Fdecode_coding_region, 4);
2610 EXFUN (Fdecode_shift_jis_char, 1);
2611 EXFUN (Fdefault_boundp, 1);
2612 EXFUN (Fdefault_value, 1);
2613 EXFUN (Fdefine_key, 3);
2614 EXFUN (Fdelete_region, 3);
2615 EXFUN (Fdelq, 2);
2616 EXFUN (Fdestructive_alist_to_plist, 1);
2617 EXFUN (Fdetect_coding_region, 3);
2618 EXFUN (Fdgettext, 2);
2619 EXFUN (Fding, 3);
2620 EXFUN (Fdirectory_file_name, 1);
2621 EXFUN (Fdisable_timeout, 1);
2622 EXFUN (Fdiscard_input, 0);
2623 EXFUN (Fdispatch_event, 1);
2624 EXFUN (Fdisplay_error, 2);
2625 EXFUN (Fdo_auto_save, 2);
2626 EXFUN (Fdowncase, 2);
2627 EXFUN (Felt, 2);
2628 EXFUN (Fencode_big5_char, 1);
2629 EXFUN (Fencode_coding_region, 4);
2630 EXFUN (Fencode_shift_jis_char, 1);
2631 EXFUN (Fend_of_line, 2);
2632 EXFUN (Fenqueue_eval_event, 2);
2633 EXFUN (Feobp, 1);
2634 EXFUN (Feolp, 1);
2635 EXFUN (Fequal, 2);
2636 EXFUN (Ferror_message_string, 1);
2637 EXFUN (Feval, 1);
2638 EXFUN (Fevent_to_character, 4);
2639 EXFUN (Fexecute_kbd_macro, 2);
2640 EXFUN (Fexpand_abbrev, 0);
2641 EXFUN (Fexpand_file_name, 2);
2642 EXFUN (Fextent_at, 5);
2643 EXFUN (Fextent_property, 3);
2644 EXFUN (Ffboundp, 1);
2645 EXFUN (Ffile_accessible_directory_p, 1);
2646 EXFUN (Ffile_directory_p, 1);
2647 EXFUN (Ffile_executable_p, 1);
2648 EXFUN (Ffile_exists_p, 1);
2649 EXFUN (Ffile_name_absolute_p, 1);
2650 EXFUN (Ffile_name_as_directory, 1);
2651 EXFUN (Ffile_name_directory, 1);
2652 EXFUN (Ffile_name_nondirectory, 1);
2653 EXFUN (Ffile_readable_p, 1);
2654 EXFUN (Ffile_symlink_p, 1);
2655 EXFUN (Ffile_truename, 2);
2656 EXFUN (Ffind_coding_system, 1);
2657 EXFUN (Ffind_file_name_handler, 2);
2658 EXFUN (Ffollowing_char, 1);
2659 EXFUN (Fformat, MANY);
2660 EXFUN (Fforward_char, 2);
2661 EXFUN (Fforward_line, 2);
2662 EXFUN (Ffset, 2);
2663 EXFUN (Ffuncall, MANY);
2664 EXFUN (Fgeq, MANY);
2665 EXFUN (Fget, 3);
2666 EXFUN (Fget_buffer_process, 1);
2667 EXFUN (Fget_coding_system, 1);
2668 EXFUN (Fget_process, 1);
2669 EXFUN (Fget_range_table, 3);
2670 EXFUN (Fgettext, 1);
2671 EXFUN (Fgoto_char, 2);
2672 EXFUN (Fgtr, MANY);
2673 EXFUN (Findent_to, 3);
2674 EXFUN (Findirect_function, 1);
2675 EXFUN (Finsert, MANY);
2676 EXFUN (Finsert_buffer_substring, 3);
2677 EXFUN (Finsert_char, 4);
2678 EXFUN (Finsert_file_contents_internal, 7);
2679 EXFUN (Finteractive_p, 0);
2680 EXFUN (Fintern, 2);
2681 EXFUN (Fintern_soft, 2);
2682 EXFUN (Fkey_description, 1);
2683 EXFUN (Fkill_emacs, 1);
2684 EXFUN (Fkill_local_variable, 1);
2685 EXFUN (Flax_plist_get, 3);
2686 EXFUN (Flax_plist_remprop, 2);
2687 EXFUN (Flength, 1);
2688 EXFUN (Fleq, MANY);
2689 EXFUN (Flist, MANY);
2690 EXFUN (Flistp, 1);
2691 #ifdef HAVE_SHLIB
2692 EXFUN (Flist_modules, 0);
2693 EXFUN (Fload_module, 3);
2694 #endif
2695 EXFUN (Flss, MANY);
2696 EXFUN (Fmake_byte_code, MANY);
2697 EXFUN (Fmake_coding_system, 4);
2698 EXFUN (Fmake_glyph_internal, 1);
2699 EXFUN (Fmake_list, 2);
2700 EXFUN (Fmake_marker, 0);
2701 EXFUN (Fmake_range_table, 0);
2702 EXFUN (Fmake_sparse_keymap, 1);
2703 EXFUN (Fmake_string, 2);
2704 EXFUN (Fmake_symbol, 1);
2705 EXFUN (Fmake_vector, 2);
2706 EXFUN (Fmapcar, 2);
2707 EXFUN (Fmarker_buffer, 1);
2708 EXFUN (Fmarker_position, 1);
2709 EXFUN (Fmatch_beginning, 1);
2710 EXFUN (Fmatch_end, 1);
2711 EXFUN (Fmax, MANY);
2712 EXFUN (Fmember, 2);
2713 EXFUN (Fmemq, 2);
2714 EXFUN (Fmin, MANY);
2715 EXFUN (Fminus, MANY);
2716 EXFUN (Fnarrow_to_region, 3);
2717 EXFUN (Fnconc, MANY);
2718 EXFUN (Fnext_event, 2);
2719 EXFUN (Fnreverse, 1);
2720 EXFUN (Fnthcdr, 2);
2721 EXFUN (Fnumber_to_string, 1);
2722 EXFUN (Fold_assq, 2);
2723 EXFUN (Fold_equal, 2);
2724 EXFUN (Fold_member, 2);
2725 EXFUN (Fold_memq, 2);
2726 EXFUN (Fplist_get, 3);
2727 EXFUN (Fplist_member, 2);
2728 EXFUN (Fplist_put, 3);
2729 EXFUN (Fplus, MANY);
2730 EXFUN (Fpoint, 1);
2731 EXFUN (Fpoint_marker, 2);
2732 EXFUN (Fpoint_max, 1);
2733 EXFUN (Fpoint_min, 1);
2734 EXFUN (Fpreceding_char, 1);
2735 EXFUN (Fprefix_numeric_value, 1);
2736 EXFUN (Fprin1, 2);
2737 EXFUN (Fprin1_to_string, 2);
2738 EXFUN (Fprinc, 2);
2739 EXFUN (Fprint, 2);
2740 EXFUN (Fprocess_status, 1);
2741 EXFUN (Fprogn, UNEVALLED);
2742 EXFUN (Fprovide, 1);
2743 EXFUN (Fpurecopy, 1);
2744 EXFUN (Fput, 3);
2745 EXFUN (Fput_range_table, 4);
2746 EXFUN (Fput_text_property, 5);
2747 EXFUN (Fquo, MANY);
2748 EXFUN (Frassq, 2);
2749 EXFUN (Fread, 1);
2750 EXFUN (Fread_key_sequence, 3);
2751 EXFUN (Freally_free, 1);
2752 EXFUN (Frem, 2);
2753 EXFUN (Fremassq, 2);
2754 EXFUN (Fselected_frame, 1);
2755 EXFUN (Fset, 2);
2756 EXFUN (Fset_coding_category_system, 2);
2757 EXFUN (Fset_coding_priority_list, 1);
2758 EXFUN (Fset_default, 2);
2759 EXFUN (Fset_marker, 3);
2760 EXFUN (Fset_standard_case_table, 1);
2761 EXFUN (Fsetcar, 2);
2762 EXFUN (Fsetcdr, 2);
2763 EXFUN (Fsignal, 2);
2764 EXFUN (Fsit_for, 2);
2765 EXFUN (Fskip_chars_backward, 3);
2766 EXFUN (Fskip_chars_forward, 3);
2767 EXFUN (Fsleep_for, 1);
2768 EXFUN (Fsort, 2);
2769 EXFUN (Fspecifier_spec_list, 4);
2770 EXFUN (Fstring_equal, 2);
2771 EXFUN (Fstring_lessp, 2);
2772 EXFUN (Fstring_match, 4);
2773 EXFUN (Fsub1, 1);
2774 EXFUN (Fsubr_max_args, 1);
2775 EXFUN (Fsubr_min_args, 1);
2776 EXFUN (Fsubsidiary_coding_system, 2);
2777 EXFUN (Fsubstitute_command_keys, 1);
2778 EXFUN (Fsubstitute_in_file_name, 1);
2779 EXFUN (Fsubstring, 3);
2780 EXFUN (Fsymbol_function, 1);
2781 EXFUN (Fsymbol_name, 1);
2782 EXFUN (Fsymbol_plist, 1);
2783 EXFUN (Fsymbol_value, 1);
2784 EXFUN (Fsystem_name, 0);
2785 EXFUN (Fthrow, 2);
2786 EXFUN (Ftimes, MANY);
2787 EXFUN (Ftruncate, 1);
2788 EXFUN (Fundo_boundary, 0);
2789 EXFUN (Funhandled_file_name_directory, 1);
2790 EXFUN (Funlock_buffer, 0);
2791 EXFUN (Fupcase, 2);
2792 EXFUN (Fupcase_initials, 2);
2793 EXFUN (Fupcase_initials_region, 3);
2794 EXFUN (Fupcase_region, 3);
2795 EXFUN (Fuser_home_directory, 0);
2796 EXFUN (Fuser_login_name, 1);
2797 EXFUN (Fvector, MANY);
2798 EXFUN (Fverify_visited_file_modtime, 1);
2799 EXFUN (Fvertical_motion, 3);
2800 EXFUN (Fwiden, 1);
2801
2802
2803 extern Lisp_Object Q_style, Qactually_requested, Qactivate_menubar_hook;
2804 extern Lisp_Object Qafter, Qall, Qand;
2805 extern Lisp_Object Qarith_error, Qarrayp, Qassoc, Qat, Qautodetect, Qautoload;
2806 extern Lisp_Object Qbackground, Qbackground_pixmap, Qbad_variable, Qbefore;
2807 extern Lisp_Object Qbeginning_of_buffer, Qbig5, Qbinary, Qbitmap, Qbitp, Qblinking;
2808 extern Lisp_Object Qboolean, Qbottom, Qbuffer, Qbuffer_file_coding_system;
2809 extern Lisp_Object Qbuffer_glyph_p, Qbuffer_live_p, Qbuffer_read_only, Qbutton;
2810 extern Lisp_Object Qbyte_code, Qcall_interactively, Qcategory;
2811 extern Lisp_Object Qcategory_designator_p, Qcategory_table_value_p, Qccl, Qcdr;
2812 extern Lisp_Object Qchannel, Qchar, Qchar_or_string_p, Qcharacter, Qcharacterp;
2813 extern Lisp_Object Qchars, Qcharset_g0, Qcharset_g1, Qcharset_g2, Qcharset_g3;
2814 extern Lisp_Object Qcircular_list, Qcircular_property_list;
2815 extern Lisp_Object Qcoding_system_error, Qcoding_system_p;
2816 extern Lisp_Object Qcolor, Qcolor_pixmap_image_instance_p;
2817 extern Lisp_Object Qcolumns, Qcommand, Qcommandp, Qcompletion_ignore_case;
2818 extern Lisp_Object Qconsole, Qconsole_live_p, Qconst_specifier, Qcr, Qcritical;
2819 extern Lisp_Object Qcrlf, Qctext, Qcurrent_menubar, Qcursor;
2820 extern Lisp_Object Qcyclic_variable_indirection, Qdata, Qdead, Qdecode;
2821 extern Lisp_Object Qdefault, Qdefun, Qdelete, Qdelq, Qdevice, Qdevice_live_p;
2822 extern Lisp_Object Qdim, Qdimension, Qdisabled, Qdisplay, Qdisplay_table;
2823 extern Lisp_Object Qdoc_string, Qdomain_error, Qdynarr_overhead;
2824 extern Lisp_Object Qempty, Qencode, Qend_of_buffer, Qend_of_file, Qend_open;
2825 extern Lisp_Object Qeol_cr, Qeol_crlf, Qeol_lf, Qeol_type, Qeq, Qeql, Qequal;
2826 extern Lisp_Object Qerror, Qerror_conditions, Qerror_message, Qescape_quoted;
2827 extern Lisp_Object Qeval, Qevent_live_p, Qexit, Qextent_live_p, Qextents;
2828 extern Lisp_Object Qexternal_debugging_output, Qface, Qfeaturep, Qfile_error;
2829 extern Lisp_Object Qfont, Qforce_g0_on_output, Qforce_g1_on_output;
2830 extern Lisp_Object Qforce_g2_on_output, Qforce_g3_on_output, Qforeground;
2831 extern Lisp_Object Qformat, Qframe, Qframe_live_p, Qfunction, Qgap_overhead;
2832 extern Lisp_Object Qgeneric, Qgeometry, Qglobal, Qheight, Qhighlight, Qicon;
2833 extern Lisp_Object Qicon_glyph_p, Qid, Qidentity, Qimage, Qinfo, Qinherit;
2834 extern Lisp_Object Qinhibit_quit, Qinhibit_read_only;
2835 extern Lisp_Object Qinput_charset_conversion, Qinteger;
2836 extern Lisp_Object Qinteger_char_or_marker_p, Qinteger_or_char_p;
2837 extern Lisp_Object Qinteger_or_marker_p, Qintegerp, Qinteractive, Qinternal;
2838 extern Lisp_Object Qinvalid_function, Qinvalid_read_syntax, Qio_error;
2839 extern Lisp_Object Qiso2022, Qkey, Qkey_assoc, Qkeymap, Qlambda, Qleft, Qlf;
2840 extern Lisp_Object Qlist, Qlistp, Qload, Qlock_shift, Qmacro, Qmagic;
2841 extern Lisp_Object Qmalformed_list, Qmalformed_property_list;
2842 extern Lisp_Object Qmalloc_overhead, Qmark, Qmarkers;
2843 extern Lisp_Object Qmax, Qmemory, Qmessage, Qminus, Qmnemonic, Qmodifiers;
2844 extern Lisp_Object Qmono_pixmap_image_instance_p, Qmotion;
2845 extern Lisp_Object Qmouse_leave_buffer_hook, Qmswindows, Qname, Qnas, Qnatnump;
2846 extern Lisp_Object Qno_ascii_cntl, Qno_ascii_eol, Qno_catch;
2847 extern Lisp_Object Qno_conversion, Qno_iso6429, Qnone, Qnot, Qnothing;
2848 extern Lisp_Object Qnothing_image_instance_p, Qnotice;
2849 extern Lisp_Object Qnumber_char_or_marker_p, Qnumber_or_marker_p, Qnumberp;
2850 extern Lisp_Object Qobject, Qold_assoc, Qold_delete, Qold_delq, Qold_rassoc;
2851 extern Lisp_Object Qold_rassq, Qonly, Qor, Qother, Qoutput_charset_conversion;
2852 extern Lisp_Object Qoverflow_error, Qpath, Qpoint, Qpointer, Qpointer_glyph_p;
2853 extern Lisp_Object Qpointer_image_instance_p, Qpost_read_conversion;
2854 extern Lisp_Object Qpre_write_conversion, Qprint, Qprint_length;
2855 extern Lisp_Object Qprint_string_length, Qprocess, Qprogn, Qprovide, Qquit;
2856 extern Lisp_Object Qquote, Qrange_error, Qrassoc, Qrassq, Qread_char;
2857 extern Lisp_Object Qread_from_minibuffer, Qreally_early_error_handler;
2858 extern Lisp_Object Qregion_beginning, Qregion_end, Qrequire, Qresource;
2859 extern Lisp_Object Qreturn, Qreverse, Qright, Qrun_hooks, Qsans_modifiers;
2860 extern Lisp_Object Qsave_buffers_kill_emacs, Qsearch, Qselected, Qself_insert_command;
2861 extern Lisp_Object Qsequencep, Qsetting_constant, Qseven, Qshift_jis, Qshort;
2862 extern Lisp_Object Qsignal, Qsimple, Qsingularity_error, Qsize, Qspace;
2863 extern Lisp_Object Qspecifier, Qstandard_input, Qstandard_output, Qstart_open;
2864 extern Lisp_Object Qstream, Qstring, Qstring_lessp, Qsubwindow;
2865 extern Lisp_Object Qsubwindow_image_instance_p, Qsymbol, Qsyntax, Qt, Qtest;
2866 extern Lisp_Object Qtext, Qtext_image_instance_p, Qtimeout, Qtimestamp;
2867 extern Lisp_Object Qtoolbar, Qtop, Qtop_level, Qtrue_list_p, Qtty, Qtype;
2868 extern Lisp_Object Qunbound, Qundecided, Qundefined, Qunderflow_error;
2869 extern Lisp_Object Qunderline, Qunimplemented, Quser_files_and_directories;
2870 extern Lisp_Object Qvalue_assoc, Qvalues;
2871 extern Lisp_Object Qvariable_documentation, Qvariable_domain, Qvector;
2872 extern Lisp_Object Qvoid_function, Qvoid_variable, Qwarning, Qwidth, Qwidget, Qwindow;
2873 extern Lisp_Object Qwindow_live_p, Qwindow_system, Qwrong_number_of_arguments;
2874 extern Lisp_Object Qwrong_type_argument, Qx, Qy, Qyes_or_no_p;
2875 extern Lisp_Object Vactivate_menubar_hook, Vascii_canon_table;
2876 extern Lisp_Object Vascii_downcase_table, Vascii_eqv_table;
2877 extern Lisp_Object Vascii_upcase_table, Vautoload_queue, Vbinary_process_input;
2878 extern Lisp_Object Vbinary_process_output, Vblank_menubar;
2879 extern Lisp_Object Vcharset_ascii, Vcharset_composite, Vcharset_control_1;
2880 extern Lisp_Object Vcoding_system_for_read, Vcoding_system_for_write;
2881 extern Lisp_Object Vcoding_system_hash_table, Vcommand_history;
2882 extern Lisp_Object Vcommand_line_args, Vconfigure_info_directory;
2883 extern Lisp_Object Vconfigure_site_directory, Vconfigure_site_module_directory;
2884 extern Lisp_Object Vconsole_list, Vcontrolling_terminal;
2885 extern Lisp_Object Vcurrent_compiled_function_annotation, Vcurrent_load_list;
2886 extern Lisp_Object Vcurrent_mouse_event, Vcurrent_prefix_arg, Vdata_directory;
2887 extern Lisp_Object Vdisabled_command_hook, Vdoc_directory, Vinternal_doc_file_name;
2888 extern Lisp_Object Vecho_area_buffer, Vemacs_major_version;
2889 extern Lisp_Object Vemacs_minor_version, Vexec_directory, Vexec_path;
2890 extern Lisp_Object Vexecuting_macro, Vfeatures, Vfile_domain;
2891 extern Lisp_Object Vfile_name_coding_system, Vinhibit_quit;
2892 extern Lisp_Object Vinvocation_directory, Vinvocation_name;
2893 extern Lisp_Object Vkeyboard_coding_system, Vlast_command, Vlast_command_char;
2894 extern Lisp_Object Vlast_command_event, Vlast_input_event;
2895 extern Lisp_Object Vload_file_name_internal;
2896 extern Lisp_Object Vload_file_name_internal_the_purecopy, Vload_history;
2897 extern Lisp_Object Vload_path, Vmark_even_if_inactive, Vmenubar_configuration;
2898 extern Lisp_Object Vminibuf_preprompt, Vminibuf_prompt, Vminibuffer_zero;
2899 extern Lisp_Object Vmirror_ascii_canon_table, Vmirror_ascii_downcase_table;
2900 extern Lisp_Object Vmirror_ascii_eqv_table, Vmirror_ascii_upcase_table;
2901 extern Lisp_Object Vmodule_directory, Vmswindows_downcase_file_names;
2902 extern Lisp_Object Vmswindows_get_true_file_attributes, Vobarray;
2903 extern Lisp_Object Vprint_length, Vprint_level, Vprocess_environment;
2904 extern Lisp_Object Vquit_flag;
2905 extern Lisp_Object Vrecent_keys_ring, Vshell_file_name, Vsite_directory;
2906 extern Lisp_Object Vsite_module_directory;
2907 extern Lisp_Object Vstandard_input, Vstandard_output, Vstdio_str;
2908 extern Lisp_Object Vsynchronous_sounds, Vsystem_name, Vterminal_coding_system;
2909 extern Lisp_Object Vthis_command_keys, Vunread_command_event;
2910 extern Lisp_Object Vwin32_generate_fake_inodes, Vwin32_pipe_read_delay;
2911 extern Lisp_Object Vx_initial_argv_list;
2912
2913 extern Lisp_Object Qmakunbound, Qset;
2914
2915 #endif /* _XEMACS_LISP_H_ */