Mercurial > emacs
annotate src/lisp.h @ 53653:6f2b0bb10619
[ENABLE_CHECKING]: Don't force union type.
author | Stefan Monnier <monnier@iro.umontreal.ca> |
---|---|
date | Wed, 21 Jan 2004 04:19:21 +0000 |
parents | db670c1b5944 |
children | 8dc805af6250 |
rev | line source |
---|---|
302 | 1 /* Fundamental definitions for GNU Emacs Lisp interpreter. |
53653
6f2b0bb10619
[ENABLE_CHECKING]: Don't force union type.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
53331
diff
changeset
|
2 Copyright (C) 1985,86,87,93,94,95,97,98,1999,2000,01,02,03,2004 |
27141
d7b1de135a40
Add prototype for allocate_string_data.
Gerd Moellmann <gerd@gnu.org>
parents:
27078
diff
changeset
|
3 Free Software Foundation, Inc. |
302 | 4 |
5 This file is part of GNU Emacs. | |
6 | |
7 GNU Emacs is free software; you can redistribute it and/or modify | |
8 it under the terms of the GNU General Public License as published by | |
621 | 9 the Free Software Foundation; either version 2, or (at your option) |
302 | 10 any later version. |
11 | |
12 GNU Emacs is distributed in the hope that it will be useful, | |
13 but WITHOUT ANY WARRANTY; without even the implied warranty of | |
14 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
15 GNU General Public License for more details. | |
16 | |
17 You should have received a copy of the GNU General Public License | |
18 along with GNU Emacs; see the file COPYING. If not, write to | |
14186
ee40177f6c68
Update FSF's address in the preamble.
Erik Naggum <erik@naggum.no>
parents:
13363
diff
changeset
|
19 the Free Software Foundation, Inc., 59 Temple Place - Suite 330, |
ee40177f6c68
Update FSF's address in the preamble.
Erik Naggum <erik@naggum.no>
parents:
13363
diff
changeset
|
20 Boston, MA 02111-1307, USA. */ |
302 | 21 |
52274 | 22 #ifndef EMACS_LISP_H |
23 #define EMACS_LISP_H | |
24 | |
25017
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
25 /* Declare the prototype for a general external function. */ |
28054
d53d22ce7f4b
(P_): Define based on PROTOTYPES, not __STDC__.
Dave Love <fx@gnu.org>
parents:
27885
diff
changeset
|
26 #if defined (PROTOTYPES) || defined (WINDOWSNT) |
25017
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
27 #define P_(proto) proto |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
28 #else |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
29 #define P_(proto) () |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
30 #endif |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
31 |
36941
8107e2a17261
(Vx_resource_name) [HAVE_X_WINDOWS]: Declare extern.
Gerd Moellmann <gerd@gnu.org>
parents:
36816
diff
changeset
|
32 #if 0 |
35184
07ec5658a7a5
(STRING_BYTES) [GC_CHECK_STRING_BYTES]: Call
Gerd Moellmann <gerd@gnu.org>
parents:
35173
diff
changeset
|
33 /* Define this temporarily to hunt a bug. If defined, the size of |
07ec5658a7a5
(STRING_BYTES) [GC_CHECK_STRING_BYTES]: Call
Gerd Moellmann <gerd@gnu.org>
parents:
35173
diff
changeset
|
34 strings is redundantly recorded in sdata structures so that it can |
07ec5658a7a5
(STRING_BYTES) [GC_CHECK_STRING_BYTES]: Call
Gerd Moellmann <gerd@gnu.org>
parents:
35173
diff
changeset
|
35 be compared to the sizes recorded in Lisp strings. */ |
07ec5658a7a5
(STRING_BYTES) [GC_CHECK_STRING_BYTES]: Call
Gerd Moellmann <gerd@gnu.org>
parents:
35173
diff
changeset
|
36 |
07ec5658a7a5
(STRING_BYTES) [GC_CHECK_STRING_BYTES]: Call
Gerd Moellmann <gerd@gnu.org>
parents:
35173
diff
changeset
|
37 #define GC_CHECK_STRING_BYTES 1 |
51167
70fb9c159754
(Vfundamental_mode_abbrev_table): Don't declare.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51035
diff
changeset
|
38 #endif /* 0 */ |
35184
07ec5658a7a5
(STRING_BYTES) [GC_CHECK_STRING_BYTES]: Call
Gerd Moellmann <gerd@gnu.org>
parents:
35173
diff
changeset
|
39 |
302 | 40 |
8835
48bcdcb9d191
(EMACS_INT, EMACS_UINT): Define, if not already defined.
Richard M. Stallman <rms@gnu.org>
parents:
8827
diff
changeset
|
41 /* These are default choices for the types to use. */ |
26088
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
25818
diff
changeset
|
42 #ifdef _LP64 |
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
25818
diff
changeset
|
43 #ifndef EMACS_INT |
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
25818
diff
changeset
|
44 #define EMACS_INT long |
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
25818
diff
changeset
|
45 #define BITS_PER_EMACS_INT BITS_PER_LONG |
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
25818
diff
changeset
|
46 #endif |
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
25818
diff
changeset
|
47 #ifndef EMACS_UINT |
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
25818
diff
changeset
|
48 #define EMACS_UINT unsigned long |
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
25818
diff
changeset
|
49 #endif |
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
25818
diff
changeset
|
50 #else /* not _LP64 */ |
8835
48bcdcb9d191
(EMACS_INT, EMACS_UINT): Define, if not already defined.
Richard M. Stallman <rms@gnu.org>
parents:
8827
diff
changeset
|
51 #ifndef EMACS_INT |
48bcdcb9d191
(EMACS_INT, EMACS_UINT): Define, if not already defined.
Richard M. Stallman <rms@gnu.org>
parents:
8827
diff
changeset
|
52 #define EMACS_INT int |
16133 | 53 #define BITS_PER_EMACS_INT BITS_PER_INT |
8835
48bcdcb9d191
(EMACS_INT, EMACS_UINT): Define, if not already defined.
Richard M. Stallman <rms@gnu.org>
parents:
8827
diff
changeset
|
54 #endif |
48bcdcb9d191
(EMACS_INT, EMACS_UINT): Define, if not already defined.
Richard M. Stallman <rms@gnu.org>
parents:
8827
diff
changeset
|
55 #ifndef EMACS_UINT |
48bcdcb9d191
(EMACS_INT, EMACS_UINT): Define, if not already defined.
Richard M. Stallman <rms@gnu.org>
parents:
8827
diff
changeset
|
56 #define EMACS_UINT unsigned int |
48bcdcb9d191
(EMACS_INT, EMACS_UINT): Define, if not already defined.
Richard M. Stallman <rms@gnu.org>
parents:
8827
diff
changeset
|
57 #endif |
26088
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
25818
diff
changeset
|
58 #endif |
8835
48bcdcb9d191
(EMACS_INT, EMACS_UINT): Define, if not already defined.
Richard M. Stallman <rms@gnu.org>
parents:
8827
diff
changeset
|
59 |
28406
451721e784a8
Stop assuming interval pointers and lisp objects can be distinguished by
Ken Raeburn <raeburn@raeburn.org>
parents:
28141
diff
changeset
|
60 /* Extra internal type checking? */ |
451721e784a8
Stop assuming interval pointers and lisp objects can be distinguished by
Ken Raeburn <raeburn@raeburn.org>
parents:
28141
diff
changeset
|
61 extern int suppress_checking; |
28430
f805ef5a2a03
* lisp.h (NO_UNION_TYPE) [ENABLE_CHECKING]: Undef.
Ken Raeburn <raeburn@raeburn.org>
parents:
28417
diff
changeset
|
62 extern void die P_((const char *, const char *, int)); |
f805ef5a2a03
* lisp.h (NO_UNION_TYPE) [ENABLE_CHECKING]: Undef.
Ken Raeburn <raeburn@raeburn.org>
parents:
28417
diff
changeset
|
63 |
28406
451721e784a8
Stop assuming interval pointers and lisp objects can be distinguished by
Ken Raeburn <raeburn@raeburn.org>
parents:
28141
diff
changeset
|
64 #ifdef ENABLE_CHECKING |
28430
f805ef5a2a03
* lisp.h (NO_UNION_TYPE) [ENABLE_CHECKING]: Undef.
Ken Raeburn <raeburn@raeburn.org>
parents:
28417
diff
changeset
|
65 |
50761
3afa0d82e92e
(CHECK): Wrap args in parenthesis.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
50748
diff
changeset
|
66 #define CHECK(check,msg) (((check) || suppress_checking \ |
30943
429bcc971263
(CHECK) [ENABLE_CHECKING]: Make both side of the
Gerd Moellmann <gerd@gnu.org>
parents:
30934
diff
changeset
|
67 ? (void) 0 \ |
50761
3afa0d82e92e
(CHECK): Wrap args in parenthesis.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
50748
diff
changeset
|
68 : die ((msg), __FILE__, __LINE__)), \ |
28430
f805ef5a2a03
* lisp.h (NO_UNION_TYPE) [ENABLE_CHECKING]: Undef.
Ken Raeburn <raeburn@raeburn.org>
parents:
28417
diff
changeset
|
69 0) |
28406
451721e784a8
Stop assuming interval pointers and lisp objects can be distinguished by
Ken Raeburn <raeburn@raeburn.org>
parents:
28141
diff
changeset
|
70 #else |
28430
f805ef5a2a03
* lisp.h (NO_UNION_TYPE) [ENABLE_CHECKING]: Undef.
Ken Raeburn <raeburn@raeburn.org>
parents:
28417
diff
changeset
|
71 |
28406
451721e784a8
Stop assuming interval pointers and lisp objects can be distinguished by
Ken Raeburn <raeburn@raeburn.org>
parents:
28141
diff
changeset
|
72 /* Produce same side effects and result, but don't complain. */ |
451721e784a8
Stop assuming interval pointers and lisp objects can be distinguished by
Ken Raeburn <raeburn@raeburn.org>
parents:
28141
diff
changeset
|
73 #define CHECK(check,msg) ((check),0) |
28430
f805ef5a2a03
* lisp.h (NO_UNION_TYPE) [ENABLE_CHECKING]: Undef.
Ken Raeburn <raeburn@raeburn.org>
parents:
28417
diff
changeset
|
74 |
28406
451721e784a8
Stop assuming interval pointers and lisp objects can be distinguished by
Ken Raeburn <raeburn@raeburn.org>
parents:
28141
diff
changeset
|
75 #endif |
28430
f805ef5a2a03
* lisp.h (NO_UNION_TYPE) [ENABLE_CHECKING]: Undef.
Ken Raeburn <raeburn@raeburn.org>
parents:
28417
diff
changeset
|
76 |
31907
b786c3535d32
(XINT) [EXPLICIT_SIGN_EXTEND]: Use BITS_PER_EMACS_INT
Gerd Moellmann <gerd@gnu.org>
parents:
31901
diff
changeset
|
77 /* Used for making sure that Emacs is compilable in all |
39194
e07b62d39bec
Fix a typo in a comment. From Pavel Janik <Pavel@Janik.cz>.
Eli Zaretskii <eliz@gnu.org>
parents:
38474
diff
changeset
|
78 configurations. */ |
31907
b786c3535d32
(XINT) [EXPLICIT_SIGN_EXTEND]: Use BITS_PER_EMACS_INT
Gerd Moellmann <gerd@gnu.org>
parents:
31901
diff
changeset
|
79 |
b786c3535d32
(XINT) [EXPLICIT_SIGN_EXTEND]: Use BITS_PER_EMACS_INT
Gerd Moellmann <gerd@gnu.org>
parents:
31901
diff
changeset
|
80 #ifdef USE_LISP_UNION_TYPE |
b786c3535d32
(XINT) [EXPLICIT_SIGN_EXTEND]: Use BITS_PER_EMACS_INT
Gerd Moellmann <gerd@gnu.org>
parents:
31901
diff
changeset
|
81 #undef NO_UNION_TYPE |
b786c3535d32
(XINT) [EXPLICIT_SIGN_EXTEND]: Use BITS_PER_EMACS_INT
Gerd Moellmann <gerd@gnu.org>
parents:
31901
diff
changeset
|
82 #endif |
b786c3535d32
(XINT) [EXPLICIT_SIGN_EXTEND]: Use BITS_PER_EMACS_INT
Gerd Moellmann <gerd@gnu.org>
parents:
31901
diff
changeset
|
83 |
28406
451721e784a8
Stop assuming interval pointers and lisp objects can be distinguished by
Ken Raeburn <raeburn@raeburn.org>
parents:
28141
diff
changeset
|
84 /* Define an Emacs version of "assert", since some system ones are |
451721e784a8
Stop assuming interval pointers and lisp objects can be distinguished by
Ken Raeburn <raeburn@raeburn.org>
parents:
28141
diff
changeset
|
85 flaky. */ |
29337
637117135842
(eassert) [!ENABLE_CHECKING]: Define as `(void) 0'.
Gerd Moellmann <gerd@gnu.org>
parents:
29276
diff
changeset
|
86 #ifndef ENABLE_CHECKING |
637117135842
(eassert) [!ENABLE_CHECKING]: Define as `(void) 0'.
Gerd Moellmann <gerd@gnu.org>
parents:
29276
diff
changeset
|
87 #define eassert(X) (void) 0 |
637117135842
(eassert) [!ENABLE_CHECKING]: Define as `(void) 0'.
Gerd Moellmann <gerd@gnu.org>
parents:
29276
diff
changeset
|
88 #else /* ENABLE_CHECKING */ |
28406
451721e784a8
Stop assuming interval pointers and lisp objects can be distinguished by
Ken Raeburn <raeburn@raeburn.org>
parents:
28141
diff
changeset
|
89 #if defined (__GNUC__) && __GNUC__ >= 2 && defined (__STDC__) |
451721e784a8
Stop assuming interval pointers and lisp objects can be distinguished by
Ken Raeburn <raeburn@raeburn.org>
parents:
28141
diff
changeset
|
90 #define eassert(cond) CHECK(cond,"assertion failed: " #cond) |
451721e784a8
Stop assuming interval pointers and lisp objects can be distinguished by
Ken Raeburn <raeburn@raeburn.org>
parents:
28141
diff
changeset
|
91 #else |
451721e784a8
Stop assuming interval pointers and lisp objects can be distinguished by
Ken Raeburn <raeburn@raeburn.org>
parents:
28141
diff
changeset
|
92 #define eassert(cond) CHECK(cond,"assertion failed") |
451721e784a8
Stop assuming interval pointers and lisp objects can be distinguished by
Ken Raeburn <raeburn@raeburn.org>
parents:
28141
diff
changeset
|
93 #endif |
29337
637117135842
(eassert) [!ENABLE_CHECKING]: Define as `(void) 0'.
Gerd Moellmann <gerd@gnu.org>
parents:
29276
diff
changeset
|
94 #endif /* ENABLE_CHECKING */ |
28406
451721e784a8
Stop assuming interval pointers and lisp objects can be distinguished by
Ken Raeburn <raeburn@raeburn.org>
parents:
28141
diff
changeset
|
95 |
10316
272f15eddaca
(enum Lisp_Type): Delete Lisp_Buffer.
Richard M. Stallman <rms@gnu.org>
parents:
10292
diff
changeset
|
96 /* Define the fundamental Lisp data structures. */ |
302 | 97 |
10316
272f15eddaca
(enum Lisp_Type): Delete Lisp_Buffer.
Richard M. Stallman <rms@gnu.org>
parents:
10292
diff
changeset
|
98 /* This is the set of Lisp data types. */ |
302 | 99 |
100 enum Lisp_Type | |
101 { | |
10316
272f15eddaca
(enum Lisp_Type): Delete Lisp_Buffer.
Richard M. Stallman <rms@gnu.org>
parents:
10292
diff
changeset
|
102 /* Integer. XINT (obj) is the integer value. */ |
302 | 103 Lisp_Int, |
104 | |
10316
272f15eddaca
(enum Lisp_Type): Delete Lisp_Buffer.
Richard M. Stallman <rms@gnu.org>
parents:
10292
diff
changeset
|
105 /* Symbol. XSYMBOL (object) points to a struct Lisp_Symbol. */ |
302 | 106 Lisp_Symbol, |
107 | |
9435
3a157cdf395c
(Lisp_Misc): new type code, replacing Lisp_Marker (and soon to replace other
Karl Heuer <kwzh@gnu.org>
parents:
9392
diff
changeset
|
108 /* Miscellaneous. XMISC (object) points to a union Lisp_Misc, |
3a157cdf395c
(Lisp_Misc): new type code, replacing Lisp_Marker (and soon to replace other
Karl Heuer <kwzh@gnu.org>
parents:
9392
diff
changeset
|
109 whose first member indicates the subtype. */ |
3a157cdf395c
(Lisp_Misc): new type code, replacing Lisp_Marker (and soon to replace other
Karl Heuer <kwzh@gnu.org>
parents:
9392
diff
changeset
|
110 Lisp_Misc, |
302 | 111 |
112 /* String. XSTRING (object) points to a struct Lisp_String. | |
10316
272f15eddaca
(enum Lisp_Type): Delete Lisp_Buffer.
Richard M. Stallman <rms@gnu.org>
parents:
10292
diff
changeset
|
113 The length of the string, and its contents, are stored therein. */ |
302 | 114 Lisp_String, |
115 | |
10010
67375493afa2
(enum Lisp_Misc_Type): Rename Lisp_Vector to Lisp_Vectorlike. Mark
Karl Heuer <kwzh@gnu.org>
parents:
10003
diff
changeset
|
116 /* Vector of Lisp objects, or something resembling it. |
10292
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
117 XVECTOR (object) points to a struct Lisp_Vector, which contains |
10010
67375493afa2
(enum Lisp_Misc_Type): Rename Lisp_Vector to Lisp_Vectorlike. Mark
Karl Heuer <kwzh@gnu.org>
parents:
10003
diff
changeset
|
118 the size and contents. The size field also contains the type |
67375493afa2
(enum Lisp_Misc_Type): Rename Lisp_Vector to Lisp_Vectorlike. Mark
Karl Heuer <kwzh@gnu.org>
parents:
10003
diff
changeset
|
119 information, if it's not a real vector object. */ |
67375493afa2
(enum Lisp_Misc_Type): Rename Lisp_Vector to Lisp_Vectorlike. Mark
Karl Heuer <kwzh@gnu.org>
parents:
10003
diff
changeset
|
120 Lisp_Vectorlike, |
302 | 121 |
10316
272f15eddaca
(enum Lisp_Type): Delete Lisp_Buffer.
Richard M. Stallman <rms@gnu.org>
parents:
10292
diff
changeset
|
122 /* Cons. XCONS (object) points to a struct Lisp_Cons. */ |
302 | 123 Lisp_Cons, |
124 | |
2780
cfe7659bbc05
* lisp.h (Lisp_Overlay): New tag.
Jim Blandy <jimb@redhat.com>
parents:
2728
diff
changeset
|
125 Lisp_Float, |
10246
c000ce65503e
(enum Lisp_Type): Add Max_Lisp_Type.
Richard M. Stallman <rms@gnu.org>
parents:
10032
diff
changeset
|
126 |
c000ce65503e
(enum Lisp_Type): Add Max_Lisp_Type.
Richard M. Stallman <rms@gnu.org>
parents:
10032
diff
changeset
|
127 /* This is not a type code. It is for range checking. */ |
10321
c91b1f4295a1
(enum Lisp_Type): Don't use trailing comma.
Karl Heuer <kwzh@gnu.org>
parents:
10316
diff
changeset
|
128 Lisp_Type_Limit |
302 | 129 }; |
130 | |
39579
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
131 /* This is the set of data types that share a common structure. |
10396
47938020b39d
Use large constants for Lisp_Misc_Type.
Karl Heuer <kwzh@gnu.org>
parents:
10387
diff
changeset
|
132 The first member of the structure is a type code from this set. |
47938020b39d
Use large constants for Lisp_Misc_Type.
Karl Heuer <kwzh@gnu.org>
parents:
10387
diff
changeset
|
133 The enum values are arbitrary, but we'll use large numbers to make it |
47938020b39d
Use large constants for Lisp_Misc_Type.
Karl Heuer <kwzh@gnu.org>
parents:
10387
diff
changeset
|
134 more likely that we'll spot the error if a random word in memory is |
47938020b39d
Use large constants for Lisp_Misc_Type.
Karl Heuer <kwzh@gnu.org>
parents:
10387
diff
changeset
|
135 mistakenly interpreted as a Lisp_Misc. */ |
9392
32186e807f02
(enum Lisp_Misc_Type): New type.
Karl Heuer <kwzh@gnu.org>
parents:
9370
diff
changeset
|
136 enum Lisp_Misc_Type |
32186e807f02
(enum Lisp_Misc_Type): New type.
Karl Heuer <kwzh@gnu.org>
parents:
9370
diff
changeset
|
137 { |
10396
47938020b39d
Use large constants for Lisp_Misc_Type.
Karl Heuer <kwzh@gnu.org>
parents:
10387
diff
changeset
|
138 Lisp_Misc_Free = 0x5eab, |
9435
3a157cdf395c
(Lisp_Misc): new type code, replacing Lisp_Marker (and soon to replace other
Karl Heuer <kwzh@gnu.org>
parents:
9392
diff
changeset
|
139 Lisp_Misc_Marker, |
9462
3601bf7327b2
(enum Lisp_Misc_Type): Add new enumerations Lisp_Misc_Intfwd,
Karl Heuer <kwzh@gnu.org>
parents:
9435
diff
changeset
|
140 Lisp_Misc_Intfwd, |
3601bf7327b2
(enum Lisp_Misc_Type): Add new enumerations Lisp_Misc_Intfwd,
Karl Heuer <kwzh@gnu.org>
parents:
9435
diff
changeset
|
141 Lisp_Misc_Boolfwd, |
3601bf7327b2
(enum Lisp_Misc_Type): Add new enumerations Lisp_Misc_Intfwd,
Karl Heuer <kwzh@gnu.org>
parents:
9435
diff
changeset
|
142 Lisp_Misc_Objfwd, |
9891
f4a53f86853d
(enum Lisp_Misc_Type): Add new enumerations Lisp_Misc_Buffer_Local_Value and
Karl Heuer <kwzh@gnu.org>
parents:
9885
diff
changeset
|
143 Lisp_Misc_Buffer_Objfwd, |
f4a53f86853d
(enum Lisp_Misc_Type): Add new enumerations Lisp_Misc_Buffer_Local_Value and
Karl Heuer <kwzh@gnu.org>
parents:
9885
diff
changeset
|
144 Lisp_Misc_Buffer_Local_Value, |
9924
594e838f4567
(enum Lisp_Misc_Type): Add new enumeration Lisp_Misc_Overlay.
Karl Heuer <kwzh@gnu.org>
parents:
9904
diff
changeset
|
145 Lisp_Misc_Some_Buffer_Local_Value, |
10316
272f15eddaca
(enum Lisp_Type): Delete Lisp_Buffer.
Richard M. Stallman <rms@gnu.org>
parents:
10292
diff
changeset
|
146 Lisp_Misc_Overlay, |
11012
31d88266ed12
(struct KBOARD, MULTI_KBOARD, current_kboard, all_kboards,
Karl Heuer <kwzh@gnu.org>
parents:
10944
diff
changeset
|
147 Lisp_Misc_Kboard_Objfwd, |
49056
88f14a14e005
New misc type Lisp_Save_Value.
Richard M. Stallman <rms@gnu.org>
parents:
48540
diff
changeset
|
148 Lisp_Misc_Save_Value, |
10316
272f15eddaca
(enum Lisp_Type): Delete Lisp_Buffer.
Richard M. Stallman <rms@gnu.org>
parents:
10292
diff
changeset
|
149 /* Currently floats are not a misc type, |
272f15eddaca
(enum Lisp_Type): Delete Lisp_Buffer.
Richard M. Stallman <rms@gnu.org>
parents:
10292
diff
changeset
|
150 but let's define this in case we want to change that. */ |
272f15eddaca
(enum Lisp_Type): Delete Lisp_Buffer.
Richard M. Stallman <rms@gnu.org>
parents:
10292
diff
changeset
|
151 Lisp_Misc_Float, |
272f15eddaca
(enum Lisp_Type): Delete Lisp_Buffer.
Richard M. Stallman <rms@gnu.org>
parents:
10292
diff
changeset
|
152 /* This is not a type code. It is for range checking. */ |
272f15eddaca
(enum Lisp_Type): Delete Lisp_Buffer.
Richard M. Stallman <rms@gnu.org>
parents:
10292
diff
changeset
|
153 Lisp_Misc_Limit |
9392
32186e807f02
(enum Lisp_Misc_Type): New type.
Karl Heuer <kwzh@gnu.org>
parents:
9370
diff
changeset
|
154 }; |
32186e807f02
(enum Lisp_Misc_Type): New type.
Karl Heuer <kwzh@gnu.org>
parents:
9370
diff
changeset
|
155 |
51858
bf6232373c39
(VALBITS): Define in terms of GCTYPEBITS.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51833
diff
changeset
|
156 #ifndef GCTYPEBITS |
bf6232373c39
(VALBITS): Define in terms of GCTYPEBITS.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51833
diff
changeset
|
157 #define GCTYPEBITS 3 |
bf6232373c39
(VALBITS): Define in terms of GCTYPEBITS.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51833
diff
changeset
|
158 #endif |
bf6232373c39
(VALBITS): Define in terms of GCTYPEBITS.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51833
diff
changeset
|
159 |
10321
c91b1f4295a1
(enum Lisp_Type): Don't use trailing comma.
Karl Heuer <kwzh@gnu.org>
parents:
10316
diff
changeset
|
160 /* These values are overridden by the m- file on some machines. */ |
c91b1f4295a1
(enum Lisp_Type): Don't use trailing comma.
Karl Heuer <kwzh@gnu.org>
parents:
10316
diff
changeset
|
161 #ifndef VALBITS |
52476
1b64668b2442
(VALBITS): Don't remove 1 for the markbit.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
52401
diff
changeset
|
162 #define VALBITS (BITS_PER_EMACS_INT - GCTYPEBITS) |
10321
c91b1f4295a1
(enum Lisp_Type): Don't use trailing comma.
Karl Heuer <kwzh@gnu.org>
parents:
10316
diff
changeset
|
163 #endif |
c91b1f4295a1
(enum Lisp_Type): Don't use trailing comma.
Karl Heuer <kwzh@gnu.org>
parents:
10316
diff
changeset
|
164 |
302 | 165 #ifndef NO_UNION_TYPE |
166 | |
5241
1536c6b80ff6
Use WORDS_BIG_ENDIAN, not BIG_ENDIAN.
Richard M. Stallman <rms@gnu.org>
parents:
5128
diff
changeset
|
167 #ifndef WORDS_BIG_ENDIAN |
302 | 168 |
169 /* Definition of Lisp_Object for little-endian machines. */ | |
170 | |
171 typedef | |
172 union Lisp_Object | |
173 { | |
174 /* Used for comparing two Lisp_Objects; | |
10316
272f15eddaca
(enum Lisp_Type): Delete Lisp_Buffer.
Richard M. Stallman <rms@gnu.org>
parents:
10292
diff
changeset
|
175 also, positive integers can be accessed fast this way. */ |
31901
4e2853ad5d2d
(union Lisp_Object) [!NO_UNION_TYPE]: Use EMACS_INT and
Gerd Moellmann <gerd@gnu.org>
parents:
31833
diff
changeset
|
176 EMACS_INT i; |
302 | 177 |
178 struct | |
179 { | |
31901
4e2853ad5d2d
(union Lisp_Object) [!NO_UNION_TYPE]: Use EMACS_INT and
Gerd Moellmann <gerd@gnu.org>
parents:
31833
diff
changeset
|
180 EMACS_INT val : VALBITS; |
52476
1b64668b2442
(VALBITS): Don't remove 1 for the markbit.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
52401
diff
changeset
|
181 EMACS_UINT type : GCTYPEBITS; |
302 | 182 } s; |
183 struct | |
184 { | |
31901
4e2853ad5d2d
(union Lisp_Object) [!NO_UNION_TYPE]: Use EMACS_INT and
Gerd Moellmann <gerd@gnu.org>
parents:
31833
diff
changeset
|
185 EMACS_UINT val : VALBITS; |
52476
1b64668b2442
(VALBITS): Don't remove 1 for the markbit.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
52401
diff
changeset
|
186 EMACS_UINT type : GCTYPEBITS; |
302 | 187 } u; |
188 struct | |
189 { | |
31901
4e2853ad5d2d
(union Lisp_Object) [!NO_UNION_TYPE]: Use EMACS_INT and
Gerd Moellmann <gerd@gnu.org>
parents:
31833
diff
changeset
|
190 EMACS_UINT val : VALBITS; |
4e2853ad5d2d
(union Lisp_Object) [!NO_UNION_TYPE]: Use EMACS_INT and
Gerd Moellmann <gerd@gnu.org>
parents:
31833
diff
changeset
|
191 enum Lisp_Type type : GCTYPEBITS; |
302 | 192 } gu; |
193 } | |
194 Lisp_Object; | |
195 | |
5241
1536c6b80ff6
Use WORDS_BIG_ENDIAN, not BIG_ENDIAN.
Richard M. Stallman <rms@gnu.org>
parents:
5128
diff
changeset
|
196 #else /* If WORDS_BIG_ENDIAN */ |
302 | 197 |
198 typedef | |
199 union Lisp_Object | |
200 { | |
201 /* Used for comparing two Lisp_Objects; | |
10316
272f15eddaca
(enum Lisp_Type): Delete Lisp_Buffer.
Richard M. Stallman <rms@gnu.org>
parents:
10292
diff
changeset
|
202 also, positive integers can be accessed fast this way. */ |
31901
4e2853ad5d2d
(union Lisp_Object) [!NO_UNION_TYPE]: Use EMACS_INT and
Gerd Moellmann <gerd@gnu.org>
parents:
31833
diff
changeset
|
203 EMACS_INT i; |
302 | 204 |
205 struct | |
206 { | |
52476
1b64668b2442
(VALBITS): Don't remove 1 for the markbit.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
52401
diff
changeset
|
207 EMACS_UINT type : GCTYPEBITS; |
31901
4e2853ad5d2d
(union Lisp_Object) [!NO_UNION_TYPE]: Use EMACS_INT and
Gerd Moellmann <gerd@gnu.org>
parents:
31833
diff
changeset
|
208 EMACS_INT val : VALBITS; |
302 | 209 } s; |
210 struct | |
211 { | |
52476
1b64668b2442
(VALBITS): Don't remove 1 for the markbit.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
52401
diff
changeset
|
212 EMACS_UINT type : GCTYPEBITS; |
31901
4e2853ad5d2d
(union Lisp_Object) [!NO_UNION_TYPE]: Use EMACS_INT and
Gerd Moellmann <gerd@gnu.org>
parents:
31833
diff
changeset
|
213 EMACS_UINT val : VALBITS; |
302 | 214 } u; |
215 struct | |
216 { | |
31901
4e2853ad5d2d
(union Lisp_Object) [!NO_UNION_TYPE]: Use EMACS_INT and
Gerd Moellmann <gerd@gnu.org>
parents:
31833
diff
changeset
|
217 enum Lisp_Type type : GCTYPEBITS; |
4e2853ad5d2d
(union Lisp_Object) [!NO_UNION_TYPE]: Use EMACS_INT and
Gerd Moellmann <gerd@gnu.org>
parents:
31833
diff
changeset
|
218 EMACS_UINT val : VALBITS; |
302 | 219 } gu; |
220 } | |
221 Lisp_Object; | |
222 | |
5241
1536c6b80ff6
Use WORDS_BIG_ENDIAN, not BIG_ENDIAN.
Richard M. Stallman <rms@gnu.org>
parents:
5128
diff
changeset
|
223 #endif /* WORDS_BIG_ENDIAN */ |
302 | 224 |
39973
579177964efa
Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents:
39924
diff
changeset
|
225 #ifdef __GNUC__ |
579177964efa
Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents:
39924
diff
changeset
|
226 static __inline__ Lisp_Object |
579177964efa
Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents:
39924
diff
changeset
|
227 LISP_MAKE_RVALUE (Lisp_Object o) |
579177964efa
Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents:
39924
diff
changeset
|
228 { |
579177964efa
Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents:
39924
diff
changeset
|
229 return o; |
579177964efa
Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents:
39924
diff
changeset
|
230 } |
579177964efa
Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents:
39924
diff
changeset
|
231 #else |
45416
c6aa7f66df20
update LISP_MAKE_RVALUE comment for union, non-gcc case
Ken Raeburn <raeburn@raeburn.org>
parents:
45405
diff
changeset
|
232 /* This isn't quite right - it keeps the argument as an lvalue. |
c6aa7f66df20
update LISP_MAKE_RVALUE comment for union, non-gcc case
Ken Raeburn <raeburn@raeburn.org>
parents:
45405
diff
changeset
|
233 Making it const via casting would help avoid code actually |
c6aa7f66df20
update LISP_MAKE_RVALUE comment for union, non-gcc case
Ken Raeburn <raeburn@raeburn.org>
parents:
45405
diff
changeset
|
234 modifying the location in question, but the casting could cover |
c6aa7f66df20
update LISP_MAKE_RVALUE comment for union, non-gcc case
Ken Raeburn <raeburn@raeburn.org>
parents:
45405
diff
changeset
|
235 other type-related bugs. */ |
c6aa7f66df20
update LISP_MAKE_RVALUE comment for union, non-gcc case
Ken Raeburn <raeburn@raeburn.org>
parents:
45405
diff
changeset
|
236 #define LISP_MAKE_RVALUE(o) (o) |
39973
579177964efa
Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents:
39924
diff
changeset
|
237 #endif |
579177964efa
Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents:
39924
diff
changeset
|
238 |
302 | 239 #endif /* NO_UNION_TYPE */ |
240 | |
241 | |
18115
06ce39d8e93e
(VALMASK, GCTYPEMASK, MARKBIT, ARRAY_MARK_FLAG)
Richard M. Stallman <rms@gnu.org>
parents:
18111
diff
changeset
|
242 /* If union type is not wanted, define Lisp_Object as just a number. */ |
302 | 243 |
244 #ifdef NO_UNION_TYPE | |
8827
97bf951c0b98
(Lisp_Object): Use EMACS_INT.
Richard M. Stallman <rms@gnu.org>
parents:
8631
diff
changeset
|
245 #define Lisp_Object EMACS_INT |
39973
579177964efa
Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents:
39924
diff
changeset
|
246 #define LISP_MAKE_RVALUE(o) (0+(o)) |
18115
06ce39d8e93e
(VALMASK, GCTYPEMASK, MARKBIT, ARRAY_MARK_FLAG)
Richard M. Stallman <rms@gnu.org>
parents:
18111
diff
changeset
|
247 #endif /* NO_UNION_TYPE */ |
302 | 248 |
6216
9f7708f75f17
(ARRAY_MARK_FLAG): Define here.
Richard M. Stallman <rms@gnu.org>
parents:
6131
diff
changeset
|
249 /* Two flags that are set during GC. On some machines, these flags |
9f7708f75f17
(ARRAY_MARK_FLAG): Define here.
Richard M. Stallman <rms@gnu.org>
parents:
6131
diff
changeset
|
250 are defined differently by the m- file. */ |
9f7708f75f17
(ARRAY_MARK_FLAG): Define here.
Richard M. Stallman <rms@gnu.org>
parents:
6131
diff
changeset
|
251 |
51685
5c80476f5ff2
(MARKBIT): Update comment.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51666
diff
changeset
|
252 /* In the size word of a vector, this bit means the vector has been marked. */ |
6216
9f7708f75f17
(ARRAY_MARK_FLAG): Define here.
Richard M. Stallman <rms@gnu.org>
parents:
6131
diff
changeset
|
253 |
9f7708f75f17
(ARRAY_MARK_FLAG): Define here.
Richard M. Stallman <rms@gnu.org>
parents:
6131
diff
changeset
|
254 #ifndef ARRAY_MARK_FLAG |
53088
63a8b584e971
(VALMASK): Only define for non-union type.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
53001
diff
changeset
|
255 #define ARRAY_MARK_FLAG ((EMACS_INT) ((EMACS_UINT) 1 << (VALBITS + GCTYPEBITS - 1))) |
6216
9f7708f75f17
(ARRAY_MARK_FLAG): Define here.
Richard M. Stallman <rms@gnu.org>
parents:
6131
diff
changeset
|
256 #endif /* no ARRAY_MARK_FLAG */ |
9f7708f75f17
(ARRAY_MARK_FLAG): Define here.
Richard M. Stallman <rms@gnu.org>
parents:
6131
diff
changeset
|
257 |
10010
67375493afa2
(enum Lisp_Misc_Type): Rename Lisp_Vector to Lisp_Vectorlike. Mark
Karl Heuer <kwzh@gnu.org>
parents:
10003
diff
changeset
|
258 /* In the size word of a struct Lisp_Vector, this bit means it's really |
67375493afa2
(enum Lisp_Misc_Type): Rename Lisp_Vector to Lisp_Vectorlike. Mark
Karl Heuer <kwzh@gnu.org>
parents:
10003
diff
changeset
|
259 some other vector-like object. */ |
67375493afa2
(enum Lisp_Misc_Type): Rename Lisp_Vector to Lisp_Vectorlike. Mark
Karl Heuer <kwzh@gnu.org>
parents:
10003
diff
changeset
|
260 #ifndef PSEUDOVECTOR_FLAG |
67375493afa2
(enum Lisp_Misc_Type): Rename Lisp_Vector to Lisp_Vectorlike. Mark
Karl Heuer <kwzh@gnu.org>
parents:
10003
diff
changeset
|
261 #define PSEUDOVECTOR_FLAG ((ARRAY_MARK_FLAG >> 1) & ~ARRAY_MARK_FLAG) |
67375493afa2
(enum Lisp_Misc_Type): Rename Lisp_Vector to Lisp_Vectorlike. Mark
Karl Heuer <kwzh@gnu.org>
parents:
10003
diff
changeset
|
262 #endif |
67375493afa2
(enum Lisp_Misc_Type): Rename Lisp_Vector to Lisp_Vectorlike. Mark
Karl Heuer <kwzh@gnu.org>
parents:
10003
diff
changeset
|
263 |
10322
c1c2ec3aeefa
Use consistent spelling in comments.
Karl Heuer <kwzh@gnu.org>
parents:
10321
diff
changeset
|
264 /* In a pseudovector, the size field actually contains a word with one |
10010
67375493afa2
(enum Lisp_Misc_Type): Rename Lisp_Vector to Lisp_Vectorlike. Mark
Karl Heuer <kwzh@gnu.org>
parents:
10003
diff
changeset
|
265 PSEUDOVECTOR_FLAG bit set, and exactly one of the following bits to |
67375493afa2
(enum Lisp_Misc_Type): Rename Lisp_Vector to Lisp_Vectorlike. Mark
Karl Heuer <kwzh@gnu.org>
parents:
10003
diff
changeset
|
266 indicate the actual type. */ |
10316
272f15eddaca
(enum Lisp_Type): Delete Lisp_Buffer.
Richard M. Stallman <rms@gnu.org>
parents:
10292
diff
changeset
|
267 enum pvec_type |
272f15eddaca
(enum Lisp_Type): Delete Lisp_Buffer.
Richard M. Stallman <rms@gnu.org>
parents:
10292
diff
changeset
|
268 { |
272f15eddaca
(enum Lisp_Type): Delete Lisp_Buffer.
Richard M. Stallman <rms@gnu.org>
parents:
10292
diff
changeset
|
269 PVEC_NORMAL_VECTOR = 0, |
272f15eddaca
(enum Lisp_Type): Delete Lisp_Buffer.
Richard M. Stallman <rms@gnu.org>
parents:
10292
diff
changeset
|
270 PVEC_PROCESS = 0x200, |
272f15eddaca
(enum Lisp_Type): Delete Lisp_Buffer.
Richard M. Stallman <rms@gnu.org>
parents:
10292
diff
changeset
|
271 PVEC_FRAME = 0x400, |
272f15eddaca
(enum Lisp_Type): Delete Lisp_Buffer.
Richard M. Stallman <rms@gnu.org>
parents:
10292
diff
changeset
|
272 PVEC_COMPILED = 0x800, |
272f15eddaca
(enum Lisp_Type): Delete Lisp_Buffer.
Richard M. Stallman <rms@gnu.org>
parents:
10292
diff
changeset
|
273 PVEC_WINDOW = 0x1000, |
272f15eddaca
(enum Lisp_Type): Delete Lisp_Buffer.
Richard M. Stallman <rms@gnu.org>
parents:
10292
diff
changeset
|
274 PVEC_WINDOW_CONFIGURATION = 0x2000, |
272f15eddaca
(enum Lisp_Type): Delete Lisp_Buffer.
Richard M. Stallman <rms@gnu.org>
parents:
10292
diff
changeset
|
275 PVEC_SUBR = 0x4000, |
13149
b1dcc3e87ffb
(struct Lisp_Boolvector): New data type.
Richard M. Stallman <rms@gnu.org>
parents:
12890
diff
changeset
|
276 PVEC_CHAR_TABLE = 0x8000, |
b1dcc3e87ffb
(struct Lisp_Boolvector): New data type.
Richard M. Stallman <rms@gnu.org>
parents:
12890
diff
changeset
|
277 PVEC_BOOL_VECTOR = 0x10000, |
b1dcc3e87ffb
(struct Lisp_Boolvector): New data type.
Richard M. Stallman <rms@gnu.org>
parents:
12890
diff
changeset
|
278 PVEC_BUFFER = 0x20000, |
25017
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
279 PVEC_HASH_TABLE = 0x40000, |
26569
d5f7eaff00db
Fix typo in previous change.
Gerd Moellmann <gerd@gnu.org>
parents:
26566
diff
changeset
|
280 PVEC_TYPE_MASK = 0x7fe00 |
45623
0e92d219e195
(current_column): Now returns float.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents:
45545
diff
changeset
|
281 |
26569
d5f7eaff00db
Fix typo in previous change.
Gerd Moellmann <gerd@gnu.org>
parents:
26566
diff
changeset
|
282 #if 0 /* This is used to make the value of PSEUDOVECTOR_FLAG available to |
d5f7eaff00db
Fix typo in previous change.
Gerd Moellmann <gerd@gnu.org>
parents:
26566
diff
changeset
|
283 GDB. It doesn't work on OS Alpha. Moved to a variable in |
d5f7eaff00db
Fix typo in previous change.
Gerd Moellmann <gerd@gnu.org>
parents:
26566
diff
changeset
|
284 emacs.c. */ |
12246
4de2d34c04d3
(enum pvec_type): Don't use trailing comma.
Karl Heuer <kwzh@gnu.org>
parents:
12114
diff
changeset
|
285 PVEC_FLAG = PSEUDOVECTOR_FLAG |
26569
d5f7eaff00db
Fix typo in previous change.
Gerd Moellmann <gerd@gnu.org>
parents:
26566
diff
changeset
|
286 #endif |
10316
272f15eddaca
(enum Lisp_Type): Delete Lisp_Buffer.
Richard M. Stallman <rms@gnu.org>
parents:
10292
diff
changeset
|
287 }; |
10010
67375493afa2
(enum Lisp_Misc_Type): Rename Lisp_Vector to Lisp_Vectorlike. Mark
Karl Heuer <kwzh@gnu.org>
parents:
10003
diff
changeset
|
288 |
67375493afa2
(enum Lisp_Misc_Type): Rename Lisp_Vector to Lisp_Vectorlike. Mark
Karl Heuer <kwzh@gnu.org>
parents:
10003
diff
changeset
|
289 /* For convenience, we also store the number of elements in these bits. */ |
13149
b1dcc3e87ffb
(struct Lisp_Boolvector): New data type.
Richard M. Stallman <rms@gnu.org>
parents:
12890
diff
changeset
|
290 #define PSEUDOVECTOR_SIZE_MASK 0x1ff |
302 | 291 |
292 /* These macros extract various sorts of values from a Lisp_Object. | |
293 For example, if tem is a Lisp_Object whose type is Lisp_Cons, | |
10316
272f15eddaca
(enum Lisp_Type): Delete Lisp_Buffer.
Richard M. Stallman <rms@gnu.org>
parents:
10292
diff
changeset
|
294 XCONS (tem) is the struct Lisp_Cons * pointing to the memory for that cons. */ |
302 | 295 |
296 #ifdef NO_UNION_TYPE | |
297 | |
53088
63a8b584e971
(VALMASK): Only define for non-union type.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
53001
diff
changeset
|
298 #define VALMASK ((((EMACS_INT) 1) << VALBITS) - 1) |
63a8b584e971
(VALMASK): Only define for non-union type.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
53001
diff
changeset
|
299 |
302 | 300 /* One need to override this if there must be high bits set in data space |
301 (doing the result of the below & ((1 << (GCTYPE + 1)) - 1) would work | |
39579
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
302 on all machines, but would penalize machines which don't need it) |
302 | 303 */ |
52476
1b64668b2442
(VALBITS): Don't remove 1 for the markbit.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
52401
diff
changeset
|
304 #define XTYPE(a) ((enum Lisp_Type) (((EMACS_UINT) (a)) >> VALBITS)) |
302 | 305 |
9292 | 306 /* For integers known to be positive, XFASTINT provides fast retrieval |
307 and XSETFASTINT provides fast storage. This takes advantage of the | |
53088
63a8b584e971
(VALMASK): Only define for non-union type.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
53001
diff
changeset
|
308 fact that Lisp_Int is 0. */ |
9328
4db4768d5857
(XFASTINT): Changed to non-lvalue syntax, to ensure that callers will use
Karl Heuer <kwzh@gnu.org>
parents:
9292
diff
changeset
|
309 #define XFASTINT(a) ((a) + 0) |
9292 | 310 #define XSETFASTINT(a, b) ((a) = (b)) |
302 | 311 |
312 /* Extract the value of a Lisp_Object as a signed integer. */ | |
313 | |
314 #ifndef XINT /* Some machines need to do this differently. */ | |
52998
3d26cfe32fa7
(XINT): Move the cast to clarify what is going on.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
52476
diff
changeset
|
315 #define XINT(a) ((((EMACS_INT) (a)) << (BITS_PER_EMACS_INT - VALBITS)) \ |
3d26cfe32fa7
(XINT): Move the cast to clarify what is going on.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
52476
diff
changeset
|
316 >> (BITS_PER_EMACS_INT - VALBITS)) |
302 | 317 #endif |
318 | |
319 /* Extract the value as an unsigned integer. This is a basis | |
320 for extracting it as a pointer to a structure in storage. */ | |
321 | |
322 #ifndef XUINT | |
31907
b786c3535d32
(XINT) [EXPLICIT_SIGN_EXTEND]: Use BITS_PER_EMACS_INT
Gerd Moellmann <gerd@gnu.org>
parents:
31901
diff
changeset
|
323 #define XUINT(a) ((EMACS_UINT) ((a) & VALMASK)) |
302 | 324 #endif |
325 | |
326 #ifndef XSET | |
327 #define XSET(var, type, ptr) \ | |
8827
97bf951c0b98
(Lisp_Object): Use EMACS_INT.
Richard M. Stallman <rms@gnu.org>
parents:
8631
diff
changeset
|
328 ((var) = ((EMACS_INT)(type) << VALBITS) + ((EMACS_INT) (ptr) & VALMASK)) |
302 | 329 #endif |
330 | |
14306
b30429f0b599
(XCAR, XCDR, CAR, CDR): New macros.
Karl Heuer <kwzh@gnu.org>
parents:
14186
diff
changeset
|
331 /* Convert a C integer into a Lisp_Object integer. */ |
b30429f0b599
(XCAR, XCDR, CAR, CDR): New macros.
Karl Heuer <kwzh@gnu.org>
parents:
14186
diff
changeset
|
332 |
b30429f0b599
(XCAR, XCDR, CAR, CDR): New macros.
Karl Heuer <kwzh@gnu.org>
parents:
14186
diff
changeset
|
333 #define make_number(N) \ |
b30429f0b599
(XCAR, XCDR, CAR, CDR): New macros.
Karl Heuer <kwzh@gnu.org>
parents:
14186
diff
changeset
|
334 ((((EMACS_INT) (N)) & VALMASK) | ((EMACS_INT) Lisp_Int) << VALBITS) |
b30429f0b599
(XCAR, XCDR, CAR, CDR): New macros.
Karl Heuer <kwzh@gnu.org>
parents:
14186
diff
changeset
|
335 |
53088
63a8b584e971
(VALMASK): Only define for non-union type.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
53001
diff
changeset
|
336 #define EQ(x, y) ((x) == (y)) |
63a8b584e971
(VALMASK): Only define for non-union type.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
53001
diff
changeset
|
337 |
63a8b584e971
(VALMASK): Only define for non-union type.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
53001
diff
changeset
|
338 #else /* not NO_UNION_TYPE */ |
302 | 339 |
340 #define XTYPE(a) ((enum Lisp_Type) (a).u.type) | |
341 | |
9292 | 342 /* For integers known to be positive, XFASTINT provides fast retrieval |
343 and XSETFASTINT provides fast storage. This takes advantage of the | |
344 fact that Lisp_Int is 0. */ | |
9328
4db4768d5857
(XFASTINT): Changed to non-lvalue syntax, to ensure that callers will use
Karl Heuer <kwzh@gnu.org>
parents:
9292
diff
changeset
|
345 #define XFASTINT(a) ((a).i + 0) |
9292 | 346 #define XSETFASTINT(a, b) ((a).i = (b)) |
302 | 347 |
348 #ifdef EXPLICIT_SIGN_EXTEND | |
349 /* Make sure we sign-extend; compilers have been known to fail to do so. */ | |
31907
b786c3535d32
(XINT) [EXPLICIT_SIGN_EXTEND]: Use BITS_PER_EMACS_INT
Gerd Moellmann <gerd@gnu.org>
parents:
31901
diff
changeset
|
350 #define XINT(a) (((a).i << (BITS_PER_EMACS_INT - VALBITS)) \ |
b786c3535d32
(XINT) [EXPLICIT_SIGN_EXTEND]: Use BITS_PER_EMACS_INT
Gerd Moellmann <gerd@gnu.org>
parents:
31901
diff
changeset
|
351 >> (BITS_PER_EMACS_INT - VALBITS)) |
302 | 352 #else |
353 #define XINT(a) ((a).s.val) | |
354 #endif /* EXPLICIT_SIGN_EXTEND */ | |
355 | |
356 #define XUINT(a) ((a).u.val) | |
357 | |
358 #define XSET(var, vartype, ptr) \ | |
31901
4e2853ad5d2d
(union Lisp_Object) [!NO_UNION_TYPE]: Use EMACS_INT and
Gerd Moellmann <gerd@gnu.org>
parents:
31833
diff
changeset
|
359 (((var).s.val = ((EMACS_INT) (ptr))), ((var).s.type = ((char) (vartype)))) |
28508
a68042252425
* lisp.h (make_number) [!NO_UNION_TYPE && __GNUC__ >= 2 && __OPTIMIZE__]:
Ken Raeburn <raeburn@raeburn.org>
parents:
28480
diff
changeset
|
360 |
a68042252425
* lisp.h (make_number) [!NO_UNION_TYPE && __GNUC__ >= 2 && __OPTIMIZE__]:
Ken Raeburn <raeburn@raeburn.org>
parents:
28480
diff
changeset
|
361 #if __GNUC__ >= 2 && defined (__OPTIMIZE__) |
a68042252425
* lisp.h (make_number) [!NO_UNION_TYPE && __GNUC__ >= 2 && __OPTIMIZE__]:
Ken Raeburn <raeburn@raeburn.org>
parents:
28480
diff
changeset
|
362 #define make_number(N) \ |
a68042252425
* lisp.h (make_number) [!NO_UNION_TYPE && __GNUC__ >= 2 && __OPTIMIZE__]:
Ken Raeburn <raeburn@raeburn.org>
parents:
28480
diff
changeset
|
363 (__extension__ ({ Lisp_Object _l; _l.s.val = (N); _l.s.type = Lisp_Int; _l; })) |
a68042252425
* lisp.h (make_number) [!NO_UNION_TYPE && __GNUC__ >= 2 && __OPTIMIZE__]:
Ken Raeburn <raeburn@raeburn.org>
parents:
28480
diff
changeset
|
364 #else |
17404
73012b195cf3
(DOWNCASE): Return int, not Lisp_Object.
Karl Heuer <kwzh@gnu.org>
parents:
17326
diff
changeset
|
365 extern Lisp_Object make_number (); |
28508
a68042252425
* lisp.h (make_number) [!NO_UNION_TYPE && __GNUC__ >= 2 && __OPTIMIZE__]:
Ken Raeburn <raeburn@raeburn.org>
parents:
28480
diff
changeset
|
366 #endif |
17404
73012b195cf3
(DOWNCASE): Return int, not Lisp_Object.
Karl Heuer <kwzh@gnu.org>
parents:
17326
diff
changeset
|
367 |
53088
63a8b584e971
(VALMASK): Only define for non-union type.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
53001
diff
changeset
|
368 #define EQ(x, y) ((x).s.val == (y).s.val) |
63a8b584e971
(VALMASK): Only define for non-union type.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
53001
diff
changeset
|
369 |
53000
8e568e954adf
(GCTYPEMASK): Remove.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
52998
diff
changeset
|
370 #endif /* NO_UNION_TYPE */ |
8e568e954adf
(GCTYPEMASK): Remove.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
52998
diff
changeset
|
371 |
302 | 372 /* During garbage collection, XGCTYPE must be used for extracting types |
53000
8e568e954adf
(GCTYPEMASK): Remove.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
52998
diff
changeset
|
373 so that the mark bit is ignored. XMARKBIT accesses the markbit. |
302 | 374 Markbits are used only in particular slots of particular structure types. |
375 Other markbits are always zero. | |
376 Outside of garbage collection, all mark bits are always zero. */ | |
377 | |
53000
8e568e954adf
(GCTYPEMASK): Remove.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
52998
diff
changeset
|
378 #ifndef XGCTYPE |
8e568e954adf
(GCTYPEMASK): Remove.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
52998
diff
changeset
|
379 /* The distinction does not exist now that the MARKBIT has been eliminated. */ |
53088
63a8b584e971
(VALMASK): Only define for non-union type.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
53001
diff
changeset
|
380 #define XGCTYPE(a) XTYPE (a) |
53000
8e568e954adf
(GCTYPEMASK): Remove.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
52998
diff
changeset
|
381 #endif |
302 | 382 |
46650
445d27e93380
(XPNTR): Use NO_UNION_TYPE version for union as well,
Ken Raeburn <raeburn@raeburn.org>
parents:
46573
diff
changeset
|
383 #ifndef XPNTR |
445d27e93380
(XPNTR): Use NO_UNION_TYPE version for union as well,
Ken Raeburn <raeburn@raeburn.org>
parents:
46573
diff
changeset
|
384 #ifdef HAVE_SHM |
445d27e93380
(XPNTR): Use NO_UNION_TYPE version for union as well,
Ken Raeburn <raeburn@raeburn.org>
parents:
46573
diff
changeset
|
385 /* In this representation, data is found in two widely separated segments. */ |
445d27e93380
(XPNTR): Use NO_UNION_TYPE version for union as well,
Ken Raeburn <raeburn@raeburn.org>
parents:
46573
diff
changeset
|
386 extern size_t pure_size; |
445d27e93380
(XPNTR): Use NO_UNION_TYPE version for union as well,
Ken Raeburn <raeburn@raeburn.org>
parents:
46573
diff
changeset
|
387 #define XPNTR(a) \ |
445d27e93380
(XPNTR): Use NO_UNION_TYPE version for union as well,
Ken Raeburn <raeburn@raeburn.org>
parents:
46573
diff
changeset
|
388 (XUINT (a) | (XUINT (a) > pure_size ? DATA_SEG_BITS : PURE_SEG_BITS)) |
445d27e93380
(XPNTR): Use NO_UNION_TYPE version for union as well,
Ken Raeburn <raeburn@raeburn.org>
parents:
46573
diff
changeset
|
389 #else /* not HAVE_SHM */ |
445d27e93380
(XPNTR): Use NO_UNION_TYPE version for union as well,
Ken Raeburn <raeburn@raeburn.org>
parents:
46573
diff
changeset
|
390 #ifdef DATA_SEG_BITS |
445d27e93380
(XPNTR): Use NO_UNION_TYPE version for union as well,
Ken Raeburn <raeburn@raeburn.org>
parents:
46573
diff
changeset
|
391 /* This case is used for the rt-pc. |
445d27e93380
(XPNTR): Use NO_UNION_TYPE version for union as well,
Ken Raeburn <raeburn@raeburn.org>
parents:
46573
diff
changeset
|
392 In the diffs I was given, it checked for ptr = 0 |
445d27e93380
(XPNTR): Use NO_UNION_TYPE version for union as well,
Ken Raeburn <raeburn@raeburn.org>
parents:
46573
diff
changeset
|
393 and did not adjust it in that case. |
445d27e93380
(XPNTR): Use NO_UNION_TYPE version for union as well,
Ken Raeburn <raeburn@raeburn.org>
parents:
46573
diff
changeset
|
394 But I don't think that zero should ever be found |
445d27e93380
(XPNTR): Use NO_UNION_TYPE version for union as well,
Ken Raeburn <raeburn@raeburn.org>
parents:
46573
diff
changeset
|
395 in a Lisp object whose data type says it points to something. */ |
445d27e93380
(XPNTR): Use NO_UNION_TYPE version for union as well,
Ken Raeburn <raeburn@raeburn.org>
parents:
46573
diff
changeset
|
396 #define XPNTR(a) (XUINT (a) | DATA_SEG_BITS) |
445d27e93380
(XPNTR): Use NO_UNION_TYPE version for union as well,
Ken Raeburn <raeburn@raeburn.org>
parents:
46573
diff
changeset
|
397 #else |
445d27e93380
(XPNTR): Use NO_UNION_TYPE version for union as well,
Ken Raeburn <raeburn@raeburn.org>
parents:
46573
diff
changeset
|
398 #define XPNTR(a) XUINT (a) |
445d27e93380
(XPNTR): Use NO_UNION_TYPE version for union as well,
Ken Raeburn <raeburn@raeburn.org>
parents:
46573
diff
changeset
|
399 #endif |
445d27e93380
(XPNTR): Use NO_UNION_TYPE version for union as well,
Ken Raeburn <raeburn@raeburn.org>
parents:
46573
diff
changeset
|
400 #endif /* not HAVE_SHM */ |
445d27e93380
(XPNTR): Use NO_UNION_TYPE version for union as well,
Ken Raeburn <raeburn@raeburn.org>
parents:
46573
diff
changeset
|
401 #endif /* no XPNTR */ |
445d27e93380
(XPNTR): Use NO_UNION_TYPE version for union as well,
Ken Raeburn <raeburn@raeburn.org>
parents:
46573
diff
changeset
|
402 |
39640 | 403 /* Largest and smallest representable fixnum values. These are the C |
404 values. */ | |
405 | |
406 #define MOST_NEGATIVE_FIXNUM - ((EMACS_INT) 1 << (VALBITS - 1)) | |
407 #define MOST_POSITIVE_FIXNUM (((EMACS_INT) 1 << (VALBITS - 1)) - 1) | |
53088
63a8b584e971
(VALMASK): Only define for non-union type.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
53001
diff
changeset
|
408 /* Mask indicating the significant bits of a Lisp_Int. |
63a8b584e971
(VALMASK): Only define for non-union type.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
53001
diff
changeset
|
409 I.e. (x & INTMASK) == XUINT (make_number (x)). */ |
63a8b584e971
(VALMASK): Only define for non-union type.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
53001
diff
changeset
|
410 #define INTMASK ((((EMACS_INT) 1) << VALBITS) - 1) |
39631
3d61dd23854a
(MOST_NEGATIVE_FIXNUM, MOST_POSITIVE_FIXNUM)
Gerd Moellmann <gerd@gnu.org>
parents:
39579
diff
changeset
|
411 |
3d61dd23854a
(MOST_NEGATIVE_FIXNUM, MOST_POSITIVE_FIXNUM)
Gerd Moellmann <gerd@gnu.org>
parents:
39579
diff
changeset
|
412 /* Value is non-zero if C integer I doesn't fit into a Lisp fixnum. */ |
3d61dd23854a
(MOST_NEGATIVE_FIXNUM, MOST_POSITIVE_FIXNUM)
Gerd Moellmann <gerd@gnu.org>
parents:
39579
diff
changeset
|
413 |
3d61dd23854a
(MOST_NEGATIVE_FIXNUM, MOST_POSITIVE_FIXNUM)
Gerd Moellmann <gerd@gnu.org>
parents:
39579
diff
changeset
|
414 #define FIXNUM_OVERFLOW_P(i) \ |
39779
15e432be013a
(FIXNUM_OVERFLOW_P): Cast I to EMACS_INT in comparisons
Gerd Moellmann <gerd@gnu.org>
parents:
39773
diff
changeset
|
415 ((EMACS_INT)(i) > MOST_POSITIVE_FIXNUM \ |
15e432be013a
(FIXNUM_OVERFLOW_P): Cast I to EMACS_INT in comparisons
Gerd Moellmann <gerd@gnu.org>
parents:
39773
diff
changeset
|
416 || (EMACS_INT) (i) < MOST_NEGATIVE_FIXNUM) |
39631
3d61dd23854a
(MOST_NEGATIVE_FIXNUM, MOST_POSITIVE_FIXNUM)
Gerd Moellmann <gerd@gnu.org>
parents:
39579
diff
changeset
|
417 |
10316
272f15eddaca
(enum Lisp_Type): Delete Lisp_Buffer.
Richard M. Stallman <rms@gnu.org>
parents:
10292
diff
changeset
|
418 /* Extract a value or address from a Lisp_Object. */ |
302 | 419 |
28417
4b675266db04
* lisp.h (XCONS, XSTRING, XSYMBOL, XFLOAT, XPROCESS, XWINDOW, XSUBR, XBUFFER):
Ken Raeburn <raeburn@raeburn.org>
parents:
28414
diff
changeset
|
420 #define XCONS(a) (eassert (GC_CONSP(a)),(struct Lisp_Cons *) XPNTR(a)) |
38474
86bc182c8651
* lisp.h (XVECTOR): Verify correct object type before returning a pointer.
Ken Raeburn <raeburn@raeburn.org>
parents:
38289
diff
changeset
|
421 #define XVECTOR(a) (eassert (GC_VECTORLIKEP(a)),(struct Lisp_Vector *) XPNTR(a)) |
28417
4b675266db04
* lisp.h (XCONS, XSTRING, XSYMBOL, XFLOAT, XPROCESS, XWINDOW, XSUBR, XBUFFER):
Ken Raeburn <raeburn@raeburn.org>
parents:
28414
diff
changeset
|
422 #define XSTRING(a) (eassert (GC_STRINGP(a)),(struct Lisp_String *) XPNTR(a)) |
4b675266db04
* lisp.h (XCONS, XSTRING, XSYMBOL, XFLOAT, XPROCESS, XWINDOW, XSUBR, XBUFFER):
Ken Raeburn <raeburn@raeburn.org>
parents:
28414
diff
changeset
|
423 #define XSYMBOL(a) (eassert (GC_SYMBOLP(a)),(struct Lisp_Symbol *) XPNTR(a)) |
4b675266db04
* lisp.h (XCONS, XSTRING, XSYMBOL, XFLOAT, XPROCESS, XWINDOW, XSUBR, XBUFFER):
Ken Raeburn <raeburn@raeburn.org>
parents:
28414
diff
changeset
|
424 #define XFLOAT(a) (eassert (GC_FLOATP(a)),(struct Lisp_Float *) XPNTR(a)) |
10292
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
425 |
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
426 /* Misc types. */ |
30173
420acffb79c2
(AREF, ASET, ASIZE): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
30081
diff
changeset
|
427 |
9435
3a157cdf395c
(Lisp_Misc): new type code, replacing Lisp_Marker (and soon to replace other
Karl Heuer <kwzh@gnu.org>
parents:
9392
diff
changeset
|
428 #define XMISC(a) ((union Lisp_Misc *) XPNTR(a)) |
11335
78eda0ee4cba
(XMISCTYPE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
11204
diff
changeset
|
429 #define XMISCTYPE(a) (XMARKER (a)->type) |
9435
3a157cdf395c
(Lisp_Misc): new type code, replacing Lisp_Marker (and soon to replace other
Karl Heuer <kwzh@gnu.org>
parents:
9392
diff
changeset
|
430 #define XMARKER(a) (&(XMISC(a)->u_marker)) |
9462
3601bf7327b2
(enum Lisp_Misc_Type): Add new enumerations Lisp_Misc_Intfwd,
Karl Heuer <kwzh@gnu.org>
parents:
9435
diff
changeset
|
431 #define XINTFWD(a) (&(XMISC(a)->u_intfwd)) |
3601bf7327b2
(enum Lisp_Misc_Type): Add new enumerations Lisp_Misc_Intfwd,
Karl Heuer <kwzh@gnu.org>
parents:
9435
diff
changeset
|
432 #define XBOOLFWD(a) (&(XMISC(a)->u_boolfwd)) |
3601bf7327b2
(enum Lisp_Misc_Type): Add new enumerations Lisp_Misc_Intfwd,
Karl Heuer <kwzh@gnu.org>
parents:
9435
diff
changeset
|
433 #define XOBJFWD(a) (&(XMISC(a)->u_objfwd)) |
3601bf7327b2
(enum Lisp_Misc_Type): Add new enumerations Lisp_Misc_Intfwd,
Karl Heuer <kwzh@gnu.org>
parents:
9435
diff
changeset
|
434 #define XBUFFER_OBJFWD(a) (&(XMISC(a)->u_buffer_objfwd)) |
9891
f4a53f86853d
(enum Lisp_Misc_Type): Add new enumerations Lisp_Misc_Buffer_Local_Value and
Karl Heuer <kwzh@gnu.org>
parents:
9885
diff
changeset
|
435 #define XBUFFER_LOCAL_VALUE(a) (&(XMISC(a)->u_buffer_local_value)) |
9924
594e838f4567
(enum Lisp_Misc_Type): Add new enumeration Lisp_Misc_Overlay.
Karl Heuer <kwzh@gnu.org>
parents:
9904
diff
changeset
|
436 #define XOVERLAY(a) (&(XMISC(a)->u_overlay)) |
11012
31d88266ed12
(struct KBOARD, MULTI_KBOARD, current_kboard, all_kboards,
Karl Heuer <kwzh@gnu.org>
parents:
10944
diff
changeset
|
437 #define XKBOARD_OBJFWD(a) (&(XMISC(a)->u_kboard_objfwd)) |
49056
88f14a14e005
New misc type Lisp_Save_Value.
Richard M. Stallman <rms@gnu.org>
parents:
48540
diff
changeset
|
438 #define XSAVE_VALUE(a) (&(XMISC(a)->u_save_value)) |
302 | 439 |
10292
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
440 /* Pseudovector types. */ |
30173
420acffb79c2
(AREF, ASET, ASIZE): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
30081
diff
changeset
|
441 |
28417
4b675266db04
* lisp.h (XCONS, XSTRING, XSYMBOL, XFLOAT, XPROCESS, XWINDOW, XSUBR, XBUFFER):
Ken Raeburn <raeburn@raeburn.org>
parents:
28414
diff
changeset
|
442 #define XPROCESS(a) (eassert (GC_PROCESSP(a)),(struct Lisp_Process *) XPNTR(a)) |
4b675266db04
* lisp.h (XCONS, XSTRING, XSYMBOL, XFLOAT, XPROCESS, XWINDOW, XSUBR, XBUFFER):
Ken Raeburn <raeburn@raeburn.org>
parents:
28414
diff
changeset
|
443 #define XWINDOW(a) (eassert (GC_WINDOWP(a)),(struct window *) XPNTR(a)) |
4b675266db04
* lisp.h (XCONS, XSTRING, XSYMBOL, XFLOAT, XPROCESS, XWINDOW, XSUBR, XBUFFER):
Ken Raeburn <raeburn@raeburn.org>
parents:
28414
diff
changeset
|
444 #define XSUBR(a) (eassert (GC_SUBRP(a)),(struct Lisp_Subr *) XPNTR(a)) |
4b675266db04
* lisp.h (XCONS, XSTRING, XSYMBOL, XFLOAT, XPROCESS, XWINDOW, XSUBR, XBUFFER):
Ken Raeburn <raeburn@raeburn.org>
parents:
28414
diff
changeset
|
445 #define XBUFFER(a) (eassert (GC_BUFFERP(a)),(struct buffer *) XPNTR(a)) |
13149
b1dcc3e87ffb
(struct Lisp_Boolvector): New data type.
Richard M. Stallman <rms@gnu.org>
parents:
12890
diff
changeset
|
446 #define XCHAR_TABLE(a) ((struct Lisp_Char_Table *) XPNTR(a)) |
b1dcc3e87ffb
(struct Lisp_Boolvector): New data type.
Richard M. Stallman <rms@gnu.org>
parents:
12890
diff
changeset
|
447 #define XBOOL_VECTOR(a) ((struct Lisp_Bool_Vector *) XPNTR(a)) |
10316
272f15eddaca
(enum Lisp_Type): Delete Lisp_Buffer.
Richard M. Stallman <rms@gnu.org>
parents:
10292
diff
changeset
|
448 |
272f15eddaca
(enum Lisp_Type): Delete Lisp_Buffer.
Richard M. Stallman <rms@gnu.org>
parents:
10292
diff
changeset
|
449 /* Construct a Lisp_Object from a value or address. */ |
10292
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
450 |
51657
7fb427e8d984
(struct interval, struct Lisp_Symbol, struct Lisp_Free)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51167
diff
changeset
|
451 #define XSETINT(a, b) (a) = make_number (b) |
9287
781ada39b15c
(XSETINT, XSETCONS, XSETBUFFER, XSETVECTOR, XSETSUBR, XSETSTRING, XSETSYMBOL,
Karl Heuer <kwzh@gnu.org>
parents:
9150
diff
changeset
|
452 #define XSETCONS(a, b) XSET (a, Lisp_Cons, b) |
10010
67375493afa2
(enum Lisp_Misc_Type): Rename Lisp_Vector to Lisp_Vectorlike. Mark
Karl Heuer <kwzh@gnu.org>
parents:
10003
diff
changeset
|
453 #define XSETVECTOR(a, b) XSET (a, Lisp_Vectorlike, b) |
9287
781ada39b15c
(XSETINT, XSETCONS, XSETBUFFER, XSETVECTOR, XSETSUBR, XSETSTRING, XSETSYMBOL,
Karl Heuer <kwzh@gnu.org>
parents:
9150
diff
changeset
|
454 #define XSETSTRING(a, b) XSET (a, Lisp_String, b) |
781ada39b15c
(XSETINT, XSETCONS, XSETBUFFER, XSETVECTOR, XSETSUBR, XSETSTRING, XSETSYMBOL,
Karl Heuer <kwzh@gnu.org>
parents:
9150
diff
changeset
|
455 #define XSETSYMBOL(a, b) XSET (a, Lisp_Symbol, b) |
10292
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
456 #define XSETFLOAT(a, b) XSET (a, Lisp_Float, b) |
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
457 |
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
458 /* Misc types. */ |
30173
420acffb79c2
(AREF, ASET, ASIZE): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
30081
diff
changeset
|
459 |
9435
3a157cdf395c
(Lisp_Misc): new type code, replacing Lisp_Marker (and soon to replace other
Karl Heuer <kwzh@gnu.org>
parents:
9392
diff
changeset
|
460 #define XSETMISC(a, b) XSET (a, Lisp_Misc, b) |
11335
78eda0ee4cba
(XMISCTYPE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
11204
diff
changeset
|
461 #define XSETMARKER(a, b) (XSETMISC (a, b), XMISCTYPE (a) = Lisp_Misc_Marker) |
10292
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
462 |
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
463 /* Pseudovector types. */ |
30173
420acffb79c2
(AREF, ASET, ASIZE): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
30081
diff
changeset
|
464 |
10292
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
465 #define XSETPSEUDOVECTOR(a, b, code) \ |
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
466 (XSETVECTOR (a, b), XVECTOR (a)->size |= PSEUDOVECTOR_FLAG | (code)) |
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
467 #define XSETWINDOW_CONFIGURATION(a, b) \ |
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
468 (XSETPSEUDOVECTOR (a, b, PVEC_WINDOW_CONFIGURATION)) |
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
469 #define XSETPROCESS(a, b) (XSETPSEUDOVECTOR (a, b, PVEC_PROCESS)) |
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
470 #define XSETWINDOW(a, b) (XSETPSEUDOVECTOR (a, b, PVEC_WINDOW)) |
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
471 #define XSETSUBR(a, b) (XSETPSEUDOVECTOR (a, b, PVEC_SUBR)) |
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
472 #define XSETCOMPILED(a, b) (XSETPSEUDOVECTOR (a, b, PVEC_COMPILED)) |
10316
272f15eddaca
(enum Lisp_Type): Delete Lisp_Buffer.
Richard M. Stallman <rms@gnu.org>
parents:
10292
diff
changeset
|
473 #define XSETBUFFER(a, b) (XSETPSEUDOVECTOR (a, b, PVEC_BUFFER)) |
13149
b1dcc3e87ffb
(struct Lisp_Boolvector): New data type.
Richard M. Stallman <rms@gnu.org>
parents:
12890
diff
changeset
|
474 #define XSETCHAR_TABLE(a, b) (XSETPSEUDOVECTOR (a, b, PVEC_CHAR_TABLE)) |
b1dcc3e87ffb
(struct Lisp_Boolvector): New data type.
Richard M. Stallman <rms@gnu.org>
parents:
12890
diff
changeset
|
475 #define XSETBOOL_VECTOR(a, b) (XSETPSEUDOVECTOR (a, b, PVEC_BOOL_VECTOR)) |
30173
420acffb79c2
(AREF, ASET, ASIZE): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
30081
diff
changeset
|
476 |
420acffb79c2
(AREF, ASET, ASIZE): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
30081
diff
changeset
|
477 /* Convenience macros for dealing with Lisp arrays. */ |
420acffb79c2
(AREF, ASET, ASIZE): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
30081
diff
changeset
|
478 |
420acffb79c2
(AREF, ASET, ASIZE): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
30081
diff
changeset
|
479 #define AREF(ARRAY, IDX) XVECTOR ((ARRAY))->contents[IDX] |
420acffb79c2
(AREF, ASET, ASIZE): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
30081
diff
changeset
|
480 #define ASET(ARRAY, IDX, VAL) (AREF ((ARRAY), (IDX)) = (VAL)) |
420acffb79c2
(AREF, ASET, ASIZE): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
30081
diff
changeset
|
481 #define ASIZE(ARRAY) XVECTOR ((ARRAY))->size |
420acffb79c2
(AREF, ASET, ASIZE): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
30081
diff
changeset
|
482 |
43780
412b8fa3fd95
(SREF, SDATA, SCHARS, SBYTES, SMBP): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
43713
diff
changeset
|
483 /* Convenience macros for dealing with Lisp strings. */ |
412b8fa3fd95
(SREF, SDATA, SCHARS, SBYTES, SMBP): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
43713
diff
changeset
|
484 |
46428
82755b55ec33
* lisp.h (SREF): Produce rvalue.
Ken Raeburn <raeburn@raeburn.org>
parents:
46416
diff
changeset
|
485 #define SREF(string, index) (XSTRING (string)->data[index] + 0) |
82755b55ec33
* lisp.h (SREF): Produce rvalue.
Ken Raeburn <raeburn@raeburn.org>
parents:
46416
diff
changeset
|
486 #define SSET(string, index, new) (XSTRING (string)->data[index] = (new)) |
46416
de62156bec9a
(SDATA): Produce rvalue.
Ken Raeburn <raeburn@raeburn.org>
parents:
46377
diff
changeset
|
487 #define SDATA(string) (XSTRING (string)->data + 0) |
46372
e7289ef367d8
* lisp.h (STRING_SET_CHARS): New macro.
Ken Raeburn <raeburn@raeburn.org>
parents:
46369
diff
changeset
|
488 #define SCHARS(string) (XSTRING (string)->size + 0) |
e7289ef367d8
* lisp.h (STRING_SET_CHARS): New macro.
Ken Raeburn <raeburn@raeburn.org>
parents:
46369
diff
changeset
|
489 #define SBYTES(string) (STRING_BYTES (XSTRING (string)) + 0) |
e7289ef367d8
* lisp.h (STRING_SET_CHARS): New macro.
Ken Raeburn <raeburn@raeburn.org>
parents:
46369
diff
changeset
|
490 |
e7289ef367d8
* lisp.h (STRING_SET_CHARS): New macro.
Ken Raeburn <raeburn@raeburn.org>
parents:
46369
diff
changeset
|
491 #define STRING_SET_CHARS(string, newsize) \ |
e7289ef367d8
* lisp.h (STRING_SET_CHARS): New macro.
Ken Raeburn <raeburn@raeburn.org>
parents:
46369
diff
changeset
|
492 (XSTRING (string)->size = (newsize)) |
43780
412b8fa3fd95
(SREF, SDATA, SCHARS, SBYTES, SMBP): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
43713
diff
changeset
|
493 |
46552
cb055b77d3c6
(STRING_COPYIN): New macro.
Ken Raeburn <raeburn@raeburn.org>
parents:
46471
diff
changeset
|
494 #define STRING_COPYIN(string, index, new, count) \ |
cb055b77d3c6
(STRING_COPYIN): New macro.
Ken Raeburn <raeburn@raeburn.org>
parents:
46471
diff
changeset
|
495 bcopy (new, XSTRING (string)->data + index, count) |
cb055b77d3c6
(STRING_COPYIN): New macro.
Ken Raeburn <raeburn@raeburn.org>
parents:
46471
diff
changeset
|
496 |
302 | 497 |
51858
bf6232373c39
(VALBITS): Define in terms of GCTYPEBITS.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51833
diff
changeset
|
498 /* See the macros in intervals.h. */ |
1290
9b0ddca4773b
* lisp.h: Conditionally define interval structure and macros.
Joseph Arceneaux <jla@gnu.org>
parents:
1277
diff
changeset
|
499 |
9b0ddca4773b
* lisp.h: Conditionally define interval structure and macros.
Joseph Arceneaux <jla@gnu.org>
parents:
1277
diff
changeset
|
500 typedef struct interval *INTERVAL; |
9b0ddca4773b
* lisp.h: Conditionally define interval structure and macros.
Joseph Arceneaux <jla@gnu.org>
parents:
1277
diff
changeset
|
501 |
9b0ddca4773b
* lisp.h: Conditionally define interval structure and macros.
Joseph Arceneaux <jla@gnu.org>
parents:
1277
diff
changeset
|
502 /* Complain if object is not string or buffer type */ |
40653
6c48a4da1da5
(CHECK_STRING_OR_BUFFER, CHECK_HASH_TABLE, CHECK_LIST, CHECK_STRING,
Pavel Janík <Pavel@Janik.cz>
parents:
40536
diff
changeset
|
503 #define CHECK_STRING_OR_BUFFER(x) \ |
9150
642bbaf7c3fc
(BOOLFWDP, INTERNALP, INTFWDP, OBJFWDP, INTERNAL_STREAMP, BUFFER_LOCAL_VALUEP,
Karl Heuer <kwzh@gnu.org>
parents:
9099
diff
changeset
|
504 { if (!STRINGP ((x)) && !BUFFERP ((x))) \ |
1290
9b0ddca4773b
* lisp.h: Conditionally define interval structure and macros.
Joseph Arceneaux <jla@gnu.org>
parents:
1277
diff
changeset
|
505 x = wrong_type_argument (Qbuffer_or_string_p, (x)); } |
9b0ddca4773b
* lisp.h: Conditionally define interval structure and macros.
Joseph Arceneaux <jla@gnu.org>
parents:
1277
diff
changeset
|
506 |
302 | 507 /* In a cons, the markbit of the car is the gc mark bit */ |
508 | |
509 struct Lisp_Cons | |
510 { | |
25421
65a7e9c02d4f
(struct Lisp_Cons, XCAR, XCDR, struct Lisp_Float): Change names of structure
Ken Raeburn <raeburn@raeburn.org>
parents:
25392
diff
changeset
|
511 /* Please do not use the names of these elements in code other |
65a7e9c02d4f
(struct Lisp_Cons, XCAR, XCDR, struct Lisp_Float): Change names of structure
Ken Raeburn <raeburn@raeburn.org>
parents:
25392
diff
changeset
|
512 than the core lisp implementation. Use XCAR and XCDR below. */ |
65a7e9c02d4f
(struct Lisp_Cons, XCAR, XCDR, struct Lisp_Float): Change names of structure
Ken Raeburn <raeburn@raeburn.org>
parents:
25392
diff
changeset
|
513 #ifdef HIDE_LISP_IMPLEMENTATION |
65a7e9c02d4f
(struct Lisp_Cons, XCAR, XCDR, struct Lisp_Float): Change names of structure
Ken Raeburn <raeburn@raeburn.org>
parents:
25392
diff
changeset
|
514 Lisp_Object car_, cdr_; |
65a7e9c02d4f
(struct Lisp_Cons, XCAR, XCDR, struct Lisp_Float): Change names of structure
Ken Raeburn <raeburn@raeburn.org>
parents:
25392
diff
changeset
|
515 #else |
302 | 516 Lisp_Object car, cdr; |
25421
65a7e9c02d4f
(struct Lisp_Cons, XCAR, XCDR, struct Lisp_Float): Change names of structure
Ken Raeburn <raeburn@raeburn.org>
parents:
25392
diff
changeset
|
517 #endif |
302 | 518 }; |
519 | |
14306
b30429f0b599
(XCAR, XCDR, CAR, CDR): New macros.
Karl Heuer <kwzh@gnu.org>
parents:
14186
diff
changeset
|
520 /* Take the car or cdr of something known to be a cons cell. */ |
39973
579177964efa
Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents:
39924
diff
changeset
|
521 /* The _AS_LVALUE macros shouldn't be used outside of the minimal set |
579177964efa
Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents:
39924
diff
changeset
|
522 of code that has to know what a cons cell looks like. Other code not |
579177964efa
Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents:
39924
diff
changeset
|
523 part of the basic lisp implementation should assume that the car and cdr |
579177964efa
Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents:
39924
diff
changeset
|
524 fields are not accessible as lvalues. (What if we want to switch to |
579177964efa
Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents:
39924
diff
changeset
|
525 a copying collector someday? Cached cons cell field addresses may be |
579177964efa
Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents:
39924
diff
changeset
|
526 invalidated at arbitrary points.) */ |
25421
65a7e9c02d4f
(struct Lisp_Cons, XCAR, XCDR, struct Lisp_Float): Change names of structure
Ken Raeburn <raeburn@raeburn.org>
parents:
25392
diff
changeset
|
527 #ifdef HIDE_LISP_IMPLEMENTATION |
39973
579177964efa
Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents:
39924
diff
changeset
|
528 #define XCAR_AS_LVALUE(c) (XCONS ((c))->car_) |
579177964efa
Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents:
39924
diff
changeset
|
529 #define XCDR_AS_LVALUE(c) (XCONS ((c))->cdr_) |
25421
65a7e9c02d4f
(struct Lisp_Cons, XCAR, XCDR, struct Lisp_Float): Change names of structure
Ken Raeburn <raeburn@raeburn.org>
parents:
25392
diff
changeset
|
530 #else |
39973
579177964efa
Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents:
39924
diff
changeset
|
531 #define XCAR_AS_LVALUE(c) (XCONS ((c))->car) |
579177964efa
Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents:
39924
diff
changeset
|
532 #define XCDR_AS_LVALUE(c) (XCONS ((c))->cdr) |
25421
65a7e9c02d4f
(struct Lisp_Cons, XCAR, XCDR, struct Lisp_Float): Change names of structure
Ken Raeburn <raeburn@raeburn.org>
parents:
25392
diff
changeset
|
533 #endif |
14306
b30429f0b599
(XCAR, XCDR, CAR, CDR): New macros.
Karl Heuer <kwzh@gnu.org>
parents:
14186
diff
changeset
|
534 |
39973
579177964efa
Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents:
39924
diff
changeset
|
535 /* Use these from normal code. */ |
579177964efa
Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents:
39924
diff
changeset
|
536 #define XCAR(c) LISP_MAKE_RVALUE(XCAR_AS_LVALUE(c)) |
579177964efa
Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents:
39924
diff
changeset
|
537 #define XCDR(c) LISP_MAKE_RVALUE(XCDR_AS_LVALUE(c)) |
579177964efa
Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents:
39924
diff
changeset
|
538 |
579177964efa
Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents:
39924
diff
changeset
|
539 /* Use these to set the fields of a cons cell. |
579177964efa
Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents:
39924
diff
changeset
|
540 |
579177964efa
Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents:
39924
diff
changeset
|
541 Note that both arguments may refer to the same object, so 'n' |
579177964efa
Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents:
39924
diff
changeset
|
542 should not be read after 'c' is first modified. Also, neither |
579177964efa
Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents:
39924
diff
changeset
|
543 argument should be evaluated more than once; side effects are |
579177964efa
Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents:
39924
diff
changeset
|
544 especially common in the second argument. */ |
579177964efa
Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents:
39924
diff
changeset
|
545 #define XSETCAR(c,n) (XCAR_AS_LVALUE(c) = (n)) |
579177964efa
Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents:
39924
diff
changeset
|
546 #define XSETCDR(c,n) (XCDR_AS_LVALUE(c) = (n)) |
579177964efa
Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents:
39924
diff
changeset
|
547 |
579177964efa
Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents:
39924
diff
changeset
|
548 /* For performance: Fast storage of positive integers into the |
579177964efa
Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents:
39924
diff
changeset
|
549 fields of a cons cell. See above caveats. */ |
579177964efa
Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents:
39924
diff
changeset
|
550 #define XSETCARFASTINT(c,n) XSETFASTINT(XCAR_AS_LVALUE(c),(n)) |
579177964efa
Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents:
39924
diff
changeset
|
551 #define XSETCDRFASTINT(c,n) XSETFASTINT(XCDR_AS_LVALUE(c),(n)) |
579177964efa
Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents:
39924
diff
changeset
|
552 |
14306
b30429f0b599
(XCAR, XCDR, CAR, CDR): New macros.
Karl Heuer <kwzh@gnu.org>
parents:
14186
diff
changeset
|
553 /* Take the car or cdr of something whose type is not known. */ |
b30429f0b599
(XCAR, XCDR, CAR, CDR): New macros.
Karl Heuer <kwzh@gnu.org>
parents:
14186
diff
changeset
|
554 #define CAR(c) \ |
b30429f0b599
(XCAR, XCDR, CAR, CDR): New macros.
Karl Heuer <kwzh@gnu.org>
parents:
14186
diff
changeset
|
555 (CONSP ((c)) ? XCAR ((c)) \ |
b30429f0b599
(XCAR, XCDR, CAR, CDR): New macros.
Karl Heuer <kwzh@gnu.org>
parents:
14186
diff
changeset
|
556 : NILP ((c)) ? Qnil \ |
b30429f0b599
(XCAR, XCDR, CAR, CDR): New macros.
Karl Heuer <kwzh@gnu.org>
parents:
14186
diff
changeset
|
557 : wrong_type_argument (Qlistp, (c))) |
b30429f0b599
(XCAR, XCDR, CAR, CDR): New macros.
Karl Heuer <kwzh@gnu.org>
parents:
14186
diff
changeset
|
558 |
b30429f0b599
(XCAR, XCDR, CAR, CDR): New macros.
Karl Heuer <kwzh@gnu.org>
parents:
14186
diff
changeset
|
559 #define CDR(c) \ |
b30429f0b599
(XCAR, XCDR, CAR, CDR): New macros.
Karl Heuer <kwzh@gnu.org>
parents:
14186
diff
changeset
|
560 (CONSP ((c)) ? XCDR ((c)) \ |
b30429f0b599
(XCAR, XCDR, CAR, CDR): New macros.
Karl Heuer <kwzh@gnu.org>
parents:
14186
diff
changeset
|
561 : NILP ((c)) ? Qnil \ |
b30429f0b599
(XCAR, XCDR, CAR, CDR): New macros.
Karl Heuer <kwzh@gnu.org>
parents:
14186
diff
changeset
|
562 : wrong_type_argument (Qlistp, (c))) |
b30429f0b599
(XCAR, XCDR, CAR, CDR): New macros.
Karl Heuer <kwzh@gnu.org>
parents:
14186
diff
changeset
|
563 |
21276 | 564 /* Nonzero if STR is a multibyte string. */ |
565 #define STRING_MULTIBYTE(STR) \ | |
566 (XSTRING (STR)->size_byte >= 0) | |
567 | |
568 /* Return the length in bytes of STR. */ | |
35184
07ec5658a7a5
(STRING_BYTES) [GC_CHECK_STRING_BYTES]: Call
Gerd Moellmann <gerd@gnu.org>
parents:
35173
diff
changeset
|
569 |
07ec5658a7a5
(STRING_BYTES) [GC_CHECK_STRING_BYTES]: Call
Gerd Moellmann <gerd@gnu.org>
parents:
35173
diff
changeset
|
570 #ifdef GC_CHECK_STRING_BYTES |
07ec5658a7a5
(STRING_BYTES) [GC_CHECK_STRING_BYTES]: Call
Gerd Moellmann <gerd@gnu.org>
parents:
35173
diff
changeset
|
571 |
07ec5658a7a5
(STRING_BYTES) [GC_CHECK_STRING_BYTES]: Call
Gerd Moellmann <gerd@gnu.org>
parents:
35173
diff
changeset
|
572 struct Lisp_String; |
07ec5658a7a5
(STRING_BYTES) [GC_CHECK_STRING_BYTES]: Call
Gerd Moellmann <gerd@gnu.org>
parents:
35173
diff
changeset
|
573 extern int string_bytes P_ ((struct Lisp_String *)); |
07ec5658a7a5
(STRING_BYTES) [GC_CHECK_STRING_BYTES]: Call
Gerd Moellmann <gerd@gnu.org>
parents:
35173
diff
changeset
|
574 #define STRING_BYTES(S) string_bytes ((S)) |
07ec5658a7a5
(STRING_BYTES) [GC_CHECK_STRING_BYTES]: Call
Gerd Moellmann <gerd@gnu.org>
parents:
35173
diff
changeset
|
575 |
07ec5658a7a5
(STRING_BYTES) [GC_CHECK_STRING_BYTES]: Call
Gerd Moellmann <gerd@gnu.org>
parents:
35173
diff
changeset
|
576 #else /* not GC_CHECK_STRING_BYTES */ |
07ec5658a7a5
(STRING_BYTES) [GC_CHECK_STRING_BYTES]: Call
Gerd Moellmann <gerd@gnu.org>
parents:
35173
diff
changeset
|
577 |
21276 | 578 #define STRING_BYTES(STR) \ |
579 ((STR)->size_byte < 0 ? (STR)->size : (STR)->size_byte) | |
580 | |
35184
07ec5658a7a5
(STRING_BYTES) [GC_CHECK_STRING_BYTES]: Call
Gerd Moellmann <gerd@gnu.org>
parents:
35173
diff
changeset
|
581 #endif /* not GC_CHECK_STRING_BYTES */ |
07ec5658a7a5
(STRING_BYTES) [GC_CHECK_STRING_BYTES]: Call
Gerd Moellmann <gerd@gnu.org>
parents:
35173
diff
changeset
|
582 |
46369
dd1d3b1d0053
(SMBP): Deleted. All uses changed to STRING_MULTIBYTE.
Ken Raeburn <raeburn@raeburn.org>
parents:
46304
diff
changeset
|
583 /* Mark STR as a unibyte string. */ |
dd1d3b1d0053
(SMBP): Deleted. All uses changed to STRING_MULTIBYTE.
Ken Raeburn <raeburn@raeburn.org>
parents:
46304
diff
changeset
|
584 #define STRING_SET_UNIBYTE(STR) (XSTRING (STR)->size_byte = -1) |
dd1d3b1d0053
(SMBP): Deleted. All uses changed to STRING_MULTIBYTE.
Ken Raeburn <raeburn@raeburn.org>
parents:
46304
diff
changeset
|
585 |
dd1d3b1d0053
(SMBP): Deleted. All uses changed to STRING_MULTIBYTE.
Ken Raeburn <raeburn@raeburn.org>
parents:
46304
diff
changeset
|
586 /* Get text properties. */ |
46377
d50779ef2a76
* lisp.h (STRING_INTERVALS): Produce rvalue.
Ken Raeburn <raeburn@raeburn.org>
parents:
46372
diff
changeset
|
587 #define STRING_INTERVALS(STR) (XSTRING (STR)->intervals + 0) |
d50779ef2a76
* lisp.h (STRING_INTERVALS): Produce rvalue.
Ken Raeburn <raeburn@raeburn.org>
parents:
46372
diff
changeset
|
588 |
d50779ef2a76
* lisp.h (STRING_INTERVALS): Produce rvalue.
Ken Raeburn <raeburn@raeburn.org>
parents:
46372
diff
changeset
|
589 /* Set text properties. */ |
d50779ef2a76
* lisp.h (STRING_INTERVALS): Produce rvalue.
Ken Raeburn <raeburn@raeburn.org>
parents:
46372
diff
changeset
|
590 #define STRING_SET_INTERVALS(STR, INT) (XSTRING (STR)->intervals = (INT)) |
21276 | 591 |
302 | 592 /* In a string or vector, the sign bit of the `size' is the gc mark bit */ |
593 | |
594 struct Lisp_String | |
595 { | |
8827
97bf951c0b98
(Lisp_Object): Use EMACS_INT.
Richard M. Stallman <rms@gnu.org>
parents:
8631
diff
changeset
|
596 EMACS_INT size; |
20625
a9c4bf3f4e46
(STRING_MULTIBYTE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
20569
diff
changeset
|
597 EMACS_INT size_byte; |
30934
ce33e6835a31
(Lisp_String): Replace DECLARE_INTERVALS with real decl.
Miles Bader <miles@gnu.org>
parents:
30918
diff
changeset
|
598 INTERVAL intervals; /* text properties in this string */ |
27141
d7b1de135a40
Add prototype for allocate_string_data.
Gerd Moellmann <gerd@gnu.org>
parents:
27078
diff
changeset
|
599 unsigned char *data; |
302 | 600 }; |
601 | |
9971 | 602 /* If a struct is made to look like a vector, this macro returns the length |
14473
7c93a4ce40b0
(VECSIZE): Round up when dividing.
Richard M. Stallman <rms@gnu.org>
parents:
14306
diff
changeset
|
603 of the shortest vector that would hold that struct. */ |
7c93a4ce40b0
(VECSIZE): Round up when dividing.
Richard M. Stallman <rms@gnu.org>
parents:
14306
diff
changeset
|
604 #define VECSIZE(type) ((sizeof (type) - (sizeof (struct Lisp_Vector) \ |
7c93a4ce40b0
(VECSIZE): Round up when dividing.
Richard M. Stallman <rms@gnu.org>
parents:
14306
diff
changeset
|
605 - sizeof (Lisp_Object)) \ |
7c93a4ce40b0
(VECSIZE): Round up when dividing.
Richard M. Stallman <rms@gnu.org>
parents:
14306
diff
changeset
|
606 + sizeof(Lisp_Object) - 1) /* round up */ \ |
9971 | 607 / sizeof (Lisp_Object)) |
608 | |
302 | 609 struct Lisp_Vector |
610 { | |
8827
97bf951c0b98
(Lisp_Object): Use EMACS_INT.
Richard M. Stallman <rms@gnu.org>
parents:
8631
diff
changeset
|
611 EMACS_INT size; |
302 | 612 struct Lisp_Vector *next; |
613 Lisp_Object contents[1]; | |
614 }; | |
615 | |
17326
bd34aa57f3f5
(CHAR_TABLE_STANDARD_SLOTS): Now 4 more slots than
Kenichi Handa <handa@m17n.org>
parents:
17289
diff
changeset
|
616 /* A char table is a kind of vectorlike, with contents are like a |
bd34aa57f3f5
(CHAR_TABLE_STANDARD_SLOTS): Now 4 more slots than
Kenichi Handa <handa@m17n.org>
parents:
17289
diff
changeset
|
617 vector but with a few other slots. For some purposes, it makes |
bd34aa57f3f5
(CHAR_TABLE_STANDARD_SLOTS): Now 4 more slots than
Kenichi Handa <handa@m17n.org>
parents:
17289
diff
changeset
|
618 sense to handle a chartable with type struct Lisp_Vector. An |
bd34aa57f3f5
(CHAR_TABLE_STANDARD_SLOTS): Now 4 more slots than
Kenichi Handa <handa@m17n.org>
parents:
17289
diff
changeset
|
619 element of a char table can be any Lisp objects, but if it is a sub |
bd34aa57f3f5
(CHAR_TABLE_STANDARD_SLOTS): Now 4 more slots than
Kenichi Handa <handa@m17n.org>
parents:
17289
diff
changeset
|
620 char-table, we treat it a table that contains information of a |
bd34aa57f3f5
(CHAR_TABLE_STANDARD_SLOTS): Now 4 more slots than
Kenichi Handa <handa@m17n.org>
parents:
17289
diff
changeset
|
621 group of characters of the same charsets or a specific character of |
bd34aa57f3f5
(CHAR_TABLE_STANDARD_SLOTS): Now 4 more slots than
Kenichi Handa <handa@m17n.org>
parents:
17289
diff
changeset
|
622 a charset. A sub char-table has the same structure as a char table |
bd34aa57f3f5
(CHAR_TABLE_STANDARD_SLOTS): Now 4 more slots than
Kenichi Handa <handa@m17n.org>
parents:
17289
diff
changeset
|
623 except for that the former omits several slots at the tail. A sub |
bd34aa57f3f5
(CHAR_TABLE_STANDARD_SLOTS): Now 4 more slots than
Kenichi Handa <handa@m17n.org>
parents:
17289
diff
changeset
|
624 char table appears only in an element of a char table, and there's |
bd34aa57f3f5
(CHAR_TABLE_STANDARD_SLOTS): Now 4 more slots than
Kenichi Handa <handa@m17n.org>
parents:
17289
diff
changeset
|
625 no way to access it directly from Emacs Lisp program. */ |
17404
73012b195cf3
(DOWNCASE): Return int, not Lisp_Object.
Karl Heuer <kwzh@gnu.org>
parents:
17326
diff
changeset
|
626 |
17188
e38cc84db8ab
(CHAR_TABLE_ORDINARY_SLOTS): Change to 384 (== 256 + 128).
Kenichi Handa <handa@m17n.org>
parents:
17141
diff
changeset
|
627 /* This is the number of slots that apply to characters or character |
e38cc84db8ab
(CHAR_TABLE_ORDINARY_SLOTS): Change to 384 (== 256 + 128).
Kenichi Handa <handa@m17n.org>
parents:
17141
diff
changeset
|
628 sets. The first 128 are for ASCII, the next 128 are for 8-bit |
17326
bd34aa57f3f5
(CHAR_TABLE_STANDARD_SLOTS): Now 4 more slots than
Kenichi Handa <handa@m17n.org>
parents:
17289
diff
changeset
|
629 European characters, and the last 128 are for multibyte characters. |
bd34aa57f3f5
(CHAR_TABLE_STANDARD_SLOTS): Now 4 more slots than
Kenichi Handa <handa@m17n.org>
parents:
17289
diff
changeset
|
630 The first 256 are indexed by the code itself, but the last 128 are |
bd34aa57f3f5
(CHAR_TABLE_STANDARD_SLOTS): Now 4 more slots than
Kenichi Handa <handa@m17n.org>
parents:
17289
diff
changeset
|
631 indexed by (charset-id + 128). */ |
17188
e38cc84db8ab
(CHAR_TABLE_ORDINARY_SLOTS): Change to 384 (== 256 + 128).
Kenichi Handa <handa@m17n.org>
parents:
17141
diff
changeset
|
632 #define CHAR_TABLE_ORDINARY_SLOTS 384 |
e38cc84db8ab
(CHAR_TABLE_ORDINARY_SLOTS): Change to 384 (== 256 + 128).
Kenichi Handa <handa@m17n.org>
parents:
17141
diff
changeset
|
633 |
e38cc84db8ab
(CHAR_TABLE_ORDINARY_SLOTS): Change to 384 (== 256 + 128).
Kenichi Handa <handa@m17n.org>
parents:
17141
diff
changeset
|
634 /* This is the number of slots that apply to characters of ASCII and |
e38cc84db8ab
(CHAR_TABLE_ORDINARY_SLOTS): Change to 384 (== 256 + 128).
Kenichi Handa <handa@m17n.org>
parents:
17141
diff
changeset
|
635 8-bit Europeans only. */ |
e38cc84db8ab
(CHAR_TABLE_ORDINARY_SLOTS): Change to 384 (== 256 + 128).
Kenichi Handa <handa@m17n.org>
parents:
17141
diff
changeset
|
636 #define CHAR_TABLE_SINGLE_BYTE_SLOTS 256 |
13149
b1dcc3e87ffb
(struct Lisp_Boolvector): New data type.
Richard M. Stallman <rms@gnu.org>
parents:
12890
diff
changeset
|
637 |
17326
bd34aa57f3f5
(CHAR_TABLE_STANDARD_SLOTS): Now 4 more slots than
Kenichi Handa <handa@m17n.org>
parents:
17289
diff
changeset
|
638 /* This is the number of slots that every char table must have. This |
bd34aa57f3f5
(CHAR_TABLE_STANDARD_SLOTS): Now 4 more slots than
Kenichi Handa <handa@m17n.org>
parents:
17289
diff
changeset
|
639 counts the ordinary slots and the top, defalt, parent, and purpose |
bd34aa57f3f5
(CHAR_TABLE_STANDARD_SLOTS): Now 4 more slots than
Kenichi Handa <handa@m17n.org>
parents:
17289
diff
changeset
|
640 slots. */ |
bd34aa57f3f5
(CHAR_TABLE_STANDARD_SLOTS): Now 4 more slots than
Kenichi Handa <handa@m17n.org>
parents:
17289
diff
changeset
|
641 #define CHAR_TABLE_STANDARD_SLOTS (CHAR_TABLE_ORDINARY_SLOTS + 4) |
bd34aa57f3f5
(CHAR_TABLE_STANDARD_SLOTS): Now 4 more slots than
Kenichi Handa <handa@m17n.org>
parents:
17289
diff
changeset
|
642 |
bd34aa57f3f5
(CHAR_TABLE_STANDARD_SLOTS): Now 4 more slots than
Kenichi Handa <handa@m17n.org>
parents:
17289
diff
changeset
|
643 /* This is the number of slots that apply to position-code-1 and |
bd34aa57f3f5
(CHAR_TABLE_STANDARD_SLOTS): Now 4 more slots than
Kenichi Handa <handa@m17n.org>
parents:
17289
diff
changeset
|
644 position-code-2 of a multibyte character at the 2nd and 3rd level |
bd34aa57f3f5
(CHAR_TABLE_STANDARD_SLOTS): Now 4 more slots than
Kenichi Handa <handa@m17n.org>
parents:
17289
diff
changeset
|
645 sub char tables respectively. */ |
bd34aa57f3f5
(CHAR_TABLE_STANDARD_SLOTS): Now 4 more slots than
Kenichi Handa <handa@m17n.org>
parents:
17289
diff
changeset
|
646 #define SUB_CHAR_TABLE_ORDINARY_SLOTS 128 |
bd34aa57f3f5
(CHAR_TABLE_STANDARD_SLOTS): Now 4 more slots than
Kenichi Handa <handa@m17n.org>
parents:
17289
diff
changeset
|
647 |
bd34aa57f3f5
(CHAR_TABLE_STANDARD_SLOTS): Now 4 more slots than
Kenichi Handa <handa@m17n.org>
parents:
17289
diff
changeset
|
648 /* This is the number of slots that every sub char table must have. |
bd34aa57f3f5
(CHAR_TABLE_STANDARD_SLOTS): Now 4 more slots than
Kenichi Handa <handa@m17n.org>
parents:
17289
diff
changeset
|
649 This counts the ordinary slots and the top and defalt slot. */ |
17404
73012b195cf3
(DOWNCASE): Return int, not Lisp_Object.
Karl Heuer <kwzh@gnu.org>
parents:
17326
diff
changeset
|
650 #define SUB_CHAR_TABLE_STANDARD_SLOTS (SUB_CHAR_TABLE_ORDINARY_SLOTS + 2) |
13149
b1dcc3e87ffb
(struct Lisp_Boolvector): New data type.
Richard M. Stallman <rms@gnu.org>
parents:
12890
diff
changeset
|
651 |
b1dcc3e87ffb
(struct Lisp_Boolvector): New data type.
Richard M. Stallman <rms@gnu.org>
parents:
12890
diff
changeset
|
652 /* Return the number of "extra" slots in the char table CT. */ |
b1dcc3e87ffb
(struct Lisp_Boolvector): New data type.
Richard M. Stallman <rms@gnu.org>
parents:
12890
diff
changeset
|
653 |
b1dcc3e87ffb
(struct Lisp_Boolvector): New data type.
Richard M. Stallman <rms@gnu.org>
parents:
12890
diff
changeset
|
654 #define CHAR_TABLE_EXTRA_SLOTS(CT) \ |
b1dcc3e87ffb
(struct Lisp_Boolvector): New data type.
Richard M. Stallman <rms@gnu.org>
parents:
12890
diff
changeset
|
655 (((CT)->size & PSEUDOVECTOR_SIZE_MASK) - CHAR_TABLE_STANDARD_SLOTS) |
b1dcc3e87ffb
(struct Lisp_Boolvector): New data type.
Richard M. Stallman <rms@gnu.org>
parents:
12890
diff
changeset
|
656 |
17188
e38cc84db8ab
(CHAR_TABLE_ORDINARY_SLOTS): Change to 384 (== 256 + 128).
Kenichi Handa <handa@m17n.org>
parents:
17141
diff
changeset
|
657 /* Almost equivalent to Faref (CT, IDX) with optimization for ASCII |
18006
d29a9b467ac9
(CHAR_TABLE_REF): Do not check validity of CT.
Kenichi Handa <handa@m17n.org>
parents:
17871
diff
changeset
|
658 and 8-bit Europeans characters. For these characters, do not check |
d29a9b467ac9
(CHAR_TABLE_REF): Do not check validity of CT.
Kenichi Handa <handa@m17n.org>
parents:
17871
diff
changeset
|
659 validity of CT. Do not follow parent. */ |
d29a9b467ac9
(CHAR_TABLE_REF): Do not check validity of CT.
Kenichi Handa <handa@m17n.org>
parents:
17871
diff
changeset
|
660 #define CHAR_TABLE_REF(CT, IDX) \ |
23721
e593fb9c68c3
(CHAR_TABLE_REF): Check if IDX is negative or not.
Kenichi Handa <handa@m17n.org>
parents:
23429
diff
changeset
|
661 ((IDX) >= 0 && (IDX) < CHAR_TABLE_SINGLE_BYTE_SLOTS \ |
18613
614b916ff5bf
Fix bugs with inappropriate mixing of Lisp_Object with int.
Richard M. Stallman <rms@gnu.org>
parents:
18115
diff
changeset
|
662 ? (!NILP (XCHAR_TABLE (CT)->contents[IDX]) \ |
614b916ff5bf
Fix bugs with inappropriate mixing of Lisp_Object with int.
Richard M. Stallman <rms@gnu.org>
parents:
18115
diff
changeset
|
663 ? XCHAR_TABLE (CT)->contents[IDX] \ |
18006
d29a9b467ac9
(CHAR_TABLE_REF): Do not check validity of CT.
Kenichi Handa <handa@m17n.org>
parents:
17871
diff
changeset
|
664 : XCHAR_TABLE (CT)->defalt) \ |
18613
614b916ff5bf
Fix bugs with inappropriate mixing of Lisp_Object with int.
Richard M. Stallman <rms@gnu.org>
parents:
18115
diff
changeset
|
665 : Faref (CT, make_number (IDX))) |
17188
e38cc84db8ab
(CHAR_TABLE_ORDINARY_SLOTS): Change to 384 (== 256 + 128).
Kenichi Handa <handa@m17n.org>
parents:
17141
diff
changeset
|
666 |
22239
0a666cecb85d
(CHAR_TABLE_TRANSLATE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
22190
diff
changeset
|
667 /* Almost equivalent to Faref (CT, IDX) with optimization for ASCII |
0a666cecb85d
(CHAR_TABLE_TRANSLATE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
22190
diff
changeset
|
668 and 8-bit Europeans characters. However, if the result is nil, |
0a666cecb85d
(CHAR_TABLE_TRANSLATE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
22190
diff
changeset
|
669 return IDX. |
0a666cecb85d
(CHAR_TABLE_TRANSLATE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
22190
diff
changeset
|
670 |
0a666cecb85d
(CHAR_TABLE_TRANSLATE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
22190
diff
changeset
|
671 For these characters, do not check validity of CT |
0a666cecb85d
(CHAR_TABLE_TRANSLATE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
22190
diff
changeset
|
672 and do not follow parent. */ |
0a666cecb85d
(CHAR_TABLE_TRANSLATE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
22190
diff
changeset
|
673 #define CHAR_TABLE_TRANSLATE(CT, IDX) \ |
0a666cecb85d
(CHAR_TABLE_TRANSLATE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
22190
diff
changeset
|
674 ((IDX) < CHAR_TABLE_SINGLE_BYTE_SLOTS \ |
0a666cecb85d
(CHAR_TABLE_TRANSLATE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
22190
diff
changeset
|
675 ? (!NILP (XCHAR_TABLE (CT)->contents[IDX]) \ |
0a666cecb85d
(CHAR_TABLE_TRANSLATE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
22190
diff
changeset
|
676 ? XINT (XCHAR_TABLE (CT)->contents[IDX]) \ |
0a666cecb85d
(CHAR_TABLE_TRANSLATE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
22190
diff
changeset
|
677 : IDX) \ |
0a666cecb85d
(CHAR_TABLE_TRANSLATE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
22190
diff
changeset
|
678 : char_table_translate (CT, IDX)) |
0a666cecb85d
(CHAR_TABLE_TRANSLATE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
22190
diff
changeset
|
679 |
17188
e38cc84db8ab
(CHAR_TABLE_ORDINARY_SLOTS): Change to 384 (== 256 + 128).
Kenichi Handa <handa@m17n.org>
parents:
17141
diff
changeset
|
680 /* Equivalent to Faset (CT, IDX, VAL) with optimization for ASCII and |
18006
d29a9b467ac9
(CHAR_TABLE_REF): Do not check validity of CT.
Kenichi Handa <handa@m17n.org>
parents:
17871
diff
changeset
|
681 8-bit Europeans characters. Do not check validity of CT. */ |
d29a9b467ac9
(CHAR_TABLE_REF): Do not check validity of CT.
Kenichi Handa <handa@m17n.org>
parents:
17871
diff
changeset
|
682 #define CHAR_TABLE_SET(CT, IDX, VAL) \ |
d29a9b467ac9
(CHAR_TABLE_REF): Do not check validity of CT.
Kenichi Handa <handa@m17n.org>
parents:
17871
diff
changeset
|
683 do { \ |
d29a9b467ac9
(CHAR_TABLE_REF): Do not check validity of CT.
Kenichi Handa <handa@m17n.org>
parents:
17871
diff
changeset
|
684 if (XFASTINT (IDX) < CHAR_TABLE_SINGLE_BYTE_SLOTS) \ |
d29a9b467ac9
(CHAR_TABLE_REF): Do not check validity of CT.
Kenichi Handa <handa@m17n.org>
parents:
17871
diff
changeset
|
685 XCHAR_TABLE (CT)->contents[XFASTINT (IDX)] = VAL; \ |
d29a9b467ac9
(CHAR_TABLE_REF): Do not check validity of CT.
Kenichi Handa <handa@m17n.org>
parents:
17871
diff
changeset
|
686 else \ |
d29a9b467ac9
(CHAR_TABLE_REF): Do not check validity of CT.
Kenichi Handa <handa@m17n.org>
parents:
17871
diff
changeset
|
687 Faset (CT, IDX, VAL); \ |
17188
e38cc84db8ab
(CHAR_TABLE_ORDINARY_SLOTS): Change to 384 (== 256 + 128).
Kenichi Handa <handa@m17n.org>
parents:
17141
diff
changeset
|
688 } while (0) |
e38cc84db8ab
(CHAR_TABLE_ORDINARY_SLOTS): Change to 384 (== 256 + 128).
Kenichi Handa <handa@m17n.org>
parents:
17141
diff
changeset
|
689 |
13149
b1dcc3e87ffb
(struct Lisp_Boolvector): New data type.
Richard M. Stallman <rms@gnu.org>
parents:
12890
diff
changeset
|
690 struct Lisp_Char_Table |
b1dcc3e87ffb
(struct Lisp_Boolvector): New data type.
Richard M. Stallman <rms@gnu.org>
parents:
12890
diff
changeset
|
691 { |
b1dcc3e87ffb
(struct Lisp_Boolvector): New data type.
Richard M. Stallman <rms@gnu.org>
parents:
12890
diff
changeset
|
692 /* This is the vector's size field, which also holds the |
b1dcc3e87ffb
(struct Lisp_Boolvector): New data type.
Richard M. Stallman <rms@gnu.org>
parents:
12890
diff
changeset
|
693 pseudovector type information. It holds the size, too. |
17326
bd34aa57f3f5
(CHAR_TABLE_STANDARD_SLOTS): Now 4 more slots than
Kenichi Handa <handa@m17n.org>
parents:
17289
diff
changeset
|
694 The size counts the top, defalt, purpose, and parent slots. |
bd34aa57f3f5
(CHAR_TABLE_STANDARD_SLOTS): Now 4 more slots than
Kenichi Handa <handa@m17n.org>
parents:
17289
diff
changeset
|
695 The last three are not counted if this is a sub char table. */ |
13149
b1dcc3e87ffb
(struct Lisp_Boolvector): New data type.
Richard M. Stallman <rms@gnu.org>
parents:
12890
diff
changeset
|
696 EMACS_INT size; |
b1dcc3e87ffb
(struct Lisp_Boolvector): New data type.
Richard M. Stallman <rms@gnu.org>
parents:
12890
diff
changeset
|
697 struct Lisp_Vector *next; |
17326
bd34aa57f3f5
(CHAR_TABLE_STANDARD_SLOTS): Now 4 more slots than
Kenichi Handa <handa@m17n.org>
parents:
17289
diff
changeset
|
698 /* This holds a flag to tell if this is a top level char table (t) |
bd34aa57f3f5
(CHAR_TABLE_STANDARD_SLOTS): Now 4 more slots than
Kenichi Handa <handa@m17n.org>
parents:
17289
diff
changeset
|
699 or a sub char table (nil). */ |
bd34aa57f3f5
(CHAR_TABLE_STANDARD_SLOTS): Now 4 more slots than
Kenichi Handa <handa@m17n.org>
parents:
17289
diff
changeset
|
700 Lisp_Object top; |
13149
b1dcc3e87ffb
(struct Lisp_Boolvector): New data type.
Richard M. Stallman <rms@gnu.org>
parents:
12890
diff
changeset
|
701 /* This holds a default value, |
b1dcc3e87ffb
(struct Lisp_Boolvector): New data type.
Richard M. Stallman <rms@gnu.org>
parents:
12890
diff
changeset
|
702 which is used whenever the value for a specific character is nil. */ |
b1dcc3e87ffb
(struct Lisp_Boolvector): New data type.
Richard M. Stallman <rms@gnu.org>
parents:
12890
diff
changeset
|
703 Lisp_Object defalt; |
17326
bd34aa57f3f5
(CHAR_TABLE_STANDARD_SLOTS): Now 4 more slots than
Kenichi Handa <handa@m17n.org>
parents:
17289
diff
changeset
|
704 /* This holds an actual value of each element. A sub char table |
bd34aa57f3f5
(CHAR_TABLE_STANDARD_SLOTS): Now 4 more slots than
Kenichi Handa <handa@m17n.org>
parents:
17289
diff
changeset
|
705 has only SUB_CHAR_TABLE_ORDINARY_SLOTS number of elements. */ |
bd34aa57f3f5
(CHAR_TABLE_STANDARD_SLOTS): Now 4 more slots than
Kenichi Handa <handa@m17n.org>
parents:
17289
diff
changeset
|
706 Lisp_Object contents[CHAR_TABLE_ORDINARY_SLOTS]; |
bd34aa57f3f5
(CHAR_TABLE_STANDARD_SLOTS): Now 4 more slots than
Kenichi Handa <handa@m17n.org>
parents:
17289
diff
changeset
|
707 |
bd34aa57f3f5
(CHAR_TABLE_STANDARD_SLOTS): Now 4 more slots than
Kenichi Handa <handa@m17n.org>
parents:
17289
diff
changeset
|
708 /* A sub char table doesn't has the following slots. */ |
bd34aa57f3f5
(CHAR_TABLE_STANDARD_SLOTS): Now 4 more slots than
Kenichi Handa <handa@m17n.org>
parents:
17289
diff
changeset
|
709 |
13149
b1dcc3e87ffb
(struct Lisp_Boolvector): New data type.
Richard M. Stallman <rms@gnu.org>
parents:
12890
diff
changeset
|
710 /* This points to another char table, which we inherit from |
b1dcc3e87ffb
(struct Lisp_Boolvector): New data type.
Richard M. Stallman <rms@gnu.org>
parents:
12890
diff
changeset
|
711 when the value for a specific character is nil. |
b1dcc3e87ffb
(struct Lisp_Boolvector): New data type.
Richard M. Stallman <rms@gnu.org>
parents:
12890
diff
changeset
|
712 The `defalt' slot takes precedence over this. */ |
b1dcc3e87ffb
(struct Lisp_Boolvector): New data type.
Richard M. Stallman <rms@gnu.org>
parents:
12890
diff
changeset
|
713 Lisp_Object parent; |
13202
b307cd5c259f
(struct Lisp_Char_Table): New slot `purpose'.
Richard M. Stallman <rms@gnu.org>
parents:
13149
diff
changeset
|
714 /* This should be a symbol which says what kind of use |
b307cd5c259f
(struct Lisp_Char_Table): New slot `purpose'.
Richard M. Stallman <rms@gnu.org>
parents:
13149
diff
changeset
|
715 this char-table is meant for. |
b307cd5c259f
(struct Lisp_Char_Table): New slot `purpose'.
Richard M. Stallman <rms@gnu.org>
parents:
13149
diff
changeset
|
716 Typically now the values can be `syntax-table' and `display-table'. */ |
b307cd5c259f
(struct Lisp_Char_Table): New slot `purpose'.
Richard M. Stallman <rms@gnu.org>
parents:
13149
diff
changeset
|
717 Lisp_Object purpose; |
13149
b1dcc3e87ffb
(struct Lisp_Boolvector): New data type.
Richard M. Stallman <rms@gnu.org>
parents:
12890
diff
changeset
|
718 /* These hold additional data. */ |
b1dcc3e87ffb
(struct Lisp_Boolvector): New data type.
Richard M. Stallman <rms@gnu.org>
parents:
12890
diff
changeset
|
719 Lisp_Object extras[1]; |
b1dcc3e87ffb
(struct Lisp_Boolvector): New data type.
Richard M. Stallman <rms@gnu.org>
parents:
12890
diff
changeset
|
720 }; |
b1dcc3e87ffb
(struct Lisp_Boolvector): New data type.
Richard M. Stallman <rms@gnu.org>
parents:
12890
diff
changeset
|
721 |
b1dcc3e87ffb
(struct Lisp_Boolvector): New data type.
Richard M. Stallman <rms@gnu.org>
parents:
12890
diff
changeset
|
722 /* A boolvector is a kind of vectorlike, with contents are like a string. */ |
b1dcc3e87ffb
(struct Lisp_Boolvector): New data type.
Richard M. Stallman <rms@gnu.org>
parents:
12890
diff
changeset
|
723 struct Lisp_Bool_Vector |
b1dcc3e87ffb
(struct Lisp_Boolvector): New data type.
Richard M. Stallman <rms@gnu.org>
parents:
12890
diff
changeset
|
724 { |
b1dcc3e87ffb
(struct Lisp_Boolvector): New data type.
Richard M. Stallman <rms@gnu.org>
parents:
12890
diff
changeset
|
725 /* This is the vector's size field. It doesn't have the real size, |
b1dcc3e87ffb
(struct Lisp_Boolvector): New data type.
Richard M. Stallman <rms@gnu.org>
parents:
12890
diff
changeset
|
726 just the subtype information. */ |
b1dcc3e87ffb
(struct Lisp_Boolvector): New data type.
Richard M. Stallman <rms@gnu.org>
parents:
12890
diff
changeset
|
727 EMACS_INT vector_size; |
b1dcc3e87ffb
(struct Lisp_Boolvector): New data type.
Richard M. Stallman <rms@gnu.org>
parents:
12890
diff
changeset
|
728 struct Lisp_Vector *next; |
b1dcc3e87ffb
(struct Lisp_Boolvector): New data type.
Richard M. Stallman <rms@gnu.org>
parents:
12890
diff
changeset
|
729 /* This is the size in bits. */ |
b1dcc3e87ffb
(struct Lisp_Boolvector): New data type.
Richard M. Stallman <rms@gnu.org>
parents:
12890
diff
changeset
|
730 EMACS_INT size; |
b1dcc3e87ffb
(struct Lisp_Boolvector): New data type.
Richard M. Stallman <rms@gnu.org>
parents:
12890
diff
changeset
|
731 /* This contains the actual bits, packed into bytes. */ |
b1dcc3e87ffb
(struct Lisp_Boolvector): New data type.
Richard M. Stallman <rms@gnu.org>
parents:
12890
diff
changeset
|
732 unsigned char data[1]; |
b1dcc3e87ffb
(struct Lisp_Boolvector): New data type.
Richard M. Stallman <rms@gnu.org>
parents:
12890
diff
changeset
|
733 }; |
b1dcc3e87ffb
(struct Lisp_Boolvector): New data type.
Richard M. Stallman <rms@gnu.org>
parents:
12890
diff
changeset
|
734 |
10292
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
735 /* This structure describes a built-in function. |
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
736 It is generated by the DEFUN macro only. |
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
737 defsubr makes it into a Lisp object. |
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
738 |
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
739 This type is treated in most respects as a pseudovector, |
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
740 but since we never dynamically allocate or free them, |
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
741 we don't need a next-vector field. */ |
17404
73012b195cf3
(DOWNCASE): Return int, not Lisp_Object.
Karl Heuer <kwzh@gnu.org>
parents:
17326
diff
changeset
|
742 |
302 | 743 struct Lisp_Subr |
744 { | |
10292
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
745 EMACS_INT size; |
302 | 746 Lisp_Object (*function) (); |
747 short min_args, max_args; | |
748 char *symbol_name; | |
749 char *prompt; | |
750 char *doc; | |
751 }; | |
25017
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
752 |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
753 |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
754 /*********************************************************************** |
39579
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
755 Symbols |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
756 ***********************************************************************/ |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
757 |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
758 /* Interned state of a symbol. */ |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
759 |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
760 enum symbol_interned |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
761 { |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
762 SYMBOL_UNINTERNED = 0, |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
763 SYMBOL_INTERNED = 1, |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
764 SYMBOL_INTERNED_IN_INITIAL_OBARRAY = 2 |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
765 }; |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
766 |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
767 /* In a symbol, the markbit of the plist is used as the gc mark bit */ |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
768 |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
769 struct Lisp_Symbol |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
770 { |
51657
7fb427e8d984
(struct interval, struct Lisp_Symbol, struct Lisp_Free)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51167
diff
changeset
|
771 unsigned gcmarkbit : 1; |
7fb427e8d984
(struct interval, struct Lisp_Symbol, struct Lisp_Free)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51167
diff
changeset
|
772 |
39579
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
773 /* Non-zero means symbol serves as a variable alias. The symbol |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
774 holding the real value is found in the value slot. */ |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
775 unsigned indirect_variable : 1; |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
776 |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
777 /* Non-zero means symbol is constant, i.e. changing its value |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
778 should signal an error. */ |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
779 unsigned constant : 1; |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
780 |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
781 /* Interned state of the symbol. This is an enumerator from |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
782 enum symbol_interned. */ |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
783 unsigned interned : 2; |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
784 |
45405
13e858104d3b
* lisp.h (struct Lisp_Symbol): Replace field "name" with a lisp
Ken Raeburn <raeburn@raeburn.org>
parents:
45375
diff
changeset
|
785 /* The symbol's name, as a Lisp string. |
13e858104d3b
* lisp.h (struct Lisp_Symbol): Replace field "name" with a lisp
Ken Raeburn <raeburn@raeburn.org>
parents:
45375
diff
changeset
|
786 |
13e858104d3b
* lisp.h (struct Lisp_Symbol): Replace field "name" with a lisp
Ken Raeburn <raeburn@raeburn.org>
parents:
45375
diff
changeset
|
787 The name "xname" is used to intentionally break code referring to |
13e858104d3b
* lisp.h (struct Lisp_Symbol): Replace field "name" with a lisp
Ken Raeburn <raeburn@raeburn.org>
parents:
45375
diff
changeset
|
788 the old field "name" of type pointer to struct Lisp_String. */ |
13e858104d3b
* lisp.h (struct Lisp_Symbol): Replace field "name" with a lisp
Ken Raeburn <raeburn@raeburn.org>
parents:
45375
diff
changeset
|
789 Lisp_Object xname; |
39579
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
790 |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
791 /* Value of the symbol or Qunbound if unbound. If this symbol is a |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
792 defvaralias, `value' contains the symbol for which it is an |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
793 alias. Use the SYMBOL_VALUE and SET_SYMBOL_VALUE macros to get |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
794 and set a symbol's value, to take defvaralias into account. */ |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
795 Lisp_Object value; |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
796 |
41615
6486180ed9ef
(run_hook_list_with_args): Remove.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
41262
diff
changeset
|
797 /* Function value of the symbol or Qunbound if not fboundp. */ |
39579
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
798 Lisp_Object function; |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
799 |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
800 /* The symbol's property list. */ |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
801 Lisp_Object plist; |
45623
0e92d219e195
(current_column): Now returns float.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents:
45545
diff
changeset
|
802 |
39579
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
803 /* Next symbol in obarray bucket, if the symbol is interned. */ |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
804 struct Lisp_Symbol *next; |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
805 }; |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
806 |
45405
13e858104d3b
* lisp.h (struct Lisp_Symbol): Replace field "name" with a lisp
Ken Raeburn <raeburn@raeburn.org>
parents:
45375
diff
changeset
|
807 /* Value is name of symbol. */ |
13e858104d3b
* lisp.h (struct Lisp_Symbol): Replace field "name" with a lisp
Ken Raeburn <raeburn@raeburn.org>
parents:
45375
diff
changeset
|
808 |
13e858104d3b
* lisp.h (struct Lisp_Symbol): Replace field "name" with a lisp
Ken Raeburn <raeburn@raeburn.org>
parents:
45375
diff
changeset
|
809 #define SYMBOL_NAME(sym) \ |
13e858104d3b
* lisp.h (struct Lisp_Symbol): Replace field "name" with a lisp
Ken Raeburn <raeburn@raeburn.org>
parents:
45375
diff
changeset
|
810 LISP_MAKE_RVALUE (XSYMBOL (sym)->xname) |
13e858104d3b
* lisp.h (struct Lisp_Symbol): Replace field "name" with a lisp
Ken Raeburn <raeburn@raeburn.org>
parents:
45375
diff
changeset
|
811 |
39579
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
812 /* Value is non-zero if SYM is an interned symbol. */ |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
813 |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
814 #define SYMBOL_INTERNED_P(sym) \ |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
815 (XSYMBOL (sym)->interned != SYMBOL_UNINTERNED) |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
816 |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
817 /* Value is non-zero if SYM is interned in initial_obarray. */ |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
818 |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
819 #define SYMBOL_INTERNED_IN_INITIAL_OBARRAY_P(sym) \ |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
820 (XSYMBOL (sym)->interned == SYMBOL_INTERNED_IN_INITIAL_OBARRAY) |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
821 |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
822 /* Value is non-zero if symbol is considered a constant, i.e. its |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
823 value cannot be changed (there is an exception for keyword symbols, |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
824 whose value can be set to the keyword symbol itself). */ |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
825 |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
826 #define SYMBOL_CONSTANT_P(sym) XSYMBOL (sym)->constant |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
827 |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
828 /* Value is the value of SYM, with defvaralias taken into |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
829 account. */ |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
830 |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
831 #define SYMBOL_VALUE(sym) \ |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
832 (XSYMBOL (sym)->indirect_variable \ |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
833 ? XSYMBOL (indirect_variable (sym))->value \ |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
834 : XSYMBOL (sym)->value) |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
835 |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
836 /* Set SYM's value to VAL, taking defvaralias into account. */ |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
837 |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
838 #define SET_SYMBOL_VALUE(sym, val) \ |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
839 do { \ |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
840 if (XSYMBOL (sym)->indirect_variable) \ |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
841 XSYMBOL (indirect_variable ((sym)))->value = (val); \ |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
842 else \ |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
843 XSYMBOL (sym)->value = (val); \ |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
844 } while (0) |
45623
0e92d219e195
(current_column): Now returns float.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents:
45545
diff
changeset
|
845 |
39579
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
846 |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
847 /*********************************************************************** |
25017
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
848 Hash Tables |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
849 ***********************************************************************/ |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
850 |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
851 /* The structure of a Lisp hash table. */ |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
852 |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
853 struct Lisp_Hash_Table |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
854 { |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
855 /* Vector fields. The hash table code doesn't refer to these. */ |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
856 EMACS_INT size; |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
857 struct Lisp_Vector *vec_next; |
45623
0e92d219e195
(current_column): Now returns float.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents:
45545
diff
changeset
|
858 |
25017
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
859 /* Function used to compare keys. */ |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
860 Lisp_Object test; |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
861 |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
862 /* Nil if table is non-weak. Otherwise a symbol describing the |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
863 weakness of the table. */ |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
864 Lisp_Object weak; |
45623
0e92d219e195
(current_column): Now returns float.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents:
45545
diff
changeset
|
865 |
25017
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
866 /* When the table is resized, and this is an integer, compute the |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
867 new size by adding this to the old size. If a float, compute the |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
868 new size by multiplying the old size with this factor. */ |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
869 Lisp_Object rehash_size; |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
870 |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
871 /* Resize hash table when number of entries/ table size is >= this |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
872 ratio, a float. */ |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
873 Lisp_Object rehash_threshold; |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
874 |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
875 /* Number of key/value entries in the table. */ |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
876 Lisp_Object count; |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
877 |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
878 /* Vector of keys and values. The key of item I is found at index |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
879 2 * I, the value is found at index 2 * I + 1. */ |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
880 Lisp_Object key_and_value; |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
881 |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
882 /* Vector of hash codes.. If hash[I] is nil, this means that that |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
883 entry I is unused. */ |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
884 Lisp_Object hash; |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
885 |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
886 /* Vector used to chain entries. If entry I is free, next[I] is the |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
887 entry number of the next free item. If entry I is non-free, |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
888 next[I] is the index of the next entry in the collision chain. */ |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
889 Lisp_Object next; |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
890 |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
891 /* Index of first free entry in free list. */ |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
892 Lisp_Object next_free; |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
893 |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
894 /* Bucket vector. A non-nil entry is the index of the first item in |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
895 a collision chain. This vector's size can be larger than the |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
896 hash table size to reduce collisions. */ |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
897 Lisp_Object index; |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
898 |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
899 /* Next weak hash table if this is a weak hash table. The head |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
900 of the list is in Vweak_hash_tables. */ |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
901 Lisp_Object next_weak; |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
902 |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
903 /* User-supplied hash function, or nil. */ |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
904 Lisp_Object user_hash_function; |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
905 |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
906 /* User-supplied key comparison function, or nil. */ |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
907 Lisp_Object user_cmp_function; |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
908 |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
909 /* C function to compare two keys. */ |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
910 int (* cmpfn) P_ ((struct Lisp_Hash_Table *, Lisp_Object, |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
911 unsigned, Lisp_Object, unsigned)); |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
912 |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
913 /* C function to compute hash code. */ |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
914 unsigned (* hashfn) P_ ((struct Lisp_Hash_Table *, Lisp_Object)); |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
915 }; |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
916 |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
917 |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
918 #define XHASH_TABLE(OBJ) \ |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
919 ((struct Lisp_Hash_Table *) XPNTR (OBJ)) |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
920 |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
921 #define XSET_HASH_TABLE(VAR, PTR) \ |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
922 (XSETPSEUDOVECTOR (VAR, PTR, PVEC_HASH_TABLE)) |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
923 |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
924 #define HASH_TABLE_P(OBJ) PSEUDOVECTORP (OBJ, PVEC_HASH_TABLE) |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
925 #define GC_HASH_TABLE_P(x) GC_PSEUDOVECTORP (x, PVEC_HASH_TABLE) |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
926 |
40653
6c48a4da1da5
(CHECK_STRING_OR_BUFFER, CHECK_HASH_TABLE, CHECK_LIST, CHECK_STRING,
Pavel Janík <Pavel@Janik.cz>
parents:
40536
diff
changeset
|
927 #define CHECK_HASH_TABLE(x) \ |
25017
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
928 do \ |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
929 { \ |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
930 if (!HASH_TABLE_P ((x))) \ |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
931 x = wrong_type_argument (Qhash_table_p, (x)); \ |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
932 } \ |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
933 while (0) |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
934 |
46220
5abad41fb43b
(HASH_KEY, HASH_VALUE, HASH_NEXT, HASH_HASH, HASH_INDEX)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
46070
diff
changeset
|
935 /* Value is the key part of entry IDX in hash table H. */ |
5abad41fb43b
(HASH_KEY, HASH_VALUE, HASH_NEXT, HASH_HASH, HASH_INDEX)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
46070
diff
changeset
|
936 |
5abad41fb43b
(HASH_KEY, HASH_VALUE, HASH_NEXT, HASH_HASH, HASH_INDEX)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
46070
diff
changeset
|
937 #define HASH_KEY(H, IDX) AREF ((H)->key_and_value, 2 * (IDX)) |
5abad41fb43b
(HASH_KEY, HASH_VALUE, HASH_NEXT, HASH_HASH, HASH_INDEX)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
46070
diff
changeset
|
938 |
5abad41fb43b
(HASH_KEY, HASH_VALUE, HASH_NEXT, HASH_HASH, HASH_INDEX)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
46070
diff
changeset
|
939 /* Value is the value part of entry IDX in hash table H. */ |
5abad41fb43b
(HASH_KEY, HASH_VALUE, HASH_NEXT, HASH_HASH, HASH_INDEX)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
46070
diff
changeset
|
940 |
5abad41fb43b
(HASH_KEY, HASH_VALUE, HASH_NEXT, HASH_HASH, HASH_INDEX)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
46070
diff
changeset
|
941 #define HASH_VALUE(H, IDX) AREF ((H)->key_and_value, 2 * (IDX) + 1) |
5abad41fb43b
(HASH_KEY, HASH_VALUE, HASH_NEXT, HASH_HASH, HASH_INDEX)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
46070
diff
changeset
|
942 |
5abad41fb43b
(HASH_KEY, HASH_VALUE, HASH_NEXT, HASH_HASH, HASH_INDEX)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
46070
diff
changeset
|
943 /* Value is the index of the next entry following the one at IDX |
5abad41fb43b
(HASH_KEY, HASH_VALUE, HASH_NEXT, HASH_HASH, HASH_INDEX)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
46070
diff
changeset
|
944 in hash table H. */ |
5abad41fb43b
(HASH_KEY, HASH_VALUE, HASH_NEXT, HASH_HASH, HASH_INDEX)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
46070
diff
changeset
|
945 |
5abad41fb43b
(HASH_KEY, HASH_VALUE, HASH_NEXT, HASH_HASH, HASH_INDEX)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
46070
diff
changeset
|
946 #define HASH_NEXT(H, IDX) AREF ((H)->next, (IDX)) |
5abad41fb43b
(HASH_KEY, HASH_VALUE, HASH_NEXT, HASH_HASH, HASH_INDEX)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
46070
diff
changeset
|
947 |
5abad41fb43b
(HASH_KEY, HASH_VALUE, HASH_NEXT, HASH_HASH, HASH_INDEX)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
46070
diff
changeset
|
948 /* Value is the hash code computed for entry IDX in hash table H. */ |
5abad41fb43b
(HASH_KEY, HASH_VALUE, HASH_NEXT, HASH_HASH, HASH_INDEX)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
46070
diff
changeset
|
949 |
5abad41fb43b
(HASH_KEY, HASH_VALUE, HASH_NEXT, HASH_HASH, HASH_INDEX)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
46070
diff
changeset
|
950 #define HASH_HASH(H, IDX) AREF ((H)->hash, (IDX)) |
5abad41fb43b
(HASH_KEY, HASH_VALUE, HASH_NEXT, HASH_HASH, HASH_INDEX)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
46070
diff
changeset
|
951 |
5abad41fb43b
(HASH_KEY, HASH_VALUE, HASH_NEXT, HASH_HASH, HASH_INDEX)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
46070
diff
changeset
|
952 /* Value is the index of the element in hash table H that is the |
5abad41fb43b
(HASH_KEY, HASH_VALUE, HASH_NEXT, HASH_HASH, HASH_INDEX)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
46070
diff
changeset
|
953 start of the collision list at index IDX in the index vector of H. */ |
5abad41fb43b
(HASH_KEY, HASH_VALUE, HASH_NEXT, HASH_HASH, HASH_INDEX)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
46070
diff
changeset
|
954 |
5abad41fb43b
(HASH_KEY, HASH_VALUE, HASH_NEXT, HASH_HASH, HASH_INDEX)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
46070
diff
changeset
|
955 #define HASH_INDEX(H, IDX) AREF ((H)->index, (IDX)) |
5abad41fb43b
(HASH_KEY, HASH_VALUE, HASH_NEXT, HASH_HASH, HASH_INDEX)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
46070
diff
changeset
|
956 |
5abad41fb43b
(HASH_KEY, HASH_VALUE, HASH_NEXT, HASH_HASH, HASH_INDEX)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
46070
diff
changeset
|
957 /* Value is the size of hash table H. */ |
5abad41fb43b
(HASH_KEY, HASH_VALUE, HASH_NEXT, HASH_HASH, HASH_INDEX)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
46070
diff
changeset
|
958 |
5abad41fb43b
(HASH_KEY, HASH_VALUE, HASH_NEXT, HASH_HASH, HASH_INDEX)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
46070
diff
changeset
|
959 #define HASH_TABLE_SIZE(H) XVECTOR ((H)->next)->size |
5abad41fb43b
(HASH_KEY, HASH_VALUE, HASH_NEXT, HASH_HASH, HASH_INDEX)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
46070
diff
changeset
|
960 |
25017
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
961 /* Default size for hash tables if not specified. */ |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
962 |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
963 #define DEFAULT_HASH_SIZE 65 |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
964 |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
965 /* Default threshold specifying when to resize a hash table. The |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
966 value gives the ratio of current entries in the hash table and the |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
967 size of the hash table. */ |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
968 |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
969 #define DEFAULT_REHASH_THRESHOLD 0.8 |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
970 |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
971 /* Default factor by which to increase the size of a hash table. */ |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
972 |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
973 #define DEFAULT_REHASH_SIZE 1.5 |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
974 |
9462
3601bf7327b2
(enum Lisp_Misc_Type): Add new enumerations Lisp_Misc_Intfwd,
Karl Heuer <kwzh@gnu.org>
parents:
9435
diff
changeset
|
975 |
10292
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
976 /* These structures are used for various misc types. */ |
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
977 |
302 | 978 struct Lisp_Marker |
12890
2a1edeeb13fb
(struct Lisp_Marker): Make insertion_type an unsigned int.
Richard M. Stallman <rms@gnu.org>
parents:
12731
diff
changeset
|
979 { |
2a1edeeb13fb
(struct Lisp_Marker): Make insertion_type an unsigned int.
Richard M. Stallman <rms@gnu.org>
parents:
12731
diff
changeset
|
980 int type : 16; /* = Lisp_Misc_Marker */ |
51657
7fb427e8d984
(struct interval, struct Lisp_Symbol, struct Lisp_Free)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51167
diff
changeset
|
981 unsigned gcmarkbit : 1; |
7fb427e8d984
(struct interval, struct Lisp_Symbol, struct Lisp_Free)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51167
diff
changeset
|
982 int spacer : 14; |
12890
2a1edeeb13fb
(struct Lisp_Marker): Make insertion_type an unsigned int.
Richard M. Stallman <rms@gnu.org>
parents:
12731
diff
changeset
|
983 /* 1 means normal insertion at the marker's position |
2a1edeeb13fb
(struct Lisp_Marker): Make insertion_type an unsigned int.
Richard M. Stallman <rms@gnu.org>
parents:
12731
diff
changeset
|
984 leaves the marker after the inserted text. */ |
2a1edeeb13fb
(struct Lisp_Marker): Make insertion_type an unsigned int.
Richard M. Stallman <rms@gnu.org>
parents:
12731
diff
changeset
|
985 unsigned int insertion_type : 1; |
20559
38941faa1564
(struct Lisp_Marker): New field `charpos'.
Richard M. Stallman <rms@gnu.org>
parents:
20499
diff
changeset
|
986 /* This is the buffer that the marker points into, |
38941faa1564
(struct Lisp_Marker): New field `charpos'.
Richard M. Stallman <rms@gnu.org>
parents:
20499
diff
changeset
|
987 or 0 if it points nowhere. */ |
12890
2a1edeeb13fb
(struct Lisp_Marker): Make insertion_type an unsigned int.
Richard M. Stallman <rms@gnu.org>
parents:
12731
diff
changeset
|
988 struct buffer *buffer; |
20559
38941faa1564
(struct Lisp_Marker): New field `charpos'.
Richard M. Stallman <rms@gnu.org>
parents:
20499
diff
changeset
|
989 |
38941faa1564
(struct Lisp_Marker): New field `charpos'.
Richard M. Stallman <rms@gnu.org>
parents:
20499
diff
changeset
|
990 /* The remaining fields are meaningless in a marker that |
38941faa1564
(struct Lisp_Marker): New field `charpos'.
Richard M. Stallman <rms@gnu.org>
parents:
20499
diff
changeset
|
991 does not point anywhere. */ |
38941faa1564
(struct Lisp_Marker): New field `charpos'.
Richard M. Stallman <rms@gnu.org>
parents:
20499
diff
changeset
|
992 |
38941faa1564
(struct Lisp_Marker): New field `charpos'.
Richard M. Stallman <rms@gnu.org>
parents:
20499
diff
changeset
|
993 /* For markers that point somewhere, |
38941faa1564
(struct Lisp_Marker): New field `charpos'.
Richard M. Stallman <rms@gnu.org>
parents:
20499
diff
changeset
|
994 this is used to chain of all the markers in a given buffer. */ |
51666
7181f5ced81c
(unchain_marker): Lisp_Object arg => Lisp_Marker.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51657
diff
changeset
|
995 struct Lisp_Marker *next; |
20559
38941faa1564
(struct Lisp_Marker): New field `charpos'.
Richard M. Stallman <rms@gnu.org>
parents:
20499
diff
changeset
|
996 /* This is the char position where the marker points. */ |
51858
bf6232373c39
(VALBITS): Define in terms of GCTYPEBITS.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51833
diff
changeset
|
997 EMACS_INT charpos; |
20569
d8013f2236a0
(struct Lisp_Marker): Rename `bufpos' to `bytepos'.
Richard M. Stallman <rms@gnu.org>
parents:
20559
diff
changeset
|
998 /* This is the byte position. */ |
51858
bf6232373c39
(VALBITS): Define in terms of GCTYPEBITS.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51833
diff
changeset
|
999 EMACS_INT bytepos; |
12890
2a1edeeb13fb
(struct Lisp_Marker): Make insertion_type an unsigned int.
Richard M. Stallman <rms@gnu.org>
parents:
12731
diff
changeset
|
1000 }; |
302 | 1001 |
9462
3601bf7327b2
(enum Lisp_Misc_Type): Add new enumerations Lisp_Misc_Intfwd,
Karl Heuer <kwzh@gnu.org>
parents:
9435
diff
changeset
|
1002 /* Forwarding pointer to an int variable. |
3601bf7327b2
(enum Lisp_Misc_Type): Add new enumerations Lisp_Misc_Intfwd,
Karl Heuer <kwzh@gnu.org>
parents:
9435
diff
changeset
|
1003 This is allowed only in the value cell of a symbol, |
3601bf7327b2
(enum Lisp_Misc_Type): Add new enumerations Lisp_Misc_Intfwd,
Karl Heuer <kwzh@gnu.org>
parents:
9435
diff
changeset
|
1004 and it means that the symbol's value really lives in the |
3601bf7327b2
(enum Lisp_Misc_Type): Add new enumerations Lisp_Misc_Intfwd,
Karl Heuer <kwzh@gnu.org>
parents:
9435
diff
changeset
|
1005 specified int variable. */ |
3601bf7327b2
(enum Lisp_Misc_Type): Add new enumerations Lisp_Misc_Intfwd,
Karl Heuer <kwzh@gnu.org>
parents:
9435
diff
changeset
|
1006 struct Lisp_Intfwd |
3601bf7327b2
(enum Lisp_Misc_Type): Add new enumerations Lisp_Misc_Intfwd,
Karl Heuer <kwzh@gnu.org>
parents:
9435
diff
changeset
|
1007 { |
10387
40988c371fca
(struct Lisp_Free, struct Lisp_Marker, etc.):
Richard M. Stallman <rms@gnu.org>
parents:
10339
diff
changeset
|
1008 int type : 16; /* = Lisp_Misc_Intfwd */ |
51657
7fb427e8d984
(struct interval, struct Lisp_Symbol, struct Lisp_Free)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51167
diff
changeset
|
1009 unsigned gcmarkbit : 1; |
7fb427e8d984
(struct interval, struct Lisp_Symbol, struct Lisp_Free)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51167
diff
changeset
|
1010 int spacer : 15; |
43713
f92c4d87863a
Change defvar_int def and vars to use EMACS_INT instead of just int.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
43699
diff
changeset
|
1011 EMACS_INT *intvar; |
9462
3601bf7327b2
(enum Lisp_Misc_Type): Add new enumerations Lisp_Misc_Intfwd,
Karl Heuer <kwzh@gnu.org>
parents:
9435
diff
changeset
|
1012 }; |
3601bf7327b2
(enum Lisp_Misc_Type): Add new enumerations Lisp_Misc_Intfwd,
Karl Heuer <kwzh@gnu.org>
parents:
9435
diff
changeset
|
1013 |
3601bf7327b2
(enum Lisp_Misc_Type): Add new enumerations Lisp_Misc_Intfwd,
Karl Heuer <kwzh@gnu.org>
parents:
9435
diff
changeset
|
1014 /* Boolean forwarding pointer to an int variable. |
3601bf7327b2
(enum Lisp_Misc_Type): Add new enumerations Lisp_Misc_Intfwd,
Karl Heuer <kwzh@gnu.org>
parents:
9435
diff
changeset
|
1015 This is like Lisp_Intfwd except that the ostensible |
3601bf7327b2
(enum Lisp_Misc_Type): Add new enumerations Lisp_Misc_Intfwd,
Karl Heuer <kwzh@gnu.org>
parents:
9435
diff
changeset
|
1016 "value" of the symbol is t if the int variable is nonzero, |
3601bf7327b2
(enum Lisp_Misc_Type): Add new enumerations Lisp_Misc_Intfwd,
Karl Heuer <kwzh@gnu.org>
parents:
9435
diff
changeset
|
1017 nil if it is zero. */ |
3601bf7327b2
(enum Lisp_Misc_Type): Add new enumerations Lisp_Misc_Intfwd,
Karl Heuer <kwzh@gnu.org>
parents:
9435
diff
changeset
|
1018 struct Lisp_Boolfwd |
9435
3a157cdf395c
(Lisp_Misc): new type code, replacing Lisp_Marker (and soon to replace other
Karl Heuer <kwzh@gnu.org>
parents:
9392
diff
changeset
|
1019 { |
10387
40988c371fca
(struct Lisp_Free, struct Lisp_Marker, etc.):
Richard M. Stallman <rms@gnu.org>
parents:
10339
diff
changeset
|
1020 int type : 16; /* = Lisp_Misc_Boolfwd */ |
51657
7fb427e8d984
(struct interval, struct Lisp_Symbol, struct Lisp_Free)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51167
diff
changeset
|
1021 unsigned gcmarkbit : 1; |
7fb427e8d984
(struct interval, struct Lisp_Symbol, struct Lisp_Free)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51167
diff
changeset
|
1022 int spacer : 15; |
9462
3601bf7327b2
(enum Lisp_Misc_Type): Add new enumerations Lisp_Misc_Intfwd,
Karl Heuer <kwzh@gnu.org>
parents:
9435
diff
changeset
|
1023 int *boolvar; |
3601bf7327b2
(enum Lisp_Misc_Type): Add new enumerations Lisp_Misc_Intfwd,
Karl Heuer <kwzh@gnu.org>
parents:
9435
diff
changeset
|
1024 }; |
3601bf7327b2
(enum Lisp_Misc_Type): Add new enumerations Lisp_Misc_Intfwd,
Karl Heuer <kwzh@gnu.org>
parents:
9435
diff
changeset
|
1025 |
3601bf7327b2
(enum Lisp_Misc_Type): Add new enumerations Lisp_Misc_Intfwd,
Karl Heuer <kwzh@gnu.org>
parents:
9435
diff
changeset
|
1026 /* Forwarding pointer to a Lisp_Object variable. |
3601bf7327b2
(enum Lisp_Misc_Type): Add new enumerations Lisp_Misc_Intfwd,
Karl Heuer <kwzh@gnu.org>
parents:
9435
diff
changeset
|
1027 This is allowed only in the value cell of a symbol, |
3601bf7327b2
(enum Lisp_Misc_Type): Add new enumerations Lisp_Misc_Intfwd,
Karl Heuer <kwzh@gnu.org>
parents:
9435
diff
changeset
|
1028 and it means that the symbol's value really lives in the |
3601bf7327b2
(enum Lisp_Misc_Type): Add new enumerations Lisp_Misc_Intfwd,
Karl Heuer <kwzh@gnu.org>
parents:
9435
diff
changeset
|
1029 specified variable. */ |
3601bf7327b2
(enum Lisp_Misc_Type): Add new enumerations Lisp_Misc_Intfwd,
Karl Heuer <kwzh@gnu.org>
parents:
9435
diff
changeset
|
1030 struct Lisp_Objfwd |
3601bf7327b2
(enum Lisp_Misc_Type): Add new enumerations Lisp_Misc_Intfwd,
Karl Heuer <kwzh@gnu.org>
parents:
9435
diff
changeset
|
1031 { |
10387
40988c371fca
(struct Lisp_Free, struct Lisp_Marker, etc.):
Richard M. Stallman <rms@gnu.org>
parents:
10339
diff
changeset
|
1032 int type : 16; /* = Lisp_Misc_Objfwd */ |
51657
7fb427e8d984
(struct interval, struct Lisp_Symbol, struct Lisp_Free)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51167
diff
changeset
|
1033 unsigned gcmarkbit : 1; |
7fb427e8d984
(struct interval, struct Lisp_Symbol, struct Lisp_Free)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51167
diff
changeset
|
1034 int spacer : 15; |
9462
3601bf7327b2
(enum Lisp_Misc_Type): Add new enumerations Lisp_Misc_Intfwd,
Karl Heuer <kwzh@gnu.org>
parents:
9435
diff
changeset
|
1035 Lisp_Object *objvar; |
3601bf7327b2
(enum Lisp_Misc_Type): Add new enumerations Lisp_Misc_Intfwd,
Karl Heuer <kwzh@gnu.org>
parents:
9435
diff
changeset
|
1036 }; |
3601bf7327b2
(enum Lisp_Misc_Type): Add new enumerations Lisp_Misc_Intfwd,
Karl Heuer <kwzh@gnu.org>
parents:
9435
diff
changeset
|
1037 |
3601bf7327b2
(enum Lisp_Misc_Type): Add new enumerations Lisp_Misc_Intfwd,
Karl Heuer <kwzh@gnu.org>
parents:
9435
diff
changeset
|
1038 /* Like Lisp_Objfwd except that value lives in a slot in the |
3601bf7327b2
(enum Lisp_Misc_Type): Add new enumerations Lisp_Misc_Intfwd,
Karl Heuer <kwzh@gnu.org>
parents:
9435
diff
changeset
|
1039 current buffer. Value is byte index of slot within buffer. */ |
3601bf7327b2
(enum Lisp_Misc_Type): Add new enumerations Lisp_Misc_Intfwd,
Karl Heuer <kwzh@gnu.org>
parents:
9435
diff
changeset
|
1040 struct Lisp_Buffer_Objfwd |
3601bf7327b2
(enum Lisp_Misc_Type): Add new enumerations Lisp_Misc_Intfwd,
Karl Heuer <kwzh@gnu.org>
parents:
9435
diff
changeset
|
1041 { |
10387
40988c371fca
(struct Lisp_Free, struct Lisp_Marker, etc.):
Richard M. Stallman <rms@gnu.org>
parents:
10339
diff
changeset
|
1042 int type : 16; /* = Lisp_Misc_Buffer_Objfwd */ |
51657
7fb427e8d984
(struct interval, struct Lisp_Symbol, struct Lisp_Free)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51167
diff
changeset
|
1043 unsigned gcmarkbit : 1; |
7fb427e8d984
(struct interval, struct Lisp_Symbol, struct Lisp_Free)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51167
diff
changeset
|
1044 int spacer : 15; |
9462
3601bf7327b2
(enum Lisp_Misc_Type): Add new enumerations Lisp_Misc_Intfwd,
Karl Heuer <kwzh@gnu.org>
parents:
9435
diff
changeset
|
1045 int offset; |
9435
3a157cdf395c
(Lisp_Misc): new type code, replacing Lisp_Marker (and soon to replace other
Karl Heuer <kwzh@gnu.org>
parents:
9392
diff
changeset
|
1046 }; |
3a157cdf395c
(Lisp_Misc): new type code, replacing Lisp_Marker (and soon to replace other
Karl Heuer <kwzh@gnu.org>
parents:
9392
diff
changeset
|
1047 |
27779 | 1048 /* struct Lisp_Buffer_Local_Value is used in a symbol value cell when |
1049 the symbol has buffer-local or frame-local bindings. (Exception: | |
1050 some buffer-local variables are built-in, with their values stored | |
1051 in the buffer structure itself. They are handled differently, | |
1052 using struct Lisp_Buffer_Objfwd.) | |
1053 | |
1054 The `realvalue' slot holds the variable's current value, or a | |
1055 forwarding pointer to where that value is kept. This value is the | |
1056 one that corresponds to the loaded binding. To read or set the | |
1057 variable, you must first make sure the right binding is loaded; | |
1058 then you can access the value in (or through) `realvalue'. | |
45623
0e92d219e195
(current_column): Now returns float.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents:
45545
diff
changeset
|
1059 |
27779 | 1060 `buffer' and `frame' are the buffer and frame for which the loaded |
1061 binding was found. If those have changed, to make sure the right | |
1062 binding is loaded it is necessary to find which binding goes with | |
1063 the current buffer and selected frame, then load it. To load it, | |
1064 first unload the previous binding, then copy the value of the new | |
1065 binding into `realvalue' (or through it). Also update | |
1066 LOADED-BINDING to point to the newly loaded binding. | |
9891
f4a53f86853d
(enum Lisp_Misc_Type): Add new enumerations Lisp_Misc_Buffer_Local_Value and
Karl Heuer <kwzh@gnu.org>
parents:
9885
diff
changeset
|
1067 |
f4a53f86853d
(enum Lisp_Misc_Type): Add new enumerations Lisp_Misc_Buffer_Local_Value and
Karl Heuer <kwzh@gnu.org>
parents:
9885
diff
changeset
|
1068 Lisp_Misc_Buffer_Local_Value and Lisp_Misc_Some_Buffer_Local_Value |
27779 | 1069 both use this kind of structure. With the former, merely setting |
1070 the variable creates a local binding for the current buffer. With | |
1071 the latter, setting the variable does not do that; only | |
1072 make-local-variable does that. */ | |
1073 | |
9891
f4a53f86853d
(enum Lisp_Misc_Type): Add new enumerations Lisp_Misc_Buffer_Local_Value and
Karl Heuer <kwzh@gnu.org>
parents:
9885
diff
changeset
|
1074 struct Lisp_Buffer_Local_Value |
f4a53f86853d
(enum Lisp_Misc_Type): Add new enumerations Lisp_Misc_Buffer_Local_Value and
Karl Heuer <kwzh@gnu.org>
parents:
9885
diff
changeset
|
1075 { |
21147
81b02a3ea5e0
(struct Lisp_Buffer_Local_Value):
Richard M. Stallman <rms@gnu.org>
parents:
21038
diff
changeset
|
1076 int type : 16; /* = Lisp_Misc_Buffer_Local_Value |
81b02a3ea5e0
(struct Lisp_Buffer_Local_Value):
Richard M. Stallman <rms@gnu.org>
parents:
21038
diff
changeset
|
1077 or Lisp_Misc_Some_Buffer_Local_Value */ |
51657
7fb427e8d984
(struct interval, struct Lisp_Symbol, struct Lisp_Free)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51167
diff
changeset
|
1078 unsigned gcmarkbit : 1; |
7fb427e8d984
(struct interval, struct Lisp_Symbol, struct Lisp_Free)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51167
diff
changeset
|
1079 int spacer : 12; |
27779 | 1080 |
1081 /* 1 means this variable is allowed to have frame-local bindings, | |
1082 so check for them when looking for the proper binding. */ | |
21147
81b02a3ea5e0
(struct Lisp_Buffer_Local_Value):
Richard M. Stallman <rms@gnu.org>
parents:
21038
diff
changeset
|
1083 unsigned int check_frame : 1; |
27779 | 1084 /* 1 means that the binding now loaded was found |
1085 as a local binding for the buffer in the `buffer' slot. */ | |
21147
81b02a3ea5e0
(struct Lisp_Buffer_Local_Value):
Richard M. Stallman <rms@gnu.org>
parents:
21038
diff
changeset
|
1086 unsigned int found_for_buffer : 1; |
27779 | 1087 /* 1 means that the binding now loaded was found |
1088 as a local binding for the frame in the `frame' slot. */ | |
21147
81b02a3ea5e0
(struct Lisp_Buffer_Local_Value):
Richard M. Stallman <rms@gnu.org>
parents:
21038
diff
changeset
|
1089 unsigned int found_for_frame : 1; |
81b02a3ea5e0
(struct Lisp_Buffer_Local_Value):
Richard M. Stallman <rms@gnu.org>
parents:
21038
diff
changeset
|
1090 Lisp_Object realvalue; |
27779 | 1091 /* The buffer and frame for which the loaded binding was found. */ |
21147
81b02a3ea5e0
(struct Lisp_Buffer_Local_Value):
Richard M. Stallman <rms@gnu.org>
parents:
21038
diff
changeset
|
1092 Lisp_Object buffer, frame; |
27779 | 1093 |
1094 /* A cons cell, (LOADED-BINDING . DEFAULT-VALUE). | |
1095 | |
1096 LOADED-BINDING is the binding now loaded. It is a cons cell | |
1097 whose cdr is the binding's value. The cons cell may be an | |
1098 element of a buffer's local-variable alist, or an element of a | |
1099 frame's parameter alist, or it may be this cons cell. | |
1100 | |
1101 DEFAULT-VALUE is the variable's default value, seen when the | |
1102 current buffer and selected frame do not have their own | |
1103 bindings for the variable. When the default binding is loaded, | |
1104 LOADED-BINDING is actually this very cons cell; thus, its car | |
1105 points to itself. */ | |
21147
81b02a3ea5e0
(struct Lisp_Buffer_Local_Value):
Richard M. Stallman <rms@gnu.org>
parents:
21038
diff
changeset
|
1106 Lisp_Object cdr; |
9891
f4a53f86853d
(enum Lisp_Misc_Type): Add new enumerations Lisp_Misc_Buffer_Local_Value and
Karl Heuer <kwzh@gnu.org>
parents:
9885
diff
changeset
|
1107 }; |
f4a53f86853d
(enum Lisp_Misc_Type): Add new enumerations Lisp_Misc_Buffer_Local_Value and
Karl Heuer <kwzh@gnu.org>
parents:
9885
diff
changeset
|
1108 |
51858
bf6232373c39
(VALBITS): Define in terms of GCTYPEBITS.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51833
diff
changeset
|
1109 /* START and END are markers in the overlay's buffer, and |
9924
594e838f4567
(enum Lisp_Misc_Type): Add new enumeration Lisp_Misc_Overlay.
Karl Heuer <kwzh@gnu.org>
parents:
9904
diff
changeset
|
1110 PLIST is the overlay's property list. */ |
594e838f4567
(enum Lisp_Misc_Type): Add new enumeration Lisp_Misc_Overlay.
Karl Heuer <kwzh@gnu.org>
parents:
9904
diff
changeset
|
1111 struct Lisp_Overlay |
594e838f4567
(enum Lisp_Misc_Type): Add new enumeration Lisp_Misc_Overlay.
Karl Heuer <kwzh@gnu.org>
parents:
9904
diff
changeset
|
1112 { |
10387
40988c371fca
(struct Lisp_Free, struct Lisp_Marker, etc.):
Richard M. Stallman <rms@gnu.org>
parents:
10339
diff
changeset
|
1113 int type : 16; /* = Lisp_Misc_Overlay */ |
51657
7fb427e8d984
(struct interval, struct Lisp_Symbol, struct Lisp_Free)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51167
diff
changeset
|
1114 unsigned gcmarkbit : 1; |
7fb427e8d984
(struct interval, struct Lisp_Symbol, struct Lisp_Free)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51167
diff
changeset
|
1115 int spacer : 15; |
51833
a52679a2aae5
(struct Lisp_Overlay): New field `next'.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51772
diff
changeset
|
1116 struct Lisp_Overlay *next; |
9924
594e838f4567
(enum Lisp_Misc_Type): Add new enumeration Lisp_Misc_Overlay.
Karl Heuer <kwzh@gnu.org>
parents:
9904
diff
changeset
|
1117 Lisp_Object start, end, plist; |
594e838f4567
(enum Lisp_Misc_Type): Add new enumeration Lisp_Misc_Overlay.
Karl Heuer <kwzh@gnu.org>
parents:
9904
diff
changeset
|
1118 }; |
10387
40988c371fca
(struct Lisp_Free, struct Lisp_Marker, etc.):
Richard M. Stallman <rms@gnu.org>
parents:
10339
diff
changeset
|
1119 |
10580
09fcb080e537
(enum Lisp_Misc_Type): New enumeration Lisp_Misc_Display_Local.
Karl Heuer <kwzh@gnu.org>
parents:
10578
diff
changeset
|
1120 /* Like Lisp_Objfwd except that value lives in a slot in the |
11012
31d88266ed12
(struct KBOARD, MULTI_KBOARD, current_kboard, all_kboards,
Karl Heuer <kwzh@gnu.org>
parents:
10944
diff
changeset
|
1121 current kboard. */ |
31d88266ed12
(struct KBOARD, MULTI_KBOARD, current_kboard, all_kboards,
Karl Heuer <kwzh@gnu.org>
parents:
10944
diff
changeset
|
1122 struct Lisp_Kboard_Objfwd |
10580
09fcb080e537
(enum Lisp_Misc_Type): New enumeration Lisp_Misc_Display_Local.
Karl Heuer <kwzh@gnu.org>
parents:
10578
diff
changeset
|
1123 { |
11012
31d88266ed12
(struct KBOARD, MULTI_KBOARD, current_kboard, all_kboards,
Karl Heuer <kwzh@gnu.org>
parents:
10944
diff
changeset
|
1124 int type : 16; /* = Lisp_Misc_Kboard_Objfwd */ |
51657
7fb427e8d984
(struct interval, struct Lisp_Symbol, struct Lisp_Free)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51167
diff
changeset
|
1125 unsigned gcmarkbit : 1; |
7fb427e8d984
(struct interval, struct Lisp_Symbol, struct Lisp_Free)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51167
diff
changeset
|
1126 int spacer : 15; |
10580
09fcb080e537
(enum Lisp_Misc_Type): New enumeration Lisp_Misc_Display_Local.
Karl Heuer <kwzh@gnu.org>
parents:
10578
diff
changeset
|
1127 int offset; |
09fcb080e537
(enum Lisp_Misc_Type): New enumeration Lisp_Misc_Display_Local.
Karl Heuer <kwzh@gnu.org>
parents:
10578
diff
changeset
|
1128 }; |
09fcb080e537
(enum Lisp_Misc_Type): New enumeration Lisp_Misc_Display_Local.
Karl Heuer <kwzh@gnu.org>
parents:
10578
diff
changeset
|
1129 |
49056
88f14a14e005
New misc type Lisp_Save_Value.
Richard M. Stallman <rms@gnu.org>
parents:
48540
diff
changeset
|
1130 /* Hold a C pointer for later use. |
88f14a14e005
New misc type Lisp_Save_Value.
Richard M. Stallman <rms@gnu.org>
parents:
48540
diff
changeset
|
1131 This type of object is used in the arg to record_unwind_protect. */ |
88f14a14e005
New misc type Lisp_Save_Value.
Richard M. Stallman <rms@gnu.org>
parents:
48540
diff
changeset
|
1132 struct Lisp_Save_Value |
88f14a14e005
New misc type Lisp_Save_Value.
Richard M. Stallman <rms@gnu.org>
parents:
48540
diff
changeset
|
1133 { |
88f14a14e005
New misc type Lisp_Save_Value.
Richard M. Stallman <rms@gnu.org>
parents:
48540
diff
changeset
|
1134 int type : 16; /* = Lisp_Misc_Save_Value */ |
51657
7fb427e8d984
(struct interval, struct Lisp_Symbol, struct Lisp_Free)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51167
diff
changeset
|
1135 unsigned gcmarkbit : 1; |
7fb427e8d984
(struct interval, struct Lisp_Symbol, struct Lisp_Free)
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51167
diff
changeset
|
1136 int spacer : 15; |
49056
88f14a14e005
New misc type Lisp_Save_Value.
Richard M. Stallman <rms@gnu.org>
parents:
48540
diff
changeset
|
1137 void *pointer; |
88f14a14e005
New misc type Lisp_Save_Value.
Richard M. Stallman <rms@gnu.org>
parents:
48540
diff
changeset
|
1138 int integer; |
88f14a14e005
New misc type Lisp_Save_Value.
Richard M. Stallman <rms@gnu.org>
parents:
48540
diff
changeset
|
1139 }; |
88f14a14e005
New misc type Lisp_Save_Value.
Richard M. Stallman <rms@gnu.org>
parents:
48540
diff
changeset
|
1140 |
10387
40988c371fca
(struct Lisp_Free, struct Lisp_Marker, etc.):
Richard M. Stallman <rms@gnu.org>
parents:
10339
diff
changeset
|
1141 |
53088
63a8b584e971
(VALMASK): Only define for non-union type.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
53001
diff
changeset
|
1142 /* A miscellaneous object, when it's on the free list. */ |
63a8b584e971
(VALMASK): Only define for non-union type.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
53001
diff
changeset
|
1143 struct Lisp_Free |
63a8b584e971
(VALMASK): Only define for non-union type.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
53001
diff
changeset
|
1144 { |
63a8b584e971
(VALMASK): Only define for non-union type.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
53001
diff
changeset
|
1145 int type : 16; /* = Lisp_Misc_Free */ |
63a8b584e971
(VALMASK): Only define for non-union type.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
53001
diff
changeset
|
1146 unsigned gcmarkbit : 1; |
63a8b584e971
(VALMASK): Only define for non-union type.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
53001
diff
changeset
|
1147 int spacer : 15; |
63a8b584e971
(VALMASK): Only define for non-union type.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
53001
diff
changeset
|
1148 union Lisp_Misc *chain; |
63a8b584e971
(VALMASK): Only define for non-union type.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
53001
diff
changeset
|
1149 }; |
63a8b584e971
(VALMASK): Only define for non-union type.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
53001
diff
changeset
|
1150 |
11335
78eda0ee4cba
(XMISCTYPE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
11204
diff
changeset
|
1151 /* To get the type field of a union Lisp_Misc, use XMISCTYPE. |
78eda0ee4cba
(XMISCTYPE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
11204
diff
changeset
|
1152 It uses one of these struct subtypes to get the type field. */ |
78eda0ee4cba
(XMISCTYPE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
11204
diff
changeset
|
1153 |
9435
3a157cdf395c
(Lisp_Misc): new type code, replacing Lisp_Marker (and soon to replace other
Karl Heuer <kwzh@gnu.org>
parents:
9392
diff
changeset
|
1154 union Lisp_Misc |
3a157cdf395c
(Lisp_Misc): new type code, replacing Lisp_Marker (and soon to replace other
Karl Heuer <kwzh@gnu.org>
parents:
9392
diff
changeset
|
1155 { |
3a157cdf395c
(Lisp_Misc): new type code, replacing Lisp_Marker (and soon to replace other
Karl Heuer <kwzh@gnu.org>
parents:
9392
diff
changeset
|
1156 struct Lisp_Free u_free; |
3a157cdf395c
(Lisp_Misc): new type code, replacing Lisp_Marker (and soon to replace other
Karl Heuer <kwzh@gnu.org>
parents:
9392
diff
changeset
|
1157 struct Lisp_Marker u_marker; |
9462
3601bf7327b2
(enum Lisp_Misc_Type): Add new enumerations Lisp_Misc_Intfwd,
Karl Heuer <kwzh@gnu.org>
parents:
9435
diff
changeset
|
1158 struct Lisp_Intfwd u_intfwd; |
3601bf7327b2
(enum Lisp_Misc_Type): Add new enumerations Lisp_Misc_Intfwd,
Karl Heuer <kwzh@gnu.org>
parents:
9435
diff
changeset
|
1159 struct Lisp_Boolfwd u_boolfwd; |
3601bf7327b2
(enum Lisp_Misc_Type): Add new enumerations Lisp_Misc_Intfwd,
Karl Heuer <kwzh@gnu.org>
parents:
9435
diff
changeset
|
1160 struct Lisp_Objfwd u_objfwd; |
3601bf7327b2
(enum Lisp_Misc_Type): Add new enumerations Lisp_Misc_Intfwd,
Karl Heuer <kwzh@gnu.org>
parents:
9435
diff
changeset
|
1161 struct Lisp_Buffer_Objfwd u_buffer_objfwd; |
9891
f4a53f86853d
(enum Lisp_Misc_Type): Add new enumerations Lisp_Misc_Buffer_Local_Value and
Karl Heuer <kwzh@gnu.org>
parents:
9885
diff
changeset
|
1162 struct Lisp_Buffer_Local_Value u_buffer_local_value; |
9924
594e838f4567
(enum Lisp_Misc_Type): Add new enumeration Lisp_Misc_Overlay.
Karl Heuer <kwzh@gnu.org>
parents:
9904
diff
changeset
|
1163 struct Lisp_Overlay u_overlay; |
11012
31d88266ed12
(struct KBOARD, MULTI_KBOARD, current_kboard, all_kboards,
Karl Heuer <kwzh@gnu.org>
parents:
10944
diff
changeset
|
1164 struct Lisp_Kboard_Objfwd u_kboard_objfwd; |
49056
88f14a14e005
New misc type Lisp_Save_Value.
Richard M. Stallman <rms@gnu.org>
parents:
48540
diff
changeset
|
1165 struct Lisp_Save_Value u_save_value; |
9435
3a157cdf395c
(Lisp_Misc): new type code, replacing Lisp_Marker (and soon to replace other
Karl Heuer <kwzh@gnu.org>
parents:
9392
diff
changeset
|
1166 }; |
10292
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
1167 |
27727
9400865ec7cf
Remove `LISP_FLOAT_TYPE' and `standalone'.
Gerd Moellmann <gerd@gnu.org>
parents:
27427
diff
changeset
|
1168 /* Lisp floating point type */ |
302 | 1169 struct Lisp_Float |
1170 { | |
25421
65a7e9c02d4f
(struct Lisp_Cons, XCAR, XCDR, struct Lisp_Float): Change names of structure
Ken Raeburn <raeburn@raeburn.org>
parents:
25392
diff
changeset
|
1171 #ifdef HIDE_LISP_IMPLEMENTATION |
65a7e9c02d4f
(struct Lisp_Cons, XCAR, XCDR, struct Lisp_Float): Change names of structure
Ken Raeburn <raeburn@raeburn.org>
parents:
25392
diff
changeset
|
1172 double data_; |
65a7e9c02d4f
(struct Lisp_Cons, XCAR, XCDR, struct Lisp_Float): Change names of structure
Ken Raeburn <raeburn@raeburn.org>
parents:
25392
diff
changeset
|
1173 #else |
17404
73012b195cf3
(DOWNCASE): Return int, not Lisp_Object.
Karl Heuer <kwzh@gnu.org>
parents:
17326
diff
changeset
|
1174 double data; |
25421
65a7e9c02d4f
(struct Lisp_Cons, XCAR, XCDR, struct Lisp_Float): Change names of structure
Ken Raeburn <raeburn@raeburn.org>
parents:
25392
diff
changeset
|
1175 #endif |
302 | 1176 }; |
25421
65a7e9c02d4f
(struct Lisp_Cons, XCAR, XCDR, struct Lisp_Float): Change names of structure
Ken Raeburn <raeburn@raeburn.org>
parents:
25392
diff
changeset
|
1177 |
65a7e9c02d4f
(struct Lisp_Cons, XCAR, XCDR, struct Lisp_Float): Change names of structure
Ken Raeburn <raeburn@raeburn.org>
parents:
25392
diff
changeset
|
1178 #ifdef HIDE_LISP_IMPLEMENTATION |
65a7e9c02d4f
(struct Lisp_Cons, XCAR, XCDR, struct Lisp_Float): Change names of structure
Ken Raeburn <raeburn@raeburn.org>
parents:
25392
diff
changeset
|
1179 #define XFLOAT_DATA(f) (XFLOAT (f)->data_) |
65a7e9c02d4f
(struct Lisp_Cons, XCAR, XCDR, struct Lisp_Float): Change names of structure
Ken Raeburn <raeburn@raeburn.org>
parents:
25392
diff
changeset
|
1180 #else |
65a7e9c02d4f
(struct Lisp_Cons, XCAR, XCDR, struct Lisp_Float): Change names of structure
Ken Raeburn <raeburn@raeburn.org>
parents:
25392
diff
changeset
|
1181 #define XFLOAT_DATA(f) (XFLOAT (f)->data) |
65a7e9c02d4f
(struct Lisp_Cons, XCAR, XCDR, struct Lisp_Float): Change names of structure
Ken Raeburn <raeburn@raeburn.org>
parents:
25392
diff
changeset
|
1182 #endif |
302 | 1183 |
1184 /* A character, declared with the following typedef, is a member | |
10316
272f15eddaca
(enum Lisp_Type): Delete Lisp_Buffer.
Richard M. Stallman <rms@gnu.org>
parents:
10292
diff
changeset
|
1185 of some character set associated with the current buffer. */ |
3324
b0e1cf2177fc
(UCHAR): Don't define if _UCHAR_T.
Richard M. Stallman <rms@gnu.org>
parents:
2979
diff
changeset
|
1186 #ifndef _UCHAR_T /* Protect against something in ctab.h on AIX. */ |
b0e1cf2177fc
(UCHAR): Don't define if _UCHAR_T.
Richard M. Stallman <rms@gnu.org>
parents:
2979
diff
changeset
|
1187 #define _UCHAR_T |
302 | 1188 typedef unsigned char UCHAR; |
3324
b0e1cf2177fc
(UCHAR): Don't define if _UCHAR_T.
Richard M. Stallman <rms@gnu.org>
parents:
2979
diff
changeset
|
1189 #endif |
302 | 1190 |
1191 /* Meanings of slots in a Lisp_Compiled: */ | |
1192 | |
1193 #define COMPILED_ARGLIST 0 | |
1194 #define COMPILED_BYTECODE 1 | |
1195 #define COMPILED_CONSTANTS 2 | |
1196 #define COMPILED_STACK_DEPTH 3 | |
1197 #define COMPILED_DOC_STRING 4 | |
1198 #define COMPILED_INTERACTIVE 5 | |
2014
637d9ebe3f50
(CHAR_META, CHAR_SHIFT, CHAR_CTL): New macros.
Richard M. Stallman <rms@gnu.org>
parents:
1990
diff
changeset
|
1199 |
2662
5b92bdfb7fbb
* lisp.h (CHAR_ALT, CHAR_SUPER, CHAR_HYPER, CHAR_SHIFT, CHAR_CTL,
Jim Blandy <jimb@redhat.com>
parents:
2653
diff
changeset
|
1200 /* Flag bits in a character. These also get used in termhooks.h. |
5b92bdfb7fbb
* lisp.h (CHAR_ALT, CHAR_SUPER, CHAR_HYPER, CHAR_SHIFT, CHAR_CTL,
Jim Blandy <jimb@redhat.com>
parents:
2653
diff
changeset
|
1201 Richard Stallman <rms@gnu.ai.mit.edu> thinks that MULE |
10292
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
1202 (MUlti-Lingual Emacs) might need 22 bits for the character value |
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
1203 itself, so we probably shouldn't use any bits lower than 0x0400000. */ |
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
1204 #define CHAR_ALT (0x0400000) |
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
1205 #define CHAR_SUPER (0x0800000) |
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
1206 #define CHAR_HYPER (0x1000000) |
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
1207 #define CHAR_SHIFT (0x2000000) |
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
1208 #define CHAR_CTL (0x4000000) |
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
1209 #define CHAR_META (0x8000000) |
2728
93c9529b2b69
* config.h.in: Remove mention of GLYPH datatype; that shouldn't be
Jim Blandy <jimb@redhat.com>
parents:
2662
diff
changeset
|
1210 |
25252
fc1b2b29e66d
(CHAR_MODIFIER_MASK): New macro.
Kenichi Handa <handa@m17n.org>
parents:
25017
diff
changeset
|
1211 #define CHAR_MODIFIER_MASK \ |
fc1b2b29e66d
(CHAR_MODIFIER_MASK): New macro.
Kenichi Handa <handa@m17n.org>
parents:
25017
diff
changeset
|
1212 (CHAR_ALT | CHAR_SUPER | CHAR_HYPER | CHAR_SHIFT | CHAR_CTL | CHAR_META) |
fc1b2b29e66d
(CHAR_MODIFIER_MASK): New macro.
Kenichi Handa <handa@m17n.org>
parents:
25017
diff
changeset
|
1213 |
fc1b2b29e66d
(CHAR_MODIFIER_MASK): New macro.
Kenichi Handa <handa@m17n.org>
parents:
25017
diff
changeset
|
1214 |
17037
af637c0168ad
(CHARACTERBITS, GLYPH_MASK_REV_DIR): New macros.
Karl Heuer <kwzh@gnu.org>
parents:
16913
diff
changeset
|
1215 /* Actually, the current Emacs uses 19 bits for the character value |
af637c0168ad
(CHARACTERBITS, GLYPH_MASK_REV_DIR): New macros.
Karl Heuer <kwzh@gnu.org>
parents:
16913
diff
changeset
|
1216 itself. */ |
af637c0168ad
(CHARACTERBITS, GLYPH_MASK_REV_DIR): New macros.
Karl Heuer <kwzh@gnu.org>
parents:
16913
diff
changeset
|
1217 #define CHARACTERBITS 19 |
af637c0168ad
(CHARACTERBITS, GLYPH_MASK_REV_DIR): New macros.
Karl Heuer <kwzh@gnu.org>
parents:
16913
diff
changeset
|
1218 |
26479
cf75e5b634ec
(KEY_DESCRIPTION_SIZE): New macro.
Kenichi Handa <handa@m17n.org>
parents:
26404
diff
changeset
|
1219 /* The maximum byte size consumed by push_key_description. |
cf75e5b634ec
(KEY_DESCRIPTION_SIZE): New macro.
Kenichi Handa <handa@m17n.org>
parents:
26404
diff
changeset
|
1220 All callers should assure that at least this size of memory is |
cf75e5b634ec
(KEY_DESCRIPTION_SIZE): New macro.
Kenichi Handa <handa@m17n.org>
parents:
26404
diff
changeset
|
1221 allocated at the place pointed by the second argument. |
cf75e5b634ec
(KEY_DESCRIPTION_SIZE): New macro.
Kenichi Handa <handa@m17n.org>
parents:
26404
diff
changeset
|
1222 |
cf75e5b634ec
(KEY_DESCRIPTION_SIZE): New macro.
Kenichi Handa <handa@m17n.org>
parents:
26404
diff
changeset
|
1223 Thers are 6 modifiers, each consumes 2 chars. |
cf75e5b634ec
(KEY_DESCRIPTION_SIZE): New macro.
Kenichi Handa <handa@m17n.org>
parents:
26404
diff
changeset
|
1224 The octal form of a character code consumes |
cf75e5b634ec
(KEY_DESCRIPTION_SIZE): New macro.
Kenichi Handa <handa@m17n.org>
parents:
26404
diff
changeset
|
1225 (1 + CHARACTERBITS / 3 + 1) chars (including backslash at the head). |
cf75e5b634ec
(KEY_DESCRIPTION_SIZE): New macro.
Kenichi Handa <handa@m17n.org>
parents:
26404
diff
changeset
|
1226 We need one more byte for string terminator `\0'. */ |
cf75e5b634ec
(KEY_DESCRIPTION_SIZE): New macro.
Kenichi Handa <handa@m17n.org>
parents:
26404
diff
changeset
|
1227 #define KEY_DESCRIPTION_SIZE ((2 * 6) + 1 + (CHARACTERBITS / 3) + 1 + 1) |
cf75e5b634ec
(KEY_DESCRIPTION_SIZE): New macro.
Kenichi Handa <handa@m17n.org>
parents:
26404
diff
changeset
|
1228 |
5642
665c0dc2b4bd
(VOID_TO_LISP, CVOID_TO_LISP, LISP_TO_VOID, LISP_TO_CVOID): New macros.
Richard M. Stallman <rms@gnu.org>
parents:
5241
diff
changeset
|
1229 #ifdef USE_X_TOOLKIT |
665c0dc2b4bd
(VOID_TO_LISP, CVOID_TO_LISP, LISP_TO_VOID, LISP_TO_CVOID): New macros.
Richard M. Stallman <rms@gnu.org>
parents:
5241
diff
changeset
|
1230 #ifdef NO_UNION_TYPE |
665c0dc2b4bd
(VOID_TO_LISP, CVOID_TO_LISP, LISP_TO_VOID, LISP_TO_CVOID): New macros.
Richard M. Stallman <rms@gnu.org>
parents:
5241
diff
changeset
|
1231 /* Use this for turning a (void *) into a Lisp_Object, as when the |
665c0dc2b4bd
(VOID_TO_LISP, CVOID_TO_LISP, LISP_TO_VOID, LISP_TO_CVOID): New macros.
Richard M. Stallman <rms@gnu.org>
parents:
5241
diff
changeset
|
1232 Lisp_Object is passed into a toolkit callback function. */ |
665c0dc2b4bd
(VOID_TO_LISP, CVOID_TO_LISP, LISP_TO_VOID, LISP_TO_CVOID): New macros.
Richard M. Stallman <rms@gnu.org>
parents:
5241
diff
changeset
|
1233 #define VOID_TO_LISP(larg,varg) \ |
665c0dc2b4bd
(VOID_TO_LISP, CVOID_TO_LISP, LISP_TO_VOID, LISP_TO_CVOID): New macros.
Richard M. Stallman <rms@gnu.org>
parents:
5241
diff
changeset
|
1234 do { ((larg) = ((Lisp_Object) (varg))); } while (0) |
665c0dc2b4bd
(VOID_TO_LISP, CVOID_TO_LISP, LISP_TO_VOID, LISP_TO_CVOID): New macros.
Richard M. Stallman <rms@gnu.org>
parents:
5241
diff
changeset
|
1235 #define CVOID_TO_LISP VOID_TO_LISP |
665c0dc2b4bd
(VOID_TO_LISP, CVOID_TO_LISP, LISP_TO_VOID, LISP_TO_CVOID): New macros.
Richard M. Stallman <rms@gnu.org>
parents:
5241
diff
changeset
|
1236 |
665c0dc2b4bd
(VOID_TO_LISP, CVOID_TO_LISP, LISP_TO_VOID, LISP_TO_CVOID): New macros.
Richard M. Stallman <rms@gnu.org>
parents:
5241
diff
changeset
|
1237 /* Use this for turning a Lisp_Object into a (void *), as when the |
665c0dc2b4bd
(VOID_TO_LISP, CVOID_TO_LISP, LISP_TO_VOID, LISP_TO_CVOID): New macros.
Richard M. Stallman <rms@gnu.org>
parents:
5241
diff
changeset
|
1238 Lisp_Object is passed into a toolkit callback function. */ |
665c0dc2b4bd
(VOID_TO_LISP, CVOID_TO_LISP, LISP_TO_VOID, LISP_TO_CVOID): New macros.
Richard M. Stallman <rms@gnu.org>
parents:
5241
diff
changeset
|
1239 #define LISP_TO_VOID(larg) ((void *) (larg)) |
665c0dc2b4bd
(VOID_TO_LISP, CVOID_TO_LISP, LISP_TO_VOID, LISP_TO_CVOID): New macros.
Richard M. Stallman <rms@gnu.org>
parents:
5241
diff
changeset
|
1240 #define LISP_TO_CVOID(varg) ((const void *) (larg)) |
665c0dc2b4bd
(VOID_TO_LISP, CVOID_TO_LISP, LISP_TO_VOID, LISP_TO_CVOID): New macros.
Richard M. Stallman <rms@gnu.org>
parents:
5241
diff
changeset
|
1241 |
665c0dc2b4bd
(VOID_TO_LISP, CVOID_TO_LISP, LISP_TO_VOID, LISP_TO_CVOID): New macros.
Richard M. Stallman <rms@gnu.org>
parents:
5241
diff
changeset
|
1242 #else /* not NO_UNION_TYPE */ |
665c0dc2b4bd
(VOID_TO_LISP, CVOID_TO_LISP, LISP_TO_VOID, LISP_TO_CVOID): New macros.
Richard M. Stallman <rms@gnu.org>
parents:
5241
diff
changeset
|
1243 /* Use this for turning a (void *) into a Lisp_Object, as when the |
665c0dc2b4bd
(VOID_TO_LISP, CVOID_TO_LISP, LISP_TO_VOID, LISP_TO_CVOID): New macros.
Richard M. Stallman <rms@gnu.org>
parents:
5241
diff
changeset
|
1244 Lisp_Object is passed into a toolkit callback function. */ |
665c0dc2b4bd
(VOID_TO_LISP, CVOID_TO_LISP, LISP_TO_VOID, LISP_TO_CVOID): New macros.
Richard M. Stallman <rms@gnu.org>
parents:
5241
diff
changeset
|
1245 #define VOID_TO_LISP(larg,varg) \ |
665c0dc2b4bd
(VOID_TO_LISP, CVOID_TO_LISP, LISP_TO_VOID, LISP_TO_CVOID): New macros.
Richard M. Stallman <rms@gnu.org>
parents:
5241
diff
changeset
|
1246 do { ((larg).v = (void *) (varg)); } while (0) |
665c0dc2b4bd
(VOID_TO_LISP, CVOID_TO_LISP, LISP_TO_VOID, LISP_TO_CVOID): New macros.
Richard M. Stallman <rms@gnu.org>
parents:
5241
diff
changeset
|
1247 #define CVOID_TO_LISP(larg,varg) \ |
665c0dc2b4bd
(VOID_TO_LISP, CVOID_TO_LISP, LISP_TO_VOID, LISP_TO_CVOID): New macros.
Richard M. Stallman <rms@gnu.org>
parents:
5241
diff
changeset
|
1248 do { ((larg).cv = (const void *) (varg)); } while (0) |
665c0dc2b4bd
(VOID_TO_LISP, CVOID_TO_LISP, LISP_TO_VOID, LISP_TO_CVOID): New macros.
Richard M. Stallman <rms@gnu.org>
parents:
5241
diff
changeset
|
1249 |
665c0dc2b4bd
(VOID_TO_LISP, CVOID_TO_LISP, LISP_TO_VOID, LISP_TO_CVOID): New macros.
Richard M. Stallman <rms@gnu.org>
parents:
5241
diff
changeset
|
1250 /* Use this for turning a Lisp_Object into a (void *), as when the |
665c0dc2b4bd
(VOID_TO_LISP, CVOID_TO_LISP, LISP_TO_VOID, LISP_TO_CVOID): New macros.
Richard M. Stallman <rms@gnu.org>
parents:
5241
diff
changeset
|
1251 Lisp_Object is passed into a toolkit callback function. */ |
665c0dc2b4bd
(VOID_TO_LISP, CVOID_TO_LISP, LISP_TO_VOID, LISP_TO_CVOID): New macros.
Richard M. Stallman <rms@gnu.org>
parents:
5241
diff
changeset
|
1252 #define LISP_TO_VOID(larg) ((larg).v) |
665c0dc2b4bd
(VOID_TO_LISP, CVOID_TO_LISP, LISP_TO_VOID, LISP_TO_CVOID): New macros.
Richard M. Stallman <rms@gnu.org>
parents:
5241
diff
changeset
|
1253 #define LISP_TO_CVOID(larg) ((larg).cv) |
665c0dc2b4bd
(VOID_TO_LISP, CVOID_TO_LISP, LISP_TO_VOID, LISP_TO_CVOID): New macros.
Richard M. Stallman <rms@gnu.org>
parents:
5241
diff
changeset
|
1254 #endif /* not NO_UNION_TYPE */ |
665c0dc2b4bd
(VOID_TO_LISP, CVOID_TO_LISP, LISP_TO_VOID, LISP_TO_CVOID): New macros.
Richard M. Stallman <rms@gnu.org>
parents:
5241
diff
changeset
|
1255 #endif /* USE_X_TOOLKIT */ |
665c0dc2b4bd
(VOID_TO_LISP, CVOID_TO_LISP, LISP_TO_VOID, LISP_TO_CVOID): New macros.
Richard M. Stallman <rms@gnu.org>
parents:
5241
diff
changeset
|
1256 |
2728
93c9529b2b69
* config.h.in: Remove mention of GLYPH datatype; that shouldn't be
Jim Blandy <jimb@redhat.com>
parents:
2662
diff
changeset
|
1257 |
93c9529b2b69
* config.h.in: Remove mention of GLYPH datatype; that shouldn't be
Jim Blandy <jimb@redhat.com>
parents:
2662
diff
changeset
|
1258 /* The glyph datatype, used to represent characters on the display. */ |
93c9529b2b69
* config.h.in: Remove mention of GLYPH datatype; that shouldn't be
Jim Blandy <jimb@redhat.com>
parents:
2662
diff
changeset
|
1259 |
26994
be1938426575
(GLYPH): Defined as `int', not `unsigned int'. Now the
Kenichi Handa <handa@m17n.org>
parents:
26865
diff
changeset
|
1260 /* Glyph code to use as an index to the glyph table. If it is out of |
be1938426575
(GLYPH): Defined as `int', not `unsigned int'. Now the
Kenichi Handa <handa@m17n.org>
parents:
26865
diff
changeset
|
1261 range for the glyph table, or the corresonding element in the table |
be1938426575
(GLYPH): Defined as `int', not `unsigned int'. Now the
Kenichi Handa <handa@m17n.org>
parents:
26865
diff
changeset
|
1262 is nil, the low 8 bits are the single byte character code, and the |
be1938426575
(GLYPH): Defined as `int', not `unsigned int'. Now the
Kenichi Handa <handa@m17n.org>
parents:
26865
diff
changeset
|
1263 bits above are the numeric face ID. If FID is the face ID of a |
be1938426575
(GLYPH): Defined as `int', not `unsigned int'. Now the
Kenichi Handa <handa@m17n.org>
parents:
26865
diff
changeset
|
1264 glyph on a frame F, then F->display.x->faces[FID] contains the |
be1938426575
(GLYPH): Defined as `int', not `unsigned int'. Now the
Kenichi Handa <handa@m17n.org>
parents:
26865
diff
changeset
|
1265 description of that face. This is an int instead of a short, so we |
be1938426575
(GLYPH): Defined as `int', not `unsigned int'. Now the
Kenichi Handa <handa@m17n.org>
parents:
26865
diff
changeset
|
1266 can support a good bunch of face ID's (2^(31 - 8)); given that we |
17037
af637c0168ad
(CHARACTERBITS, GLYPH_MASK_REV_DIR): New macros.
Karl Heuer <kwzh@gnu.org>
parents:
16913
diff
changeset
|
1267 have no mechanism for tossing unused frame face ID's yet, we'll |
26994
be1938426575
(GLYPH): Defined as `int', not `unsigned int'. Now the
Kenichi Handa <handa@m17n.org>
parents:
26865
diff
changeset
|
1268 probably run out of 255 pretty quickly. |
be1938426575
(GLYPH): Defined as `int', not `unsigned int'. Now the
Kenichi Handa <handa@m17n.org>
parents:
26865
diff
changeset
|
1269 This is always -1 for a multibyte character. */ |
be1938426575
(GLYPH): Defined as `int', not `unsigned int'. Now the
Kenichi Handa <handa@m17n.org>
parents:
26865
diff
changeset
|
1270 #define GLYPH int |
be1938426575
(GLYPH): Defined as `int', not `unsigned int'. Now the
Kenichi Handa <handa@m17n.org>
parents:
26865
diff
changeset
|
1271 |
17037
af637c0168ad
(CHARACTERBITS, GLYPH_MASK_REV_DIR): New macros.
Karl Heuer <kwzh@gnu.org>
parents:
16913
diff
changeset
|
1272 /* Mask bits for face. */ |
30447
e60d22cf57b4
(GLYPH_MASK_CHAR, GLYPH_MASK_FACE): Use 19 bits
Gerd Moellmann <gerd@gnu.org>
parents:
30440
diff
changeset
|
1273 #define GLYPH_MASK_FACE 0x7FF80000 |
26994
be1938426575
(GLYPH): Defined as `int', not `unsigned int'. Now the
Kenichi Handa <handa@m17n.org>
parents:
26865
diff
changeset
|
1274 /* Mask bits for character code. */ |
30447
e60d22cf57b4
(GLYPH_MASK_CHAR, GLYPH_MASK_FACE): Use 19 bits
Gerd Moellmann <gerd@gnu.org>
parents:
30440
diff
changeset
|
1275 #define GLYPH_MASK_CHAR 0x0007FFFF /* The lowest 19 bits */ |
17037
af637c0168ad
(CHARACTERBITS, GLYPH_MASK_REV_DIR): New macros.
Karl Heuer <kwzh@gnu.org>
parents:
16913
diff
changeset
|
1276 |
6416
6f57787905d9
(MAKE_GLYPH, GLYPH_CHAR, GLYPH_FACE): Handle termcap frames as well as X.
Karl Heuer <kwzh@gnu.org>
parents:
6277
diff
changeset
|
1277 /* The FAST macros assume that we already know we're in an X window. */ |
6f57787905d9
(MAKE_GLYPH, GLYPH_CHAR, GLYPH_FACE): Handle termcap frames as well as X.
Karl Heuer <kwzh@gnu.org>
parents:
6277
diff
changeset
|
1278 |
26994
be1938426575
(GLYPH): Defined as `int', not `unsigned int'. Now the
Kenichi Handa <handa@m17n.org>
parents:
26865
diff
changeset
|
1279 /* Set a character code and a face ID in a glyph G. */ |
30447
e60d22cf57b4
(GLYPH_MASK_CHAR, GLYPH_MASK_FACE): Use 19 bits
Gerd Moellmann <gerd@gnu.org>
parents:
30440
diff
changeset
|
1280 #define FAST_MAKE_GLYPH(char, face) ((char) | ((face) << CHARACTERBITS)) |
2728
93c9529b2b69
* config.h.in: Remove mention of GLYPH datatype; that shouldn't be
Jim Blandy <jimb@redhat.com>
parents:
2662
diff
changeset
|
1281 |
93c9529b2b69
* config.h.in: Remove mention of GLYPH datatype; that shouldn't be
Jim Blandy <jimb@redhat.com>
parents:
2662
diff
changeset
|
1282 /* Return a glyph's character code. */ |
17037
af637c0168ad
(CHARACTERBITS, GLYPH_MASK_REV_DIR): New macros.
Karl Heuer <kwzh@gnu.org>
parents:
16913
diff
changeset
|
1283 #define FAST_GLYPH_CHAR(glyph) ((glyph) & GLYPH_MASK_CHAR) |
2728
93c9529b2b69
* config.h.in: Remove mention of GLYPH datatype; that shouldn't be
Jim Blandy <jimb@redhat.com>
parents:
2662
diff
changeset
|
1284 |
93c9529b2b69
* config.h.in: Remove mention of GLYPH datatype; that shouldn't be
Jim Blandy <jimb@redhat.com>
parents:
2662
diff
changeset
|
1285 /* Return a glyph's face ID. */ |
30447
e60d22cf57b4
(GLYPH_MASK_CHAR, GLYPH_MASK_FACE): Use 19 bits
Gerd Moellmann <gerd@gnu.org>
parents:
30440
diff
changeset
|
1286 #define FAST_GLYPH_FACE(glyph) (((glyph) & GLYPH_MASK_FACE) >> CHARACTERBITS) |
6416
6f57787905d9
(MAKE_GLYPH, GLYPH_CHAR, GLYPH_FACE): Handle termcap frames as well as X.
Karl Heuer <kwzh@gnu.org>
parents:
6277
diff
changeset
|
1287 |
6f57787905d9
(MAKE_GLYPH, GLYPH_CHAR, GLYPH_FACE): Handle termcap frames as well as X.
Karl Heuer <kwzh@gnu.org>
parents:
6277
diff
changeset
|
1288 /* Slower versions that test the frame type first. */ |
25017
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
1289 #define MAKE_GLYPH(f, char, face) (FAST_MAKE_GLYPH (char, face)) |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
1290 #define GLYPH_CHAR(f, g) (FAST_GLYPH_CHAR (g)) |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
1291 #define GLYPH_FACE(f, g) (FAST_GLYPH_FACE (g)) |
2728
93c9529b2b69
* config.h.in: Remove mention of GLYPH datatype; that shouldn't be
Jim Blandy <jimb@redhat.com>
parents:
2662
diff
changeset
|
1292 |
17188
e38cc84db8ab
(CHAR_TABLE_ORDINARY_SLOTS): Change to 384 (== 256 + 128).
Kenichi Handa <handa@m17n.org>
parents:
17141
diff
changeset
|
1293 /* Return 1 iff GLYPH contains valid character code. */ |
37643
fb0bf81296d5
(GLYPH_CHAR_VALID_P): Use CHAR_VALID_P.
Gerd Moellmann <gerd@gnu.org>
parents:
37188
diff
changeset
|
1294 #define GLYPH_CHAR_VALID_P(glyph) CHAR_VALID_P (FAST_GLYPH_CHAR (glyph), 1) |
17188
e38cc84db8ab
(CHAR_TABLE_ORDINARY_SLOTS): Change to 384 (== 256 + 128).
Kenichi Handa <handa@m17n.org>
parents:
17141
diff
changeset
|
1295 |
6277
444351051761
(GLYPH_MODE_LINE_FACE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
6243
diff
changeset
|
1296 /* The ID of the mode line highlighting face. */ |
444351051761
(GLYPH_MODE_LINE_FACE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
6243
diff
changeset
|
1297 #define GLYPH_MODE_LINE_FACE 1 |
302 | 1298 |
1299 /* Data type checking */ | |
1300 | |
621 | 1301 #define NILP(x) (XFASTINT (x) == XFASTINT (Qnil)) |
1990
c7d6c746fea6
Use the term `scroll bar', instead of `scrollbar'.
Jim Blandy <jimb@redhat.com>
parents:
1923
diff
changeset
|
1302 #define GC_NILP(x) GC_EQ (x, Qnil) |
621 | 1303 |
9150
642bbaf7c3fc
(BOOLFWDP, INTERNALP, INTFWDP, OBJFWDP, INTERNAL_STREAMP, BUFFER_LOCAL_VALUEP,
Karl Heuer <kwzh@gnu.org>
parents:
9099
diff
changeset
|
1304 #define NUMBERP(x) (INTEGERP (x) || FLOATP (x)) |
9947
84efab2ce30b
(GC_INTEGERP, etc): New type-test macros for use during GC.
Karl Heuer <kwzh@gnu.org>
parents:
9943
diff
changeset
|
1305 #define GC_NUMBERP(x) (GC_INTEGERP (x) || GC_FLOATP (x)) |
9943 | 1306 #define NATNUMP(x) (INTEGERP (x) && XINT (x) >= 0) |
9947
84efab2ce30b
(GC_INTEGERP, etc): New type-test macros for use during GC.
Karl Heuer <kwzh@gnu.org>
parents:
9943
diff
changeset
|
1307 #define GC_NATNUMP(x) (GC_INTEGERP (x) && XINT (x) >= 0) |
302 | 1308 |
2187
12b50e8d3b1c
(INTEGERP, SYMBOLP, MARKERP, STRINGP, VECTORP): New macros.
Richard M. Stallman <rms@gnu.org>
parents:
2155
diff
changeset
|
1309 #define INTEGERP(x) (XTYPE ((x)) == Lisp_Int) |
53088
63a8b584e971
(VALMASK): Only define for non-union type.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
53001
diff
changeset
|
1310 #define GC_INTEGERP(x) INTEGERP (x) |
2187
12b50e8d3b1c
(INTEGERP, SYMBOLP, MARKERP, STRINGP, VECTORP): New macros.
Richard M. Stallman <rms@gnu.org>
parents:
2155
diff
changeset
|
1311 #define SYMBOLP(x) (XTYPE ((x)) == Lisp_Symbol) |
9947
84efab2ce30b
(GC_INTEGERP, etc): New type-test macros for use during GC.
Karl Heuer <kwzh@gnu.org>
parents:
9943
diff
changeset
|
1312 #define GC_SYMBOLP(x) (XGCTYPE ((x)) == Lisp_Symbol) |
9435
3a157cdf395c
(Lisp_Misc): new type code, replacing Lisp_Marker (and soon to replace other
Karl Heuer <kwzh@gnu.org>
parents:
9392
diff
changeset
|
1313 #define MISCP(x) (XTYPE ((x)) == Lisp_Misc) |
9947
84efab2ce30b
(GC_INTEGERP, etc): New type-test macros for use during GC.
Karl Heuer <kwzh@gnu.org>
parents:
9943
diff
changeset
|
1314 #define GC_MISCP(x) (XGCTYPE ((x)) == Lisp_Misc) |
10010
67375493afa2
(enum Lisp_Misc_Type): Rename Lisp_Vector to Lisp_Vectorlike. Mark
Karl Heuer <kwzh@gnu.org>
parents:
10003
diff
changeset
|
1315 #define VECTORLIKEP(x) (XTYPE ((x)) == Lisp_Vectorlike) |
67375493afa2
(enum Lisp_Misc_Type): Rename Lisp_Vector to Lisp_Vectorlike. Mark
Karl Heuer <kwzh@gnu.org>
parents:
10003
diff
changeset
|
1316 #define GC_VECTORLIKEP(x) (XGCTYPE ((x)) == Lisp_Vectorlike) |
2187
12b50e8d3b1c
(INTEGERP, SYMBOLP, MARKERP, STRINGP, VECTORP): New macros.
Richard M. Stallman <rms@gnu.org>
parents:
2155
diff
changeset
|
1317 #define STRINGP(x) (XTYPE ((x)) == Lisp_String) |
9947
84efab2ce30b
(GC_INTEGERP, etc): New type-test macros for use during GC.
Karl Heuer <kwzh@gnu.org>
parents:
9943
diff
changeset
|
1318 #define GC_STRINGP(x) (XGCTYPE ((x)) == Lisp_String) |
302 | 1319 #define CONSP(x) (XTYPE ((x)) == Lisp_Cons) |
9947
84efab2ce30b
(GC_INTEGERP, etc): New type-test macros for use during GC.
Karl Heuer <kwzh@gnu.org>
parents:
9943
diff
changeset
|
1320 #define GC_CONSP(x) (XGCTYPE ((x)) == Lisp_Cons) |
10292
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
1321 |
2187
12b50e8d3b1c
(INTEGERP, SYMBOLP, MARKERP, STRINGP, VECTORP): New macros.
Richard M. Stallman <rms@gnu.org>
parents:
2155
diff
changeset
|
1322 #define FLOATP(x) (XTYPE ((x)) == Lisp_Float) |
9947
84efab2ce30b
(GC_INTEGERP, etc): New type-test macros for use during GC.
Karl Heuer <kwzh@gnu.org>
parents:
9943
diff
changeset
|
1323 #define GC_FLOATP(x) (XGCTYPE ((x)) == Lisp_Float) |
10010
67375493afa2
(enum Lisp_Misc_Type): Rename Lisp_Vector to Lisp_Vectorlike. Mark
Karl Heuer <kwzh@gnu.org>
parents:
10003
diff
changeset
|
1324 #define VECTORP(x) (VECTORLIKEP (x) && !(XVECTOR (x)->size & PSEUDOVECTOR_FLAG)) |
67375493afa2
(enum Lisp_Misc_Type): Rename Lisp_Vector to Lisp_Vectorlike. Mark
Karl Heuer <kwzh@gnu.org>
parents:
10003
diff
changeset
|
1325 #define GC_VECTORP(x) (GC_VECTORLIKEP (x) && !(XVECTOR (x)->size & PSEUDOVECTOR_FLAG)) |
11335
78eda0ee4cba
(XMISCTYPE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
11204
diff
changeset
|
1326 #define OVERLAYP(x) (MISCP (x) && XMISCTYPE (x) == Lisp_Misc_Overlay) |
78eda0ee4cba
(XMISCTYPE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
11204
diff
changeset
|
1327 #define GC_OVERLAYP(x) (GC_MISCP (x) && XMISCTYPE (x) == Lisp_Misc_Overlay) |
78eda0ee4cba
(XMISCTYPE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
11204
diff
changeset
|
1328 #define MARKERP(x) (MISCP (x) && XMISCTYPE (x) == Lisp_Misc_Marker) |
78eda0ee4cba
(XMISCTYPE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
11204
diff
changeset
|
1329 #define GC_MARKERP(x) (GC_MISCP (x) && XMISCTYPE (x) == Lisp_Misc_Marker) |
78eda0ee4cba
(XMISCTYPE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
11204
diff
changeset
|
1330 #define INTFWDP(x) (MISCP (x) && XMISCTYPE (x) == Lisp_Misc_Intfwd) |
78eda0ee4cba
(XMISCTYPE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
11204
diff
changeset
|
1331 #define GC_INTFWDP(x) (GC_MISCP (x) && XMISCTYPE (x) == Lisp_Misc_Intfwd) |
78eda0ee4cba
(XMISCTYPE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
11204
diff
changeset
|
1332 #define BOOLFWDP(x) (MISCP (x) && XMISCTYPE (x) == Lisp_Misc_Boolfwd) |
78eda0ee4cba
(XMISCTYPE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
11204
diff
changeset
|
1333 #define GC_BOOLFWDP(x) (GC_MISCP (x) && XMISCTYPE (x) == Lisp_Misc_Boolfwd) |
78eda0ee4cba
(XMISCTYPE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
11204
diff
changeset
|
1334 #define OBJFWDP(x) (MISCP (x) && XMISCTYPE (x) == Lisp_Misc_Objfwd) |
78eda0ee4cba
(XMISCTYPE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
11204
diff
changeset
|
1335 #define GC_OBJFWDP(x) (GC_MISCP (x) && XMISCTYPE (x) == Lisp_Misc_Objfwd) |
78eda0ee4cba
(XMISCTYPE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
11204
diff
changeset
|
1336 #define BUFFER_OBJFWDP(x) (MISCP (x) && XMISCTYPE (x) == Lisp_Misc_Buffer_Objfwd) |
78eda0ee4cba
(XMISCTYPE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
11204
diff
changeset
|
1337 #define GC_BUFFER_OBJFWDP(x) (GC_MISCP (x) && XMISCTYPE (x) == Lisp_Misc_Buffer_Objfwd) |
78eda0ee4cba
(XMISCTYPE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
11204
diff
changeset
|
1338 #define BUFFER_LOCAL_VALUEP(x) (MISCP (x) && XMISCTYPE (x) == Lisp_Misc_Buffer_Local_Value) |
78eda0ee4cba
(XMISCTYPE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
11204
diff
changeset
|
1339 #define GC_BUFFER_LOCAL_VALUEP(x) (GC_MISCP (x) && XMISCTYPE (x) == Lisp_Misc_Buffer_Local_Value) |
78eda0ee4cba
(XMISCTYPE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
11204
diff
changeset
|
1340 #define SOME_BUFFER_LOCAL_VALUEP(x) (MISCP (x) && XMISCTYPE (x) == Lisp_Misc_Some_Buffer_Local_Value) |
78eda0ee4cba
(XMISCTYPE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
11204
diff
changeset
|
1341 #define GC_SOME_BUFFER_LOCAL_VALUEP(x) (GC_MISCP (x) && XMISCTYPE (x) == Lisp_Misc_Some_Buffer_Local_Value) |
78eda0ee4cba
(XMISCTYPE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
11204
diff
changeset
|
1342 #define KBOARD_OBJFWDP(x) (MISCP (x) && XMISCTYPE (x) == Lisp_Misc_Kboard_Objfwd) |
78eda0ee4cba
(XMISCTYPE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
11204
diff
changeset
|
1343 #define GC_KBOARD_OBJFWDP(x) (GC_MISCP (x) && XMISCTYPE (x) == Lisp_Misc_Kboard_Objfwd) |
2187
12b50e8d3b1c
(INTEGERP, SYMBOLP, MARKERP, STRINGP, VECTORP): New macros.
Richard M. Stallman <rms@gnu.org>
parents:
2155
diff
changeset
|
1344 |
10292
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
1345 |
10322
c1c2ec3aeefa
Use consistent spelling in comments.
Karl Heuer <kwzh@gnu.org>
parents:
10321
diff
changeset
|
1346 /* True if object X is a pseudovector whose code is CODE. */ |
10292
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
1347 #define PSEUDOVECTORP(x, code) \ |
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
1348 (VECTORLIKEP (x) \ |
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
1349 && (((XVECTOR (x)->size & (PSEUDOVECTOR_FLAG | (code)))) \ |
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
1350 == (PSEUDOVECTOR_FLAG | (code)))) |
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
1351 |
10322
c1c2ec3aeefa
Use consistent spelling in comments.
Karl Heuer <kwzh@gnu.org>
parents:
10321
diff
changeset
|
1352 /* True if object X is a pseudovector whose code is CODE. |
10292
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
1353 This one works during GC. */ |
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
1354 #define GC_PSEUDOVECTORP(x, code) \ |
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
1355 (GC_VECTORLIKEP (x) \ |
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
1356 && (((XVECTOR (x)->size & (PSEUDOVECTOR_FLAG | (code)))) \ |
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
1357 == (PSEUDOVECTOR_FLAG | (code)))) |
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
1358 |
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
1359 /* Test for specific pseudovector types. */ |
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
1360 #define WINDOW_CONFIGURATIONP(x) PSEUDOVECTORP (x, PVEC_WINDOW_CONFIGURATION) |
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
1361 #define GC_WINDOW_CONFIGURATIONP(x) GC_PSEUDOVECTORP (x, PVEC_WINDOW_CONFIGURATION) |
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
1362 #define PROCESSP(x) PSEUDOVECTORP (x, PVEC_PROCESS) |
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
1363 #define GC_PROCESSP(x) GC_PSEUDOVECTORP (x, PVEC_PROCESS) |
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
1364 #define WINDOWP(x) PSEUDOVECTORP (x, PVEC_WINDOW) |
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
1365 #define GC_WINDOWP(x) GC_PSEUDOVECTORP (x, PVEC_WINDOW) |
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
1366 #define SUBRP(x) PSEUDOVECTORP (x, PVEC_SUBR) |
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
1367 #define GC_SUBRP(x) GC_PSEUDOVECTORP (x, PVEC_SUBR) |
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
1368 #define COMPILEDP(x) PSEUDOVECTORP (x, PVEC_COMPILED) |
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
1369 #define GC_COMPILEDP(x) GC_PSEUDOVECTORP (x, PVEC_COMPILED) |
10316
272f15eddaca
(enum Lisp_Type): Delete Lisp_Buffer.
Richard M. Stallman <rms@gnu.org>
parents:
10292
diff
changeset
|
1370 #define BUFFERP(x) PSEUDOVECTORP (x, PVEC_BUFFER) |
272f15eddaca
(enum Lisp_Type): Delete Lisp_Buffer.
Richard M. Stallman <rms@gnu.org>
parents:
10292
diff
changeset
|
1371 #define GC_BUFFERP(x) GC_PSEUDOVECTORP (x, PVEC_BUFFER) |
13149
b1dcc3e87ffb
(struct Lisp_Boolvector): New data type.
Richard M. Stallman <rms@gnu.org>
parents:
12890
diff
changeset
|
1372 #define CHAR_TABLE_P(x) PSEUDOVECTORP (x, PVEC_CHAR_TABLE) |
b1dcc3e87ffb
(struct Lisp_Boolvector): New data type.
Richard M. Stallman <rms@gnu.org>
parents:
12890
diff
changeset
|
1373 #define GC_CHAR_TABLE_P(x) GC_PSEUDOVECTORP (x, PVEC_CHAR_TABLE) |
b1dcc3e87ffb
(struct Lisp_Boolvector): New data type.
Richard M. Stallman <rms@gnu.org>
parents:
12890
diff
changeset
|
1374 #define BOOL_VECTOR_P(x) PSEUDOVECTORP (x, PVEC_BOOL_VECTOR) |
b1dcc3e87ffb
(struct Lisp_Boolvector): New data type.
Richard M. Stallman <rms@gnu.org>
parents:
12890
diff
changeset
|
1375 #define GC_BOOL_VECTOR_P(x) GC_PSEUDOVECTORP (x, PVEC_BOOL_VECTOR) |
10292
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
1376 #define FRAMEP(x) PSEUDOVECTORP (x, PVEC_FRAME) |
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
1377 #define GC_FRAMEP(x) GC_PSEUDOVECTORP (x, PVEC_FRAME) |
17326
bd34aa57f3f5
(CHAR_TABLE_STANDARD_SLOTS): Now 4 more slots than
Kenichi Handa <handa@m17n.org>
parents:
17289
diff
changeset
|
1378 |
bd34aa57f3f5
(CHAR_TABLE_STANDARD_SLOTS): Now 4 more slots than
Kenichi Handa <handa@m17n.org>
parents:
17289
diff
changeset
|
1379 #define SUB_CHAR_TABLE_P(x) (CHAR_TABLE_P (x) && NILP (XCHAR_TABLE (x)->top)) |
53331
db670c1b5944
(IMAGEP): New macro to test for image object type.
Kim F. Storm <storm@cua.dk>
parents:
53111
diff
changeset
|
1380 |
db670c1b5944
(IMAGEP): New macro to test for image object type.
Kim F. Storm <storm@cua.dk>
parents:
53111
diff
changeset
|
1381 /* Test for image (image . spec) */ |
db670c1b5944
(IMAGEP): New macro to test for image object type.
Kim F. Storm <storm@cua.dk>
parents:
53111
diff
changeset
|
1382 #define IMAGEP(x) (CONSP (x) && EQ (XCAR (x), Qimage)) |
db670c1b5944
(IMAGEP): New macro to test for image object type.
Kim F. Storm <storm@cua.dk>
parents:
53111
diff
changeset
|
1383 |
10292
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
1384 |
53088
63a8b584e971
(VALMASK): Only define for non-union type.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
53001
diff
changeset
|
1385 #define GC_EQ(x, y) EQ (x, y) |
621 | 1386 |
40653
6c48a4da1da5
(CHECK_STRING_OR_BUFFER, CHECK_HASH_TABLE, CHECK_LIST, CHECK_STRING,
Pavel Janík <Pavel@Janik.cz>
parents:
40536
diff
changeset
|
1387 #define CHECK_LIST(x) \ |
9150
642bbaf7c3fc
(BOOLFWDP, INTERNALP, INTFWDP, OBJFWDP, INTERNAL_STREAMP, BUFFER_LOCAL_VALUEP,
Karl Heuer <kwzh@gnu.org>
parents:
9099
diff
changeset
|
1388 do { if (!CONSP ((x)) && !NILP (x)) x = wrong_type_argument (Qlistp, (x)); } while (0) |
302 | 1389 |
40653
6c48a4da1da5
(CHECK_STRING_OR_BUFFER, CHECK_HASH_TABLE, CHECK_LIST, CHECK_STRING,
Pavel Janík <Pavel@Janik.cz>
parents:
40536
diff
changeset
|
1390 #define CHECK_STRING(x) \ |
9150
642bbaf7c3fc
(BOOLFWDP, INTERNALP, INTFWDP, OBJFWDP, INTERNAL_STREAMP, BUFFER_LOCAL_VALUEP,
Karl Heuer <kwzh@gnu.org>
parents:
9099
diff
changeset
|
1391 do { if (!STRINGP ((x))) x = wrong_type_argument (Qstringp, (x)); } while (0) |
302 | 1392 |
40689
1e79b0de40a1
(CHECK_STRING_CAR): New macro.
Ken Raeburn <raeburn@raeburn.org>
parents:
40653
diff
changeset
|
1393 #define CHECK_STRING_CAR(x) \ |
1e79b0de40a1
(CHECK_STRING_CAR): New macro.
Ken Raeburn <raeburn@raeburn.org>
parents:
40653
diff
changeset
|
1394 do { if (!STRINGP (XCAR (x))) XSETCAR (x, wrong_type_argument (Qstringp, XCAR (x))); } while (0) |
1e79b0de40a1
(CHECK_STRING_CAR): New macro.
Ken Raeburn <raeburn@raeburn.org>
parents:
40653
diff
changeset
|
1395 |
40653
6c48a4da1da5
(CHECK_STRING_OR_BUFFER, CHECK_HASH_TABLE, CHECK_LIST, CHECK_STRING,
Pavel Janík <Pavel@Janik.cz>
parents:
40536
diff
changeset
|
1396 #define CHECK_CONS(x) \ |
9150
642bbaf7c3fc
(BOOLFWDP, INTERNALP, INTFWDP, OBJFWDP, INTERNAL_STREAMP, BUFFER_LOCAL_VALUEP,
Karl Heuer <kwzh@gnu.org>
parents:
9099
diff
changeset
|
1397 do { if (!CONSP ((x))) x = wrong_type_argument (Qconsp, (x)); } while (0) |
302 | 1398 |
40653
6c48a4da1da5
(CHECK_STRING_OR_BUFFER, CHECK_HASH_TABLE, CHECK_LIST, CHECK_STRING,
Pavel Janík <Pavel@Janik.cz>
parents:
40536
diff
changeset
|
1399 #define CHECK_SYMBOL(x) \ |
9150
642bbaf7c3fc
(BOOLFWDP, INTERNALP, INTFWDP, OBJFWDP, INTERNAL_STREAMP, BUFFER_LOCAL_VALUEP,
Karl Heuer <kwzh@gnu.org>
parents:
9099
diff
changeset
|
1400 do { if (!SYMBOLP ((x))) x = wrong_type_argument (Qsymbolp, (x)); } while (0) |
302 | 1401 |
40653
6c48a4da1da5
(CHECK_STRING_OR_BUFFER, CHECK_HASH_TABLE, CHECK_LIST, CHECK_STRING,
Pavel Janík <Pavel@Janik.cz>
parents:
40536
diff
changeset
|
1402 #define CHECK_CHAR_TABLE(x) \ |
13357
74a891e3ef44
(CHECK_CHAR_TABLE): Don't accept nil.
Richard M. Stallman <rms@gnu.org>
parents:
13330
diff
changeset
|
1403 do { if (!CHAR_TABLE_P ((x))) \ |
13149
b1dcc3e87ffb
(struct Lisp_Boolvector): New data type.
Richard M. Stallman <rms@gnu.org>
parents:
12890
diff
changeset
|
1404 x = wrong_type_argument (Qchar_table_p, (x)); } while (0) |
b1dcc3e87ffb
(struct Lisp_Boolvector): New data type.
Richard M. Stallman <rms@gnu.org>
parents:
12890
diff
changeset
|
1405 |
40653
6c48a4da1da5
(CHECK_STRING_OR_BUFFER, CHECK_HASH_TABLE, CHECK_LIST, CHECK_STRING,
Pavel Janík <Pavel@Janik.cz>
parents:
40536
diff
changeset
|
1406 #define CHECK_VECTOR(x) \ |
9150
642bbaf7c3fc
(BOOLFWDP, INTERNALP, INTFWDP, OBJFWDP, INTERNAL_STREAMP, BUFFER_LOCAL_VALUEP,
Karl Heuer <kwzh@gnu.org>
parents:
9099
diff
changeset
|
1407 do { if (!VECTORP ((x))) x = wrong_type_argument (Qvectorp, (x)); } while (0) |
302 | 1408 |
40653
6c48a4da1da5
(CHECK_STRING_OR_BUFFER, CHECK_HASH_TABLE, CHECK_LIST, CHECK_STRING,
Pavel Janík <Pavel@Janik.cz>
parents:
40536
diff
changeset
|
1409 #define CHECK_VECTOR_OR_CHAR_TABLE(x) \ |
13202
b307cd5c259f
(struct Lisp_Char_Table): New slot `purpose'.
Richard M. Stallman <rms@gnu.org>
parents:
13149
diff
changeset
|
1410 do { if (!VECTORP ((x)) && !CHAR_TABLE_P ((x))) \ |
b307cd5c259f
(struct Lisp_Char_Table): New slot `purpose'.
Richard M. Stallman <rms@gnu.org>
parents:
13149
diff
changeset
|
1411 x = wrong_type_argument (Qvector_or_char_table_p, (x)); \ |
b307cd5c259f
(struct Lisp_Char_Table): New slot `purpose'.
Richard M. Stallman <rms@gnu.org>
parents:
13149
diff
changeset
|
1412 } while (0) |
b307cd5c259f
(struct Lisp_Char_Table): New slot `purpose'.
Richard M. Stallman <rms@gnu.org>
parents:
13149
diff
changeset
|
1413 |
40653
6c48a4da1da5
(CHECK_STRING_OR_BUFFER, CHECK_HASH_TABLE, CHECK_LIST, CHECK_STRING,
Pavel Janík <Pavel@Janik.cz>
parents:
40536
diff
changeset
|
1414 #define CHECK_BUFFER(x) \ |
9150
642bbaf7c3fc
(BOOLFWDP, INTERNALP, INTFWDP, OBJFWDP, INTERNAL_STREAMP, BUFFER_LOCAL_VALUEP,
Karl Heuer <kwzh@gnu.org>
parents:
9099
diff
changeset
|
1415 do { if (!BUFFERP ((x))) x = wrong_type_argument (Qbufferp, (x)); } while (0) |
302 | 1416 |
40653
6c48a4da1da5
(CHECK_STRING_OR_BUFFER, CHECK_HASH_TABLE, CHECK_LIST, CHECK_STRING,
Pavel Janík <Pavel@Janik.cz>
parents:
40536
diff
changeset
|
1417 #define CHECK_WINDOW(x) \ |
9150
642bbaf7c3fc
(BOOLFWDP, INTERNALP, INTFWDP, OBJFWDP, INTERNAL_STREAMP, BUFFER_LOCAL_VALUEP,
Karl Heuer <kwzh@gnu.org>
parents:
9099
diff
changeset
|
1418 do { if (!WINDOWP ((x))) x = wrong_type_argument (Qwindowp, (x)); } while (0) |
302 | 1419 |
1442
89ac471c745c
* lisp.h (CHECK_LIVE_WINDOW): New predicate.
Jim Blandy <jimb@redhat.com>
parents:
1306
diff
changeset
|
1420 /* This macro rejects windows on the interior of the window tree as |
17404
73012b195cf3
(DOWNCASE): Return int, not Lisp_Object.
Karl Heuer <kwzh@gnu.org>
parents:
17326
diff
changeset
|
1421 "dead", which is what we want; this is an argument-checking macro, and |
1442
89ac471c745c
* lisp.h (CHECK_LIVE_WINDOW): New predicate.
Jim Blandy <jimb@redhat.com>
parents:
1306
diff
changeset
|
1422 the user should never get access to interior windows. |
89ac471c745c
* lisp.h (CHECK_LIVE_WINDOW): New predicate.
Jim Blandy <jimb@redhat.com>
parents:
1306
diff
changeset
|
1423 |
89ac471c745c
* lisp.h (CHECK_LIVE_WINDOW): New predicate.
Jim Blandy <jimb@redhat.com>
parents:
1306
diff
changeset
|
1424 A window of any sort, leaf or interior, is dead iff the buffer, |
89ac471c745c
* lisp.h (CHECK_LIVE_WINDOW): New predicate.
Jim Blandy <jimb@redhat.com>
parents:
1306
diff
changeset
|
1425 vchild, and hchild members are all nil. */ |
89ac471c745c
* lisp.h (CHECK_LIVE_WINDOW): New predicate.
Jim Blandy <jimb@redhat.com>
parents:
1306
diff
changeset
|
1426 |
40653
6c48a4da1da5
(CHECK_STRING_OR_BUFFER, CHECK_HASH_TABLE, CHECK_LIST, CHECK_STRING,
Pavel Janík <Pavel@Janik.cz>
parents:
40536
diff
changeset
|
1427 #define CHECK_LIVE_WINDOW(x) \ |
3793
374fc1ccdc3f
* lisp.h (CHECK_LIST, CHECK_STRING, CHECK_CONS, CHECK_SYMBOL,
Jim Blandy <jimb@redhat.com>
parents:
3785
diff
changeset
|
1428 do { \ |
9150
642bbaf7c3fc
(BOOLFWDP, INTERNALP, INTFWDP, OBJFWDP, INTERNAL_STREAMP, BUFFER_LOCAL_VALUEP,
Karl Heuer <kwzh@gnu.org>
parents:
9099
diff
changeset
|
1429 if (!WINDOWP ((x)) \ |
1442
89ac471c745c
* lisp.h (CHECK_LIVE_WINDOW): New predicate.
Jim Blandy <jimb@redhat.com>
parents:
1306
diff
changeset
|
1430 || NILP (XWINDOW ((x))->buffer)) \ |
2210
22d78dbb3cc7
Rename `live-window-p' to `window-live-p', for consistency with
Jim Blandy <jimb@redhat.com>
parents:
2187
diff
changeset
|
1431 x = wrong_type_argument (Qwindow_live_p, (x)); \ |
3793
374fc1ccdc3f
* lisp.h (CHECK_LIST, CHECK_STRING, CHECK_CONS, CHECK_SYMBOL,
Jim Blandy <jimb@redhat.com>
parents:
3785
diff
changeset
|
1432 } while (0) |
1442
89ac471c745c
* lisp.h (CHECK_LIVE_WINDOW): New predicate.
Jim Blandy <jimb@redhat.com>
parents:
1306
diff
changeset
|
1433 |
40653
6c48a4da1da5
(CHECK_STRING_OR_BUFFER, CHECK_HASH_TABLE, CHECK_LIST, CHECK_STRING,
Pavel Janík <Pavel@Janik.cz>
parents:
40536
diff
changeset
|
1434 #define CHECK_PROCESS(x) \ |
9150
642bbaf7c3fc
(BOOLFWDP, INTERNALP, INTFWDP, OBJFWDP, INTERNAL_STREAMP, BUFFER_LOCAL_VALUEP,
Karl Heuer <kwzh@gnu.org>
parents:
9099
diff
changeset
|
1435 do { if (!PROCESSP ((x))) x = wrong_type_argument (Qprocessp, (x)); } while (0) |
302 | 1436 |
40653
6c48a4da1da5
(CHECK_STRING_OR_BUFFER, CHECK_HASH_TABLE, CHECK_LIST, CHECK_STRING,
Pavel Janík <Pavel@Janik.cz>
parents:
40536
diff
changeset
|
1437 #define CHECK_NUMBER(x) \ |
9150
642bbaf7c3fc
(BOOLFWDP, INTERNALP, INTFWDP, OBJFWDP, INTERNAL_STREAMP, BUFFER_LOCAL_VALUEP,
Karl Heuer <kwzh@gnu.org>
parents:
9099
diff
changeset
|
1438 do { if (!INTEGERP ((x))) x = wrong_type_argument (Qintegerp, (x)); } while (0) |
302 | 1439 |
40653
6c48a4da1da5
(CHECK_STRING_OR_BUFFER, CHECK_HASH_TABLE, CHECK_LIST, CHECK_STRING,
Pavel Janík <Pavel@Janik.cz>
parents:
40536
diff
changeset
|
1440 #define CHECK_NATNUM(x) \ |
9943 | 1441 do { if (!NATNUMP (x)) x = wrong_type_argument (Qwholenump, (x)); } while (0) |
302 | 1442 |
40653
6c48a4da1da5
(CHECK_STRING_OR_BUFFER, CHECK_HASH_TABLE, CHECK_LIST, CHECK_STRING,
Pavel Janík <Pavel@Janik.cz>
parents:
40536
diff
changeset
|
1443 #define CHECK_MARKER(x) \ |
9150
642bbaf7c3fc
(BOOLFWDP, INTERNALP, INTFWDP, OBJFWDP, INTERNAL_STREAMP, BUFFER_LOCAL_VALUEP,
Karl Heuer <kwzh@gnu.org>
parents:
9099
diff
changeset
|
1444 do { if (!MARKERP ((x))) x = wrong_type_argument (Qmarkerp, (x)); } while (0) |
302 | 1445 |
40653
6c48a4da1da5
(CHECK_STRING_OR_BUFFER, CHECK_HASH_TABLE, CHECK_LIST, CHECK_STRING,
Pavel Janík <Pavel@Janik.cz>
parents:
40536
diff
changeset
|
1446 #define CHECK_NUMBER_COERCE_MARKER(x) \ |
9292 | 1447 do { if (MARKERP ((x))) XSETFASTINT (x, marker_position (x)); \ |
9150
642bbaf7c3fc
(BOOLFWDP, INTERNALP, INTFWDP, OBJFWDP, INTERNAL_STREAMP, BUFFER_LOCAL_VALUEP,
Karl Heuer <kwzh@gnu.org>
parents:
9099
diff
changeset
|
1448 else if (!INTEGERP ((x))) x = wrong_type_argument (Qinteger_or_marker_p, (x)); } while (0) |
302 | 1449 |
1450 #define XFLOATINT(n) extract_float((n)) | |
1451 | |
40653
6c48a4da1da5
(CHECK_STRING_OR_BUFFER, CHECK_HASH_TABLE, CHECK_LIST, CHECK_STRING,
Pavel Janík <Pavel@Janik.cz>
parents:
40536
diff
changeset
|
1452 #define CHECK_FLOAT(x) \ |
9150
642bbaf7c3fc
(BOOLFWDP, INTERNALP, INTFWDP, OBJFWDP, INTERNAL_STREAMP, BUFFER_LOCAL_VALUEP,
Karl Heuer <kwzh@gnu.org>
parents:
9099
diff
changeset
|
1453 do { if (!FLOATP (x)) \ |
3793
374fc1ccdc3f
* lisp.h (CHECK_LIST, CHECK_STRING, CHECK_CONS, CHECK_SYMBOL,
Jim Blandy <jimb@redhat.com>
parents:
3785
diff
changeset
|
1454 x = wrong_type_argument (Qfloatp, (x)); } while (0) |
302 | 1455 |
40653
6c48a4da1da5
(CHECK_STRING_OR_BUFFER, CHECK_HASH_TABLE, CHECK_LIST, CHECK_STRING,
Pavel Janík <Pavel@Janik.cz>
parents:
40536
diff
changeset
|
1456 #define CHECK_NUMBER_OR_FLOAT(x) \ |
9150
642bbaf7c3fc
(BOOLFWDP, INTERNALP, INTFWDP, OBJFWDP, INTERNAL_STREAMP, BUFFER_LOCAL_VALUEP,
Karl Heuer <kwzh@gnu.org>
parents:
9099
diff
changeset
|
1457 do { if (!FLOATP (x) && !INTEGERP (x)) \ |
3793
374fc1ccdc3f
* lisp.h (CHECK_LIST, CHECK_STRING, CHECK_CONS, CHECK_SYMBOL,
Jim Blandy <jimb@redhat.com>
parents:
3785
diff
changeset
|
1458 x = wrong_type_argument (Qnumberp, (x)); } while (0) |
302 | 1459 |
40653
6c48a4da1da5
(CHECK_STRING_OR_BUFFER, CHECK_HASH_TABLE, CHECK_LIST, CHECK_STRING,
Pavel Janík <Pavel@Janik.cz>
parents:
40536
diff
changeset
|
1460 #define CHECK_NUMBER_OR_FLOAT_COERCE_MARKER(x) \ |
9292 | 1461 do { if (MARKERP (x)) XSETFASTINT (x, marker_position (x)); \ |
9150
642bbaf7c3fc
(BOOLFWDP, INTERNALP, INTFWDP, OBJFWDP, INTERNAL_STREAMP, BUFFER_LOCAL_VALUEP,
Karl Heuer <kwzh@gnu.org>
parents:
9099
diff
changeset
|
1462 else if (!INTEGERP (x) && !FLOATP (x)) \ |
3793
374fc1ccdc3f
* lisp.h (CHECK_LIST, CHECK_STRING, CHECK_CONS, CHECK_SYMBOL,
Jim Blandy <jimb@redhat.com>
parents:
3785
diff
changeset
|
1463 x = wrong_type_argument (Qnumber_or_marker_p, (x)); } while (0) |
302 | 1464 |
40653
6c48a4da1da5
(CHECK_STRING_OR_BUFFER, CHECK_HASH_TABLE, CHECK_LIST, CHECK_STRING,
Pavel Janík <Pavel@Janik.cz>
parents:
40536
diff
changeset
|
1465 #define CHECK_OVERLAY(x) \ |
9150
642bbaf7c3fc
(BOOLFWDP, INTERNALP, INTFWDP, OBJFWDP, INTERNAL_STREAMP, BUFFER_LOCAL_VALUEP,
Karl Heuer <kwzh@gnu.org>
parents:
9099
diff
changeset
|
1466 do { if (!OVERLAYP ((x))) x = wrong_type_argument (Qoverlayp, (x));} while (0) |
2780
cfe7659bbc05
* lisp.h (Lisp_Overlay): New tag.
Jim Blandy <jimb@redhat.com>
parents:
2728
diff
changeset
|
1467 |
39973
579177964efa
Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents:
39924
diff
changeset
|
1468 /* Since we can't assign directly to the CAR or CDR fields of a cons |
579177964efa
Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents:
39924
diff
changeset
|
1469 cell, use these when checking that those fields contain numbers. */ |
40653
6c48a4da1da5
(CHECK_STRING_OR_BUFFER, CHECK_HASH_TABLE, CHECK_LIST, CHECK_STRING,
Pavel Janík <Pavel@Janik.cz>
parents:
40536
diff
changeset
|
1470 #define CHECK_NUMBER_CAR(x) \ |
39973
579177964efa
Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents:
39924
diff
changeset
|
1471 do { \ |
579177964efa
Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents:
39924
diff
changeset
|
1472 Lisp_Object tmp = XCAR (x); \ |
40653
6c48a4da1da5
(CHECK_STRING_OR_BUFFER, CHECK_HASH_TABLE, CHECK_LIST, CHECK_STRING,
Pavel Janík <Pavel@Janik.cz>
parents:
40536
diff
changeset
|
1473 CHECK_NUMBER (tmp); \ |
39973
579177964efa
Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents:
39924
diff
changeset
|
1474 XSETCAR ((x), tmp); \ |
579177964efa
Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents:
39924
diff
changeset
|
1475 } while (0) |
579177964efa
Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents:
39924
diff
changeset
|
1476 |
40653
6c48a4da1da5
(CHECK_STRING_OR_BUFFER, CHECK_HASH_TABLE, CHECK_LIST, CHECK_STRING,
Pavel Janík <Pavel@Janik.cz>
parents:
40536
diff
changeset
|
1477 #define CHECK_NUMBER_CDR(x) \ |
39973
579177964efa
Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents:
39924
diff
changeset
|
1478 do { \ |
579177964efa
Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents:
39924
diff
changeset
|
1479 Lisp_Object tmp = XCDR (x); \ |
40653
6c48a4da1da5
(CHECK_STRING_OR_BUFFER, CHECK_HASH_TABLE, CHECK_LIST, CHECK_STRING,
Pavel Janík <Pavel@Janik.cz>
parents:
40536
diff
changeset
|
1480 CHECK_NUMBER (tmp); \ |
39973
579177964efa
Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents:
39924
diff
changeset
|
1481 XSETCDR ((x), tmp); \ |
579177964efa
Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents:
39924
diff
changeset
|
1482 } while (0) |
579177964efa
Avoid (most) uses of XCAR/XCDR as lvalues, for flexibility in experimenting
Ken Raeburn <raeburn@raeburn.org>
parents:
39924
diff
changeset
|
1483 |
302 | 1484 /* Cast pointers to this type to compare them. Some machines want int. */ |
1485 #ifndef PNTR_COMPARISON_TYPE | |
26088
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
25818
diff
changeset
|
1486 #define PNTR_COMPARISON_TYPE EMACS_UINT |
302 | 1487 #endif |
1488 | |
1489 /* Define a built-in function for calling from Lisp. | |
1490 `lname' should be the name to give the function in Lisp, | |
1491 as a null-terminated C string. | |
1492 `fnname' should be the name of the function in C. | |
1493 By convention, it starts with F. | |
1494 `sname' should be the name for the C constant structure | |
1495 that records information on this function for internal use. | |
1496 By convention, it should be the same as `fnname' but with S instead of F. | |
1497 It's too bad that C macros can't compute this from `fnname'. | |
1498 `minargs' should be a number, the minimum number of arguments allowed. | |
1499 `maxargs' should be a number, the maximum number of arguments allowed, | |
1500 or else MANY or UNEVALLED. | |
1501 MANY means pass a vector of evaluated arguments, | |
1502 in the form of an integer number-of-arguments | |
1503 followed by the address of a vector of Lisp_Objects | |
1504 which contains the argument values. | |
1505 UNEVALLED means pass the list of unevaluated arguments | |
1506 `prompt' says how to read arguments for an interactive call. | |
9904 | 1507 See the doc string for `interactive'. |
302 | 1508 A null string means call interactively with no arguments. |
9904 | 1509 `doc' is documentation for the user. */ |
302 | 1510 |
29443 | 1511 #if (!defined (__STDC__) && !defined (PROTOTYPES)) \ |
1512 || defined (USE_NONANSI_DEFUN) | |
39898
bc20a5e30bfd
(DEFUN, DEFVAR_LISP, ...) [DOC_STRINGS_IN_COMMENTS]:
Gerd Moellmann <gerd@gnu.org>
parents:
39861
diff
changeset
|
1513 |
44065
fca68830d4e0
(DEFUN) [USE_NONANSI_DEFUN]: The 2001-10-17 patch
Kim F. Storm <storm@cua.dk>
parents:
44009
diff
changeset
|
1514 #define DEFUN(lname, fnname, sname, minargs, maxargs, prompt, doc) \ |
39898
bc20a5e30bfd
(DEFUN, DEFVAR_LISP, ...) [DOC_STRINGS_IN_COMMENTS]:
Gerd Moellmann <gerd@gnu.org>
parents:
39861
diff
changeset
|
1515 Lisp_Object fnname (); \ |
bc20a5e30bfd
(DEFUN, DEFVAR_LISP, ...) [DOC_STRINGS_IN_COMMENTS]:
Gerd Moellmann <gerd@gnu.org>
parents:
39861
diff
changeset
|
1516 struct Lisp_Subr sname = \ |
bc20a5e30bfd
(DEFUN, DEFVAR_LISP, ...) [DOC_STRINGS_IN_COMMENTS]:
Gerd Moellmann <gerd@gnu.org>
parents:
39861
diff
changeset
|
1517 { PVEC_SUBR | (sizeof (struct Lisp_Subr) / sizeof (EMACS_INT)), \ |
bc20a5e30bfd
(DEFUN, DEFVAR_LISP, ...) [DOC_STRINGS_IN_COMMENTS]:
Gerd Moellmann <gerd@gnu.org>
parents:
39861
diff
changeset
|
1518 fnname, minargs, maxargs, lname, prompt, 0}; \ |
44065
fca68830d4e0
(DEFUN) [USE_NONANSI_DEFUN]: The 2001-10-17 patch
Kim F. Storm <storm@cua.dk>
parents:
44009
diff
changeset
|
1519 Lisp_Object fnname |
39898
bc20a5e30bfd
(DEFUN, DEFVAR_LISP, ...) [DOC_STRINGS_IN_COMMENTS]:
Gerd Moellmann <gerd@gnu.org>
parents:
39861
diff
changeset
|
1520 |
5241
1536c6b80ff6
Use WORDS_BIG_ENDIAN, not BIG_ENDIAN.
Richard M. Stallman <rms@gnu.org>
parents:
5128
diff
changeset
|
1521 #else |
1536c6b80ff6
Use WORDS_BIG_ENDIAN, not BIG_ENDIAN.
Richard M. Stallman <rms@gnu.org>
parents:
5128
diff
changeset
|
1522 |
1536c6b80ff6
Use WORDS_BIG_ENDIAN, not BIG_ENDIAN.
Richard M. Stallman <rms@gnu.org>
parents:
5128
diff
changeset
|
1523 /* This version of DEFUN declares a function prototype with the right |
10316
272f15eddaca
(enum Lisp_Type): Delete Lisp_Buffer.
Richard M. Stallman <rms@gnu.org>
parents:
10292
diff
changeset
|
1524 arguments, so we can catch errors with maxargs at compile-time. */ |
10292
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
1525 #define DEFUN(lname, fnname, sname, minargs, maxargs, prompt, doc) \ |
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
1526 Lisp_Object fnname DEFUN_ARGS_ ## maxargs ; \ |
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
1527 struct Lisp_Subr sname = \ |
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
1528 { PVEC_SUBR | (sizeof (struct Lisp_Subr) / sizeof (EMACS_INT)), \ |
c467ec24a6bd
(VALBITS): Default now 28.
Richard M. Stallman <rms@gnu.org>
parents:
10247
diff
changeset
|
1529 fnname, minargs, maxargs, lname, prompt, 0}; \ |
5241
1536c6b80ff6
Use WORDS_BIG_ENDIAN, not BIG_ENDIAN.
Richard M. Stallman <rms@gnu.org>
parents:
5128
diff
changeset
|
1530 Lisp_Object fnname |
1536c6b80ff6
Use WORDS_BIG_ENDIAN, not BIG_ENDIAN.
Richard M. Stallman <rms@gnu.org>
parents:
5128
diff
changeset
|
1531 |
1536c6b80ff6
Use WORDS_BIG_ENDIAN, not BIG_ENDIAN.
Richard M. Stallman <rms@gnu.org>
parents:
5128
diff
changeset
|
1532 /* Note that the weird token-substitution semantics of ANSI C makes |
10316
272f15eddaca
(enum Lisp_Type): Delete Lisp_Buffer.
Richard M. Stallman <rms@gnu.org>
parents:
10292
diff
changeset
|
1533 this work for MANY and UNEVALLED. */ |
5241
1536c6b80ff6
Use WORDS_BIG_ENDIAN, not BIG_ENDIAN.
Richard M. Stallman <rms@gnu.org>
parents:
5128
diff
changeset
|
1534 #define DEFUN_ARGS_MANY (int, Lisp_Object *) |
1536c6b80ff6
Use WORDS_BIG_ENDIAN, not BIG_ENDIAN.
Richard M. Stallman <rms@gnu.org>
parents:
5128
diff
changeset
|
1535 #define DEFUN_ARGS_UNEVALLED (Lisp_Object) |
1536c6b80ff6
Use WORDS_BIG_ENDIAN, not BIG_ENDIAN.
Richard M. Stallman <rms@gnu.org>
parents:
5128
diff
changeset
|
1536 #define DEFUN_ARGS_0 (void) |
1536c6b80ff6
Use WORDS_BIG_ENDIAN, not BIG_ENDIAN.
Richard M. Stallman <rms@gnu.org>
parents:
5128
diff
changeset
|
1537 #define DEFUN_ARGS_1 (Lisp_Object) |
1536c6b80ff6
Use WORDS_BIG_ENDIAN, not BIG_ENDIAN.
Richard M. Stallman <rms@gnu.org>
parents:
5128
diff
changeset
|
1538 #define DEFUN_ARGS_2 (Lisp_Object, Lisp_Object) |
1536c6b80ff6
Use WORDS_BIG_ENDIAN, not BIG_ENDIAN.
Richard M. Stallman <rms@gnu.org>
parents:
5128
diff
changeset
|
1539 #define DEFUN_ARGS_3 (Lisp_Object, Lisp_Object, Lisp_Object) |
1536c6b80ff6
Use WORDS_BIG_ENDIAN, not BIG_ENDIAN.
Richard M. Stallman <rms@gnu.org>
parents:
5128
diff
changeset
|
1540 #define DEFUN_ARGS_4 (Lisp_Object, Lisp_Object, Lisp_Object, Lisp_Object) |
1536c6b80ff6
Use WORDS_BIG_ENDIAN, not BIG_ENDIAN.
Richard M. Stallman <rms@gnu.org>
parents:
5128
diff
changeset
|
1541 #define DEFUN_ARGS_5 (Lisp_Object, Lisp_Object, Lisp_Object, Lisp_Object, \ |
1536c6b80ff6
Use WORDS_BIG_ENDIAN, not BIG_ENDIAN.
Richard M. Stallman <rms@gnu.org>
parents:
5128
diff
changeset
|
1542 Lisp_Object) |
1536c6b80ff6
Use WORDS_BIG_ENDIAN, not BIG_ENDIAN.
Richard M. Stallman <rms@gnu.org>
parents:
5128
diff
changeset
|
1543 #define DEFUN_ARGS_6 (Lisp_Object, Lisp_Object, Lisp_Object, Lisp_Object, \ |
1536c6b80ff6
Use WORDS_BIG_ENDIAN, not BIG_ENDIAN.
Richard M. Stallman <rms@gnu.org>
parents:
5128
diff
changeset
|
1544 Lisp_Object, Lisp_Object) |
1536c6b80ff6
Use WORDS_BIG_ENDIAN, not BIG_ENDIAN.
Richard M. Stallman <rms@gnu.org>
parents:
5128
diff
changeset
|
1545 #define DEFUN_ARGS_7 (Lisp_Object, Lisp_Object, Lisp_Object, Lisp_Object, \ |
1536c6b80ff6
Use WORDS_BIG_ENDIAN, not BIG_ENDIAN.
Richard M. Stallman <rms@gnu.org>
parents:
5128
diff
changeset
|
1546 Lisp_Object, Lisp_Object, Lisp_Object) |
19547
70d930b49bb4
(DEFUN_ARGS_8): New macro.
Kenichi Handa <handa@m17n.org>
parents:
19224
diff
changeset
|
1547 #define DEFUN_ARGS_8 (Lisp_Object, Lisp_Object, Lisp_Object, Lisp_Object, \ |
70d930b49bb4
(DEFUN_ARGS_8): New macro.
Kenichi Handa <handa@m17n.org>
parents:
19224
diff
changeset
|
1548 Lisp_Object, Lisp_Object, Lisp_Object, Lisp_Object) |
5241
1536c6b80ff6
Use WORDS_BIG_ENDIAN, not BIG_ENDIAN.
Richard M. Stallman <rms@gnu.org>
parents:
5128
diff
changeset
|
1549 #endif |
1536c6b80ff6
Use WORDS_BIG_ENDIAN, not BIG_ENDIAN.
Richard M. Stallman <rms@gnu.org>
parents:
5128
diff
changeset
|
1550 |
30218 | 1551 /* Non-zero if OBJ is a Lisp function. */ |
1552 | |
1553 #define FUNCTIONP(OBJ) \ | |
1554 ((CONSP (OBJ) && EQ (XCAR (OBJ), Qlambda)) \ | |
1555 || (SYMBOLP (OBJ) && !NILP (Ffboundp (OBJ))) \ | |
1556 || COMPILEDP (OBJ) \ | |
1557 || SUBRP (OBJ)) | |
45623
0e92d219e195
(current_column): Now returns float.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents:
45545
diff
changeset
|
1558 |
302 | 1559 /* defsubr (Sname); |
41080 | 1560 is how we define the symbol for function `name' at start-up time. */ |
20297
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
1561 extern void defsubr P_ ((struct Lisp_Subr *)); |
302 | 1562 |
1563 #define MANY -2 | |
1564 #define UNEVALLED -1 | |
1565 | |
20297
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
1566 extern void defvar_lisp P_ ((char *, Lisp_Object *)); |
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
1567 extern void defvar_lisp_nopro P_ ((char *, Lisp_Object *)); |
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
1568 extern void defvar_bool P_ ((char *, int *)); |
43713
f92c4d87863a
Change defvar_int def and vars to use EMACS_INT instead of just int.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
43699
diff
changeset
|
1569 extern void defvar_int P_ ((char *, EMACS_INT *)); |
20297
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
1570 extern void defvar_per_buffer P_ ((char *, Lisp_Object *, Lisp_Object, char *)); |
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
1571 extern void defvar_kboard P_ ((char *, int)); |
302 | 1572 |
1573 /* Macros we use to define forwarded Lisp variables. | |
1574 These are used in the syms_of_FILENAME functions. */ | |
1575 | |
1576 #define DEFVAR_LISP(lname, vname, doc) defvar_lisp (lname, vname) | |
1577 #define DEFVAR_LISP_NOPRO(lname, vname, doc) defvar_lisp_nopro (lname, vname) | |
1578 #define DEFVAR_BOOL(lname, vname, doc) defvar_bool (lname, vname) | |
1579 #define DEFVAR_INT(lname, vname, doc) defvar_int (lname, vname) | |
999 | 1580 #define DEFVAR_PER_BUFFER(lname, vname, type, doc) \ |
1581 defvar_per_buffer (lname, vname, type, 0) | |
11012
31d88266ed12
(struct KBOARD, MULTI_KBOARD, current_kboard, all_kboards,
Karl Heuer <kwzh@gnu.org>
parents:
10944
diff
changeset
|
1582 #define DEFVAR_KBOARD(lname, vname, doc) \ |
31d88266ed12
(struct KBOARD, MULTI_KBOARD, current_kboard, all_kboards,
Karl Heuer <kwzh@gnu.org>
parents:
10944
diff
changeset
|
1583 defvar_kboard (lname, \ |
31d88266ed12
(struct KBOARD, MULTI_KBOARD, current_kboard, all_kboards,
Karl Heuer <kwzh@gnu.org>
parents:
10944
diff
changeset
|
1584 (int)((char *)(¤t_kboard->vname) \ |
31d88266ed12
(struct KBOARD, MULTI_KBOARD, current_kboard, all_kboards,
Karl Heuer <kwzh@gnu.org>
parents:
10944
diff
changeset
|
1585 - (char *)current_kboard)) |
39898
bc20a5e30bfd
(DEFUN, DEFVAR_LISP, ...) [DOC_STRINGS_IN_COMMENTS]:
Gerd Moellmann <gerd@gnu.org>
parents:
39861
diff
changeset
|
1586 |
bc20a5e30bfd
(DEFUN, DEFVAR_LISP, ...) [DOC_STRINGS_IN_COMMENTS]:
Gerd Moellmann <gerd@gnu.org>
parents:
39861
diff
changeset
|
1587 |
302 | 1588 |
1197
4eee4dc734bb
* lisp.h (struct handler): Remove the poll_suppress_count member
Jim Blandy <jimb@redhat.com>
parents:
1184
diff
changeset
|
1589 /* Structure for recording Lisp call stack for backtrace purposes. */ |
4eee4dc734bb
* lisp.h (struct handler): Remove the poll_suppress_count member
Jim Blandy <jimb@redhat.com>
parents:
1184
diff
changeset
|
1590 |
4eee4dc734bb
* lisp.h (struct handler): Remove the poll_suppress_count member
Jim Blandy <jimb@redhat.com>
parents:
1184
diff
changeset
|
1591 /* The special binding stack holds the outer values of variables while |
4eee4dc734bb
* lisp.h (struct handler): Remove the poll_suppress_count member
Jim Blandy <jimb@redhat.com>
parents:
1184
diff
changeset
|
1592 they are bound by a function application or a let form, stores the |
4eee4dc734bb
* lisp.h (struct handler): Remove the poll_suppress_count member
Jim Blandy <jimb@redhat.com>
parents:
1184
diff
changeset
|
1593 code to be executed for Lisp unwind-protect forms, and stores the C |
4eee4dc734bb
* lisp.h (struct handler): Remove the poll_suppress_count member
Jim Blandy <jimb@redhat.com>
parents:
1184
diff
changeset
|
1594 functions to be called for record_unwind_protect. |
302 | 1595 |
1197
4eee4dc734bb
* lisp.h (struct handler): Remove the poll_suppress_count member
Jim Blandy <jimb@redhat.com>
parents:
1184
diff
changeset
|
1596 If func is non-zero, undoing this binding applies func to old_value; |
4eee4dc734bb
* lisp.h (struct handler): Remove the poll_suppress_count member
Jim Blandy <jimb@redhat.com>
parents:
1184
diff
changeset
|
1597 This implements record_unwind_protect. |
27292
d0aba668c5af
(set_internal): Enter the new arg.
Richard M. Stallman <rms@gnu.org>
parents:
27141
diff
changeset
|
1598 |
d0aba668c5af
(set_internal): Enter the new arg.
Richard M. Stallman <rms@gnu.org>
parents:
27141
diff
changeset
|
1599 Otherwise, the element is a variable binding. |
45623
0e92d219e195
(current_column): Now returns float.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents:
45545
diff
changeset
|
1600 |
27292
d0aba668c5af
(set_internal): Enter the new arg.
Richard M. Stallman <rms@gnu.org>
parents:
27141
diff
changeset
|
1601 If the symbol field is a symbol, it is an ordinary variable binding. |
45623
0e92d219e195
(current_column): Now returns float.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents:
45545
diff
changeset
|
1602 |
38289 | 1603 Otherwise, it should be a structure (SYMBOL WHERE |
1604 . CURRENT-BUFFER), which means having bound a local value while | |
1605 CURRENT-BUFFER was active. If WHERE is nil this means we saw the | |
38275 | 1606 default value when binding SYMBOL. WHERE being a buffer or frame |
38289 | 1607 means we saw a buffer-local or frame-local value. Other values of |
1608 WHERE mean an internal error. */ | |
27292
d0aba668c5af
(set_internal): Enter the new arg.
Richard M. Stallman <rms@gnu.org>
parents:
27141
diff
changeset
|
1609 |
51035
b17fe74b2af3
(specbinding_func): New typedef.
Richard M. Stallman <rms@gnu.org>
parents:
50996
diff
changeset
|
1610 typedef Lisp_Object (*specbinding_func) P_ ((Lisp_Object)); |
b17fe74b2af3
(specbinding_func): New typedef.
Richard M. Stallman <rms@gnu.org>
parents:
50996
diff
changeset
|
1611 |
302 | 1612 struct specbinding |
1613 { | |
50918
d1b8ac33a632
(struct specbinding): Declare elements volatile.
Richard M. Stallman <rms@gnu.org>
parents:
50761
diff
changeset
|
1614 volatile Lisp_Object symbol, old_value; |
51035
b17fe74b2af3
(specbinding_func): New typedef.
Richard M. Stallman <rms@gnu.org>
parents:
50996
diff
changeset
|
1615 volatile specbinding_func func; |
302 | 1616 Lisp_Object unused; /* Dividing by 16 is faster than by 12 */ |
1617 }; | |
1618 | |
1619 extern struct specbinding *specpdl; | |
50918
d1b8ac33a632
(struct specbinding): Declare elements volatile.
Richard M. Stallman <rms@gnu.org>
parents:
50761
diff
changeset
|
1620 extern volatile struct specbinding *specpdl_ptr; |
302 | 1621 extern int specpdl_size; |
1622 | |
43713
f92c4d87863a
Change defvar_int def and vars to use EMACS_INT instead of just int.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
43699
diff
changeset
|
1623 extern EMACS_INT max_specpdl_size; |
42415
cdbdb10cfbe6
(max_specpdl_size): Add declaration.
Richard M. Stallman <rms@gnu.org>
parents:
42278
diff
changeset
|
1624 |
46284
36c70758a8d7
(SPECPDL_INDEX): Rename from BINDING_STACK_SIZE. All callers updated.
Juanma Barranquero <lekktu@gmail.com>
parents:
46220
diff
changeset
|
1625 #define SPECPDL_INDEX() (specpdl_ptr - specpdl) |
33508
027d4bc2e846
(BINDING_STACK_SIZE): New macro.
Gerd Moellmann <gerd@gnu.org>
parents:
33461
diff
changeset
|
1626 |
1197
4eee4dc734bb
* lisp.h (struct handler): Remove the poll_suppress_count member
Jim Blandy <jimb@redhat.com>
parents:
1184
diff
changeset
|
1627 /* Everything needed to describe an active condition case. */ |
302 | 1628 struct handler |
1629 { | |
1197
4eee4dc734bb
* lisp.h (struct handler): Remove the poll_suppress_count member
Jim Blandy <jimb@redhat.com>
parents:
1184
diff
changeset
|
1630 /* The handler clauses and variable from the condition-case form. */ |
46866 | 1631 /* For a handler set up in Lisp code, this is always a list. |
1632 For an internal handler set up by internal_condition_case*, | |
1633 this can instead be the symbol t or `error'. | |
1634 t: handle all conditions. | |
1635 error: handle all conditions, and errors can run the debugger | |
1636 or display a backtrace. */ | |
302 | 1637 Lisp_Object handler; |
1638 Lisp_Object var; | |
6131
854e14ecfa93
(struct handler): New field chosen_clause.
Richard M. Stallman <rms@gnu.org>
parents:
6094
diff
changeset
|
1639 /* Fsignal stores here the condition-case clause that applies, |
854e14ecfa93
(struct handler): New field chosen_clause.
Richard M. Stallman <rms@gnu.org>
parents:
6094
diff
changeset
|
1640 and Fcondition_case thus knows which clause to run. */ |
854e14ecfa93
(struct handler): New field chosen_clause.
Richard M. Stallman <rms@gnu.org>
parents:
6094
diff
changeset
|
1641 Lisp_Object chosen_clause; |
1197
4eee4dc734bb
* lisp.h (struct handler): Remove the poll_suppress_count member
Jim Blandy <jimb@redhat.com>
parents:
1184
diff
changeset
|
1642 |
4eee4dc734bb
* lisp.h (struct handler): Remove the poll_suppress_count member
Jim Blandy <jimb@redhat.com>
parents:
1184
diff
changeset
|
1643 /* Used to effect the longjump out to the handler. */ |
302 | 1644 struct catchtag *tag; |
1197
4eee4dc734bb
* lisp.h (struct handler): Remove the poll_suppress_count member
Jim Blandy <jimb@redhat.com>
parents:
1184
diff
changeset
|
1645 |
4eee4dc734bb
* lisp.h (struct handler): Remove the poll_suppress_count member
Jim Blandy <jimb@redhat.com>
parents:
1184
diff
changeset
|
1646 /* The next enclosing handler. */ |
302 | 1647 struct handler *next; |
1648 }; | |
1649 | |
1650 extern struct handler *handlerlist; | |
1651 | |
1652 extern struct catchtag *catchlist; | |
1653 extern struct backtrace *backtrace_list; | |
1654 | |
6131
854e14ecfa93
(struct handler): New field chosen_clause.
Richard M. Stallman <rms@gnu.org>
parents:
6094
diff
changeset
|
1655 extern Lisp_Object memory_signal_data; |
854e14ecfa93
(struct handler): New field chosen_clause.
Richard M. Stallman <rms@gnu.org>
parents:
6094
diff
changeset
|
1656 |
302 | 1657 /* An address near the bottom of the stack. |
1658 Tells GC how to save a copy of the stack. */ | |
1659 extern char *stack_bottom; | |
1660 | |
26296
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1661 /* Check quit-flag and quit if it is non-nil. |
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1662 Typing C-g does not directly cause a quit; it only sets Vquit_flag. |
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1663 So the program needs to do QUIT at times when it is safe to quit. |
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1664 Every loop that might run for a long time or might not exit |
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1665 ought to do QUIT at least once, at a safe place. |
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1666 Unless that is impossible, of course. |
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1667 But it is very desirable to avoid creating loops where QUIT is impossible. |
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1668 |
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1669 Exception: if you set immediate_quit to nonzero, |
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1670 then the handler that responds to the C-g does the quit itself. |
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1671 This is a good thing to do around a loop that has no side effects |
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1672 and (in particular) cannot call arbitrary Lisp code. */ |
302 | 1673 |
26309
8817f3f80755
(QUIT): Give it statement form.
Gerd Moellmann <gerd@gnu.org>
parents:
26296
diff
changeset
|
1674 #define QUIT \ |
8817f3f80755
(QUIT): Give it statement form.
Gerd Moellmann <gerd@gnu.org>
parents:
26296
diff
changeset
|
1675 do { \ |
8817f3f80755
(QUIT): Give it statement form.
Gerd Moellmann <gerd@gnu.org>
parents:
26296
diff
changeset
|
1676 if (!NILP (Vquit_flag) && NILP (Vinhibit_quit)) \ |
8817f3f80755
(QUIT): Give it statement form.
Gerd Moellmann <gerd@gnu.org>
parents:
26296
diff
changeset
|
1677 { \ |
8817f3f80755
(QUIT): Give it statement form.
Gerd Moellmann <gerd@gnu.org>
parents:
26296
diff
changeset
|
1678 Vquit_flag = Qnil; \ |
8817f3f80755
(QUIT): Give it statement form.
Gerd Moellmann <gerd@gnu.org>
parents:
26296
diff
changeset
|
1679 Fsignal (Qquit, Qnil); \ |
8817f3f80755
(QUIT): Give it statement form.
Gerd Moellmann <gerd@gnu.org>
parents:
26296
diff
changeset
|
1680 } \ |
8817f3f80755
(QUIT): Give it statement form.
Gerd Moellmann <gerd@gnu.org>
parents:
26296
diff
changeset
|
1681 } while (0) |
302 | 1682 |
1683 /* Nonzero if ought to quit now. */ | |
1684 | |
493 | 1685 #define QUITP (!NILP (Vquit_flag) && NILP (Vinhibit_quit)) |
302 | 1686 |
18006
d29a9b467ac9
(CHAR_TABLE_REF): Do not check validity of CT.
Kenichi Handa <handa@m17n.org>
parents:
17871
diff
changeset
|
1687 /* Variables used locally in the following case handling macros. */ |
18613
614b916ff5bf
Fix bugs with inappropriate mixing of Lisp_Object with int.
Richard M. Stallman <rms@gnu.org>
parents:
18115
diff
changeset
|
1688 extern int case_temp1; |
614b916ff5bf
Fix bugs with inappropriate mixing of Lisp_Object with int.
Richard M. Stallman <rms@gnu.org>
parents:
18115
diff
changeset
|
1689 extern Lisp_Object case_temp2; |
18006
d29a9b467ac9
(CHAR_TABLE_REF): Do not check validity of CT.
Kenichi Handa <handa@m17n.org>
parents:
17871
diff
changeset
|
1690 |
17404
73012b195cf3
(DOWNCASE): Return int, not Lisp_Object.
Karl Heuer <kwzh@gnu.org>
parents:
17326
diff
changeset
|
1691 /* Current buffer's map from characters to lower-case characters. */ |
73012b195cf3
(DOWNCASE): Return int, not Lisp_Object.
Karl Heuer <kwzh@gnu.org>
parents:
17326
diff
changeset
|
1692 |
18006
d29a9b467ac9
(CHAR_TABLE_REF): Do not check validity of CT.
Kenichi Handa <handa@m17n.org>
parents:
17871
diff
changeset
|
1693 #define DOWNCASE_TABLE current_buffer->downcase_table |
17404
73012b195cf3
(DOWNCASE): Return int, not Lisp_Object.
Karl Heuer <kwzh@gnu.org>
parents:
17326
diff
changeset
|
1694 |
73012b195cf3
(DOWNCASE): Return int, not Lisp_Object.
Karl Heuer <kwzh@gnu.org>
parents:
17326
diff
changeset
|
1695 /* Current buffer's map from characters to upper-case characters. */ |
73012b195cf3
(DOWNCASE): Return int, not Lisp_Object.
Karl Heuer <kwzh@gnu.org>
parents:
17326
diff
changeset
|
1696 |
18006
d29a9b467ac9
(CHAR_TABLE_REF): Do not check validity of CT.
Kenichi Handa <handa@m17n.org>
parents:
17871
diff
changeset
|
1697 #define UPCASE_TABLE current_buffer->upcase_table |
17404
73012b195cf3
(DOWNCASE): Return int, not Lisp_Object.
Karl Heuer <kwzh@gnu.org>
parents:
17326
diff
changeset
|
1698 |
73012b195cf3
(DOWNCASE): Return int, not Lisp_Object.
Karl Heuer <kwzh@gnu.org>
parents:
17326
diff
changeset
|
1699 /* Downcase a character, or make no change if that cannot be done. */ |
73012b195cf3
(DOWNCASE): Return int, not Lisp_Object.
Karl Heuer <kwzh@gnu.org>
parents:
17326
diff
changeset
|
1700 |
18006
d29a9b467ac9
(CHAR_TABLE_REF): Do not check validity of CT.
Kenichi Handa <handa@m17n.org>
parents:
17871
diff
changeset
|
1701 #define DOWNCASE(CH) \ |
d29a9b467ac9
(CHAR_TABLE_REF): Do not check validity of CT.
Kenichi Handa <handa@m17n.org>
parents:
17871
diff
changeset
|
1702 ((case_temp1 = (CH), \ |
d29a9b467ac9
(CHAR_TABLE_REF): Do not check validity of CT.
Kenichi Handa <handa@m17n.org>
parents:
17871
diff
changeset
|
1703 case_temp2 = CHAR_TABLE_REF (DOWNCASE_TABLE, case_temp1), \ |
d29a9b467ac9
(CHAR_TABLE_REF): Do not check validity of CT.
Kenichi Handa <handa@m17n.org>
parents:
17871
diff
changeset
|
1704 NATNUMP (case_temp2)) \ |
d29a9b467ac9
(CHAR_TABLE_REF): Do not check validity of CT.
Kenichi Handa <handa@m17n.org>
parents:
17871
diff
changeset
|
1705 ? XFASTINT (case_temp2) : case_temp1) |
17404
73012b195cf3
(DOWNCASE): Return int, not Lisp_Object.
Karl Heuer <kwzh@gnu.org>
parents:
17326
diff
changeset
|
1706 |
302 | 1707 /* 1 if CH is upper case. */ |
1708 | |
18111
4bd5e5e3db42
(concat3, get_truename_buffer): Declare them.
Richard M. Stallman <rms@gnu.org>
parents:
18006
diff
changeset
|
1709 #define UPPERCASEP(CH) (DOWNCASE (CH) != (CH)) |
17404
73012b195cf3
(DOWNCASE): Return int, not Lisp_Object.
Karl Heuer <kwzh@gnu.org>
parents:
17326
diff
changeset
|
1710 |
73012b195cf3
(DOWNCASE): Return int, not Lisp_Object.
Karl Heuer <kwzh@gnu.org>
parents:
17326
diff
changeset
|
1711 /* 1 if CH is neither upper nor lower case. */ |
73012b195cf3
(DOWNCASE): Return int, not Lisp_Object.
Karl Heuer <kwzh@gnu.org>
parents:
17326
diff
changeset
|
1712 |
18006
d29a9b467ac9
(CHAR_TABLE_REF): Do not check validity of CT.
Kenichi Handa <handa@m17n.org>
parents:
17871
diff
changeset
|
1713 #define NOCASEP(CH) (UPCASE1 (CH) == (CH)) |
302 | 1714 |
1715 /* 1 if CH is lower case. */ | |
1716 | |
17289
83cc6a193391
(CHAR_TABLE_REF): Fix syntax error.
Karl Heuer <kwzh@gnu.org>
parents:
17188
diff
changeset
|
1717 #define LOWERCASEP(CH) (!UPPERCASEP (CH) && !NOCASEP(CH)) |
302 | 1718 |
1719 /* Upcase a character, or make no change if that cannot be done. */ | |
1720 | |
17289
83cc6a193391
(CHAR_TABLE_REF): Fix syntax error.
Karl Heuer <kwzh@gnu.org>
parents:
17188
diff
changeset
|
1721 #define UPCASE(CH) (!UPPERCASEP (CH) ? UPCASE1 (CH) : (CH)) |
302 | 1722 |
1723 /* Upcase a character known to be not upper case. */ | |
1724 | |
18006
d29a9b467ac9
(CHAR_TABLE_REF): Do not check validity of CT.
Kenichi Handa <handa@m17n.org>
parents:
17871
diff
changeset
|
1725 #define UPCASE1(CH) \ |
d29a9b467ac9
(CHAR_TABLE_REF): Do not check validity of CT.
Kenichi Handa <handa@m17n.org>
parents:
17871
diff
changeset
|
1726 ((case_temp1 = (CH), \ |
d29a9b467ac9
(CHAR_TABLE_REF): Do not check validity of CT.
Kenichi Handa <handa@m17n.org>
parents:
17871
diff
changeset
|
1727 case_temp2 = CHAR_TABLE_REF (UPCASE_TABLE, case_temp1), \ |
d29a9b467ac9
(CHAR_TABLE_REF): Do not check validity of CT.
Kenichi Handa <handa@m17n.org>
parents:
17871
diff
changeset
|
1728 NATNUMP (case_temp2)) \ |
d29a9b467ac9
(CHAR_TABLE_REF): Do not check validity of CT.
Kenichi Handa <handa@m17n.org>
parents:
17871
diff
changeset
|
1729 ? XFASTINT (case_temp2) : case_temp1) |
302 | 1730 |
13241
b1d118fb7b3e
(UPCASE_TABLE): Definition deleted.
Richard M. Stallman <rms@gnu.org>
parents:
13202
diff
changeset
|
1731 extern Lisp_Object Vascii_downcase_table; |
302 | 1732 |
10316
272f15eddaca
(enum Lisp_Type): Delete Lisp_Buffer.
Richard M. Stallman <rms@gnu.org>
parents:
10292
diff
changeset
|
1733 /* Number of bytes of structure consed since last GC. */ |
302 | 1734 |
1735 extern int consing_since_gc; | |
1736 | |
10316
272f15eddaca
(enum Lisp_Type): Delete Lisp_Buffer.
Richard M. Stallman <rms@gnu.org>
parents:
10292
diff
changeset
|
1737 /* Threshold for doing another gc. */ |
302 | 1738 |
43713
f92c4d87863a
Change defvar_int def and vars to use EMACS_INT instead of just int.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
43699
diff
changeset
|
1739 extern EMACS_INT gc_cons_threshold; |
302 | 1740 |
10316
272f15eddaca
(enum Lisp_Type): Delete Lisp_Buffer.
Richard M. Stallman <rms@gnu.org>
parents:
10292
diff
changeset
|
1741 /* Structure for recording stack slots that need marking. */ |
302 | 1742 |
1743 /* This is a chain of structures, each of which points at a Lisp_Object variable | |
1744 whose value should be marked in garbage collection. | |
1745 Normally every link of the chain is an automatic variable of a function, | |
1746 and its `val' points to some argument or local variable of the function. | |
1747 On exit to the function, the chain is set back to the value it had on entry. | |
4826 | 1748 This way, no link remains in the chain when the stack frame containing the |
1749 link disappears. | |
302 | 1750 |
1751 Every function that can call Feval must protect in this fashion all | |
10316
272f15eddaca
(enum Lisp_Type): Delete Lisp_Buffer.
Richard M. Stallman <rms@gnu.org>
parents:
10292
diff
changeset
|
1752 Lisp_Object variables whose contents will be used again. */ |
302 | 1753 |
1754 extern struct gcpro *gcprolist; | |
1755 | |
1756 struct gcpro | |
32065
4f8ce7eb45a5
(wrong_type_argument): Remove NO_RETURN, the function can
Gerd Moellmann <gerd@gnu.org>
parents:
31991
diff
changeset
|
1757 { |
4f8ce7eb45a5
(wrong_type_argument): Remove NO_RETURN, the function can
Gerd Moellmann <gerd@gnu.org>
parents:
31991
diff
changeset
|
1758 struct gcpro *next; |
45623
0e92d219e195
(current_column): Now returns float.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents:
45545
diff
changeset
|
1759 |
32065
4f8ce7eb45a5
(wrong_type_argument): Remove NO_RETURN, the function can
Gerd Moellmann <gerd@gnu.org>
parents:
31991
diff
changeset
|
1760 /* Address of first protected variable. */ |
4f8ce7eb45a5
(wrong_type_argument): Remove NO_RETURN, the function can
Gerd Moellmann <gerd@gnu.org>
parents:
31991
diff
changeset
|
1761 volatile Lisp_Object *var; |
45623
0e92d219e195
(current_column): Now returns float.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents:
45545
diff
changeset
|
1762 |
32065
4f8ce7eb45a5
(wrong_type_argument): Remove NO_RETURN, the function can
Gerd Moellmann <gerd@gnu.org>
parents:
31991
diff
changeset
|
1763 /* Number of consecutive protected variables. */ |
4f8ce7eb45a5
(wrong_type_argument): Remove NO_RETURN, the function can
Gerd Moellmann <gerd@gnu.org>
parents:
31991
diff
changeset
|
1764 int nvars; |
45623
0e92d219e195
(current_column): Now returns float.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents:
45545
diff
changeset
|
1765 |
26296
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1766 #ifdef DEBUG_GCPRO |
32065
4f8ce7eb45a5
(wrong_type_argument): Remove NO_RETURN, the function can
Gerd Moellmann <gerd@gnu.org>
parents:
31991
diff
changeset
|
1767 int level; |
26296
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1768 #endif |
32065
4f8ce7eb45a5
(wrong_type_argument): Remove NO_RETURN, the function can
Gerd Moellmann <gerd@gnu.org>
parents:
31991
diff
changeset
|
1769 }; |
302 | 1770 |
27741
ef732a190ead
(GC_USE_GCPROS_AS_BEFORE, GC_MAKE_GCPROS_NOOPS)
Gerd Moellmann <gerd@gnu.org>
parents:
27727
diff
changeset
|
1771 /* Values of GC_MARK_STACK during compilation: |
ef732a190ead
(GC_USE_GCPROS_AS_BEFORE, GC_MAKE_GCPROS_NOOPS)
Gerd Moellmann <gerd@gnu.org>
parents:
27727
diff
changeset
|
1772 |
ef732a190ead
(GC_USE_GCPROS_AS_BEFORE, GC_MAKE_GCPROS_NOOPS)
Gerd Moellmann <gerd@gnu.org>
parents:
27727
diff
changeset
|
1773 0 Use GCPRO as before |
ef732a190ead
(GC_USE_GCPROS_AS_BEFORE, GC_MAKE_GCPROS_NOOPS)
Gerd Moellmann <gerd@gnu.org>
parents:
27727
diff
changeset
|
1774 1 Do the real thing, make GCPROs and UNGCPRO no-ops. |
ef732a190ead
(GC_USE_GCPROS_AS_BEFORE, GC_MAKE_GCPROS_NOOPS)
Gerd Moellmann <gerd@gnu.org>
parents:
27727
diff
changeset
|
1775 2 Mark the stack, and check that everything GCPRO'd is |
ef732a190ead
(GC_USE_GCPROS_AS_BEFORE, GC_MAKE_GCPROS_NOOPS)
Gerd Moellmann <gerd@gnu.org>
parents:
27727
diff
changeset
|
1776 marked. |
ef732a190ead
(GC_USE_GCPROS_AS_BEFORE, GC_MAKE_GCPROS_NOOPS)
Gerd Moellmann <gerd@gnu.org>
parents:
27727
diff
changeset
|
1777 3 Mark using GCPRO's, mark stack last, and count how many |
ef732a190ead
(GC_USE_GCPROS_AS_BEFORE, GC_MAKE_GCPROS_NOOPS)
Gerd Moellmann <gerd@gnu.org>
parents:
27727
diff
changeset
|
1778 dead objects are kept alive. */ |
ef732a190ead
(GC_USE_GCPROS_AS_BEFORE, GC_MAKE_GCPROS_NOOPS)
Gerd Moellmann <gerd@gnu.org>
parents:
27727
diff
changeset
|
1779 |
ef732a190ead
(GC_USE_GCPROS_AS_BEFORE, GC_MAKE_GCPROS_NOOPS)
Gerd Moellmann <gerd@gnu.org>
parents:
27727
diff
changeset
|
1780 |
ef732a190ead
(GC_USE_GCPROS_AS_BEFORE, GC_MAKE_GCPROS_NOOPS)
Gerd Moellmann <gerd@gnu.org>
parents:
27727
diff
changeset
|
1781 #define GC_USE_GCPROS_AS_BEFORE 0 |
ef732a190ead
(GC_USE_GCPROS_AS_BEFORE, GC_MAKE_GCPROS_NOOPS)
Gerd Moellmann <gerd@gnu.org>
parents:
27727
diff
changeset
|
1782 #define GC_MAKE_GCPROS_NOOPS 1 |
ef732a190ead
(GC_USE_GCPROS_AS_BEFORE, GC_MAKE_GCPROS_NOOPS)
Gerd Moellmann <gerd@gnu.org>
parents:
27727
diff
changeset
|
1783 #define GC_MARK_STACK_CHECK_GCPROS 2 |
ef732a190ead
(GC_USE_GCPROS_AS_BEFORE, GC_MAKE_GCPROS_NOOPS)
Gerd Moellmann <gerd@gnu.org>
parents:
27727
diff
changeset
|
1784 #define GC_USE_GCPROS_CHECK_ZOMBIES 3 |
ef732a190ead
(GC_USE_GCPROS_AS_BEFORE, GC_MAKE_GCPROS_NOOPS)
Gerd Moellmann <gerd@gnu.org>
parents:
27727
diff
changeset
|
1785 |
ef732a190ead
(GC_USE_GCPROS_AS_BEFORE, GC_MAKE_GCPROS_NOOPS)
Gerd Moellmann <gerd@gnu.org>
parents:
27727
diff
changeset
|
1786 #ifndef GC_MARK_STACK |
ef732a190ead
(GC_USE_GCPROS_AS_BEFORE, GC_MAKE_GCPROS_NOOPS)
Gerd Moellmann <gerd@gnu.org>
parents:
27727
diff
changeset
|
1787 #define GC_MARK_STACK GC_USE_GCPROS_AS_BEFORE |
ef732a190ead
(GC_USE_GCPROS_AS_BEFORE, GC_MAKE_GCPROS_NOOPS)
Gerd Moellmann <gerd@gnu.org>
parents:
27727
diff
changeset
|
1788 #endif |
ef732a190ead
(GC_USE_GCPROS_AS_BEFORE, GC_MAKE_GCPROS_NOOPS)
Gerd Moellmann <gerd@gnu.org>
parents:
27727
diff
changeset
|
1789 |
ef732a190ead
(GC_USE_GCPROS_AS_BEFORE, GC_MAKE_GCPROS_NOOPS)
Gerd Moellmann <gerd@gnu.org>
parents:
27727
diff
changeset
|
1790 #if GC_MARK_STACK == GC_MAKE_GCPROS_NOOPS |
ef732a190ead
(GC_USE_GCPROS_AS_BEFORE, GC_MAKE_GCPROS_NOOPS)
Gerd Moellmann <gerd@gnu.org>
parents:
27727
diff
changeset
|
1791 |
41659
e37febff5532
(GCPRO1, GCPRO2, GCPRO3, GCPRO4, GCPRO5):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
41615
diff
changeset
|
1792 /* Do something silly with gcproN vars just so gcc shuts up. */ |
48540 | 1793 /* You get warnings from MIPSPro... */ |
41659
e37febff5532
(GCPRO1, GCPRO2, GCPRO3, GCPRO4, GCPRO5):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
41615
diff
changeset
|
1794 |
e37febff5532
(GCPRO1, GCPRO2, GCPRO3, GCPRO4, GCPRO5):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
41615
diff
changeset
|
1795 #define GCPRO1(varname) ((void) gcpro1) |
45623
0e92d219e195
(current_column): Now returns float.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents:
45545
diff
changeset
|
1796 #define GCPRO2(varname1, varname2)(((void) gcpro2, (void) gcpro1)) |
41659
e37febff5532
(GCPRO1, GCPRO2, GCPRO3, GCPRO4, GCPRO5):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
41615
diff
changeset
|
1797 #define GCPRO3(varname1, varname2, varname3) \ |
e37febff5532
(GCPRO1, GCPRO2, GCPRO3, GCPRO4, GCPRO5):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
41615
diff
changeset
|
1798 (((void) gcpro3, (void) gcpro2, (void) gcpro1)) |
e37febff5532
(GCPRO1, GCPRO2, GCPRO3, GCPRO4, GCPRO5):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
41615
diff
changeset
|
1799 #define GCPRO4(varname1, varname2, varname3, varname4) \ |
e37febff5532
(GCPRO1, GCPRO2, GCPRO3, GCPRO4, GCPRO5):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
41615
diff
changeset
|
1800 (((void) gcpro4, (void) gcpro3, (void) gcpro2, (void) gcpro1)) |
e37febff5532
(GCPRO1, GCPRO2, GCPRO3, GCPRO4, GCPRO5):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
41615
diff
changeset
|
1801 #define GCPRO5(varname1, varname2, varname3, varname4, varname5) \ |
e37febff5532
(GCPRO1, GCPRO2, GCPRO3, GCPRO4, GCPRO5):
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
41615
diff
changeset
|
1802 (((void) gcpro5, (void) gcpro4, (void) gcpro3, (void) gcpro2, (void) gcpro1)) |
43616 | 1803 #define GCPRO6(varname1, varname2, varname3, varname4, varname5, varname6) \ |
1804 (((void) gcpro6, (void) gcpro5, (void) gcpro4, (void) gcpro3, (void) gcpro2, (void) gcpro1)) | |
27741
ef732a190ead
(GC_USE_GCPROS_AS_BEFORE, GC_MAKE_GCPROS_NOOPS)
Gerd Moellmann <gerd@gnu.org>
parents:
27727
diff
changeset
|
1805 #define UNGCPRO ((void) 0) |
ef732a190ead
(GC_USE_GCPROS_AS_BEFORE, GC_MAKE_GCPROS_NOOPS)
Gerd Moellmann <gerd@gnu.org>
parents:
27727
diff
changeset
|
1806 |
ef732a190ead
(GC_USE_GCPROS_AS_BEFORE, GC_MAKE_GCPROS_NOOPS)
Gerd Moellmann <gerd@gnu.org>
parents:
27727
diff
changeset
|
1807 #else /* GC_MARK_STACK != GC_MAKE_GCPROS_NOOPS */ |
ef732a190ead
(GC_USE_GCPROS_AS_BEFORE, GC_MAKE_GCPROS_NOOPS)
Gerd Moellmann <gerd@gnu.org>
parents:
27727
diff
changeset
|
1808 |
26296
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1809 #ifndef DEBUG_GCPRO |
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1810 |
302 | 1811 #define GCPRO1(varname) \ |
1812 {gcpro1.next = gcprolist; gcpro1.var = &varname; gcpro1.nvars = 1; \ | |
1813 gcprolist = &gcpro1; } | |
1814 | |
1815 #define GCPRO2(varname1, varname2) \ | |
1816 {gcpro1.next = gcprolist; gcpro1.var = &varname1; gcpro1.nvars = 1; \ | |
1817 gcpro2.next = &gcpro1; gcpro2.var = &varname2; gcpro2.nvars = 1; \ | |
1818 gcprolist = &gcpro2; } | |
1819 | |
1820 #define GCPRO3(varname1, varname2, varname3) \ | |
1821 {gcpro1.next = gcprolist; gcpro1.var = &varname1; gcpro1.nvars = 1; \ | |
1822 gcpro2.next = &gcpro1; gcpro2.var = &varname2; gcpro2.nvars = 1; \ | |
1823 gcpro3.next = &gcpro2; gcpro3.var = &varname3; gcpro3.nvars = 1; \ | |
1824 gcprolist = &gcpro3; } | |
1825 | |
1826 #define GCPRO4(varname1, varname2, varname3, varname4) \ | |
1827 {gcpro1.next = gcprolist; gcpro1.var = &varname1; gcpro1.nvars = 1; \ | |
1828 gcpro2.next = &gcpro1; gcpro2.var = &varname2; gcpro2.nvars = 1; \ | |
1829 gcpro3.next = &gcpro2; gcpro3.var = &varname3; gcpro3.nvars = 1; \ | |
1830 gcpro4.next = &gcpro3; gcpro4.var = &varname4; gcpro4.nvars = 1; \ | |
1831 gcprolist = &gcpro4; } | |
1832 | |
8009
abbe65c17b55
(RETURN_UNGCPRO): Swallow semicolon.
Richard M. Stallman <rms@gnu.org>
parents:
7906
diff
changeset
|
1833 #define GCPRO5(varname1, varname2, varname3, varname4, varname5) \ |
abbe65c17b55
(RETURN_UNGCPRO): Swallow semicolon.
Richard M. Stallman <rms@gnu.org>
parents:
7906
diff
changeset
|
1834 {gcpro1.next = gcprolist; gcpro1.var = &varname1; gcpro1.nvars = 1; \ |
abbe65c17b55
(RETURN_UNGCPRO): Swallow semicolon.
Richard M. Stallman <rms@gnu.org>
parents:
7906
diff
changeset
|
1835 gcpro2.next = &gcpro1; gcpro2.var = &varname2; gcpro2.nvars = 1; \ |
abbe65c17b55
(RETURN_UNGCPRO): Swallow semicolon.
Richard M. Stallman <rms@gnu.org>
parents:
7906
diff
changeset
|
1836 gcpro3.next = &gcpro2; gcpro3.var = &varname3; gcpro3.nvars = 1; \ |
abbe65c17b55
(RETURN_UNGCPRO): Swallow semicolon.
Richard M. Stallman <rms@gnu.org>
parents:
7906
diff
changeset
|
1837 gcpro4.next = &gcpro3; gcpro4.var = &varname4; gcpro4.nvars = 1; \ |
abbe65c17b55
(RETURN_UNGCPRO): Swallow semicolon.
Richard M. Stallman <rms@gnu.org>
parents:
7906
diff
changeset
|
1838 gcpro5.next = &gcpro4; gcpro5.var = &varname5; gcpro5.nvars = 1; \ |
abbe65c17b55
(RETURN_UNGCPRO): Swallow semicolon.
Richard M. Stallman <rms@gnu.org>
parents:
7906
diff
changeset
|
1839 gcprolist = &gcpro5; } |
abbe65c17b55
(RETURN_UNGCPRO): Swallow semicolon.
Richard M. Stallman <rms@gnu.org>
parents:
7906
diff
changeset
|
1840 |
43616 | 1841 #define GCPRO6(varname1, varname2, varname3, varname4, varname5, varname6) \ |
1842 {gcpro1.next = gcprolist; gcpro1.var = &varname1; gcpro1.nvars = 1; \ | |
1843 gcpro2.next = &gcpro1; gcpro2.var = &varname2; gcpro2.nvars = 1; \ | |
1844 gcpro3.next = &gcpro2; gcpro3.var = &varname3; gcpro3.nvars = 1; \ | |
1845 gcpro4.next = &gcpro3; gcpro4.var = &varname4; gcpro4.nvars = 1; \ | |
1846 gcpro5.next = &gcpro4; gcpro5.var = &varname5; gcpro5.nvars = 1; \ | |
1847 gcpro6.next = &gcpro5; gcpro6.var = &varname6; gcpro6.nvars = 1; \ | |
1848 gcprolist = &gcpro6; } | |
1849 | |
302 | 1850 #define UNGCPRO (gcprolist = gcpro1.next) |
1851 | |
26296
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1852 #else |
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1853 |
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1854 extern int gcpro_level; |
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1855 |
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1856 #define GCPRO1(varname) \ |
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1857 {gcpro1.next = gcprolist; gcpro1.var = &varname; gcpro1.nvars = 1; \ |
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1858 gcpro1.level = gcpro_level++; \ |
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1859 gcprolist = &gcpro1; } |
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1860 |
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1861 #define GCPRO2(varname1, varname2) \ |
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1862 {gcpro1.next = gcprolist; gcpro1.var = &varname1; gcpro1.nvars = 1; \ |
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1863 gcpro1.level = gcpro_level; \ |
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1864 gcpro2.next = &gcpro1; gcpro2.var = &varname2; gcpro2.nvars = 1; \ |
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1865 gcpro2.level = gcpro_level++; \ |
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1866 gcprolist = &gcpro2; } |
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1867 |
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1868 #define GCPRO3(varname1, varname2, varname3) \ |
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1869 {gcpro1.next = gcprolist; gcpro1.var = &varname1; gcpro1.nvars = 1; \ |
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1870 gcpro1.level = gcpro_level; \ |
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1871 gcpro2.next = &gcpro1; gcpro2.var = &varname2; gcpro2.nvars = 1; \ |
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1872 gcpro3.next = &gcpro2; gcpro3.var = &varname3; gcpro3.nvars = 1; \ |
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1873 gcpro3.level = gcpro_level++; \ |
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1874 gcprolist = &gcpro3; } |
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1875 |
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1876 #define GCPRO4(varname1, varname2, varname3, varname4) \ |
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1877 {gcpro1.next = gcprolist; gcpro1.var = &varname1; gcpro1.nvars = 1; \ |
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1878 gcpro1.level = gcpro_level; \ |
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1879 gcpro2.next = &gcpro1; gcpro2.var = &varname2; gcpro2.nvars = 1; \ |
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1880 gcpro3.next = &gcpro2; gcpro3.var = &varname3; gcpro3.nvars = 1; \ |
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1881 gcpro4.next = &gcpro3; gcpro4.var = &varname4; gcpro4.nvars = 1; \ |
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1882 gcpro4.level = gcpro_level++; \ |
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1883 gcprolist = &gcpro4; } |
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1884 |
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1885 #define GCPRO5(varname1, varname2, varname3, varname4, varname5) \ |
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1886 {gcpro1.next = gcprolist; gcpro1.var = &varname1; gcpro1.nvars = 1; \ |
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1887 gcpro1.level = gcpro_level; \ |
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1888 gcpro2.next = &gcpro1; gcpro2.var = &varname2; gcpro2.nvars = 1; \ |
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1889 gcpro3.next = &gcpro2; gcpro3.var = &varname3; gcpro3.nvars = 1; \ |
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1890 gcpro4.next = &gcpro3; gcpro4.var = &varname4; gcpro4.nvars = 1; \ |
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1891 gcpro5.next = &gcpro4; gcpro5.var = &varname5; gcpro5.nvars = 1; \ |
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1892 gcpro5.level = gcpro_level++; \ |
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1893 gcprolist = &gcpro5; } |
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1894 |
43616 | 1895 #define GCPRO6(varname1, varname2, varname3, varname4, varname5, varname6) \ |
1896 {gcpro1.next = gcprolist; gcpro1.var = &varname1; gcpro1.nvars = 1; \ | |
1897 gcpro1.level = gcpro_level; \ | |
1898 gcpro2.next = &gcpro1; gcpro2.var = &varname2; gcpro2.nvars = 1; \ | |
1899 gcpro3.next = &gcpro2; gcpro3.var = &varname3; gcpro3.nvars = 1; \ | |
1900 gcpro4.next = &gcpro3; gcpro4.var = &varname4; gcpro4.nvars = 1; \ | |
1901 gcpro5.next = &gcpro4; gcpro5.var = &varname5; gcpro5.nvars = 1; \ | |
1902 gcpro6.next = &gcpro5; gcpro6.var = &varname6; gcpro6.nvars = 1; \ | |
1903 gcpro6.level = gcpro_level++; \ | |
1904 gcprolist = &gcpro6; } | |
1905 | |
26296
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1906 #define UNGCPRO \ |
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1907 ((--gcpro_level != gcpro1.level) \ |
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1908 ? (abort (), 0) \ |
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1909 : ((gcprolist = gcpro1.next), 0)) |
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1910 |
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1911 #endif /* DEBUG_GCPRO */ |
27741
ef732a190ead
(GC_USE_GCPROS_AS_BEFORE, GC_MAKE_GCPROS_NOOPS)
Gerd Moellmann <gerd@gnu.org>
parents:
27727
diff
changeset
|
1912 #endif /* GC_MARK_STACK != GC_MAKE_GCPROS_NOOPS */ |
ef732a190ead
(GC_USE_GCPROS_AS_BEFORE, GC_MAKE_GCPROS_NOOPS)
Gerd Moellmann <gerd@gnu.org>
parents:
27727
diff
changeset
|
1913 |
26296
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1914 |
8560 | 1915 /* Evaluate expr, UNGCPRO, and then return the value of expr. */ |
8009
abbe65c17b55
(RETURN_UNGCPRO): Swallow semicolon.
Richard M. Stallman <rms@gnu.org>
parents:
7906
diff
changeset
|
1916 #define RETURN_UNGCPRO(expr) \ |
25769
4399d55899d3
(RETURN_UNGCPRO): Use do-while (0) idiom.
Gerd Moellmann <gerd@gnu.org>
parents:
25765
diff
changeset
|
1917 do \ |
8009
abbe65c17b55
(RETURN_UNGCPRO): Swallow semicolon.
Richard M. Stallman <rms@gnu.org>
parents:
7906
diff
changeset
|
1918 { \ |
abbe65c17b55
(RETURN_UNGCPRO): Swallow semicolon.
Richard M. Stallman <rms@gnu.org>
parents:
7906
diff
changeset
|
1919 Lisp_Object ret_ungc_val; \ |
abbe65c17b55
(RETURN_UNGCPRO): Swallow semicolon.
Richard M. Stallman <rms@gnu.org>
parents:
7906
diff
changeset
|
1920 ret_ungc_val = (expr); \ |
abbe65c17b55
(RETURN_UNGCPRO): Swallow semicolon.
Richard M. Stallman <rms@gnu.org>
parents:
7906
diff
changeset
|
1921 UNGCPRO; \ |
abbe65c17b55
(RETURN_UNGCPRO): Swallow semicolon.
Richard M. Stallman <rms@gnu.org>
parents:
7906
diff
changeset
|
1922 return ret_ungc_val; \ |
abbe65c17b55
(RETURN_UNGCPRO): Swallow semicolon.
Richard M. Stallman <rms@gnu.org>
parents:
7906
diff
changeset
|
1923 } \ |
25769
4399d55899d3
(RETURN_UNGCPRO): Use do-while (0) idiom.
Gerd Moellmann <gerd@gnu.org>
parents:
25765
diff
changeset
|
1924 while (0) |
26296
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1925 |
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1926 /* Call staticpro (&var) to protect static variable `var'. */ |
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1927 |
e5c745f5a9fc
(struct gcpro) [DEBUG_GCPRO]: New field `level'.
Richard M. Stallman <rms@gnu.org>
parents:
26275
diff
changeset
|
1928 void staticpro P_ ((Lisp_Object *)); |
302 | 1929 |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
1930 /* Declare a Lisp-callable function. The MAXARGS parameter has the same |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
1931 meaning as in the DEFUN macro, and is used to construct a prototype. */ |
29443 | 1932 #if (!defined (__STDC__) && !defined (PROTOTYPES)) \ |
1933 || defined (USE_NONANSI_DEFUN) | |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
1934 #define EXFUN(fnname, maxargs) \ |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
1935 extern Lisp_Object fnname () |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
1936 #else |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
1937 /* We can use the same trick as in the DEFUN macro to generate the |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
1938 appropriate prototype. */ |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
1939 #define EXFUN(fnname, maxargs) \ |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
1940 extern Lisp_Object fnname DEFUN_ARGS_ ## maxargs |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
1941 #endif |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
1942 |
20297
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
1943 /* Forward declarations for prototypes. */ |
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
1944 struct window; |
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
1945 struct frame; |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
1946 |
302 | 1947 /* Defined in data.c */ |
1948 extern Lisp_Object Qnil, Qt, Qquote, Qlambda, Qsubr, Qunbound; | |
1949 extern Lisp_Object Qerror_conditions, Qerror_message, Qtop_level; | |
1950 extern Lisp_Object Qerror, Qquit, Qwrong_type_argument, Qargs_out_of_range; | |
1951 extern Lisp_Object Qvoid_variable, Qvoid_function; | |
1952 extern Lisp_Object Qsetting_constant, Qinvalid_read_syntax; | |
1953 extern Lisp_Object Qinvalid_function, Qwrong_number_of_arguments, Qno_catch; | |
53111 | 1954 extern Lisp_Object Qend_of_file, Qarith_error, Qmark_inactive; |
302 | 1955 extern Lisp_Object Qbeginning_of_buffer, Qend_of_buffer, Qbuffer_read_only; |
53111 | 1956 extern Lisp_Object Qtext_read_only; |
1957 | |
1958 extern Lisp_Object Qintegerp, Qnatnump, Qwholenump, Qsymbolp, Qlistp, Qconsp; | |
1959 extern Lisp_Object Qstringp, Qarrayp, Qsequencep, Qbufferp; | |
1960 extern Lisp_Object Qchar_or_string_p, Qmarkerp, Qinteger_or_marker_p, Qvectorp; | |
1961 extern Lisp_Object Qbuffer_or_string_p; | |
1962 extern Lisp_Object Qboundp, Qfboundp; | |
1963 extern Lisp_Object Qchar_table_p, Qvector_or_char_table_p; | |
1964 | |
1965 extern Lisp_Object Qcdr; | |
302 | 1966 |
2653
d547e1a7eb9b
* lisp.h (CHAR_ALT, CHAR_SUPER, CHAR_HYPER): New constants, in
Jim Blandy <jimb@redhat.com>
parents:
2605
diff
changeset
|
1967 extern Lisp_Object Qrange_error, Qdomain_error, Qsingularity_error; |
d547e1a7eb9b
* lisp.h (CHAR_ALT, CHAR_SUPER, CHAR_HYPER): New constants, in
Jim Blandy <jimb@redhat.com>
parents:
2605
diff
changeset
|
1968 extern Lisp_Object Qoverflow_error, Qunderflow_error; |
2155
3ec142562a65
(Qrange_error, Qdomain_error, Qsingularity_error):
Richard M. Stallman <rms@gnu.org>
parents:
2014
diff
changeset
|
1969 |
53111 | 1970 extern Lisp_Object Qfloatp; |
1971 extern Lisp_Object Qnumberp, Qnumber_or_marker_p; | |
1972 | |
1973 extern Lisp_Object Qinteger; | |
302 | 1974 |
39766
2a0aa5b942d7
(circular_list_error): Add prototype.
Gerd Moellmann <gerd@gnu.org>
parents:
39710
diff
changeset
|
1975 extern void circular_list_error P_ ((Lisp_Object)); |
2a0aa5b942d7
(circular_list_error): Add prototype.
Gerd Moellmann <gerd@gnu.org>
parents:
39710
diff
changeset
|
1976 |
53111 | 1977 /* Defined in frame.c */ |
1978 extern Lisp_Object Qframep; | |
1979 | |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
1980 EXFUN (Feq, 2); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
1981 EXFUN (Fnull, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
1982 EXFUN (Flistp, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
1983 EXFUN (Fconsp, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
1984 EXFUN (Fatom, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
1985 EXFUN (Fnlistp, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
1986 EXFUN (Fintegerp, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
1987 EXFUN (Fnatnump, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
1988 EXFUN (Fsymbolp, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
1989 EXFUN (Fvectorp, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
1990 EXFUN (Fstringp, 1); |
20625
a9c4bf3f4e46
(STRING_MULTIBYTE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
20569
diff
changeset
|
1991 EXFUN (Fmultibyte_string_p, 1); |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
1992 EXFUN (Farrayp, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
1993 EXFUN (Fsequencep, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
1994 EXFUN (Fbufferp, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
1995 EXFUN (Fmarkerp, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
1996 EXFUN (Fsubrp, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
1997 EXFUN (Fchar_or_string_p, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
1998 EXFUN (Finteger_or_marker_p, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
1999 EXFUN (Ffloatp, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2000 EXFUN (Finteger_or_floatp, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2001 EXFUN (Finteger_or_float_or_marker_p, 1); |
302 | 2002 |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2003 EXFUN (Fcar, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2004 EXFUN (Fcar_safe, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2005 EXFUN (Fcdr, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2006 EXFUN (Fcdr_safe, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2007 EXFUN (Fsetcar, 2); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2008 EXFUN (Fsetcdr, 2); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2009 EXFUN (Fboundp, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2010 EXFUN (Ffboundp, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2011 EXFUN (Fmakunbound, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2012 EXFUN (Ffmakunbound, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2013 EXFUN (Fsymbol_function, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2014 EXFUN (Fsymbol_plist, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2015 EXFUN (Fsymbol_name, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2016 extern Lisp_Object indirect_function P_ ((Lisp_Object)); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2017 EXFUN (Findirect_function, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2018 EXFUN (Ffset, 2); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2019 EXFUN (Fsetplist, 2); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2020 EXFUN (Fsymbol_value, 1); |
19224
db9418ba5d32
(Flocal_variable_p, Ffind_operation_coding_system): Declared.
Richard M. Stallman <rms@gnu.org>
parents:
19119
diff
changeset
|
2021 extern Lisp_Object find_symbol_value P_ ((Lisp_Object)); |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2022 EXFUN (Fset, 2); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2023 EXFUN (Fdefault_value, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2024 EXFUN (Fset_default, 2); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2025 EXFUN (Fdefault_boundp, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2026 EXFUN (Fmake_local_variable, 1); |
19224
db9418ba5d32
(Flocal_variable_p, Ffind_operation_coding_system): Declared.
Richard M. Stallman <rms@gnu.org>
parents:
19119
diff
changeset
|
2027 EXFUN (Flocal_variable_p, 2); |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2028 EXFUN (Flocal_variable_if_set_p, 2); |
302 | 2029 |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2030 EXFUN (Faref, 2); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2031 EXFUN (Faset, 3); |
302 | 2032 |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2033 EXFUN (Fstring_to_number, 2); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2034 EXFUN (Fnumber_to_string, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2035 EXFUN (Feqlsign, 2); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2036 EXFUN (Fgtr, 2); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2037 EXFUN (Flss, 2); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2038 EXFUN (Fgeq, 2); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2039 EXFUN (Fleq, 2); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2040 EXFUN (Fneq, 2); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2041 EXFUN (Fzerop, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2042 EXFUN (Fplus, MANY); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2043 EXFUN (Fminus, MANY); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2044 EXFUN (Ftimes, MANY); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2045 EXFUN (Fquo, MANY); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2046 EXFUN (Frem, 2); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2047 EXFUN (Fmax, MANY); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2048 EXFUN (Fmin, MANY); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2049 EXFUN (Flogand, MANY); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2050 EXFUN (Flogior, MANY); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2051 EXFUN (Flogxor, MANY); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2052 EXFUN (Flognot, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2053 EXFUN (Flsh, 2); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2054 EXFUN (Fash, 2); |
302 | 2055 |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2056 EXFUN (Fadd1, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2057 EXFUN (Fsub1, 1); |
34154
88440ae23652
(Fmake_variable_buffer_local, Fbuffer_file_name): Declare.
Ken Raeburn <raeburn@raeburn.org>
parents:
33508
diff
changeset
|
2058 EXFUN (Fmake_variable_buffer_local, 1); |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2059 |
39579
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
2060 extern Lisp_Object indirect_variable P_ ((Lisp_Object)); |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2061 extern Lisp_Object long_to_cons P_ ((unsigned long)); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2062 extern unsigned long cons_to_long P_ ((Lisp_Object)); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2063 extern void args_out_of_range P_ ((Lisp_Object, Lisp_Object)); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2064 extern void args_out_of_range_3 P_ ((Lisp_Object, Lisp_Object, Lisp_Object)); |
32065
4f8ce7eb45a5
(wrong_type_argument): Remove NO_RETURN, the function can
Gerd Moellmann <gerd@gnu.org>
parents:
31991
diff
changeset
|
2065 extern Lisp_Object wrong_type_argument P_ ((Lisp_Object, Lisp_Object)); |
36816
f8cbdb29cbe6
(store_symval_forwarding): Change prototype.
Gerd Moellmann <gerd@gnu.org>
parents:
36807
diff
changeset
|
2066 extern void store_symval_forwarding P_ ((Lisp_Object, Lisp_Object, |
f8cbdb29cbe6
(store_symval_forwarding): Change prototype.
Gerd Moellmann <gerd@gnu.org>
parents:
36807
diff
changeset
|
2067 Lisp_Object, struct buffer *)); |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2068 extern Lisp_Object do_symval_forwarding P_ ((Lisp_Object)); |
27292
d0aba668c5af
(set_internal): Enter the new arg.
Richard M. Stallman <rms@gnu.org>
parents:
27141
diff
changeset
|
2069 extern Lisp_Object set_internal P_ ((Lisp_Object, Lisp_Object, struct buffer *, int)); |
21931 | 2070 extern void syms_of_data P_ ((void)); |
2071 extern void init_data P_ ((void)); | |
29925
2fdc619acc14
(swap_in_global_binding): Declare.
Dave Love <fx@gnu.org>
parents:
29785
diff
changeset
|
2072 extern void swap_in_global_binding P_ ((Lisp_Object)); |
302 | 2073 |
11934
4b82fb5bde27
(Foverlay_start, Foverlay_end): Declare these functions.
Karl Heuer <kwzh@gnu.org>
parents:
11913
diff
changeset
|
2074 /* Defined in cmds.c */ |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2075 EXFUN (Fend_of_line, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2076 EXFUN (Fforward_char, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2077 EXFUN (Fforward_line, 1); |
20297
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2078 extern int internal_self_insert P_ ((int, int)); |
21931 | 2079 extern void syms_of_cmds P_ ((void)); |
2080 extern void keys_of_cmds P_ ((void)); | |
11934
4b82fb5bde27
(Foverlay_start, Foverlay_end): Declare these functions.
Karl Heuer <kwzh@gnu.org>
parents:
11913
diff
changeset
|
2081 |
17037
af637c0168ad
(CHARACTERBITS, GLYPH_MASK_REV_DIR): New macros.
Karl Heuer <kwzh@gnu.org>
parents:
16913
diff
changeset
|
2082 /* Defined in coding.c */ |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2083 EXFUN (Fcoding_system_p, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2084 EXFUN (Fcheck_coding_system, 1); |
19757
328233592e3b
(Fread_coding_system): Update decl.
Richard M. Stallman <rms@gnu.org>
parents:
19698
diff
changeset
|
2085 EXFUN (Fread_coding_system, 2); |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2086 EXFUN (Fread_non_nil_coding_system, 1); |
19224
db9418ba5d32
(Flocal_variable_p, Ffind_operation_coding_system): Declared.
Richard M. Stallman <rms@gnu.org>
parents:
19119
diff
changeset
|
2087 EXFUN (Ffind_operation_coding_system, MANY); |
42756
711b64458618
(adjust_after_replace_noundo)
Pavel Janík <Pavel@Janik.cz>
parents:
42466
diff
changeset
|
2088 EXFUN (Fupdate_coding_systems_internal, 0); |
20297
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2089 EXFUN (Fencode_coding_string, 3); |
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2090 EXFUN (Fdecode_coding_string, 3); |
46552
cb055b77d3c6
(STRING_COPYIN): New macro.
Ken Raeburn <raeburn@raeburn.org>
parents:
46471
diff
changeset
|
2091 extern Lisp_Object detect_coding_system P_ ((const unsigned char *, int, int, |
cb055b77d3c6
(STRING_COPYIN): New macro.
Ken Raeburn <raeburn@raeburn.org>
parents:
46471
diff
changeset
|
2092 int)); |
22791 | 2093 extern void init_coding P_ ((void)); |
21931 | 2094 extern void init_coding_once P_ ((void)); |
2095 extern void syms_of_coding P_ ((void)); | |
25769
4399d55899d3
(RETURN_UNGCPRO): Use do-while (0) idiom.
Gerd Moellmann <gerd@gnu.org>
parents:
25765
diff
changeset
|
2096 extern Lisp_Object code_convert_string_norecord P_ ((Lisp_Object, Lisp_Object, |
4399d55899d3
(RETURN_UNGCPRO): Use do-while (0) idiom.
Gerd Moellmann <gerd@gnu.org>
parents:
25765
diff
changeset
|
2097 int)); |
17037
af637c0168ad
(CHARACTERBITS, GLYPH_MASK_REV_DIR): New macros.
Karl Heuer <kwzh@gnu.org>
parents:
16913
diff
changeset
|
2098 |
19574 | 2099 /* Defined in charset.c */ |
43713
f92c4d87863a
Change defvar_int def and vars to use EMACS_INT instead of just int.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
43699
diff
changeset
|
2100 extern EMACS_INT nonascii_insert_offset; |
22123
42a41d39c4fb
(Vnonascii_translation_table): Name changed from
Kenichi Handa <handa@m17n.org>
parents:
21931
diff
changeset
|
2101 extern Lisp_Object Vnonascii_translation_table; |
19574 | 2102 EXFUN (Fchar_bytes, 1); |
21515 | 2103 EXFUN (Fchar_width, 1); |
27885 | 2104 EXFUN (Fstring, MANY); |
46471
028a5b2de9e4
(chars_in_text, multibyte_chars_in_text, copy_text):
Ken Raeburn <raeburn@raeburn.org>
parents:
46428
diff
changeset
|
2105 extern int chars_in_text P_ ((const unsigned char *, int)); |
028a5b2de9e4
(chars_in_text, multibyte_chars_in_text, copy_text):
Ken Raeburn <raeburn@raeburn.org>
parents:
46428
diff
changeset
|
2106 extern int multibyte_chars_in_text P_ ((const unsigned char *, int)); |
20708 | 2107 extern int unibyte_char_to_multibyte P_ ((int)); |
22928
db3229678ef9
(multibyte_char_to_unibyte): Extern it.
Kenichi Handa <handa@m17n.org>
parents:
22925
diff
changeset
|
2108 extern int multibyte_char_to_unibyte P_ ((int, Lisp_Object)); |
21038
9b33c6a5b4dc
(Vnonascii_translate_table, Qcharset): New variable decls.
Richard M. Stallman <rms@gnu.org>
parents:
20723
diff
changeset
|
2109 extern Lisp_Object Qcharset; |
21931 | 2110 extern void init_charset_once P_ ((void)); |
2111 extern void syms_of_charset P_ ((void)); | |
19574 | 2112 |
11934
4b82fb5bde27
(Foverlay_start, Foverlay_end): Declare these functions.
Karl Heuer <kwzh@gnu.org>
parents:
11913
diff
changeset
|
2113 /* Defined in syntax.c */ |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2114 EXFUN (Fforward_word, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2115 EXFUN (Fskip_chars_forward, 2); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2116 EXFUN (Fskip_chars_backward, 2); |
20297
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2117 EXFUN (Fsyntax_table_p, 1); |
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2118 EXFUN (Fsyntax_table, 0); |
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2119 EXFUN (Fset_syntax_table, 1); |
21931 | 2120 extern void init_syntax_once P_ ((void)); |
2121 extern void syms_of_syntax P_ ((void)); | |
11934
4b82fb5bde27
(Foverlay_start, Foverlay_end): Declare these functions.
Karl Heuer <kwzh@gnu.org>
parents:
11913
diff
changeset
|
2122 |
302 | 2123 /* Defined in fns.c */ |
31015
0a24ffcc4061
(set_time_zone_rule): Add prototype.
Gerd Moellmann <gerd@gnu.org>
parents:
30943
diff
changeset
|
2124 extern int use_dialog_box; |
29978
4b651d582c5f
(next_almost_prime): Add prototype.
Gerd Moellmann <gerd@gnu.org>
parents:
29940
diff
changeset
|
2125 extern int next_almost_prime P_ ((int)); |
28480
cbe58003b232
(larger_vector): Add prototype.
Gerd Moellmann <gerd@gnu.org>
parents:
28430
diff
changeset
|
2126 extern Lisp_Object larger_vector P_ ((Lisp_Object, int, Lisp_Object)); |
25765
416e6af8f06a
Add prototype for shrink_regexp_cache,
Gerd Moellmann <gerd@gnu.org>
parents:
25759
diff
changeset
|
2127 extern void sweep_weak_hash_tables P_ ((void)); |
302 | 2128 extern Lisp_Object Qstring_lessp; |
29443 | 2129 EXFUN (Foptimize_char_table, 1); |
302 | 2130 extern Lisp_Object Vfeatures; |
26865
87623e53b7c6
(QCtest, QCweakness, Qequal): Extern them.
Kenichi Handa <handa@m17n.org>
parents:
26742
diff
changeset
|
2131 extern Lisp_Object QCtest, QCweakness, Qequal; |
25017
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
2132 unsigned sxhash P_ ((Lisp_Object, int)); |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
2133 Lisp_Object make_hash_table P_ ((Lisp_Object, Lisp_Object, Lisp_Object, |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
2134 Lisp_Object, Lisp_Object, Lisp_Object, |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
2135 Lisp_Object)); |
25366
78de9d041747
Add prototype for copy_hash_table and Fcopy_hash_table.
Gerd Moellmann <gerd@gnu.org>
parents:
25353
diff
changeset
|
2136 Lisp_Object copy_hash_table P_ ((struct Lisp_Hash_Table *)); |
25017
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
2137 int hash_lookup P_ ((struct Lisp_Hash_Table *, Lisp_Object, unsigned *)); |
26865
87623e53b7c6
(QCtest, QCweakness, Qequal): Extern them.
Kenichi Handa <handa@m17n.org>
parents:
26742
diff
changeset
|
2138 int hash_put P_ ((struct Lisp_Hash_Table *, Lisp_Object, Lisp_Object, |
87623e53b7c6
(QCtest, QCweakness, Qequal): Extern them.
Kenichi Handa <handa@m17n.org>
parents:
26742
diff
changeset
|
2139 unsigned)); |
25017
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
2140 void hash_remove P_ ((struct Lisp_Hash_Table *, Lisp_Object)); |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
2141 void hash_clear P_ ((struct Lisp_Hash_Table *)); |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
2142 void remove_hash_entry P_ ((struct Lisp_Hash_Table *, int)); |
25748
6fddda6e635e
Add prototype for uninterrupt_malloc, memory_warnings,
Gerd Moellmann <gerd@gnu.org>
parents:
25737
diff
changeset
|
2143 extern void init_fns P_ ((void)); |
25017
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
2144 EXFUN (Fsxhash, 1); |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
2145 EXFUN (Fmake_hash_table, MANY); |
25366
78de9d041747
Add prototype for copy_hash_table and Fcopy_hash_table.
Gerd Moellmann <gerd@gnu.org>
parents:
25353
diff
changeset
|
2146 EXFUN (Fcopy_hash_table, 1); |
25017
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
2147 EXFUN (Fhash_table_count, 1); |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
2148 EXFUN (Fhash_table_rehash_size, 1); |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
2149 EXFUN (Fhash_table_rehash_threshold, 1); |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
2150 EXFUN (Fhash_table_size, 1); |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
2151 EXFUN (Fhash_table_test, 1); |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
2152 EXFUN (Fhash_table_weak, 1); |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
2153 EXFUN (Fhash_table_p, 1); |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
2154 EXFUN (Fclrhash, 1); |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
2155 EXFUN (Fgethash, 3); |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
2156 EXFUN (Fputhash, 3); |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
2157 EXFUN (Fremhash, 2); |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
2158 EXFUN (Fmaphash, 2); |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
2159 EXFUN (Fdefine_hash_table_test, 3); |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
2160 |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2161 EXFUN (Fidentity, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2162 EXFUN (Frandom, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2163 EXFUN (Flength, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2164 EXFUN (Fsafe_length, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2165 EXFUN (Fappend, MANY); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2166 EXFUN (Fconcat, MANY); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2167 EXFUN (Fvconcat, MANY); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2168 EXFUN (Fcopy_sequence, 1); |
21038
9b33c6a5b4dc
(Vnonascii_translate_table, Qcharset): New variable decls.
Richard M. Stallman <rms@gnu.org>
parents:
20723
diff
changeset
|
2169 EXFUN (Fstring_make_multibyte, 1); |
9b33c6a5b4dc
(Vnonascii_translate_table, Qcharset): New variable decls.
Richard M. Stallman <rms@gnu.org>
parents:
20723
diff
changeset
|
2170 EXFUN (Fstring_make_unibyte, 1); |
9b33c6a5b4dc
(Vnonascii_translate_table, Qcharset): New variable decls.
Richard M. Stallman <rms@gnu.org>
parents:
20723
diff
changeset
|
2171 EXFUN (Fstring_as_multibyte, 1); |
9b33c6a5b4dc
(Vnonascii_translate_table, Qcharset): New variable decls.
Richard M. Stallman <rms@gnu.org>
parents:
20723
diff
changeset
|
2172 EXFUN (Fstring_as_unibyte, 1); |
49866
c1513decc2e5
(Fcancel_kbd_macro_events, Fstring_to_multibyte): Add
Andreas Schwab <schwab@suse.de>
parents:
49665
diff
changeset
|
2173 EXFUN (Fstring_to_multibyte, 1); |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2174 EXFUN (Fsubstring, 3); |
20625
a9c4bf3f4e46
(STRING_MULTIBYTE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
20569
diff
changeset
|
2175 extern Lisp_Object substring_both P_ ((Lisp_Object, int, int, int, int)); |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2176 EXFUN (Fnth, 2); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2177 EXFUN (Fnthcdr, 2); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2178 EXFUN (Fmemq, 2); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2179 EXFUN (Fassq, 2); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2180 EXFUN (Fassoc, 2); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2181 EXFUN (Felt, 2); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2182 EXFUN (Fmember, 2); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2183 EXFUN (Frassq, 2); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2184 EXFUN (Fdelq, 2); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2185 EXFUN (Fsort, 2); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2186 EXFUN (Freverse, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2187 EXFUN (Fnreverse, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2188 EXFUN (Fget, 2); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2189 EXFUN (Fput, 3); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2190 EXFUN (Fequal, 2); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2191 EXFUN (Ffillarray, 2); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2192 EXFUN (Fnconc, MANY); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2193 EXFUN (Fmapcar, 2); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2194 EXFUN (Fmapconcat, 3); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2195 EXFUN (Fy_or_n_p, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2196 extern Lisp_Object do_yes_or_no_p P_ ((Lisp_Object)); |
23772
afe440aabd55
(Frequire): Update declaration.
Kenichi Handa <handa@m17n.org>
parents:
23721
diff
changeset
|
2197 EXFUN (Frequire, 3); |
39860
32241ddd6e73
(Ffeaturep, Fprovide): Update prototype.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
39810
diff
changeset
|
2198 EXFUN (Fprovide, 2); |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2199 extern Lisp_Object concat2 P_ ((Lisp_Object, Lisp_Object)); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2200 extern Lisp_Object concat3 P_ ((Lisp_Object, Lisp_Object, Lisp_Object)); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2201 extern Lisp_Object nconc2 P_ ((Lisp_Object, Lisp_Object)); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2202 extern Lisp_Object assq_no_quit P_ ((Lisp_Object, Lisp_Object)); |
27885 | 2203 extern void clear_string_char_byte_cache P_ ((void)); |
20625
a9c4bf3f4e46
(STRING_MULTIBYTE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
20569
diff
changeset
|
2204 extern int string_char_to_byte P_ ((Lisp_Object, int)); |
a9c4bf3f4e46
(STRING_MULTIBYTE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
20569
diff
changeset
|
2205 extern int string_byte_to_char P_ ((Lisp_Object, int)); |
21515 | 2206 extern Lisp_Object string_make_multibyte P_ ((Lisp_Object)); |
2207 extern Lisp_Object string_make_unibyte P_ ((Lisp_Object)); | |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2208 EXFUN (Fcopy_alist, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2209 EXFUN (Fplist_get, 2); |
25017
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
2210 EXFUN (Fplist_put, 3); |
44009
e67bcd447b16
(Fplist_member): Add prototype.
Pavel Janík <Pavel@Janik.cz>
parents:
43816
diff
changeset
|
2211 EXFUN (Fplist_member, 2); |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2212 EXFUN (Fset_char_table_parent, 2); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2213 EXFUN (Fchar_table_extra_slot, 2); |
20297
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2214 EXFUN (Fset_char_table_extra_slot, 3); |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2215 EXFUN (Frassoc, 2); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2216 EXFUN (Fstring_equal, 2); |
21842
870b55420529
Declare Fcompare_strings.
Andreas Schwab <schwab@suse.de>
parents:
21826
diff
changeset
|
2217 EXFUN (Fcompare_strings, 7); |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2218 EXFUN (Fstring_lessp, 2); |
21515 | 2219 extern int char_table_translate P_ ((Lisp_Object, int)); |
20297
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2220 extern void map_char_table P_ ((void (*) (Lisp_Object, Lisp_Object, Lisp_Object), |
51035
b17fe74b2af3
(specbinding_func): New typedef.
Richard M. Stallman <rms@gnu.org>
parents:
50996
diff
changeset
|
2221 Lisp_Object, Lisp_Object, Lisp_Object, Lisp_Object, int, |
20297
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2222 Lisp_Object *)); |
30489
fb23cf90b636
(char_table_ref_and_index): Add prototype.
Kenichi Handa <handa@m17n.org>
parents:
30447
diff
changeset
|
2223 extern Lisp_Object char_table_ref_and_index P_ ((Lisp_Object, int, int *)); |
21931 | 2224 extern void syms_of_fns P_ ((void)); |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2225 |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2226 /* Defined in floatfns.c */ |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2227 extern double extract_float P_ ((Lisp_Object)); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2228 EXFUN (Ffloat, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2229 EXFUN (Ftruncate, 2); |
21931 | 2230 extern void init_floatfns P_ ((void)); |
2231 extern void syms_of_floatfns P_ ((void)); | |
302 | 2232 |
10396
47938020b39d
Use large constants for Lisp_Misc_Type.
Karl Heuer <kwzh@gnu.org>
parents:
10387
diff
changeset
|
2233 /* Defined in insdel.c */ |
39245
76c1a0ab4517
(Qinhibit_modification_hooks): Declare.
Gerd Moellmann <gerd@gnu.org>
parents:
39194
diff
changeset
|
2234 extern Lisp_Object Qinhibit_modification_hooks; |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2235 extern void move_gap P_ ((int)); |
20559
38941faa1564
(struct Lisp_Marker): New field `charpos'.
Richard M. Stallman <rms@gnu.org>
parents:
20499
diff
changeset
|
2236 extern void move_gap_both P_ ((int, int)); |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2237 extern void make_gap P_ ((int)); |
46471
028a5b2de9e4
(chars_in_text, multibyte_chars_in_text, copy_text):
Ken Raeburn <raeburn@raeburn.org>
parents:
46428
diff
changeset
|
2238 extern int copy_text P_ ((const unsigned char *, unsigned char *, int, int, int)); |
028a5b2de9e4
(chars_in_text, multibyte_chars_in_text, copy_text):
Ken Raeburn <raeburn@raeburn.org>
parents:
46428
diff
changeset
|
2239 extern int count_size_as_multibyte P_ ((const unsigned char *, int)); |
028a5b2de9e4
(chars_in_text, multibyte_chars_in_text, copy_text):
Ken Raeburn <raeburn@raeburn.org>
parents:
46428
diff
changeset
|
2240 extern int count_combining_before P_ ((const unsigned char *, int, int, int)); |
028a5b2de9e4
(chars_in_text, multibyte_chars_in_text, copy_text):
Ken Raeburn <raeburn@raeburn.org>
parents:
46428
diff
changeset
|
2241 extern int count_combining_after P_ ((const unsigned char *, int, int, int)); |
028a5b2de9e4
(chars_in_text, multibyte_chars_in_text, copy_text):
Ken Raeburn <raeburn@raeburn.org>
parents:
46428
diff
changeset
|
2242 extern void insert P_ ((const unsigned char *, int)); |
028a5b2de9e4
(chars_in_text, multibyte_chars_in_text, copy_text):
Ken Raeburn <raeburn@raeburn.org>
parents:
46428
diff
changeset
|
2243 extern void insert_and_inherit P_ ((const unsigned char *, int)); |
028a5b2de9e4
(chars_in_text, multibyte_chars_in_text, copy_text):
Ken Raeburn <raeburn@raeburn.org>
parents:
46428
diff
changeset
|
2244 extern void insert_1 P_ ((const unsigned char *, int, int, int, int)); |
028a5b2de9e4
(chars_in_text, multibyte_chars_in_text, copy_text):
Ken Raeburn <raeburn@raeburn.org>
parents:
46428
diff
changeset
|
2245 extern void insert_1_both P_ ((const unsigned char *, int, int, int, int, int)); |
20625
a9c4bf3f4e46
(STRING_MULTIBYTE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
20569
diff
changeset
|
2246 extern void insert_from_string P_ ((Lisp_Object, int, int, int, int, int)); |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2247 extern void insert_from_buffer P_ ((struct buffer *, int, int, int)); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2248 extern void insert_char P_ ((int)); |
46471
028a5b2de9e4
(chars_in_text, multibyte_chars_in_text, copy_text):
Ken Raeburn <raeburn@raeburn.org>
parents:
46428
diff
changeset
|
2249 extern void insert_string P_ ((const char *)); |
028a5b2de9e4
(chars_in_text, multibyte_chars_in_text, copy_text):
Ken Raeburn <raeburn@raeburn.org>
parents:
46428
diff
changeset
|
2250 extern void insert_before_markers P_ ((const unsigned char *, int)); |
028a5b2de9e4
(chars_in_text, multibyte_chars_in_text, copy_text):
Ken Raeburn <raeburn@raeburn.org>
parents:
46428
diff
changeset
|
2251 extern void insert_before_markers_and_inherit P_ ((const unsigned char *, int)); |
20625
a9c4bf3f4e46
(STRING_MULTIBYTE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
20569
diff
changeset
|
2252 extern void insert_from_string_before_markers P_ ((Lisp_Object, int, int, int, int, int)); |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2253 extern void del_range P_ ((int, int)); |
26742
936b39bd05b4
* editfns.c (Fdelete_and_extract_region): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
26603
diff
changeset
|
2254 extern Lisp_Object del_range_1 P_ ((int, int, int, int)); |
20559
38941faa1564
(struct Lisp_Marker): New field `charpos'.
Richard M. Stallman <rms@gnu.org>
parents:
20499
diff
changeset
|
2255 extern void del_range_byte P_ ((int, int, int)); |
38941faa1564
(struct Lisp_Marker): New field `charpos'.
Richard M. Stallman <rms@gnu.org>
parents:
20499
diff
changeset
|
2256 extern void del_range_both P_ ((int, int, int, int, int)); |
26742
936b39bd05b4
* editfns.c (Fdelete_and_extract_region): New function.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
26603
diff
changeset
|
2257 extern Lisp_Object del_range_2 P_ ((int, int, int, int, int)); |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2258 extern void modify_region P_ ((struct buffer *, int, int)); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2259 extern void prepare_to_modify_buffer P_ ((int, int, int *)); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2260 extern void signal_before_change P_ ((int, int, int *)); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2261 extern void signal_after_change P_ ((int, int, int)); |
21322
f93df7bbcead
(adjust_after_replace, adjust_after_insert): Extern them.
Kenichi Handa <handa@m17n.org>
parents:
21282
diff
changeset
|
2262 extern void adjust_after_replace P_ ((int, int, Lisp_Object, int, int)); |
42756
711b64458618
(adjust_after_replace_noundo)
Pavel Janík <Pavel@Janik.cz>
parents:
42466
diff
changeset
|
2263 extern void adjust_after_replace_noundo P_ ((int, int, int, int, int, int)); |
21322
f93df7bbcead
(adjust_after_replace, adjust_after_insert): Extern them.
Kenichi Handa <handa@m17n.org>
parents:
21282
diff
changeset
|
2264 extern void adjust_after_insert P_ ((int, int, int, int, int)); |
21276 | 2265 extern void replace_range P_ ((int, int, Lisp_Object, int, int, int)); |
21931 | 2266 extern void syms_of_insdel P_ ((void)); |
10396
47938020b39d
Use large constants for Lisp_Misc_Type.
Karl Heuer <kwzh@gnu.org>
parents:
10387
diff
changeset
|
2267 |
16133 | 2268 /* Defined in dispnew.c */ |
25672
68068da11161
(selected_frame): Add external declaration.
Gerd Moellmann <gerd@gnu.org>
parents:
25556
diff
changeset
|
2269 extern Lisp_Object selected_frame; |
43713
f92c4d87863a
Change defvar_int def and vars to use EMACS_INT instead of just int.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
43699
diff
changeset
|
2270 extern EMACS_INT baud_rate; |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2271 EXFUN (Fding, 1); |
25450
b5c133b3bfa0
Add declarations for some functions.
Andreas Schwab <schwab@suse.de>
parents:
25421
diff
changeset
|
2272 EXFUN (Fredraw_frame, 1); |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2273 EXFUN (Fredraw_display, 0); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2274 EXFUN (Fsleep_for, 2); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2275 EXFUN (Fsit_for, 3); |
20297
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2276 extern Lisp_Object sit_for P_ ((int, int, int, int, int)); |
21931 | 2277 extern void init_display P_ ((void)); |
2278 extern void syms_of_display P_ ((void)); | |
46552
cb055b77d3c6
(STRING_COPYIN): New macro.
Ken Raeburn <raeburn@raeburn.org>
parents:
46471
diff
changeset
|
2279 extern void safe_bcopy P_ ((const char *, char *, int)); |
16133 | 2280 |
10396
47938020b39d
Use large constants for Lisp_Misc_Type.
Karl Heuer <kwzh@gnu.org>
parents:
10387
diff
changeset
|
2281 /* Defined in xdisp.c */ |
34796
560b081d8800
(Qinhibit_point_motion_hooks): Declare extern.
Gerd Moellmann <gerd@gnu.org>
parents:
34534
diff
changeset
|
2282 extern Lisp_Object Qinhibit_point_motion_hooks; |
31447
12a61566fea1
(Qdisplay): Declare extern.
Gerd Moellmann <gerd@gnu.org>
parents:
31207
diff
changeset
|
2283 extern Lisp_Object Qinhibit_redisplay, Qdisplay; |
37042
a644f4966169
(Qinhibit_eval_during_redisplay): Declare extern.
Gerd Moellmann <gerd@gnu.org>
parents:
36941
diff
changeset
|
2284 extern Lisp_Object Qinhibit_eval_during_redisplay; |
29636
04d079a75b41
(Qmessage_truncate_lines): External declaration.
Gerd Moellmann <gerd@gnu.org>
parents:
29443
diff
changeset
|
2285 extern Lisp_Object Qmessage_truncate_lines; |
53331
db670c1b5944
(IMAGEP): New macro to test for image object type.
Kim F. Storm <storm@cua.dk>
parents:
53111
diff
changeset
|
2286 extern Lisp_Object Qimage; |
11191 | 2287 extern Lisp_Object Vmessage_log_max; |
20625
a9c4bf3f4e46
(STRING_MULTIBYTE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
20569
diff
changeset
|
2288 extern int message_enable_multibyte; |
25353 | 2289 extern Lisp_Object echo_area_buffer[2]; |
25748
6fddda6e635e
Add prototype for uninterrupt_malloc, memory_warnings,
Gerd Moellmann <gerd@gnu.org>
parents:
25737
diff
changeset
|
2290 extern void check_message_stack P_ ((void)); |
25353 | 2291 extern void setup_echo_area_for_printing P_ ((int)); |
2292 extern int push_message P_ ((void)); | |
47393
38bf43c3fb05
(pop_message_unwind): Renamed from push_message_unwind.
Richard M. Stallman <rms@gnu.org>
parents:
47136
diff
changeset
|
2293 extern Lisp_Object pop_message_unwind P_ ((Lisp_Object)); |
38bf43c3fb05
(pop_message_unwind): Renamed from push_message_unwind.
Richard M. Stallman <rms@gnu.org>
parents:
47136
diff
changeset
|
2294 extern Lisp_Object restore_message_unwind P_ ((Lisp_Object)); |
25353 | 2295 extern void pop_message P_ ((void)); |
2296 extern void restore_message P_ ((void)); | |
2297 extern Lisp_Object current_message P_ ((void)); | |
46471
028a5b2de9e4
(chars_in_text, multibyte_chars_in_text, copy_text):
Ken Raeburn <raeburn@raeburn.org>
parents:
46428
diff
changeset
|
2298 extern void set_message P_ ((const char *s, Lisp_Object, int, int)); |
25353 | 2299 extern void clear_message P_ ((int, int)); |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2300 extern void message P_ ((/* char *, ... */)); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2301 extern void message_nolog P_ ((/* char *, ... */)); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2302 extern void message1 P_ ((char *)); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2303 extern void message1_nolog P_ ((char *)); |
46471
028a5b2de9e4
(chars_in_text, multibyte_chars_in_text, copy_text):
Ken Raeburn <raeburn@raeburn.org>
parents:
46428
diff
changeset
|
2304 extern void message2 P_ ((const char *, int, int)); |
028a5b2de9e4
(chars_in_text, multibyte_chars_in_text, copy_text):
Ken Raeburn <raeburn@raeburn.org>
parents:
46428
diff
changeset
|
2305 extern void message2_nolog P_ ((const char *, int, int)); |
25017
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
2306 extern void message3 P_ ((Lisp_Object, int, int)); |
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
2307 extern void message3_nolog P_ ((Lisp_Object, int, int)); |
46471
028a5b2de9e4
(chars_in_text, multibyte_chars_in_text, copy_text):
Ken Raeburn <raeburn@raeburn.org>
parents:
46428
diff
changeset
|
2308 extern void message_dolog P_ ((const char *, int, int, int)); |
20625
a9c4bf3f4e46
(STRING_MULTIBYTE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
20569
diff
changeset
|
2309 extern void message_with_string P_ ((char *, Lisp_Object, int)); |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2310 extern void message_log_maybe_newline P_ ((void)); |
20297
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2311 extern void update_echo_area P_ ((void)); |
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2312 extern void truncate_echo_area P_ ((int)); |
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2313 extern void redisplay P_ ((void)); |
26865
87623e53b7c6
(QCtest, QCweakness, Qequal): Extern them.
Kenichi Handa <handa@m17n.org>
parents:
26742
diff
changeset
|
2314 extern int check_point_in_composition |
87623e53b7c6
(QCtest, QCweakness, Qequal): Extern them.
Kenichi Handa <handa@m17n.org>
parents:
26742
diff
changeset
|
2315 P_ ((struct buffer *, int, struct buffer *, int)); |
35335
b5a39d371511
(redisplay_preserve_echo_area): Change prototype.
Gerd Moellmann <gerd@gnu.org>
parents:
35184
diff
changeset
|
2316 extern void redisplay_preserve_echo_area P_ ((int)); |
20297
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2317 extern void mark_window_display_accurate P_ ((Lisp_Object, int)); |
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2318 extern void prepare_menu_bars P_ ((void)); |
48322
7fc75e78e65f
(get_specified_cursor_type, get_window_cursor_type):
Dave Love <fx@gnu.org>
parents:
47991
diff
changeset
|
2319 |
47136
09135ba45a40
(Qcursor_in_non_selected_windows): Extern removed.
Kim F. Storm <storm@cua.dk>
parents:
46886
diff
changeset
|
2320 void set_frame_cursor_types P_ ((struct frame *, Lisp_Object)); |
21931 | 2321 extern void syms_of_xdisp P_ ((void)); |
2322 extern void init_xdisp P_ ((void)); | |
32173
fea92799d3e9
(safe_call): Renamed from call_function.
Gerd Moellmann <gerd@gnu.org>
parents:
32065
diff
changeset
|
2323 extern Lisp_Object safe_eval P_ ((Lisp_Object)); |
33461
ca213c01c256
(pos_visible_p): Change prototype.
Gerd Moellmann <gerd@gnu.org>
parents:
33351
diff
changeset
|
2324 extern int pos_visible_p P_ ((struct window *, int, int *, int)); |
10396
47938020b39d
Use large constants for Lisp_Misc_Type.
Karl Heuer <kwzh@gnu.org>
parents:
10387
diff
changeset
|
2325 |
25748
6fddda6e635e
Add prototype for uninterrupt_malloc, memory_warnings,
Gerd Moellmann <gerd@gnu.org>
parents:
25737
diff
changeset
|
2326 /* Defined in vm-limit.c. */ |
28054
d53d22ce7f4b
(P_): Define based on PROTOTYPES, not __STDC__.
Dave Love <fx@gnu.org>
parents:
27885
diff
changeset
|
2327 extern void memory_warnings P_ ((POINTER_TYPE *, void (*warnfun) ())); |
d53d22ce7f4b
(P_): Define based on PROTOTYPES, not __STDC__.
Dave Love <fx@gnu.org>
parents:
27885
diff
changeset
|
2328 |
302 | 2329 /* Defined in alloc.c */ |
39579
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
2330 extern void check_pure_size P_ ((void)); |
27141
d7b1de135a40
Add prototype for allocate_string_data.
Gerd Moellmann <gerd@gnu.org>
parents:
27078
diff
changeset
|
2331 extern void allocate_string_data P_ ((struct Lisp_String *, int, int)); |
25748
6fddda6e635e
Add prototype for uninterrupt_malloc, memory_warnings,
Gerd Moellmann <gerd@gnu.org>
parents:
25737
diff
changeset
|
2332 extern void uninterrupt_malloc P_ ((void)); |
20297
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2333 extern void malloc_warning P_ ((char *)); |
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2334 extern void memory_full P_ ((void)); |
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2335 extern void buffer_memory_full P_ ((void)); |
25017
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
2336 extern int survives_gc_p P_ ((Lisp_Object)); |
51766
eee1bdf9de54
(mark_object): Change prototype to only pass Lisp_Object.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51724
diff
changeset
|
2337 extern void mark_object P_ ((Lisp_Object)); |
302 | 2338 extern Lisp_Object Vpurify_flag; |
46304
76246741e5c2
(Vmemory_full): Add declaration.
Richard M. Stallman <rms@gnu.org>
parents:
46284
diff
changeset
|
2339 extern Lisp_Object Vmemory_full; |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2340 EXFUN (Fcons, 2); |
21038
9b33c6a5b4dc
(Vnonascii_translate_table, Qcharset): New variable decls.
Richard M. Stallman <rms@gnu.org>
parents:
20723
diff
changeset
|
2341 EXFUN (list2, 2); |
9b33c6a5b4dc
(Vnonascii_translate_table, Qcharset): New variable decls.
Richard M. Stallman <rms@gnu.org>
parents:
20723
diff
changeset
|
2342 EXFUN (list3, 3); |
9b33c6a5b4dc
(Vnonascii_translate_table, Qcharset): New variable decls.
Richard M. Stallman <rms@gnu.org>
parents:
20723
diff
changeset
|
2343 EXFUN (list4, 4); |
9b33c6a5b4dc
(Vnonascii_translate_table, Qcharset): New variable decls.
Richard M. Stallman <rms@gnu.org>
parents:
20723
diff
changeset
|
2344 EXFUN (list5, 5); |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2345 EXFUN (Flist, MANY); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2346 EXFUN (Fmake_list, 2); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2347 extern Lisp_Object allocate_misc P_ ((void)); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2348 EXFUN (Fmake_vector, 2); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2349 EXFUN (Fvector, MANY); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2350 EXFUN (Fmake_symbol, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2351 EXFUN (Fmake_marker, 0); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2352 EXFUN (Fmake_string, 2); |
46471
028a5b2de9e4
(chars_in_text, multibyte_chars_in_text, copy_text):
Ken Raeburn <raeburn@raeburn.org>
parents:
46428
diff
changeset
|
2353 extern Lisp_Object build_string P_ ((const char *)); |
028a5b2de9e4
(chars_in_text, multibyte_chars_in_text, copy_text):
Ken Raeburn <raeburn@raeburn.org>
parents:
46428
diff
changeset
|
2354 extern Lisp_Object make_string P_ ((const char *, int)); |
028a5b2de9e4
(chars_in_text, multibyte_chars_in_text, copy_text):
Ken Raeburn <raeburn@raeburn.org>
parents:
46428
diff
changeset
|
2355 extern Lisp_Object make_unibyte_string P_ ((const char *, int)); |
028a5b2de9e4
(chars_in_text, multibyte_chars_in_text, copy_text):
Ken Raeburn <raeburn@raeburn.org>
parents:
46428
diff
changeset
|
2356 extern Lisp_Object make_multibyte_string P_ ((const char *, int, int)); |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2357 extern Lisp_Object make_event_array P_ ((int, Lisp_Object *)); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2358 extern Lisp_Object make_uninit_string P_ ((int)); |
20625
a9c4bf3f4e46
(STRING_MULTIBYTE): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
20569
diff
changeset
|
2359 extern Lisp_Object make_uninit_multibyte_string P_ ((int, int)); |
50276
fc6bcd4af686
(make_string_from_bytes, make_specified_string):
Kenichi Handa <handa@m17n.org>
parents:
49866
diff
changeset
|
2360 extern Lisp_Object make_string_from_bytes P_ ((const char *, int, int)); |
fc6bcd4af686
(make_string_from_bytes, make_specified_string):
Kenichi Handa <handa@m17n.org>
parents:
49866
diff
changeset
|
2361 extern Lisp_Object make_specified_string P_ ((const char *, int, int, int)); |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2362 EXFUN (Fpurecopy, 1); |
21276 | 2363 extern Lisp_Object make_pure_string P_ ((char *, int, int, int)); |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2364 extern Lisp_Object pure_cons P_ ((Lisp_Object, Lisp_Object)); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2365 extern Lisp_Object make_pure_vector P_ ((EMACS_INT)); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2366 EXFUN (Fgarbage_collect, 0); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2367 EXFUN (Fmake_byte_code, MANY); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2368 EXFUN (Fmake_bool_vector, 2); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2369 EXFUN (Fmake_char_table, 2); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2370 extern Lisp_Object make_sub_char_table P_ ((Lisp_Object)); |
13202
b307cd5c259f
(struct Lisp_Char_Table): New slot `purpose'.
Richard M. Stallman <rms@gnu.org>
parents:
13149
diff
changeset
|
2371 extern Lisp_Object Qchar_table_extra_slots; |
36430
5b0805c237e1
(allocate_vectorlike): Remove prototype.
Gerd Moellmann <gerd@gnu.org>
parents:
35773
diff
changeset
|
2372 extern struct Lisp_Vector *allocate_vector P_ ((EMACS_INT)); |
5b0805c237e1
(allocate_vectorlike): Remove prototype.
Gerd Moellmann <gerd@gnu.org>
parents:
35773
diff
changeset
|
2373 extern struct Lisp_Vector *allocate_other_vector P_ ((EMACS_INT)); |
5b0805c237e1
(allocate_vectorlike): Remove prototype.
Gerd Moellmann <gerd@gnu.org>
parents:
35773
diff
changeset
|
2374 extern struct Lisp_Hash_Table *allocate_hash_table P_ ((void)); |
5b0805c237e1
(allocate_vectorlike): Remove prototype.
Gerd Moellmann <gerd@gnu.org>
parents:
35773
diff
changeset
|
2375 extern struct window *allocate_window P_ ((void)); |
5b0805c237e1
(allocate_vectorlike): Remove prototype.
Gerd Moellmann <gerd@gnu.org>
parents:
35773
diff
changeset
|
2376 extern struct frame *allocate_frame P_ ((void)); |
5b0805c237e1
(allocate_vectorlike): Remove prototype.
Gerd Moellmann <gerd@gnu.org>
parents:
35773
diff
changeset
|
2377 extern struct Lisp_Process *allocate_process P_ ((void)); |
6657
28359458811c
(gc_in_progress): Declared.
Richard M. Stallman <rms@gnu.org>
parents:
6458
diff
changeset
|
2378 extern int gc_in_progress; |
50748
7c1d1ca51ca7
(abort_on_gc): Add decl.
Richard M. Stallman <rms@gnu.org>
parents:
50539
diff
changeset
|
2379 extern int abort_on_gc; |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2380 extern Lisp_Object make_float P_ ((double)); |
20297
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2381 extern void display_malloc_warning P_ ((void)); |
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2382 extern int inhibit_garbage_collection P_ ((void)); |
49056
88f14a14e005
New misc type Lisp_Save_Value.
Richard M. Stallman <rms@gnu.org>
parents:
48540
diff
changeset
|
2383 extern Lisp_Object make_save_value P_ ((void *, int)); |
20297
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2384 extern void free_marker P_ ((Lisp_Object)); |
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2385 extern void free_cons P_ ((struct Lisp_Cons *)); |
21931 | 2386 extern void init_alloc_once P_ ((void)); |
2387 extern void init_alloc P_ ((void)); | |
2388 extern void syms_of_alloc P_ ((void)); | |
27885 | 2389 extern struct buffer * allocate_buffer P_ ((void)); |
302 | 2390 |
2391 /* Defined in print.c */ | |
2392 extern Lisp_Object Vprin1_to_string_buffer; | |
25712
178d6245c681
Add prototype for debug_print.
Gerd Moellmann <gerd@gnu.org>
parents:
25704
diff
changeset
|
2393 extern void debug_print P_ ((Lisp_Object)); |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2394 EXFUN (Fprin1, 2); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2395 EXFUN (Fprin1_to_string, 2); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2396 EXFUN (Fprinc, 2); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2397 EXFUN (Fterpri, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2398 EXFUN (Fprint, 2); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2399 EXFUN (Ferror_message_string, 1); |
302 | 2400 extern Lisp_Object Vstandard_output, Qstandard_output; |
439 | 2401 extern Lisp_Object Qexternal_debugging_output; |
46552
cb055b77d3c6
(STRING_COPYIN): New macro.
Ken Raeburn <raeburn@raeburn.org>
parents:
46471
diff
changeset
|
2402 extern void temp_output_buffer_setup P_ ((const char *)); |
302 | 2403 extern int print_level, print_escape_newlines; |
2404 extern Lisp_Object Qprint_escape_newlines; | |
20297
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2405 extern void write_string P_ ((char *, int)); |
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2406 extern void write_string_1 P_ ((char *, int, Lisp_Object)); |
46573
4de08f73c18e
(print_error_message): Declare new args.
Richard M. Stallman <rms@gnu.org>
parents:
46552
diff
changeset
|
2407 extern void print_error_message P_ ((Lisp_Object, Lisp_Object, char *, Lisp_Object)); |
20297
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2408 extern Lisp_Object internal_with_output_to_temp_buffer |
46552
cb055b77d3c6
(STRING_COPYIN): New macro.
Ken Raeburn <raeburn@raeburn.org>
parents:
46471
diff
changeset
|
2409 P_ ((const char *, Lisp_Object (*) (Lisp_Object), Lisp_Object)); |
20297
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2410 extern void float_to_string P_ ((unsigned char *, double)); |
21931 | 2411 extern void syms_of_print P_ ((void)); |
20297
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2412 |
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2413 /* Defined in doprnt.c */ |
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2414 extern int doprnt P_ ((char *, int, char *, char *, int, char **)); |
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2415 extern int doprnt_lisp P_ ((char *, int, char *, char *, int, char **)); |
302 | 2416 |
2417 /* Defined in lread.c */ | |
2418 extern Lisp_Object Qvariable_documentation, Qstandard_input; | |
21774
101cc2e8a4b7
Include initial_obarray from lread.c
Richard M. Stallman <rms@gnu.org>
parents:
21711
diff
changeset
|
2419 extern Lisp_Object Vobarray, initial_obarray, Vstandard_input; |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2420 EXFUN (Fread, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2421 EXFUN (Fread_from_string, 3); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2422 EXFUN (Fintern, 2); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2423 EXFUN (Fintern_soft, 2); |
19119
e772b77b919e
(Fload): Update declaration.
Richard M. Stallman <rms@gnu.org>
parents:
18732
diff
changeset
|
2424 EXFUN (Fload, 5); |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2425 EXFUN (Fget_file_char, 0); |
23061
74a5a99c805e
(Fread_event, Fread_char, Fread_char_exclusive):
Richard M. Stallman <rms@gnu.org>
parents:
22928
diff
changeset
|
2426 EXFUN (Fread_char, 2); |
74a5a99c805e
(Fread_event, Fread_char, Fread_char_exclusive):
Richard M. Stallman <rms@gnu.org>
parents:
22928
diff
changeset
|
2427 EXFUN (Fread_event, 2); |
74a5a99c805e
(Fread_event, Fread_char, Fread_char_exclusive):
Richard M. Stallman <rms@gnu.org>
parents:
22928
diff
changeset
|
2428 extern Lisp_Object read_filtered_event P_ ((int, int, int, int)); |
22418
340060628c47
(Feval_region): Accept 4 args.
Richard M. Stallman <rms@gnu.org>
parents:
22269
diff
changeset
|
2429 EXFUN (Feval_region, 4); |
46471
028a5b2de9e4
(chars_in_text, multibyte_chars_in_text, copy_text):
Ken Raeburn <raeburn@raeburn.org>
parents:
46428
diff
changeset
|
2430 extern Lisp_Object intern P_ ((const char *)); |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2431 extern Lisp_Object make_symbol P_ ((char *)); |
46471
028a5b2de9e4
(chars_in_text, multibyte_chars_in_text, copy_text):
Ken Raeburn <raeburn@raeburn.org>
parents:
46428
diff
changeset
|
2432 extern Lisp_Object oblookup P_ ((Lisp_Object, const char *, int, int)); |
2605
b3c605e9bb30
(LOADHIST_ATTACH): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
2515
diff
changeset
|
2433 #define LOADHIST_ATTACH(x) \ |
b3c605e9bb30
(LOADHIST_ATTACH): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
2515
diff
changeset
|
2434 if (initialized) Vcurrent_load_list = Fcons (x, Vcurrent_load_list) |
b3c605e9bb30
(LOADHIST_ATTACH): New macro.
Richard M. Stallman <rms@gnu.org>
parents:
2515
diff
changeset
|
2435 extern Lisp_Object Vcurrent_load_list; |
39810
4b565579e4f5
(Vload_suffixes, Vexec_suffixes): Declare.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
39804
diff
changeset
|
2436 extern Lisp_Object Vload_history, Vload_suffixes; |
4b565579e4f5
(Vload_suffixes, Vexec_suffixes): Declare.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
39804
diff
changeset
|
2437 extern int openp P_ ((Lisp_Object, Lisp_Object, Lisp_Object, |
45000
34382d9145d7
(openp): Update prototype.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
44940
diff
changeset
|
2438 Lisp_Object *, Lisp_Object)); |
20297
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2439 extern int isfloat_string P_ ((char *)); |
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2440 extern void map_obarray P_ ((Lisp_Object, void (*) (Lisp_Object, Lisp_Object), |
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2441 Lisp_Object)); |
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2442 extern void dir_warning P_ ((char *, Lisp_Object)); |
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2443 extern void close_load_descs P_ ((void)); |
21931 | 2444 extern void init_obarray P_ ((void)); |
2445 extern void init_lread P_ ((void)); | |
2446 extern void syms_of_lread P_ ((void)); | |
302 | 2447 |
2448 /* Defined in eval.c */ | |
2449 extern Lisp_Object Qautoload, Qexit, Qinteractive, Qcommandp, Qdefun, Qmacro; | |
381 | 2450 extern Lisp_Object Vinhibit_quit, Qinhibit_quit, Vquit_flag; |
302 | 2451 extern Lisp_Object Vautoload_queue; |
8995
2281d87b7c91
(Vdebug_on_error): Declared.
Richard M. Stallman <rms@gnu.org>
parents:
8912
diff
changeset
|
2452 extern Lisp_Object Vdebug_on_error; |
30072
da80009c3957
(Vsignaling_function): External declaration.
Gerd Moellmann <gerd@gnu.org>
parents:
29978
diff
changeset
|
2453 extern Lisp_Object Vsignaling_function; |
30081
60dfd5c7304c
(handling_signal): External declaration.
Gerd Moellmann <gerd@gnu.org>
parents:
30072
diff
changeset
|
2454 extern int handling_signal; |
35773
04bb0b45e18c
(interactive_p): Add prototype.
Gerd Moellmann <gerd@gnu.org>
parents:
35335
diff
changeset
|
2455 extern int interactive_p P_ ((int)); |
30072
da80009c3957
(Vsignaling_function): External declaration.
Gerd Moellmann <gerd@gnu.org>
parents:
29978
diff
changeset
|
2456 |
12731
cac1b80e43be
Declare hook running functions.
Simon Marshall <simon@gnu.org>
parents:
12653
diff
changeset
|
2457 /* To run a normal hook, use the appropriate function from the list below. |
cac1b80e43be
Declare hook running functions.
Simon Marshall <simon@gnu.org>
parents:
12653
diff
changeset
|
2458 The calling convention: |
cac1b80e43be
Declare hook running functions.
Simon Marshall <simon@gnu.org>
parents:
12653
diff
changeset
|
2459 |
6216
9f7708f75f17
(ARRAY_MARK_FLAG): Define here.
Richard M. Stallman <rms@gnu.org>
parents:
6131
diff
changeset
|
2460 if (!NILP (Vrun_hooks)) |
12731
cac1b80e43be
Declare hook running functions.
Simon Marshall <simon@gnu.org>
parents:
12653
diff
changeset
|
2461 call1 (Vrun_hooks, Qmy_funny_hook); |
cac1b80e43be
Declare hook running functions.
Simon Marshall <simon@gnu.org>
parents:
12653
diff
changeset
|
2462 |
cac1b80e43be
Declare hook running functions.
Simon Marshall <simon@gnu.org>
parents:
12653
diff
changeset
|
2463 should no longer be used. */ |
302 | 2464 extern Lisp_Object Vrun_hooks; |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2465 EXFUN (Frun_hooks, MANY); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2466 EXFUN (Frun_hook_with_args, MANY); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2467 EXFUN (Frun_hook_with_args_until_success, MANY); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2468 EXFUN (Frun_hook_with_args_until_failure, MANY); |
41751
7a360dc26b8a
(run_hook_list_with_args): Undo last change.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
41659
diff
changeset
|
2469 extern Lisp_Object run_hook_list_with_args P_ ((Lisp_Object, int, Lisp_Object *)); |
20297
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2470 extern void run_hook_with_args_2 P_ ((Lisp_Object, Lisp_Object, Lisp_Object)); |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2471 EXFUN (Fand, UNEVALLED); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2472 EXFUN (For, UNEVALLED); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2473 EXFUN (Fif, UNEVALLED); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2474 EXFUN (Fprogn, UNEVALLED); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2475 EXFUN (Fprog1, UNEVALLED); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2476 EXFUN (Fprog2, UNEVALLED); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2477 EXFUN (Fsetq, UNEVALLED); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2478 EXFUN (Fquote, UNEVALLED); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2479 EXFUN (Fuser_variable_p, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2480 EXFUN (Finteractive_p, 0); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2481 EXFUN (Fdefun, UNEVALLED); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2482 EXFUN (Flet, UNEVALLED); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2483 EXFUN (FletX, UNEVALLED); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2484 EXFUN (Fwhile, UNEVALLED); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2485 EXFUN (Fcatch, UNEVALLED); |
31833
12c10704f00c
(wrong_type_argument, Fthrow, Fsignal, error): Declare
Gerd Moellmann <gerd@gnu.org>
parents:
31447
diff
changeset
|
2486 EXFUN (Fthrow, 2) NO_RETURN; |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2487 EXFUN (Funwind_protect, UNEVALLED); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2488 EXFUN (Fcondition_case, UNEVALLED); |
32065
4f8ce7eb45a5
(wrong_type_argument): Remove NO_RETURN, the function can
Gerd Moellmann <gerd@gnu.org>
parents:
31991
diff
changeset
|
2489 EXFUN (Fsignal, 2); |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2490 EXFUN (Fautoload, 5); |
44940
2686a6ef3d19
(Fcommandp): Declare new arg.
Richard M. Stallman <rms@gnu.org>
parents:
44522
diff
changeset
|
2491 EXFUN (Fcommandp, 2); |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2492 EXFUN (Feval, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2493 EXFUN (Fapply, MANY); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2494 EXFUN (Ffuncall, MANY); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2495 EXFUN (Fbacktrace, 0); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2496 extern Lisp_Object apply1 P_ ((Lisp_Object, Lisp_Object)); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2497 extern Lisp_Object call0 P_ ((Lisp_Object)); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2498 extern Lisp_Object call1 P_ ((Lisp_Object, Lisp_Object)); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2499 extern Lisp_Object call2 P_ ((Lisp_Object, Lisp_Object, Lisp_Object)); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2500 extern Lisp_Object call3 P_ ((Lisp_Object, Lisp_Object, Lisp_Object, Lisp_Object)); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2501 extern Lisp_Object call4 P_ ((Lisp_Object, Lisp_Object, Lisp_Object, Lisp_Object, Lisp_Object)); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2502 extern Lisp_Object call5 P_ ((Lisp_Object, Lisp_Object, Lisp_Object, Lisp_Object, Lisp_Object, Lisp_Object)); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2503 extern Lisp_Object call6 P_ ((Lisp_Object, Lisp_Object, Lisp_Object, Lisp_Object, Lisp_Object, Lisp_Object, Lisp_Object)); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2504 EXFUN (Fdo_auto_save, 2); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2505 extern Lisp_Object apply_lambda P_ ((Lisp_Object, Lisp_Object, int)); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2506 extern Lisp_Object internal_catch P_ ((Lisp_Object, Lisp_Object (*) (Lisp_Object), Lisp_Object)); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2507 extern Lisp_Object internal_condition_case P_ ((Lisp_Object (*) (void), Lisp_Object, Lisp_Object (*) (Lisp_Object))); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2508 extern Lisp_Object internal_condition_case_1 P_ ((Lisp_Object (*) (Lisp_Object), Lisp_Object, Lisp_Object, Lisp_Object (*) (Lisp_Object))); |
30218 | 2509 extern Lisp_Object internal_condition_case_2 P_ ((Lisp_Object (*) (int, Lisp_Object *), int, Lisp_Object *, Lisp_Object, Lisp_Object (*) (Lisp_Object))); |
20297
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2510 extern void specbind P_ ((Lisp_Object, Lisp_Object)); |
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2511 extern void record_unwind_protect P_ ((Lisp_Object (*) (Lisp_Object), Lisp_Object)); |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2512 extern Lisp_Object unbind_to P_ ((int, Lisp_Object)); |
31833
12c10704f00c
(wrong_type_argument, Fthrow, Fsignal, error): Declare
Gerd Moellmann <gerd@gnu.org>
parents:
31447
diff
changeset
|
2513 extern void error P_ ((/* char *, ... */)) NO_RETURN; |
20297
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2514 extern void do_autoload P_ ((Lisp_Object, Lisp_Object)); |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2515 extern Lisp_Object un_autoload P_ ((Lisp_Object)); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2516 EXFUN (Ffetch_bytecode, 1); |
21931 | 2517 extern void init_eval_once P_ ((void)); |
32173
fea92799d3e9
(safe_call): Renamed from call_function.
Gerd Moellmann <gerd@gnu.org>
parents:
32065
diff
changeset
|
2518 extern Lisp_Object safe_call P_ ((int, Lisp_Object *)); |
fea92799d3e9
(safe_call): Renamed from call_function.
Gerd Moellmann <gerd@gnu.org>
parents:
32065
diff
changeset
|
2519 extern Lisp_Object safe_call1 P_ ((Lisp_Object, Lisp_Object)); |
21931 | 2520 extern void init_eval P_ ((void)); |
2521 extern void syms_of_eval P_ ((void)); | |
302 | 2522 |
2523 /* Defined in editfns.c */ | |
44522
cada3f53aa13
(Fpropertize): Add prototype.
Pavel Janík <Pavel@Janik.cz>
parents:
44065
diff
changeset
|
2524 EXFUN (Fpropertize, MANY); |
25353 | 2525 EXFUN (Fcurrent_message, 0); |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2526 EXFUN (Fgoto_char, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2527 EXFUN (Fpoint_min_marker, 0); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2528 EXFUN (Fpoint_max_marker, 0); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2529 EXFUN (Fpoint_min, 0); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2530 EXFUN (Fpoint_max, 0); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2531 EXFUN (Fpoint, 0); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2532 EXFUN (Fpoint_marker, 0); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2533 EXFUN (Fmark_marker, 0); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2534 EXFUN (Fline_beginning_position, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2535 EXFUN (Fline_end_position, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2536 EXFUN (Ffollowing_char, 0); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2537 EXFUN (Fprevious_char, 0); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2538 EXFUN (Fchar_after, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2539 EXFUN (Finsert, MANY); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2540 EXFUN (Finsert_and_inherit, MANY); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2541 EXFUN (Finsert_before_markers, MANY); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2542 EXFUN (Finsert_buffer_substring, 3); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2543 EXFUN (Finsert_char, 3); |
20297
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2544 extern void insert1 P_ ((Lisp_Object)); |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2545 EXFUN (Feolp, 0); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2546 EXFUN (Feobp, 0); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2547 EXFUN (Fbolp, 0); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2548 EXFUN (Fbobp, 0); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2549 EXFUN (Fformat, MANY); |
25017
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
2550 EXFUN (Fmessage, MANY); |
49446
21086b629b21
Declare format2 instead of format1.
Richard M. Stallman <rms@gnu.org>
parents:
49322
diff
changeset
|
2551 extern Lisp_Object format2 P_ ((char *, Lisp_Object, Lisp_Object)); |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2552 extern Lisp_Object make_buffer_string P_ ((int, int, int)); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2553 EXFUN (Fbuffer_substring, 2); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2554 EXFUN (Fbuffer_string, 0); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2555 extern Lisp_Object save_excursion_save P_ ((void)); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2556 extern Lisp_Object save_restriction_save P_ ((void)); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2557 extern Lisp_Object save_excursion_restore P_ ((Lisp_Object)); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2558 extern Lisp_Object save_restriction_restore P_ ((Lisp_Object)); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2559 EXFUN (Fchar_to_string, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2560 EXFUN (Fdelete_region, 2); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2561 EXFUN (Fnarrow_to_region, 2); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2562 EXFUN (Fwiden, 0); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2563 EXFUN (Fuser_login_name, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2564 EXFUN (Fsystem_name, 0); |
25450
b5c133b3bfa0
Add declarations for some functions.
Andreas Schwab <schwab@suse.de>
parents:
25421
diff
changeset
|
2565 EXFUN (Fcurrent_time, 0); |
20297
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2566 extern int clip_to_bounds P_ ((int, int, int)); |
21282
58268912c0b5
(make_buffer_string, make_buffer_string_both): Extern them.
Kenichi Handa <handa@m17n.org>
parents:
21277
diff
changeset
|
2567 extern Lisp_Object make_buffer_string P_ ((int, int, int)); |
58268912c0b5
(make_buffer_string, make_buffer_string_both): Extern them.
Kenichi Handa <handa@m17n.org>
parents:
21277
diff
changeset
|
2568 extern Lisp_Object make_buffer_string_both P_ ((int, int, int, int, int)); |
21931 | 2569 extern void init_editfns P_ ((void)); |
2570 extern void syms_of_editfns P_ ((void)); | |
25759
e473b3e5cf6d
Declare Fcurrent_message, Fmake_temp_name, read_bytecode_char,
Dave Love <fx@gnu.org>
parents:
25748
diff
changeset
|
2571 EXFUN (Fcurrent_message, 0); |
27078
bedae2f61170
Add extern declaration for Vinhibit_field_text_motion.
Gerd Moellmann <gerd@gnu.org>
parents:
26994
diff
changeset
|
2572 extern Lisp_Object Vinhibit_field_text_motion; |
30440
a438686586dd
(Fconstrain_to_field): Update external declaration.
Miles Bader <miles@gnu.org>
parents:
30322
diff
changeset
|
2573 EXFUN (Fconstrain_to_field, 5); |
27885 | 2574 EXFUN (Ffield_string, 1); |
2575 EXFUN (Fdelete_field, 1); | |
41067
2031344d2205
(Ffield_beginning, Ffield_end): Update EXFUN decl.
Miles Bader <miles@gnu.org>
parents:
40727
diff
changeset
|
2576 EXFUN (Ffield_beginning, 3); |
2031344d2205
(Ffield_beginning, Ffield_end): Update EXFUN decl.
Miles Bader <miles@gnu.org>
parents:
40727
diff
changeset
|
2577 EXFUN (Ffield_end, 3); |
27885 | 2578 EXFUN (Ffield_string_no_properties, 1); |
31015
0a24ffcc4061
(set_time_zone_rule): Add prototype.
Gerd Moellmann <gerd@gnu.org>
parents:
30943
diff
changeset
|
2579 extern void set_time_zone_rule P_ ((char *)); |
302 | 2580 |
2581 /* defined in buffer.c */ | |
36585
50e14a0ca5eb
(mouse_face_overlay_overlaps): Add prototype.
Gerd Moellmann <gerd@gnu.org>
parents:
36445
diff
changeset
|
2582 extern int mouse_face_overlay_overlaps P_ ((Lisp_Object)); |
20297
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2583 extern void nsberror P_ ((Lisp_Object)); |
25737
542f95129dd9
Add prototype for no_switch_window.
Gerd Moellmann <gerd@gnu.org>
parents:
25712
diff
changeset
|
2584 extern char *no_switch_window P_ ((Lisp_Object window)); |
25353 | 2585 EXFUN (Fset_buffer_multibyte, 1); |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2586 EXFUN (Foverlay_start, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2587 EXFUN (Foverlay_end, 1); |
51868
6806fc84a58f
(adjust_overlays_for_insert, adjust_overlays_for_delete): Update prototype.
Andreas Schwab <schwab@suse.de>
parents:
51858
diff
changeset
|
2588 extern void adjust_overlays_for_insert P_ ((EMACS_INT, EMACS_INT)); |
6806fc84a58f
(adjust_overlays_for_insert, adjust_overlays_for_delete): Update prototype.
Andreas Schwab <schwab@suse.de>
parents:
51858
diff
changeset
|
2589 extern void adjust_overlays_for_delete P_ ((EMACS_INT, EMACS_INT)); |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2590 extern void fix_overlays_in_range P_ ((int, int)); |
20297
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2591 extern void report_overlay_modification P_ ((Lisp_Object, Lisp_Object, int, |
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2592 Lisp_Object, Lisp_Object, Lisp_Object)); |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2593 extern int overlay_touches_p P_ ((int)); |
3539
a9b1e2a5523b
Don't declare malloc or realloc.
Richard M. Stallman <rms@gnu.org>
parents:
3324
diff
changeset
|
2594 extern Lisp_Object Vbuffer_alist, Vinhibit_read_only; |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2595 EXFUN (Fget_buffer, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2596 EXFUN (Fget_buffer_create, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2597 EXFUN (Fset_buffer, 1); |
20708 | 2598 EXFUN (set_buffer_if_live, 1); |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2599 EXFUN (Fbarf_if_buffer_read_only, 0); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2600 EXFUN (Fcurrent_buffer, 0); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2601 EXFUN (Fswitch_to_buffer, 2); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2602 EXFUN (Fpop_to_buffer, 3); |
22190
54a0e89d2a48
(frame_buffer_predicate, frame_buffer_list)
Richard M. Stallman <rms@gnu.org>
parents:
22123
diff
changeset
|
2603 EXFUN (Fother_buffer, 3); |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2604 EXFUN (Foverlay_get, 2); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2605 EXFUN (Fbuffer_modified_p, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2606 EXFUN (Fset_buffer_modified_p, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2607 EXFUN (Fkill_buffer, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2608 EXFUN (Fkill_all_local_variables, 0); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2609 EXFUN (Fbuffer_disable_undo, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2610 EXFUN (Fbuffer_enable_undo, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2611 EXFUN (Ferase_buffer, 0); |
2780
cfe7659bbc05
* lisp.h (Lisp_Overlay): New tag.
Jim Blandy <jimb@redhat.com>
parents:
2728
diff
changeset
|
2612 extern Lisp_Object Qoverlayp; |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2613 extern Lisp_Object get_truename_buffer P_ ((Lisp_Object)); |
302 | 2614 extern struct buffer *all_buffers; |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2615 EXFUN (Fprevious_overlay_change, 1); |
34154
88440ae23652
(Fmake_variable_buffer_local, Fbuffer_file_name): Declare.
Ken Raeburn <raeburn@raeburn.org>
parents:
33508
diff
changeset
|
2616 EXFUN (Fbuffer_file_name, 1); |
21931 | 2617 extern void init_buffer_once P_ ((void)); |
2618 extern void init_buffer P_ ((void)); | |
2619 extern void syms_of_buffer P_ ((void)); | |
2620 extern void keys_of_buffer P_ ((void)); | |
302 | 2621 |
2622 /* defined in marker.c */ | |
2623 | |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2624 EXFUN (Fmarker_position, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2625 EXFUN (Fmarker_buffer, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2626 EXFUN (Fcopy_marker, 2); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2627 EXFUN (Fset_marker, 3); |
20297
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2628 extern int marker_position P_ ((Lisp_Object)); |
21515 | 2629 extern int marker_byte_position P_ ((Lisp_Object)); |
2630 extern void clear_charpos_cache P_ ((struct buffer *)); | |
2631 extern int charpos_to_bytepos P_ ((int)); | |
2632 extern int buf_charpos_to_bytepos P_ ((struct buffer *, int)); | |
2633 extern int buf_bytepos_to_charpos P_ ((struct buffer *, int)); | |
51666
7181f5ced81c
(unchain_marker): Lisp_Object arg => Lisp_Marker.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51657
diff
changeset
|
2634 extern void unchain_marker P_ ((struct Lisp_Marker *marker)); |
20297
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2635 extern Lisp_Object set_marker_restricted P_ ((Lisp_Object, Lisp_Object, Lisp_Object)); |
20559
38941faa1564
(struct Lisp_Marker): New field `charpos'.
Richard M. Stallman <rms@gnu.org>
parents:
20499
diff
changeset
|
2636 extern Lisp_Object set_marker_both P_ ((Lisp_Object, Lisp_Object, int, int)); |
38941faa1564
(struct Lisp_Marker): New field `charpos'.
Richard M. Stallman <rms@gnu.org>
parents:
20499
diff
changeset
|
2637 extern Lisp_Object set_marker_restricted_both P_ ((Lisp_Object, Lisp_Object, |
38941faa1564
(struct Lisp_Marker): New field `charpos'.
Richard M. Stallman <rms@gnu.org>
parents:
20499
diff
changeset
|
2638 int, int)); |
21931 | 2639 extern void syms_of_marker P_ ((void)); |
302 | 2640 |
2641 /* Defined in fileio.c */ | |
2642 | |
2643 extern Lisp_Object Qfile_error; | |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2644 EXFUN (Ffind_file_name_handler, 2); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2645 EXFUN (Ffile_name_as_directory, 1); |
25450
b5c133b3bfa0
Add declarations for some functions.
Andreas Schwab <schwab@suse.de>
parents:
25421
diff
changeset
|
2646 EXFUN (Fmake_temp_name, 1); |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2647 EXFUN (Fexpand_file_name, 2); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2648 EXFUN (Ffile_name_nondirectory, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2649 EXFUN (Fsubstitute_in_file_name, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2650 EXFUN (Ffile_symlink_p, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2651 EXFUN (Fverify_visited_file_modtime, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2652 EXFUN (Ffile_exists_p, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2653 EXFUN (Ffile_name_absolute_p, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2654 EXFUN (Fdirectory_file_name, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2655 EXFUN (Ffile_name_directory, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2656 extern Lisp_Object expand_and_dir_to_file P_ ((Lisp_Object, Lisp_Object)); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2657 EXFUN (Ffile_accessible_directory_p, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2658 EXFUN (Funhandled_file_name_directory, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2659 EXFUN (Ffile_directory_p, 1); |
21038
9b33c6a5b4dc
(Vnonascii_translate_table, Qcharset): New variable decls.
Richard M. Stallman <rms@gnu.org>
parents:
20723
diff
changeset
|
2660 EXFUN (Fwrite_region, 7); |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2661 EXFUN (Ffile_readable_p, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2662 EXFUN (Ffile_executable_p, 1); |
45545
6b37dbf4d2a5
(Fread_file_name): Now has 6 args.
Kim F. Storm <storm@cua.dk>
parents:
45416
diff
changeset
|
2663 EXFUN (Fread_file_name, 6); |
25704
71063541d5e3
Declare close_file_unwind.
Andreas Schwab <schwab@suse.de>
parents:
25672
diff
changeset
|
2664 extern Lisp_Object close_file_unwind P_ ((Lisp_Object)); |
46471
028a5b2de9e4
(chars_in_text, multibyte_chars_in_text, copy_text):
Ken Raeburn <raeburn@raeburn.org>
parents:
46428
diff
changeset
|
2665 extern void report_file_error P_ ((const char *, Lisp_Object)); |
20297
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2666 extern int internal_delete_file P_ ((Lisp_Object)); |
21931 | 2667 extern void syms_of_fileio P_ ((void)); |
25759
e473b3e5cf6d
Declare Fcurrent_message, Fmake_temp_name, read_bytecode_char,
Dave Love <fx@gnu.org>
parents:
25748
diff
changeset
|
2668 EXFUN (Fmake_temp_name, 1); |
25748
6fddda6e635e
Add prototype for uninterrupt_malloc, memory_warnings,
Gerd Moellmann <gerd@gnu.org>
parents:
25737
diff
changeset
|
2669 extern void init_fileio_once P_ ((void)); |
29443 | 2670 extern Lisp_Object make_temp_name P_ ((Lisp_Object, int)); |
302 | 2671 |
2672 /* Defined in abbrev.c */ | |
2673 | |
21931 | 2674 extern void syms_of_abbrev P_ ((void)); |
302 | 2675 |
2676 /* defined in search.c */ | |
25765
416e6af8f06a
Add prototype for shrink_regexp_cache,
Gerd Moellmann <gerd@gnu.org>
parents:
25759
diff
changeset
|
2677 extern void shrink_regexp_cache P_ ((void)); |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2678 EXFUN (Fstring_match, 3); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2679 extern void restore_match_data P_ ((void)); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2680 EXFUN (Fmatch_data, 2); |
21199
7da9a3e9d3c8
Fstore_match_data => Fset_match_data.
Richard M. Stallman <rms@gnu.org>
parents:
21147
diff
changeset
|
2681 EXFUN (Fset_match_data, 1); |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2682 EXFUN (Fmatch_beginning, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2683 EXFUN (Fmatch_end, 1); |
33351
6d19f06da8a4
* lisp.h (Flooking_at): Declare.
Ken Raeburn <raeburn@raeburn.org>
parents:
32988
diff
changeset
|
2684 EXFUN (Flooking_at, 1); |
20297
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2685 extern int fast_string_match P_ ((Lisp_Object, Lisp_Object)); |
46471
028a5b2de9e4
(chars_in_text, multibyte_chars_in_text, copy_text):
Ken Raeburn <raeburn@raeburn.org>
parents:
46428
diff
changeset
|
2686 extern int fast_c_string_match_ignore_case P_ ((Lisp_Object, const char *)); |
20297
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2687 extern int scan_buffer P_ ((int, int, int, int, int *, int)); |
20559
38941faa1564
(struct Lisp_Marker): New field `charpos'.
Richard M. Stallman <rms@gnu.org>
parents:
20499
diff
changeset
|
2688 extern int scan_newline P_ ((int, int, int, int, int, int)); |
20297
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2689 extern int find_next_newline P_ ((int, int)); |
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2690 extern int find_next_newline_no_quit P_ ((int, int)); |
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2691 extern int find_before_next_newline P_ ((int, int, int)); |
21931 | 2692 extern void syms_of_search P_ ((void)); |
302 | 2693 |
2694 /* defined in minibuf.c */ | |
2695 | |
2696 extern Lisp_Object last_minibuf_string; | |
20297
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2697 extern void choose_minibuf_frame P_ ((void)); |
19547
70d930b49bb4
(DEFUN_ARGS_8): New macro.
Kenichi Handa <handa@m17n.org>
parents:
19224
diff
changeset
|
2698 EXFUN (Fcompleting_read, 8); |
70d930b49bb4
(DEFUN_ARGS_8): New macro.
Kenichi Handa <handa@m17n.org>
parents:
19224
diff
changeset
|
2699 EXFUN (Fread_from_minibuffer, 7); |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2700 EXFUN (Fread_variable, 2); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2701 EXFUN (Fread_buffer, 3); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2702 EXFUN (Fread_minibuffer, 2); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2703 EXFUN (Feval_minibuffer, 2); |
19547
70d930b49bb4
(DEFUN_ARGS_8): New macro.
Kenichi Handa <handa@m17n.org>
parents:
19224
diff
changeset
|
2704 EXFUN (Fread_string, 5); |
70d930b49bb4
(DEFUN_ARGS_8): New macro.
Kenichi Handa <handa@m17n.org>
parents:
19224
diff
changeset
|
2705 EXFUN (Fread_no_blanks_input, 3); |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2706 extern Lisp_Object get_minibuffer P_ ((int)); |
50539
4bdf6c3c3d59
(temp_echo_area_glyphs): Adjust prototype.
Kenichi Handa <handa@m17n.org>
parents:
50276
diff
changeset
|
2707 extern void temp_echo_area_glyphs P_ ((Lisp_Object)); |
21931 | 2708 extern void init_minibuf_once P_ ((void)); |
2709 extern void syms_of_minibuf P_ ((void)); | |
2710 extern void keys_of_minibuf P_ ((void)); | |
302 | 2711 |
2712 /* Defined in callint.c */ | |
2713 | |
12114
437964ecfc70
(current_prefix_partial): Deleted.
Karl Heuer <kwzh@gnu.org>
parents:
12093
diff
changeset
|
2714 extern Lisp_Object Qminus, Qplus, Vcurrent_prefix_arg; |
302 | 2715 extern Lisp_Object Vcommand_history; |
15695
597fb46cb2fd
(Qmouse_leave_buffer_hook): Declare it here.
Karl Heuer <kwzh@gnu.org>
parents:
15090
diff
changeset
|
2716 extern Lisp_Object Qcall_interactively, Qmouse_leave_buffer_hook; |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2717 EXFUN (Fcall_interactively, 3); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2718 EXFUN (Fprefix_numeric_value, 1); |
21931 | 2719 extern void syms_of_callint P_ ((void)); |
302 | 2720 |
2721 /* defined in casefiddle.c */ | |
2722 | |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2723 EXFUN (Fdowncase, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2724 EXFUN (Fupcase, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2725 EXFUN (Fcapitalize, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2726 EXFUN (Fupcase_region, 2); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2727 EXFUN (Fupcase_initials, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2728 EXFUN (Fupcase_initials_region, 2); |
21931 | 2729 extern void syms_of_casefiddle P_ ((void)); |
2730 extern void keys_of_casefiddle P_ ((void)); | |
302 | 2731 |
16133 | 2732 /* defined in casetab.c */ |
2733 | |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2734 EXFUN (Fset_case_table, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2735 EXFUN (Fset_standard_case_table, 1); |
21931 | 2736 extern void init_casetab_once P_ ((void)); |
2737 extern void syms_of_casetab P_ ((void)); | |
16133 | 2738 |
302 | 2739 /* defined in keyboard.c */ |
2740 | |
37188
da91f955f74c
(echoing, echo_message_buffer, cancel_echoing): Declare.
Gerd Moellmann <gerd@gnu.org>
parents:
37042
diff
changeset
|
2741 extern int echoing; |
da91f955f74c
(echoing, echo_message_buffer, cancel_echoing): Declare.
Gerd Moellmann <gerd@gnu.org>
parents:
37042
diff
changeset
|
2742 extern Lisp_Object echo_message_buffer; |
39451
f9d098bd1299
(echo_kboard): Declare extern.
Gerd Moellmann <gerd@gnu.org>
parents:
39245
diff
changeset
|
2743 extern struct kboard *echo_kboard; |
37188
da91f955f74c
(echoing, echo_message_buffer, cancel_echoing): Declare.
Gerd Moellmann <gerd@gnu.org>
parents:
37042
diff
changeset
|
2744 extern void cancel_echoing P_ ((void)); |
29940
3a3b1bda631d
(QCfilter): External declaration.
Gerd Moellmann <gerd@gnu.org>
parents:
29925
diff
changeset
|
2745 extern Lisp_Object Qdisabled, QCfilter; |
17871
1c5753313c4e
(Vtty_erase_char): Declared.
Richard M. Stallman <rms@gnu.org>
parents:
17714
diff
changeset
|
2746 extern Lisp_Object Vtty_erase_char, Vhelp_form, Vtop_level; |
30723
882e52f9e2bd
(input_pending): External declaration.
Gerd Moellmann <gerd@gnu.org>
parents:
30556
diff
changeset
|
2747 extern int input_pending; |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2748 EXFUN (Fdiscard_input, 0); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2749 EXFUN (Frecursive_edit, 0); |
39924
c1262fd975b2
(Ftop_level): Add prototype.
Pavel Janík <Pavel@Janik.cz>
parents:
39898
diff
changeset
|
2750 EXFUN (Ftop_level, 0); |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2751 EXFUN (Fcommand_execute, 4); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2752 EXFUN (Finput_pending_p, 0); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2753 extern Lisp_Object menu_bar_items P_ ((Lisp_Object)); |
25544
693ca9ba497a
Change spelling of `toolbar' to `tool_bar' or `tool-bar'.
Gerd Moellmann <gerd@gnu.org>
parents:
25515
diff
changeset
|
2754 extern Lisp_Object tool_bar_items P_ ((Lisp_Object, int *)); |
1990
c7d6c746fea6
Use the term `scroll bar', instead of `scrollbar'.
Jim Blandy <jimb@redhat.com>
parents:
1923
diff
changeset
|
2755 extern Lisp_Object Qvertical_scroll_bar; |
27885 | 2756 extern void discard_mouse_events P_ ((void)); |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2757 EXFUN (Fevent_convert_list, 1); |
22925
e89aad442cf7
(Fread_key_sequence): Update declaration.
Kenichi Handa <handa@m17n.org>
parents:
22791
diff
changeset
|
2758 EXFUN (Fread_key_sequence, 5); |
20297
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2759 EXFUN (Fset_input_mode, 4); |
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2760 extern int detect_input_pending P_ ((void)); |
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2761 extern int detect_input_pending_run_timers P_ ((int)); |
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2762 extern void safe_run_hooks P_ ((Lisp_Object)); |
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2763 extern void cmd_error_internal P_ ((Lisp_Object, char *)); |
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2764 extern Lisp_Object command_loop_1 P_ ((void)); |
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2765 extern Lisp_Object recursive_edit_1 P_ ((void)); |
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2766 extern void record_auto_save P_ ((void)); |
21931 | 2767 extern void init_keyboard P_ ((void)); |
2768 extern void syms_of_keyboard P_ ((void)); | |
2769 extern void keys_of_keyboard P_ ((void)); | |
34907
cc3aa3f6232a
(push_key_description): Add prototype.
Gerd Moellmann <gerd@gnu.org>
parents:
34796
diff
changeset
|
2770 extern char *push_key_description P_ ((unsigned int, char *, int)); |
302 | 2771 |
2772 | |
2773 /* defined in indent.c */ | |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2774 EXFUN (Fvertical_motion, 2); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2775 EXFUN (Findent_to, 2); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2776 EXFUN (Fcurrent_column, 0); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2777 EXFUN (Fmove_to_column, 2); |
46304
76246741e5c2
(Vmemory_full): Add declaration.
Richard M. Stallman <rms@gnu.org>
parents:
46284
diff
changeset
|
2778 extern double current_column P_ ((void)); |
20297
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2779 extern void invalidate_current_column P_ ((void)); |
46304
76246741e5c2
(Vmemory_full): Add declaration.
Richard M. Stallman <rms@gnu.org>
parents:
46284
diff
changeset
|
2780 extern int indented_beyond_p P_ ((int, int, double)); |
21931 | 2781 extern void syms_of_indent P_ ((void)); |
302 | 2782 |
765 | 2783 /* defined in frame.c */ |
6243 | 2784 extern Lisp_Object Qvisible; |
20297
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2785 extern void store_frame_param P_ ((struct frame *, Lisp_Object, Lisp_Object)); |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2786 extern void store_in_alist P_ ((Lisp_Object *, Lisp_Object, Lisp_Object)); |
36807
2c739584e2a6
(do_switch_frame): Change prototype.
Gerd Moellmann <gerd@gnu.org>
parents:
36595
diff
changeset
|
2787 extern Lisp_Object do_switch_frame P_ ((Lisp_Object, int, int)); |
20297
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2788 extern Lisp_Object get_frame_param P_ ((struct frame *, Lisp_Object)); |
22190
54a0e89d2a48
(frame_buffer_predicate, frame_buffer_list)
Richard M. Stallman <rms@gnu.org>
parents:
22123
diff
changeset
|
2789 extern Lisp_Object frame_buffer_predicate P_ ((Lisp_Object)); |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2790 EXFUN (Fframep, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2791 EXFUN (Fselect_frame, 2); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2792 EXFUN (Fselected_frame, 0); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2793 EXFUN (Fwindow_frame, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2794 EXFUN (Fframe_root_window, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2795 EXFUN (Fframe_first_window, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2796 EXFUN (Fframe_selected_window, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2797 EXFUN (Fframe_list, 0); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2798 EXFUN (Fnext_frame, 2); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2799 EXFUN (Fdelete_frame, 2); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2800 EXFUN (Fset_mouse_position, 3); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2801 EXFUN (Fmake_frame_visible, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2802 EXFUN (Fmake_frame_invisible, 2); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2803 EXFUN (Ficonify_frame, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2804 EXFUN (Fframe_visible_p, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2805 EXFUN (Fvisible_frame_list, 0); |
36445
904a83f1b00b
* lisp.h (Fframe_parameter): Declare.
Ken Raeburn <raeburn@raeburn.org>
parents:
36430
diff
changeset
|
2806 EXFUN (Fframe_parameter, 2); |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2807 EXFUN (Fframe_parameters, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2808 EXFUN (Fmodify_frame_parameters, 2); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2809 EXFUN (Fset_frame_height, 3); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2810 EXFUN (Fset_frame_width, 3); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2811 EXFUN (Fset_frame_size, 3); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2812 EXFUN (Fset_frame_position, 3); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2813 EXFUN (Fraise_frame, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2814 EXFUN (Fredirect_frame_focus, 2); |
20297
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2815 EXFUN (Fset_frame_selected_window, 2); |
22190
54a0e89d2a48
(frame_buffer_predicate, frame_buffer_list)
Richard M. Stallman <rms@gnu.org>
parents:
22123
diff
changeset
|
2816 extern Lisp_Object frame_buffer_list P_ ((Lisp_Object)); |
20297
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2817 extern void frames_discard_buffer P_ ((Lisp_Object)); |
22190
54a0e89d2a48
(frame_buffer_predicate, frame_buffer_list)
Richard M. Stallman <rms@gnu.org>
parents:
22123
diff
changeset
|
2818 extern void set_frame_buffer_list P_ ((Lisp_Object, Lisp_Object)); |
20297
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2819 extern void frames_bury_buffer P_ ((Lisp_Object)); |
21931 | 2820 extern void syms_of_frame P_ ((void)); |
302 | 2821 |
2822 /* defined in emacs.c */ | |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2823 extern Lisp_Object decode_env_path P_ ((char *, char *)); |
4528
5622149e7f75
(Vinvocation_directory): Declared.
Richard M. Stallman <rms@gnu.org>
parents:
4139
diff
changeset
|
2824 extern Lisp_Object Vinvocation_name, Vinvocation_directory; |
39804
b5d09b92489c
(empty_string): Declare.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
39779
diff
changeset
|
2825 extern Lisp_Object Vinstallation_directory, empty_string; |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2826 EXFUN (Fkill_emacs, 1); |
26088
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
25818
diff
changeset
|
2827 #if HAVE_SETLOCALE |
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
25818
diff
changeset
|
2828 void fixup_locale P_ ((void)); |
26526
b7438760079b
* callproc.c (strerror): Remove decl.
Paul Eggert <eggert@twinsun.com>
parents:
26479
diff
changeset
|
2829 void synchronize_system_messages_locale P_ ((void)); |
b7438760079b
* callproc.c (strerror): Remove decl.
Paul Eggert <eggert@twinsun.com>
parents:
26479
diff
changeset
|
2830 void synchronize_system_time_locale P_ ((void)); |
26088
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
25818
diff
changeset
|
2831 #else |
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
25818
diff
changeset
|
2832 #define setlocale(category, locale) |
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
25818
diff
changeset
|
2833 #define fixup_locale() |
26526
b7438760079b
* callproc.c (strerror): Remove decl.
Paul Eggert <eggert@twinsun.com>
parents:
26479
diff
changeset
|
2834 #define synchronize_system_messages_locale() |
b7438760079b
* callproc.c (strerror): Remove decl.
Paul Eggert <eggert@twinsun.com>
parents:
26479
diff
changeset
|
2835 #define synchronize_system_time_locale() |
26088
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
25818
diff
changeset
|
2836 #endif |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2837 void shut_down_emacs P_ ((int, int, Lisp_Object)); |
302 | 2838 /* Nonzero means don't do interactive redisplay and don't change tty modes */ |
2839 extern int noninteractive; | |
2840 /* Nonzero means don't do use window-system-specific display code */ | |
2841 extern int inhibit_window_system; | |
10316
272f15eddaca
(enum Lisp_Type): Delete Lisp_Buffer.
Richard M. Stallman <rms@gnu.org>
parents:
10292
diff
changeset
|
2842 /* Nonzero means that a filter or a sentinel is running. */ |
10032
f689803caa92
Added code for automatically saving and restoring the match data
Francesco Potortì <pot@gnu.org>
parents:
10010
diff
changeset
|
2843 extern int running_asynch_code; |
302 | 2844 |
2845 /* defined in process.c */ | |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2846 EXFUN (Fget_process, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2847 EXFUN (Fget_buffer_process, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2848 EXFUN (Fprocessp, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2849 EXFUN (Fprocess_status, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2850 EXFUN (Fkill_process, 2); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2851 EXFUN (Fprocess_send_eof, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2852 EXFUN (Fwaiting_for_user_input_p, 0); |
10727 | 2853 extern Lisp_Object Qprocessp; |
20297
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2854 extern void kill_buffer_processes P_ ((Lisp_Object)); |
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2855 extern int wait_reading_process_input P_ ((int, int, Lisp_Object, int)); |
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2856 extern void deactivate_process P_ ((Lisp_Object)); |
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2857 extern void add_keyboard_wait_descriptor P_ ((int)); |
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2858 extern void delete_keyboard_wait_descriptor P_ ((int)); |
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2859 extern void close_process_descs P_ ((void)); |
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2860 extern void status_notify P_ ((void)); |
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2861 extern int read_process_output P_ ((Lisp_Object, int)); |
21931 | 2862 extern void init_process P_ ((void)); |
2863 extern void syms_of_process P_ ((void)); | |
49665
c102e97c89eb
(setup_process_coding_systems): Add prototype.
Kenichi Handa <handa@m17n.org>
parents:
49446
diff
changeset
|
2864 extern void setup_process_coding_systems P_ ((Lisp_Object)); |
302 | 2865 |
2866 /* defined in callproc.c */ | |
39810
4b565579e4f5
(Vload_suffixes, Vexec_suffixes): Declare.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
39804
diff
changeset
|
2867 extern Lisp_Object Vexec_path, Vexec_suffixes, |
4b565579e4f5
(Vload_suffixes, Vexec_suffixes): Declare.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
39804
diff
changeset
|
2868 Vexec_directory, Vdata_directory; |
6029 | 2869 extern Lisp_Object Vdoc_directory; |
25450
b5c133b3bfa0
Add declarations for some functions.
Andreas Schwab <schwab@suse.de>
parents:
25421
diff
changeset
|
2870 EXFUN (Fcall_process, MANY); |
20297
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2871 extern int child_setup P_ ((int, int, int, char **, int, Lisp_Object)); |
21931 | 2872 extern void init_callproc_1 P_ ((void)); |
2873 extern void init_callproc P_ ((void)); | |
2874 extern void set_process_environment P_ ((void)); | |
2875 extern void syms_of_callproc P_ ((void)); | |
302 | 2876 |
2877 /* defined in doc.c */ | |
2878 extern Lisp_Object Vdoc_file_name; | |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2879 EXFUN (Fsubstitute_command_keys, 1); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2880 EXFUN (Fdocumentation, 2); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2881 EXFUN (Fdocumentation_property, 3); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2882 extern Lisp_Object read_doc_string P_ ((Lisp_Object)); |
22604
51f68ee599f8
(get_doc_string): Adjust declaration.
Richard M. Stallman <rms@gnu.org>
parents:
22541
diff
changeset
|
2883 extern Lisp_Object get_doc_string P_ ((Lisp_Object, int, int)); |
21931 | 2884 extern void syms_of_doc P_ ((void)); |
25759
e473b3e5cf6d
Declare Fcurrent_message, Fmake_temp_name, read_bytecode_char,
Dave Love <fx@gnu.org>
parents:
25748
diff
changeset
|
2885 extern int read_bytecode_char P_ ((int)); |
302 | 2886 |
2887 /* defined in bytecode.c */ | |
2888 extern Lisp_Object Qbytecode; | |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2889 EXFUN (Fbyte_code, 3); |
21931 | 2890 extern void syms_of_bytecode P_ ((void)); |
26367
9f71d570068d
Add prototypes for new functions in bytecode.c.
Gerd Moellmann <gerd@gnu.org>
parents:
26309
diff
changeset
|
2891 extern struct byte_stack *byte_stack_list; |
9f71d570068d
Add prototypes for new functions in bytecode.c.
Gerd Moellmann <gerd@gnu.org>
parents:
26309
diff
changeset
|
2892 extern void mark_byte_stack P_ ((void)); |
26377
55f8aad5034d
Add prototype for unmark_byte_stack.
Gerd Moellmann <gerd@gnu.org>
parents:
26367
diff
changeset
|
2893 extern void unmark_byte_stack P_ ((void)); |
302 | 2894 |
2895 /* defined in macros.c */ | |
2896 extern Lisp_Object Qexecute_kbd_macro; | |
46886
1bc111036f11
(Fexecute_kbd_macro): Update prototype.
Kim F. Storm <storm@cua.dk>
parents:
46866
diff
changeset
|
2897 EXFUN (Fexecute_kbd_macro, 3); |
49866
c1513decc2e5
(Fcancel_kbd_macro_events, Fstring_to_multibyte): Add
Andreas Schwab <schwab@suse.de>
parents:
49665
diff
changeset
|
2898 EXFUN (Fcancel_kbd_macro_events, 0); |
21931 | 2899 extern void init_macros P_ ((void)); |
2900 extern void syms_of_macros P_ ((void)); | |
302 | 2901 |
1518
eda3ace74d74
* lisp.h (Fdefault_boundp, make_float, Ffloat, Fnth, Fcopy_alist,
Jim Blandy <jimb@redhat.com>
parents:
1442
diff
changeset
|
2902 /* defined in undo.c */ |
14665
7a50843d260f
(Qinhibit_read_only): Declared.
Richard M. Stallman <rms@gnu.org>
parents:
14473
diff
changeset
|
2903 extern Lisp_Object Qinhibit_read_only; |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2904 EXFUN (Fundo_boundary, 0); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2905 extern Lisp_Object truncate_undo_list P_ ((Lisp_Object, int, int)); |
20297
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2906 extern void record_marker_adjustment P_ ((Lisp_Object, int)); |
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2907 extern void record_insert P_ ((int, int)); |
21277
be5da0a5cf64
(record_delete): The second arg is Lisp_Object.
Kenichi Handa <handa@m17n.org>
parents:
21276
diff
changeset
|
2908 extern void record_delete P_ ((int, Lisp_Object)); |
20297
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2909 extern void record_first_change P_ ((void)); |
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2910 extern void record_change P_ ((int, int)); |
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2911 extern void record_property_change P_ ((int, int, Lisp_Object, Lisp_Object, |
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2912 Lisp_Object)); |
21931 | 2913 extern void syms_of_undo P_ ((void)); |
1518
eda3ace74d74
* lisp.h (Fdefault_boundp, make_float, Ffloat, Fnth, Fcopy_alist,
Jim Blandy <jimb@redhat.com>
parents:
1442
diff
changeset
|
2914 |
4067
379b03502e48
(Qinsert_before_hooks, Qinsert_after_hooks): Declared.
Richard M. Stallman <rms@gnu.org>
parents:
4035
diff
changeset
|
2915 /* defined in textprop.c */ |
51858
bf6232373c39
(VALBITS): Define in terms of GCTYPEBITS.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
51833
diff
changeset
|
2916 extern Lisp_Object Qfont, Qmouse_face; |
4079
c1b16f1167d4
(Qinsert_in_front_hooks, Qinsert_behind_hooks): Declared.
Richard M. Stallman <rms@gnu.org>
parents:
4067
diff
changeset
|
2917 extern Lisp_Object Qinsert_in_front_hooks, Qinsert_behind_hooks; |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2918 EXFUN (Fnext_single_property_change, 4); |
30322
6dd0219378f5
(Fnext_single_char_property_change): Add prototype.
Gerd Moellmann <gerd@gnu.org>
parents:
30218
diff
changeset
|
2919 EXFUN (Fnext_single_char_property_change, 4); |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2920 EXFUN (Fprevious_single_property_change, 4); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2921 EXFUN (Fput_text_property, 5); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2922 EXFUN (Fprevious_char_property_change, 2); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2923 EXFUN (Fnext_char_property_change, 2); |
20297
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2924 extern void report_interval_modification P_ ((Lisp_Object, Lisp_Object)); |
25818
c5458623cf16
(toplevel): Add prototype for
Gerd Moellmann <gerd@gnu.org>
parents:
25786
diff
changeset
|
2925 extern Lisp_Object next_single_char_property_change P_ ((Lisp_Object, |
c5458623cf16
(toplevel): Add prototype for
Gerd Moellmann <gerd@gnu.org>
parents:
25786
diff
changeset
|
2926 Lisp_Object, |
c5458623cf16
(toplevel): Add prototype for
Gerd Moellmann <gerd@gnu.org>
parents:
25786
diff
changeset
|
2927 Lisp_Object, |
c5458623cf16
(toplevel): Add prototype for
Gerd Moellmann <gerd@gnu.org>
parents:
25786
diff
changeset
|
2928 Lisp_Object)); |
4067
379b03502e48
(Qinsert_before_hooks, Qinsert_after_hooks): Declared.
Richard M. Stallman <rms@gnu.org>
parents:
4035
diff
changeset
|
2929 |
12093
7212f4fd85e3
(Fwaiting_for_user_input_p): Function declared.
Karl Heuer <kwzh@gnu.org>
parents:
11934
diff
changeset
|
2930 /* defined in xmenu.c */ |
18732
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2931 EXFUN (Fx_popup_menu, 2); |
a0663e413622
(EXFUN, P_): New definitions. Use them to declare
Richard M. Stallman <rms@gnu.org>
parents:
18613
diff
changeset
|
2932 EXFUN (Fx_popup_dialog, 2); |
21931 | 2933 extern void syms_of_xmenu P_ ((void)); |
20297
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2934 |
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2935 /* defined in sysdep.c */ |
25769
4399d55899d3
(RETURN_UNGCPRO): Use do-while (0) idiom.
Gerd Moellmann <gerd@gnu.org>
parents:
25765
diff
changeset
|
2936 extern void stuff_char P_ ((char c)); |
20297
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2937 extern void init_sigio P_ ((int)); |
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2938 extern void request_sigio P_ ((void)); |
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2939 extern void unrequest_sigio P_ ((void)); |
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2940 extern void reset_sys_modes P_ ((void)); |
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2941 extern void sys_subshell P_ ((void)); |
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2942 extern void sys_suspend P_ ((void)); |
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2943 extern void discard_tty_input P_ ((void)); |
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2944 extern void init_sys_modes P_ ((void)); |
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2945 extern void reset_sys_modes P_ ((void)); |
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2946 extern void get_frame_size P_ ((int *, int *)); |
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2947 extern void wait_for_termination P_ ((int)); |
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2948 extern void flush_pending_output P_ ((int)); |
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2949 extern void child_setup_tty P_ ((int)); |
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2950 extern void setup_pty P_ ((int)); |
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2951 extern int set_window_size P_ ((int, int, int)); |
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2952 extern void create_process P_ ((Lisp_Object, char **, Lisp_Object)); |
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2953 extern int tabs_safe_p P_ ((void)); |
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2954 extern void init_baud_rate P_ ((void)); |
46471
028a5b2de9e4
(chars_in_text, multibyte_chars_in_text, copy_text):
Ken Raeburn <raeburn@raeburn.org>
parents:
46428
diff
changeset
|
2955 extern int emacs_open P_ ((const char *, int, int)); |
26088
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
25818
diff
changeset
|
2956 extern int emacs_close P_ ((int)); |
b7aa6ac26872
Add support for large files, 64-bit Solaris, system locale codings.
Paul Eggert <eggert@twinsun.com>
parents:
25818
diff
changeset
|
2957 extern int emacs_read P_ ((int, char *, unsigned int)); |
46552
cb055b77d3c6
(STRING_COPYIN): New macro.
Ken Raeburn <raeburn@raeburn.org>
parents:
46471
diff
changeset
|
2958 extern int emacs_write P_ ((int, const char *, unsigned int)); |
20297
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2959 |
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2960 /* defined in filelock.c */ |
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2961 EXFUN (Funlock_buffer, 0); |
21711
2aa9965afd39
Remove extraneous semicolon.
Erik Naggum <erik@naggum.no>
parents:
21515
diff
changeset
|
2962 EXFUN (Ffile_locked_p, 1); |
20297
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2963 extern void unlock_all_files P_ ((void)); |
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2964 extern void lock_file P_ ((Lisp_Object)); |
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2965 extern void unlock_file P_ ((Lisp_Object)); |
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
2966 extern void unlock_buffer P_ ((struct buffer *)); |
21931 | 2967 extern void syms_of_filelock P_ ((void)); |
25748
6fddda6e635e
Add prototype for uninterrupt_malloc, memory_warnings,
Gerd Moellmann <gerd@gnu.org>
parents:
25737
diff
changeset
|
2968 extern void init_filelock P_ ((void)); |
6fddda6e635e
Add prototype for uninterrupt_malloc, memory_warnings,
Gerd Moellmann <gerd@gnu.org>
parents:
25737
diff
changeset
|
2969 |
6fddda6e635e
Add prototype for uninterrupt_malloc, memory_warnings,
Gerd Moellmann <gerd@gnu.org>
parents:
25737
diff
changeset
|
2970 /* Defined in sound.c */ |
6fddda6e635e
Add prototype for uninterrupt_malloc, memory_warnings,
Gerd Moellmann <gerd@gnu.org>
parents:
25737
diff
changeset
|
2971 extern void syms_of_sound P_ ((void)); |
6fddda6e635e
Add prototype for uninterrupt_malloc, memory_warnings,
Gerd Moellmann <gerd@gnu.org>
parents:
25737
diff
changeset
|
2972 extern void init_sound P_ ((void)); |
21931 | 2973 |
2974 /* Defined in category.c */ | |
2975 extern void init_category_once P_ ((void)); | |
2976 extern void syms_of_category P_ ((void)); | |
2977 | |
2978 /* Defined in ccl.c */ | |
2979 extern void syms_of_ccl P_ ((void)); | |
2980 | |
2981 /* Defined in dired.c */ | |
53111 | 2982 EXFUN (Ffile_attributes, 2); |
21931 | 2983 extern void syms_of_dired P_ ((void)); |
2984 | |
2985 /* Defined in term.c */ | |
2986 extern void syms_of_term P_ ((void)); | |
31991
9f3e98c1221e
(fatal): Declare NO_RETURN.
Gerd Moellmann <gerd@gnu.org>
parents:
31907
diff
changeset
|
2987 extern void fatal () NO_RETURN; |
21931 | 2988 |
2989 #ifdef HAVE_X_WINDOWS | |
2990 /* Defined in fontset.c */ | |
2991 extern void syms_of_fontset P_ ((void)); | |
25017
4a142fb92f94
(P_): Moved to top of file.
Gerd Moellmann <gerd@gnu.org>
parents:
23984
diff
changeset
|
2992 EXFUN (Fset_fontset_font, 4); |
21931 | 2993 #endif |
2994 | |
2995 /* Defined in xfaces.c */ | |
2996 extern void syms_of_xfaces P_ ((void)); | |
2997 | |
25712
178d6245c681
Add prototype for debug_print.
Gerd Moellmann <gerd@gnu.org>
parents:
25704
diff
changeset
|
2998 /* Defined in getloadavg.c */ |
178d6245c681
Add prototype for debug_print.
Gerd Moellmann <gerd@gnu.org>
parents:
25704
diff
changeset
|
2999 extern int getloadavg P_ ((double *, int)); |
178d6245c681
Add prototype for debug_print.
Gerd Moellmann <gerd@gnu.org>
parents:
25704
diff
changeset
|
3000 |
21931 | 3001 #ifdef HAVE_X_WINDOWS |
3002 /* Defined in xfns.c */ | |
3003 extern void syms_of_xfns P_ ((void)); | |
25748
6fddda6e635e
Add prototype for uninterrupt_malloc, memory_warnings,
Gerd Moellmann <gerd@gnu.org>
parents:
25737
diff
changeset
|
3004 extern void init_xfns P_ ((void)); |
36941
8107e2a17261
(Vx_resource_name) [HAVE_X_WINDOWS]: Declare extern.
Gerd Moellmann <gerd@gnu.org>
parents:
36816
diff
changeset
|
3005 extern Lisp_Object Vx_resource_name; |
49322 | 3006 extern Lisp_Object Vx_resource_class; |
27885 | 3007 EXFUN (Fxw_display_color_p, 1); |
43176
0d7ab82f058d
(Fx_file_dialog): Export (for Motif code in fileio.c).
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
42756
diff
changeset
|
3008 EXFUN (Fx_file_dialog, 4); |
28141
52b185e0d8bd
(free_frame_xic) [HAVE_X_I18N]: Add missing semicolon.
Gerd Moellmann <gerd@gnu.org>
parents:
28054
diff
changeset
|
3009 #endif /* HAVE_X_WINDOWS */ |
21931 | 3010 |
43816
a00859016219
Extern declare syms_of_xsmfns ().
Jan Djärv <jan.h.d@swipnet.se>
parents:
43782
diff
changeset
|
3011 /* Defined in xsmfns.c */ |
a00859016219
Extern declare syms_of_xsmfns ().
Jan Djärv <jan.h.d@swipnet.se>
parents:
43782
diff
changeset
|
3012 extern void syms_of_xsmfns P_ ((void)); |
a00859016219
Extern declare syms_of_xsmfns ().
Jan Djärv <jan.h.d@swipnet.se>
parents:
43782
diff
changeset
|
3013 |
21931 | 3014 /* Defined in xselect.c */ |
3015 extern void syms_of_xselect P_ ((void)); | |
3016 | |
3017 /* Defined in xterm.c */ | |
3018 extern void syms_of_xterm P_ ((void)); | |
25759
e473b3e5cf6d
Declare Fcurrent_message, Fmake_temp_name, read_bytecode_char,
Dave Love <fx@gnu.org>
parents:
25748
diff
changeset
|
3019 |
e473b3e5cf6d
Declare Fcurrent_message, Fmake_temp_name, read_bytecode_char,
Dave Love <fx@gnu.org>
parents:
25748
diff
changeset
|
3020 /* Defined in getloadavg.c */ |
e473b3e5cf6d
Declare Fcurrent_message, Fmake_temp_name, read_bytecode_char,
Dave Love <fx@gnu.org>
parents:
25748
diff
changeset
|
3021 extern int getloadavg P_ ((double [], int)); |
29779
4fe4901e5113
(x_set_tool_bar_lines, free_frame_xic, compose_text, getenv, ctime)
Dave Love <fx@gnu.org>
parents:
29636
diff
changeset
|
3022 |
302 | 3023 /* Nonzero means Emacs has already been initialized. |
3024 Used during startup to detect startup of dumped Emacs. */ | |
3025 extern int initialized; | |
3026 | |
3027 extern int immediate_quit; /* Nonzero means ^G can quit instantly */ | |
3028 | |
30556
8014dddae2f1
(Fsingle_key_description, xmalloc, xrealloc): Change
Gerd Moellmann <gerd@gnu.org>
parents:
30489
diff
changeset
|
3029 extern POINTER_TYPE *xmalloc P_ ((size_t)); |
8014dddae2f1
(Fsingle_key_description, xmalloc, xrealloc): Change
Gerd Moellmann <gerd@gnu.org>
parents:
30489
diff
changeset
|
3030 extern POINTER_TYPE *xrealloc P_ ((POINTER_TYPE *, size_t)); |
29785
d092cbe8cae7
Add xfree missed from last change.
Dave Love <fx@gnu.org>
parents:
29779
diff
changeset
|
3031 extern void xfree P_ ((POINTER_TYPE *)); |
d092cbe8cae7
Add xfree missed from last change.
Dave Love <fx@gnu.org>
parents:
29779
diff
changeset
|
3032 |
46471
028a5b2de9e4
(chars_in_text, multibyte_chars_in_text, copy_text):
Ken Raeburn <raeburn@raeburn.org>
parents:
46428
diff
changeset
|
3033 extern char *xstrdup P_ ((const char *)); |
302 | 3034 |
31097
cf17fa39721a
[WINDOWSNT]: Don't declare externs for getenv, ctime and getwd.
Andrew Innes <andrewi@gnu.org>
parents:
31015
diff
changeset
|
3035 #ifndef USE_CRT_DLL |
20297
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
3036 extern char *egetenv P_ ((char *)); |
31097
cf17fa39721a
[WINDOWSNT]: Don't declare externs for getenv, ctime and getwd.
Andrew Innes <andrewi@gnu.org>
parents:
31015
diff
changeset
|
3037 #endif |
17404
73012b195cf3
(DOWNCASE): Return int, not Lisp_Object.
Karl Heuer <kwzh@gnu.org>
parents:
17326
diff
changeset
|
3038 |
7906
1d64f77001be
declare init_system_name (replaces get_system_name).
Karl Heuer <kwzh@gnu.org>
parents:
7307
diff
changeset
|
3039 /* Set up the name of the machine we're running on. */ |
20297
bf0a54297d95
Add more prototypes and declarations. Forward declare
Andreas Schwab <schwab@suse.de>
parents:
20123
diff
changeset
|
3040 extern void init_system_name P_ ((void)); |
9799
c9c11e41bf07
(DEVICE_SEP, DIRECTORY_SEP, IS_DEVICE_SEP)
Richard M. Stallman <rms@gnu.org>
parents:
9572
diff
changeset
|
3041 |
c9c11e41bf07
(DEVICE_SEP, DIRECTORY_SEP, IS_DEVICE_SEP)
Richard M. Stallman <rms@gnu.org>
parents:
9572
diff
changeset
|
3042 /* Some systems (e.g., NT) use a different path separator than Unix, |
c9c11e41bf07
(DEVICE_SEP, DIRECTORY_SEP, IS_DEVICE_SEP)
Richard M. Stallman <rms@gnu.org>
parents:
9572
diff
changeset
|
3043 in addition to a device separator. Default the path separator |
c9c11e41bf07
(DEVICE_SEP, DIRECTORY_SEP, IS_DEVICE_SEP)
Richard M. Stallman <rms@gnu.org>
parents:
9572
diff
changeset
|
3044 to '/', and don't test for a device separator in IS_ANY_SEP. */ |
c9c11e41bf07
(DEVICE_SEP, DIRECTORY_SEP, IS_DEVICE_SEP)
Richard M. Stallman <rms@gnu.org>
parents:
9572
diff
changeset
|
3045 |
15090
c07a2c3e141d
[WINDOWS_NT]: Declare Vdirectory_sep_char.
Richard M. Stallman <rms@gnu.org>
parents:
14665
diff
changeset
|
3046 #ifdef WINDOWSNT |
c07a2c3e141d
[WINDOWS_NT]: Declare Vdirectory_sep_char.
Richard M. Stallman <rms@gnu.org>
parents:
14665
diff
changeset
|
3047 extern Lisp_Object Vdirectory_sep_char; |
c07a2c3e141d
[WINDOWS_NT]: Declare Vdirectory_sep_char.
Richard M. Stallman <rms@gnu.org>
parents:
14665
diff
changeset
|
3048 #endif |
c07a2c3e141d
[WINDOWS_NT]: Declare Vdirectory_sep_char.
Richard M. Stallman <rms@gnu.org>
parents:
14665
diff
changeset
|
3049 |
9799
c9c11e41bf07
(DEVICE_SEP, DIRECTORY_SEP, IS_DEVICE_SEP)
Richard M. Stallman <rms@gnu.org>
parents:
9572
diff
changeset
|
3050 #ifndef DIRECTORY_SEP |
c9c11e41bf07
(DEVICE_SEP, DIRECTORY_SEP, IS_DEVICE_SEP)
Richard M. Stallman <rms@gnu.org>
parents:
9572
diff
changeset
|
3051 #define DIRECTORY_SEP '/' |
c9c11e41bf07
(DEVICE_SEP, DIRECTORY_SEP, IS_DEVICE_SEP)
Richard M. Stallman <rms@gnu.org>
parents:
9572
diff
changeset
|
3052 #endif |
c9c11e41bf07
(DEVICE_SEP, DIRECTORY_SEP, IS_DEVICE_SEP)
Richard M. Stallman <rms@gnu.org>
parents:
9572
diff
changeset
|
3053 #ifndef IS_DIRECTORY_SEP |
c9c11e41bf07
(DEVICE_SEP, DIRECTORY_SEP, IS_DEVICE_SEP)
Richard M. Stallman <rms@gnu.org>
parents:
9572
diff
changeset
|
3054 #define IS_DIRECTORY_SEP(_c_) ((_c_) == DIRECTORY_SEP) |
c9c11e41bf07
(DEVICE_SEP, DIRECTORY_SEP, IS_DEVICE_SEP)
Richard M. Stallman <rms@gnu.org>
parents:
9572
diff
changeset
|
3055 #endif |
c9c11e41bf07
(DEVICE_SEP, DIRECTORY_SEP, IS_DEVICE_SEP)
Richard M. Stallman <rms@gnu.org>
parents:
9572
diff
changeset
|
3056 #ifndef IS_DEVICE_SEP |
c9c11e41bf07
(DEVICE_SEP, DIRECTORY_SEP, IS_DEVICE_SEP)
Richard M. Stallman <rms@gnu.org>
parents:
9572
diff
changeset
|
3057 #ifndef DEVICE_SEP |
c9c11e41bf07
(DEVICE_SEP, DIRECTORY_SEP, IS_DEVICE_SEP)
Richard M. Stallman <rms@gnu.org>
parents:
9572
diff
changeset
|
3058 #define IS_DEVICE_SEP(_c_) 0 |
c9c11e41bf07
(DEVICE_SEP, DIRECTORY_SEP, IS_DEVICE_SEP)
Richard M. Stallman <rms@gnu.org>
parents:
9572
diff
changeset
|
3059 #else |
c9c11e41bf07
(DEVICE_SEP, DIRECTORY_SEP, IS_DEVICE_SEP)
Richard M. Stallman <rms@gnu.org>
parents:
9572
diff
changeset
|
3060 #define IS_DEVICE_SEP(_c_) ((_c_) == DEVICE_SEP) |
c9c11e41bf07
(DEVICE_SEP, DIRECTORY_SEP, IS_DEVICE_SEP)
Richard M. Stallman <rms@gnu.org>
parents:
9572
diff
changeset
|
3061 #endif |
c9c11e41bf07
(DEVICE_SEP, DIRECTORY_SEP, IS_DEVICE_SEP)
Richard M. Stallman <rms@gnu.org>
parents:
9572
diff
changeset
|
3062 #endif |
c9c11e41bf07
(DEVICE_SEP, DIRECTORY_SEP, IS_DEVICE_SEP)
Richard M. Stallman <rms@gnu.org>
parents:
9572
diff
changeset
|
3063 #ifndef IS_ANY_SEP |
c9c11e41bf07
(DEVICE_SEP, DIRECTORY_SEP, IS_DEVICE_SEP)
Richard M. Stallman <rms@gnu.org>
parents:
9572
diff
changeset
|
3064 #define IS_ANY_SEP(_c_) (IS_DIRECTORY_SEP (_c_)) |
c9c11e41bf07
(DEVICE_SEP, DIRECTORY_SEP, IS_DEVICE_SEP)
Richard M. Stallman <rms@gnu.org>
parents:
9572
diff
changeset
|
3065 #endif |
10455 | 3066 |
3067 #ifdef SWITCH_ENUM_BUG | |
3068 #define SWITCH_ENUM_CAST(x) ((int)(x)) | |
3069 #else | |
3070 #define SWITCH_ENUM_CAST(x) (x) | |
3071 #endif | |
39579
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
3072 |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
3073 /* Loop over Lisp list LIST. Signal an error if LIST is not a proper |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
3074 list, or if it contains circles. |
45623
0e92d219e195
(current_column): Now returns float.
Thien-Thi Nguyen <ttn@gnuvola.org>
parents:
45545
diff
changeset
|
3075 |
39579
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
3076 HARE and TORTOISE should be the names of Lisp_Object variables, and |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
3077 N should be the name of an EMACS_INT variable declared in the |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
3078 function where the macro is used. Each nested loop should use |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
3079 its own variables. |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
3080 |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
3081 In the loop body, HARE is set to each cons of LIST, and N is the |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
3082 length of the list processed so far. */ |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
3083 |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
3084 #define LIST_END_P(list, obj) \ |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
3085 (NILP (obj) \ |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
3086 ? 1 \ |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
3087 : (CONSP (obj) \ |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
3088 ? 0 \ |
41615
6486180ed9ef
(run_hook_list_with_args): Remove.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
41262
diff
changeset
|
3089 : (wrong_type_argument (Qlistp, (list))), 1)) |
39579
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
3090 |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
3091 #define FOREACH(hare, list, tortoise, n) \ |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
3092 for (tortoise = hare = (list), n = 0; \ |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
3093 !LIST_END_P (list, hare); \ |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
3094 (hare = XCDR (hare), ++n, \ |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
3095 ((n & 1) != 0 \ |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
3096 ? (tortoise = XCDR (tortoise), \ |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
3097 (EQ (hare, tortoise) \ |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
3098 && (circular_list_error ((list)), 1))) \ |
e307d3530117
(LIST_END_P, FOREACH): New macros.
Gerd Moellmann <gerd@gnu.org>
parents:
39451
diff
changeset
|
3099 : 0))) |
39681 | 3100 |
3101 /* The ubiquitous min and max macros. */ | |
3102 | |
39710
45e11013c850
[max]: Undef min and max before redefining them.
Andrew Innes <andrewi@gnu.org>
parents:
39699
diff
changeset
|
3103 #ifdef max |
45e11013c850
[max]: Undef min and max before redefining them.
Andrew Innes <andrewi@gnu.org>
parents:
39699
diff
changeset
|
3104 #undef max |
45e11013c850
[max]: Undef min and max before redefining them.
Andrew Innes <andrewi@gnu.org>
parents:
39699
diff
changeset
|
3105 #undef min |
45e11013c850
[max]: Undef min and max before redefining them.
Andrew Innes <andrewi@gnu.org>
parents:
39699
diff
changeset
|
3106 #endif |
39681 | 3107 #define min(a, b) ((a) < (b) ? (a) : (b)) |
3108 #define max(a, b) ((a) > (b) ? (a) : (b)) | |
39773
51f74f0f7fce
(make_fixnum_or_float): New macro.
Gerd Moellmann <gerd@gnu.org>
parents:
39766
diff
changeset
|
3109 |
51f74f0f7fce
(make_fixnum_or_float): New macro.
Gerd Moellmann <gerd@gnu.org>
parents:
39766
diff
changeset
|
3110 /* Return a fixnum or float, depending on whether VAL fits in a Lisp |
51f74f0f7fce
(make_fixnum_or_float): New macro.
Gerd Moellmann <gerd@gnu.org>
parents:
39766
diff
changeset
|
3111 fixnum. */ |
51f74f0f7fce
(make_fixnum_or_float): New macro.
Gerd Moellmann <gerd@gnu.org>
parents:
39766
diff
changeset
|
3112 |
51f74f0f7fce
(make_fixnum_or_float): New macro.
Gerd Moellmann <gerd@gnu.org>
parents:
39766
diff
changeset
|
3113 #define make_fixnum_or_float(val) \ |
41615
6486180ed9ef
(run_hook_list_with_args): Remove.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
41262
diff
changeset
|
3114 (FIXNUM_OVERFLOW_P (val) \ |
6486180ed9ef
(run_hook_list_with_args): Remove.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
41262
diff
changeset
|
3115 ? make_float (val) \ |
6486180ed9ef
(run_hook_list_with_args): Remove.
Stefan Monnier <monnier@iro.umontreal.ca>
parents:
41262
diff
changeset
|
3116 : make_number ((EMACS_INT)(val))) |
52274 | 3117 |
3118 #endif /* EMACS_LISP_H */ | |
52401 | 3119 |
3120 /* arch-tag: 9b2ed020-70eb-47ac-94ee-e1c2a5107d5e | |
3121 (do not change this comment) */ |