Mercurial > hg > xemacs-beta
annotate src/lisp.h @ 4843:715b15990d0a
add more foo_checking_assert macros
lisp.h: Add structure_checking_assert(), gc_checking_assert(), etc. for
all types of error-checking. Also FOO_checking_assert_with_message()
and inline_FOO_checking_assert() -- the latter for use in an inline
function where you want the calling function's line/file to be reported
(requires some conspiracy with the function itself).
Add disabled_assert(), disabled_assert_at_line(),
disabled_assert_with_message(), for what to do when an assert is
disabled. Formerly, we used to do ((void) 0), but now we do
((void) x), so the variable appears used and any side effects of the
expression do get done. In Unicode-internal, the standard assert()
uses this, but not yet in this workspace.
author | Ben Wing <ben@xemacs.org> |
---|---|
date | Wed, 13 Jan 2010 03:01:43 -0600 |
parents | 3465c3161fea |
children | 91b3d00e717f |
rev | line source |
---|---|
428 | 1 /* Fundamental definitions for XEmacs Lisp interpreter. |
2 Copyright (C) 1985-1987, 1992-1995 Free Software Foundation, Inc. | |
3 Copyright (C) 1993-1996 Richard Mlynarik. | |
4843
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
4 Copyright (C) 1995, 1996, 2000-2005, 2009, 2010 Ben Wing. |
428 | 5 |
6 This file is part of XEmacs. | |
7 | |
8 XEmacs is free software; you can redistribute it and/or modify it | |
9 under the terms of the GNU General Public License as published by the | |
10 Free Software Foundation; either version 2, or (at your option) any | |
11 later version. | |
12 | |
13 XEmacs is distributed in the hope that it will be useful, but WITHOUT | |
14 ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or | |
15 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License | |
16 for more details. | |
17 | |
18 You should have received a copy of the GNU General Public License | |
19 along with XEmacs; see the file COPYING. If not, write to | |
20 the Free Software Foundation, Inc., 59 Temple Place - Suite 330, | |
21 Boston, MA 02111-1307, USA. */ | |
22 | |
23 /* Synched up with: FSF 19.30. */ | |
24 | |
853 | 25 /* Authorship: |
26 | |
27 Based on code from pre-release FSF 19, c. 1991. | |
28 Various changes by Jamie Zawinski 1991-1994: | |
29 converting to ANSI C, splitting out function prototypes to a separate | |
30 file (later moved back for unknown reasons by Steve Baur?), debug-gcpro | |
31 stuff (now moribund). | |
32 ANSI-fication of DEFUN macros by Felix Lee, c. 1992? | |
33 NOT_REACHED, DOESNT_RETURN, PRINTF_ARGS by Richard Mlynarik, c. 1994. | |
34 Many changes over the years corresponding to Lisp_Object definition | |
35 changes, esp. by Richard Mlynarik (c. 1993) and Kyle Jones (c. 1998). | |
36 See alloc.c for more details. | |
37 Overhauled and reordered by Ben Wing, 1995-1996, and many things added: | |
38 Dynarrs, REALLOC macros, asserts, typedefs, inline header code, | |
39 first LIST_LOOP macros, CONCHECK_*, all error-checking code | |
40 (e.g. error-checking versions of XFOO macros), structure read syntax, | |
41 weak lists, lcrecord lists, reworking of quit handling, object hashing, | |
42 nested GCPRO, character objects and Ebola checking, memory usage stats, | |
43 others. | |
44 LOADHIST changes from Steve Baur, c. 1997? | |
45 Various macro-related changes by Martin Buchholz, 1998-1999: | |
46 LIST_LOOP macros greatly expanded and tortoise-hared; | |
47 RETURN_SANS_WARNINGS; reworked DEFUN macros; EXFUN macros (???). | |
1743 | 48 Various macro-related changes by Jerry James, 2003: |
49 MODULE_API introduced; | |
50 Compiler-specific definitions modernized and moved to compiler.h. | |
853 | 51 */ |
52 | |
440 | 53 #ifndef INCLUDED_lisp_h_ |
54 #define INCLUDED_lisp_h_ | |
428 | 55 |
56 /************************************************************************/ | |
57 /* general definitions */ | |
58 /************************************************************************/ | |
59 | |
2367 | 60 /* Conventions in comments: |
61 | |
62 "Mule-izing" is the process of going through a file and eliminating | |
63 assumptions that the internal format (Ibyte * text) is the same as the | |
64 external format used by library routines. Mule-ization should also | |
65 include replacing *ALL* raw references to `char' or `unsigned char' with | |
66 one of the self-documenting types created below. How exactly to do the | |
67 conversion, and how to write correctly Mule-ized code, is described in | |
68 the internals manual. Files that say "This file is Mule-ized" have | |
69 been reviewed at some point; that's not to say that incorrect code hasn't | |
70 crept in, though. | |
71 | |
72 "Unicode-splitting" is the process of fixing a file so that it will | |
73 handle external text in Unicode under Microsoft Windows, as appropriate. | |
74 ("splitting" because it needs to handle either Unicode or variable-width | |
75 multibyte depending on the OS -- NT or 9x). See intl-win32.c. | |
76 | |
77 #### is a way of marking problems of any sort. | |
78 | |
79 !!#### marks places that are not properly Mule-ized. | |
80 | |
81 &&#### marks places that need to be fixed in order for the "8-bit mule" | |
82 conversion to work correctly, i.e. in order to support multiple different | |
83 buffer formats under Mule, including a fixed 8-bit format. | |
84 | |
85 ^^#### marks places that need to be fixed in order to eliminate the | |
86 assumption that Ibyte * text is composed of 1-byte units (e.g. UTF-16 | |
87 is composed of 2-byte units and might be a possible format to consider | |
88 for Ibyte * text). | |
89 | |
90 %%#### marks places that need work for KKCC (the new garbage collector). | |
91 | |
92 */ | |
93 | |
1318 | 94 /* -------------------------- include files --------------------- */ |
442 | 95 |
428 | 96 /* We include the following generally useful header files so that you |
97 don't have to worry about prototypes when using the standard C | |
98 library functions and macros. These files shouldn't be excessively | |
99 large so they shouldn't cause that much of a slowdown. */ | |
100 | |
101 #include <stdlib.h> | |
102 #include <string.h> /* primarily for memcpy, etc. */ | |
103 #include <stdio.h> /* NULL, etc. */ | |
104 #include <ctype.h> | |
105 #include <stdarg.h> | |
106 #include <stddef.h> /* offsetof */ | |
107 #include <sys/types.h> | |
442 | 108 #include <limits.h> |
109 | |
1318 | 110 /* -------------------------- error-checking ------------------------ */ |
853 | 111 |
112 /* The large categories established by configure can be subdivided into | |
113 smaller subcategories, for problems in specific modules. You can't | |
114 control this using configure, but you can manually stick in a define as | |
115 necessary. */ | |
116 | |
4843
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
117 /* How these work: |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
118 |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
119 The most common classes will be `text' and `type', followed by `structure'. |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
120 `text' is for problems related to bad textual format. `type' is for |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
121 problems related to wrongly typed arguments, structure fields, etc. |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
122 `structure' is for bad data inside of a structure. Sometimes these are |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
123 used "incorrectly", e.g. `type' is often used for structure-checking. |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
124 Consider `text': |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
125 |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
126 `text_checking_assert() will assert() only when ERROR_CHECK_TEXT is defined; |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
127 otherwise it's a no-op. text_checking_assert_at_line() is similar, but |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
128 allows you to override the file name and line number normally supplied in |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
129 the message. This is especially useful in inline header functions, and |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
130 so there's a special inline_text_checking_assert() for this; this works |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
131 like text_checking_assert() but supplies the file and line of the calling |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
132 function. In order for this to work, you need to declare your inline |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
133 function with INLINE_TEXT_CHECK_ARGS at the end of its argument list, |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
134 and give its function name a _1 extension or similar. Then create a |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
135 macro that calls your inline function and includes INLINE_TEXT_CHECK_CALL |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
136 at the end of the parameter list. This will arrange to pass in and receive |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
137 the file and line (__FILE__, __LINE__) at place where the call occurs in |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
138 the calling function; but nothing will get passed in when ERROR_CHECK_TEXT |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
139 is not defined. |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
140 */ |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
141 |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
142 |
853 | 143 #ifdef ERROR_CHECK_STRUCTURES |
144 /* Check for problems with the catch list and specbind stack */ | |
145 #define ERROR_CHECK_CATCH | |
146 /* Check for insufficient use of call_trapping_problems(), particularly | |
147 due to glyph-related changes causing eval or QUIT within redisplay */ | |
148 #define ERROR_CHECK_TRAPPING_PROBLEMS | |
4843
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
149 #endif /* ERROR_CHECK_STRUCTURES */ |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
150 |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
151 #define INLINE_ERROR_CHECK_ARGS , const char *__file__, int __line__ |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
152 #define INLINE_ERROR_CHECK_CALL , __FILE__, __LINE__ |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
153 #define DISABLED_INLINE_ERROR_CHECK_ARGS |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
154 #define DISABLED_INLINE_ERROR_CHECK_CALL |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
155 |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
156 /* For assertions in inline header functions which will report the file and |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
157 line of the calling function */ |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
158 #define inline_assert(assertion) assert_at_line (assertion, __file__, __line__) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
159 #define disabled_inline_assert(assertion) \ |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
160 disabled_assert_at_line (assertion, __file__, __line__) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
161 |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
162 #ifdef ERROR_CHECK_TEXT |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
163 #define text_checking_assert(assertion) assert (assertion) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
164 #define text_checking_assert_at_line(assertion, file, line) \ |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
165 assert_at_line (assertion, file, line) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
166 #define inline_text_checking_assert(assertion) inline_assert (assertion) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
167 #define INLINE_TEXT_CHECK_ARGS INLINE_ERROR_CHECK_ARGS |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
168 #define INLINE_TEXT_CHECK_CALL INLINE_ERROR_CHECK_CALL |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
169 #define text_checking_assert_with_message(assertion, msg) \ |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
170 assert_with_message (assertion, msg) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
171 #else /* not ERROR_CHECK_TEXT */ |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
172 #define text_checking_assert(assertion) disabled_assert (assertion) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
173 #define text_checking_assert_at_line(assertion, file, line) \ |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
174 disabled_assert_at_line (assertion, file, line) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
175 #define inline_text_checking_assert(assertion) \ |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
176 disabled_inline_assert (assertion) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
177 #define INLINE_TEXT_CHECK_ARGS DISABLED_INLINE_ERROR_CHECK_ARGS |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
178 #define INLINE_TEXT_CHECK_CALL DISABLED_INLINE_ERROR_CHECK_CALL |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
179 #define text_checking_assert_with_message(assertion, msg) \ |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
180 disabled_assert_with_message (assertion, msg) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
181 #endif /* ERROR_CHECK_TEXT */ |
853 | 182 |
1318 | 183 #ifdef ERROR_CHECK_TYPES |
184 #define type_checking_assert(assertion) assert (assertion) | |
185 #define type_checking_assert_at_line(assertion, file, line) \ | |
186 assert_at_line (assertion, file, line) | |
4843
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
187 #define inline_type_checking_assert(assertion) inline_assert (assertion) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
188 #define INLINE_TYPE_CHECK_ARGS INLINE_ERROR_CHECK_ARGS |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
189 #define INLINE_TYPE_CHECK_CALL INLINE_ERROR_CHECK_CALL |
1318 | 190 #define type_checking_assert_with_message(assertion, msg) \ |
191 assert_with_message (assertion, msg) | |
4843
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
192 #else /* not ERROR_CHECK_TYPES */ |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
193 #define type_checking_assert(assertion) disabled_assert (assertion) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
194 #define type_checking_assert_at_line(assertion, file, line) \ |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
195 disabled_assert_at_line (assertion, file, line) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
196 #define inline_type_checking_assert(assertion) \ |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
197 disabled_inline_assert (assertion) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
198 #define INLINE_TYPE_CHECK_ARGS DISABLED_INLINE_ERROR_CHECK_ARGS |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
199 #define INLINE_TYPE_CHECK_CALL DISABLED_INLINE_ERROR_CHECK_CALL |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
200 #define type_checking_assert_with_message(assertion, msg) \ |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
201 disabled_assert_with_message (assertion, msg) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
202 #endif /* ERROR_CHECK_TYPES */ |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
203 |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
204 #ifdef ERROR_CHECK_STRUCTURES |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
205 #define structure_checking_assert(assertion) assert (assertion) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
206 #define structure_checking_assert_at_line(assertion, file, line) \ |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
207 assert_at_line (assertion, file, line) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
208 #define inline_structure_checking_assert(assertion) inline_assert (assertion) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
209 #define INLINE_STRUCTURE_CHECK_ARGS INLINE_ERROR_CHECK_ARGS |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
210 #define INLINE_STRUCTURE_CHECK_CALL INLINE_ERROR_CHECK_CALL |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
211 #define structure_checking_assert_with_message(assertion, msg) \ |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
212 assert_with_message (assertion, msg) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
213 #else /* not ERROR_CHECK_STRUCTURES */ |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
214 #define structure_checking_assert(assertion) disabled_assert (assertion) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
215 #define structure_checking_assert_at_line(assertion, file, line) \ |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
216 disabled_assert_at_line (assertion, file, line) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
217 #define inline_structure_checking_assert(assertion) \ |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
218 disabled_inline_assert (assertion) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
219 #define INLINE_STRUCTURE_CHECK_ARGS DISABLED_INLINE_ERROR_CHECK_ARGS |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
220 #define INLINE_STRUCTURE_CHECK_CALL DISABLED_INLINE_ERROR_CHECK_CALL |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
221 #define structure_checking_assert_with_message(assertion, msg) \ |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
222 disabled_assert_with_message (assertion, msg) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
223 #endif /* ERROR_CHECK_STRUCTURES */ |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
224 |
1318 | 225 #ifdef ERROR_CHECK_GC |
226 #define gc_checking_assert(assertion) assert (assertion) | |
227 #define gc_checking_assert_at_line(assertion, file, line) \ | |
228 assert_at_line (assertion, file, line) | |
4843
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
229 #define inline_gc_checking_assert(assertion) inline_assert (assertion) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
230 #define INLINE_GC_CHECK_ARGS INLINE_ERROR_CHECK_ARGS |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
231 #define INLINE_GC_CHECK_CALL INLINE_ERROR_CHECK_CALL |
1318 | 232 #define gc_checking_assert_with_message(assertion, msg) \ |
233 assert_with_message (assertion, msg) | |
4843
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
234 #else /* not ERROR_CHECK_GC */ |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
235 #define gc_checking_assert(assertion) disabled_assert (assertion) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
236 #define gc_checking_assert_at_line(assertion, file, line) \ |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
237 disabled_assert_at_line (assertion, file, line) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
238 #define inline_gc_checking_assert(assertion) \ |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
239 disabled_inline_assert (assertion) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
240 #define INLINE_GC_CHECK_ARGS DISABLED_INLINE_ERROR_CHECK_ARGS |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
241 #define INLINE_GC_CHECK_CALL DISABLED_INLINE_ERROR_CHECK_CALL |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
242 #define gc_checking_assert_with_message(assertion, msg) \ |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
243 disabled_assert_with_message (assertion, msg) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
244 #endif /* ERROR_CHECK_GC */ |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
245 |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
246 #ifdef ERROR_CHECK_DISPLAY |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
247 #define display_checking_assert(assertion) assert (assertion) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
248 #define display_checking_assert_at_line(assertion, file, line) \ |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
249 assert_at_line (assertion, file, line) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
250 #define inline_display_checking_assert(assertion) inline_assert (assertion) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
251 #define INLINE_DISPLAY_CHECK_ARGS INLINE_ERROR_CHECK_ARGS |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
252 #define INLINE_DISPLAY_CHECK_CALL INLINE_ERROR_CHECK_CALL |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
253 #define display_checking_assert_with_message(assertion, msg) \ |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
254 assert_with_message (assertion, msg) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
255 #else /* not ERROR_CHECK_DISPLAY */ |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
256 #define display_checking_assert(assertion) disabled_assert (assertion) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
257 #define display_checking_assert_at_line(assertion, file, line) \ |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
258 disabled_assert_at_line (assertion, file, line) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
259 #define inline_display_checking_assert(assertion) \ |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
260 disabled_inline_assert (assertion) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
261 #define INLINE_DISPLAY_CHECK_ARGS DISABLED_INLINE_ERROR_CHECK_ARGS |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
262 #define INLINE_DISPLAY_CHECK_CALL DISABLED_INLINE_ERROR_CHECK_CALL |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
263 #define display_checking_assert_with_message(assertion, msg) \ |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
264 disabled_assert_with_message (assertion, msg) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
265 #endif /* ERROR_CHECK_DISPLAY */ |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
266 |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
267 #ifdef ERROR_CHECK_GLYPHS |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
268 #define glyph_checking_assert(assertion) assert (assertion) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
269 #define glyph_checking_assert_at_line(assertion, file, line) \ |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
270 assert_at_line (assertion, file, line) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
271 #define inline_glyph_checking_assert(assertion) inline_assert (assertion) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
272 #define INLINE_GLYPH_CHECK_ARGS INLINE_ERROR_CHECK_ARGS |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
273 #define INLINE_GLYPH_CHECK_CALL INLINE_ERROR_CHECK_CALL |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
274 #define glyph_checking_assert_with_message(assertion, msg) \ |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
275 assert_with_message (assertion, msg) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
276 #else /* not ERROR_CHECK_GLYPHS */ |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
277 #define glyph_checking_assert(assertion) disabled_assert (assertion) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
278 #define glyph_checking_assert_at_line(assertion, file, line) \ |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
279 disabled_assert_at_line (assertion, file, line) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
280 #define inline_glyph_checking_assert(assertion) \ |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
281 disabled_inline_assert (assertion) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
282 #define INLINE_GLYPH_CHECK_ARGS DISABLED_INLINE_ERROR_CHECK_ARGS |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
283 #define INLINE_GLYPH_CHECK_CALL DISABLED_INLINE_ERROR_CHECK_CALL |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
284 #define glyph_checking_assert_with_message(assertion, msg) \ |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
285 disabled_assert_with_message (assertion, msg) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
286 #endif /* ERROR_CHECK_GLYPHS */ |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
287 |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
288 #ifdef ERROR_CHECK_EXTENTS |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
289 #define extent_checking_assert(assertion) assert (assertion) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
290 #define extent_checking_assert_at_line(assertion, file, line) \ |
1318 | 291 assert_at_line (assertion, file, line) |
4843
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
292 #define inline_extent_checking_assert(assertion) inline_assert (assertion) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
293 #define INLINE_EXTENT_CHECK_ARGS INLINE_ERROR_CHECK_ARGS |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
294 #define INLINE_EXTENT_CHECK_CALL INLINE_ERROR_CHECK_CALL |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
295 #define extent_checking_assert_with_message(assertion, msg) \ |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
296 assert_with_message (assertion, msg) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
297 #else /* not ERROR_CHECK_EXTENTS */ |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
298 #define extent_checking_assert(assertion) disabled_assert (assertion) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
299 #define extent_checking_assert_at_line(assertion, file, line) \ |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
300 disabled_assert_at_line (assertion, file, line) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
301 #define inline_extent_checking_assert(assertion) \ |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
302 disabled_inline_assert (assertion) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
303 #define INLINE_EXTENT_CHECK_ARGS DISABLED_INLINE_ERROR_CHECK_ARGS |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
304 #define INLINE_EXTENT_CHECK_CALL DISABLED_INLINE_ERROR_CHECK_CALL |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
305 #define extent_checking_assert_with_message(assertion, msg) \ |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
306 disabled_assert_with_message (assertion, msg) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
307 #endif /* ERROR_CHECK_EXTENTS */ |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
308 |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
309 #ifdef ERROR_CHECK_MALLOC |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
310 #define malloc_checking_assert(assertion) assert (assertion) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
311 #define malloc_checking_assert_at_line(assertion, file, line) \ |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
312 assert_at_line (assertion, file, line) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
313 #define inline_malloc_checking_assert(assertion) inline_assert (assertion) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
314 #define INLINE_MALLOC_CHECK_ARGS INLINE_ERROR_CHECK_ARGS |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
315 #define INLINE_MALLOC_CHECK_CALL INLINE_ERROR_CHECK_CALL |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
316 #define malloc_checking_assert_with_message(assertion, msg) \ |
1318 | 317 assert_with_message (assertion, msg) |
4843
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
318 #else /* not ERROR_CHECK_MALLOC */ |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
319 #define malloc_checking_assert(assertion) disabled_assert (assertion) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
320 #define malloc_checking_assert_at_line(assertion, file, line) \ |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
321 disabled_assert_at_line (assertion, file, line) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
322 #define inline_malloc_checking_assert(assertion) \ |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
323 disabled_inline_assert (assertion) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
324 #define INLINE_MALLOC_CHECK_ARGS DISABLED_INLINE_ERROR_CHECK_ARGS |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
325 #define INLINE_MALLOC_CHECK_CALL DISABLED_INLINE_ERROR_CHECK_CALL |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
326 #define malloc_checking_assert_with_message(assertion, msg) \ |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
327 disabled_assert_with_message (assertion, msg) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
328 #endif /* ERROR_CHECK_MALLOC */ |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
329 |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
330 #ifdef ERROR_CHECK_BYTE_CODE |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
331 #define byte_code_checking_assert(assertion) assert (assertion) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
332 #define byte_code_checking_assert_at_line(assertion, file, line) \ |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
333 assert_at_line (assertion, file, line) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
334 #define inline_byte_code_checking_assert(assertion) inline_assert (assertion) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
335 #define INLINE_BYTE_CODE_CHECK_ARGS INLINE_ERROR_CHECK_ARGS |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
336 #define INLINE_BYTE_CODE_CHECK_CALL INLINE_ERROR_CHECK_CALL |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
337 #define byte_code_checking_assert_with_message(assertion, msg) \ |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
338 assert_with_message (assertion, msg) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
339 #else /* not ERROR_CHECK_BYTE_CODE */ |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
340 #define byte_code_checking_assert(assertion) disabled_assert (assertion) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
341 #define byte_code_checking_assert_at_line(assertion, file, line) \ |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
342 disabled_assert_at_line (assertion, file, line) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
343 #define inline_byte_code_checking_assert(assertion) \ |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
344 disabled_inline_assert (assertion) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
345 #define INLINE_BYTE_CODE_CHECK_ARGS DISABLED_INLINE_ERROR_CHECK_ARGS |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
346 #define INLINE_BYTE_CODE_CHECK_CALL DISABLED_INLINE_ERROR_CHECK_CALL |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
347 #define byte_code_checking_assert_with_message(assertion, msg) \ |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
348 disabled_assert_with_message (assertion, msg) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
349 #endif /* ERROR_CHECK_BYTE_CODE */ |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
350 |
1318 | 351 #ifdef ERROR_CHECK_TRAPPING_PROBLEMS |
352 #define trapping_problems_checking_assert(assertion) assert (assertion) | |
353 #define trapping_problems_checking_assert_at_line(assertion, file, line) \ | |
354 assert_at_line (assertion, file, line) | |
4843
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
355 #define inline_trapping_problems_checking_assert(assertion) inline_assert (assertion) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
356 #define INLINE_TRAPPING_PROBLEMS_CHECK_ARGS INLINE_ERROR_CHECK_ARGS |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
357 #define INLINE_TRAPPING_PROBLEMS_CHECK_CALL INLINE_ERROR_CHECK_CALL |
1318 | 358 #define trapping_problems_checking_assert_with_message(assertion, msg) \ |
359 assert_with_message (assertion, msg) | |
4843
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
360 #else /* not ERROR_CHECK_TRAPPING_PROBLEMS */ |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
361 #define trapping_problems_checking_assert(assertion) disabled_assert (assertion) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
362 #define trapping_problems_checking_assert_at_line(assertion, file, line) \ |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
363 disabled_assert_at_line (assertion, file, line) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
364 #define inline_trapping_problems_checking_assert(assertion) \ |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
365 disabled_inline_assert (assertion) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
366 #define INLINE_TRAPPING_PROBLEMS_CHECK_ARGS DISABLED_INLINE_ERROR_CHECK_ARGS |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
367 #define INLINE_TRAPPING_PROBLEMS_CHECK_CALL DISABLED_INLINE_ERROR_CHECK_CALL |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
368 #define trapping_problems_checking_assert_with_message(assertion, msg) \ |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
369 disabled_assert_with_message (assertion, msg) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
370 #endif /* ERROR_CHECK_TRAPPING_PROBLEMS */ |
1318 | 371 |
2367 | 372 /************************************************************************/ |
373 /** Definitions of basic types **/ | |
374 /************************************************************************/ | |
375 | |
376 /* ------------- generic 8/16/32/64/128-bit integral types ------------ */ | |
647 | 377 |
826 | 378 #if SIZEOF_SHORT == 2 |
379 #define INT_16_BIT short | |
380 #define UINT_16_BIT unsigned short | |
381 #elif SIZEOF_INT == 2 | |
382 /* Bwa ha ha. As if XEmacs could actually support such systems. */ | |
383 #define INT_16_BIT int | |
384 #define UINT_16_BIT unsigned int | |
385 #else | |
386 #error Unable to find a 16-bit integral type | |
387 #endif | |
388 | |
389 #if SIZEOF_INT == 4 | |
390 #define INT_32_BIT int | |
391 #define UINT_32_BIT unsigned int | |
392 #define MAKE_32_BIT_UNSIGNED_CONSTANT(num) num##U | |
393 #elif SIZEOF_LONG == 4 | |
394 /* Bwa ha ha again. */ | |
395 #define INT_32_BIT long | |
396 #define UINT_32_BIT unsigned long | |
397 #define MAKE_32_BIT_UNSIGNED_CONSTANT(num) num##UL | |
398 #elif SIZEOF_SHORT == 4 | |
399 /* And again. */ | |
400 #define INT_32_BIT short | |
401 #define UINT_32_BIT unsigned short | |
402 #define MAKE_32_BIT_UNSIGNED_CONSTANT(num) num##U | |
1429 | 403 #elif 1 /* Unable to find a 32-bit integral type! */ |
826 | 404 #error What kind of strange-ass system are you running on? |
405 #endif | |
406 | |
407 #if SIZEOF_LONG == 8 | |
408 #define INT_64_BIT long | |
409 #define UINT_64_BIT unsigned long | |
410 #define MAKE_64_BIT_UNSIGNED_CONSTANT(num) num##UL | |
411 #elif SIZEOF_LONG_LONG == 8 | |
412 #define INT_64_BIT long long | |
413 #define UINT_64_BIT unsigned long long | |
414 #define MAKE_64_BIT_UNSIGNED_CONSTANT(num) num##ULL | |
4682
648f4a0dac3e
Fix build problems on WIN32 platforms caused by the large image crash fix.
Jerry James <james@xemacs.org>
parents:
4678
diff
changeset
|
415 #elif defined(WIN32_ANY) |
648f4a0dac3e
Fix build problems on WIN32 platforms caused by the large image crash fix.
Jerry James <james@xemacs.org>
parents:
4678
diff
changeset
|
416 #define INT_64_BIT __int64 |
648f4a0dac3e
Fix build problems on WIN32 platforms caused by the large image crash fix.
Jerry James <james@xemacs.org>
parents:
4678
diff
changeset
|
417 #define UINT_64_BIT unsigned __int64 |
648f4a0dac3e
Fix build problems on WIN32 platforms caused by the large image crash fix.
Jerry James <james@xemacs.org>
parents:
4678
diff
changeset
|
418 #define MAKE_64_BIT_UNSIGNED_CONSTANT(num) num##UI64 |
826 | 419 /* No error otherwise; just leave undefined */ |
420 #endif | |
421 | |
422 #if SIZEOF_LONG_LONG == 16 | |
423 #define INT_128_BIT long long | |
424 #define UINT_128_BIT unsigned long long | |
425 #define MAKE_128_BIT_UNSIGNED_CONSTANT(num) num##ULL | |
426 /* No error otherwise; just leave undefined */ | |
427 #endif | |
428 | |
429 /* #### Fill this in for other systems */ | |
430 #if defined (INT_64_BIT) && !(defined (i386) || defined (__i386__)) | |
431 #define EFFICIENT_INT_64_BIT INT_64_BIT | |
432 #define EFFICIENT_UINT_64_BIT UINT_64_BIT | |
433 #endif | |
434 | |
435 #if defined (INT_128_BIT) | |
436 #define EFFICIENT_INT_128_BIT INT_128_BIT | |
437 #define EFFICIENT_UINT_128_BIT UINT_128_BIT | |
438 #endif | |
439 | |
2367 | 440 #ifdef HAVE_INTTYPES_H |
441 #include <inttypes.h> | |
442 #elif defined (HAVE_INTPTR_T_IN_SYS_TYPES_H) | |
443 /* included elsewhere */ | |
444 #elif SIZEOF_VOID_P == SIZEOF_INT | |
445 typedef int intptr_t; | |
446 typedef unsigned int uintptr_t; | |
447 #elif SIZEOF_VOID_P == SIZEOF_LONG | |
448 typedef long intptr_t; | |
449 typedef unsigned long uintptr_t; | |
450 #elif defined (SIZEOF_LONG_LONG) && SIZEOF_VOID_P == SIZEOF_LONG_LONG | |
451 typedef long long intptr_t; | |
452 typedef unsigned long long uintptr_t; | |
453 #else | |
454 /* Just pray. May break, may not. */ | |
455 typedef long intptr_t; | |
456 typedef unsigned long uintptr_t; | |
457 #endif | |
458 | |
3988 | 459 #if SIZEOF_VOID_P == 8 |
460 #define DEADBEEF_CONSTANT 0xCAFEBABEDEADBEEF | |
461 #elif SIZEOF_VOID_P == 4 | |
462 #define DEADBEEF_CONSTANT 0xDEADBEEF | |
463 #else | |
464 #error "What size are your pointers, really?" | |
465 #endif /* SIZEOF_VOID_P == 8 */ | |
466 | |
2367 | 467 /* ---------------------- definition of EMACS_INT --------------------- */ |
468 | |
469 /* EMACS_INT is the underlying integral type into which a Lisp_Object must fit. | |
470 In particular, it must be large enough to contain a pointer. | |
471 config.h can override this, e.g. to use `long long' for bigger lisp ints. | |
472 | |
473 #### In point of fact, it would NOT be a good idea for config.h to mess | |
474 with EMACS_INT. A lot of code makes the basic assumption that EMACS_INT | |
475 is the size of a pointer. */ | |
476 | |
477 #ifndef SIZEOF_EMACS_INT | |
478 # define SIZEOF_EMACS_INT SIZEOF_VOID_P | |
479 #endif | |
480 | |
481 #ifndef EMACS_INT | |
482 # if SIZEOF_EMACS_INT == SIZEOF_LONG | |
483 # define EMACS_INT long | |
484 # elif SIZEOF_EMACS_INT == SIZEOF_INT | |
485 # define EMACS_INT int | |
486 # elif SIZEOF_EMACS_INT == SIZEOF_LONG_LONG | |
487 # define EMACS_INT long long | |
488 # else | |
489 # error Unable to determine suitable type for EMACS_INT | |
490 # endif | |
491 #endif | |
492 | |
493 #ifndef EMACS_UINT | |
494 # define EMACS_UINT unsigned EMACS_INT | |
495 #endif | |
496 | |
497 #define BITS_PER_EMACS_INT (SIZEOF_EMACS_INT * BITS_PER_CHAR) | |
498 | |
499 /* -------------------------- basic byte typedefs --------------------- */ | |
500 | |
501 /* The definitions we put here and in the next section use typedefs to | |
502 attribute specific meaning to types that by themselves are pretty | |
503 general. | |
504 | |
505 REMEMBER! These typedefs are purely for documentation purposes; from | |
647 | 506 the C code's perspective, they are exactly equivalent to `char *', |
507 `unsigned char *', etc., so you can freely use them with library | |
2367 | 508 functions declared as such. |
509 | |
510 (See also "Byte/Character Types" in text.c) | |
511 | |
512 The basic semantics for `char': | |
513 | |
514 a) [Ibyte] pointer to internally-formatted text | |
515 b) [Extbyte] pointer to text in some external format, which can be | |
516 defined as all formats other than the internal one | |
517 c) [Ascbyte] pure ASCII text | |
518 d) [Binbyte] binary data that is not meant to be interpreted as text | |
519 e) [Rawbyte] general data in memory, where we don't care about whether | |
520 it's text or binary | |
521 f) [Boolbyte] a zero or a one | |
522 g) [Bitbyte] a byte used for bit fields | |
523 h) [Chbyte] null-semantics `char *'; used when casting an argument to | |
524 an external API where the the other types may not be | |
525 appropriate | |
526 | |
527 | |
528 Prefixing codes: | |
529 | |
530 C = plain char, when the base type is unsigned | |
531 U = unsigned | |
532 S = signed | |
533 | |
534 Ideally, XEmacs code should NEVER directly use `char' or any type | |
535 derived from it. This is for Mule-cleanliness. If you find yourself | |
536 wanting or needing to use `char' and one of the above six semantics does | |
537 not apply, add a new type of semantics; don't use `char' directly. | |
538 | |
539 See text.c under "Byte Types", and following sections. | |
540 */ | |
647 | 541 |
542 /* The data representing the text in a buffer is logically a set | |
867 | 543 of Ibytes, declared as follows. */ |
544 | |
545 typedef unsigned char Ibyte; | |
647 | 546 |
547 /* The following should be used when you are working with internal data | |
548 but for whatever reason need to have it declared a "char *". Examples | |
549 are function arguments whose values are most commonly literal strings, | |
550 or where you have to apply a stdlib string function to internal data. | |
551 | |
2367 | 552 In general, you should avoid this where possible and use Ascbyte if the |
553 text is just ASCII (e.g. string literals) or otherwise Ibyte, for | |
554 consistency. For example, the new Mule workspace contains Ibyte | |
555 versions of the stdlib string functions. */ | |
867 | 556 |
557 typedef char CIbyte; | |
647 | 558 |
559 /* The data representing a string in "external" format (binary or any | |
560 external encoding) is logically a set of Extbytes, declared as | |
561 follows. Extbyte is guaranteed to be just a char, so for example | |
562 strlen (Extbyte *) is OK. Extbyte is only a documentation device | |
563 for referring to external text. */ | |
564 | |
565 typedef char Extbyte; | |
771 | 566 typedef unsigned char UExtbyte; |
647 | 567 |
2367 | 568 #define EXTTEXT_ZTERM_SIZE (sizeof (Extbyte)) |
647 | 569 |
570 /* A byte in a string in entirely US-ASCII format: (Nothing outside | |
571 the range 00 - 7F) */ | |
572 | |
2367 | 573 typedef char Ascbyte; |
574 typedef unsigned char UAscbyte; | |
575 | |
576 /* A generic memory pointer, no text or binary semantics assumed. | |
577 In general, there should be no manipulation of the memory pointed to | |
578 by these pointers other than just copying it around. */ | |
579 | |
580 typedef unsigned char Rawbyte; | |
581 typedef char CRawbyte; | |
582 | |
583 /* A byte in a string in binary (not meant as text) format: */ | |
584 | |
585 typedef unsigned char Binbyte; | |
586 typedef char CBinbyte; | |
587 typedef signed char SBinbyte; | |
588 | |
589 /* A byte used to represent a boolean value: 0 or 1. | |
590 Normally use plain Boolint, and only use Boolbyte to save space. */ | |
591 | |
592 typedef char Boolbyte; | |
593 | |
594 /* A byte composed of bitfields. Hardly ever used. */ | |
595 | |
596 typedef unsigned char Bitbyte; | |
597 | |
598 /* A no-semantics `char'. Used (pretty-much) ONLY for casting arguments to | |
599 functions accepting a `char *', `unsigned char *', etc. where the other | |
600 types don't exactly apply and what you are logically concerned with is | |
601 the type of the function's argument and not its semantics. | |
602 | |
603 DO NOT DO NOT DO NOT DO NOT use this as a sloppy replacement for one of | |
604 the other types. If you're not using this as part of casting an | |
605 argument to a function call, and you're not Ben Wing, you're using it | |
606 wrong. Go find another one of the types. */ | |
607 | |
608 typedef char Chbyte; | |
609 typedef unsigned char UChbyte; | |
610 typedef signed char SChbyte; | |
611 | |
612 /* ------------------------ other text-related typedefs ------------------- */ | |
647 | 613 |
826 | 614 /* To the user, a buffer is made up of characters. In the non-Mule world, |
867 | 615 characters and Ibytes are equivalent, restricted to the range 0 - 255. |
3498 | 616 In the Mule world, many more characters are possible (21 bits worth, |
867 | 617 more or less), and a character requires (typically) 1 to 4 Ibytes for |
826 | 618 its representation in a buffer or string. Note that the representation |
619 of a character by itself, in a variable, is very different from its | |
620 representation in a string of text (in a buffer or Lisp string). | |
621 | |
622 Under Mule, text can be represented in more than one way. The "default" | |
623 format is variable-width (1 to 4 bytes) and compatible with ASCII -- | |
624 ASCII chars are stored in one byte, as themselves, and all other chars | |
625 use only high bytes. The default format is currently the only format | |
626 used for text stored anywhere but in a buffer. In a buffer, other | |
627 formats -- fixed-width formats (1, 2, or 4 bytes) -- are possible, for | |
628 speed. | |
629 | |
630 See text.c/text.h for a detailed discussion of all of this. */ | |
631 | |
632 /* A character, as represented on its own. */ | |
647 | 633 |
867 | 634 typedef int Ichar; |
647 | 635 |
826 | 636 /* The "raw value" of a character as stored in the buffer. In the default |
637 format, this is just the same as the character. In fixed-width formats, | |
638 this is the actual value in the buffer, which will be limited to the | |
639 range as established by the format. This is used when searching for a | |
640 character in a buffer -- it's faster to convert the character to the raw | |
641 value and look for that, than repeatedly convert each raw value in the | |
642 buffer into a character. */ | |
643 | |
867 | 644 typedef int Raw_Ichar; |
826 | 645 |
2367 | 646 /* Internal text as a series of textual units (8-bit bytes in the old |
647 "Mule" encoding -- still the standard internal encoding -- and in UTF-8, | |
648 but 16-bit bytes in UTF-16 and 32-bit bytes in UTF-32). See text.c. */ | |
649 | |
650 #ifdef UTF16_IBYTE_FORMAT | |
651 #define NON_ASCII_INTERNAL_FORMAT | |
652 typedef unsigned short Itext; | |
653 #else | |
654 typedef Ibyte Itext; | |
655 #endif | |
656 typedef EMACS_INT Textcount; | |
657 | |
658 #define ITEXT_SIZE (sizeof (Itext)) | |
659 /* Use this to emphasize that we are adding space for the zero-terminator */ | |
660 #define ITEXT_ZTERM_SIZE ITEXT_SIZE | |
661 | |
662 /* Wexttext is wchar_t on WIN32_NATIVE (and perhaps other systems that | |
663 support wchar_t's in library functions), and Extbyte otherwise. This is | |
664 used whenever we have to do any sort of manipulation of | |
665 externally-encoded strings -- generally a very bad idea, and unsafe, but | |
666 in some cases we have no choice (especially at startup, and esp. prior | |
667 to pdump, where we haven't loaded the Unicode tables necessary for | |
668 conversion under Windows). On platforms where the external encoding may | |
669 be Unicode (i.e. Windows), we always do our manipulations in Unicode, | |
670 converting to and from multibyte if necessary -- otherwise we'd have to | |
671 conditionalize on Unicode vs. multibyte all over the place, which is | |
672 just a nightmare. */ | |
673 #ifdef WIN32_NATIVE | |
674 #define WEXTTEXT_IS_WIDE | |
675 typedef wchar_t Wexttext; | |
676 #else | |
677 typedef Extbyte Wexttext; | |
678 #endif | |
826 | 679 |
680 #if !defined (__cplusplus) || !defined (CPLUSPLUS_INTEGRAL_CLASSES_NOT_YET) | |
681 | |
682 /* Counts of bytes or chars */ | |
683 | |
684 typedef EMACS_INT Bytecount; | |
685 typedef EMACS_INT Charcount; | |
686 | |
647 | 687 /* Different ways of referring to a position in a buffer. We use |
688 the typedefs in preference to 'EMACS_INT' to make it clearer what | |
826 | 689 sort of position is being used. See text.c for a description |
690 of the different positions. | |
691 | |
692 Note that buffer positions are 1-based, and there's a gap in the middle | |
693 of a buffer; that's why we have separate typedefs. For Lisp strings and | |
694 other strings of text, we just use Bytecount and Charcount. */ | |
800 | 695 |
665 | 696 typedef EMACS_INT Charbpos; |
697 typedef EMACS_INT Bytebpos; | |
698 typedef EMACS_INT Membpos; | |
647 | 699 |
826 | 700 /* Different ways of referring to a position that can be either in a buffer |
701 or string; used when passing around an object that can be either a | |
702 buffer or string, and an associated position. Conceptually, they | |
703 resolve as follows: | |
704 | |
705 Typedef Buffer String | |
706 ------------------------------------------------------ | |
707 Charxpos Charbpos Charcount | |
708 Bytexpos Bytebpos Bytecount | |
709 Memxpos Membpos Bytecount | |
710 | |
711 */ | |
712 | |
814 | 713 typedef EMACS_INT Charxpos; |
714 typedef EMACS_INT Bytexpos; | |
715 typedef EMACS_INT Memxpos; | |
716 | |
717 #else /* __cplusplus */ | |
718 | |
719 /* Implement strong type-checking of the above integral types by declaring | |
720 them to be classes and using operator overloading. Unfortunately this | |
721 is a huge pain in the ass because C++ doesn't strongly distinguish | |
722 "bool" and "size_t" from int. The problem is especially bad with "bool" | |
2956 | 723 -- if you want to be able to say `if (len--)' where len is e.g. a |
814 | 724 Bytecount, you need to declare a conversion operator to bool(); and |
725 since bool is just an alias for int, you suddenly get tons and tons of | |
726 ambiguities, which need to be resolved by lots of laborious declarations | |
727 for every single possible type combination. Hence the multitude of | |
728 declarations in DECLARE_INTCLASS_ARITH_COMPARE(). The bool/int | |
729 equivalence also means that we have to forcibly block the combinations | |
730 we don't want by creating overloaded versions of them and declaring them | |
731 private. */ | |
732 | |
733 class Bytecount; | |
734 class Bytebpos; | |
735 class Bytexpos; | |
736 class Charcount; | |
737 class Charbpos; | |
738 class Charxpos; | |
739 class Membpos; | |
740 class Memxpos; | |
741 | |
742 /* Declare the arithmetic and comparison operations for an integral class, | |
743 i.e. one of the above classes. If this is a "position" class, where the | |
744 difference between two positions is a different class (a "count" class), | |
745 then use POSCL for the position class and COUNTCL for the count class. | |
746 If this is a simple class, where all operations yield the same class, | |
747 substitute the same class for POSCL and COUNTCL. */ | |
748 | |
749 #define DECLARE_INTCLASS_ARITH_COMPARE(poscl, countcl) \ | |
750 poscl operator += (const countcl& l) { data += l.data; return *this; } \ | |
751 poscl operator -= (const countcl& l) { data -= l.data; return *this; } \ | |
752 poscl operator + (const countcl& l) const { return poscl (data + l.data); } \ | |
753 poscl operator - (const countcl& l) const { return poscl (data - l.data); } \ | |
754 poscl operator += (const int& l) { data += l; return *this; } \ | |
755 poscl operator -= (const int& l) { data -= l; return *this; } \ | |
756 poscl operator + (const int& l) const { return poscl (data + l); } \ | |
757 poscl operator - (const int& l) const { return poscl (data - l); } \ | |
758 poscl operator += (const unsigned int& l) { data += l; return *this; } \ | |
759 poscl operator -= (const unsigned int& l) { data -= l; return *this; } \ | |
760 poscl operator + (const unsigned int& l) const \ | |
761 { return poscl (data + l); } \ | |
762 poscl operator - (const unsigned int& l) const \ | |
763 { return poscl (data - l); } \ | |
764 poscl operator += (const long& l) { data += l; return *this; } \ | |
765 poscl operator -= (const long& l) { data -= l; return *this; } \ | |
766 poscl operator + (const long& l) const { return poscl (data + l); } \ | |
767 poscl operator - (const long& l) const { return poscl (data - l); } \ | |
768 poscl operator += (const unsigned long& l) { data += l; return *this; } \ | |
769 poscl operator -= (const unsigned long& l) { data -= l; return *this; } \ | |
770 poscl operator + (const unsigned long& l) const \ | |
771 { return poscl (data + l); } \ | |
772 poscl operator - (const unsigned long& l) const \ | |
773 { return poscl (data - l); } \ | |
774 poscl operator += (const short& l) { data += l; return *this; } \ | |
775 poscl operator -= (const short& l) { data -= l; return *this; } \ | |
776 poscl operator + (const short& l) const { return poscl (data + l); } \ | |
777 poscl operator - (const short& l) const { return poscl (data - l); } \ | |
778 poscl operator += (const unsigned short& l) { data += l; return *this; } \ | |
779 poscl operator -= (const unsigned short& l) { data -= l; return *this; } \ | |
780 poscl operator + (const unsigned short& l) const \ | |
781 { return poscl (data + l); } \ | |
782 poscl operator - (const unsigned short& l) const \ | |
783 { return poscl (data - l); } \ | |
784 \ | |
785 poscl operator *= (const countcl& l) { data *= l.data; return *this; } \ | |
786 poscl operator /= (const countcl& l) { data /= l.data; return *this; } \ | |
787 poscl operator * (const countcl& l) const { return poscl (data * l.data); } \ | |
788 poscl operator / (const countcl& l) const { return poscl (data / l.data); } \ | |
789 poscl operator *= (const int& l) { data *= l; return *this; } \ | |
790 poscl operator /= (const int& l) { data /= l; return *this; } \ | |
791 poscl operator * (const int& l) const { return poscl (data * l); } \ | |
792 poscl operator / (const int& l) const { return poscl (data / l); } \ | |
793 poscl operator *= (const unsigned int& l) { data *= l; return *this; } \ | |
794 poscl operator /= (const unsigned int& l) { data /= l; return *this; } \ | |
795 poscl operator * (const unsigned int& l) const { return poscl (data * l); } \ | |
796 poscl operator / (const unsigned int& l) const { return poscl (data / l); } \ | |
797 poscl operator *= (const long& l) { data *= l; return *this; } \ | |
798 poscl operator /= (const long& l) { data /= l; return *this; } \ | |
799 poscl operator * (const long& l) const { return poscl (data * l); } \ | |
800 poscl operator / (const long& l) const { return poscl (data / l); } \ | |
801 poscl operator *= (const unsigned long& l) { data *= l; return *this; } \ | |
802 poscl operator /= (const unsigned long& l) { data /= l; return *this; } \ | |
803 poscl operator * (const unsigned long& l) const \ | |
804 { return poscl (data * l); } \ | |
805 poscl operator / (const unsigned long& l) const \ | |
806 { return poscl (data / l); } \ | |
807 poscl operator *= (const short& l) { data *= l; return *this; } \ | |
808 poscl operator /= (const short& l) { data /= l; return *this; } \ | |
809 poscl operator * (const short& l) const { return poscl (data * l); } \ | |
810 poscl operator / (const short& l) const { return poscl (data / l); } \ | |
811 poscl operator *= (const unsigned short& l) { data *= l; return *this; } \ | |
812 poscl operator /= (const unsigned short& l) { data /= l; return *this; } \ | |
813 poscl operator * (const unsigned short& l) const \ | |
814 { return poscl (data * l); } \ | |
815 poscl operator / (const unsigned short& l) const \ | |
816 { return poscl (data / l); } \ | |
817 \ | |
818 poscl operator &= (const countcl& l) { data &= l.data; return *this; } \ | |
819 poscl operator |= (const countcl& l) { data |= l.data; return *this; } \ | |
820 poscl operator & (const countcl& l) const { return poscl (data & l.data); } \ | |
821 poscl operator | (const countcl& l) const { return poscl (data | l.data); } \ | |
822 poscl operator &= (const int& l) { data &= l; return *this; } \ | |
823 poscl operator |= (const int& l) { data |= l; return *this; } \ | |
824 poscl operator & (const int& l) const { return poscl (data & l); } \ | |
825 poscl operator | (const int& l) const { return poscl (data | l); } \ | |
826 poscl operator &= (const unsigned int& l) { data &= l; return *this; } \ | |
827 poscl operator |= (const unsigned int& l) { data |= l; return *this; } \ | |
828 poscl operator & (const unsigned int& l) const { return poscl (data & l); } \ | |
829 poscl operator | (const unsigned int& l) const { return poscl (data | l); } \ | |
830 poscl operator &= (const long& l) { data &= l; return *this; } \ | |
831 poscl operator |= (const long& l) { data |= l; return *this; } \ | |
832 poscl operator & (const long& l) const { return poscl (data & l); } \ | |
833 poscl operator | (const long& l) const { return poscl (data | l); } \ | |
834 poscl operator &= (const unsigned long& l) { data &= l; return *this; } \ | |
835 poscl operator |= (const unsigned long& l) { data |= l; return *this; } \ | |
836 poscl operator & (const unsigned long& l) const \ | |
837 { return poscl (data & l); } \ | |
838 poscl operator | (const unsigned long& l) const \ | |
839 { return poscl (data | l); } \ | |
840 poscl operator &= (const short& l) { data &= l; return *this; } \ | |
841 poscl operator |= (const short& l) { data |= l; return *this; } \ | |
842 poscl operator & (const short& l) const { return poscl (data & l); } \ | |
843 poscl operator | (const short& l) const { return poscl (data | l); } \ | |
844 poscl operator &= (const unsigned short& l) { data &= l; return *this; } \ | |
845 poscl operator |= (const unsigned short& l) { data |= l; return *this; } \ | |
846 poscl operator & (const unsigned short& l) const \ | |
847 { return poscl (data & l); } \ | |
848 poscl operator | (const unsigned short& l) const \ | |
849 { return poscl (data | l); } \ | |
850 \ | |
851 poscl operator - () { return poscl (-data); } \ | |
852 poscl operator-- () { data--; return *this; } \ | |
853 poscl operator-- (int) { data--; return poscl (data + 1); } \ | |
854 poscl operator++ () { data++; return *this; } \ | |
855 poscl operator++ (int) { data++; return poscl (data - 1); } \ | |
856 \ | |
857 bool operator < (const poscl& l) const { return data < l.data; } \ | |
858 bool operator <= (const poscl& l) const { return data <= l.data; } \ | |
859 bool operator > (const poscl& l) const { return data > l.data; } \ | |
860 bool operator >= (const poscl& l) const { return data >= l.data; } \ | |
861 bool operator == (const poscl& l) const { return data == l.data; } \ | |
862 bool operator != (const poscl& l) const { return data != l.data; } \ | |
863 bool operator < (const int& l) const { return data < (EMACS_INT) l; } \ | |
864 bool operator <= (const int& l) const { return data <= (EMACS_INT) l; } \ | |
865 bool operator > (const int& l) const { return data > (EMACS_INT) l; } \ | |
866 bool operator >= (const int& l) const { return data >= (EMACS_INT) l; } \ | |
867 bool operator == (const int& l) const { return data == (EMACS_INT) l; } \ | |
868 bool operator != (const int& l) const { return data != (EMACS_INT) l; } \ | |
869 bool operator < (const unsigned int& l) const \ | |
870 { return data < (EMACS_INT) l; } \ | |
871 bool operator <= (const unsigned int& l) const \ | |
872 { return data <= (EMACS_INT) l; } \ | |
873 bool operator > (const unsigned int& l) const \ | |
874 { return data > (EMACS_INT) l; } \ | |
875 bool operator >= (const unsigned int& l) const \ | |
876 { return data >= (EMACS_INT) l; } \ | |
877 bool operator == (const unsigned int& l) const \ | |
878 { return data == (EMACS_INT) l; } \ | |
879 bool operator != (const unsigned int& l) const \ | |
880 { return data != (EMACS_INT) l; } \ | |
881 bool operator < (const long& l) const { return data < (EMACS_INT) l; } \ | |
882 bool operator <= (const long& l) const { return data <= (EMACS_INT) l; } \ | |
883 bool operator > (const long& l) const { return data > (EMACS_INT) l; } \ | |
884 bool operator >= (const long& l) const { return data >= (EMACS_INT) l; } \ | |
885 bool operator == (const long& l) const { return data == (EMACS_INT) l; } \ | |
886 bool operator != (const long& l) const { return data != (EMACS_INT) l; } \ | |
887 bool operator < (const unsigned long& l) const \ | |
888 { return data < (EMACS_INT) l; } \ | |
889 bool operator <= (const unsigned long& l) const \ | |
890 { return data <= (EMACS_INT) l; } \ | |
891 bool operator > (const unsigned long& l) const \ | |
892 { return data > (EMACS_INT) l; } \ | |
893 bool operator >= (const unsigned long& l) const \ | |
894 { return data >= (EMACS_INT) l; } \ | |
895 bool operator == (const unsigned long& l) const \ | |
896 { return data == (EMACS_INT) l; } \ | |
897 bool operator != (const unsigned long& l) const \ | |
898 { return data != (EMACS_INT) l; } \ | |
899 bool operator < (const short& l) const { return data < (EMACS_INT) l; } \ | |
900 bool operator <= (const short& l) const { return data <= (EMACS_INT) l; } \ | |
901 bool operator > (const short& l) const { return data > (EMACS_INT) l; } \ | |
902 bool operator >= (const short& l) const { return data >= (EMACS_INT) l; } \ | |
903 bool operator == (const short& l) const { return data == (EMACS_INT) l; } \ | |
904 bool operator != (const short& l) const { return data != (EMACS_INT) l; } \ | |
905 bool operator < (const unsigned short& l) const \ | |
906 { return data < (EMACS_INT) l; } \ | |
907 bool operator <= (const unsigned short& l) const \ | |
908 { return data <= (EMACS_INT) l; } \ | |
909 bool operator > (const unsigned short& l) const \ | |
910 { return data > (EMACS_INT) l; } \ | |
911 bool operator >= (const unsigned short& l) const \ | |
912 { return data >= (EMACS_INT) l; } \ | |
913 bool operator == (const unsigned short& l) const \ | |
914 { return data == (EMACS_INT) l; } \ | |
915 bool operator != (const unsigned short& l) const \ | |
916 { return data != (EMACS_INT) l; } \ | |
917 bool operator ! () const { return !data; } | |
918 | |
919 /* Declare the "bad" or disallowed arithmetic and comparion operations | |
920 between class GOOD and class BAD. Meant to go inside the private | |
921 section of class GOOD. */ | |
922 | |
923 #define DECLARE_BAD_INTCLASS_ARITH_COMPARE(good, bad) \ | |
924 good operator += (const bad& l) { return badret; } \ | |
925 good operator -= (const bad& l) { return badret; } \ | |
926 good operator *= (const bad& l) { return badret; } \ | |
927 good operator /= (const bad& l) { return badret; } \ | |
928 good operator + (const bad& l) { return badret; } \ | |
929 good operator - (const bad& l) { return badret; } \ | |
930 good operator * (const bad& l) { return badret; } \ | |
931 good operator / (const bad& l) { return badret; } \ | |
932 \ | |
933 bool operator < (const bad& l) { return 0; } \ | |
934 bool operator <= (const bad& l) { return 0; } \ | |
935 bool operator > (const bad& l) { return 0; } \ | |
936 bool operator >= (const bad& l) { return 0; } \ | |
937 bool operator == (const bad& l) { return 0; } \ | |
938 bool operator != (const bad& l) { return 0; } | |
939 | |
940 /* Declare the "bad" or disallowed arithmetic operations between class GOOD | |
941 and another of the same class, for a position class. Meant to go inside | |
942 the private section of class GOOD. */ | |
943 | |
944 #define DECLARE_BAD_POS_CLASS_ARITH(good) \ | |
945 good operator += (const good& l) { return badret; } \ | |
946 good operator -= (const good& l) { return badret; } \ | |
947 good operator *= (const good& l) { return badret; } \ | |
948 good operator /= (const good& l) { return badret; } \ | |
949 good operator + (const good& l) { return badret; } \ | |
950 good operator * (const good& l) { return badret; } \ | |
951 good operator / (const good& l) { return badret; } | |
952 | |
953 /* Basic declaration at the top of all integral classes. Don't call | |
954 directly, use one of the more specific versions below. */ | |
955 | |
956 #define DECLARE_INTCLASS(cl) \ | |
957 public: \ | |
958 EMACS_INT data; \ | |
959 cl () { data = 0xCDCDCDCD; } \ | |
960 cl (int i) { data = i; } \ | |
961 cl (unsigned int i) { data = i; } \ | |
962 cl (long i) { data = i; } \ | |
963 cl (unsigned long i) { data = i; } \ | |
964 cl (short i) { data = i; } \ | |
965 cl (unsigned short i) { data = i; } \ | |
966 operator EMACS_INT () const { return data; } | |
967 | |
968 /* Basic declaration at the top of all count classes. */ | |
969 | |
970 #define DECLARE_COUNT_CLASS(cl) \ | |
971 DECLARE_INTCLASS (cl) \ | |
972 DECLARE_INTCLASS_ARITH_COMPARE (cl, cl) \ | |
973 private: \ | |
974 static cl badret; | |
975 | |
976 /* Basic declaration at the bottom of the prelude of all position classes. | |
977 Don't call directly. */ | |
978 | |
979 #define DECLARE_POS_CLASS_SECOND_HALF(cl, countcl) \ | |
980 DECLARE_INTCLASS_ARITH_COMPARE (cl, countcl) \ | |
981 countcl operator - (const cl& l) const { return countcl (data - l.data); } \ | |
982 private: \ | |
983 static cl badret; \ | |
984 DECLARE_BAD_POS_INTCLASS_ARITH (cl) | |
985 | |
986 /* Basic declaration at the top of all buffer position classes. */ | |
987 | |
988 #define DECLARE_BPOS_CLASS(cl, countcl) \ | |
989 DECLARE_INTCLASS (cl) \ | |
990 DECLARE_POS_CLASS_SECOND_HALF (cl, countcl) | |
991 | |
992 /* Basic declaration at the top of all X-position classes (that can refer | |
993 to buffers or strings). CL1 and CL2 are the equivalent more specific | |
1318 | 994 classes referring only to buffers or strings, respectively. */ |
814 | 995 |
996 #define DECLARE_XPOS_CLASS(cl, countcl, cl1, cl2) \ | |
997 DECLARE_INTCLASS (cl) \ | |
998 cl (const cl1& x) { data = x.data; } \ | |
999 cl (const cl2& x) { data = x.data; } \ | |
1000 operator cl1 () const { return cl1 (data); } \ | |
1001 operator cl2 () const { return cl2 (data); } \ | |
1002 DECLARE_POS_CLASS_SECOND_HALF (cl, countcl) | |
1003 | |
1004 /* Declare the "bad" or disallowed arithmetic and comparion operations | |
1005 between class CHARCL (a character class) and various non-character | |
1006 classes. Meant to go inside the private section of class GOOD. */ | |
1007 | |
1008 #define DECLARE_BAD_CHAR_INTCLASS_ARITH_COMPARE(charcl) \ | |
1009 DECLARE_BAD_INTCLASS_ARITH_COMPARE (charcl, Bytecount) \ | |
1010 DECLARE_BAD_INTCLASS_ARITH_COMPARE (charcl, Bytebpos) \ | |
1011 DECLARE_BAD_INTCLASS_ARITH_COMPARE (charcl, Bytexpos) \ | |
1012 DECLARE_BAD_INTCLASS_ARITH_COMPARE (charcl, Membpos) \ | |
1013 DECLARE_BAD_INTCLASS_ARITH_COMPARE (charcl, Memxpos) | |
1014 | |
1015 /* Declare the "bad" or disallowed arithmetic and comparion operations | |
1016 between class BYTECL (a byte class) and various non-byte classes. | |
1017 Meant to go inside the private section of class GOOD. */ | |
1018 | |
1019 #define DECLARE_BAD_BYTE_INTCLASS_ARITH_COMPARE(bytecl) \ | |
1020 DECLARE_BAD_INTCLASS_ARITH_COMPARE (bytecl, Charcount) \ | |
1021 DECLARE_BAD_INTCLASS_ARITH_COMPARE (bytecl, Charbpos) \ | |
1022 DECLARE_BAD_INTCLASS_ARITH_COMPARE (bytecl, Charxpos) \ | |
1023 DECLARE_BAD_INTCLASS_ARITH_COMPARE (bytecl, Membpos) \ | |
1024 DECLARE_BAD_INTCLASS_ARITH_COMPARE (bytecl, Memxpos) | |
1025 | |
1026 /* Declare the "bad" or disallowed arithmetic and comparion operations | |
1027 between class BYTECL (a mem class) and various non-mem classes. | |
1028 Meant to go inside the private section of class GOOD. */ | |
1029 | |
1030 #define DECLARE_BAD_MEM_INTCLASS_ARITH_COMPARE(bytecl) \ | |
1031 DECLARE_BAD_INTCLASS_ARITH_COMPARE (bytecl, Charcount) \ | |
1032 DECLARE_BAD_INTCLASS_ARITH_COMPARE (bytecl, Charbpos) \ | |
1033 DECLARE_BAD_INTCLASS_ARITH_COMPARE (bytecl, Charxpos) \ | |
1034 DECLARE_BAD_INTCLASS_ARITH_COMPARE (bytecl, Bytebpos) \ | |
1035 DECLARE_BAD_INTCLASS_ARITH_COMPARE (bytecl, Bytexpos) | |
1036 | |
1037 class Charcount | |
1038 { | |
1039 DECLARE_COUNT_CLASS (Charcount) | |
1040 DECLARE_BAD_CHAR_INTCLASS_ARITH_COMPARE (Charcount) | |
1041 }; | |
1042 | |
1043 class Charbpos | |
1044 { | |
1045 DECLARE_BPOS_CLASS (Charbpos, Charcount) | |
1046 DECLARE_BAD_CHAR_INTCLASS_ARITH_COMPARE (Charbpos) | |
1047 }; | |
1048 | |
1049 class Charxpos | |
1050 { | |
1051 DECLARE_XPOS_CLASS (Charxpos, Charcount, Charbpos, Charcount) | |
1052 DECLARE_BAD_CHAR_INTCLASS_ARITH_COMPARE (Charxpos) | |
1053 }; | |
1054 | |
1055 class Bytecount | |
1056 { | |
1057 DECLARE_COUNT_CLASS (Bytecount) | |
1058 DECLARE_BAD_BYTE_INTCLASS_ARITH_COMPARE (Bytecount) | |
1059 }; | |
1060 | |
1061 class Bytebpos | |
1062 { | |
1063 DECLARE_BPOS_CLASS (Bytebpos, Bytecount) | |
1064 DECLARE_BAD_BYTE_INTCLASS_ARITH_COMPARE (Bytebpos) | |
1065 }; | |
1066 | |
1067 class Bytexpos | |
1068 { | |
1069 DECLARE_XPOS_CLASS (Bytexpos, Bytecount, Bytebpos, Bytecount) | |
1070 DECLARE_BAD_BYTE_INTCLASS_ARITH_COMPARE (Bytexpos) | |
1071 }; | |
1072 | |
1073 class Membpos | |
1074 { | |
1075 DECLARE_BPOS_CLASS (Membpos, Bytecount) | |
1076 DECLARE_BAD_MEM_INTCLASS_ARITH_COMPARE (Membpos) | |
1077 }; | |
1078 | |
1079 class Memxpos | |
1080 { | |
1081 DECLARE_XPOS_CLASS (Memxpos, Bytecount, Membpos, Bytecount) | |
1082 DECLARE_BAD_MEM_INTCLASS_ARITH_COMPARE (Memxpos) | |
1083 }; | |
1084 | |
826 | 1085 #define DECLARE_POINTER_TYPE_ARITH_COUNT(pointer, countcl) \ |
1086 inline pointer operator += (const pointer & x, const countcl& y) \ | |
1087 { x += y.data; return x; } \ | |
1088 inline pointer operator -= (const pointer & x, const countcl& y) \ | |
1089 { x -= y.data; return x; } \ | |
1090 inline pointer operator + (const pointer x, const countcl& y) \ | |
1091 { return x + y.data; } \ | |
1092 inline pointer operator - (const pointer x, const countcl& y) \ | |
814 | 1093 { return x - y.data; } |
1094 | |
1095 #define DECLARE_INTEGRAL_TYPE_ARITH_COUNT(integral, countcl) \ | |
1096 inline integral operator += (integral & x, const countcl& y) \ | |
1097 { x += y.data; return x; } \ | |
1098 inline integral operator -= (integral & x, const countcl& y) \ | |
1099 { x -= y.data; return x; } \ | |
1100 inline countcl operator + (integral x, const countcl& y) \ | |
1101 { return countcl (x + y.data); } \ | |
1102 inline countcl operator - (integral x, const countcl& y) \ | |
1103 { return countcl (x - y.data); } | |
1104 | |
1105 #define DECLARE_INTEGRAL_TYPE_COMPARE(integral, cl) \ | |
1106 inline bool operator < (integral x, const cl& y) \ | |
1107 { return (EMACS_INT) x < y.data; } \ | |
1108 inline bool operator <= (integral x, const cl& y) \ | |
1109 { return (EMACS_INT) x <= y.data; } \ | |
1110 inline bool operator > (integral x, const cl& y) \ | |
1111 { return (EMACS_INT) x > y.data; } \ | |
1112 inline bool operator >= (integral x, const cl& y) \ | |
1113 { return (EMACS_INT) x >= y.data; } \ | |
1114 inline bool operator == (integral x, const cl& y) \ | |
1115 { return (EMACS_INT) x == y.data; } \ | |
1116 inline bool operator != (integral x, const cl& y) \ | |
1117 { return (EMACS_INT) x != y.data; } | |
1118 | |
1119 #if 0 | |
1120 /* Unfortunately C++ doesn't let you overload the ?: operator, so we have | |
1121 to manually deal with ambiguities using casting */ | |
1122 #define DECLARE_INTEGRAL_TYPE_TRISTATE(integral, cl) \ | |
1123 inline cl operator ?: (bool b, integral x, const cl& y) \ | |
1124 { return b ? cl (x) : y; } \ | |
1125 inline cl operator ?: (bool b, const cl& x, integral y) \ | |
1126 { return b ? x : cl (y); } | |
1127 #endif /* 0 */ | |
1128 | |
867 | 1129 /* DECLARE_POINTER_TYPE_ARITH_COUNT (const Ibyte *, Bytecount); |
826 | 1130 DECLARE_POINTER_TYPE_ARITH_COUNT (const Extbyte *, Bytecount); */ |
867 | 1131 DECLARE_POINTER_TYPE_ARITH_COUNT (Ibyte *, Bytecount); |
814 | 1132 DECLARE_POINTER_TYPE_ARITH_COUNT (Extbyte *, Bytecount); |
1133 | |
1134 DECLARE_INTEGRAL_TYPE_ARITH_COUNT (int, Bytecount); | |
1135 DECLARE_INTEGRAL_TYPE_ARITH_COUNT (int, Charcount); | |
1136 DECLARE_INTEGRAL_TYPE_ARITH_COUNT (unsigned int, Bytecount); | |
1137 DECLARE_INTEGRAL_TYPE_ARITH_COUNT (unsigned int, Charcount); | |
1138 DECLARE_INTEGRAL_TYPE_ARITH_COUNT (long, Bytecount); | |
1139 DECLARE_INTEGRAL_TYPE_ARITH_COUNT (long, Charcount); | |
1140 DECLARE_INTEGRAL_TYPE_ARITH_COUNT (unsigned long, Bytecount); | |
1141 DECLARE_INTEGRAL_TYPE_ARITH_COUNT (unsigned long, Charcount); | |
1142 | |
1143 DECLARE_INTEGRAL_TYPE_COMPARE (int, Bytecount); | |
1144 DECLARE_INTEGRAL_TYPE_COMPARE (int, Charcount); | |
1145 DECLARE_INTEGRAL_TYPE_COMPARE (unsigned int, Bytecount); | |
1146 DECLARE_INTEGRAL_TYPE_COMPARE (unsigned int, Charcount); | |
1147 DECLARE_INTEGRAL_TYPE_COMPARE (long, Bytecount); | |
1148 DECLARE_INTEGRAL_TYPE_COMPARE (long, Charcount); | |
1149 DECLARE_INTEGRAL_TYPE_COMPARE (unsigned long, Bytecount); | |
1150 DECLARE_INTEGRAL_TYPE_COMPARE (unsigned long, Charcount); | |
1151 | |
1152 #if 0 /* doesn't work */ | |
867 | 1153 inline Bytecount operator - (const Ibyte *x, const Ibyte *y) \ |
814 | 1154 { return Bytecount (x - y); } |
1155 #endif | |
1156 | |
1157 #endif /* __cplusplus */ | |
1158 | |
665 | 1159 /* Counts of elements */ |
1160 typedef EMACS_INT Elemcount; | |
1161 /* Hash codes */ | |
1162 typedef unsigned long Hashcode; | |
2367 | 1163 /* Booleans */ |
1164 typedef int Boolint; | |
771 | 1165 |
793 | 1166 /* ------------------------ basic compiler defines ------------------- */ |
428 | 1167 |
1743 | 1168 #include "compiler.h" |
1632 | 1169 |
793 | 1170 /* ------------------------ alignment definitions ------------------- */ |
1171 | |
454 | 1172 /* No type has a greater alignment requirement than max_align_t. |
1173 (except perhaps for types we don't use, like long double) */ | |
1174 typedef union | |
1175 { | |
1176 struct { long l; } l; | |
1177 struct { void *p; } p; | |
1178 struct { void (*f)(void); } f; | |
1179 struct { double d; } d; | |
1180 } max_align_t; | |
1181 | |
771 | 1182 /* ALIGNOF returns the required alignment of a type -- i.e. a value such |
1183 that data of this type must begin at a memory address which is a | |
1184 multiple of that value. For simple types, this is often the same size | |
1185 as the type itself. */ | |
1186 | |
428 | 1187 #ifndef ALIGNOF |
1188 # if defined (__GNUC__) && (__GNUC__ >= 2) | |
454 | 1189 /* gcc has an extension that gives us exactly what we want. */ |
1190 # define ALIGNOF(type) __alignof__ (type) | |
1191 # elif ! defined (__cplusplus) | |
1192 /* The following is mostly portable, except that: | |
1193 - it doesn't work for inside out declarations like void (*) (void). | |
1194 (so just call ALIGNOF with a typedef'ed name) | |
1195 - it doesn't work with C++. The C++ committee has decided, | |
1196 in its infinite wisdom, that: | |
1197 "Types must be declared in declarations, not in expressions." */ | |
1198 # define ALIGNOF(type) offsetof (struct { char c; type member; }, member) | |
428 | 1199 # else |
456 | 1200 /* C++ is annoying, but it has a big bag of tricks. |
1201 The following doesn't have the "inside out" declaration bug C does. */ | |
458 | 1202 template<typename T> struct alignment_trick { char c; T member; }; |
456 | 1203 # define ALIGNOF(type) offsetof (alignment_trick<type>, member) |
428 | 1204 # endif |
454 | 1205 #endif /* ALIGNOF */ |
428 | 1206 |
771 | 1207 /* ALIGN_SIZE returns the smallest size greater than or equal to LEN which |
1208 is a multiple of UNIT. This can be used to assure that data that | |
1209 follows a block of the returned size is of correct alignment for a type | |
1210 whose alignment (as returned by ALIGNOF) is UNIT (provided that the | |
1211 block itself is correctly aligned for this type; memory returned by | |
1212 malloc() is guaranteed to be correctly aligned for all types). */ | |
1213 | |
428 | 1214 #define ALIGN_SIZE(len, unit) \ |
1215 ((((len) + (unit) - 1) / (unit)) * (unit)) | |
1216 | |
826 | 1217 /* ALIGN_FOR_TYPE returns the smallest size greater than or equal to LEN |
1218 which is aligned for the given type. This can be used to assure that | |
1219 data that follows a block of the returned size is of correct alignment | |
1220 for the type (provided that the block itself is correctly aligned for | |
1221 this type; memory returned by malloc() is guaranteed to be correctly | |
1222 aligned for all types). */ | |
1223 | |
1224 #define ALIGN_FOR_TYPE(len, type) ALIGN_SIZE (len, ALIGNOF (type)) | |
1225 | |
771 | 1226 /* MAX_ALIGN_SIZE returns the smallest size greater than or equal to LEN |
1227 which guarantees that data following a block of such size is correctly | |
1228 aligned for all types (provided that the block itself is so aligned, | |
1229 which is the case for memory returned by malloc()). */ | |
1230 | |
826 | 1231 #define MAX_ALIGN_SIZE(len) ALIGN_FOR_TYPE (len, max_align_t) |
1232 | |
1233 /* ALIGN_PTR returns the smallest pointer >= PTR which is aligned for | |
1234 data of TYPE. */ | |
1235 #define ALIGN_PTR(ptr, type) ((void *) ALIGN_FOR_TYPE ((size_t) (ptr), type)) | |
428 | 1236 |
1743 | 1237 BEGIN_C_DECLS |
1650 | 1238 |
793 | 1239 /* ------------------------ assertions ------------------- */ |
428 | 1240 |
1241 /* We define assert iff USE_ASSERTIONS or DEBUG_XEMACS is defined. | |
1242 Otherwise we define it to be empty. Quantify has shown that the | |
1243 time the assert checks take is measurable so let's not include them | |
771 | 1244 in production binaries. |
1245 | |
788 | 1246 If ASSERTIONS_DONT_ABORT defined, we will continue after assertion |
1247 failures. | |
1248 | |
1249 assert_at_line() is used for asserts inside of inline functions called | |
1250 from error-checking macros. If we're not tricky, we just get the file | |
1251 and line of the inline function, which is not very useful. */ | |
428 | 1252 |
1253 /* Highly dubious kludge */ | |
1254 /* (thanks, Jamie, I feel better now -- ben) */ | |
2367 | 1255 MODULE_API void assert_failed (const Ascbyte *, int, const Ascbyte *); |
2535 | 1256 #define ABORT() (assert_failed (__FILE__, __LINE__, "ABORT()")) |
1257 | |
4843
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
1258 /* This used to be ((void) (0)) but that triggers lots of unused variable |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
1259 warnings. It's pointless to force all that code to be rewritten, with |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
1260 added ifdefs. Any reasonable compiler will eliminate an expression with |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
1261 no effects. We keep this abstracted out like this in case we want to |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
1262 change it in the future. */ |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
1263 #define disabled_assert(x) ((void) (x)) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
1264 #define disabled_assert_with_message(x, msg) disabled_assert (x) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
1265 #define disabled_assert_at_line(x, file, line) disabled_assert (x) |
715b15990d0a
add more foo_checking_assert macros
Ben Wing <ben@xemacs.org>
parents:
4841
diff
changeset
|
1266 |
2535 | 1267 #ifdef USE_ASSERTIONS |
428 | 1268 # define assert(x) ((x) ? (void) 0 : assert_failed (__FILE__, __LINE__, #x)) |
853 | 1269 # define assert_with_message(x, msg) \ |
1270 ((x) ? (void) 0 : assert_failed (__FILE__, __LINE__, msg)) | |
788 | 1271 # define assert_at_line(x, file, line) \ |
1272 ((x) ? (void) 0 : assert_failed (file, line, #x)) | |
2535 | 1273 #elif defined (DEBUG_XEMACS) |
1274 # define assert(x) ((x) ? (void) 0 : (void) ABORT ()) | |
2956 | 1275 # define assert_with_message(x, msg) assert (x) |
2535 | 1276 # define assert_at_line(x, file, line) assert (x) |
428 | 1277 #else |
2956 | 1278 /* This used to be ((void) (0)) but that triggers lots of unused variable |
1279 warnings. It's pointless to force all that code to be rewritten, with | |
1280 added ifdefs. Any reasonable compiler will eliminate an expression with | |
1281 no effects. */ | |
1282 # define assert(x) ((void) (x)) | |
1283 # define assert_with_message(x, msg) assert (x) | |
2535 | 1284 # define assert_at_line(x, file, line) assert (x) |
428 | 1285 #endif |
1286 | |
2367 | 1287 /************************************************************************/ |
1288 /** Memory allocation **/ | |
1289 /************************************************************************/ | |
853 | 1290 |
793 | 1291 /* ------------------------ simple memory allocation ------------------- */ |
1292 | |
2367 | 1293 /* Basic memory allocation and freeing functions */ |
1294 void malloc_warning (const Ascbyte *); | |
1743 | 1295 MODULE_API void *xmalloc (Bytecount size) ATTRIBUTE_MALLOC; |
1296 MODULE_API void *xmalloc_and_zero (Bytecount size) ATTRIBUTE_MALLOC; | |
1297 MODULE_API void *xrealloc (void *, Bytecount size) ATTRIBUTE_MALLOC; | |
2367 | 1298 MODULE_API Chbyte *xstrdup (const Chbyte *) ATTRIBUTE_MALLOC; |
1299 | |
1300 /* Basic free function */ | |
1301 | |
1302 MODULE_API void xfree_1 (void *); | |
1303 #ifdef ERROR_CHECK_MALLOC | |
1304 /* This used to use a temporary variable, which both avoided the multiple | |
1305 evaluation and obviated the need for the TYPE argument. But that triggered | |
1306 complaints under strict aliasing. #### There should be a better way. */ | |
1307 #define xfree(lvalue, type) do \ | |
1308 { \ | |
1309 xfree_1 (lvalue); \ | |
3988 | 1310 VOIDP_CAST (lvalue) = (void *) DEADBEEF_CONSTANT; \ |
2367 | 1311 } while (0) |
1312 #else | |
1313 #define xfree(lvalue,type) xfree_1 (lvalue) | |
1314 #endif /* ERROR_CHECK_MALLOC */ | |
1315 | |
1316 /* ------------------------ stack allocation -------------------------- */ | |
1317 | |
1318 /* Allocating excessively large blocks on the stack can cause crashes. | |
851 | 1319 We provide MALLOC_OR_ALLOCA() below for places where it's likely that |
1320 large amounts will be allocated; it mallocs the block if it's too big. | |
1321 Unfortunately, that requires a call to unbind_to() at the end of the | |
1322 function, and it's not feasible to rewrite all calls to alloca() this | |
1323 way. | |
1324 | |
1325 Instead, we use the portable C alloca() substitute in alloca.c above a | |
1326 certain size. This actually uses malloc(), but checks the current stack | |
1327 pointer to see if data from previous alloca() calls needs to be freed. | |
1328 However, this can lead to large heap sizes -- especially since cleanup | |
1329 can only happen in a parent function, and will never happen if (as will | |
1330 often be the case) it's the same function in the same place in the code | |
1331 that keeps tripping the alloca() limit. | |
1332 | |
1333 So we set up a system to periodically force cleanup. Currently we | |
1334 do cleanup: | |
1335 | |
1336 -- Only when there's C alloca() data, and then | |
1337 -- Every stack alloca() or allocation of Lisp data, every call to | |
1338 next_event_internal() [typically near the top of the stack], | |
1339 or every 10th funcall | |
1340 | |
1341 This should not be a big penalty because | |
1342 | |
1343 (a) If there are few C alloca() chunks, checking them will be fast | |
1344 (b) If not, we've allocated a huge amount of heap space (remember, each | |
1345 chunk represents > 256K of heap), and we really want them gone | |
1346 */ | |
1347 | |
1348 /* We use a larger maximum when the choice is alloca() vs. the C alloca() | |
1349 substitute than when the choice is vs. malloc(), because in the former | |
1350 case, our alternative choice is less palatable because the memory may | |
1351 not be freed for awhile. */ | |
1352 | |
1353 #define MAX_ALLOCA_VS_C_ALLOCA 262144 | |
1354 #define MAX_ALLOCA_VS_MALLOC 65536 | |
1355 | |
1356 #define MAX_FUNCALLS_BETWEEN_ALLOCA_CLEANUP 10 | |
1357 | |
1632 | 1358 extern MODULE_API Bytecount __temp_alloca_size__; |
851 | 1359 extern Bytecount funcall_alloca_count; |
1360 | |
1333 | 1361 #ifdef ERROR_CHECK_MALLOC |
1632 | 1362 extern MODULE_API int regex_malloc_disallowed; |
1333 | 1363 #define REGEX_MALLOC_CHECK() assert (!regex_malloc_disallowed) |
1364 #else | |
1365 #define REGEX_MALLOC_CHECK() ((void) 0) | |
1366 #endif | |
1367 | |
851 | 1368 /* Do stack or heap alloca() depending on size. |
1369 | |
1370 NOTE: The use of a global temporary like this is unsafe if ALLOCA() occurs | |
1371 twice anywhere in the same expression; but that seems highly unlikely. The | |
1372 alternative is to force all callers to declare a local temporary if the | |
1373 expression has side effects -- something easy to forget. */ | |
1374 | |
1375 #define ALLOCA(size) \ | |
1333 | 1376 (REGEX_MALLOC_CHECK (), \ |
1377 __temp_alloca_size__ = (size), \ | |
851 | 1378 __temp_alloca_size__ > MAX_ALLOCA_VS_C_ALLOCA ? \ |
1379 xemacs_c_alloca (__temp_alloca_size__) : \ | |
1380 (need_to_check_c_alloca ? xemacs_c_alloca (0) : 0, \ | |
1381 alloca (__temp_alloca_size__))) | |
1382 | |
1318 | 1383 /* Version of ALLOCA() that is guaranteed to work inside of function calls |
1384 (i.e., we call the C alloca if regular alloca() is broken inside of | |
1385 function calls). */ | |
1386 #ifdef BROKEN_ALLOCA_IN_FUNCTION_CALLS | |
1387 #define ALLOCA_FUNCALL_OK(size) xemacs_c_alloca (size) | |
1388 #else | |
1389 #define ALLOCA_FUNCALL_OK(size) ALLOCA (size) | |
1390 #endif | |
1391 | |
2367 | 1392 MODULE_API void *xemacs_c_alloca (unsigned int size) ATTRIBUTE_MALLOC; |
1393 | |
1394 MODULE_API int record_unwind_protect_freeing (void *ptr); | |
1395 | |
1396 DECLARE_INLINE_HEADER ( | |
1397 void * | |
1398 xmalloc_and_record_unwind (Bytecount size) | |
1399 ) | |
1400 { | |
1401 void *ptr = xmalloc (size); | |
1402 record_unwind_protect_freeing (ptr); | |
1403 return ptr; | |
1404 } | |
1405 | |
851 | 1406 /* WARNING: If you use this, you must unbind_to() at the end of your |
1407 function! */ | |
1408 | |
1409 #define MALLOC_OR_ALLOCA(size) \ | |
1333 | 1410 (REGEX_MALLOC_CHECK (), \ |
1411 __temp_alloca_size__ = (size), \ | |
851 | 1412 __temp_alloca_size__ > MAX_ALLOCA_VS_MALLOC ? \ |
1413 xmalloc_and_record_unwind (__temp_alloca_size__) : \ | |
1414 (need_to_check_c_alloca ? xemacs_c_alloca (0) : 0, \ | |
1415 alloca (__temp_alloca_size__))) | |
793 | 1416 |
2367 | 1417 /* -------------- convenience functions for memory allocation ------------- */ |
1418 | |
1419 #define countof(x) ((int) (sizeof(x)/sizeof((x)[0]))) | |
1420 #define xnew(type) ((type *) xmalloc (sizeof (type))) | |
1421 #define xnew_array(type, len) ((type *) xmalloc ((len) * sizeof (type))) | |
1422 #define xnew_and_zero(type) ((type *) xmalloc_and_zero (sizeof (type))) | |
1423 #define xzero(lvalue) ((void) memset (&(lvalue), '\0', sizeof (lvalue))) | |
1424 #define xnew_array_and_zero(type, len) ((type *) xmalloc_and_zero ((len) * sizeof (type))) | |
1425 | |
1426 #define alloca_new(type) ((type *) ALLOCA (sizeof (type))) | |
1427 #define alloca_array(type, len) ((type *) ALLOCA ((len) * sizeof (type))) | |
1428 | |
1429 #define alloca_itexts(num) alloca_array (Itext, num) | |
1430 #define alloca_ibytes(num) alloca_array (Ibyte, num) | |
1431 #define alloca_extbytes(num) alloca_array (Extbyte, num) | |
1432 #define alloca_rawbytes(num) alloca_array (Rawbyte, num) | |
1433 #define alloca_binbytes(num) alloca_array (Binbyte, num) | |
1434 #define alloca_ascbytes(num) alloca_array (Ascbyte, num) | |
1435 #define xmalloc_itexts(num) xnew_array (Itext, num) | |
1436 #define xnew_ibytes(num) xnew_array (Ibyte, num) | |
1437 #define xnew_extbytes(num) xnew_array (Extbyte, num) | |
1438 #define xnew_rawbytes(num) xnew_array (Rawbyte, num) | |
1439 #define xnew_binbytes(num) xnew_array (Binbyte, num) | |
1440 #define xnew_ascbytes(num) xnew_array (Ascbyte, num) | |
1441 | |
1442 /* Make an alloca'd copy of a Ibyte * */ | |
1443 #define IBYTE_STRING_TO_ALLOCA(p, lval) \ | |
1444 do { \ | |
1445 Ibyte **_bsta_ = (Ibyte **) &(lval); \ | |
1446 const Ibyte *_bsta_2 = (p); \ | |
1447 Bytecount _bsta_3 = qxestrlen (_bsta_2); \ | |
1448 *_bsta_ = alloca_ibytes (1 + _bsta_3); \ | |
1449 memcpy (*_bsta_, _bsta_2, 1 + _bsta_3); \ | |
1450 } while (0) | |
1451 | |
1452 /* ----------------- convenience functions for reallocation --------------- */ | |
1453 | |
1454 #define XREALLOC_ARRAY(ptr, type, len) \ | |
1455 ((void) (ptr = (type *) xrealloc (ptr, (len) * sizeof (type)))) | |
1456 | |
793 | 1457 /* also generally useful if you want to avoid arbitrary size limits |
1458 but don't need a full dynamic array. Assumes that BASEVAR points | |
1459 to a malloced array of TYPE objects (or possibly a NULL pointer, | |
1460 if SIZEVAR is 0), with the total size stored in SIZEVAR. This | |
1461 macro will realloc BASEVAR as necessary so that it can hold at | |
1462 least NEEDED_SIZE objects. The reallocing is done by doubling, | |
1463 which ensures constant amortized time per element. */ | |
1464 #define DO_REALLOC(basevar, sizevar, needed_size, type) do { \ | |
1465 Bytecount do_realloc_needed_size = (needed_size); \ | |
1333 | 1466 REGEX_MALLOC_CHECK (); \ |
793 | 1467 if ((sizevar) < do_realloc_needed_size) \ |
1468 { \ | |
1469 if ((sizevar) < 32) \ | |
1470 (sizevar) = 32; \ | |
1471 while ((sizevar) < do_realloc_needed_size) \ | |
1472 (sizevar) *= 2; \ | |
1473 XREALLOC_ARRAY (basevar, type, (sizevar)); \ | |
1474 } \ | |
1475 } while (0) | |
1476 | |
2367 | 1477 /************************************************************************/ |
1478 /** Definitions of more complex types **/ | |
1479 /************************************************************************/ | |
428 | 1480 |
647 | 1481 /* Note that the simplest typedefs are near the top of this file. */ |
1482 | |
428 | 1483 /* We put typedefs here so that prototype declarations don't choke. |
1484 Note that we don't actually declare the structures here (except | |
1485 maybe for simple structures like Dynarrs); that keeps them private | |
1486 to the routines that actually use them. */ | |
1487 | |
771 | 1488 /* ------------------------------- */ |
1489 /* Error_Behavior typedefs */ | |
1490 /* ------------------------------- */ | |
1491 | |
800 | 1492 #ifndef ERROR_CHECK_TYPES |
771 | 1493 |
1494 typedef enum error_behavior | |
428 | 1495 { |
771 | 1496 ERROR_ME, |
1497 ERROR_ME_NOT, | |
793 | 1498 ERROR_ME_WARN, |
1499 ERROR_ME_DEBUG_WARN | |
771 | 1500 } Error_Behavior; |
1501 | |
1502 #define ERRB_EQ(a, b) ((a) == (b)) | |
1503 | |
1504 #else | |
1505 | |
1506 /* By defining it like this, we provide strict type-checking | |
1507 for code that lazily uses ints. */ | |
1508 | |
1509 typedef struct _error_behavior_struct_ | |
428 | 1510 { |
771 | 1511 int really_unlikely_name_to_have_accidentally_in_a_non_errb_structure; |
1512 } Error_Behavior; | |
1513 | |
1514 extern Error_Behavior ERROR_ME; | |
1515 extern Error_Behavior ERROR_ME_NOT; | |
1516 extern Error_Behavior ERROR_ME_WARN; | |
793 | 1517 extern Error_Behavior ERROR_ME_DEBUG_WARN; |
771 | 1518 |
1519 #define ERRB_EQ(a, b) \ | |
1520 ((a).really_unlikely_name_to_have_accidentally_in_a_non_errb_structure == \ | |
1521 (b).really_unlikely_name_to_have_accidentally_in_a_non_errb_structure) | |
1522 | |
1523 #endif | |
1524 | |
1525 /* ------------------------------- */ | |
1526 /* Empty structures and typedefs */ | |
1527 /* ------------------------------- */ | |
428 | 1528 |
1529 struct buffer; /* "buffer.h" */ | |
1530 struct console; /* "console.h" */ | |
1531 struct device; /* "device.h" */ | |
1532 struct extent_fragment; | |
1533 struct extent; | |
1534 struct frame; /* "frame.h" */ | |
1535 struct window; /* "window.h" */ | |
771 | 1536 struct utimbuf; /* "systime.h" or <utime.h> */ |
428 | 1537 struct display_line; |
1538 struct display_glyph_area; | |
1539 struct display_box; | |
1540 struct redisplay_info; | |
1541 struct window_mirror; | |
1542 struct scrollbar_instance; | |
1543 struct font_metric_info; | |
1544 struct face_cachel; | |
1545 struct console_type_entry; | |
1546 | |
771 | 1547 /* This is shared by process.h, events.h and others in future. |
1548 See events.h for description */ | |
4123 | 1549 typedef unsigned EMACS_INT USID; |
771 | 1550 typedef int face_index; |
1551 typedef int glyph_index; | |
1726 | 1552 typedef struct lstream Lstream; /* lstream.h */ |
872 | 1553 typedef struct extent *EXTENT; /* extents-impl.h */ |
771 | 1554 typedef struct Lisp_Event Lisp_Event; /* "events.h" */ |
872 | 1555 typedef struct Lisp_Face Lisp_Face; /* "faces-impl.h" */ |
771 | 1556 typedef struct Lisp_Process Lisp_Process; /* "procimpl.h" */ |
872 | 1557 typedef struct Lisp_Color_Instance Lisp_Color_Instance; /* objects-impl.h */ |
1558 typedef struct Lisp_Font_Instance Lisp_Font_Instance; /* objects-impl.h */ | |
1726 | 1559 typedef struct Lisp_Image_Instance Lisp_Image_Instance; /* glyphs.h */ |
771 | 1560 typedef struct Lisp_Gui_Item Lisp_Gui_Item; |
1561 | |
1562 /* ------------------------------- */ | |
1563 /* enum typedefs */ | |
1564 /* ------------------------------- */ | |
1565 | |
428 | 1566 enum run_hooks_condition |
1567 { | |
1568 RUN_HOOKS_TO_COMPLETION, | |
1569 RUN_HOOKS_UNTIL_SUCCESS, | |
1570 RUN_HOOKS_UNTIL_FAILURE | |
1571 }; | |
1572 | |
1573 #ifdef HAVE_TOOLBARS | |
1574 enum toolbar_pos | |
1575 { | |
1576 TOP_TOOLBAR, | |
1577 BOTTOM_TOOLBAR, | |
1578 LEFT_TOOLBAR, | |
1579 RIGHT_TOOLBAR | |
1580 }; | |
1581 #endif | |
1582 | |
1583 enum edge_style | |
1584 { | |
1585 EDGE_ETCHED_IN, | |
1586 EDGE_ETCHED_OUT, | |
1587 EDGE_BEVEL_IN, | |
1588 EDGE_BEVEL_OUT | |
1589 }; | |
1590 | |
1591 enum munge_me_out_the_door | |
1592 { | |
1593 MUNGE_ME_FUNCTION_KEY, | |
1594 MUNGE_ME_KEY_TRANSLATION | |
1595 }; | |
1596 | |
771 | 1597 /* ------------------------------- */ |
1598 /* misc */ | |
1599 /* ------------------------------- */ | |
1600 | |
1601 #ifdef MEMORY_USAGE_STATS | |
1602 | |
1603 /* This structure is used to keep statistics on the amount of memory | |
1604 in use. | |
1605 | |
1606 WAS_REQUESTED stores the actual amount of memory that was requested | |
1607 of the allocation function. The *_OVERHEAD fields store the | |
1608 additional amount of memory that was grabbed by the functions to | |
1609 facilitate allocation, reallocation, etc. MALLOC_OVERHEAD is for | |
1610 memory allocated with malloc(); DYNARR_OVERHEAD is for dynamic | |
1611 arrays; GAP_OVERHEAD is for gap arrays. Note that for (e.g.) | |
1612 dynamic arrays, there is both MALLOC_OVERHEAD and DYNARR_OVERHEAD | |
1613 memory: The dynamic array allocates memory above and beyond what | |
1614 was asked of it, and when it in turns allocates memory using | |
1615 malloc(), malloc() allocates memory beyond what it was asked | |
1616 to allocate. | |
1617 | |
1618 Functions that accept a structure of this sort do not initialize | |
1619 the fields to 0, and add any existing values to whatever was there | |
1620 before; this way, you can get a cumulative effect. */ | |
1621 | |
1622 struct overhead_stats | |
1623 { | |
1624 int was_requested; | |
1625 int malloc_overhead; | |
1626 int dynarr_overhead; | |
1627 int gap_overhead; | |
1628 }; | |
1629 | |
1630 #endif /* MEMORY_USAGE_STATS */ | |
1631 | |
428 | 1632 |
1633 /************************************************************************/ | |
1634 /* Definition of Lisp_Object data type */ | |
1635 /************************************************************************/ | |
1636 | |
1637 /* Define the fundamental Lisp data structures */ | |
1638 | |
1639 /* This is the set of Lisp data types */ | |
1640 | |
1641 enum Lisp_Type | |
1642 { | |
1643 Lisp_Type_Record, | |
1644 Lisp_Type_Int_Even, | |
1645 Lisp_Type_Char, | |
1646 Lisp_Type_Int_Odd | |
1647 }; | |
1648 | |
1649 #define POINTER_TYPE_P(type) ((type) == Lisp_Type_Record) | |
1650 | |
1651 /* Overridden by m/next.h */ | |
1652 #ifndef ASSERT_VALID_POINTER | |
1653 # define ASSERT_VALID_POINTER(pnt) (assert ((((EMACS_UINT) pnt) & 3) == 0)) | |
1654 #endif | |
1655 | |
1656 #define GCMARKBITS 0 | |
1657 #define GCTYPEBITS 2 | |
1658 #define GCBITS 2 | |
1659 #define INT_GCBITS 1 | |
1660 | |
1661 #define INT_VALBITS (BITS_PER_EMACS_INT - INT_GCBITS) | |
1662 #define VALBITS (BITS_PER_EMACS_INT - GCBITS) | |
542 | 1663 #define EMACS_INT_MAX ((EMACS_INT) ((1UL << (INT_VALBITS - 1)) -1UL)) |
442 | 1664 #define EMACS_INT_MIN (-(EMACS_INT_MAX) - 1) |
802 | 1665 /* WARNING: evaluates its arg twice. */ |
1666 #define NUMBER_FITS_IN_AN_EMACS_INT(num) \ | |
1667 ((num) <= EMACS_INT_MAX && (num) >= EMACS_INT_MIN) | |
428 | 1668 |
1669 #ifdef USE_UNION_TYPE | |
1670 # include "lisp-union.h" | |
1671 #else /* !USE_UNION_TYPE */ | |
1672 # include "lisp-disunion.h" | |
1673 #endif /* !USE_UNION_TYPE */ | |
1674 | |
1675 #define XPNTR(x) ((void *) XPNTRVAL(x)) | |
1676 | |
1677 /* Close your eyes now lest you vomit or spontaneously combust ... */ | |
1678 | |
1679 #define HACKEQ_UNSAFE(obj1, obj2) \ | |
1680 (EQ (obj1, obj2) || (!POINTER_TYPE_P (XTYPE (obj1)) \ | |
1681 && !POINTER_TYPE_P (XTYPE (obj2)) \ | |
1682 && XCHAR_OR_INT (obj1) == XCHAR_OR_INT (obj2))) | |
1683 | |
1684 #ifdef DEBUG_XEMACS | |
1632 | 1685 extern MODULE_API int debug_issue_ebola_notices; |
1686 MODULE_API int eq_with_ebola_notice (Lisp_Object, Lisp_Object); | |
428 | 1687 #define EQ_WITH_EBOLA_NOTICE(obj1, obj2) \ |
1688 (debug_issue_ebola_notices ? eq_with_ebola_notice (obj1, obj2) \ | |
1689 : EQ (obj1, obj2)) | |
1690 #else | |
1691 #define EQ_WITH_EBOLA_NOTICE(obj1, obj2) EQ (obj1, obj2) | |
1692 #endif | |
1693 | |
1694 /* OK, you can open them again */ | |
1695 | |
1743 | 1696 END_C_DECLS |
1650 | 1697 |
428 | 1698 /************************************************************************/ |
442 | 1699 /** Definitions of basic Lisp objects **/ |
428 | 1700 /************************************************************************/ |
1701 | |
1702 #include "lrecord.h" | |
1703 | |
1743 | 1704 BEGIN_C_DECLS |
1650 | 1705 |
3293 | 1706 /* ------------------------ dynamic arrays ------------------- */ |
1707 | |
3092 | 1708 #ifdef NEW_GC |
1709 #ifdef ERROR_CHECK_STRUCTURES | |
1710 #define Dynarr_declare(type) \ | |
1711 struct lrecord_header header; \ | |
1712 type *base; \ | |
1713 const struct lrecord_implementation *lisp_imp; \ | |
1714 int locked; \ | |
1715 int elsize; \ | |
1716 int cur; \ | |
1717 int largest; \ | |
1718 int max | |
1719 #else | |
1720 #define Dynarr_declare(type) \ | |
1721 struct lrecord_header header; \ | |
1722 type *base; \ | |
1723 const struct lrecord_implementation *lisp_imp; \ | |
1724 int elsize; \ | |
1725 int cur; \ | |
1726 int largest; \ | |
1727 int max | |
1728 #endif /* ERROR_CHECK_STRUCTURES */ | |
3293 | 1729 #else /* not NEW_GC */ |
1730 #ifdef ERROR_CHECK_STRUCTURES | |
1731 #define Dynarr_declare(type) \ | |
1732 struct lrecord_header header; \ | |
1733 type *base; \ | |
1734 int locked; \ | |
1735 int elsize; \ | |
1736 int cur; \ | |
1737 int largest; \ | |
1738 int max | |
1739 #else | |
1740 #define Dynarr_declare(type) \ | |
1741 struct lrecord_header header; \ | |
1742 type *base; \ | |
1743 int elsize; \ | |
1744 int cur; \ | |
1745 int largest; \ | |
1746 int max | |
1747 #endif /* ERROR_CHECK_STRUCTURES */ | |
1748 #endif /* not NEW_GC */ | |
3092 | 1749 |
1750 typedef struct dynarr | |
1751 { | |
1752 Dynarr_declare (void); | |
1753 } Dynarr; | |
1754 | |
1755 MODULE_API void *Dynarr_newf (int elsize); | |
1756 MODULE_API void Dynarr_resize (void *dy, Elemcount size); | |
1757 MODULE_API void Dynarr_insert_many (void *d, const void *el, int len, int start); | |
1758 MODULE_API void Dynarr_delete_many (void *d, int start, int len); | |
1759 MODULE_API void Dynarr_free (void *d); | |
1760 | |
3293 | 1761 #ifdef NEW_GC |
3092 | 1762 MODULE_API void *Dynarr_lisp_newf (int elsize, |
1763 const struct lrecord_implementation | |
1764 *dynarr_imp, | |
1765 const struct lrecord_implementation *imp); | |
1766 | |
1767 #define Dynarr_lisp_new(type, dynarr_imp, imp) \ | |
1768 ((type##_dynarr *) Dynarr_lisp_newf (sizeof (type), dynarr_imp, imp)) | |
1769 #define Dynarr_lisp_new2(dynarr_type, type, dynarr_imp, imp) \ | |
1770 ((dynarr_type *) Dynarr_lisp_newf (sizeof (type)), dynarr_imp, imp) | |
3293 | 1771 #endif /* NEW_GC */ |
3092 | 1772 #define Dynarr_new(type) ((type##_dynarr *) Dynarr_newf (sizeof (type))) |
1773 #define Dynarr_new2(dynarr_type, type) \ | |
1774 ((dynarr_type *) Dynarr_newf (sizeof (type))) | |
1775 #define Dynarr_at(d, pos) ((d)->base[pos]) | |
1776 #define Dynarr_atp(d, pos) (&Dynarr_at (d, pos)) | |
1777 #define Dynarr_begin(d) Dynarr_atp (d, 0) | |
1778 #define Dynarr_end(d) Dynarr_atp (d, Dynarr_length (d) - 1) | |
1779 #define Dynarr_sizeof(d) ((d)->cur * (d)->elsize) | |
1780 | |
1781 #ifdef ERROR_CHECK_STRUCTURES | |
1782 DECLARE_INLINE_HEADER ( | |
1783 Dynarr * | |
1784 Dynarr_verify_1 (void *d, const Ascbyte *file, int line) | |
1785 ) | |
1786 { | |
1787 Dynarr *dy = (Dynarr *) d; | |
1788 assert_at_line (dy->cur >= 0 && dy->cur <= dy->largest && | |
1789 dy->largest <= dy->max, file, line); | |
1790 return dy; | |
1791 } | |
1792 | |
1793 DECLARE_INLINE_HEADER ( | |
1794 Dynarr * | |
1795 Dynarr_verify_mod_1 (void *d, const Ascbyte *file, int line) | |
1796 ) | |
1797 { | |
1798 Dynarr *dy = (Dynarr *) d; | |
1799 assert_at_line (!dy->locked, file, line); | |
1800 assert_at_line (dy->cur >= 0 && dy->cur <= dy->largest && | |
1801 dy->largest <= dy->max, file, line); | |
1802 return dy; | |
1803 } | |
1804 | |
1805 #define Dynarr_verify(d) Dynarr_verify_1 (d, __FILE__, __LINE__) | |
1806 #define Dynarr_verify_mod(d) Dynarr_verify_mod_1 (d, __FILE__, __LINE__) | |
1807 #define Dynarr_lock(d) (Dynarr_verify_mod (d)->locked = 1) | |
1808 #define Dynarr_unlock(d) ((d)->locked = 0) | |
1809 #else | |
1810 #define Dynarr_verify(d) (d) | |
1811 #define Dynarr_verify_mod(d) (d) | |
1812 #define Dynarr_lock(d) | |
1813 #define Dynarr_unlock(d) | |
1814 #endif /* ERROR_CHECK_STRUCTURES */ | |
1815 | |
1816 #define Dynarr_length(d) (Dynarr_verify (d)->cur) | |
1817 #define Dynarr_largest(d) (Dynarr_verify (d)->largest) | |
1818 #define Dynarr_reset(d) (Dynarr_verify_mod (d)->cur = 0) | |
1819 #define Dynarr_add_many(d, el, len) Dynarr_insert_many (d, el, len, (d)->cur) | |
1820 #define Dynarr_insert_many_at_start(d, el, len) \ | |
1821 Dynarr_insert_many (d, el, len, 0) | |
1822 #define Dynarr_add_literal_string(d, s) Dynarr_add_many (d, s, sizeof (s) - 1) | |
1823 #define Dynarr_add_lisp_string(d, s, codesys) \ | |
1824 do { \ | |
1825 Lisp_Object dyna_ls_s = (s); \ | |
1826 Lisp_Object dyna_ls_cs = (codesys); \ | |
1827 Extbyte *dyna_ls_eb; \ | |
1828 Bytecount dyna_ls_bc; \ | |
1829 \ | |
1830 LISP_STRING_TO_SIZED_EXTERNAL (dyna_ls_s, dyna_ls_eb, \ | |
1831 dyna_ls_bc, dyna_ls_cs); \ | |
1832 Dynarr_add_many (d, dyna_ls_eb, dyna_ls_bc); \ | |
1833 } while (0) | |
1834 | |
3293 | 1835 #ifdef NEW_GC |
3092 | 1836 #define Dynarr_add(d, el) \ |
1837 do { \ | |
3319 | 1838 const struct lrecord_implementation *imp = (d)->lisp_imp; \ |
3092 | 1839 if (Dynarr_verify_mod (d)->cur >= (d)->max) \ |
1840 Dynarr_resize ((d), (d)->cur+1); \ | |
1841 ((d)->base)[(d)->cur] = (el); \ | |
1842 \ | |
3319 | 1843 if (imp) \ |
3092 | 1844 set_lheader_implementation \ |
3319 | 1845 ((struct lrecord_header *)&(((d)->base)[(d)->cur]), imp); \ |
3092 | 1846 \ |
1847 (d)->cur++; \ | |
1848 if ((d)->cur > (d)->largest) \ | |
1849 (d)->largest = (d)->cur; \ | |
1850 } while (0) | |
3293 | 1851 #else /* not NEW_GC */ |
3092 | 1852 #define Dynarr_add(d, el) ( \ |
1853 Dynarr_verify_mod (d)->cur >= (d)->max ? Dynarr_resize ((d), (d)->cur+1) : \ | |
1854 (void) 0, \ | |
1855 ((d)->base)[(d)->cur++] = (el), \ | |
1856 (d)->cur > (d)->largest ? (d)->largest = (d)->cur : (int) 0) | |
3293 | 1857 #endif /* not NEW_GC */ |
3092 | 1858 |
1859 | |
1860 /* The following defines will get you into real trouble if you aren't | |
1861 careful. But they can save a lot of execution time when used wisely. */ | |
1862 #define Dynarr_increment(d) (Dynarr_verify_mod (d)->cur++) | |
1863 #define Dynarr_set_size(d, n) (Dynarr_verify_mod (d)->cur = n) | |
1864 | |
1865 #define Dynarr_pop(d) \ | |
1866 (assert ((d)->cur > 0), Dynarr_verify_mod (d)->cur--, \ | |
1867 Dynarr_at (d, (d)->cur)) | |
1868 #define Dynarr_delete(d, i) Dynarr_delete_many (d, i, 1) | |
1869 #define Dynarr_delete_by_pointer(d, p) \ | |
1870 Dynarr_delete_many (d, (p) - ((d)->base), 1) | |
1871 | |
1872 #define Dynarr_delete_object(d, el) \ | |
1873 do \ | |
1874 { \ | |
1875 REGISTER int i; \ | |
1876 for (i = Dynarr_length (d) - 1; i >= 0; i--) \ | |
1877 { \ | |
1878 if (el == Dynarr_at (d, i)) \ | |
1879 Dynarr_delete_many (d, i, 1); \ | |
1880 } \ | |
1881 } while (0) | |
1882 | |
1883 #ifdef MEMORY_USAGE_STATS | |
1884 struct overhead_stats; | |
1885 Bytecount Dynarr_memory_usage (void *d, struct overhead_stats *stats); | |
1886 #endif | |
1887 | |
1888 void *stack_like_malloc (Bytecount size); | |
1889 void stack_like_free (void *val); | |
1890 | |
1891 /* ------------------------------- */ | |
1892 /* Dynarr typedefs */ | |
1893 /* ------------------------------- */ | |
1894 | |
1895 /* Dynarr typedefs -- basic types first */ | |
1896 | |
1897 typedef struct | |
1898 { | |
1899 Dynarr_declare (Ibyte); | |
1900 } Ibyte_dynarr; | |
1901 | |
1902 typedef struct | |
1903 { | |
1904 Dynarr_declare (Extbyte); | |
1905 } Extbyte_dynarr; | |
1906 | |
1907 typedef struct | |
1908 { | |
1909 Dynarr_declare (Ichar); | |
1910 } Ichar_dynarr; | |
1911 | |
1912 typedef struct | |
1913 { | |
1914 Dynarr_declare (char); | |
1915 } char_dynarr; | |
1916 | |
1917 typedef struct | |
1918 { | |
1919 Dynarr_declare (char *); | |
1920 } char_ptr_dynarr; | |
1921 | |
1922 typedef unsigned char unsigned_char; | |
1923 typedef struct | |
1924 { | |
1925 Dynarr_declare (unsigned char); | |
1926 } unsigned_char_dynarr; | |
1927 | |
1928 typedef unsigned long unsigned_long; | |
1929 typedef struct | |
1930 { | |
1931 Dynarr_declare (unsigned long); | |
1932 } unsigned_long_dynarr; | |
1933 | |
1934 typedef struct | |
1935 { | |
1936 Dynarr_declare (int); | |
1937 } int_dynarr; | |
1938 | |
1939 typedef struct | |
1940 { | |
1941 Dynarr_declare (Charbpos); | |
1942 } Charbpos_dynarr; | |
1943 | |
1944 typedef struct | |
1945 { | |
1946 Dynarr_declare (Bytebpos); | |
1947 } Bytebpos_dynarr; | |
1948 | |
1949 typedef struct | |
1950 { | |
1951 Dynarr_declare (Charcount); | |
1952 } Charcount_dynarr; | |
1953 | |
1954 typedef struct | |
1955 { | |
1956 Dynarr_declare (Bytecount); | |
1957 } Bytecount_dynarr; | |
1958 | |
1959 /* Dynarr typedefs -- more complex types */ | |
1960 | |
1961 typedef struct | |
1962 { | |
1963 Dynarr_declare (struct face_cachel); | |
1964 } face_cachel_dynarr; | |
1965 | |
3293 | 1966 #ifdef NEW_GC |
3092 | 1967 DECLARE_LRECORD (face_cachel_dynarr, face_cachel_dynarr); |
1968 #define XFACE_CACHEL_DYNARR(x) \ | |
1969 XRECORD (x, face_cachel_dynarr, face_cachel_dynarr) | |
1970 #define wrap_face_cachel_dynarr(p) wrap_record (p, face_cachel_dynarr) | |
1971 #define FACE_CACHEL_DYNARRP(x) RECORDP (x, face_cachel_dynarr) | |
1972 #define CHECK_FACE_CACHEL_DYNARR(x) CHECK_RECORD (x, face_cachel_dynarr) | |
1973 #define CONCHECK_FACE_CACHEL_DYNARR(x) CONCHECK_RECORD (x, face_cachel_dynarr) | |
3293 | 1974 #endif /* NEW_GC */ |
3092 | 1975 |
1976 typedef struct | |
1977 { | |
1978 Dynarr_declare (struct glyph_cachel); | |
1979 } glyph_cachel_dynarr; | |
1980 | |
3293 | 1981 #ifdef NEW_GC |
3092 | 1982 DECLARE_LRECORD (glyph_cachel_dynarr, glyph_cachel_dynarr); |
1983 #define XGLYPH_CACHEL_DYNARR(x) \ | |
1984 XRECORD (x, glyph_cachel_dynarr, glyph_cachel_dynarr) | |
1985 #define wrap_glyph_cachel_dynarr(p) wrap_record (p, glyph_cachel_dynarr) | |
1986 #define GLYPH_CACHEL_DYNARRP(x) RECORDP (x, glyph_cachel_dynarr) | |
1987 #define CHECK_GLYPH_CACHEL_DYNARR(x) CHECK_RECORD (x, glyph_cachel_dynarr) | |
1988 #define CONCHECK_GLYPH_CACHEL_DYNARR(x) \ | |
1989 CONCHECK_RECORD (x, glyph_cachel_dynarr) | |
3293 | 1990 #endif /* NEW_GC */ |
3092 | 1991 |
1992 typedef struct | |
1993 { | |
1994 Dynarr_declare (struct console_type_entry); | |
1995 } console_type_entry_dynarr; | |
1996 | |
1997 /* WARNING WARNING WARNING. You must ensure on your own that proper | |
1998 GC protection is provided for the elements in this array. */ | |
1999 typedef struct | |
2000 { | |
2001 Dynarr_declare (Lisp_Object); | |
2002 } Lisp_Object_dynarr; | |
2003 | |
2004 typedef struct | |
2005 { | |
2006 Dynarr_declare (Lisp_Object *); | |
2007 } Lisp_Object_ptr_dynarr; | |
2008 | |
442 | 2009 /*------------------------------ unbound -------------------------------*/ |
428 | 2010 |
2011 /* Qunbound is a special Lisp_Object (actually of type | |
2012 symbol-value-forward), that can never be visible to | |
2013 the Lisp caller and thus can be used in the C code | |
2014 to mean "no such value". */ | |
2015 | |
2016 #define UNBOUNDP(val) EQ (val, Qunbound) | |
2017 | |
771 | 2018 /* Evaluate expr, return it if it's not Qunbound. */ |
2019 #define RETURN_IF_NOT_UNBOUND(expr) do \ | |
2020 { \ | |
2021 Lisp_Object ret_nunb_val = (expr); \ | |
2022 if (!UNBOUNDP (ret_nunb_val)) \ | |
2023 RETURN_SANS_WARNINGS ret_nunb_val; \ | |
2024 } while (0) | |
2025 | |
442 | 2026 /*------------------------------- cons ---------------------------------*/ |
428 | 2027 |
2028 /* In a cons, the markbit of the car is the gc mark bit */ | |
2029 | |
2030 struct Lisp_Cons | |
2031 { | |
2032 struct lrecord_header lheader; | |
853 | 2033 Lisp_Object car_, cdr_; |
428 | 2034 }; |
2035 typedef struct Lisp_Cons Lisp_Cons; | |
2036 | |
2037 #if 0 /* FSFmacs */ | |
2038 /* Like a cons, but records info on where the text lives that it was read from */ | |
2039 /* This is not really in use now */ | |
2040 | |
2041 struct Lisp_Buffer_Cons | |
2042 { | |
2043 Lisp_Object car, cdr; | |
2044 struct buffer *buffer; | |
665 | 2045 int charbpos; |
428 | 2046 }; |
2047 #endif | |
2048 | |
1632 | 2049 DECLARE_MODULE_API_LRECORD (cons, Lisp_Cons); |
428 | 2050 #define XCONS(x) XRECORD (x, cons, Lisp_Cons) |
617 | 2051 #define wrap_cons(p) wrap_record (p, cons) |
428 | 2052 #define CONSP(x) RECORDP (x, cons) |
2053 #define CHECK_CONS(x) CHECK_RECORD (x, cons) | |
2054 #define CONCHECK_CONS(x) CONCHECK_RECORD (x, cons) | |
2055 | |
3263 | 2056 #ifdef NEW_GC |
2720 | 2057 #define CONS_MARKED_P(c) MARKED_P (&((c)->lheader)) |
2058 #define MARK_CONS(c) MARK (&((c)->lheader)) | |
3263 | 2059 #else /* not NEW_GC */ |
428 | 2060 #define CONS_MARKED_P(c) MARKED_RECORD_HEADER_P(&((c)->lheader)) |
2061 #define MARK_CONS(c) MARK_RECORD_HEADER (&((c)->lheader)) | |
3263 | 2062 #endif /* not NEW_GC */ |
428 | 2063 |
1632 | 2064 extern MODULE_API Lisp_Object Qnil; |
428 | 2065 |
2066 #define NILP(x) EQ (x, Qnil) | |
853 | 2067 #define cons_car(a) ((a)->car_) |
2068 #define cons_cdr(a) ((a)->cdr_) | |
2069 #define XCAR(a) (XCONS (a)->car_) | |
2070 #define XCDR(a) (XCONS (a)->cdr_) | |
1318 | 2071 #define XCADR(a) (XCAR (XCDR (a))) |
2072 #define XCDDR(a) (XCDR (XCDR (a))) | |
2073 #define XCADDR(a) (XCAR (XCDDR (a))) | |
2074 #define XCDDDR(a) (XCDR (XCDDR (a))) | |
2075 #define XCADDDR(a) (XCAR (XCDDDR (a))) | |
2076 #define XCDDDDR(a) (XCDR (XCDDDR (a))) | |
2077 #define XCADDDDR(a) (XCAR (XCDDDDR (a))) | |
2078 #define XCDDDDDR(a) (XCDR (XCDDDDR (a))) | |
2079 #define XCADDDDDR(a) (XCAR (XCDDDDDR (a))) | |
2080 #define XCDDDDDDR(a) (XCDR (XCDDDDDR (a))) | |
2081 #define X1ST(a) XCAR (a) | |
2082 #define X2ND(a) XCADR (a) | |
2083 #define X3RD(a) XCADDR (a) | |
2084 #define X4TH(a) XCADDDR (a) | |
2085 #define X5TH(a) XCADDDDR (a) | |
2086 #define X6TH(a) XCADDDDDR (a) | |
2087 | |
853 | 2088 #define XSETCAR(a, b) (XCONS (a)->car_ = (b)) |
2089 #define XSETCDR(a, b) (XCONS (a)->cdr_ = (b)) | |
428 | 2090 #define LISTP(x) (CONSP(x) || NILP(x)) |
2091 | |
2092 #define CHECK_LIST(x) do { \ | |
2093 if (!LISTP (x)) \ | |
2094 dead_wrong_type_argument (Qlistp, x); \ | |
2095 } while (0) | |
2096 | |
2097 #define CONCHECK_LIST(x) do { \ | |
2098 if (!LISTP (x)) \ | |
2099 x = wrong_type_argument (Qlistp, x); \ | |
2100 } while (0) | |
2101 | |
442 | 2102 /*---------------------- list traversal macros -------------------------*/ |
2103 | |
2104 /* Note: These macros are for traversing through a list in some format, | |
2105 and executing code that you specify on each member of the list. | |
2106 | |
2107 There are two kinds of macros, those requiring surrounding braces, and | |
2108 those not requiring this. Which type of macro will be indicated. | |
2109 The general format for using a brace-requiring macro is | |
2110 | |
2111 { | |
2112 LIST_LOOP_3 (elt, list, tail) | |
2113 execute_code_here; | |
2114 } | |
2115 | |
2116 or | |
2117 | |
2118 { | |
2119 LIST_LOOP_3 (elt, list, tail) | |
2120 { | |
2121 execute_code_here; | |
2122 } | |
2123 } | |
2124 | |
2125 You can put variable declarations between the brace and beginning of | |
2126 macro, but NOTHING ELSE. | |
2127 | |
2128 The brace-requiring macros typically declare themselves any arguments | |
2129 that are initialized and iterated by the macros. If for some reason | |
2130 you need to declare these arguments yourself (e.g. to do something on | |
2131 them before the iteration starts, use the _NO_DECLARE versions of the | |
2132 macros.) | |
2133 */ | |
2134 | |
2135 /* There are two basic kinds of macros: those that handle "internal" lists | |
2136 that are known to be correctly structured (i.e. first element is a cons | |
2137 or nil, and the car of each cons is also a cons or nil, and there are | |
2138 no circularities), and those that handle "external" lists, where the | |
2139 list may have any sort of invalid formation. This is reflected in | |
2140 the names: those with "EXTERNAL_" work with external lists, and those | |
2141 without this prefix work with internal lists. The internal-list | |
2142 macros will hit an assertion failure if the structure is ill-formed; | |
2143 the external-list macros will signal an error in this case, either a | |
2144 malformed-list error or a circular-list error. | |
2145 */ | |
2146 | |
2367 | 2147 /* LIST_LOOP is a simple, old-fashioned macro. It doesn't require brace |
2148 surrounding, and iterates through a list, which may or may not known to | |
2149 be syntactically correct. It accepts two args, TAIL (set progressively | |
2150 to each cons starting with the first), and LIST, the list to iterate | |
2151 over. TAIL needs to be defined by the caller. | |
442 | 2152 |
2153 In each iteration, you can retrieve the current list item using XCAR | |
2154 (tail), or destructively modify the list using XSETCAR (tail, | |
2155 ...). */ | |
2156 | |
428 | 2157 #define LIST_LOOP(tail, list) \ |
2158 for (tail = list; \ | |
2159 !NILP (tail); \ | |
2160 tail = XCDR (tail)) | |
2161 | |
442 | 2162 /* The following macros are the "core" macros for list traversal. |
2163 | |
2164 *** ALL OF THESE MACROS MUST BE DECLARED INSIDE BRACES -- SEE ABOVE. *** | |
2165 | |
2166 LIST_LOOP_2 and EXTERNAL_LIST_LOOP_2 are the standard, most-often used | |
2167 macros. They take two arguments, an element variable ELT and the list | |
2168 LIST. ELT is automatically declared, and set to each element in turn | |
2169 from LIST. | |
2170 | |
2171 LIST_LOOP_3 and EXTERNAL_LIST_LOOP_3 are the same, but they have a third | |
2172 argument TAIL, another automatically-declared variable. At each iteration, | |
2173 this one points to the cons cell for which ELT is the car. | |
2174 | |
2175 EXTERNAL_LIST_LOOP_4 is like EXTERNAL_LIST_LOOP_3 but takes an additional | |
2176 LEN argument, again automatically declared, which counts the number of | |
2177 iterations gone by. It is 0 during the first iteration. | |
2178 | |
2179 EXTERNAL_LIST_LOOP_4_NO_DECLARE is like EXTERNAL_LIST_LOOP_4 but none | |
2180 of the variables are automatically declared, and so you need to declare | |
2181 them yourself. (ELT and TAIL are Lisp_Objects, and LEN is an EMACS_INT.) | |
2182 */ | |
2183 | |
2184 #define LIST_LOOP_2(elt, list) \ | |
2185 LIST_LOOP_3(elt, list, unused_tail_##elt) | |
2186 | |
2187 #define LIST_LOOP_3(elt, list, tail) \ | |
2188 Lisp_Object elt, tail; \ | |
2189 for (tail = list; \ | |
2190 NILP (tail) ? \ | |
2191 0 : (elt = XCAR (tail), 1); \ | |
2192 tail = XCDR (tail)) | |
428 | 2193 |
2194 /* The following macros are for traversing lisp lists. | |
2195 Signal an error if LIST is not properly acyclic and nil-terminated. | |
2196 | |
2197 Use tortoise/hare algorithm to check for cycles, but only if it | |
2198 looks like the list is getting too long. Not only is the hare | |
2199 faster than the tortoise; it even gets a head start! */ | |
2200 | |
2201 /* Optimized and safe macros for looping over external lists. */ | |
2202 #define CIRCULAR_LIST_SUSPICION_LENGTH 1024 | |
2203 | |
2204 #define EXTERNAL_LIST_LOOP_1(list) \ | |
2205 Lisp_Object ELL1_elt, ELL1_hare, ELL1_tortoise; \ | |
442 | 2206 EMACS_INT ELL1_len; \ |
2207 PRIVATE_EXTERNAL_LIST_LOOP_6 (ELL1_elt, list, ELL1_len, ELL1_hare, \ | |
428 | 2208 ELL1_tortoise, CIRCULAR_LIST_SUSPICION_LENGTH) |
2209 | |
2210 #define EXTERNAL_LIST_LOOP_2(elt, list) \ | |
442 | 2211 Lisp_Object elt, hare_##elt, tortoise_##elt; \ |
2212 EMACS_INT len_##elt; \ | |
2213 PRIVATE_EXTERNAL_LIST_LOOP_6 (elt, list, len_##elt, hare_##elt, \ | |
428 | 2214 tortoise_##elt, CIRCULAR_LIST_SUSPICION_LENGTH) |
2215 | |
2367 | 2216 |
2217 #define GC_EXTERNAL_LIST_LOOP_2(elt, list) \ | |
2218 do { \ | |
2219 XGCDECL3 (elt); \ | |
2220 Lisp_Object elt, hare_##elt, tortoise_##elt; \ | |
2221 EMACS_INT len_##elt; \ | |
2222 XGCPRO3 (elt, elt, hare_##elt, tortoise_##elt); \ | |
2223 PRIVATE_EXTERNAL_LIST_LOOP_6 (elt, list, len_##elt, hare_##elt, \ | |
2224 tortoise_##elt, \ | |
2225 CIRCULAR_LIST_SUSPICION_LENGTH) | |
2226 | |
2227 #define END_GC_EXTERNAL_LIST_LOOP(elt) \ | |
2228 XUNGCPRO (elt); \ | |
2229 } \ | |
2230 while (0) | |
2231 | |
428 | 2232 #define EXTERNAL_LIST_LOOP_3(elt, list, tail) \ |
442 | 2233 Lisp_Object elt, tail, tortoise_##elt; \ |
2234 EMACS_INT len_##elt; \ | |
2235 PRIVATE_EXTERNAL_LIST_LOOP_6 (elt, list, len_##elt, tail, \ | |
2236 tortoise_##elt, CIRCULAR_LIST_SUSPICION_LENGTH) | |
2237 | |
2238 #define EXTERNAL_LIST_LOOP_4_NO_DECLARE(elt, list, tail, len) \ | |
428 | 2239 Lisp_Object tortoise_##elt; \ |
442 | 2240 PRIVATE_EXTERNAL_LIST_LOOP_6 (elt, list, len, tail, \ |
428 | 2241 tortoise_##elt, CIRCULAR_LIST_SUSPICION_LENGTH) |
2242 | |
2243 #define EXTERNAL_LIST_LOOP_4(elt, list, tail, len) \ | |
442 | 2244 Lisp_Object elt, tail, tortoise_##elt; \ |
2245 EMACS_INT len; \ | |
2246 PRIVATE_EXTERNAL_LIST_LOOP_6 (elt, list, len, tail, \ | |
428 | 2247 tortoise_##elt, CIRCULAR_LIST_SUSPICION_LENGTH) |
2248 | |
2249 | |
444 | 2250 #define PRIVATE_EXTERNAL_LIST_LOOP_6(elt, list, len, hare, \ |
2251 tortoise, suspicion_length) \ | |
2252 for (tortoise = hare = list, len = 0; \ | |
2253 \ | |
2254 (CONSP (hare) ? ((elt = XCAR (hare)), 1) : \ | |
2255 (NILP (hare) ? 0 : \ | |
2256 (signal_malformed_list_error (list), 0))); \ | |
2257 \ | |
2258 hare = XCDR (hare), \ | |
2259 (void) \ | |
2260 ((++len > suspicion_length) \ | |
2261 && \ | |
2262 ((((len & 1) != 0) && (tortoise = XCDR (tortoise), 0)), \ | |
2263 (EQ (hare, tortoise) && (signal_circular_list_error (list), 0))))) | |
428 | 2264 |
442 | 2265 /* GET_LIST_LENGTH and GET_EXTERNAL_LIST_LENGTH: |
2266 | |
2267 These two macros return the length of LIST (either an internal or external | |
2268 list, according to which macro is used), stored into LEN (which must | |
2269 be declared by the caller). Circularities are trapped in external lists | |
2270 (and cause errors). Neither macro need be declared inside brackets. */ | |
2271 | |
2272 #define GET_LIST_LENGTH(list, len) do { \ | |
2273 Lisp_Object GLL_tail; \ | |
2274 for (GLL_tail = list, len = 0; \ | |
2275 !NILP (GLL_tail); \ | |
2276 GLL_tail = XCDR (GLL_tail), ++len) \ | |
2277 DO_NOTHING; \ | |
2278 } while (0) | |
2279 | |
2280 #define GET_EXTERNAL_LIST_LENGTH(list, len) \ | |
2281 do { \ | |
2282 Lisp_Object GELL_elt, GELL_tail; \ | |
2283 EXTERNAL_LIST_LOOP_4_NO_DECLARE (GELL_elt, list, GELL_tail, len) \ | |
2284 ; \ | |
2285 } while (0) | |
2286 | |
2287 /* For a list that's known to be in valid list format, where we may | |
2288 be deleting the current element out of the list -- | |
2500 | 2289 will ABORT() if the list is not in valid format */ |
442 | 2290 #define LIST_LOOP_DELETING(consvar, nextconsvar, list) \ |
2291 for (consvar = list; \ | |
2292 !NILP (consvar) ? (nextconsvar = XCDR (consvar), 1) :0; \ | |
2293 consvar = nextconsvar) | |
2294 | |
2295 /* LIST_LOOP_DELETE_IF and EXTERNAL_LIST_LOOP_DELETE_IF: | |
2296 | |
2297 These two macros delete all elements of LIST (either an internal or | |
2298 external list, according to which macro is used) satisfying | |
2299 CONDITION, a C expression referring to variable ELT. ELT is | |
2300 automatically declared. Circularities are trapped in external | |
2301 lists (and cause errors). Neither macro need be declared inside | |
2302 brackets. */ | |
2303 | |
2304 #define LIST_LOOP_DELETE_IF(elt, list, condition) do { \ | |
2305 /* Do not use ##list when creating new variables because \ | |
2306 that may not be just a variable name. */ \ | |
2307 Lisp_Object prev_tail_##elt = Qnil; \ | |
2308 LIST_LOOP_3 (elt, list, tail_##elt) \ | |
2309 { \ | |
2310 if (condition) \ | |
2311 { \ | |
2312 if (NILP (prev_tail_##elt)) \ | |
2313 list = XCDR (tail_##elt); \ | |
2314 else \ | |
2315 XCDR (prev_tail_##elt) = XCDR (tail_##elt); \ | |
2316 } \ | |
2317 else \ | |
2318 prev_tail_##elt = tail_##elt; \ | |
2319 } \ | |
2320 } while (0) | |
2321 | |
2322 #define EXTERNAL_LIST_LOOP_DELETE_IF(elt, list, condition) do { \ | |
2323 Lisp_Object prev_tail_##elt = Qnil; \ | |
2324 EXTERNAL_LIST_LOOP_4 (elt, list, tail_##elt, len_##elt) \ | |
2325 { \ | |
2326 if (condition) \ | |
2327 { \ | |
2328 if (NILP (prev_tail_##elt)) \ | |
2329 list = XCDR (tail_##elt); \ | |
2330 else \ | |
2331 XCDR (prev_tail_##elt) = XCDR (tail_##elt); \ | |
2332 /* Keep tortoise from ever passing hare. */ \ | |
2333 len_##elt = 0; \ | |
2334 } \ | |
2335 else \ | |
2336 prev_tail_##elt = tail_##elt; \ | |
2337 } \ | |
2338 } while (0) | |
2339 | |
2340 | |
1204 | 2341 /* Macros for looping over internal alists. |
2342 | |
2343 *** ALL OF THESE MACROS MUST BE DECLARED INSIDE BRACES -- SEE ABOVE. *** | |
2344 | |
2345 ALIST_LOOP_3 loops over an alist, at each iteration setting CAR and CDR | |
2346 to the car and cdr of the acons. CAR and CDR are automatically | |
2347 declared. | |
2348 | |
2349 ALIST_LOOP_4 is similar to ALIST_LOOP_3 but contains an additional | |
2350 variable ACONS at the beginning for access to the acons itself.All of | |
2351 the variables ACONS, CAR and CDR are automatically declared. | |
2352 */ | |
2353 | |
2354 #define ALIST_LOOP_3(car, cdr, alist) \ | |
2355 Lisp_Object _al3_acons_##car, car, cdr, _al3_tail_##car; \ | |
2356 for (_al3_tail_##car = alist; \ | |
2357 NILP (_al3_tail_##car) ? \ | |
2358 0 : (_al3_acons_##car = XCAR (_al3_tail_##car), \ | |
2359 car = XCAR (_al3_acons_##car), \ | |
2360 cdr = XCDR (_al3_acons_##car), 1); \ | |
2361 _al3_tail_##car = XCDR (_al3_tail_##car)) | |
2362 | |
2363 #define ALIST_LOOP_4(acons, car, cdr, list) \ | |
2364 Lisp_Object acons, car, cdr, _al4_tail_##car; \ | |
2365 for (_al4_tail_##car = list; \ | |
2366 NILP (_al4_tail_##car) ? \ | |
2367 0 : (elt = XCAR (_al4_tail_##car), car = XCAR (elt), \ | |
2368 cdr = XCDR (elt), 1); \ | |
2369 _al4_tail_##car = XCDR (tail)) | |
2370 | |
442 | 2371 /* Macros for looping over external alists. |
2372 | |
2373 *** ALL OF THESE MACROS MUST BE DECLARED INSIDE BRACES -- SEE ABOVE. *** | |
2374 | |
2375 EXTERNAL_ALIST_LOOP_4 is similar to EXTERNAL_LIST_LOOP_2, but it | |
2376 assumes the elements are aconses (the elements in an alist) and | |
2377 sets two additional argument variables ELT_CAR and ELT_CDR to the | |
2378 car and cdr of the acons. All of the variables ELT, ELT_CAR and | |
2379 ELT_CDR are automatically declared. | |
2380 | |
2381 EXTERNAL_ALIST_LOOP_5 adds a TAIL argument to EXTERNAL_ALIST_LOOP_4, | |
2382 just like EXTERNAL_LIST_LOOP_3 does, and again TAIL is automatically | |
2383 declared. | |
2384 | |
2385 EXTERNAL_ALIST_LOOP_6 adds a LEN argument to EXTERNAL_ALIST_LOOP_5, | |
2386 just like EXTERNAL_LIST_LOOP_4 does, and again LEN is automatically | |
2387 declared. | |
2388 | |
2389 EXTERNAL_ALIST_LOOP_6_NO_DECLARE does not declare any of its arguments, | |
2390 just like EXTERNAL_LIST_LOOP_4_NO_DECLARE, and so these must be declared | |
2391 manually. | |
2392 */ | |
428 | 2393 |
2394 /* Optimized and safe macros for looping over external alists. */ | |
2395 #define EXTERNAL_ALIST_LOOP_4(elt, elt_car, elt_cdr, list) \ | |
442 | 2396 Lisp_Object elt, elt_car, elt_cdr; \ |
428 | 2397 Lisp_Object hare_##elt, tortoise_##elt; \ |
2398 EMACS_INT len_##elt; \ | |
442 | 2399 PRIVATE_EXTERNAL_ALIST_LOOP_8 (elt, elt_car, elt_cdr, list, \ |
428 | 2400 len_##elt, hare_##elt, tortoise_##elt, \ |
2401 CIRCULAR_LIST_SUSPICION_LENGTH) | |
2402 | |
2403 #define EXTERNAL_ALIST_LOOP_5(elt, elt_car, elt_cdr, list, tail) \ | |
442 | 2404 Lisp_Object elt, elt_car, elt_cdr, tail; \ |
428 | 2405 Lisp_Object tortoise_##elt; \ |
2406 EMACS_INT len_##elt; \ | |
442 | 2407 PRIVATE_EXTERNAL_ALIST_LOOP_8 (elt, elt_car, elt_cdr, list, \ |
428 | 2408 len_##elt, tail, tortoise_##elt, \ |
2409 CIRCULAR_LIST_SUSPICION_LENGTH) \ | |
2410 | |
2411 #define EXTERNAL_ALIST_LOOP_6(elt, elt_car, elt_cdr, list, tail, len) \ | |
442 | 2412 Lisp_Object elt, elt_car, elt_cdr, tail; \ |
2413 EMACS_INT len; \ | |
428 | 2414 Lisp_Object tortoise_##elt; \ |
442 | 2415 PRIVATE_EXTERNAL_ALIST_LOOP_8 (elt, elt_car, elt_cdr, list, \ |
428 | 2416 len, tail, tortoise_##elt, \ |
2417 CIRCULAR_LIST_SUSPICION_LENGTH) | |
2418 | |
442 | 2419 #define EXTERNAL_ALIST_LOOP_6_NO_DECLARE(elt, elt_car, elt_cdr, list, \ |
2420 tail, len) \ | |
2421 Lisp_Object tortoise_##elt; \ | |
2422 PRIVATE_EXTERNAL_ALIST_LOOP_8 (elt, elt_car, elt_cdr, list, \ | |
2423 len, tail, tortoise_##elt, \ | |
2424 CIRCULAR_LIST_SUSPICION_LENGTH) | |
2425 | |
2426 | |
2427 #define PRIVATE_EXTERNAL_ALIST_LOOP_8(elt, elt_car, elt_cdr, list, len, \ | |
2428 hare, tortoise, suspicion_length) \ | |
2429 PRIVATE_EXTERNAL_LIST_LOOP_6 (elt, list, len, hare, tortoise, \ | |
2430 suspicion_length) \ | |
428 | 2431 if (CONSP (elt) ? (elt_car = XCAR (elt), elt_cdr = XCDR (elt), 0) :1) \ |
2432 continue; \ | |
2433 else | |
2434 | |
442 | 2435 /* Macros for looping over external property lists. |
2436 | |
2437 *** ALL OF THESE MACROS MUST BE DECLARED INSIDE BRACES -- SEE ABOVE. *** | |
2438 | |
2439 EXTERNAL_PROPERTY_LIST_LOOP_3 maps over an external list assumed to | |
2440 be a property list, consisting of alternating pairs of keys | |
2441 (typically symbols or keywords) and values. Each iteration | |
2442 processes one such pair out of LIST, assigning the two elements to | |
2443 KEY and VALUE respectively. Malformed lists and circularities are | |
2444 trapped as usual, and in addition, property lists with an odd number | |
2445 of elements also signal an error. | |
2446 | |
2447 EXTERNAL_PROPERTY_LIST_LOOP_4 adds a TAIL argument to | |
2448 EXTERNAL_PROPERTY_LIST_LOOP_3, just like EXTERNAL_LIST_LOOP_3 does, | |
2449 and again TAIL is automatically declared. | |
2450 | |
2451 EXTERNAL_PROPERTY_LIST_LOOP_5 adds a LEN argument to | |
2452 EXTERNAL_PROPERTY_LIST_LOOP_4, just like EXTERNAL_LIST_LOOP_4 does, | |
2453 and again LEN is automatically declared. Note that in this case, | |
2454 LEN counts the iterations, NOT the total number of list elements | |
2455 processed, which is 2 * LEN. | |
2456 | |
2457 EXTERNAL_PROPERTY_LIST_LOOP_5_NO_DECLARE does not declare any of its | |
2458 arguments, just like EXTERNAL_LIST_LOOP_4_NO_DECLARE, and so these | |
2459 must be declared manually. */ | |
428 | 2460 |
2461 /* Optimized and safe macros for looping over external property lists. */ | |
2462 #define EXTERNAL_PROPERTY_LIST_LOOP_3(key, value, list) \ | |
2463 Lisp_Object key, value, hare_##key, tortoise_##key; \ | |
442 | 2464 EMACS_INT len_##key; \ |
428 | 2465 EXTERNAL_PROPERTY_LIST_LOOP_7 (key, value, list, len_##key, hare_##key, \ |
2466 tortoise_##key, CIRCULAR_LIST_SUSPICION_LENGTH) | |
2467 | |
2468 #define EXTERNAL_PROPERTY_LIST_LOOP_4(key, value, list, tail) \ | |
2469 Lisp_Object key, value, tail, tortoise_##key; \ | |
442 | 2470 EMACS_INT len_##key; \ |
428 | 2471 EXTERNAL_PROPERTY_LIST_LOOP_7 (key, value, list, len_##key, tail, \ |
2472 tortoise_##key, CIRCULAR_LIST_SUSPICION_LENGTH) | |
2473 | |
2474 #define EXTERNAL_PROPERTY_LIST_LOOP_5(key, value, list, tail, len) \ | |
2475 Lisp_Object key, value, tail, tortoise_##key; \ | |
2476 EMACS_INT len; \ | |
2477 EXTERNAL_PROPERTY_LIST_LOOP_7 (key, value, list, len, tail, \ | |
2478 tortoise_##key, CIRCULAR_LIST_SUSPICION_LENGTH) | |
2479 | |
442 | 2480 #define EXTERNAL_PROPERTY_LIST_LOOP_5_NO_DECLARE(key, value, list, \ |
2481 tail, len) \ | |
2482 Lisp_Object tortoise_##key; \ | |
2483 EXTERNAL_PROPERTY_LIST_LOOP_7 (key, value, list, len, tail, \ | |
2484 tortoise_##key, CIRCULAR_LIST_SUSPICION_LENGTH) | |
2485 | |
428 | 2486 |
2487 #define EXTERNAL_PROPERTY_LIST_LOOP_7(key, value, list, len, hare, \ | |
2488 tortoise, suspicion_length) \ | |
2489 for (tortoise = hare = list, len = 0; \ | |
2490 \ | |
2491 ((CONSP (hare) && \ | |
2492 (key = XCAR (hare), \ | |
2493 hare = XCDR (hare), \ | |
442 | 2494 (CONSP (hare) ? 1 : \ |
2495 (signal_malformed_property_list_error (list), 0)))) ? \ | |
428 | 2496 (value = XCAR (hare), 1) : \ |
2497 (NILP (hare) ? 0 : \ | |
2498 (signal_malformed_property_list_error (list), 0))); \ | |
2499 \ | |
2500 hare = XCDR (hare), \ | |
2501 ((++len < suspicion_length) ? \ | |
2502 ((void) 0) : \ | |
2503 (((len & 1) ? \ | |
2504 ((void) (tortoise = XCDR (XCDR (tortoise)))) : \ | |
2505 ((void) 0)) \ | |
2506 , \ | |
2507 (EQ (hare, tortoise) ? \ | |
2508 ((void) signal_circular_property_list_error (list)) : \ | |
2509 ((void) 0))))) | |
2510 | |
2421 | 2511 #define PRIVATE_PROPERTY_LIST_LOOP_4(tail, key, value, plist) \ |
2512 for (tail = plist; \ | |
2513 NILP (tail) ? 0 : \ | |
2514 (key = XCAR (tail), tail = XCDR (tail), \ | |
2515 value = XCAR (tail), tail = XCDR (tail), 1); \ | |
428 | 2516 ) |
2517 | |
2421 | 2518 #define PROPERTY_LIST_LOOP_3(key, value, plist) \ |
2519 Lisp_Object key, value, tail_##key; \ | |
2520 PRIVATE_PROPERTY_LIST_LOOP_4 (tail_##key, key, value, plist) | |
2521 | |
2522 #define GC_PROPERTY_LIST_LOOP_3(key, value, plist) \ | |
2523 do { \ | |
2524 XGCDECL3 (key); \ | |
2525 Lisp_Object key, value, tail_##key; \ | |
2526 XGCPRO3 (key, key, value, tail_##key); \ | |
2527 PRIVATE_PROPERTY_LIST_LOOP_4 (tail_##key, key, value, plist) | |
2528 | |
2529 #define END_GC_PROPERTY_LIST_LOOP(key) \ | |
2530 XUNGCPRO (key); \ | |
2531 } \ | |
2532 while (0) | |
2533 | |
428 | 2534 /* Return 1 if LIST is properly acyclic and nil-terminated, else 0. */ |
826 | 2535 DECLARE_INLINE_HEADER ( |
2536 int | |
428 | 2537 TRUE_LIST_P (Lisp_Object object) |
826 | 2538 ) |
428 | 2539 { |
2540 Lisp_Object hare, tortoise; | |
2541 EMACS_INT len; | |
2542 | |
2543 for (hare = tortoise = object, len = 0; | |
2544 CONSP (hare); | |
2545 hare = XCDR (hare), len++) | |
2546 { | |
2547 if (len < CIRCULAR_LIST_SUSPICION_LENGTH) | |
2548 continue; | |
2549 | |
2550 if (len & 1) | |
2551 tortoise = XCDR (tortoise); | |
2552 else if (EQ (hare, tortoise)) | |
2553 return 0; | |
2554 } | |
2555 | |
2556 return NILP (hare); | |
2557 } | |
2558 | |
2559 /* Signal an error if LIST is not properly acyclic and nil-terminated. */ | |
2560 #define CHECK_TRUE_LIST(list) do { \ | |
2561 Lisp_Object CTL_list = (list); \ | |
2562 Lisp_Object CTL_hare, CTL_tortoise; \ | |
436 | 2563 EMACS_INT CTL_len; \ |
428 | 2564 \ |
2565 for (CTL_hare = CTL_tortoise = CTL_list, CTL_len = 0; \ | |
2566 CONSP (CTL_hare); \ | |
2567 CTL_hare = XCDR (CTL_hare), CTL_len++) \ | |
2568 { \ | |
2569 if (CTL_len < CIRCULAR_LIST_SUSPICION_LENGTH) \ | |
2570 continue; \ | |
2571 \ | |
2572 if (CTL_len & 1) \ | |
2573 CTL_tortoise = XCDR (CTL_tortoise); \ | |
2574 else if (EQ (CTL_hare, CTL_tortoise)) \ | |
2575 Fsignal (Qcircular_list, list1 (CTL_list)); \ | |
2576 } \ | |
2577 \ | |
2578 if (! NILP (CTL_hare)) \ | |
2579 signal_malformed_list_error (CTL_list); \ | |
2580 } while (0) | |
2581 | |
442 | 2582 /*------------------------------ string --------------------------------*/ |
428 | 2583 |
3092 | 2584 #ifdef NEW_GC |
2585 struct Lisp_String_Direct_Data | |
2586 { | |
2587 struct lrecord_header header; | |
2588 Bytecount size; | |
2589 Ibyte data[1]; | |
2590 }; | |
2591 typedef struct Lisp_String_Direct_Data Lisp_String_Direct_Data; | |
2592 | |
2593 DECLARE_MODULE_API_LRECORD (string_direct_data, Lisp_String_Direct_Data); | |
2594 #define XSTRING_DIRECT_DATA(x) \ | |
2595 XRECORD (x, string_direct_data, Lisp_String_Direct_Data) | |
2596 #define wrap_string_direct_data(p) wrap_record (p, string_direct_data) | |
2597 #define STRING_DIRECT_DATAP(x) RECORDP (x, string_direct_data) | |
2598 #define CHECK_STRING_DIRECT_DATA(x) CHECK_RECORD (x, string_direct_data) | |
2599 #define CONCHECK_STRING_DIRECT_DATA(x) CONCHECK_RECORD (x, string_direct_data) | |
2600 | |
2601 #define XSTRING_DIRECT_DATA_SIZE(x) XSTRING_DIRECT_DATA (x)->size | |
2602 #define XSTRING_DIRECT_DATA_DATA(x) XSTRING_DIRECT_DATA (x)->data | |
2603 | |
2604 | |
2605 struct Lisp_String_Indirect_Data | |
2606 { | |
2607 struct lrecord_header header; | |
2608 Bytecount size; | |
2609 Ibyte *data; | |
2610 }; | |
2611 typedef struct Lisp_String_Indirect_Data Lisp_String_Indirect_Data; | |
2612 | |
2613 DECLARE_MODULE_API_LRECORD (string_indirect_data, Lisp_String_Indirect_Data); | |
2614 #define XSTRING_INDIRECT_DATA(x) \ | |
2615 XRECORD (x, string_indirect_data, Lisp_String_Indirect_Data) | |
2616 #define wrap_string_indirect_data(p) wrap_record (p, string_indirect_data) | |
2617 #define STRING_INDIRECT_DATAP(x) RECORDP (x, string_indirect_data) | |
2618 #define CHECK_STRING_INDIRECT_DATA(x) CHECK_RECORD (x, string_indirect_data) | |
2619 #define CONCHECK_STRING_INDIRECT_DATA(x) \ | |
2620 CONCHECK_RECORD (x, string_indirect_data) | |
2621 | |
2622 #define XSTRING_INDIRECT_DATA_SIZE(x) XSTRING_INDIRECT_DATA (x)->size | |
2623 #define XSTRING_INDIRECT_DATA_DATA(x) XSTRING_INDIRECT_DATA (x)->data | |
2624 | |
2625 | |
2626 #define XSTRING_DATA_SIZE(s) ((s)->indirect)? \ | |
2627 XSTRING_INDIRECT_DATA_SIZE ((s)->data_object): \ | |
2628 XSTRING_DIRECT_DATA_SIZE ((s)->data_object) | |
2629 #define XSTRING_DATA_DATA(s) ((s)->indirect)? \ | |
2630 XSTRING_INDIRECT_DATA_DATA ((s)->data_object): \ | |
2631 XSTRING_DIRECT_DATA_DATA ((s)->data_object) | |
2632 | |
2633 #define XSET_STRING_DATA_SIZE(s, len) \ | |
2634 if ((s)->indirect) \ | |
2635 XSTRING_INDIRECT_DATA_SIZE ((s)->data_object) = len; \ | |
2636 else \ | |
2637 XSTRING_DIRECT_DATA_SIZE ((s)->data_object) = len | |
2638 #define XSET_STRING_DATA_DATA(s, ptr) \ | |
2639 if ((s)->indirect) \ | |
2640 XSTRING_INDIRECT_DATA_DATA ((s)->data_object) = ptr; \ | |
2641 else \ | |
2642 XSTRING_DIRECT_DATA_DATA ((s)->data_object) = ptr | |
2643 #endif /* NEW_GC */ | |
2644 | |
428 | 2645 struct Lisp_String |
2646 { | |
771 | 2647 union |
2648 { | |
2649 struct lrecord_header lheader; | |
2650 struct | |
2651 { | |
2652 /* WARNING: Everything before ascii_begin must agree exactly with | |
2653 struct lrecord_header */ | |
2654 unsigned int type :8; | |
3263 | 2655 #ifdef NEW_GC |
2720 | 2656 unsigned int lisp_readonly :1; |
2657 unsigned int free :1; | |
2658 /* Number of chars at beginning of string that are one byte in length | |
2659 (byte_ascii_p) */ | |
2660 unsigned int ascii_begin :22; | |
3263 | 2661 #else /* not NEW_GC */ |
771 | 2662 unsigned int mark :1; |
2663 unsigned int c_readonly :1; | |
2664 unsigned int lisp_readonly :1; | |
2665 /* Number of chars at beginning of string that are one byte in length | |
826 | 2666 (byte_ascii_p) */ |
771 | 2667 unsigned int ascii_begin :21; |
3263 | 2668 #endif /* not NEW_GC */ |
771 | 2669 } v; |
2670 } u; | |
3092 | 2671 #ifdef NEW_GC |
2672 int indirect; | |
2673 Lisp_Object data_object; | |
2674 #else /* not NEW_GC */ | |
793 | 2675 Bytecount size_; |
867 | 2676 Ibyte *data_; |
3092 | 2677 #endif /* not NEW_GC */ |
428 | 2678 Lisp_Object plist; |
2679 }; | |
2680 typedef struct Lisp_String Lisp_String; | |
2681 | |
3263 | 2682 #ifdef NEW_GC |
3063 | 2683 #define MAX_STRING_ASCII_BEGIN ((1 << 22) - 1) |
3263 | 2684 #else /* not NEW_GC */ |
851 | 2685 #define MAX_STRING_ASCII_BEGIN ((1 << 21) - 1) |
3263 | 2686 #endif /* not NEW_GC */ |
771 | 2687 |
1632 | 2688 DECLARE_MODULE_API_LRECORD (string, Lisp_String); |
428 | 2689 #define XSTRING(x) XRECORD (x, string, Lisp_String) |
617 | 2690 #define wrap_string(p) wrap_record (p, string) |
428 | 2691 #define STRINGP(x) RECORDP (x, string) |
2692 #define CHECK_STRING(x) CHECK_RECORD (x, string) | |
2693 #define CONCHECK_STRING(x) CONCHECK_RECORD (x, string) | |
2694 | |
826 | 2695 /* Most basic macros for strings -- basically just accessing or setting |
2696 fields -- are here. Everything else is in text.h, since they depend on | |
2697 stuff there. */ | |
428 | 2698 |
793 | 2699 /* Operations on Lisp_String *'s; only ones left */ |
3092 | 2700 #ifdef NEW_GC |
3304 | 2701 #define set_lispstringp_direct(s) ((s)->indirect = 0) |
3092 | 2702 #define set_lispstringp_indirect(s) ((s)->indirect = 1) |
2703 #define set_lispstringp_length(s, len) XSET_STRING_DATA_SIZE (s, len) | |
2704 #define set_lispstringp_data(s, ptr) XSET_STRING_DATA_DATA (s, ptr) | |
2705 #else /* not NEW_GC */ | |
826 | 2706 #define set_lispstringp_length(s, len) ((void) ((s)->size_ = (len))) |
2707 #define set_lispstringp_data(s, ptr) ((void) ((s)->data_ = (ptr))) | |
3092 | 2708 #endif /* not NEW_GC */ |
826 | 2709 |
2710 /* Operations on strings as Lisp_Objects. Don't manipulate Lisp_String *'s | |
2711 in any new code. */ | |
3092 | 2712 #ifdef NEW_GC |
2713 #define STRING_DATA_OBJECT(s) ((s)->data_object) | |
2714 #define XSTRING_DATA_OBJECT(s) (STRING_DATA_OBJECT (XSTRING (s))) | |
2715 #define XSTRING_LENGTH(s) (XSTRING_DATA_SIZE (XSTRING (s))) | |
2716 #else /* not NEW_GC */ | |
793 | 2717 #define XSTRING_LENGTH(s) (XSTRING (s)->size_) |
3092 | 2718 #endif /* not NEW_GC */ |
793 | 2719 #define XSTRING_PLIST(s) (XSTRING (s)->plist) |
3092 | 2720 #ifdef NEW_GC |
2721 #define XSTRING_DATA(s) (XSTRING_DATA_DATA (XSTRING (s))) | |
2722 #else /* not NEW_GC */ | |
793 | 2723 #define XSTRING_DATA(s) (XSTRING (s)->data_ + 0) |
3092 | 2724 #endif /* not NEW_GC */ |
793 | 2725 #define XSTRING_ASCII_BEGIN(s) (XSTRING (s)->u.v.ascii_begin + 0) |
826 | 2726 #define XSET_STRING_LENGTH(s, ptr) set_lispstringp_length (XSTRING (s), ptr) |
2727 #define XSET_STRING_DATA(s, ptr) set_lispstringp_data (XSTRING (s), ptr) | |
771 | 2728 /* WARNING: If you modify an existing string, you must call |
2729 bump_string_modiff() afterwards. */ | |
793 | 2730 #define XSET_STRING_ASCII_BEGIN(s, val) \ |
2731 ((void) (XSTRING (s)->u.v.ascii_begin = (val))) | |
826 | 2732 #define XSTRING_FORMAT(s) FORMAT_DEFAULT |
428 | 2733 |
456 | 2734 /* Return the true aligned size of a struct whose last member is a |
2735 variable-length array field. (this is known as the "struct hack") */ | |
2736 /* Implementation: in practice, structtype and fieldtype usually have | |
2737 the same alignment, but we can't be sure. We need to use | |
2738 ALIGN_SIZE to be absolutely sure of getting the correct alignment. | |
2739 To help the compiler's optimizer, we use a ternary expression that | |
2740 only a very stupid compiler would fail to correctly simplify. */ | |
2741 #define FLEXIBLE_ARRAY_STRUCT_SIZEOF(structtype, \ | |
2742 fieldtype, \ | |
2743 fieldname, \ | |
2744 array_length) \ | |
2745 (ALIGNOF (structtype) == ALIGNOF (fieldtype) \ | |
2746 ? (offsetof (structtype, fieldname) + \ | |
2747 (offsetof (structtype, fieldname[1]) - \ | |
2748 offsetof (structtype, fieldname[0])) * \ | |
2749 (array_length)) \ | |
826 | 2750 : (ALIGN_FOR_TYPE \ |
456 | 2751 ((offsetof (structtype, fieldname) + \ |
2752 (offsetof (structtype, fieldname[1]) - \ | |
2753 offsetof (structtype, fieldname[0])) * \ | |
2754 (array_length)), \ | |
826 | 2755 structtype))) |
442 | 2756 |
2757 /*------------------------------ vector --------------------------------*/ | |
428 | 2758 |
2759 struct Lisp_Vector | |
2760 { | |
3017 | 2761 struct LCRECORD_HEADER header; |
428 | 2762 long size; |
2763 Lisp_Object contents[1]; | |
2764 }; | |
2765 typedef struct Lisp_Vector Lisp_Vector; | |
2766 | |
2767 DECLARE_LRECORD (vector, Lisp_Vector); | |
2768 #define XVECTOR(x) XRECORD (x, vector, Lisp_Vector) | |
617 | 2769 #define wrap_vector(p) wrap_record (p, vector) |
428 | 2770 #define VECTORP(x) RECORDP (x, vector) |
2771 #define CHECK_VECTOR(x) CHECK_RECORD (x, vector) | |
2772 #define CONCHECK_VECTOR(x) CONCHECK_RECORD (x, vector) | |
2773 | |
2774 #define vector_length(v) ((v)->size) | |
2775 #define XVECTOR_LENGTH(s) vector_length (XVECTOR (s)) | |
2776 #define vector_data(v) ((v)->contents) | |
2777 #define XVECTOR_DATA(s) vector_data (XVECTOR (s)) | |
2778 | |
442 | 2779 /*---------------------------- bit vectors -----------------------------*/ |
428 | 2780 |
2781 #if (LONGBITS < 16) | |
2782 #error What the hell?! | |
2783 #elif (LONGBITS < 32) | |
2784 # define LONGBITS_LOG2 4 | |
2785 # define LONGBITS_POWER_OF_2 16 | |
2786 #elif (LONGBITS < 64) | |
2787 # define LONGBITS_LOG2 5 | |
2788 # define LONGBITS_POWER_OF_2 32 | |
2789 #elif (LONGBITS < 128) | |
2790 # define LONGBITS_LOG2 6 | |
2791 # define LONGBITS_POWER_OF_2 64 | |
2792 #else | |
2793 #error You really have 128-bit integers?! | |
2794 #endif | |
2795 | |
2796 struct Lisp_Bit_Vector | |
2797 { | |
3017 | 2798 struct LCRECORD_HEADER lheader; |
665 | 2799 Elemcount size; |
428 | 2800 unsigned long bits[1]; |
2801 }; | |
2802 typedef struct Lisp_Bit_Vector Lisp_Bit_Vector; | |
2803 | |
2804 DECLARE_LRECORD (bit_vector, Lisp_Bit_Vector); | |
2805 #define XBIT_VECTOR(x) XRECORD (x, bit_vector, Lisp_Bit_Vector) | |
617 | 2806 #define wrap_bit_vector(p) wrap_record (p, bit_vector) |
428 | 2807 #define BIT_VECTORP(x) RECORDP (x, bit_vector) |
2808 #define CHECK_BIT_VECTOR(x) CHECK_RECORD (x, bit_vector) | |
2809 #define CONCHECK_BIT_VECTOR(x) CONCHECK_RECORD (x, bit_vector) | |
2810 | |
2811 #define BITP(x) (INTP (x) && (XINT (x) == 0 || XINT (x) == 1)) | |
2812 | |
2813 #define CHECK_BIT(x) do { \ | |
2814 if (!BITP (x)) \ | |
2815 dead_wrong_type_argument (Qbitp, x);\ | |
2816 } while (0) | |
2817 | |
2818 #define CONCHECK_BIT(x) do { \ | |
2819 if (!BITP (x)) \ | |
2820 x = wrong_type_argument (Qbitp, x); \ | |
2821 } while (0) | |
2822 | |
2823 #define bit_vector_length(v) ((v)->size) | |
2824 | |
826 | 2825 DECLARE_INLINE_HEADER ( |
2826 int | |
665 | 2827 bit_vector_bit (Lisp_Bit_Vector *v, Elemcount n) |
826 | 2828 ) |
428 | 2829 { |
2830 return ((v->bits[n >> LONGBITS_LOG2] >> (n & (LONGBITS_POWER_OF_2 - 1))) | |
2831 & 1); | |
2832 } | |
2833 | |
826 | 2834 DECLARE_INLINE_HEADER ( |
2835 void | |
665 | 2836 set_bit_vector_bit (Lisp_Bit_Vector *v, Elemcount n, int value) |
826 | 2837 ) |
428 | 2838 { |
2839 if (value) | |
2840 v->bits[n >> LONGBITS_LOG2] |= (1UL << (n & (LONGBITS_POWER_OF_2 - 1))); | |
2841 else | |
2842 v->bits[n >> LONGBITS_LOG2] &= ~(1UL << (n & (LONGBITS_POWER_OF_2 - 1))); | |
2843 } | |
2844 | |
2845 /* Number of longs required to hold LEN bits */ | |
2846 #define BIT_VECTOR_LONG_STORAGE(len) \ | |
2847 (((len) + LONGBITS_POWER_OF_2 - 1) >> LONGBITS_LOG2) | |
2848 | |
3659 | 2849 /* For when we want to include a bit vector in another structure, and we |
2850 know it's of a fixed size. */ | |
2851 #define DECLARE_INLINE_LISP_BIT_VECTOR(numbits) struct { \ | |
2852 struct LCRECORD_HEADER lheader; \ | |
2853 Elemcount size; \ | |
2854 unsigned long bits[BIT_VECTOR_LONG_STORAGE(numbits)]; \ | |
2855 } | |
853 | 2856 |
442 | 2857 /*------------------------------ symbol --------------------------------*/ |
428 | 2858 |
440 | 2859 typedef struct Lisp_Symbol Lisp_Symbol; |
428 | 2860 struct Lisp_Symbol |
2861 { | |
2862 struct lrecord_header lheader; | |
2863 /* next symbol in this obarray bucket */ | |
440 | 2864 Lisp_Symbol *next; |
793 | 2865 Lisp_Object name; |
428 | 2866 Lisp_Object value; |
2867 Lisp_Object function; | |
2868 Lisp_Object plist; | |
2869 }; | |
2870 | |
2871 #define SYMBOL_IS_KEYWORD(sym) \ | |
826 | 2872 ((string_byte (symbol_name (XSYMBOL (sym)), 0) == ':') \ |
428 | 2873 && EQ (sym, oblookup (Vobarray, \ |
793 | 2874 XSTRING_DATA (symbol_name (XSYMBOL (sym))), \ |
2875 XSTRING_LENGTH (symbol_name (XSYMBOL (sym)))))) | |
428 | 2876 #define KEYWORDP(obj) (SYMBOLP (obj) && SYMBOL_IS_KEYWORD (obj)) |
2877 | |
1632 | 2878 DECLARE_MODULE_API_LRECORD (symbol, Lisp_Symbol); |
428 | 2879 #define XSYMBOL(x) XRECORD (x, symbol, Lisp_Symbol) |
617 | 2880 #define wrap_symbol(p) wrap_record (p, symbol) |
428 | 2881 #define SYMBOLP(x) RECORDP (x, symbol) |
2882 #define CHECK_SYMBOL(x) CHECK_RECORD (x, symbol) | |
2883 #define CONCHECK_SYMBOL(x) CONCHECK_RECORD (x, symbol) | |
2884 | |
2885 #define symbol_next(s) ((s)->next) | |
2886 #define symbol_name(s) ((s)->name) | |
2887 #define symbol_value(s) ((s)->value) | |
2888 #define symbol_function(s) ((s)->function) | |
2889 #define symbol_plist(s) ((s)->plist) | |
2890 | |
793 | 2891 #define XSYMBOL_NEXT(s) (XSYMBOL (s)->next) |
2892 #define XSYMBOL_NAME(s) (XSYMBOL (s)->name) | |
2893 #define XSYMBOL_VALUE(s) (XSYMBOL (s)->value) | |
2894 #define XSYMBOL_FUNCTION(s) (XSYMBOL (s)->function) | |
2895 #define XSYMBOL_PLIST(s) (XSYMBOL (s)->plist) | |
2896 | |
2897 | |
442 | 2898 /*------------------------------- subr ---------------------------------*/ |
428 | 2899 |
853 | 2900 /* A function that takes no arguments and returns a Lisp_Object. |
2901 We could define such types for n arguments, if needed. */ | |
428 | 2902 typedef Lisp_Object (*lisp_fn_t) (void); |
2903 | |
2904 struct Lisp_Subr | |
2905 { | |
2906 struct lrecord_header lheader; | |
442 | 2907 short min_args; |
2908 short max_args; | |
3379 | 2909 /* #### We should make these const Ascbyte * or const Ibyte *, not const |
2910 char *. */ | |
442 | 2911 const char *prompt; |
2912 const char *doc; | |
2913 const char *name; | |
428 | 2914 lisp_fn_t subr_fn; |
2915 }; | |
2916 typedef struct Lisp_Subr Lisp_Subr; | |
2917 | |
2918 DECLARE_LRECORD (subr, Lisp_Subr); | |
2919 #define XSUBR(x) XRECORD (x, subr, Lisp_Subr) | |
617 | 2920 #define wrap_subr(p) wrap_record (p, subr) |
428 | 2921 #define SUBRP(x) RECORDP (x, subr) |
2922 #define CHECK_SUBR(x) CHECK_RECORD (x, subr) | |
2923 #define CONCHECK_SUBR(x) CONCHECK_RECORD (x, subr) | |
2924 | |
436 | 2925 #define subr_function(subr) ((subr)->subr_fn) |
2926 #define SUBR_FUNCTION(subr,max_args) \ | |
2927 ((Lisp_Object (*) (EXFUN_##max_args)) (subr)->subr_fn) | |
2928 #define subr_name(subr) ((subr)->name) | |
428 | 2929 |
442 | 2930 /*------------------------------ marker --------------------------------*/ |
2931 | |
428 | 2932 |
440 | 2933 typedef struct Lisp_Marker Lisp_Marker; |
428 | 2934 struct Lisp_Marker |
2935 { | |
2936 struct lrecord_header lheader; | |
440 | 2937 Lisp_Marker *next; |
2938 Lisp_Marker *prev; | |
428 | 2939 struct buffer *buffer; |
665 | 2940 Membpos membpos; |
428 | 2941 char insertion_type; |
2942 }; | |
2943 | |
1632 | 2944 DECLARE_MODULE_API_LRECORD (marker, Lisp_Marker); |
428 | 2945 #define XMARKER(x) XRECORD (x, marker, Lisp_Marker) |
617 | 2946 #define wrap_marker(p) wrap_record (p, marker) |
428 | 2947 #define MARKERP(x) RECORDP (x, marker) |
2948 #define CHECK_MARKER(x) CHECK_RECORD (x, marker) | |
2949 #define CONCHECK_MARKER(x) CONCHECK_RECORD (x, marker) | |
2950 | |
2951 /* The second check was looking for GCed markers still in use */ | |
2500 | 2952 /* if (INTP (XMARKER (x)->lheader.next.v)) ABORT (); */ |
428 | 2953 |
2954 #define marker_next(m) ((m)->next) | |
2955 #define marker_prev(m) ((m)->prev) | |
2956 | |
3063 | 2957 /*-------------------basic int (no connection to char)------------------*/ |
2958 | |
2959 #define ZEROP(x) EQ (x, Qzero) | |
428 | 2960 |
800 | 2961 #ifdef ERROR_CHECK_TYPES |
428 | 2962 |
3063 | 2963 #define XINT(x) XINT_1 (x, __FILE__, __LINE__) |
2964 | |
2965 DECLARE_INLINE_HEADER ( | |
2966 EMACS_INT | |
2967 XINT_1 (Lisp_Object obj, const Ascbyte *file, int line) | |
2968 ) | |
2969 { | |
2970 assert_at_line (INTP (obj), file, line); | |
2971 return XREALINT (obj); | |
2972 } | |
2973 | |
2974 #else /* no error checking */ | |
2975 | |
2976 #define XINT(obj) XREALINT (obj) | |
2977 | |
2978 #endif /* no error checking */ | |
2979 | |
2980 #define CHECK_INT(x) do { \ | |
2981 if (!INTP (x)) \ | |
2982 dead_wrong_type_argument (Qintegerp, x); \ | |
2983 } while (0) | |
2984 | |
2985 #define CONCHECK_INT(x) do { \ | |
2986 if (!INTP (x)) \ | |
2987 x = wrong_type_argument (Qintegerp, x); \ | |
2988 } while (0) | |
2989 | |
2990 #define NATNUMP(x) (INTP (x) && XINT (x) >= 0) | |
2991 | |
2992 #define CHECK_NATNUM(x) do { \ | |
2993 if (!NATNUMP (x)) \ | |
2994 dead_wrong_type_argument (Qnatnump, x); \ | |
2995 } while (0) | |
2996 | |
2997 #define CONCHECK_NATNUM(x) do { \ | |
2998 if (!NATNUMP (x)) \ | |
2999 x = wrong_type_argument (Qnatnump, x); \ | |
3000 } while (0) | |
3001 | |
3002 /*------------------------------- char ---------------------------------*/ | |
3003 | |
3004 /* NOTE: There are basic functions for converting between a character and | |
3005 the string representation of a character in text.h, as well as lots of | |
3006 other character-related stuff. There are other functions/macros for | |
3007 working with Ichars in charset.h, for retrieving the charset of an | |
3008 Ichar, the length of an Ichar when converted to text, etc. | |
3009 */ | |
3010 | |
3011 #ifdef MULE | |
3012 | |
3013 MODULE_API int non_ascii_valid_ichar_p (Ichar ch); | |
3014 | |
3015 /* Return whether the given Ichar is valid. | |
3016 */ | |
3017 | |
3018 DECLARE_INLINE_HEADER ( | |
3019 int | |
3020 valid_ichar_p (Ichar ch) | |
3021 ) | |
3022 { | |
3023 return (! (ch & ~0xFF)) || non_ascii_valid_ichar_p (ch); | |
3024 } | |
3025 | |
3026 #else /* not MULE */ | |
3027 | |
3028 /* This works when CH is negative, and correctly returns non-zero only when CH | |
3029 is in the range [0, 255], inclusive. */ | |
3030 #define valid_ichar_p(ch) (! (ch & ~0xFF)) | |
3031 | |
3032 #endif /* not MULE */ | |
3033 | |
3034 #ifdef ERROR_CHECK_TYPES | |
3035 | |
3036 DECLARE_INLINE_HEADER ( | |
3037 int | |
3038 CHARP_1 (Lisp_Object obj, const Ascbyte *file, int line) | |
3039 ) | |
3040 { | |
3041 if (XTYPE (obj) != Lisp_Type_Char) | |
3042 return 0; | |
3043 assert_at_line (valid_ichar_p (XCHARVAL (obj)), file, line); | |
3044 return 1; | |
3045 } | |
3046 | |
3047 #define CHARP(x) CHARP_1 (x, __FILE__, __LINE__) | |
3048 | |
826 | 3049 DECLARE_INLINE_HEADER ( |
867 | 3050 Ichar |
2367 | 3051 XCHAR_1 (Lisp_Object obj, const Ascbyte *file, int line) |
826 | 3052 ) |
428 | 3053 { |
3063 | 3054 Ichar ch; |
788 | 3055 assert_at_line (CHARP (obj), file, line); |
3063 | 3056 ch = XCHARVAL (obj); |
3057 assert_at_line (valid_ichar_p (ch), file, line); | |
3058 return ch; | |
428 | 3059 } |
3060 | |
788 | 3061 #define XCHAR(x) XCHAR_1 (x, __FILE__, __LINE__) |
3062 | |
3063 | 3063 #else /* not ERROR_CHECK_TYPES */ |
3064 | |
3065 #define CHARP(x) (XTYPE (x) == Lisp_Type_Char) | |
3066 #define XCHAR(x) ((Ichar) XCHARVAL (x)) | |
3067 | |
3068 #endif /* (else) not ERROR_CHECK_TYPES */ | |
3069 | |
3070 #define CONCHECK_CHAR(x) do { \ | |
3071 if (!CHARP (x)) \ | |
3072 x = wrong_type_argument (Qcharacterp, x); \ | |
3073 } while (0) | |
3074 | |
3075 #define CHECK_CHAR(x) do { \ | |
3076 if (!CHARP (x)) \ | |
3077 dead_wrong_type_argument (Qcharacterp, x); \ | |
3078 } while (0) | |
3079 | |
3080 | |
3081 DECLARE_INLINE_HEADER ( | |
3082 Lisp_Object | |
3083 make_char (Ichar val) | |
3084 ) | |
3085 { | |
3086 type_checking_assert (valid_ichar_p (val)); | |
3087 /* This is defined in lisp-union.h or lisp-disunion.h */ | |
3088 return make_char_1 (val); | |
3089 } | |
3090 | |
3091 /*------------------------- int-char connection ------------------------*/ | |
3092 | |
3093 #ifdef ERROR_CHECK_TYPES | |
3094 | |
3095 #define XCHAR_OR_INT(x) XCHAR_OR_INT_1 (x, __FILE__, __LINE__) | |
3096 | |
3097 DECLARE_INLINE_HEADER ( | |
3098 EMACS_INT | |
3099 XCHAR_OR_INT_1 (Lisp_Object obj, const Ascbyte *file, int line) | |
3100 ) | |
3101 { | |
3102 assert_at_line (INTP (obj) || CHARP (obj), file, line); | |
3103 return CHARP (obj) ? XCHAR (obj) : XINT (obj); | |
3104 } | |
3105 | |
788 | 3106 #else /* no error checking */ |
3107 | |
4134 | 3108 /* obj is multiply eval'ed and not an lvalue; use an inline function instead |
3109 of a macro. */ | |
3110 DECLARE_INLINE_HEADER ( | |
3111 EMACS_INT | |
3112 XCHAR_OR_INT (Lisp_Object obj) | |
3113 ) | |
3114 { | |
3115 return CHARP (obj) ? XCHAR (obj) : XINT (obj); | |
3116 } | |
788 | 3117 |
3118 #endif /* no error checking */ | |
428 | 3119 |
3063 | 3120 /* True of X is an integer whose value is the valid integral equivalent of a |
3121 character. */ | |
3122 | |
3123 #define CHAR_INTP(x) (INTP (x) && valid_ichar_p (XINT (x))) | |
3124 | |
3125 /* True of X is a character or an integral value that can be converted into a | |
3126 character. */ | |
3127 #define CHAR_OR_CHAR_INTP(x) (CHARP (x) || CHAR_INTP (x)) | |
3128 | |
3129 DECLARE_INLINE_HEADER ( | |
3130 Ichar | |
3131 XCHAR_OR_CHAR_INT (Lisp_Object obj) | |
3132 ) | |
3133 { | |
3134 return CHARP (obj) ? XCHAR (obj) : XINT (obj); | |
3135 } | |
3136 | |
3137 /* Signal an error if CH is not a valid character or integer Lisp_Object. | |
3138 If CH is an integer Lisp_Object, convert it to a character Lisp_Object, | |
3139 but merely by repackaging, without performing tests for char validity. | |
3140 */ | |
3141 | |
3142 #define CHECK_CHAR_COERCE_INT(x) do { \ | |
3143 if (CHARP (x)) \ | |
3144 ; \ | |
3145 else if (CHAR_INTP (x)) \ | |
3146 x = make_char (XINT (x)); \ | |
3147 else \ | |
3148 x = wrong_type_argument (Qcharacterp, x); \ | |
3149 } while (0) | |
3150 | |
3151 /* next three always continuable because they coerce their arguments. */ | |
3152 #define CHECK_INT_COERCE_CHAR(x) do { \ | |
3153 if (INTP (x)) \ | |
3154 ; \ | |
3155 else if (CHARP (x)) \ | |
3156 x = make_int (XCHAR (x)); \ | |
3157 else \ | |
3158 x = wrong_type_argument (Qinteger_or_char_p, x); \ | |
3159 } while (0) | |
3160 | |
3161 #define CHECK_INT_COERCE_MARKER(x) do { \ | |
3162 if (INTP (x)) \ | |
3163 ; \ | |
3164 else if (MARKERP (x)) \ | |
3165 x = make_int (marker_position (x)); \ | |
3166 else \ | |
3167 x = wrong_type_argument (Qinteger_or_marker_p, x); \ | |
3168 } while (0) | |
3169 | |
3170 #define CHECK_INT_COERCE_CHAR_OR_MARKER(x) do { \ | |
3171 if (INTP (x)) \ | |
3172 ; \ | |
3173 else if (CHARP (x)) \ | |
3174 x = make_int (XCHAR (x)); \ | |
3175 else if (MARKERP (x)) \ | |
3176 x = make_int (marker_position (x)); \ | |
3177 else \ | |
3178 x = wrong_type_argument (Qinteger_char_or_marker_p, x); \ | |
3179 } while (0) | |
428 | 3180 |
442 | 3181 /*------------------------------ float ---------------------------------*/ |
428 | 3182 |
3183 /* Note: the 'unused_next_' field exists only to ensure that the | |
3184 `next' pointer fits within the structure, for the purposes of the | |
3185 free list. This makes a difference in the unlikely case of | |
3186 sizeof(double) being smaller than sizeof(void *). */ | |
3187 | |
3188 struct Lisp_Float | |
3189 { | |
3190 struct lrecord_header lheader; | |
3191 union { double d; struct Lisp_Float *unused_next_; } data; | |
3192 }; | |
3193 typedef struct Lisp_Float Lisp_Float; | |
3194 | |
3195 DECLARE_LRECORD (float, Lisp_Float); | |
3196 #define XFLOAT(x) XRECORD (x, float, Lisp_Float) | |
617 | 3197 #define wrap_float(p) wrap_record (p, float) |
428 | 3198 #define FLOATP(x) RECORDP (x, float) |
3199 #define CHECK_FLOAT(x) CHECK_RECORD (x, float) | |
3200 #define CONCHECK_FLOAT(x) CONCHECK_RECORD (x, float) | |
3201 | |
3202 #define float_data(f) ((f)->data.d) | |
3203 #define XFLOAT_DATA(x) float_data (XFLOAT (x)) | |
3204 | |
3205 #define XFLOATINT(n) extract_float (n) | |
3206 | |
3207 #define CHECK_INT_OR_FLOAT(x) do { \ | |
3208 if (!INT_OR_FLOATP (x)) \ | |
3209 dead_wrong_type_argument (Qnumberp, x); \ | |
3210 } while (0) | |
3211 | |
3212 #define CONCHECK_INT_OR_FLOAT(x) do { \ | |
3213 if (!INT_OR_FLOATP (x)) \ | |
3214 x = wrong_type_argument (Qnumberp, x); \ | |
3215 } while (0) | |
3216 | |
3217 # define INT_OR_FLOATP(x) (INTP (x) || FLOATP (x)) | |
3218 | |
442 | 3219 /*--------------------------- readonly objects -------------------------*/ |
440 | 3220 |
3263 | 3221 #ifndef NEW_GC |
428 | 3222 #define CHECK_C_WRITEABLE(obj) \ |
3223 do { if (c_readonly (obj)) c_write_error (obj); } while (0) | |
3224 | |
2720 | 3225 #define C_READONLY(obj) (C_READONLY_RECORD_HEADER_P(XRECORD_LHEADER (obj))) |
3263 | 3226 #endif /* not NEW_GC */ |
2720 | 3227 |
428 | 3228 #define CHECK_LISP_WRITEABLE(obj) \ |
3229 do { if (lisp_readonly (obj)) lisp_write_error (obj); } while (0) | |
3230 | |
3231 #define LISP_READONLY(obj) (LISP_READONLY_RECORD_HEADER_P(XRECORD_LHEADER (obj))) | |
3232 | |
980 | 3233 /*----------------------------- structures ----------------------------*/ |
428 | 3234 |
3235 typedef struct structure_keyword_entry structure_keyword_entry; | |
3236 struct structure_keyword_entry | |
3237 { | |
3238 Lisp_Object keyword; | |
3239 int (*validate) (Lisp_Object keyword, Lisp_Object value, | |
578 | 3240 Error_Behavior errb); |
428 | 3241 }; |
3242 | |
3243 typedef struct | |
3244 { | |
3245 Dynarr_declare (structure_keyword_entry); | |
3246 } structure_keyword_entry_dynarr; | |
3247 | |
3248 typedef struct structure_type structure_type; | |
3249 struct structure_type | |
3250 { | |
3251 Lisp_Object type; | |
3252 structure_keyword_entry_dynarr *keywords; | |
578 | 3253 int (*validate) (Lisp_Object data, Error_Behavior errb); |
428 | 3254 Lisp_Object (*instantiate) (Lisp_Object data); |
3255 }; | |
3256 | |
3257 typedef struct | |
3258 { | |
3259 Dynarr_declare (structure_type); | |
3260 } structure_type_dynarr; | |
3261 | |
3262 struct structure_type *define_structure_type (Lisp_Object type, | |
3263 int (*validate) | |
3264 (Lisp_Object data, | |
578 | 3265 Error_Behavior errb), |
428 | 3266 Lisp_Object (*instantiate) |
3267 (Lisp_Object data)); | |
3268 void define_structure_type_keyword (struct structure_type *st, | |
3269 Lisp_Object keyword, | |
3270 int (*validate) (Lisp_Object keyword, | |
3271 Lisp_Object value, | |
578 | 3272 Error_Behavior errb)); |
428 | 3273 |
858 | 3274 /*---------------------------- weak boxes ------------------------------*/ |
3275 | |
3276 struct weak_box | |
3277 { | |
3017 | 3278 struct LCRECORD_HEADER header; |
858 | 3279 Lisp_Object value; |
3280 | |
3281 Lisp_Object next_weak_box; /* don't mark through this! */ | |
3282 }; | |
3283 | |
3284 void prune_weak_boxes (void); | |
3285 Lisp_Object make_weak_box (Lisp_Object value); | |
3286 Lisp_Object weak_box_ref (Lisp_Object value); | |
3287 | |
3288 DECLARE_LRECORD (weak_box, struct weak_box); | |
3289 #define XWEAK_BOX(x) XRECORD (x, weak_box, struct weak_box) | |
3290 #define XSET_WEAK_BOX(x, v) (XWEAK_BOX (x)->value = (v)) | |
3291 #define wrap_weak_box(p) wrap_record (p, weak_box) | |
3292 #define WEAK_BOXP(x) RECORDP (x, weak_box) | |
3293 #define CHECK_WEAK_BOX(x) CHECK_RECORD (x, weak_box) | |
3294 #define CONCHECK_WEAK_BOX(x) CONCHECK_RECORD (x, weak_box) | |
3295 | |
888 | 3296 /*--------------------------- ephemerons ----------------------------*/ |
3297 | |
3298 struct ephemeron | |
3299 { | |
3017 | 3300 struct LCRECORD_HEADER header; |
888 | 3301 |
3302 Lisp_Object key; | |
3303 | |
3304 /* This field holds a pair. The cdr of this cons points to the next | |
3305 ephemeron in Vall_ephemerons. The car points to another pair | |
3306 whose car is the value and whose cdr is the finalizer. | |
3307 | |
3308 This representation makes it very easy to unlink an ephemeron | |
3309 from Vall_ephemerons and chain it into | |
3310 Vall_ephemerons_to_finalize. */ | |
3311 | |
3312 Lisp_Object cons_chain; | |
3313 | |
3314 Lisp_Object value; | |
3315 }; | |
3316 | |
3317 void prune_ephemerons (void); | |
3318 Lisp_Object ephemeron_value(Lisp_Object ephi); | |
1590 | 3319 void init_marking_ephemerons(void); |
3320 int continue_marking_ephemerons(void); | |
888 | 3321 int finish_marking_ephemerons(void); |
3322 Lisp_Object zap_finalize_list(void); | |
3323 Lisp_Object make_ephemeron(Lisp_Object key, Lisp_Object value, Lisp_Object finalizer); | |
3324 | |
3325 DECLARE_LRECORD(ephemeron, struct ephemeron); | |
3326 #define XEPHEMERON(x) XRECORD (x, ephemeron, struct ephemeron) | |
3327 #define XEPHEMERON_REF(x) (XEPHEMERON (x)->value) | |
3328 #define XEPHEMERON_NEXT(x) (XCDR (XEPHEMERON(x)->cons_chain)) | |
3329 #define XEPHEMERON_FINALIZER(x) (XCDR (XCAR (XEPHEMERON (x)->cons_chain))) | |
3330 #define XSET_EPHEMERON_NEXT(x, n) (XSETCDR (XEPHEMERON(x)->cons_chain, n)) | |
3331 #define XSET_EPHEMERON_VALUE(x, v) (XEPHEMERON(x)->value = (v)) | |
3332 #define XSET_EPHEMERON_KEY(x, k) (XEPHEMERON(x)->key = (k)) | |
3333 #define wrap_ephemeron(p) wrap_record (p, ephemeron) | |
3334 #define EPHEMERONP(x) RECORDP (x, ephemeron) | |
3335 #define CHECK_EPHEMERON(x) CHECK_RECORD (x, ephemeron) | |
3336 #define CONCHECK_EPHEMERON(x) CONCHECK_RECORD (x, ephemeron) | |
3337 | |
858 | 3338 |
442 | 3339 /*---------------------------- weak lists ------------------------------*/ |
428 | 3340 |
3341 enum weak_list_type | |
3342 { | |
3343 /* element disappears if it's unmarked. */ | |
3344 WEAK_LIST_SIMPLE, | |
3345 /* element disappears if it's a cons and either its car or | |
3346 cdr is unmarked. */ | |
3347 WEAK_LIST_ASSOC, | |
3348 /* element disappears if it's a cons and its car is unmarked. */ | |
3349 WEAK_LIST_KEY_ASSOC, | |
3350 /* element disappears if it's a cons and its cdr is unmarked. */ | |
442 | 3351 WEAK_LIST_VALUE_ASSOC, |
3352 /* element disappears if it's a cons and neither its car nor | |
3353 its cdr is marked. */ | |
3354 WEAK_LIST_FULL_ASSOC | |
428 | 3355 }; |
3356 | |
3357 struct weak_list | |
3358 { | |
3017 | 3359 struct LCRECORD_HEADER header; |
428 | 3360 Lisp_Object list; /* don't mark through this! */ |
3361 enum weak_list_type type; | |
3362 Lisp_Object next_weak; /* don't mark through this! */ | |
3363 }; | |
3364 | |
3365 DECLARE_LRECORD (weak_list, struct weak_list); | |
3366 #define XWEAK_LIST(x) XRECORD (x, weak_list, struct weak_list) | |
617 | 3367 #define wrap_weak_list(p) wrap_record (p, weak_list) |
428 | 3368 #define WEAK_LISTP(x) RECORDP (x, weak_list) |
3369 #define CHECK_WEAK_LIST(x) CHECK_RECORD (x, weak_list) | |
3370 #define CONCHECK_WEAK_LIST(x) CONCHECK_RECORD (x, weak_list) | |
3371 | |
3372 #define weak_list_list(w) ((w)->list) | |
3373 #define XWEAK_LIST_LIST(w) (XWEAK_LIST (w)->list) | |
3374 | |
3375 Lisp_Object make_weak_list (enum weak_list_type type); | |
3376 /* The following two are only called by the garbage collector */ | |
3377 int finish_marking_weak_lists (void); | |
3378 void prune_weak_lists (void); | |
3379 | |
1743 | 3380 END_C_DECLS |
428 | 3381 |
3382 /************************************************************************/ | |
771 | 3383 /* Definitions related to the format of text and of characters */ |
3384 /************************************************************************/ | |
3385 | |
3386 /* Note: | |
3387 | |
3388 "internally formatted text" and the term "internal format" in | |
3389 general are likely to refer to the format of text in buffers and | |
3390 strings; "externally formatted text" and the term "external format" | |
3391 refer to any text format used in the O.S. or elsewhere outside of | |
3392 XEmacs. The format of text and of a character are related and | |
3393 there must be a one-to-one relationship (hopefully through a | |
3394 relatively simple algorithmic means of conversion) between a string | |
3395 of text and an equivalent array of characters, but the conversion | |
3396 between the two is NOT necessarily trivial. | |
3397 | |
3398 In a non-Mule XEmacs, allowed characters are numbered 0 through | |
3399 255, where no fixed meaning is assigned to them, but (when | |
3400 representing text, rather than bytes in a binary file) in practice | |
3401 the lower half represents ASCII and the upper half some other 8-bit | |
3402 character set (chosen by setting the font, case tables, syntax | |
3403 tables, etc. appropriately for the character set through ad-hoc | |
3404 means such as the `iso-8859-1' file and the | |
3405 `standard-display-european' function). | |
3406 | |
3407 #### Finish this. | |
3408 | |
3409 */ | |
3410 #include "text.h" | |
3411 | |
3412 | |
3413 /************************************************************************/ | |
428 | 3414 /* Definitions of primitive Lisp functions and variables */ |
3415 /************************************************************************/ | |
3416 | |
3417 | |
3418 /* DEFUN - Define a built-in Lisp-visible C function or `subr'. | |
3419 `lname' should be the name to give the function in Lisp, | |
3420 as a null-terminated C string. | |
3421 `Fname' should be the C equivalent of `lname', using only characters | |
3422 valid in a C identifier, with an "F" prepended. | |
3423 The name of the C constant structure that records information | |
3424 on this function for internal use is "S" concatenated with Fname. | |
3425 `min_args' should be a number, the minimum number of arguments allowed. | |
3426 `max_args' should be a number, the maximum number of arguments allowed, | |
3427 or else MANY or UNEVALLED. | |
3428 MANY means pass a vector of evaluated arguments, | |
3429 in the form of an integer number-of-arguments | |
3430 followed by the address of a vector of Lisp_Objects | |
3431 which contains the argument values. | |
3432 UNEVALLED means pass the list of unevaluated arguments. | |
3433 `prompt' says how to read arguments for an interactive call. | |
3434 See the doc string for `interactive'. | |
3435 A null string means call interactively with no arguments. | |
3436 `arglist' are the comma-separated arguments (always Lisp_Objects) for | |
3437 the function. | |
3438 The docstring for the function is placed as a "C" comment between | |
3439 the prompt and the `args' argument. make-docfile reads the | |
3440 comment and creates the DOC file from it. | |
3441 */ | |
3442 | |
3443 #define EXFUN_0 void | |
3444 #define EXFUN_1 Lisp_Object | |
3445 #define EXFUN_2 Lisp_Object,Lisp_Object | |
3446 #define EXFUN_3 Lisp_Object,Lisp_Object,Lisp_Object | |
3447 #define EXFUN_4 Lisp_Object,Lisp_Object,Lisp_Object,Lisp_Object | |
3448 #define EXFUN_5 Lisp_Object,Lisp_Object,Lisp_Object,Lisp_Object,Lisp_Object | |
3449 #define EXFUN_6 Lisp_Object,Lisp_Object,Lisp_Object,Lisp_Object,Lisp_Object, \ | |
3450 Lisp_Object | |
3451 #define EXFUN_7 Lisp_Object,Lisp_Object,Lisp_Object,Lisp_Object,Lisp_Object, \ | |
3452 Lisp_Object,Lisp_Object | |
3453 #define EXFUN_8 Lisp_Object,Lisp_Object,Lisp_Object,Lisp_Object,Lisp_Object, \ | |
3454 Lisp_Object,Lisp_Object,Lisp_Object | |
3455 #define EXFUN_MANY int, Lisp_Object* | |
3456 #define EXFUN_UNEVALLED Lisp_Object | |
3457 #define EXFUN(sym, max_args) Lisp_Object sym (EXFUN_##max_args) | |
2268 | 3458 #define EXFUN_NORETURN(sym, max_args) \ |
3459 DECLARE_DOESNT_RETURN_TYPE (Lisp_Object, sym (EXFUN_##max_args)) | |
428 | 3460 |
3461 #define SUBR_MAX_ARGS 8 | |
3462 #define MANY -2 | |
3463 #define UNEVALLED -1 | |
3464 | |
3465 /* Can't be const, because then subr->doc is read-only and | |
3466 Snarf_documentation chokes */ | |
3467 | |
3263 | 3468 #ifdef NEW_GC |
2720 | 3469 #define DEFUN(lname, Fname, min_args, max_args, prompt, arglist) \ |
3470 Lisp_Object Fname (EXFUN_##max_args); \ | |
3471 static struct Lisp_Subr MC_ALLOC_S##Fname = \ | |
3472 { \ | |
3473 { /* struct lrecord_header */ \ | |
3474 lrecord_type_subr, /* lrecord_type_index */ \ | |
3475 1, /* lisp_readonly bit */ \ | |
3476 0, /* free */ \ | |
3477 0 /* uid */ \ | |
3478 }, \ | |
3479 min_args, \ | |
3480 max_args, \ | |
3481 prompt, \ | |
3482 0, /* doc string */ \ | |
3483 lname, \ | |
3484 (lisp_fn_t) Fname \ | |
3485 }; \ | |
2814 | 3486 static struct Lisp_Subr *S##Fname; \ |
2720 | 3487 Lisp_Object Fname (DEFUN_##max_args arglist) |
3488 | |
3489 #define DEFUN_NORETURN(lname, Fname, min_args, max_args, prompt, arglist) \ | |
3490 DECLARE_DOESNT_RETURN_TYPE (Lisp_Object, Fname (EXFUN_##max_args)); \ | |
3491 static struct Lisp_Subr MC_ALLOC_S##Fname = \ | |
3492 { \ | |
3493 { /* struct lrecord_header */ \ | |
3494 lrecord_type_subr, /* lrecord_type_index */ \ | |
3495 1, /* lisp_readonly bit */ \ | |
3496 0, /* free */ \ | |
3497 0 /* uid */ \ | |
3498 }, \ | |
3499 min_args, \ | |
3500 max_args, \ | |
3501 prompt, \ | |
3502 0, /* doc string */ \ | |
3503 lname, \ | |
3504 (lisp_fn_t) Fname \ | |
3505 }; \ | |
2814 | 3506 static struct Lisp_Subr *S##Fname; \ |
2720 | 3507 DOESNT_RETURN_TYPE (Lisp_Object) Fname (DEFUN_##max_args arglist) |
2834 | 3508 #define GET_DEFUN_LISP_OBJECT(Fname) \ |
3509 wrap_subr (S##Fname); | |
3263 | 3510 #else /* not NEW_GC */ |
428 | 3511 #define DEFUN(lname, Fname, min_args, max_args, prompt, arglist) \ |
3512 Lisp_Object Fname (EXFUN_##max_args); \ | |
442 | 3513 static struct Lisp_Subr S##Fname = \ |
3514 { \ | |
3515 { /* struct lrecord_header */ \ | |
3516 lrecord_type_subr, /* lrecord_type_index */ \ | |
3517 1, /* mark bit */ \ | |
3518 1, /* c_readonly bit */ \ | |
1111 | 3519 1, /* lisp_readonly bit */ \ |
3520 0 /* unused */ \ | |
442 | 3521 }, \ |
3522 min_args, \ | |
3523 max_args, \ | |
3524 prompt, \ | |
3525 0, /* doc string */ \ | |
3526 lname, \ | |
3527 (lisp_fn_t) Fname \ | |
3528 }; \ | |
428 | 3529 Lisp_Object Fname (DEFUN_##max_args arglist) |
3530 | |
2268 | 3531 #define DEFUN_NORETURN(lname, Fname, min_args, max_args, prompt, arglist) \ |
3532 DECLARE_DOESNT_RETURN_TYPE (Lisp_Object, Fname (EXFUN_##max_args)); \ | |
3533 static struct Lisp_Subr S##Fname = \ | |
3534 { \ | |
3535 { /* struct lrecord_header */ \ | |
3536 lrecord_type_subr, /* lrecord_type_index */ \ | |
3537 1, /* mark bit */ \ | |
3538 1, /* c_readonly bit */ \ | |
3539 1, /* lisp_readonly bit */ \ | |
3540 0 /* unused */ \ | |
3541 }, \ | |
3542 min_args, \ | |
3543 max_args, \ | |
3544 prompt, \ | |
3545 0, /* doc string */ \ | |
3546 lname, \ | |
3547 (lisp_fn_t) Fname \ | |
3548 }; \ | |
3549 DOESNT_RETURN_TYPE (Lisp_Object) Fname (DEFUN_##max_args arglist) | |
2834 | 3550 #define GET_DEFUN_LISP_OBJECT(Fname) \ |
3551 wrap_subr (&S##Fname); | |
3263 | 3552 #endif /* not NEW_GC */ |
2268 | 3553 |
428 | 3554 /* Heavy ANSI C preprocessor hackery to get DEFUN to declare a |
3555 prototype that matches max_args, and add the obligatory | |
3556 `Lisp_Object' type declaration to the formal C arguments. */ | |
3557 | |
3558 #define DEFUN_MANY(named_int, named_Lisp_Object) named_int, named_Lisp_Object | |
3559 #define DEFUN_UNEVALLED(args) Lisp_Object args | |
3560 #define DEFUN_0() void | |
3561 #define DEFUN_1(a) Lisp_Object a | |
3562 #define DEFUN_2(a,b) DEFUN_1(a), Lisp_Object b | |
3563 #define DEFUN_3(a,b,c) DEFUN_2(a,b), Lisp_Object c | |
3564 #define DEFUN_4(a,b,c,d) DEFUN_3(a,b,c), Lisp_Object d | |
3565 #define DEFUN_5(a,b,c,d,e) DEFUN_4(a,b,c,d), Lisp_Object e | |
3566 #define DEFUN_6(a,b,c,d,e,f) DEFUN_5(a,b,c,d,e), Lisp_Object f | |
3567 #define DEFUN_7(a,b,c,d,e,f,g) DEFUN_6(a,b,c,d,e,f), Lisp_Object g | |
3568 #define DEFUN_8(a,b,c,d,e,f,g,h) DEFUN_7(a,b,c,d,e,f,g),Lisp_Object h | |
3569 | |
3570 /* WARNING: If you add defines here for higher values of max_args, | |
3571 make sure to also fix the clauses in PRIMITIVE_FUNCALL(), | |
3572 and change the define of SUBR_MAX_ARGS above. */ | |
3573 | |
3574 #include "symeval.h" | |
3575 | |
1743 | 3576 BEGIN_C_DECLS |
1650 | 3577 |
428 | 3578 /* `specpdl' is the special binding/unwind-protect stack. |
3579 | |
3580 Knuth says (see the Jargon File): | |
3581 At MIT, `pdl' [abbreviation for `Push Down List'] used to | |
3582 be a more common synonym for `stack'. | |
3583 Everywhere else `stack' seems to be the preferred term. | |
3584 | |
3585 specpdl_depth is the current depth of `specpdl'. | |
771 | 3586 Save this for use later as arg to `unbind_to_1'. */ |
1632 | 3587 extern MODULE_API int specpdl_depth_counter; |
428 | 3588 #define specpdl_depth() specpdl_depth_counter |
3589 | |
442 | 3590 |
3591 #define CHECK_FUNCTION(fun) do { \ | |
3592 while (NILP (Ffunctionp (fun))) \ | |
3593 signal_invalid_function_error (fun); \ | |
3594 } while (0) | |
3595 | |
428 | 3596 |
3597 /************************************************************************/ | |
3598 /* Checking for QUIT */ | |
3599 /************************************************************************/ | |
3600 | |
1123 | 3601 /* NOTE NOTE NOTE: Invoking QUIT can cause random Lisp code to be executed! |
3602 This can happen in numerous ways. For example, on many platforms, QUIT | |
3603 needs to drain the event queue to see whether there's a C-g in the works. | |
3604 A side effect of this is that, if there's a menu-press event, menu filters | |
3605 (i.e. Lisp code) will be invoked. Lisp code could also happen if there's | |
3606 an asynchronous timeout, or if the debugger is invoked as a result of | |
3607 debug-on-quit and the user returns by hitting `r', etc. etc. | |
3608 | |
3609 However, GC CANNOT HAPPEN. It is forbidden everywhere within the QUIT- | |
3610 processing code, because most callers cannot tolerate GC during QUIT | |
3611 since it's just too prevalent. */ | |
3612 | |
853 | 3613 /* The exact workings of this mechanism are described in detail in signal.c. */ |
3614 | |
428 | 3615 /* Asynchronous events set something_happened, and then are processed |
3616 within the QUIT macro. At this point, we are guaranteed to not be in | |
3617 any sensitive code. */ | |
3618 | |
1632 | 3619 extern MODULE_API volatile int something_happened; |
3620 extern MODULE_API int dont_check_for_quit; | |
3621 MODULE_API void check_what_happened (void); | |
3622 | |
3623 extern MODULE_API volatile int quit_check_signal_happened; | |
428 | 3624 extern volatile int quit_check_signal_tick_count; |
1632 | 3625 MODULE_API void check_quit (void); |
3626 | |
3627 MODULE_API void signal_quit (void); | |
428 | 3628 |
853 | 3629 int begin_dont_check_for_quit (void); |
3630 int begin_do_check_for_quit (void); | |
3631 | |
3632 /* Nonzero if the values of `quit-flag' and `inhibit-quit' indicate | |
3633 that a quit should be signalled. */ | |
771 | 3634 #define QUIT_FLAG_SAYS_SHOULD_QUIT \ |
3635 (!NILP (Vquit_flag) && \ | |
3636 (NILP (Vinhibit_quit) \ | |
3637 || (EQ (Vquit_flag, Qcritical) && !dont_check_for_quit))) | |
3638 | |
853 | 3639 /* Nonzero if ought to quit now. This is the "efficient" version, which |
3640 respects the flags set to indicate whether the full quit check should | |
3641 be done. Therefore it may be inaccurate (i.e. lagging reality), esp. | |
3642 when poll for quit is used. | |
3643 | |
3644 This is defined for code that wants to allow quitting, but needs to | |
3645 do some cleanup if that happens. (You could always register the cleanup | |
3646 code using record_unwind_protect(), but sometimes it makes more sense | |
3647 to do it using QUITP.) To use this macro, just call it at the | |
3648 appropriate time, and if its value is non-zero, do your cleanup code | |
3649 and then call QUIT. | |
3650 | |
3651 A different version (below) is used for the actual QUIT macro. */ | |
428 | 3652 #define QUITP \ |
853 | 3653 ((quit_check_signal_happened ? check_quit () : (void) 0), \ |
771 | 3654 QUIT_FLAG_SAYS_SHOULD_QUIT) |
428 | 3655 |
853 | 3656 /* This is the version actually called by QUIT. The difference |
3657 between it and QUITP is that it also has side effects in that it | |
3658 will handle anything else that has recently signalled itself | |
3659 asynchronously and wants to be handled now. Currently this | |
3660 includes executing asynchronous timeouts that may have been set | |
3661 from Lisp or from the poll-for-quit or poll-for-sigchld | |
3662 timers. (#### It seems that, to be slightly more accurate, we | |
3663 should also process poll-for-quit timers in the above version. | |
3664 However, this mechanism is inherently approximate, so it really | |
3665 doesn't matter much.) In the future, it might also include doing a | |
3666 thread context switch. Callers of QUITP generally don't except | |
1123 | 3667 random side effects to happen (#### unfortunately, random side effects |
3668 can happen anyway, e.g. through menu filters -- see comment above), | |
3669 so we have this different version. */ | |
428 | 3670 #define INTERNAL_QUITP \ |
853 | 3671 ((something_happened ? check_what_happened () : (void) 0), \ |
771 | 3672 QUIT_FLAG_SAYS_SHOULD_QUIT) |
428 | 3673 |
3674 /* Check quit-flag and quit if it is non-nil. Also do any other things | |
853 | 3675 that are triggered by asynchronous events and might want to be |
3676 handled. */ | |
428 | 3677 #define QUIT do { if (INTERNAL_QUITP) signal_quit (); } while (0) |
3678 | |
3679 | |
3680 /************************************************************************/ | |
3681 /* hashing */ | |
3682 /************************************************************************/ | |
3683 | |
3684 /* #### for a 64-bit machine, we should substitute a prime just over 2^32 */ | |
3685 #define GOOD_HASH 65599 /* prime number just over 2^16; Dragon book, p. 435 */ | |
3686 #define HASH2(a,b) (GOOD_HASH * (a) + (b)) | |
3687 #define HASH3(a,b,c) (GOOD_HASH * HASH2 (a,b) + (c)) | |
3688 #define HASH4(a,b,c,d) (GOOD_HASH * HASH3 (a,b,c) + (d)) | |
3689 #define HASH5(a,b,c,d,e) (GOOD_HASH * HASH4 (a,b,c,d) + (e)) | |
3690 #define HASH6(a,b,c,d,e,f) (GOOD_HASH * HASH5 (a,b,c,d,e) + (f)) | |
3691 #define HASH7(a,b,c,d,e,f,g) (GOOD_HASH * HASH6 (a,b,c,d,e,f) + (g)) | |
3692 #define HASH8(a,b,c,d,e,f,g,h) (GOOD_HASH * HASH7 (a,b,c,d,e,f,g) + (h)) | |
3693 #define HASH9(a,b,c,d,e,f,g,h,i) (GOOD_HASH * HASH8 (a,b,c,d,e,f,g,h) + (i)) | |
3694 | |
3695 #define LISP_HASH(obj) ((unsigned long) LISP_TO_VOID (obj)) | |
2516 | 3696 Hashcode memory_hash (const void *xv, Bytecount size); |
3697 Hashcode internal_hash (Lisp_Object obj, int depth); | |
3698 Hashcode internal_array_hash (Lisp_Object *arr, int size, int depth); | |
428 | 3699 |
3700 | |
3701 /************************************************************************/ | |
3702 /* String translation */ | |
3703 /************************************************************************/ | |
3704 | |
771 | 3705 /* When support for message translation exists, GETTEXT() translates a |
3706 string from English into the language defined by | |
3707 `current-language-environment'. This is done by looking the string | |
3708 up in a large predefined table; if no translation is found, the | |
3709 original string is returned, and the failure is possibly logged so | |
3710 that the translation can later be entered into the table. | |
3711 | |
3712 In addition to this, there is a mechanism to snarf message strings | |
3713 out of the source code so that they can be entered into the tables. | |
3714 This is what make-msgfile.lex does. | |
3715 | |
3716 Handling `format' strings is more difficult: The format string | |
3717 should get translated, but not under all circumstances. When the | |
3718 format string is a Lisp string, what should happen is that | |
3719 Fformat() should format the untranslated args[0] and return that, | |
3720 and also call Fgettext() on args[0] and, if that is different, | |
3721 format it and store it in the `string-translatable' property of the | |
3722 returned string. See Fgettext(). | |
3723 | |
3724 CGETTEXT() is the same as GETTEXT() but works with char * strings | |
867 | 3725 instead of Ibyte * strings. |
771 | 3726 |
3727 build_msg_string() is a shorthand for build_string (GETTEXT (x)). | |
3728 build_msg_intstring() is a shorthand for build_intstring (GETTEXT (x)). | |
3729 */ | |
3730 | |
3731 #define GETTEXT(x) (x) | |
3732 #define CGETTEXT(x) (x) | |
3733 #define LISP_GETTEXT(x) (x) | |
428 | 3734 |
3735 /* DEFER_GETTEXT is used to identify strings which are translated when | |
3736 they are referenced instead of when they are defined. | |
3737 These include Qerror_messages and initialized arrays of strings. | |
3738 */ | |
3739 #define DEFER_GETTEXT(x) (x) | |
3740 | |
3741 | |
3742 /************************************************************************/ | |
3743 /* Garbage collection / GC-protection */ | |
3744 /************************************************************************/ | |
3745 | |
3746 /* Structure for recording stack slots that need marking */ | |
3747 | |
3748 /* This is a chain of structures, each of which points at a Lisp_Object | |
3749 variable whose value should be marked in garbage collection. | |
3750 Normally every link of the chain is an automatic variable of a function, | |
3751 and its `val' points to some argument or local variable of the function. | |
3752 On exit to the function, the chain is set back to the value it had on | |
3753 entry. This way, no link remains in the chain when the stack frame | |
3754 containing the link disappears. | |
3755 | |
3756 Every function that can call Feval must protect in this fashion all | |
3757 Lisp_Object variables whose contents will be used again. */ | |
3758 | |
1632 | 3759 extern MODULE_API struct gcpro *gcprolist; |
428 | 3760 |
1743 | 3761 END_C_DECLS |
1650 | 3762 |
1204 | 3763 /* #### Catching insufficient gcpro: |
3764 | |
3765 The C++ code below catches GCPRO without UNGCPRO or vice-versa. | |
3766 Catching cases where there's no GCPRO or UNGCPRO but should be, however, | |
3767 is much harder, but could be done: | |
3768 | |
3769 1. Lisp_Object becomes a real object. Its creator and destructor need to | |
3770 figure out whether the object is on the stack (by looking at the range | |
3771 that `this' is within), and if so, add the pointer to a list of all | |
3772 stack-based Lisp_Objects. | |
3773 | |
3774 2. The assignment method needs to do reference-counting on actual Lisp | |
3775 objects -- in particular, we need to know if there are any references | |
3776 to a Lisp object that are *NOT* from stack-based Lisp_Objects. | |
3777 | |
3778 3. When we get to a point in the code where we might garbage collect -- | |
3779 i.e. Ffuncall(), Feval(), or Fgarbage_collect() is called -- we look | |
3780 at our list of stack-based Lisp_Objects, and if there are any that | |
3781 point to Lisp objects with no non-stack references, see if there are | |
3782 any gcpros pointing to the object, and if not, set a flag indicating | |
3783 that the object is "destroyed". (Don't abort yet because the function | |
3784 might not use the object any more.) | |
3785 | |
3786 4. When we detag a pointer using XFOO(), abort if its "destroyed" flag | |
3787 is set. | |
3788 | |
3789 --ben | |
3790 */ | |
3791 | |
428 | 3792 struct gcpro |
3793 { | |
3794 struct gcpro *next; | |
771 | 3795 const Lisp_Object *var; /* Address of first protected variable */ |
428 | 3796 int nvars; /* Number of consecutive protected variables */ |
1204 | 3797 #if defined (__cplusplus) && defined (ERROR_CHECK_GC) |
3798 /* Try to catch GCPRO without UNGCPRO, or vice-versa. G++ complains (at | |
3799 least with sufficient numbers of warnings enabled, i.e. -Weffc++) if a | |
3800 copy constructor or assignment operator is not defined. */ | |
3801 gcpro () : next (0), var (0), nvars (0) { } | |
3802 gcpro (const gcpro& g) : next (g.next), var (g.var), nvars (g.nvars) { } | |
3803 gcpro& operator= (const gcpro& g) { next = g.next; var = g.var; | |
3804 nvars = g.nvars; | |
3805 return *this;} | |
3806 ~gcpro () { assert (!next); } | |
3807 #endif /* defined (__cplusplus) && defined (ERROR_CHECK_GC) */ | |
428 | 3808 }; |
3809 | |
3810 /* Normally, you declare variables gcpro1, gcpro2, ... and use the | |
3811 GCPROn() macros. However, if you need to have nested gcpro's, | |
3812 declare ngcpro1, ngcpro2, ... and use NGCPROn(). If you need | |
3813 to nest another level, use nngcpro1, nngcpro2, ... and use | |
3814 NNGCPROn(). If you need to nest yet another level, create | |
3815 the appropriate macros. */ | |
3816 | |
1123 | 3817 /* NOTE: About comments like "This function does not GC": These are there to |
3818 try to track whether GCPROing is necessary. Strictly speaking, some | |
3819 functions that say this might actually GC, but only when it is never | |
3820 possible to return (more specifically, in the process of signalling an | |
3821 error, the debugger may be invoked, and could GC). For GCPRO purposes, | |
3822 you only have to worry about functions that can GC and then return. | |
3823 The QUIT macro cannot GC any more, although this wasn't true at some point, | |
3824 and so some "This function can GC" comments may be inaccurate. | |
3825 */ | |
3826 | |
1743 | 3827 BEGIN_C_DECLS |
1650 | 3828 |
2367 | 3829 #define XGCDECL1(x) struct gcpro x##cpro1 |
3830 #define XGCDECL2(x) struct gcpro x##cpro1, x##cpro2 | |
3831 #define XGCDECL3(x) struct gcpro x##cpro1, x##cpro2, x##cpro3 | |
3832 #define XGCDECL4(x) struct gcpro x##cpro1, x##cpro2, x##cpro3, x##cpro4 | |
3833 #define XGCDECL5(x) struct gcpro x##cpro1, x##cpro2, x##cpro3, x##cpro4, x##cpro5 | |
3834 | |
428 | 3835 #ifdef DEBUG_GCPRO |
3836 | |
2367 | 3837 MODULE_API void debug_gcpro1 (Ascbyte *, int, struct gcpro *, Lisp_Object *); |
3838 MODULE_API void debug_gcpro2 (Ascbyte *, int, struct gcpro *, struct gcpro *, | |
1632 | 3839 Lisp_Object *, Lisp_Object *); |
2367 | 3840 MODULE_API void debug_gcpro3 (Ascbyte *, int, struct gcpro *, struct gcpro *, |
1632 | 3841 struct gcpro *, Lisp_Object *, Lisp_Object *, |
3842 Lisp_Object *); | |
2367 | 3843 MODULE_API void debug_gcpro4 (Ascbyte *, int, struct gcpro *, struct gcpro *, |
1632 | 3844 struct gcpro *, struct gcpro *, Lisp_Object *, |
3845 Lisp_Object *, Lisp_Object *, Lisp_Object *); | |
2367 | 3846 MODULE_API void debug_gcpro5 (Ascbyte *, int, struct gcpro *, struct gcpro *, |
1632 | 3847 struct gcpro *, struct gcpro *, struct gcpro *, |
3848 Lisp_Object *, Lisp_Object *, Lisp_Object *, | |
3849 Lisp_Object *, Lisp_Object *); | |
2367 | 3850 MODULE_API void debug_ungcpro(Ascbyte *, int, struct gcpro *); |
3851 | |
3852 #define XGCPRO1(x,v) \ | |
3853 debug_gcpro1 (__FILE__, __LINE__,&x##cpro1,&v) | |
3854 #define XGCPRO2(x,v1,v2) \ | |
3855 debug_gcpro2 (__FILE__, __LINE__,&x##cpro1,&x##cpro2,&v1,&v2) | |
3856 #define XGCPRO3(x,v1,v2,v3) \ | |
3857 debug_gcpro3 (__FILE__, __LINE__,&x##cpro1,&x##cpro2,&x##cpro3, \ | |
3858 &v1,&v2,&v3) | |
3859 #define XGCPRO4(x,v1,v2,v3,v4) \ | |
3860 debug_gcpro4 (__FILE__, __LINE__,&x##cpro1,&x##cpro2,&x##cpro3, \ | |
3861 &x##cpro4, \ | |
428 | 3862 &v1,&v2,&v3,&v4) |
2367 | 3863 #define XGCPRO5(x,v1,v2,v3,v4,v5) \ |
3864 debug_gcpro5 (__FILE__, __LINE__,&x##cpro1,&x##cpro2,&x##cpro3, \ | |
3865 &x##cpro4,&x##cpro5, \ | |
428 | 3866 &v1,&v2,&v3,&v4,&v5) |
2367 | 3867 #define XUNGCPRO(x) \ |
3868 debug_ungcpro(__FILE__, __LINE__,&x##cpro1) | |
428 | 3869 |
3870 #else /* ! DEBUG_GCPRO */ | |
3871 | |
2367 | 3872 #define XGCPRO1(x, var1) ((void) ( \ |
3873 x##cpro1.next = gcprolist, x##cpro1.var = &var1, x##cpro1.nvars = 1, \ | |
3874 gcprolist = &x##cpro1 )) | |
3875 | |
3876 #define XGCPRO2(x, var1, var2) ((void) ( \ | |
3877 x##cpro1.next = gcprolist, x##cpro1.var = &var1, x##cpro1.nvars = 1, \ | |
3878 x##cpro2.next = &x##cpro1, x##cpro2.var = &var2, x##cpro2.nvars = 1, \ | |
3879 gcprolist = &x##cpro2 )) | |
3880 | |
3881 #define XGCPRO3(x, var1, var2, var3) ((void) ( \ | |
3882 x##cpro1.next = gcprolist, x##cpro1.var = &var1, x##cpro1.nvars = 1, \ | |
3883 x##cpro2.next = &x##cpro1, x##cpro2.var = &var2, x##cpro2.nvars = 1, \ | |
3884 x##cpro3.next = &x##cpro2, x##cpro3.var = &var3, x##cpro3.nvars = 1, \ | |
3885 gcprolist = &x##cpro3 )) | |
3886 | |
3887 #define XGCPRO4(x, var1, var2, var3, var4) ((void) ( \ | |
3888 x##cpro1.next = gcprolist, x##cpro1.var = &var1, x##cpro1.nvars = 1, \ | |
3889 x##cpro2.next = &x##cpro1, x##cpro2.var = &var2, x##cpro2.nvars = 1, \ | |
3890 x##cpro3.next = &x##cpro2, x##cpro3.var = &var3, x##cpro3.nvars = 1, \ | |
3891 x##cpro4.next = &x##cpro3, x##cpro4.var = &var4, x##cpro4.nvars = 1, \ | |
3892 gcprolist = &x##cpro4 )) | |
3893 | |
3894 #define XGCPRO5(x, var1, var2, var3, var4, var5) ((void) ( \ | |
3895 x##cpro1.next = gcprolist, x##cpro1.var = &var1, x##cpro1.nvars = 1, \ | |
3896 x##cpro2.next = &x##cpro1, x##cpro2.var = &var2, x##cpro2.nvars = 1, \ | |
3897 x##cpro3.next = &x##cpro2, x##cpro3.var = &var3, x##cpro3.nvars = 1, \ | |
3898 x##cpro4.next = &x##cpro3, x##cpro4.var = &var4, x##cpro4.nvars = 1, \ | |
3899 x##cpro5.next = &x##cpro4, x##cpro5.var = &var5, x##cpro5.nvars = 1, \ | |
3900 gcprolist = &x##cpro5 )) | |
3901 | |
3902 #define XGCPRO1_ARRAY(x, array, n) ((void) ( \ | |
3903 x##cpro1.next = gcprolist, x##cpro1.var = array, x##cpro1.nvars = n, \ | |
3904 gcprolist = &x##cpro1 )) | |
3905 | |
3906 #define XGCPRO2_ARRAY(x, array1, n1, array2, n2) ((void) ( \ | |
3907 x##cpro1.next = gcprolist, x##cpro1.var = array1, x##cpro1.nvars = n1, \ | |
3908 x##cpro2.next = &x##cpro1, x##cpro2.var = array2, x##cpro2.nvars = n2, \ | |
3909 gcprolist = &x##cpro2 )) | |
3910 | |
3911 #define XGCPRO3_ARRAY(x, array1, n1, array2, n2, array3, n3) ((void) ( \ | |
3912 x##cpro1.next = gcprolist, x##cpro1.var = array1, x##cpro1.nvars = n1, \ | |
3913 x##cpro2.next = &x##cpro1, x##cpro2.var = array2, x##cpro2.nvars = n2, \ | |
3914 x##cpro3.next = &x##cpro2, x##cpro3.var = array3, x##cpro3.nvars = n3, \ | |
3915 gcprolist = &x##cpro3 )) | |
853 | 3916 |
1204 | 3917 #if defined (__cplusplus) && defined (ERROR_CHECK_GC) |
3918 /* We need to reset each gcpro to avoid triggering the assert() in | |
3919 ~gcpro(). This happens in UNGCPRO and longjmp(). */ | |
3920 #define UNWIND_GCPRO_TO(val) \ | |
3921 do \ | |
3922 { \ | |
3923 struct gcpro *__gcpro_stop = (val); \ | |
3924 /* Try to catch UNGCPRO without GCPRO. We arrange for there to be a \ | |
3925 sentinel at the end of the gcprolist, so it should never be NULL. */ \ | |
3926 assert (__gcpro_stop); \ | |
3927 while (gcprolist != __gcpro_stop) \ | |
3928 { \ | |
3929 struct gcpro *__gcpro_next = gcprolist->next; \ | |
3930 gcprolist->next = 0; \ | |
3931 gcprolist = __gcpro_next; \ | |
3932 assert (gcprolist); \ | |
3933 } \ | |
3934 } while (0) | |
3935 #else | |
3936 #define UNWIND_GCPRO_TO(val) (gcprolist = (val)) | |
3937 #endif /* defined (__cplusplus) && defined (ERROR_CHECK_GC) */ | |
3938 | |
2367 | 3939 #define XUNGCPRO(x) UNWIND_GCPRO_TO (x##cpro1.next) |
428 | 3940 |
3941 #endif /* ! DEBUG_GCPRO */ | |
3942 | |
2367 | 3943 #define GCDECL1 XGCDECL1 (g) |
3944 #define GCDECL2 XGCDECL2 (g) | |
3945 #define GCDECL3 XGCDECL3 (g) | |
3946 #define GCDECL4 XGCDECL4 (g) | |
3947 #define GCDECL5 XGCDECL5 (g) | |
3948 | |
3949 #define GCPRO1(a) XGCPRO1 (g,a) | |
3950 #define GCPRO2(a,b) XGCPRO2 (g,a,b) | |
3951 #define GCPRO3(a,b,c) XGCPRO3 (g,a,b,c) | |
3952 #define GCPRO4(a,b,c,d) XGCPRO4 (g,a,b,c,d) | |
3953 #define GCPRO5(a,b,c,d,e) XGCPRO5 (g,a,b,c,d,e) | |
3954 | |
3955 #define GCPRO1_ARRAY(a1,n1) XGCPRO1_ARRAY(g,a1,n1) | |
3956 #define GCPRO2_ARRAY(a1,n1,a2,n2) XGCPRO2_ARRAY (g,a1,n1,a2,n2) | |
3957 #define GCPRO3_ARRAY(a1,n1,a2,n2,a3,n3) XGCPRO3_ARRAY (g,a1,n1,a2,n2,a3,n3) | |
3958 | |
3959 #define UNGCPRO XUNGCPRO (g) | |
3960 | |
3961 #define NGCDECL1 XGCDECL1 (ng) | |
3962 #define NGCDECL2 XGCDECL2 (ng) | |
3963 #define NGCDECL3 XGCDECL3 (ng) | |
3964 #define NGCDECL4 XGCDECL4 (ng) | |
3965 #define NGCDECL5 XGCDECL5 (ng) | |
3966 | |
3967 #define NGCPRO1(a) XGCPRO1 (ng,a) | |
3968 #define NGCPRO2(a,b) XGCPRO2 (ng,a,b) | |
3969 #define NGCPRO3(a,b,c) XGCPRO3 (ng,a,b,c) | |
3970 #define NGCPRO4(a,b,c,d) XGCPRO4 (ng,a,b,c,d) | |
3971 #define NGCPRO5(a,b,c,d,e) XGCPRO5 (ng,a,b,c,d,e) | |
3972 | |
3973 #define NGCPRO1_ARRAY(a1,n1) XGCPRO1_ARRAY(ng,a1,n1) | |
3974 #define NGCPRO2_ARRAY(a1,n1,a2,n2) XGCPRO2_ARRAY (ng,a1,n1,a2,n2) | |
3975 #define NGCPRO3_ARRAY(a1,n1,a2,n2,a3,n3) XGCPRO3_ARRAY (ng,a1,n1,a2,n2,a3,n3) | |
3976 | |
3977 #define NUNGCPRO XUNGCPRO (ng) | |
3978 | |
3979 #define NNGCDECL1 XGCDECL1 (nng) | |
3980 #define NNGCDECL2 XGCDECL2 (nng) | |
3981 #define NNGCDECL3 XGCDECL3 (nng) | |
3982 #define NNGCDECL4 XGCDECL4 (nng) | |
3983 #define NNGCDECL5 XGCDECL5 (nng) | |
3984 | |
3985 #define NNGCPRO1(a) XGCPRO1 (nng,a) | |
3986 #define NNGCPRO2(a,b) XGCPRO2 (nng,a,b) | |
3987 #define NNGCPRO3(a,b,c) XGCPRO3 (nng,a,b,c) | |
3988 #define NNGCPRO4(a,b,c,d) XGCPRO4 (nng,a,b,c,d) | |
3989 #define NNGCPRO5(a,b,c,d,e) XGCPRO5 (nng,a,b,c,d,e) | |
3990 | |
3991 #define NNGCPRO1_ARRAY(a1,n1) XGCPRO1_ARRAY(nng,a1,n1) | |
3992 #define NNGCPRO2_ARRAY(a1,n1,a2,n2) XGCPRO2_ARRAY (nng,a1,n1,a2,n2) | |
3993 #define NNGCPRO3_ARRAY(a1,n1,a2,n2,a3,n3) XGCPRO3_ARRAY (nng,a1,n1,a2,n2,a3,n3) | |
3994 | |
3995 #define NNUNGCPRO XUNGCPRO (nng) | |
3996 | |
428 | 3997 /* Evaluate expr, UNGCPRO, and then return the value of expr. */ |
3998 #define RETURN_UNGCPRO(expr) do \ | |
3999 { \ | |
4000 Lisp_Object ret_ungc_val = (expr); \ | |
4001 UNGCPRO; \ | |
4002 RETURN_SANS_WARNINGS ret_ungc_val; \ | |
4003 } while (0) | |
4004 | |
4005 /* Evaluate expr, NUNGCPRO, UNGCPRO, and then return the value of expr. */ | |
4006 #define RETURN_NUNGCPRO(expr) do \ | |
4007 { \ | |
4008 Lisp_Object ret_ungc_val = (expr); \ | |
4009 NUNGCPRO; \ | |
4010 UNGCPRO; \ | |
4011 RETURN_SANS_WARNINGS ret_ungc_val; \ | |
4012 } while (0) | |
4013 | |
4014 /* Evaluate expr, NNUNGCPRO, NUNGCPRO, UNGCPRO, and then return the | |
4015 value of expr. */ | |
4016 #define RETURN_NNUNGCPRO(expr) do \ | |
4017 { \ | |
4018 Lisp_Object ret_ungc_val = (expr); \ | |
4019 NNUNGCPRO; \ | |
4020 NUNGCPRO; \ | |
4021 UNGCPRO; \ | |
4022 RETURN_SANS_WARNINGS ret_ungc_val; \ | |
4023 } while (0) | |
4024 | |
452 | 4025 extern Lisp_Object_ptr_dynarr *staticpros; |
3092 | 4026 extern Lisp_Object_ptr_dynarr *staticpros_nodump; |
771 | 4027 #ifdef DEBUG_XEMACS |
4028 | |
4029 /* Help debug crashes gc-marking a staticpro'ed object. */ | |
4030 | |
2367 | 4031 MODULE_API void staticpro_1 (Lisp_Object *, Ascbyte *); |
4032 MODULE_API void staticpro_nodump_1 (Lisp_Object *, Ascbyte *); | |
4511
71bf2c5667ba
Fix g++ const char -> char warnings.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
3659
diff
changeset
|
4033 /* g++ 4.3 complains about the conversion of const char to char. |
71bf2c5667ba
Fix g++ const char -> char warnings.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
3659
diff
changeset
|
4034 These end up in a dynarray, so we would need to define a whole new class |
71bf2c5667ba
Fix g++ const char -> char warnings.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
3659
diff
changeset
|
4035 of dynarray just to handle the const char stuff. |
71bf2c5667ba
Fix g++ const char -> char warnings.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
3659
diff
changeset
|
4036 ####Check to see how hard this might be. */ |
71bf2c5667ba
Fix g++ const char -> char warnings.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
3659
diff
changeset
|
4037 #define staticpro(ptr) staticpro_1 (ptr, (Ascbyte *) #ptr) |
71bf2c5667ba
Fix g++ const char -> char warnings.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
3659
diff
changeset
|
4038 #define staticpro_nodump(ptr) staticpro_nodump_1 (ptr, (Ascbyte *) #ptr) |
771 | 4039 |
996 | 4040 #ifdef HAVE_SHLIB |
2367 | 4041 MODULE_API void unstaticpro_nodump_1 (Lisp_Object *, Ascbyte *); |
4511
71bf2c5667ba
Fix g++ const char -> char warnings.
Stephen J. Turnbull <stephen@xemacs.org>
parents:
3659
diff
changeset
|
4042 #define unstaticpro_nodump(ptr) unstaticpro_nodump_1 (ptr, (Ascbyte *) #ptr) |
996 | 4043 #endif |
4044 | |
771 | 4045 #else |
611 | 4046 |
428 | 4047 /* Call staticpro (&var) to protect static variable `var'. */ |
1632 | 4048 MODULE_API void staticpro (Lisp_Object *); |
428 | 4049 |
4050 /* Call staticpro_nodump (&var) to protect static variable `var'. */ | |
4051 /* var will not be saved at dump time */ | |
1632 | 4052 MODULE_API void staticpro_nodump (Lisp_Object *); |
428 | 4053 |
996 | 4054 #ifdef HAVE_SHLIB |
4055 /* Call unstaticpro_nodump (&var) to stop protecting static variable `var'. */ | |
1632 | 4056 MODULE_API void unstaticpro_nodump (Lisp_Object *); |
996 | 4057 #endif |
4058 | |
771 | 4059 #endif |
4060 | |
3263 | 4061 #ifdef NEW_GC |
2720 | 4062 extern Lisp_Object_dynarr *mcpros; |
4063 #ifdef DEBUG_XEMACS | |
4064 /* Help debug crashes gc-marking a mcpro'ed object. */ | |
4065 MODULE_API void mcpro_1 (Lisp_Object, char *); | |
4066 #define mcpro(ptr) mcpro_1 (ptr, #ptr) | |
4067 #else /* not DEBUG_XEMACS */ | |
4068 /* Call mcpro (&var) to protect mc variable `var'. */ | |
4069 MODULE_API void mcpro (Lisp_Object); | |
4070 #endif /* not DEBUG_XEMACS */ | |
3263 | 4071 #endif /* NEW_GC */ |
2720 | 4072 |
771 | 4073 void register_post_gc_action (void (*fun) (void *), void *arg); |
4074 int begin_gc_forbidden (void); | |
4075 void end_gc_forbidden (int count); | |
1957 | 4076 extern int gc_currently_forbidden; |
771 | 4077 |
1743 | 4078 END_C_DECLS |
1650 | 4079 |
771 | 4080 |
4081 /************************************************************************/ | |
4082 /* Misc definitions */ | |
4083 /************************************************************************/ | |
442 | 4084 |
4085 /************************************************************************/ | |
1983 | 4086 /* Other numeric types */ |
4087 /************************************************************************/ | |
4088 #ifdef WITH_NUMBER_TYPES | |
4089 #include "number.h" | |
1986 | 4090 #else |
4091 #define make_integer(x) make_int(x) | |
1983 | 4092 #endif |
4093 | |
4094 | |
4095 /************************************************************************/ | |
442 | 4096 /* prototypes */ |
4097 /************************************************************************/ | |
4098 | |
4099 /* NOTE: Prototypes should go HERE, not in various header files, unless | |
4100 they specifically reference a type that's not defined in lisp.h. | |
4101 (And even then, you might consider adding the type to lisp.h.) | |
4102 | |
4103 The idea is that header files typically contain the innards of objects, | |
4104 and we want to minimize the number of "dependencies" of one file on | |
4105 the specifics of such objects. Putting prototypes here minimizes the | |
4106 number of header files that need to be included -- good for a number | |
4107 of reasons. --ben */ | |
4108 | |
4109 /*--------------- prototypes for various public c functions ------------*/ | |
4110 | |
4111 /* Prototypes for all init/syms_of/vars_of initialization functions. */ | |
4112 #include "symsinit.h" | |
4113 | |
1743 | 4114 BEGIN_C_DECLS |
1650 | 4115 |
826 | 4116 /* Defined in abbrev.c */ |
1632 | 4117 MODULE_API EXFUN (Fexpand_abbrev, 0); |
826 | 4118 |
428 | 4119 /* Defined in alloc.c */ |
1632 | 4120 MODULE_API EXFUN (Fcons, 2); |
4121 MODULE_API EXFUN (Flist, MANY); | |
826 | 4122 EXFUN (Fmake_byte_code, MANY); |
1632 | 4123 MODULE_API EXFUN (Fmake_list, 2); |
4124 MODULE_API EXFUN (Fmake_string, 2); | |
4125 MODULE_API EXFUN (Fmake_symbol, 1); | |
4126 MODULE_API EXFUN (Fmake_vector, 2); | |
4127 MODULE_API EXFUN (Fvector, MANY); | |
826 | 4128 |
3263 | 4129 #ifndef NEW_GC |
428 | 4130 void release_breathing_space (void); |
3263 | 4131 #endif /* not NEW_GC */ |
428 | 4132 Lisp_Object noseeum_cons (Lisp_Object, Lisp_Object); |
1632 | 4133 MODULE_API Lisp_Object make_vector (Elemcount, Lisp_Object); |
4134 MODULE_API Lisp_Object vector1 (Lisp_Object); | |
4135 MODULE_API Lisp_Object vector2 (Lisp_Object, Lisp_Object); | |
4136 MODULE_API Lisp_Object vector3 (Lisp_Object, Lisp_Object, Lisp_Object); | |
665 | 4137 Lisp_Object make_bit_vector (Elemcount, Lisp_Object); |
4138 Lisp_Object make_bit_vector_from_byte_vector (unsigned char *, Elemcount); | |
428 | 4139 Lisp_Object noseeum_make_marker (void); |
3092 | 4140 #ifndef NEW_GC |
428 | 4141 void garbage_collect_1 (void); |
3092 | 4142 #endif /* not NEW_GC */ |
1632 | 4143 MODULE_API Lisp_Object acons (Lisp_Object, Lisp_Object, Lisp_Object); |
4144 MODULE_API Lisp_Object cons3 (Lisp_Object, Lisp_Object, Lisp_Object); | |
4145 MODULE_API Lisp_Object list1 (Lisp_Object); | |
4146 MODULE_API Lisp_Object list2 (Lisp_Object, Lisp_Object); | |
4147 MODULE_API Lisp_Object list3 (Lisp_Object, Lisp_Object, Lisp_Object); | |
4148 MODULE_API Lisp_Object list4 (Lisp_Object, Lisp_Object, Lisp_Object, | |
4149 Lisp_Object); | |
4150 MODULE_API Lisp_Object list5 (Lisp_Object, Lisp_Object, Lisp_Object, Lisp_Object, | |
4151 Lisp_Object); | |
4152 MODULE_API Lisp_Object list6 (Lisp_Object, Lisp_Object, Lisp_Object, Lisp_Object, | |
4153 Lisp_Object, Lisp_Object); | |
428 | 4154 DECLARE_DOESNT_RETURN (memory_full (void)); |
4155 void disksave_object_finalization (void); | |
4156 extern int purify_flag; | |
3092 | 4157 #ifndef NEW_GC |
428 | 4158 extern EMACS_INT gc_generation_number[1]; |
3092 | 4159 #endif /* not NEW_GC */ |
428 | 4160 int c_readonly (Lisp_Object); |
4161 int lisp_readonly (Lisp_Object); | |
1632 | 4162 MODULE_API void copy_lisp_object (Lisp_Object dst, Lisp_Object src); |
4163 MODULE_API Lisp_Object build_intstring (const Ibyte *); | |
4164 MODULE_API Lisp_Object build_string (const CIbyte *); | |
4165 MODULE_API Lisp_Object build_ext_string (const Extbyte *, Lisp_Object); | |
4166 MODULE_API Lisp_Object build_msg_intstring (const Ibyte *); | |
4167 MODULE_API Lisp_Object build_msg_string (const CIbyte *); | |
4168 MODULE_API Lisp_Object make_string (const Ibyte *, Bytecount); | |
4169 MODULE_API Lisp_Object make_ext_string (const Extbyte *, EMACS_INT, Lisp_Object); | |
771 | 4170 void init_string_ascii_begin (Lisp_Object string); |
428 | 4171 Lisp_Object make_uninit_string (Bytecount); |
1632 | 4172 MODULE_API Lisp_Object make_float (double); |
867 | 4173 Lisp_Object make_string_nocopy (const Ibyte *, Bytecount); |
853 | 4174 void free_cons (Lisp_Object); |
428 | 4175 void free_list (Lisp_Object); |
4176 void free_alist (Lisp_Object); | |
1204 | 4177 void free_marker (Lisp_Object); |
428 | 4178 int object_dead_p (Lisp_Object); |
4179 void mark_object (Lisp_Object obj); | |
3092 | 4180 #ifndef NEW_GC |
1598 | 4181 #ifdef USE_KKCC |
2645 | 4182 #ifdef DEBUG_XEMACS |
4183 void kkcc_gc_stack_push_lisp_object_1 (Lisp_Object obj, int level, int pos); | |
4184 #define kkcc_gc_stack_push_lisp_object(obj, level, pos) \ | |
4185 kkcc_gc_stack_push_lisp_object_1 (obj, level, pos) | |
4186 void kkcc_backtrace (void); | |
4187 #else | |
4188 void kkcc_gc_stack_push_lisp_object_1 (Lisp_Object obj); | |
4189 #define kkcc_gc_stack_push_lisp_object(obj, level, pos) \ | |
4190 kkcc_gc_stack_push_lisp_object_1 (obj) | |
4191 #define kkcc_backtrace() | |
4192 #endif | |
1598 | 4193 #endif /* USE_KKCC */ |
3092 | 4194 #endif /* not NEW_GC */ |
428 | 4195 int marked_p (Lisp_Object obj); |
851 | 4196 extern int funcall_allocation_flag; |
814 | 4197 extern int need_to_garbage_collect; |
1632 | 4198 extern MODULE_API int need_to_check_c_alloca; |
888 | 4199 extern int need_to_signal_post_gc; |
1333 | 4200 extern Lisp_Object Qpost_gc_hook, Qgarbage_collecting; |
851 | 4201 void recompute_funcall_allocation_flag (void); |
428 | 4202 |
4203 #ifdef MEMORY_USAGE_STATS | |
665 | 4204 Bytecount malloced_storage_size (void *, Bytecount, struct overhead_stats *); |
4205 Bytecount fixed_type_block_overhead (Bytecount); | |
428 | 4206 #endif |
1204 | 4207 |
4208 #ifdef EVENT_DATA_AS_OBJECTS | |
4209 Lisp_Object make_key_data (void); | |
4210 Lisp_Object make_button_data (void); | |
4211 Lisp_Object make_motion_data (void); | |
4212 Lisp_Object make_process_data (void); | |
4213 Lisp_Object make_timeout_data (void); | |
4214 Lisp_Object make_magic_data (void); | |
4215 Lisp_Object make_magic_eval_data (void); | |
4216 Lisp_Object make_eval_data (void); | |
4217 Lisp_Object make_misc_user_data (void); | |
4218 void free_key_data (Lisp_Object); | |
4219 void free_button_data (Lisp_Object); | |
4220 void free_motion_data (Lisp_Object); | |
4221 void free_process_data (Lisp_Object); | |
4222 void free_timeout_data (Lisp_Object); | |
4223 void free_magic_data (Lisp_Object); | |
4224 void free_magic_eval_data (Lisp_Object); | |
4225 void free_eval_data (Lisp_Object); | |
4226 void free_misc_user_data (Lisp_Object); | |
4227 #endif /* EVENT_DATA_AS_OBJECTS */ | |
934 | 4228 |
428 | 4229 /* Defined in buffer.c */ |
4230 Lisp_Object get_truename_buffer (Lisp_Object); | |
4231 void switch_to_buffer (Lisp_Object, Lisp_Object); | |
4232 extern int find_file_compare_truenames; | |
4233 extern int find_file_use_truenames; | |
867 | 4234 Ibyte *get_initial_directory (Ibyte *pathname, Bytecount size); |
771 | 4235 void set_buffer_internal (struct buffer *b); |
4236 struct buffer *decode_buffer (Lisp_Object buffer, int allow_string); | |
4237 | |
4238 void record_buffer (Lisp_Object buf); | |
4239 Lisp_Object get_buffer (Lisp_Object name, | |
4240 int error_if_deleted_or_does_not_exist); | |
4241 int map_over_sharing_buffers (struct buffer *buf, | |
4242 int (*mapfun) (struct buffer *buf, | |
4243 void *closure), | |
4244 void *closure); | |
1204 | 4245 void cleanup_buffer_undo_lists (void); |
771 | 4246 |
4247 extern struct buffer *current_buffer; | |
4248 | |
4249 extern void init_initial_directory (void); /* initialize initial_directory */ | |
4250 | |
4251 EXFUN (Fbuffer_disable_undo, 1); | |
1632 | 4252 MODULE_API EXFUN (Fbuffer_modified_p, 1); |
4253 MODULE_API EXFUN (Fbuffer_name, 1); | |
4254 MODULE_API EXFUN (Fcurrent_buffer, 0); | |
771 | 4255 EXFUN (Ferase_buffer, 1); |
4256 EXFUN (Fget_buffer, 1); | |
4257 EXFUN (Fget_buffer_create, 1); | |
4258 EXFUN (Fget_file_buffer, 1); | |
1632 | 4259 MODULE_API EXFUN (Fkill_buffer, 1); |
771 | 4260 EXFUN (Fother_buffer, 3); |
4261 EXFUN (Frecord_buffer, 1); | |
1632 | 4262 MODULE_API EXFUN (Fset_buffer, 1); |
771 | 4263 EXFUN (Fset_buffer_modified_p, 2); |
4264 | |
4265 extern Lisp_Object QSscratch, Qafter_change_function, Qafter_change_functions; | |
4266 extern Lisp_Object Qbefore_change_function, Qbefore_change_functions; | |
4267 extern Lisp_Object Qbuffer_or_string_p, Qdefault_directory, Qfirst_change_hook; | |
4268 extern Lisp_Object Qpermanent_local, Vafter_change_function; | |
4269 extern Lisp_Object Vafter_change_functions, Vbefore_change_function; | |
4270 extern Lisp_Object Vbefore_change_functions, Vbuffer_alist, Vbuffer_defaults; | |
4271 extern Lisp_Object Vinhibit_read_only, Vtransient_mark_mode; | |
428 | 4272 |
563 | 4273 /* Defined in bytecode.c */ |
826 | 4274 EXFUN (Fbyte_code, 3); |
4275 | |
593 | 4276 DECLARE_DOESNT_RETURN (invalid_byte_code |
867 | 4277 (const CIbyte *reason, Lisp_Object frob)); |
563 | 4278 |
826 | 4279 /* Defined in callint.c */ |
4280 EXFUN (Fcall_interactively, 3); | |
4281 EXFUN (Fprefix_numeric_value, 1); | |
4282 | |
4283 /* Defined in casefiddle.c */ | |
4284 EXFUN (Fdowncase, 2); | |
4285 EXFUN (Fupcase, 2); | |
4286 EXFUN (Fupcase_initials, 2); | |
4287 EXFUN (Fupcase_initials_region, 3); | |
4288 EXFUN (Fupcase_region, 3); | |
4289 | |
4290 /* Defined in casetab.c */ | |
4291 EXFUN (Fset_standard_case_table, 1); | |
4292 | |
4293 /* Defined in chartab.c */ | |
4294 EXFUN (Freset_char_table, 1); | |
4295 | |
4296 /* Defined in cmds.c */ | |
4297 EXFUN (Fbeginning_of_line, 2); | |
4298 EXFUN (Fend_of_line, 2); | |
4299 EXFUN (Fforward_char, 2); | |
4300 EXFUN (Fforward_line, 2); | |
4301 | |
428 | 4302 /* Defined in data.c */ |
826 | 4303 EXFUN (Fadd1, 1); |
4304 EXFUN (Faref, 2); | |
4305 EXFUN (Faset, 3); | |
4306 EXFUN (Fcar, 1); | |
4307 EXFUN (Fcar_safe, 1); | |
4308 EXFUN (Fcdr, 1); | |
919 | 4309 EXFUN (Fcdr_safe, 1); |
826 | 4310 EXFUN (Fgeq, MANY); |
4311 EXFUN (Fgtr, MANY); | |
4312 EXFUN (Findirect_function, 1); | |
4313 EXFUN (Fleq, MANY); | |
4314 EXFUN (Flistp, 1); | |
4315 EXFUN (Flss, MANY); | |
4316 EXFUN (Fmax, MANY); | |
4317 EXFUN (Fmin, MANY); | |
4318 EXFUN (Fminus, MANY); | |
4319 EXFUN (Fnumber_to_string, 1); | |
4320 EXFUN (Fplus, MANY); | |
4321 EXFUN (Fquo, MANY); | |
4322 EXFUN (Frem, 2); | |
4323 EXFUN (Fsetcar, 2); | |
4324 EXFUN (Fsetcdr, 2); | |
4325 EXFUN (Fsub1, 1); | |
4326 EXFUN (Fsubr_max_args, 1); | |
4327 EXFUN (Fsubr_min_args, 1); | |
4328 EXFUN (Ftimes, MANY); | |
4329 | |
428 | 4330 DECLARE_DOESNT_RETURN (c_write_error (Lisp_Object)); |
4331 DECLARE_DOESNT_RETURN (lisp_write_error (Lisp_Object)); | |
4332 DECLARE_DOESNT_RETURN (args_out_of_range (Lisp_Object, Lisp_Object)); | |
4333 DECLARE_DOESNT_RETURN (args_out_of_range_3 (Lisp_Object, Lisp_Object, | |
4334 Lisp_Object)); | |
1632 | 4335 MODULE_API Lisp_Object wrong_type_argument (Lisp_Object, Lisp_Object); |
4336 MODULE_API | |
428 | 4337 DECLARE_DOESNT_RETURN (dead_wrong_type_argument (Lisp_Object, Lisp_Object)); |
4338 void check_int_range (EMACS_INT, EMACS_INT, EMACS_INT); | |
4339 | |
771 | 4340 EXFUN (Fint_to_char, 1); |
4341 EXFUN (Fchar_to_int, 1); | |
4342 | |
428 | 4343 enum arith_comparison { |
4344 arith_equal, | |
4345 arith_notequal, | |
4346 arith_less, | |
4347 arith_grtr, | |
4348 arith_less_or_equal, | |
4349 arith_grtr_or_equal }; | |
4350 Lisp_Object arithcompare (Lisp_Object, Lisp_Object, enum arith_comparison); | |
4351 | |
707 | 4352 /* Do NOT use word_to_lisp or wasteful_word_to_lisp to decode time_t's |
4353 unless you KNOW arg is non-negative. They cannot return negative | |
4354 values! Use make_time. */ | |
428 | 4355 Lisp_Object word_to_lisp (unsigned int); |
4356 unsigned int lisp_to_word (Lisp_Object); | |
4357 | |
4358 /* Defined in dired.c */ | |
867 | 4359 Lisp_Object make_directory_hash_table (const Ibyte *); |
428 | 4360 Lisp_Object wasteful_word_to_lisp (unsigned int); |
4361 | |
4362 /* Defined in doc.c */ | |
826 | 4363 EXFUN (Fsubstitute_command_keys, 1); |
4364 | |
814 | 4365 Lisp_Object unparesseuxify_doc_string (int fd, EMACS_INT position, |
867 | 4366 Ibyte *name_nonreloc, |
814 | 4367 Lisp_Object name_reloc, |
4368 int standard_doc_file); | |
428 | 4369 Lisp_Object read_doc_string (Lisp_Object); |
4370 | |
4371 /* Defined in doprnt.c */ | |
867 | 4372 Bytecount emacs_doprnt_va (Lisp_Object stream, const Ibyte *format_nonreloc, |
771 | 4373 Bytecount format_length, Lisp_Object format_reloc, |
4374 va_list vargs); | |
867 | 4375 Bytecount emacs_doprnt (Lisp_Object stream, const Ibyte *format_nonreloc, |
771 | 4376 Bytecount format_length, Lisp_Object format_reloc, |
4377 int nargs, const Lisp_Object *largs, ...); | |
867 | 4378 Lisp_Object emacs_vsprintf_string_lisp (const CIbyte *format_nonreloc, |
771 | 4379 Lisp_Object format_reloc, int nargs, |
4380 const Lisp_Object *largs); | |
867 | 4381 Lisp_Object emacs_sprintf_string_lisp (const CIbyte *format_nonreloc, |
771 | 4382 Lisp_Object format_reloc, int nargs, ...); |
867 | 4383 Ibyte *emacs_vsprintf_malloc_lisp (const CIbyte *format_nonreloc, |
771 | 4384 Lisp_Object format_reloc, int nargs, |
4385 const Lisp_Object *largs, | |
4386 Bytecount *len_out); | |
867 | 4387 Ibyte *emacs_sprintf_malloc_lisp (Bytecount *len_out, |
4388 const CIbyte *format_nonreloc, | |
771 | 4389 Lisp_Object format_reloc, int nargs, ...); |
867 | 4390 Lisp_Object emacs_vsprintf_string (const CIbyte *format, va_list vargs); |
4391 Lisp_Object emacs_sprintf_string (const CIbyte *format, ...) | |
771 | 4392 PRINTF_ARGS (1, 2); |
867 | 4393 Ibyte *emacs_vsprintf_malloc (const CIbyte *format, va_list vargs, |
771 | 4394 Bytecount *len_out); |
867 | 4395 Ibyte *emacs_sprintf_malloc (Bytecount *len_out, const CIbyte *format, ...) |
771 | 4396 PRINTF_ARGS (2, 3); |
867 | 4397 Bytecount emacs_vsprintf (Ibyte *output, const CIbyte *format, |
771 | 4398 va_list vargs); |
867 | 4399 Bytecount emacs_sprintf (Ibyte *output, const CIbyte *format, ...) |
771 | 4400 PRINTF_ARGS (2, 3); |
4401 | |
428 | 4402 |
4403 /* Defined in editfns.c */ | |
826 | 4404 EXFUN (Fbobp, 1); |
4405 EXFUN (Fbolp, 1); | |
4406 EXFUN (Fbuffer_substring, 3); | |
4407 EXFUN (Fchar_after, 2); | |
4408 EXFUN (Fchar_to_string, 1); | |
4409 EXFUN (Fdelete_region, 3); | |
4410 EXFUN (Feobp, 1); | |
4411 EXFUN (Feolp, 1); | |
4412 EXFUN (Ffollowing_char, 1); | |
4413 EXFUN (Fformat, MANY); | |
4414 EXFUN (Fgoto_char, 2); | |
4415 EXFUN (Finsert, MANY); | |
4416 EXFUN (Finsert_buffer_substring, 3); | |
4417 EXFUN (Finsert_char, 4); | |
4418 EXFUN (Fnarrow_to_region, 3); | |
4419 EXFUN (Fpoint, 1); | |
4420 EXFUN (Fpoint_marker, 2); | |
4421 EXFUN (Fpoint_max, 1); | |
4422 EXFUN (Fpoint_min, 1); | |
4423 EXFUN (Fpreceding_char, 1); | |
4424 EXFUN (Fsystem_name, 0); | |
4425 EXFUN (Fuser_home_directory, 0); | |
4426 EXFUN (Fuser_login_name, 1); | |
4427 EXFUN (Fwiden, 1); | |
4428 | |
428 | 4429 void uncache_home_directory (void); |
867 | 4430 Ibyte *get_home_directory (void); |
4431 Ibyte *user_login_name (uid_t *); | |
428 | 4432 void buffer_insert1 (struct buffer *, Lisp_Object); |
665 | 4433 Lisp_Object make_string_from_buffer (struct buffer *, Charbpos, Charcount); |
4434 Lisp_Object make_string_from_buffer_no_extents (struct buffer *, Charbpos, Charcount); | |
707 | 4435 Lisp_Object make_time (time_t); |
428 | 4436 Lisp_Object save_excursion_save (void); |
844 | 4437 Lisp_Object save_restriction_save (struct buffer *buf); |
428 | 4438 Lisp_Object save_excursion_restore (Lisp_Object); |
4439 Lisp_Object save_restriction_restore (Lisp_Object); | |
771 | 4440 void widen_buffer (struct buffer *b, int no_clip); |
4441 int beginning_of_line_p (struct buffer *b, Charbpos pt); | |
428 | 4442 |
4443 /* Defined in emacsfns.c */ | |
4444 Lisp_Object save_current_buffer_restore (Lisp_Object); | |
4445 | |
4446 /* Defined in emacs.c */ | |
2268 | 4447 EXFUN_NORETURN (Fkill_emacs, 1); |
826 | 4448 EXFUN (Frunning_temacs_p, 0); |
1123 | 4449 EXFUN (Fforce_debugging_signal, 1); |
826 | 4450 |
428 | 4451 SIGTYPE fatal_error_signal (int); |
2367 | 4452 Lisp_Object make_arg_list (int, Wexttext **); |
4453 void make_argc_argv (Lisp_Object, int *, Wexttext ***); | |
4454 void free_argc_argv (Wexttext **); | |
771 | 4455 Lisp_Object split_external_path (const Extbyte *path); |
867 | 4456 Lisp_Object split_env_path (const CIbyte *evarname, const Ibyte *default_); |
771 | 4457 |
428 | 4458 /* Nonzero means don't do interactive redisplay and don't change tty modes */ |
442 | 4459 extern int noninteractive, noninteractive1; |
2367 | 4460 extern int inhibit_non_essential_conversion_operations; |
428 | 4461 extern int preparing_for_armageddon; |
458 | 4462 extern Fixnum emacs_priority; |
428 | 4463 extern int suppress_early_error_handler_backtrace; |
771 | 4464 void debug_break (void); |
4465 int debug_can_access_memory (void *ptr, Bytecount len); | |
2210 | 4466 DECLARE_DOESNT_RETURN (really_abort (void)); |
776 | 4467 void zero_out_command_line_status_vars (void); |
428 | 4468 |
826 | 4469 /* Defined in emodules.c */ |
996 | 4470 #ifdef HAVE_SHLIB |
826 | 4471 EXFUN (Flist_modules, 0); |
4472 EXFUN (Fload_module, 3); | |
996 | 4473 extern int unloading_module; |
4474 #endif | |
826 | 4475 |
428 | 4476 /* Defined in eval.c */ |
1706 | 4477 MODULE_API EXFUN (Fapply, MANY); |
826 | 4478 EXFUN (Fbacktrace, 2); |
4479 EXFUN (Fcommand_execute, 3); | |
4480 EXFUN (Fcommandp, 1); | |
4744
17f7e9191c0b
Rationalise duplicated functionality, #'custom-quote, #'quote-maybe.
Aidan Kehoe <kehoea@parhasard.net>
parents:
4690
diff
changeset
|
4481 EXFUN (Fquote_maybe, 1); |
1706 | 4482 MODULE_API EXFUN (Feval, 1); |
4483 MODULE_API EXFUN (Ffuncall, MANY); | |
826 | 4484 EXFUN (Ffunctionp, 1); |
4485 EXFUN (Finteractive_p, 0); | |
4486 EXFUN (Fprogn, UNEVALLED); | |
1706 | 4487 MODULE_API EXFUN (Fsignal, 2); |
4677
8f1ee2d15784
Support full Common Lisp multiple values in C.
Aidan Kehoe <kehoea@parhasard.net>
parents:
4512
diff
changeset
|
4488 MODULE_API EXFUN_NORETURN (Fthrow, UNEVALLED); |
1706 | 4489 MODULE_API EXFUN (Fcall_with_condition_handler, MANY); |
853 | 4490 EXFUN (Ffunction_max_args, 1); |
4491 EXFUN (Ffunction_min_args, 1); | |
826 | 4492 |
4677
8f1ee2d15784
Support full Common Lisp multiple values in C.
Aidan Kehoe <kehoea@parhasard.net>
parents:
4512
diff
changeset
|
4493 MODULE_API DECLARE_DOESNT_RETURN (throw_or_bomb_out (Lisp_Object, |
8f1ee2d15784
Support full Common Lisp multiple values in C.
Aidan Kehoe <kehoea@parhasard.net>
parents:
4512
diff
changeset
|
4494 Lisp_Object, int, |
8f1ee2d15784
Support full Common Lisp multiple values in C.
Aidan Kehoe <kehoea@parhasard.net>
parents:
4512
diff
changeset
|
4495 Lisp_Object, Lisp_Object)); |
8f1ee2d15784
Support full Common Lisp multiple values in C.
Aidan Kehoe <kehoea@parhasard.net>
parents:
4512
diff
changeset
|
4496 |
1632 | 4497 MODULE_API DECLARE_DOESNT_RETURN (signal_error_1 (Lisp_Object, Lisp_Object)); |
563 | 4498 void maybe_signal_error_1 (Lisp_Object, Lisp_Object, Lisp_Object, |
578 | 4499 Error_Behavior); |
563 | 4500 Lisp_Object maybe_signal_continuable_error_1 (Lisp_Object, Lisp_Object, |
578 | 4501 Lisp_Object, Error_Behavior); |
1743 | 4502 MODULE_API DECLARE_DOESNT_RETURN (signal_ferror (Lisp_Object, const CIbyte *, |
4503 ...)) PRINTF_ARGS(2, 3); | |
578 | 4504 void maybe_signal_ferror (Lisp_Object, Lisp_Object, Error_Behavior, |
867 | 4505 const CIbyte *, ...) PRINTF_ARGS (4, 5); |
4506 Lisp_Object signal_continuable_ferror (Lisp_Object, const CIbyte *, ...) | |
442 | 4507 PRINTF_ARGS (2, 3); |
563 | 4508 Lisp_Object maybe_signal_continuable_ferror (Lisp_Object, Lisp_Object, |
578 | 4509 Error_Behavior, |
867 | 4510 const CIbyte *, ...) |
442 | 4511 PRINTF_ARGS (4, 5); |
563 | 4512 |
867 | 4513 Lisp_Object build_error_data (const CIbyte *reason, Lisp_Object frob); |
4514 DECLARE_DOESNT_RETURN (signal_error (Lisp_Object, const CIbyte *, | |
563 | 4515 Lisp_Object)); |
867 | 4516 void maybe_signal_error (Lisp_Object, const CIbyte *, Lisp_Object, |
578 | 4517 Lisp_Object, Error_Behavior); |
867 | 4518 Lisp_Object signal_continuable_error (Lisp_Object, const CIbyte *, |
563 | 4519 Lisp_Object); |
867 | 4520 Lisp_Object maybe_signal_continuable_error (Lisp_Object, const CIbyte *, |
563 | 4521 Lisp_Object, |
578 | 4522 Lisp_Object, Error_Behavior); |
1743 | 4523 DECLARE_DOESNT_RETURN (signal_ferror_with_frob (Lisp_Object, Lisp_Object, |
4524 const CIbyte *, ...)) | |
4525 PRINTF_ARGS(3, 4); | |
563 | 4526 void maybe_signal_ferror_with_frob (Lisp_Object, Lisp_Object, Lisp_Object, |
578 | 4527 Error_Behavior, |
867 | 4528 const CIbyte *, ...) PRINTF_ARGS (5, 6); |
563 | 4529 Lisp_Object signal_continuable_ferror_with_frob (Lisp_Object, Lisp_Object, |
867 | 4530 const CIbyte *, |
563 | 4531 ...) PRINTF_ARGS (3, 4); |
4532 Lisp_Object maybe_signal_continuable_ferror_with_frob (Lisp_Object, | |
4533 Lisp_Object, | |
4534 Lisp_Object, | |
578 | 4535 Error_Behavior, |
867 | 4536 const CIbyte *, ...) |
442 | 4537 PRINTF_ARGS (5, 6); |
867 | 4538 DECLARE_DOESNT_RETURN (signal_error_2 (Lisp_Object, const CIbyte *, |
563 | 4539 Lisp_Object, Lisp_Object)); |
867 | 4540 void maybe_signal_error_2 (Lisp_Object, const CIbyte *, Lisp_Object, |
578 | 4541 Lisp_Object, Lisp_Object, Error_Behavior); |
867 | 4542 Lisp_Object signal_continuable_error_2 (Lisp_Object, const CIbyte *, |
563 | 4543 Lisp_Object, Lisp_Object); |
867 | 4544 Lisp_Object maybe_signal_continuable_error_2 (Lisp_Object, const CIbyte *, |
563 | 4545 Lisp_Object, Lisp_Object, |
4546 Lisp_Object, | |
578 | 4547 Error_Behavior); |
563 | 4548 |
4549 | |
1927 | 4550 MODULE_API DECLARE_DOESNT_RETURN (signal_malformed_list_error (Lisp_Object)); |
4551 MODULE_API DECLARE_DOESNT_RETURN (signal_malformed_property_list_error | |
4552 (Lisp_Object)); | |
4553 MODULE_API DECLARE_DOESNT_RETURN (signal_circular_list_error (Lisp_Object)); | |
4554 MODULE_API DECLARE_DOESNT_RETURN (signal_circular_property_list_error | |
4555 (Lisp_Object)); | |
436 | 4556 |
867 | 4557 DECLARE_DOESNT_RETURN (syntax_error (const CIbyte *reason, |
609 | 4558 Lisp_Object frob)); |
867 | 4559 DECLARE_DOESNT_RETURN (syntax_error_2 (const CIbyte *reason, |
609 | 4560 Lisp_Object frob1, |
442 | 4561 Lisp_Object frob2)); |
867 | 4562 void maybe_syntax_error (const CIbyte *, Lisp_Object, Lisp_Object, |
578 | 4563 Error_Behavior); |
867 | 4564 DECLARE_DOESNT_RETURN (sferror (const CIbyte *reason, Lisp_Object frob)); |
4565 DECLARE_DOESNT_RETURN (sferror_2 (const CIbyte *reason, Lisp_Object frob1, | |
563 | 4566 Lisp_Object frob2)); |
867 | 4567 void maybe_sferror (const CIbyte *, Lisp_Object, Lisp_Object, |
578 | 4568 Error_Behavior); |
1632 | 4569 MODULE_API DECLARE_DOESNT_RETURN (invalid_argument (const CIbyte *reason, |
4570 Lisp_Object frob)); | |
4571 MODULE_API DECLARE_DOESNT_RETURN (invalid_argument_2 (const CIbyte *reason, | |
4572 Lisp_Object frob1, | |
4573 Lisp_Object frob2)); | |
867 | 4574 void maybe_invalid_argument (const CIbyte *, Lisp_Object, Lisp_Object, |
578 | 4575 Error_Behavior); |
1632 | 4576 MODULE_API DECLARE_DOESNT_RETURN (invalid_operation (const CIbyte *reason, |
4577 Lisp_Object frob)); | |
4578 MODULE_API DECLARE_DOESNT_RETURN (invalid_operation_2 (const CIbyte *reason, | |
4579 Lisp_Object frob1, | |
4580 Lisp_Object frob2)); | |
4581 MODULE_API void maybe_invalid_operation (const CIbyte *, Lisp_Object, | |
4582 Lisp_Object, Error_Behavior); | |
867 | 4583 DECLARE_DOESNT_RETURN (invalid_state (const CIbyte *reason, |
563 | 4584 Lisp_Object frob)); |
867 | 4585 DECLARE_DOESNT_RETURN (invalid_state_2 (const CIbyte *reason, |
563 | 4586 Lisp_Object frob1, |
4587 Lisp_Object frob2)); | |
867 | 4588 void maybe_invalid_state (const CIbyte *, Lisp_Object, Lisp_Object, |
609 | 4589 Error_Behavior); |
867 | 4590 DECLARE_DOESNT_RETURN (invalid_change (const CIbyte *reason, |
563 | 4591 Lisp_Object frob)); |
867 | 4592 DECLARE_DOESNT_RETURN (invalid_change_2 (const CIbyte *reason, |
563 | 4593 Lisp_Object frob1, |
4594 Lisp_Object frob2)); | |
867 | 4595 void maybe_invalid_change (const CIbyte *, Lisp_Object, Lisp_Object, |
609 | 4596 Error_Behavior); |
1632 | 4597 MODULE_API DECLARE_DOESNT_RETURN (invalid_constant (const CIbyte *reason, |
4598 Lisp_Object frob)); | |
867 | 4599 DECLARE_DOESNT_RETURN (invalid_constant_2 (const CIbyte *reason, |
563 | 4600 Lisp_Object frob1, |
4601 Lisp_Object frob2)); | |
867 | 4602 void maybe_invalid_constant (const CIbyte *, Lisp_Object, Lisp_Object, |
578 | 4603 Error_Behavior); |
867 | 4604 DECLARE_DOESNT_RETURN (wtaerror (const CIbyte *reason, Lisp_Object frob)); |
1632 | 4605 MODULE_API DECLARE_DOESNT_RETURN (out_of_memory (const CIbyte *reason, |
4606 Lisp_Object frob)); | |
867 | 4607 DECLARE_DOESNT_RETURN (stack_overflow (const CIbyte *reason, |
442 | 4608 Lisp_Object frob)); |
1743 | 4609 MODULE_API DECLARE_DOESNT_RETURN (printing_unreadable_object (const CIbyte *, |
4610 ...)) | |
4611 PRINTF_ARGS (1, 2); | |
442 | 4612 |
436 | 4613 Lisp_Object signal_void_function_error (Lisp_Object); |
4614 Lisp_Object signal_invalid_function_error (Lisp_Object); | |
4615 Lisp_Object signal_wrong_number_of_arguments_error (Lisp_Object, int); | |
4616 | |
428 | 4617 Lisp_Object run_hook_with_args_in_buffer (struct buffer *, int, Lisp_Object *, |
4618 enum run_hooks_condition); | |
4619 Lisp_Object run_hook_with_args (int, Lisp_Object *, enum run_hooks_condition); | |
4620 void va_run_hook_with_args (Lisp_Object, int, ...); | |
4621 void va_run_hook_with_args_in_buffer (struct buffer *, Lisp_Object, int, ...); | |
4622 Lisp_Object run_hook (Lisp_Object); | |
1706 | 4623 MODULE_API Lisp_Object apply1 (Lisp_Object, Lisp_Object); |
4624 MODULE_API Lisp_Object call0 (Lisp_Object); | |
4625 MODULE_API Lisp_Object call1 (Lisp_Object, Lisp_Object); | |
4626 MODULE_API Lisp_Object call2 (Lisp_Object, Lisp_Object, Lisp_Object); | |
4627 MODULE_API Lisp_Object call3 (Lisp_Object, Lisp_Object, Lisp_Object, | |
4628 Lisp_Object); | |
4629 MODULE_API Lisp_Object call4 (Lisp_Object, Lisp_Object, Lisp_Object, | |
4630 Lisp_Object, Lisp_Object); | |
4631 MODULE_API Lisp_Object call5 (Lisp_Object, Lisp_Object, Lisp_Object, | |
4632 Lisp_Object, Lisp_Object, Lisp_Object); | |
4633 MODULE_API Lisp_Object call6 (Lisp_Object, Lisp_Object, Lisp_Object, | |
4634 Lisp_Object, Lisp_Object, Lisp_Object, | |
4635 Lisp_Object); | |
4636 MODULE_API Lisp_Object call7 (Lisp_Object, Lisp_Object, Lisp_Object, | |
4637 Lisp_Object, Lisp_Object, Lisp_Object, | |
4638 Lisp_Object, Lisp_Object); | |
4639 MODULE_API Lisp_Object call8 (Lisp_Object, Lisp_Object, Lisp_Object, | |
4640 Lisp_Object, Lisp_Object, Lisp_Object, | |
4641 Lisp_Object, Lisp_Object, Lisp_Object); | |
428 | 4642 Lisp_Object call0_in_buffer (struct buffer *, Lisp_Object); |
4643 Lisp_Object call1_in_buffer (struct buffer *, Lisp_Object, Lisp_Object); | |
4644 Lisp_Object call2_in_buffer (struct buffer *, Lisp_Object, Lisp_Object, | |
4645 Lisp_Object); | |
4646 Lisp_Object call3_in_buffer (struct buffer *, Lisp_Object, Lisp_Object, | |
4647 Lisp_Object, Lisp_Object); | |
4648 Lisp_Object call4_in_buffer (struct buffer *, Lisp_Object, Lisp_Object, | |
4649 Lisp_Object, Lisp_Object, Lisp_Object); | |
4650 Lisp_Object call5_in_buffer (struct buffer *, Lisp_Object, Lisp_Object, | |
4651 Lisp_Object, Lisp_Object, Lisp_Object, | |
4652 Lisp_Object); | |
4653 Lisp_Object call6_in_buffer (struct buffer *, Lisp_Object, Lisp_Object, | |
4654 Lisp_Object, Lisp_Object, Lisp_Object, | |
4655 Lisp_Object, Lisp_Object); | |
4656 Lisp_Object eval_in_buffer (struct buffer *, Lisp_Object); | |
853 | 4657 |
4658 struct call_trapping_problems_result | |
4659 { | |
4660 int caught_error, caught_throw; | |
4661 Lisp_Object error_conditions, data; | |
4662 Lisp_Object backtrace; | |
4663 Lisp_Object thrown_tag; | |
4664 Lisp_Object thrown_value; | |
4665 }; | |
4666 | |
4667 #define NO_INHIBIT_ERRORS (1<<0) | |
4668 #define NO_INHIBIT_THROWS (1<<1) | |
4669 #define INTERNAL_INHIBIT_ERRORS (1<<0) | |
4670 #define INTERNAL_INHIBIT_THROWS (1<<1) | |
4671 #define INHIBIT_WARNING_ISSUE (1<<2) | |
4672 #define ISSUE_WARNINGS_AT_DEBUG_LEVEL (1<<3) | |
4673 #define INHIBIT_QUIT (1<<4) | |
4674 #define UNINHIBIT_QUIT (1<<5) | |
4675 #define INHIBIT_GC (1<<6) | |
4676 #define INHIBIT_EXISTING_PERMANENT_DISPLAY_OBJECT_DELETION (1<<7) | |
4677 #define INHIBIT_EXISTING_CODING_SYSTEM_DELETION (1<<8) | |
4678 #define INHIBIT_EXISTING_CHARSET_DELETION (1<<9) | |
4679 #define INHIBIT_PERMANENT_DISPLAY_OBJECT_CREATION (1<<10) | |
4680 #define INHIBIT_CODING_SYSTEM_CREATION (1<<11) | |
4681 #define INHIBIT_CHARSET_CREATION (1<<12) | |
4682 #define INHIBIT_EXISTING_BUFFER_TEXT_MODIFICATION (1<<13) | |
4683 #define INHIBIT_ANY_CHANGE_AFFECTING_REDISPLAY (1<<14) | |
4684 #define INHIBIT_ENTERING_DEBUGGER (1<<15) | |
4685 #define CALL_WITH_SUSPENDED_ERRORS (1<<16) | |
1333 | 4686 #define POSTPONE_WARNING_ISSUE (1<<17) |
853 | 4687 |
4688 enum check_allowed_operation | |
4689 { | |
4690 OPERATION_DELETE_OBJECT, | |
4691 OPERATION_CREATE_OBJECT, | |
4692 OPERATION_MODIFY_BUFFER_TEXT, | |
1429 | 4693 OPERATION_MODIFY_OBJECT_PROPERTY |
853 | 4694 }; |
4695 | |
4696 int get_inhibit_flags (void); | |
4697 void check_allowed_operation (int what, Lisp_Object obj, Lisp_Object prop); | |
4698 void note_object_created (Lisp_Object obj); | |
4699 void note_object_deleted (Lisp_Object obj); | |
4700 Lisp_Object call_with_condition_handler (Lisp_Object (*handler) (Lisp_Object, | |
4701 Lisp_Object, | |
4702 Lisp_Object), | |
4703 Lisp_Object handler_arg, | |
4704 Lisp_Object (*fun) (Lisp_Object), | |
4705 Lisp_Object arg); | |
1318 | 4706 int set_trapping_problems_flags (int flags); |
853 | 4707 Lisp_Object call_trapping_problems (Lisp_Object warning_class, |
2367 | 4708 const Ascbyte *warning_string, |
853 | 4709 int flags, |
4710 struct call_trapping_problems_result | |
4711 *problem, | |
4712 Lisp_Object (*fun) (void *), | |
4713 void *arg); | |
4714 Lisp_Object va_call_trapping_problems (Lisp_Object warning_class, | |
2367 | 4715 const Ascbyte *warning_string, |
853 | 4716 int flags, |
4717 struct call_trapping_problems_result | |
4718 *problem, | |
4719 lisp_fn_t fun, int nargs, ...); | |
2367 | 4720 Lisp_Object call0_trapping_problems (const Ascbyte *, Lisp_Object, int); |
4721 Lisp_Object call1_trapping_problems (const Ascbyte *, Lisp_Object, Lisp_Object, | |
853 | 4722 int); |
2367 | 4723 Lisp_Object call2_trapping_problems (const Ascbyte *, Lisp_Object, Lisp_Object, |
853 | 4724 Lisp_Object, int); |
2367 | 4725 Lisp_Object call3_trapping_problems (const Ascbyte *, Lisp_Object, Lisp_Object, |
853 | 4726 Lisp_Object, Lisp_Object, int); |
2367 | 4727 Lisp_Object call4_trapping_problems (const Ascbyte *, Lisp_Object, Lisp_Object, |
853 | 4728 Lisp_Object, Lisp_Object, Lisp_Object, |
4729 int); | |
2367 | 4730 Lisp_Object call5_trapping_problems (const Ascbyte *, Lisp_Object, Lisp_Object, |
853 | 4731 Lisp_Object, Lisp_Object, Lisp_Object, |
4732 Lisp_Object, int); | |
2367 | 4733 Lisp_Object eval_in_buffer_trapping_problems (const Ascbyte *, struct buffer *, |
853 | 4734 Lisp_Object, int); |
1333 | 4735 Lisp_Object run_hook_trapping_problems (Lisp_Object, Lisp_Object, int); |
4736 Lisp_Object safe_run_hook_trapping_problems (Lisp_Object, Lisp_Object, int); | |
4737 Lisp_Object run_hook_with_args_in_buffer_trapping_problems (Lisp_Object, | |
4738 struct buffer *, | |
4739 int nargs, | |
853 | 4740 Lisp_Object *args, |
4741 enum | |
4742 run_hooks_condition | |
4743 cond, int flags); | |
1333 | 4744 Lisp_Object run_hook_with_args_trapping_problems (Lisp_Object, |
853 | 4745 int nargs, |
4746 Lisp_Object *args, | |
4747 enum run_hooks_condition | |
4748 cond, | |
4749 int flags); | |
1333 | 4750 Lisp_Object va_run_hook_with_args_trapping_problems (Lisp_Object, |
853 | 4751 Lisp_Object hook_var, |
4752 int nargs, ...); | |
1333 | 4753 Lisp_Object va_run_hook_with_args_in_buffer_trapping_problems (Lisp_Object, |
4754 struct buffer *, | |
4755 Lisp_Object, | |
853 | 4756 int nargs, ...); |
4757 Lisp_Object call_with_suspended_errors (lisp_fn_t, Lisp_Object, | |
4758 Lisp_Object, | |
578 | 4759 Error_Behavior, int, ...); |
428 | 4760 /* C Code should be using internal_catch, record_unwind_p, condition_case_1 */ |
1318 | 4761 int proper_redisplay_wrapping_in_place (void); |
428 | 4762 Lisp_Object internal_catch (Lisp_Object, Lisp_Object (*) (Lisp_Object), |
853 | 4763 Lisp_Object, int * volatile, |
2532 | 4764 Lisp_Object * volatile, |
853 | 4765 Lisp_Object * volatile); |
428 | 4766 Lisp_Object condition_case_1 (Lisp_Object, |
4767 Lisp_Object (*) (Lisp_Object), | |
4768 Lisp_Object, | |
4769 Lisp_Object (*) (Lisp_Object, Lisp_Object), | |
4770 Lisp_Object); | |
4771 Lisp_Object condition_case_3 (Lisp_Object, Lisp_Object, Lisp_Object); | |
1632 | 4772 MODULE_API Lisp_Object unbind_to_1 (int, Lisp_Object); |
771 | 4773 #define unbind_to(obj) unbind_to_1 (obj, Qnil) |
428 | 4774 void specbind (Lisp_Object, Lisp_Object); |
1632 | 4775 MODULE_API int record_unwind_protect (Lisp_Object (*) (Lisp_Object), |
4776 Lisp_Object); | |
771 | 4777 int record_unwind_protect_freeing_dynarr (void *ptr); |
1333 | 4778 int record_unwind_protect_restoring_int (int *addr, int val); |
802 | 4779 int internal_bind_int (int *addr, int newval); |
4780 int internal_bind_lisp_object (Lisp_Object *addr, Lisp_Object newval); | |
970 | 4781 void do_autoload (Lisp_Object, Lisp_Object); /* GCPROs both arguments */ |
428 | 4782 Lisp_Object un_autoload (Lisp_Object); |
4783 void warn_when_safe_lispobj (Lisp_Object, Lisp_Object, Lisp_Object); | |
1632 | 4784 MODULE_API void warn_when_safe (Lisp_Object, Lisp_Object, const CIbyte *, |
4785 ...) PRINTF_ARGS (3, 4); | |
1292 | 4786 extern int backtrace_with_internal_sections; |
428 | 4787 |
4841
3465c3161fea
when `debug', abort when lisp error during loadup
Ben Wing <ben@xemacs.org>
parents:
4805
diff
changeset
|
4788 extern Lisp_Object Vdebug_on_error; |
1315 | 4789 extern Lisp_Object Vstack_trace_on_error; |
428 | 4790 |
4791 /* Defined in event-stream.c */ | |
826 | 4792 EXFUN (Faccept_process_output, 3); |
4793 EXFUN (Fadd_timeout, 4); | |
4794 EXFUN (Fdisable_timeout, 1); | |
4795 EXFUN (Fdiscard_input, 0); | |
4796 EXFUN (Fdispatch_event, 1); | |
4797 EXFUN (Fenqueue_eval_event, 2); | |
4798 EXFUN (Fnext_event, 2); | |
4799 EXFUN (Fread_key_sequence, 3); | |
4800 EXFUN (Fsit_for, 2); | |
4801 EXFUN (Fsleep_for, 1); | |
4802 | |
428 | 4803 void wait_delaying_user_input (int (*) (void *), void *); |
1268 | 4804 int detect_input_pending (int how_many); |
428 | 4805 void reset_this_command_keys (Lisp_Object, int); |
4806 Lisp_Object enqueue_misc_user_event (Lisp_Object, Lisp_Object, Lisp_Object); | |
4807 Lisp_Object enqueue_misc_user_event_pos (Lisp_Object, Lisp_Object, | |
4808 Lisp_Object, int, int, int, int); | |
442 | 4809 extern int modifier_keys_are_sticky; |
428 | 4810 |
4811 /* Defined in event-Xt.c */ | |
4812 void signal_special_Xt_user_event (Lisp_Object, Lisp_Object, Lisp_Object); | |
4813 | |
4814 | |
4815 /* Defined in events.c */ | |
826 | 4816 EXFUN (Fcopy_event, 2); |
2862 | 4817 EXFUN (Fevent_to_character, 4); |
826 | 4818 |
428 | 4819 void clear_event_resource (void); |
4820 Lisp_Object allocate_event (void); | |
4821 | |
771 | 4822 EXFUN (Fevent_x_pixel, 1); |
4823 EXFUN (Fevent_y_pixel, 1); | |
4824 | |
4825 | |
4826 /* Defined in file-coding.c */ | |
4827 EXFUN (Fcoding_category_list, 0); | |
4828 EXFUN (Fcoding_category_system, 1); | |
4829 EXFUN (Fcoding_priority_list, 0); | |
4830 EXFUN (Fcoding_system_description, 1); | |
4831 EXFUN (Fcoding_system_documentation, 1); | |
4832 EXFUN (Fcoding_system_list, 1); | |
4833 EXFUN (Fcoding_system_name, 1); | |
4834 EXFUN (Fcoding_system_p, 1); | |
4835 EXFUN (Fcoding_system_property, 2); | |
4836 EXFUN (Fcoding_system_type, 1); | |
4837 EXFUN (Fcopy_coding_system, 2); | |
4838 EXFUN (Fdecode_big5_char, 1); | |
4839 EXFUN (Fdecode_coding_region, 4); | |
4840 EXFUN (Fdecode_shift_jis_char, 1); | |
4841 EXFUN (Fdefine_coding_system_alias, 2); | |
4842 EXFUN (Fdetect_coding_region, 3); | |
4843 EXFUN (Fdefault_encoding_detection_enabled_p, 0); | |
4844 EXFUN (Fencode_big5_char, 1); | |
4845 EXFUN (Fencode_coding_region, 4); | |
4846 EXFUN (Fencode_shift_jis_char, 1); | |
4847 EXFUN (Ffind_coding_system, 1); | |
4848 EXFUN (Fget_coding_system, 1); | |
4690
257b468bf2ca
Move the #'query-coding-region implementation to C.
Aidan Kehoe <kehoea@parhasard.net>
parents:
4682
diff
changeset
|
4849 EXFUN (Fmake_coding_system_internal, 4); |
771 | 4850 EXFUN (Fset_coding_category_system, 2); |
4851 EXFUN (Fset_coding_priority_list, 1); | |
4852 EXFUN (Fsubsidiary_coding_system, 2); | |
4853 | |
4854 extern Lisp_Object Qshift_jis, Qiso2022, Qbig5, Qccl; | |
4855 extern Lisp_Object Qcharset_g0; | |
4856 extern Lisp_Object Qcharset_g1, Qcharset_g2, Qcharset_g3, Qcoding_system_error; | |
4857 extern Lisp_Object Qcoding_systemp, Qcr, Qcrlf, Qdecode, Qencode; | |
4858 extern Lisp_Object Qeol_cr, Qeol_crlf, Qeol_lf, Qeol_type, Qescape_quoted; | |
4859 extern Lisp_Object Qforce_g0_on_output, Qforce_g1_on_output; | |
4860 extern Lisp_Object Qforce_g2_on_output, Qforce_g3_on_output; | |
4861 extern Lisp_Object Qinput_charset_conversion, Qlf, Qlock_shift; | |
4862 extern Lisp_Object Qmnemonic, Qno_ascii_cntl, Qno_ascii_eol; | |
4863 extern Lisp_Object Qno_conversion, Qraw_text; | |
4864 extern Lisp_Object Qno_iso6429, Qoutput_charset_conversion; | |
4865 extern Lisp_Object Qpost_read_conversion, Qpre_write_conversion, Qseven; | |
4866 extern Lisp_Object Qshort, Vcoding_system_for_read; | |
4867 extern Lisp_Object Vcoding_system_for_write; | |
4868 extern Lisp_Object Vfile_name_coding_system, Vkeyboard_coding_system; | |
4869 extern Lisp_Object Vterminal_coding_system; | |
4870 extern Lisp_Object Qcanonicalize_after_coding; | |
4871 int coding_system_is_for_text_file (Lisp_Object coding_system); | |
4872 Lisp_Object find_coding_system_for_text_file (Lisp_Object name, int eol_wrap); | |
1632 | 4873 MODULE_API Lisp_Object get_coding_system_for_text_file (Lisp_Object name, |
4874 int eol_wrap); | |
771 | 4875 int coding_system_is_binary (Lisp_Object coding_system); |
4876 | |
4877 | |
428 | 4878 /* Defined in fileio.c */ |
826 | 4879 EXFUN (Fdirectory_file_name, 1); |
4880 EXFUN (Fdo_auto_save, 2); | |
4881 EXFUN (Fexpand_file_name, 2); | |
4882 EXFUN (Ffile_accessible_directory_p, 1); | |
4883 EXFUN (Ffile_directory_p, 1); | |
4884 EXFUN (Ffile_executable_p, 1); | |
4885 EXFUN (Ffile_exists_p, 1); | |
4886 EXFUN (Ffile_name_absolute_p, 1); | |
4887 EXFUN (Ffile_name_as_directory, 1); | |
4888 EXFUN (Ffile_name_directory, 1); | |
4889 EXFUN (Ffile_name_nondirectory, 1); | |
4890 EXFUN (Ffile_readable_p, 1); | |
4891 EXFUN (Ffile_symlink_p, 1); | |
4892 EXFUN (Ffile_truename, 2); | |
4893 EXFUN (Ffind_file_name_handler, 2); | |
4894 EXFUN (Finsert_file_contents_internal, 7); | |
4895 EXFUN (Fmake_temp_name, 1); | |
4896 EXFUN (Fsubstitute_in_file_name, 1); | |
4897 EXFUN (Funhandled_file_name_directory, 1); | |
4898 EXFUN (Fverify_visited_file_modtime, 1); | |
4899 | |
428 | 4900 void record_auto_save (void); |
4901 void force_auto_save_soon (void); | |
563 | 4902 DECLARE_DOESNT_RETURN (report_error_with_errno (Lisp_Object errtype, |
867 | 4903 const CIbyte *string, |
563 | 4904 Lisp_Object data)); |
4905 DECLARE_DOESNT_RETURN (report_file_type_error (Lisp_Object errtype, | |
4906 Lisp_Object oserrmess, | |
867 | 4907 const CIbyte *string, |
563 | 4908 Lisp_Object data)); |
867 | 4909 DECLARE_DOESNT_RETURN (report_file_error (const CIbyte *, Lisp_Object)); |
428 | 4910 Lisp_Object lisp_strerror (int); |
4911 Lisp_Object expand_and_dir_to_file (Lisp_Object, Lisp_Object); | |
4912 int internal_delete_file (Lisp_Object); | |
2526 | 4913 Ibyte *find_end_of_directory_component (const Ibyte *path, |
4914 Bytecount len); | |
428 | 4915 |
4916 /* Defined in filelock.c */ | |
826 | 4917 EXFUN (Funlock_buffer, 0); |
4918 | |
428 | 4919 void lock_file (Lisp_Object); |
4920 void unlock_file (Lisp_Object); | |
4921 void unlock_all_files (void); | |
4922 void unlock_buffer (struct buffer *); | |
4923 | |
4924 /* Defined in floatfns.c */ | |
4678
b5e1d4f6b66f
Make #'floor, #'ceiling, #'round, #'truncate conform to Common Lisp.
Aidan Kehoe <kehoea@parhasard.net>
parents:
4677
diff
changeset
|
4925 EXFUN (Ftruncate, 2); |
826 | 4926 |
428 | 4927 double extract_float (Lisp_Object); |
4928 | |
4929 /* Defined in fns.c */ | |
1632 | 4930 MODULE_API EXFUN (Fappend, MANY); |
826 | 4931 EXFUN (Fassoc, 2); |
4932 EXFUN (Fassq, 2); | |
4933 EXFUN (Fcanonicalize_lax_plist, 2); | |
4934 EXFUN (Fcanonicalize_plist, 2); | |
4935 EXFUN (Fcheck_valid_plist, 1); | |
4936 EXFUN (Fconcat, MANY); | |
4937 EXFUN (Fcopy_alist, 1); | |
4938 EXFUN (Fcopy_list, 1); | |
4939 EXFUN (Fcopy_sequence, 1); | |
4940 EXFUN (Fcopy_tree, 2); | |
4941 EXFUN (Fdelete, 2); | |
4942 EXFUN (Fdelq, 2); | |
4943 EXFUN (Fdestructive_alist_to_plist, 1); | |
4944 EXFUN (Felt, 2); | |
1632 | 4945 MODULE_API EXFUN (Fequal, 2); |
4946 MODULE_API EXFUN (Fget, 3); | |
826 | 4947 EXFUN (Flast, 2); |
4948 EXFUN (Flax_plist_get, 3); | |
4949 EXFUN (Flax_plist_remprop, 2); | |
1632 | 4950 MODULE_API EXFUN (Flength, 1); |
826 | 4951 EXFUN (Fmapcar, 2); |
4952 EXFUN (Fmember, 2); | |
4953 EXFUN (Fmemq, 2); | |
4954 EXFUN (Fnconc, MANY); | |
1632 | 4955 MODULE_API EXFUN (Fnreverse, 1); |
826 | 4956 EXFUN (Fnthcdr, 2); |
4957 EXFUN (Fold_assq, 2); | |
4958 EXFUN (Fold_equal, 2); | |
4959 EXFUN (Fold_member, 2); | |
4960 EXFUN (Fold_memq, 2); | |
4961 EXFUN (Fplist_get, 3); | |
4962 EXFUN (Fplist_member, 2); | |
4963 EXFUN (Fplist_put, 3); | |
1632 | 4964 MODULE_API EXFUN (Fprovide, 1); |
4965 MODULE_API EXFUN (Fput, 3); | |
826 | 4966 EXFUN (Frassq, 2); |
4967 EXFUN (Fremassq, 2); | |
4968 EXFUN (Freplace_list, 2); | |
1632 | 4969 MODULE_API EXFUN (Freverse, 1); |
1268 | 4970 EXFUN (Fsafe_length, 1); |
826 | 4971 EXFUN (Fsort, 2); |
4972 EXFUN (Fstring_equal, 2); | |
4973 EXFUN (Fstring_lessp, 2); | |
4974 EXFUN (Fsubstring, 3); | |
4975 EXFUN (Fvalid_plist_p, 1); | |
4976 | |
428 | 4977 Lisp_Object list_sort (Lisp_Object, Lisp_Object, |
4978 int (*) (Lisp_Object, Lisp_Object, Lisp_Object)); | |
4979 Lisp_Object merge (Lisp_Object, Lisp_Object, Lisp_Object); | |
4980 | |
4981 void bump_string_modiff (Lisp_Object); | |
4982 Lisp_Object memq_no_quit (Lisp_Object, Lisp_Object); | |
4983 Lisp_Object assoc_no_quit (Lisp_Object, Lisp_Object); | |
4984 Lisp_Object assq_no_quit (Lisp_Object, Lisp_Object); | |
4985 Lisp_Object rassq_no_quit (Lisp_Object, Lisp_Object); | |
4986 Lisp_Object delq_no_quit (Lisp_Object, Lisp_Object); | |
4987 Lisp_Object delq_no_quit_and_free_cons (Lisp_Object, Lisp_Object); | |
4988 Lisp_Object remassoc_no_quit (Lisp_Object, Lisp_Object); | |
4989 Lisp_Object remassq_no_quit (Lisp_Object, Lisp_Object); | |
4990 Lisp_Object remrassq_no_quit (Lisp_Object, Lisp_Object); | |
4991 | |
4992 int plists_differ (Lisp_Object, Lisp_Object, int, int, int); | |
4993 Lisp_Object internal_plist_get (Lisp_Object, Lisp_Object); | |
4994 void internal_plist_put (Lisp_Object *, Lisp_Object, Lisp_Object); | |
4995 int internal_remprop (Lisp_Object *, Lisp_Object); | |
4996 Lisp_Object external_plist_get (Lisp_Object *, Lisp_Object, | |
578 | 4997 int, Error_Behavior); |
428 | 4998 void external_plist_put (Lisp_Object *, Lisp_Object, |
578 | 4999 Lisp_Object, int, Error_Behavior); |
5000 int external_remprop (Lisp_Object *, Lisp_Object, int, Error_Behavior); | |
853 | 5001 int internal_equal_trapping_problems (Lisp_Object warning_class, |
2367 | 5002 const Ascbyte *warning_string, |
853 | 5003 int flags, |
5004 struct call_trapping_problems_result *p, | |
5005 int retval, | |
5006 Lisp_Object obj1, Lisp_Object obj2, | |
5007 int depth); | |
428 | 5008 int internal_equal (Lisp_Object, Lisp_Object, int); |
801 | 5009 int internal_equalp (Lisp_Object obj1, Lisp_Object obj2, int depth); |
428 | 5010 Lisp_Object concat2 (Lisp_Object, Lisp_Object); |
5011 Lisp_Object concat3 (Lisp_Object, Lisp_Object, Lisp_Object); | |
5012 Lisp_Object vconcat2 (Lisp_Object, Lisp_Object); | |
5013 Lisp_Object vconcat3 (Lisp_Object, Lisp_Object, Lisp_Object); | |
5014 Lisp_Object nconc2 (Lisp_Object, Lisp_Object); | |
5015 Lisp_Object bytecode_nconc2 (Lisp_Object *); | |
442 | 5016 void check_losing_bytecode (const char *, Lisp_Object); |
428 | 5017 |
771 | 5018 Lisp_Object add_suffix_to_symbol (Lisp_Object symbol, |
2367 | 5019 const Ascbyte *ascii_string); |
5020 Lisp_Object add_prefix_to_symbol (const Ascbyte *ascii_string, | |
771 | 5021 Lisp_Object symbol); |
5022 | |
826 | 5023 /* Defined in free-hook.c */ |
5024 EXFUN (Freally_free, 1); | |
5025 | |
428 | 5026 /* Defined in glyphs.c */ |
826 | 5027 EXFUN (Fmake_glyph_internal, 1); |
5028 | |
578 | 5029 Error_Behavior decode_error_behavior_flag (Lisp_Object); |
5030 Lisp_Object encode_error_behavior_flag (Error_Behavior); | |
428 | 5031 |
563 | 5032 /* Defined in glyphs-shared.c */ |
5033 void shared_resource_validate (Lisp_Object instantiator); | |
5034 Lisp_Object shared_resource_normalize (Lisp_Object inst, | |
5035 Lisp_Object console_type, | |
5036 Lisp_Object dest_mask, | |
5037 Lisp_Object tag); | |
5038 extern Lisp_Object Q_resource_type, Q_resource_id; | |
5039 | |
5040 /* Defined in gui.c */ | |
2367 | 5041 DECLARE_DOESNT_RETURN (gui_error (const Ascbyte *reason, |
563 | 5042 Lisp_Object frob)); |
2367 | 5043 DECLARE_DOESNT_RETURN (gui_error_2 (const Ascbyte *reason, |
569 | 5044 Lisp_Object frob0, Lisp_Object frob1)); |
428 | 5045 /* Defined in indent.c */ |
826 | 5046 EXFUN (Findent_to, 3); |
5047 EXFUN (Fvertical_motion, 3); | |
5048 | |
5049 int byte_spaces_at_point (struct buffer *, Bytebpos); | |
665 | 5050 int column_at_point (struct buffer *, Charbpos, int); |
793 | 5051 int string_column_at_point (Lisp_Object, Charbpos, int); |
428 | 5052 int current_column (struct buffer *); |
5053 void invalidate_current_column (void); | |
665 | 5054 Charbpos vmotion (struct window *, Charbpos, int, int *); |
5055 Charbpos vmotion_pixels (Lisp_Object, Charbpos, int, int, int *); | |
428 | 5056 |
771 | 5057 /* Defined in insdel.c */ |
5058 void set_buffer_point (struct buffer *buf, Charbpos pos, Bytebpos bipos); | |
5059 | |
826 | 5060 /* Defined in intl.c */ |
5061 EXFUN (Fgettext, 1); | |
5062 | |
428 | 5063 /* Defined in keymap.c */ |
826 | 5064 EXFUN (Fdefine_key, 3); |
5065 EXFUN (Fkey_description, 1); | |
5066 EXFUN (Flookup_key, 3); | |
5067 EXFUN (Fmake_sparse_keymap, 1); | |
5068 | |
793 | 5069 void where_is_to_char (Lisp_Object, Eistring *); |
428 | 5070 |
5071 /* Defined in lread.c */ | |
826 | 5072 EXFUN (Fread, 1); |
5073 | |
428 | 5074 void ebolify_bytecode_constants (Lisp_Object); |
5075 void close_load_descs (void); | |
5076 int locate_file (Lisp_Object, Lisp_Object, Lisp_Object, Lisp_Object *, int); | |
5077 EXFUN (Flocate_file_clear_hashing, 1); | |
442 | 5078 int isfloat_string (const char *); |
1983 | 5079 #ifdef HAVE_RATIO |
5080 int isratio_string (const char *); | |
5081 #endif | |
428 | 5082 |
5083 /* Well, I've decided to enable this. -- ben */ | |
5084 /* And I've decided to make it work right. -- sb */ | |
5085 #define LOADHIST | |
5086 /* Define the following symbol to enable load history of dumped files */ | |
5087 #define LOADHIST_DUMPED | |
5088 /* Define the following symbol to enable load history of C source */ | |
5089 #define LOADHIST_BUILTIN | |
5090 | |
5091 #ifdef LOADHIST /* this is just a stupid idea */ | |
5092 #define LOADHIST_ATTACH(x) \ | |
5093 do { if (initialized) Vcurrent_load_list = Fcons (x, Vcurrent_load_list); } \ | |
5094 while (0) | |
5095 #else /*! LOADHIST */ | |
5096 # define LOADHIST_ATTACH(x) | |
5097 #endif /*! LOADHIST */ | |
5098 | |
826 | 5099 /* Defined in macros.c */ |
5100 EXFUN (Fexecute_kbd_macro, 2); | |
5101 | |
428 | 5102 /* Defined in marker.c */ |
826 | 5103 EXFUN (Fcopy_marker, 2); |
5104 EXFUN (Fmake_marker, 0); | |
5105 EXFUN (Fmarker_buffer, 1); | |
5106 EXFUN (Fmarker_position, 1); | |
5107 EXFUN (Fset_marker, 3); | |
5108 EXFUN (Fset_marker_insertion_type, 2); | |
5109 | |
5110 Bytebpos byte_marker_position (Lisp_Object); | |
665 | 5111 Charbpos marker_position (Lisp_Object); |
826 | 5112 void set_byte_marker_position (Lisp_Object, Bytebpos); |
665 | 5113 void set_marker_position (Lisp_Object, Charbpos); |
428 | 5114 void unchain_marker (Lisp_Object); |
5115 Lisp_Object noseeum_copy_marker (Lisp_Object, Lisp_Object); | |
5116 Lisp_Object set_marker_restricted (Lisp_Object, Lisp_Object, Lisp_Object); | |
5117 #ifdef MEMORY_USAGE_STATS | |
5118 int compute_buffer_marker_usage (struct buffer *, struct overhead_stats *); | |
5119 #endif | |
771 | 5120 void init_buffer_markers (struct buffer *b); |
5121 void uninit_buffer_markers (struct buffer *b); | |
428 | 5122 |
5123 /* Defined in minibuf.c */ | |
5124 extern int minibuf_level; | |
867 | 5125 Charcount scmp_1 (const Ibyte *, const Ibyte *, Charcount, int); |
428 | 5126 #define scmp(s1, s2, len) scmp_1 (s1, s2, len, completion_ignore_case) |
5127 extern int completion_ignore_case; | |
867 | 5128 int regexp_ignore_completion_p (const Ibyte *, Lisp_Object, |
428 | 5129 Bytecount, Bytecount); |
5130 Lisp_Object clear_echo_area (struct frame *, Lisp_Object, int); | |
5131 Lisp_Object clear_echo_area_from_print (struct frame *, Lisp_Object, int); | |
867 | 5132 void echo_area_append (struct frame *, const Ibyte *, Lisp_Object, |
428 | 5133 Bytecount, Bytecount, Lisp_Object); |
867 | 5134 void echo_area_message (struct frame *, const Ibyte *, Lisp_Object, |
428 | 5135 Bytecount, Bytecount, Lisp_Object); |
5136 Lisp_Object echo_area_status (struct frame *); | |
5137 int echo_area_active (struct frame *); | |
5138 Lisp_Object echo_area_contents (struct frame *); | |
867 | 5139 void message_internal (const Ibyte *, Lisp_Object, Bytecount, Bytecount); |
5140 void message_append_internal (const Ibyte *, Lisp_Object, | |
428 | 5141 Bytecount, Bytecount); |
1632 | 5142 MODULE_API void message (const char *, ...) PRINTF_ARGS (1, 2); |
442 | 5143 void message_append (const char *, ...) PRINTF_ARGS (1, 2); |
5144 void message_no_translate (const char *, ...) PRINTF_ARGS (1, 2); | |
428 | 5145 void clear_message (void); |
5146 | |
771 | 5147 /* Defined in mule-charset.c */ |
826 | 5148 EXFUN (Fmake_charset, 3); |
5149 | |
771 | 5150 extern Lisp_Object Ql2r, Qr2l; |
5151 | |
428 | 5152 /* Defined in print.c */ |
826 | 5153 EXFUN (Fdisplay_error, 2); |
5154 EXFUN (Ferror_message_string, 1); | |
5155 EXFUN (Fprin1, 2); | |
5156 EXFUN (Fprin1_to_string, 2); | |
5157 EXFUN (Fprinc, 2); | |
5158 EXFUN (Fprint, 2); | |
5159 | |
4394
cacc942c0d0f
Avoid clearing print-gensym-alist inappropriately when printing hash tables.
Aidan Kehoe <kehoea@parhasard.net>
parents:
4355
diff
changeset
|
5160 Lisp_Object prin1_to_string (Lisp_Object, int); |
771 | 5161 |
5162 /* Lower-level ways to output data: */ | |
3085 | 5163 void default_object_printer (Lisp_Object, Lisp_Object, int); |
771 | 5164 void print_internal (Lisp_Object, Lisp_Object, int); |
428 | 5165 void debug_print (Lisp_Object); |
1204 | 5166 void debug_p4 (Lisp_Object obj); |
5167 void debug_p3 (Lisp_Object obj); | |
5168 void debug_short_backtrace (int); | |
5169 void debug_backtrace (void); | |
428 | 5170 /* NOTE: Do not call this with the data of a Lisp_String. Use princ. |
5171 * Note: stream should be defaulted before calling | |
5172 * (eg Qnil means stdout, not Vstandard_output, etc) */ | |
1632 | 5173 MODULE_API void write_c_string (Lisp_Object stream, const CIbyte *str); |
771 | 5174 /* Same goes for this function. */ |
1632 | 5175 MODULE_API void write_string (Lisp_Object stream, const Ibyte *str); |
428 | 5176 /* Same goes for this function. */ |
867 | 5177 void write_string_1 (Lisp_Object stream, const Ibyte *str, Bytecount size); |
826 | 5178 void write_eistring (Lisp_Object stream, const Eistring *ei); |
771 | 5179 |
5180 /* Higher-level (printf-style) ways to output data: */ | |
1632 | 5181 MODULE_API void write_fmt_string (Lisp_Object stream, const CIbyte *fmt, ...); |
5182 MODULE_API void write_fmt_string_lisp (Lisp_Object stream, const CIbyte *fmt, | |
5183 int nargs, ...); | |
867 | 5184 void stderr_out (const CIbyte *, ...) PRINTF_ARGS (1, 2); |
5185 void stderr_out_lisp (const CIbyte *, int nargs, ...); | |
5186 void stdout_out (const CIbyte *, ...) PRINTF_ARGS (1, 2); | |
1346 | 5187 void external_out (int dest, const CIbyte *fmt, ...) PRINTF_ARGS (2, 3); |
867 | 5188 void debug_out (const CIbyte *, ...) PRINTF_ARGS (1, 2); |
1743 | 5189 DECLARE_DOESNT_RETURN (fatal (const CIbyte *, ...)) PRINTF_ARGS(1, 2); |
771 | 5190 |
5191 /* Internal functions: */ | |
1261 | 5192 Lisp_Object canonicalize_printcharfun (Lisp_Object printcharfun); |
771 | 5193 void temp_output_buffer_setup (Lisp_Object); |
5194 void temp_output_buffer_show (Lisp_Object, Lisp_Object); | |
428 | 5195 void print_cons (Lisp_Object, Lisp_Object, int); |
5196 void print_vector (Lisp_Object, Lisp_Object, int); | |
5197 void print_string (Lisp_Object, Lisp_Object, int); | |
771 | 5198 void print_symbol (Lisp_Object, Lisp_Object, int); |
5199 void print_float (Lisp_Object, Lisp_Object, int); | |
603 | 5200 /* The number of bytes required to store the decimal printed |
5201 representation of an integral type. Add a few bytes for truncation, | |
5202 optional sign prefix, and null byte terminator. | |
614 | 5203 2.40824 == log (256) / log (10). |
5204 | |
5205 We don't use floating point since Sun cc (buggily?) cannot use | |
5206 floating point computations to define a compile-time integral | |
5207 constant. */ | |
603 | 5208 #define DECIMAL_PRINT_SIZE(integral_type) \ |
614 | 5209 (((2410824 * sizeof (integral_type)) / 1000000) + 3) |
577 | 5210 void long_to_string (char *, long); |
4329
d9eb5ea14f65
Provide %b in #'format; use it for converting between ints and bit vectors.
Aidan Kehoe <kehoea@parhasard.net>
parents:
4134
diff
changeset
|
5211 void ulong_to_bit_string (char *, unsigned long); |
428 | 5212 extern int print_escape_newlines; |
1632 | 5213 extern MODULE_API int print_readably; |
428 | 5214 Lisp_Object internal_with_output_to_temp_buffer (Lisp_Object, |
5215 Lisp_Object (*) (Lisp_Object), | |
5216 Lisp_Object, Lisp_Object); | |
5217 void float_to_string (char *, double); | |
5218 void internal_object_printer (Lisp_Object, Lisp_Object, int); | |
5219 | |
5220 /* Defined in rangetab.c */ | |
826 | 5221 EXFUN (Fclear_range_table, 1); |
5222 EXFUN (Fget_range_table, 3); | |
2421 | 5223 EXFUN (Fmake_range_table, 1); |
826 | 5224 EXFUN (Fput_range_table, 4); |
4690
257b468bf2ca
Move the #'query-coding-region implementation to C.
Aidan Kehoe <kehoea@parhasard.net>
parents:
4682
diff
changeset
|
5225 EXFUN (Fcopy_range_table, 1); |
826 | 5226 |
2421 | 5227 extern Lisp_Object Qstart_closed_end_open; |
5228 extern Lisp_Object Qstart_open_end_open; | |
5229 extern Lisp_Object Qstart_closed_end_closed; | |
5230 extern Lisp_Object Qstart_open_end_closed; | |
5231 | |
428 | 5232 void put_range_table (Lisp_Object, EMACS_INT, EMACS_INT, Lisp_Object); |
5233 int unified_range_table_bytes_needed (Lisp_Object); | |
5234 int unified_range_table_bytes_used (void *); | |
5235 void unified_range_table_copy_data (Lisp_Object, void *); | |
5236 Lisp_Object unified_range_table_lookup (void *, EMACS_INT, Lisp_Object); | |
5237 int unified_range_table_nentries (void *); | |
5238 void unified_range_table_get_range (void *, int, EMACS_INT *, EMACS_INT *, | |
5239 Lisp_Object *); | |
5240 | |
5241 /* Defined in search.c */ | |
826 | 5242 EXFUN (Fmatch_beginning, 1); |
5243 EXFUN (Fmatch_end, 1); | |
5244 EXFUN (Fskip_chars_backward, 3); | |
5245 EXFUN (Fskip_chars_forward, 3); | |
5246 EXFUN (Fstring_match, 4); | |
5247 | |
428 | 5248 struct re_pattern_buffer; |
5249 struct re_registers; | |
867 | 5250 Charbpos scan_buffer (struct buffer *, Ichar, Charbpos, Charbpos, EMACS_INT, |
826 | 5251 EMACS_INT *, int); |
665 | 5252 Charbpos find_next_newline (struct buffer *, Charbpos, int); |
5253 Charbpos find_next_newline_no_quit (struct buffer *, Charbpos, int); | |
826 | 5254 Bytebpos byte_find_next_newline_no_quit (struct buffer *, Bytebpos, int); |
867 | 5255 Bytecount byte_find_next_ichar_in_string (Lisp_Object, Ichar, Bytecount, |
826 | 5256 EMACS_INT); |
665 | 5257 Charbpos find_before_next_newline (struct buffer *, Charbpos, Charbpos, int); |
826 | 5258 struct re_pattern_buffer *compile_pattern (Lisp_Object pattern, |
5259 struct re_registers *regp, | |
5260 Lisp_Object translate, | |
5261 Lisp_Object searchobj, | |
5262 struct buffer *searchbuf, | |
5263 int posix, Error_Behavior errb); | |
867 | 5264 Bytecount fast_string_match (Lisp_Object, const Ibyte *, |
428 | 5265 Lisp_Object, Bytecount, |
578 | 5266 Bytecount, int, Error_Behavior, int); |
428 | 5267 Bytecount fast_lisp_string_match (Lisp_Object, Lisp_Object); |
507 | 5268 extern Fixnum warn_about_possibly_incompatible_back_references; |
502 | 5269 |
428 | 5270 |
5271 /* Defined in signal.c */ | |
5272 void init_interrupts_late (void); | |
5273 | |
5274 /* Defined in sound.c */ | |
826 | 5275 EXFUN (Fding, 3); |
5276 | |
428 | 5277 void init_device_sound (struct device *); |
2367 | 5278 DECLARE_DOESNT_RETURN (report_sound_error (const Ascbyte *, Lisp_Object)); |
428 | 5279 |
5280 /* Defined in specifier.c */ | |
826 | 5281 EXFUN (Fadd_spec_to_specifier, 5); |
5282 EXFUN (Fspecifier_spec_list, 4); | |
5283 | |
428 | 5284 Lisp_Object specifier_instance (Lisp_Object, Lisp_Object, Lisp_Object, |
578 | 5285 Error_Behavior, int, int, Lisp_Object); |
428 | 5286 Lisp_Object specifier_instance_no_quit (Lisp_Object, Lisp_Object, Lisp_Object, |
578 | 5287 Error_Behavior, int, Lisp_Object); |
428 | 5288 |
5289 /* Defined in symbols.c */ | |
826 | 5290 EXFUN (Fboundp, 1); |
5291 EXFUN (Fbuilt_in_variable_type, 1); | |
5292 EXFUN (Fdefault_boundp, 1); | |
5293 EXFUN (Fdefault_value, 1); | |
5294 EXFUN (Ffboundp, 1); | |
5295 EXFUN (Ffset, 2); | |
5296 EXFUN (Fintern, 2); | |
4355
a2af1ff1761f
Provide a DEFAULT argument in #'intern-soft.
Aidan Kehoe <kehoea@parhasard.net>
parents:
4329
diff
changeset
|
5297 EXFUN (Fintern_soft, 3); |
826 | 5298 EXFUN (Fkill_local_variable, 1); |
5299 EXFUN (Fset, 2); | |
5300 EXFUN (Fset_default, 2); | |
5301 EXFUN (Fsymbol_function, 1); | |
5302 EXFUN (Fsymbol_name, 1); | |
5303 EXFUN (Fsymbol_plist, 1); | |
5304 EXFUN (Fsymbol_value, 1); | |
5305 | |
867 | 5306 unsigned int hash_string (const Ibyte *, Bytecount); |
5307 Lisp_Object intern_int (const Ibyte *str); | |
1632 | 5308 MODULE_API Lisp_Object intern (const CIbyte *str); |
867 | 5309 Lisp_Object intern_converting_underscores_to_dashes (const CIbyte *str); |
5310 Lisp_Object oblookup (Lisp_Object, const Ibyte *, Bytecount); | |
428 | 5311 void map_obarray (Lisp_Object, int (*) (Lisp_Object, void *), void *); |
5312 Lisp_Object indirect_function (Lisp_Object, int); | |
5313 Lisp_Object symbol_value_in_buffer (Lisp_Object, Lisp_Object); | |
5314 void kill_buffer_local_variables (struct buffer *); | |
5315 int symbol_value_buffer_local_info (Lisp_Object, struct buffer *); | |
5316 Lisp_Object find_symbol_value (Lisp_Object); | |
5317 Lisp_Object find_symbol_value_quickly (Lisp_Object, int); | |
5318 Lisp_Object top_level_value (Lisp_Object); | |
5319 void reject_constant_symbols (Lisp_Object sym, Lisp_Object newval, | |
5320 int function_p, | |
5321 Lisp_Object follow_past_lisp_magic); | |
5322 | |
5323 /* Defined in syntax.c */ | |
665 | 5324 Charbpos scan_words (struct buffer *, Charbpos, int); |
826 | 5325 EXFUN (Fchar_syntax, 2); |
5326 EXFUN (Fforward_word, 2); | |
5327 extern Lisp_Object Vstandard_syntax_table; | |
3250 | 5328 void signal_syntax_cache_extent_changed (EXTENT extent); |
5329 void signal_syntax_cache_extent_adjust (struct buffer *buf); | |
826 | 5330 void init_buffer_syntax_cache (struct buffer *buf); |
5331 void mark_buffer_syntax_cache (struct buffer *buf); | |
5332 void uninit_buffer_syntax_cache (struct buffer *buf); | |
5333 extern Lisp_Object Qsyntax_table; | |
428 | 5334 |
771 | 5335 /* Defined in sysdep.c */ |
5336 long get_random (void); | |
5337 void seed_random (long arg); | |
5338 | |
5339 /* Defined in text.c */ | |
867 | 5340 void find_charsets_in_ibyte_string (unsigned char *charsets, |
5341 const Ibyte *str, | |
771 | 5342 Bytecount len); |
867 | 5343 void find_charsets_in_ichar_string (unsigned char *charsets, |
5344 const Ichar *str, | |
771 | 5345 Charcount len); |
867 | 5346 int ibyte_string_displayed_columns (const Ibyte *str, Bytecount len); |
5347 int ichar_string_displayed_columns (const Ichar *str, Charcount len); | |
5348 Charcount ibyte_string_nonascii_chars (const Ibyte *str, Bytecount len); | |
5349 void convert_ibyte_string_into_ichar_dynarr (const Ibyte *str, | |
771 | 5350 Bytecount len, |
867 | 5351 Ichar_dynarr *dyn); |
5352 Charcount convert_ibyte_string_into_ichar_string (const Ibyte *str, | |
771 | 5353 Bytecount len, |
867 | 5354 Ichar *arr); |
5355 void convert_ichar_string_into_ibyte_dynarr (Ichar *arr, int nels, | |
5356 Ibyte_dynarr *dyn); | |
5357 Ibyte *convert_ichar_string_into_malloced_string (Ichar *arr, int nels, | |
771 | 5358 Bytecount *len_out); |
867 | 5359 Bytecount copy_text_between_formats (const Ibyte *src, Bytecount srclen, |
826 | 5360 Internal_Format srcfmt, |
5361 Lisp_Object srcobj, | |
867 | 5362 Ibyte *dst, Bytecount dstlen, |
826 | 5363 Internal_Format dstfmt, |
5364 Lisp_Object dstobj, | |
5365 Bytecount *src_used); | |
5366 Bytecount copy_buffer_text_out (struct buffer *buf, Bytebpos pos, | |
867 | 5367 Bytecount len, Ibyte *dst, Bytecount dstlen, |
826 | 5368 Internal_Format dstfmt, Lisp_Object dstobj, |
5369 Bytecount *src_used); | |
771 | 5370 |
5371 /* flags for get_buffer_pos_char(), get_buffer_range_char(), etc. */ | |
5372 /* At most one of GB_COERCE_RANGE and GB_NO_ERROR_IF_BAD should be | |
5373 specified. At most one of GB_NEGATIVE_FROM_END and GB_NO_ERROR_IF_BAD | |
5374 should be specified. */ | |
5375 | |
5376 #define GB_ALLOW_PAST_ACCESSIBLE (1 << 0) | |
5377 #define GB_ALLOW_NIL (1 << 1) | |
5378 #define GB_CHECK_ORDER (1 << 2) | |
5379 #define GB_COERCE_RANGE (1 << 3) | |
5380 #define GB_NO_ERROR_IF_BAD (1 << 4) | |
5381 #define GB_NEGATIVE_FROM_END (1 << 5) | |
5382 #define GB_HISTORICAL_STRING_BEHAVIOR (GB_NEGATIVE_FROM_END | GB_ALLOW_NIL) | |
5383 | |
5384 Charbpos get_buffer_pos_char (struct buffer *b, Lisp_Object pos, | |
5385 unsigned int flags); | |
5386 Bytebpos get_buffer_pos_byte (struct buffer *b, Lisp_Object pos, | |
5387 unsigned int flags); | |
5388 void get_buffer_range_char (struct buffer *b, Lisp_Object from, Lisp_Object to, | |
5389 Charbpos *from_out, Charbpos *to_out, | |
5390 unsigned int flags); | |
5391 void get_buffer_range_byte (struct buffer *b, Lisp_Object from, Lisp_Object to, | |
5392 Bytebpos *from_out, Bytebpos *to_out, | |
5393 unsigned int flags); | |
5394 Charcount get_string_pos_char (Lisp_Object string, Lisp_Object pos, | |
5395 unsigned int flags); | |
5396 Bytecount get_string_pos_byte (Lisp_Object string, Lisp_Object pos, | |
5397 unsigned int flags); | |
5398 void get_string_range_char (Lisp_Object string, Lisp_Object from, | |
5399 Lisp_Object to, Charcount *from_out, | |
5400 Charcount *to_out, unsigned int flags); | |
5401 void get_string_range_byte (Lisp_Object string, Lisp_Object from, | |
5402 Lisp_Object to, Bytecount *from_out, | |
5403 Bytecount *to_out, unsigned int flags); | |
826 | 5404 Charxpos get_buffer_or_string_pos_char (Lisp_Object object, Lisp_Object pos, |
5405 unsigned int flags); | |
5406 Bytexpos get_buffer_or_string_pos_byte (Lisp_Object object, Lisp_Object pos, | |
5407 unsigned int flags); | |
771 | 5408 void get_buffer_or_string_range_char (Lisp_Object object, Lisp_Object from, |
826 | 5409 Lisp_Object to, Charxpos *from_out, |
5410 Charxpos *to_out, unsigned int flags); | |
771 | 5411 void get_buffer_or_string_range_byte (Lisp_Object object, Lisp_Object from, |
826 | 5412 Lisp_Object to, Bytexpos *from_out, |
5413 Bytexpos *to_out, unsigned int flags); | |
5414 Charxpos buffer_or_string_accessible_begin_char (Lisp_Object object); | |
5415 Charxpos buffer_or_string_accessible_end_char (Lisp_Object object); | |
5416 Bytexpos buffer_or_string_accessible_begin_byte (Lisp_Object object); | |
5417 Bytexpos buffer_or_string_accessible_end_byte (Lisp_Object object); | |
5418 Charxpos buffer_or_string_absolute_begin_char (Lisp_Object object); | |
5419 Charxpos buffer_or_string_absolute_end_char (Lisp_Object object); | |
5420 Bytexpos buffer_or_string_absolute_begin_byte (Lisp_Object object); | |
5421 Bytexpos buffer_or_string_absolute_end_byte (Lisp_Object object); | |
5422 Charbpos charbpos_clip_to_bounds (Charbpos lower, Charbpos num, | |
5423 Charbpos upper); | |
5424 Bytebpos bytebpos_clip_to_bounds (Bytebpos lower, Bytebpos num, | |
5425 Bytebpos upper); | |
5426 Charxpos charxpos_clip_to_bounds (Charxpos lower, Charxpos num, | |
5427 Charxpos upper); | |
5428 Bytexpos bytexpos_clip_to_bounds (Bytexpos lower, Bytexpos num, | |
5429 Bytexpos upper); | |
5430 Charxpos buffer_or_string_clip_to_accessible_char (Lisp_Object object, | |
5431 Charxpos pos); | |
5432 Bytexpos buffer_or_string_clip_to_accessible_byte (Lisp_Object object, | |
5433 Bytexpos pos); | |
5434 Charxpos buffer_or_string_clip_to_absolute_char (Lisp_Object object, | |
5435 Charxpos pos); | |
5436 Bytexpos buffer_or_string_clip_to_absolute_byte (Lisp_Object object, | |
5437 Bytexpos pos); | |
5438 | |
771 | 5439 |
5440 #ifdef ENABLE_COMPOSITE_CHARS | |
5441 | |
867 | 5442 Ichar lookup_composite_char (Ibyte *str, int len); |
5443 Lisp_Object composite_char_string (Ichar ch); | |
771 | 5444 #endif /* ENABLE_COMPOSITE_CHARS */ |
5445 | |
5446 EXFUN (Ffind_charset, 1); | |
5447 EXFUN (Fget_charset, 1); | |
5448 EXFUN (Fcharset_list, 0); | |
5449 | |
5450 extern Lisp_Object Vcharset_ascii; | |
5451 extern Lisp_Object Vcharset_control_1; | |
5452 extern Lisp_Object Vcharset_latin_iso8859_1; | |
5453 extern Lisp_Object Vcharset_latin_iso8859_2; | |
5454 extern Lisp_Object Vcharset_latin_iso8859_3; | |
5455 extern Lisp_Object Vcharset_latin_iso8859_4; | |
5456 extern Lisp_Object Vcharset_thai_tis620; | |
5457 extern Lisp_Object Vcharset_greek_iso8859_7; | |
4805
980575c76541
Move the arabic-iso8859-6 character set back to C, otherwise X11 lookup fails.
Aidan Kehoe <kehoea@parhasard.net>
parents:
4744
diff
changeset
|
5458 extern Lisp_Object Vcharset_arabic_iso8859_6; |
771 | 5459 extern Lisp_Object Vcharset_hebrew_iso8859_8; |
5460 extern Lisp_Object Vcharset_katakana_jisx0201; | |
5461 extern Lisp_Object Vcharset_latin_jisx0201; | |
5462 extern Lisp_Object Vcharset_cyrillic_iso8859_5; | |
5463 extern Lisp_Object Vcharset_latin_iso8859_9; | |
3094 | 5464 extern Lisp_Object Vcharset_latin_iso8859_15; |
771 | 5465 extern Lisp_Object Vcharset_japanese_jisx0208_1978; |
5466 extern Lisp_Object Vcharset_chinese_gb2312; | |
5467 extern Lisp_Object Vcharset_japanese_jisx0208; | |
5468 extern Lisp_Object Vcharset_korean_ksc5601; | |
5469 extern Lisp_Object Vcharset_japanese_jisx0212; | |
5470 extern Lisp_Object Vcharset_chinese_cns11643_1; | |
5471 extern Lisp_Object Vcharset_chinese_cns11643_2; | |
5472 extern Lisp_Object Vcharset_chinese_big5_1; | |
5473 extern Lisp_Object Vcharset_chinese_big5_2; | |
5474 extern Lisp_Object Vcharset_composite; | |
5475 | |
867 | 5476 Ichar Lstream_get_ichar_1 (Lstream *stream, int first_char); |
5477 int Lstream_fput_ichar (Lstream *stream, Ichar ch); | |
5478 void Lstream_funget_ichar (Lstream *stream, Ichar ch); | |
5479 | |
5480 DECLARE_INLINE_HEADER (Ibyte *qxestrdup (const Ibyte *s)) | |
771 | 5481 { |
2367 | 5482 return (Ibyte *) xstrdup ((const Chbyte *) s); |
771 | 5483 } |
5484 | |
867 | 5485 DECLARE_INLINE_HEADER (Bytecount qxestrlen (const Ibyte *s)) |
771 | 5486 { |
2367 | 5487 return strlen ((const Chbyte *) s); |
771 | 5488 } |
5489 | |
867 | 5490 DECLARE_INLINE_HEADER (Charcount qxestrcharlen (const Ibyte *s)) |
771 | 5491 { |
5492 return bytecount_to_charcount (s, qxestrlen (s)); | |
5493 } | |
5494 | |
867 | 5495 DECLARE_INLINE_HEADER (int qxestrcmp (const Ibyte *s1, |
5496 const Ibyte *s2)) | |
771 | 5497 { |
2367 | 5498 return strcmp ((const Chbyte *) s1, (const Chbyte *) s2); |
771 | 5499 } |
5500 | |
2367 | 5501 DECLARE_INLINE_HEADER (int qxestrcmp_ascii (const Ibyte *s1, |
5502 const Ascbyte *s2)) | |
771 | 5503 { |
2367 | 5504 return strcmp ((const Chbyte *) s1, s2); |
771 | 5505 } |
5506 | |
867 | 5507 DECLARE_INLINE_HEADER (int qxestrncmp (const Ibyte *string1, |
5508 const Ibyte *string2, | |
771 | 5509 Bytecount count)) |
5510 { | |
2367 | 5511 return strncmp ((const Chbyte *) string1, (const Chbyte *) string2, |
771 | 5512 (size_t) count); |
5513 } | |
5514 | |
2367 | 5515 DECLARE_INLINE_HEADER (int qxestrncmp_ascii (const Ibyte *string1, |
5516 const Ascbyte *string2, | |
5517 Bytecount count)) | |
771 | 5518 { |
2367 | 5519 return strncmp ((const Chbyte *) string1, string2, (size_t) count); |
771 | 5520 } |
5521 | |
867 | 5522 DECLARE_INLINE_HEADER (Ibyte *qxestrcpy (Ibyte *strDest, |
2367 | 5523 const Ibyte *strSource)) |
771 | 5524 { |
2367 | 5525 return (Ibyte *) strcpy ((Chbyte *) strDest, (const Chbyte *) strSource); |
771 | 5526 } |
5527 | |
2367 | 5528 DECLARE_INLINE_HEADER (Ibyte *qxestrcpy_ascii (Ibyte *strDest, |
5529 const Ascbyte *strSource)) | |
771 | 5530 { |
2367 | 5531 return (Ibyte *) strcpy ((Chbyte *) strDest, strSource); |
771 | 5532 } |
5533 | |
867 | 5534 DECLARE_INLINE_HEADER (Ibyte *qxestrncpy (Ibyte *strDest, |
2367 | 5535 const Ibyte *strSource, |
5536 Bytecount count)) | |
771 | 5537 { |
2367 | 5538 return (Ibyte *) strncpy ((Chbyte *) strDest, (const Chbyte *) strSource, |
771 | 5539 (size_t) count); |
5540 } | |
5541 | |
2367 | 5542 DECLARE_INLINE_HEADER (Ibyte *qxestrncpy_ascii (Ibyte *strDest, |
5543 const Ascbyte *strSource, | |
5544 Bytecount count)) | |
771 | 5545 { |
2367 | 5546 return (Ibyte *) strncpy ((Chbyte *) strDest, strSource, (size_t) count); |
771 | 5547 } |
5548 | |
867 | 5549 DECLARE_INLINE_HEADER (Ibyte *qxestrcat (Ibyte *strDest, |
2367 | 5550 const Ibyte *strSource)) |
771 | 5551 { |
2367 | 5552 return (Ibyte *) strcat ((Chbyte *) strDest, (const Chbyte *) strSource); |
771 | 5553 } |
5554 | |
2367 | 5555 DECLARE_INLINE_HEADER (Ibyte *qxestrcat_ascii (Ibyte *strDest, |
5556 const Ascbyte *strSource)) | |
771 | 5557 { |
2367 | 5558 return (Ibyte *) strcat ((Chbyte *) strDest, strSource); |
771 | 5559 } |
5560 | |
867 | 5561 DECLARE_INLINE_HEADER (Ibyte *qxestrncat (Ibyte *strDest, |
2367 | 5562 const Ibyte *strSource, |
5563 Bytecount count)) | |
771 | 5564 { |
2367 | 5565 return (Ibyte *) strncat ((Chbyte *) strDest, (const Chbyte *) strSource, |
771 | 5566 (size_t) count); |
5567 } | |
5568 | |
2367 | 5569 DECLARE_INLINE_HEADER (Ibyte *qxestrncat_ascii (Ibyte *strDest, |
5570 const Ascbyte *strSource, | |
5571 Bytecount count)) | |
771 | 5572 { |
2367 | 5573 return (Ibyte *) strncat ((Chbyte *) strDest, strSource, (size_t) count); |
771 | 5574 } |
5575 | |
867 | 5576 DECLARE_INLINE_HEADER (Ibyte *qxestrchr (const Ibyte *s, Ichar c)) |
771 | 5577 { |
5578 assert (c >= 0 && c <= 255); | |
2367 | 5579 return (Ibyte *) strchr ((const Chbyte *) s, c); |
771 | 5580 } |
5581 | |
867 | 5582 DECLARE_INLINE_HEADER (Ibyte *qxestrrchr (const Ibyte *s, Ichar c)) |
771 | 5583 { |
5584 assert (c >= 0 && c <= 255); | |
2367 | 5585 return (Ibyte *) strrchr ((const Chbyte *) s, c); |
771 | 5586 } |
5587 | |
867 | 5588 DECLARE_INLINE_HEADER (Ibyte *qxestrstr (const Ibyte *string1, |
2367 | 5589 const Ibyte *string2)) |
771 | 5590 { |
2367 | 5591 return (Ibyte *) strstr ((const Chbyte *) string1, (const Chbyte *) string2); |
771 | 5592 } |
5593 | |
867 | 5594 DECLARE_INLINE_HEADER (Bytecount qxestrcspn (const Ibyte *string, |
5595 const CIbyte *strCharSet)) | |
771 | 5596 { |
2367 | 5597 return (Bytecount) strcspn ((const Chbyte *) string, strCharSet); |
771 | 5598 } |
5599 | |
867 | 5600 DECLARE_INLINE_HEADER (Bytecount qxestrspn (const Ibyte *string, |
5601 const CIbyte *strCharSet)) | |
771 | 5602 { |
2367 | 5603 return (Bytecount) strspn ((const Chbyte *) string, strCharSet); |
771 | 5604 } |
5605 | |
867 | 5606 DECLARE_INLINE_HEADER (Ibyte *qxestrpbrk (const Ibyte *string, |
2367 | 5607 const CIbyte *strCharSet)) |
771 | 5608 { |
2367 | 5609 return (Ibyte *) strpbrk ((const Chbyte *) string, strCharSet); |
771 | 5610 } |
5611 | |
867 | 5612 DECLARE_INLINE_HEADER (Ibyte *qxestrtok (Ibyte *strToken, |
2367 | 5613 const CIbyte *strDelimit)) |
771 | 5614 { |
2367 | 5615 return (Ibyte *) strtok ((Chbyte *) strToken, strDelimit); |
771 | 5616 } |
5617 | |
867 | 5618 DECLARE_INLINE_HEADER (double qxestrtod (const Ibyte *nptr, |
5619 Ibyte **endptr)) | |
771 | 5620 { |
2367 | 5621 return strtod ((const Chbyte *) nptr, (Chbyte **) endptr); |
771 | 5622 } |
5623 | |
867 | 5624 DECLARE_INLINE_HEADER (long qxestrtol (const Ibyte *nptr, Ibyte **endptr, |
771 | 5625 int base)) |
5626 { | |
2367 | 5627 return strtol ((const Chbyte *) nptr, (Chbyte **) endptr, base); |
771 | 5628 } |
5629 | |
867 | 5630 DECLARE_INLINE_HEADER (unsigned long qxestrtoul (const Ibyte *nptr, |
5631 Ibyte **endptr, | |
771 | 5632 int base)) |
5633 { | |
2367 | 5634 return strtoul ((const Chbyte *) nptr, (Chbyte **) endptr, base); |
771 | 5635 } |
5636 | |
867 | 5637 DECLARE_INLINE_HEADER (int qxeatoi (const Ibyte *string)) |
771 | 5638 { |
2367 | 5639 return atoi ((const Chbyte *) string); |
771 | 5640 } |
5641 | |
1204 | 5642 DECLARE_INLINE_HEADER (Ibyte *qxestrupr (Ibyte *s)) |
5643 { | |
2367 | 5644 return (Ibyte *) strupr ((Chbyte *) s); |
1204 | 5645 } |
5646 | |
5647 DECLARE_INLINE_HEADER (Ibyte *qxestrlwr (Ibyte *s)) | |
5648 { | |
2367 | 5649 return (Ibyte *) strlwr ((Chbyte *) s); |
1204 | 5650 } |
5651 | |
867 | 5652 int qxesprintf (Ibyte *buffer, const CIbyte *format, ...) |
771 | 5653 PRINTF_ARGS (2, 3); |
5654 | |
2367 | 5655 DECLARE_INLINE_HEADER (int qxesscanf_ascii_1 (Ibyte *buffer, |
5656 const Ascbyte *format, | |
5657 void *ptr)) | |
5658 { | |
5659 /* #### DAMNIT! No vsscanf! */ | |
5660 return sscanf ((Chbyte *) buffer, format, ptr); | |
5661 } | |
5662 | |
771 | 5663 /* Do not use POSIX locale routines. Not Mule-correct. */ |
5664 #define qxestrcoll DO NOT USE. | |
5665 #define qxestrxfrm DO NOT USE. | |
5666 | |
867 | 5667 int qxestrcasecmp (const Ibyte *s1, const Ibyte *s2); |
2367 | 5668 int qxestrcasecmp_ascii (const Ibyte *s1, const Ascbyte *s2); |
867 | 5669 int qxestrcasecmp_i18n (const Ibyte *s1, const Ibyte *s2); |
2367 | 5670 int ascii_strcasecmp (const Ascbyte *s1, const Ascbyte *s2); |
771 | 5671 int lisp_strcasecmp (Lisp_Object s1, Lisp_Object s2); |
5672 int lisp_strcasecmp_i18n (Lisp_Object s1, Lisp_Object s2); | |
867 | 5673 int qxestrncasecmp (const Ibyte *s1, const Ibyte *s2, Bytecount len); |
2367 | 5674 int qxestrncasecmp_ascii (const Ibyte *s1, const Ascbyte *s2, |
5675 Bytecount len); | |
867 | 5676 int qxestrncasecmp_i18n (const Ibyte *s1, const Ibyte *s2, Bytecount len); |
2367 | 5677 int ascii_strncasecmp (const Ascbyte *s1, const Ascbyte *s2, |
771 | 5678 Bytecount len); |
867 | 5679 int qxememcmp (const Ibyte *s1, const Ibyte *s2, Bytecount len); |
5680 int qxememcmp4 (const Ibyte *s1, Bytecount len1, | |
5681 const Ibyte *s2, Bytecount len2); | |
5682 int qxememcasecmp (const Ibyte *s1, const Ibyte *s2, Bytecount len); | |
5683 int qxememcasecmp4 (const Ibyte *s1, Bytecount len1, | |
5684 const Ibyte *s2, Bytecount len2); | |
5685 int qxetextcmp (const Ibyte *s1, Bytecount len1, | |
5686 const Ibyte *s2, Bytecount len2); | |
5687 int qxetextcmp_matching (const Ibyte *s1, Bytecount len1, | |
5688 const Ibyte *s2, Bytecount len2, | |
801 | 5689 Charcount *matching); |
867 | 5690 int qxetextcasecmp (const Ibyte *s1, Bytecount len1, |
5691 const Ibyte *s2, Bytecount len2); | |
5692 int qxetextcasecmp_matching (const Ibyte *s1, Bytecount len1, | |
5693 const Ibyte *s2, Bytecount len2, | |
801 | 5694 Charcount *matching); |
771 | 5695 |
5696 void buffer_mule_signal_inserted_region (struct buffer *buf, Charbpos start, | |
5697 Bytecount bytelength, | |
5698 Charcount charlength); | |
5699 void buffer_mule_signal_deleted_region (struct buffer *buf, Charbpos start, | |
826 | 5700 Charbpos end, Bytebpos byte_start, |
5701 Bytebpos byte_end); | |
771 | 5702 |
2367 | 5703 typedef struct |
5704 { | |
5705 const char *srctext; | |
5706 void *dst; | |
5707 Bytecount dst_size; | |
5708 } alloca_convert_vals; | |
5709 | |
5710 typedef struct | |
5711 { | |
5712 Dynarr_declare (alloca_convert_vals); | |
5713 } alloca_convert_vals_dynarr; | |
5714 | |
5715 extern alloca_convert_vals_dynarr *active_alloca_convert; | |
5716 | |
5717 MODULE_API int find_pos_of_existing_active_alloca_convert (const char * | |
5718 srctext); | |
5719 | |
771 | 5720 /* Defined in unicode.c */ |
1204 | 5721 extern const struct sized_memory_description to_unicode_description; |
5722 extern const struct sized_memory_description from_unicode_description; | |
771 | 5723 void init_charset_unicode_tables (Lisp_Object charset); |
5724 void free_charset_unicode_tables (Lisp_Object charset); | |
5725 void recalculate_unicode_precedence (void); | |
5726 extern Lisp_Object Qunicode; | |
4096 | 5727 extern Lisp_Object Qutf_16, Qutf_8, Qucs_4, Qutf_7, Qutf_32; |
771 | 5728 #ifdef MEMORY_USAGE_STATS |
5729 Bytecount compute_from_unicode_table_size (Lisp_Object charset, | |
5730 struct overhead_stats *stats); | |
5731 Bytecount compute_to_unicode_table_size (Lisp_Object charset, | |
5732 struct overhead_stats *stats); | |
5733 #endif /* MEMORY_USAGE_STATS */ | |
5734 | |
428 | 5735 /* Defined in undo.c */ |
826 | 5736 EXFUN (Fundo_boundary, 0); |
5737 | |
428 | 5738 Lisp_Object truncate_undo_list (Lisp_Object, int, int); |
5739 void record_extent (Lisp_Object, int); | |
665 | 5740 void record_insert (struct buffer *, Charbpos, Charcount); |
5741 void record_delete (struct buffer *, Charbpos, Charcount); | |
5742 void record_change (struct buffer *, Charbpos, Charcount); | |
428 | 5743 |
5744 /* Defined in unex*.c */ | |
814 | 5745 #ifdef WIN32_NATIVE |
867 | 5746 int unexec (Ibyte *, Ibyte *, uintptr_t, uintptr_t, uintptr_t); |
814 | 5747 #else |
5748 int unexec (Extbyte *, Extbyte *, uintptr_t, uintptr_t, uintptr_t); | |
5749 #endif | |
428 | 5750 #ifdef RUN_TIME_REMAP |
5751 int run_time_remap (char *); | |
5752 #endif | |
5753 | |
5754 /* Defined in vm-limit.c */ | |
442 | 5755 void memory_warnings (void *, void (*) (const char *)); |
428 | 5756 |
442 | 5757 /*--------------- prototypes for constant symbols ------------*/ |
5758 | |
826 | 5759 /* #### We should get rid of this and put the prototypes back up there in |
5760 #### the per-file stuff, where they belong. */ | |
5761 | |
771 | 5762 /* Use the following when you have to add a bunch of symbols. */ |
5763 | |
5764 /* | |
5765 | |
5766 (defun redo-symbols (beg end) | |
5767 "Snarf any symbols out of the region and print them into a temporary buffer, | |
5768 which is displayed when the function finishes. The symbols are laid out with | |
5769 `extern Lisp_Object ' before each one, with as many as can fit on one line | |
5770 \(the maximum line width is controlled by the constant `max-line-length' in the | |
5771 code)." | |
5772 (interactive "r") | |
5773 (save-excursion | |
5774 (goto-char beg) | |
5775 (let (syms) | |
5776 (while (re-search-forward "\\s-\\(Q[A-Za-z_0-9]+\\)" end t) | |
5777 (push (match-string 1) syms)) | |
5778 (setq syms (sort syms #'string-lessp)) | |
5779 (with-output-to-temp-buffer "*Symbols*" | |
5780 (let* ((col 0) | |
5781 (start "extern Lisp_Object ") | |
5782 (startlen (length start)) | |
5783 ;; with a default-width frame of 80 chars, you can only fit | |
5784 ;; 79 before wrapping. you can see this to a lower value if | |
5785 ;; you don't want it right up against the right margin. | |
5786 (max-line-length 79)) | |
5787 (dolist (sym syms) | |
5788 (cond (;; if something already on line (this will always be the | |
5789 ;; case except the very first iteration), see what | |
5790 ;; space we've got. (need to take into account 2 | |
5791 ;; for the comma+space, 1 for the semicolon at the | |
5792 ;; end.) if enough space, do it. | |
5793 (and (> col 0) (< (+ col (length sym) 2) | |
5794 (1- max-line-length))) | |
5795 (princ ", ") | |
5796 (princ sym) | |
5797 (incf col 2) | |
5798 (incf col (length sym))) | |
5799 (t | |
5800 ;; either we're first iteration or we ran out of space. | |
5801 ;; if the latter, terminate the previous line. this | |
5802 ;; loop is written on purpose so that it always prints | |
5803 ;; at least one item, even if that would go over. | |
5804 (when (> col 0) | |
5805 (princ ";\n") | |
5806 (setq col 0)) | |
5807 (princ start) | |
5808 (incf col startlen) | |
5809 (princ sym) | |
5810 (incf col (length sym))))) | |
5811 ;; finally terminate the last line. | |
5812 (princ ";\n")))))) | |
5813 | |
5814 */ | |
5815 | |
814 | 5816 extern Lisp_Object Qactivate_menubar_hook, Qand_optional, Qand_rest; |
5817 extern Lisp_Object Qarith_error, Qarrayp, Qautoload, Qbackground; | |
5818 extern Lisp_Object Qbackground_pixmap, Qbeginning_of_buffer, Qbitp, Qblinking; | |
5819 extern Lisp_Object Qbuffer_glyph_p, Qbuffer_live_p, Qbuffer_read_only; | |
5820 extern Lisp_Object Qbyte_code, Qcall_interactively, Qcategory_designator_p; | |
5821 extern Lisp_Object Qcategory_table_value_p, Qcdr, Qchar_or_string_p; | |
5822 extern Lisp_Object Qcharacterp, Qcircular_list, Qcircular_property_list; | |
5823 extern Lisp_Object Qcolor_pixmap_image_instance_p, Qcommandp; | |
5824 extern Lisp_Object Qcompletion_ignore_case, Qconsole_live_p, Qconst_specifier; | |
5825 extern Lisp_Object Qconversion_error, Qcurrent_menubar; | |
771 | 5826 extern Lisp_Object Qcyclic_variable_indirection, Qdefun, Qdevice_live_p, Qdim; |
5827 extern Lisp_Object Qdirection, Qdisabled, Qdisabled_command_hook; | |
930 | 5828 extern Lisp_Object Qdisplay_table, Qdll_error, Qdomain_error, Qediting_error; |
771 | 5829 extern Lisp_Object Qend_of_buffer, Qend_of_file, Qend_open, Qerror; |
5830 extern Lisp_Object Qerror_conditions, Qerror_lacks_explanatory_string; | |
5831 extern Lisp_Object Qerror_message, Qevent_live_p, Qexit, Qextent_live_p; | |
996 | 5832 extern Lisp_Object Qexternal_debugging_output, Qfeaturep, Qfile_error; |
5833 extern Lisp_Object Qfile_name_sans_extension, Qfinal; | |
1111 | 5834 extern Lisp_Object Qforeground, Qformat, Qframe_live_p, Qgraphic; |
771 | 5835 extern Lisp_Object Qgui_error, Qicon_glyph_p, Qidentity, Qinhibit_quit; |
5836 extern Lisp_Object Qinhibit_read_only, Qinteger_char_or_marker_p; | |
1632 | 5837 extern Lisp_Object Qinteger_or_char_p, Qinteger_or_marker_p; |
5838 extern Lisp_Object Qinteractive, Qinternal_error; | |
771 | 5839 extern Lisp_Object Qinvalid_byte_code, Qinvalid_change, Qinvalid_constant; |
5840 extern Lisp_Object Qinvalid_function, Qinvalid_operation; | |
5841 extern Lisp_Object Qinvalid_read_syntax, Qinvalid_state, Qio_error, Qlambda; | |
1111 | 5842 extern Lisp_Object Qlayout, Qlist_formation_error, Qlistp, Qload; |
771 | 5843 extern Lisp_Object Qlong_name, Qmacro, Qmakunbound, Qmalformed_list; |
996 | 5844 extern Lisp_Object Qmalformed_property_list, Qmark, Qmodule; |
771 | 5845 extern Lisp_Object Qmono_pixmap_image_instance_p, Qmouse_leave_buffer_hook; |
5846 extern Lisp_Object Qnative_layout, Qnatnump, Qnetwork_error, Qno_catch; | |
1983 | 5847 extern Lisp_Object Qnonnegativep, Qnothing_image_instance_p; |
5848 extern Lisp_Object Qnumber_char_or_marker_p, Qnumberp, Qout_of_memory; | |
442 | 5849 extern Lisp_Object Qoverflow_error, Qpoint, Qpointer_glyph_p; |
771 | 5850 extern Lisp_Object Qpointer_image_instance_p, Qprint_length; |
563 | 5851 extern Lisp_Object Qprint_string_length, Qprinting_unreadable_object; |
1632 | 5852 extern Lisp_Object Qprogn, Qquit, Qquote, Qrange_error; |
771 | 5853 extern Lisp_Object Qread_char, Qread_from_minibuffer; |
5854 extern Lisp_Object Qreally_early_error_handler, Qregion_beginning; | |
3659 | 5855 extern Lisp_Object Qregion_end, Qregistries, Qreverse_direction_charset; |
771 | 5856 extern Lisp_Object Qrun_hooks, Qsans_modifiers, Qsave_buffers_kill_emacs; |
5857 extern Lisp_Object Qself_insert_command, Qself_insert_defer_undo, Qsequencep; | |
5858 extern Lisp_Object Qset, Qsetting_constant, Qshort_name, Qsingularity_error; | |
5859 extern Lisp_Object Qsound_error, Qstack_overflow, Qstandard_input; | |
5860 extern Lisp_Object Qstandard_output, Qstart_open, Qstring_lessp; | |
5861 extern Lisp_Object Qstructure_formation_error, Qsubwindow; | |
1632 | 5862 extern Lisp_Object Qsubwindow_image_instance_p; |
771 | 5863 extern Lisp_Object Qtext_conversion_error, Qtext_image_instance_p, Qtop_level; |
1632 | 5864 extern Lisp_Object Qtrue_list_p, Qunderflow_error, Qunderline; |
771 | 5865 extern Lisp_Object Quser_files_and_directories, Qvalues; |
5866 extern Lisp_Object Qvariable_documentation, Qvariable_domain, Qvoid_function; | |
5867 extern Lisp_Object Qvoid_variable, Qwindow_live_p, Qwrong_number_of_arguments; | |
442 | 5868 extern Lisp_Object Qwrong_type_argument, Qyes_or_no_p; |
5869 | |
1632 | 5870 extern MODULE_API Lisp_Object Qintegerp, Qinvalid_argument, Qprocess_error; |
5871 extern MODULE_API Lisp_Object Qsyntax_error, Qt, Qunbound; | |
5872 | |
442 | 5873 #define SYMBOL(fou) extern Lisp_Object fou |
1632 | 5874 #define SYMBOL_MODULE_API(fou) extern MODULE_API Lisp_Object fou |
442 | 5875 #define SYMBOL_KEYWORD(la_cle_est_fou) extern Lisp_Object la_cle_est_fou |
5876 #define SYMBOL_GENERAL(tout_le_monde, est_fou) \ | |
5877 extern Lisp_Object tout_le_monde | |
5878 | |
5879 #include "general-slots.h" | |
5880 | |
5881 #undef SYMBOL | |
1632 | 5882 #undef SYMBOL_MODULE_API |
442 | 5883 #undef SYMBOL_KEYWORD |
5884 #undef SYMBOL_GENERAL | |
5885 | |
5886 /*--------------- prototypes for variables of type Lisp_Object ------------*/ | |
5887 | |
826 | 5888 /* #### We should get rid of this and put the prototypes back up there in |
5889 #### the per-file stuff, where they belong. */ | |
5890 | |
446 | 5891 extern Lisp_Object Vactivate_menubar_hook; |
5892 extern Lisp_Object Vautoload_queue, Vblank_menubar; | |
771 | 5893 extern Lisp_Object Vcommand_history; |
428 | 5894 extern Lisp_Object Vcommand_line_args, Vconfigure_info_directory; |
5895 extern Lisp_Object Vconfigure_site_directory, Vconfigure_site_module_directory; | |
5896 extern Lisp_Object Vconsole_list, Vcontrolling_terminal; | |
5897 extern Lisp_Object Vcurrent_compiled_function_annotation, Vcurrent_load_list; | |
5898 extern Lisp_Object Vcurrent_mouse_event, Vcurrent_prefix_arg, Vdata_directory; | |
434 | 5899 extern Lisp_Object Vdirectory_sep_char, Vdisabled_command_hook; |
5900 extern Lisp_Object Vdoc_directory, Vinternal_doc_file_name; | |
428 | 5901 extern Lisp_Object Vecho_area_buffer, Vemacs_major_version; |
5902 extern Lisp_Object Vemacs_minor_version, Vexec_directory, Vexec_path; | |
5903 extern Lisp_Object Vexecuting_macro, Vfeatures, Vfile_domain; | |
1927 | 5904 extern Lisp_Object Vinvocation_directory, Vinvocation_name; |
771 | 5905 extern Lisp_Object Vlast_command, Vlast_command_char; |
428 | 5906 extern Lisp_Object Vlast_command_event, Vlast_input_event; |
2548 | 5907 extern Lisp_Object Vload_file_name_internal, Vload_history; |
428 | 5908 extern Lisp_Object Vload_path, Vmark_even_if_inactive, Vmenubar_configuration; |
5909 extern Lisp_Object Vminibuf_preprompt, Vminibuf_prompt, Vminibuffer_zero; | |
5910 extern Lisp_Object Vmodule_directory, Vmswindows_downcase_file_names; | |
5911 extern Lisp_Object Vmswindows_get_true_file_attributes, Vobarray; | |
5912 extern Lisp_Object Vprint_length, Vprint_level, Vprocess_environment; | |
5913 extern Lisp_Object Vrecent_keys_ring, Vshell_file_name, Vsite_directory; | |
5914 extern Lisp_Object Vsite_module_directory; | |
5915 extern Lisp_Object Vstandard_input, Vstandard_output, Vstdio_str; | |
771 | 5916 extern Lisp_Object Vsynchronous_sounds, Vsystem_name; |
428 | 5917 extern Lisp_Object Vthis_command_keys, Vunread_command_event; |
5918 extern Lisp_Object Vx_initial_argv_list; | |
5919 | |
1927 | 5920 extern MODULE_API Lisp_Object Vinhibit_quit, Vquit_flag; |
5921 | |
1743 | 5922 END_C_DECLS |
1650 | 5923 |
440 | 5924 #endif /* INCLUDED_lisp_h_ */ |