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