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