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