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