mirror of
https://git.savannah.gnu.org/git/emacs.git
synced 2025-01-05 11:45:45 +00:00
(enum Lisp_Type): Delete Lisp_Buffer.
(enum Lisp_Misc_Type): Add Lisp_Misc_Float (not yet used). (XSETBUFFER, BUFFERP, GC_BUFFERP): Rewrite to use pseudovectors. (PVEC_BUFFER, PVEC_PROCESS, PVEC_FRAME, PVEC_COMPILED) (PVEC_WINDOW, PVEC_WINDOW_CONFIGURATION, PVEC_SUBR): Now enumeration constants, not macros. (PVEC_FLAG): Enumeration alias for PSEUDOVECTOR_FLAG.
This commit is contained in:
parent
d281a86afb
commit
99a3d506c1
114
src/lisp.h
114
src/lisp.h
@ -26,16 +26,16 @@ the Free Software Foundation, 675 Mass Ave, Cambridge, MA 02139, USA. */
|
||||
#define EMACS_UINT unsigned int
|
||||
#endif
|
||||
|
||||
/* Define the fundamental Lisp data structures */
|
||||
/* Define the fundamental Lisp data structures. */
|
||||
|
||||
/* This is the set of Lisp data types */
|
||||
/* This is the set of Lisp data types. */
|
||||
|
||||
enum Lisp_Type
|
||||
{
|
||||
/* Integer. XINT(obj) is the integer value. */
|
||||
/* Integer. XINT (obj) is the integer value. */
|
||||
Lisp_Int,
|
||||
|
||||
/* Symbol. XSYMBOL (object) points to a struct Lisp_Symbol. */
|
||||
/* Symbol. XSYMBOL (object) points to a struct Lisp_Symbol. */
|
||||
Lisp_Symbol,
|
||||
|
||||
/* Miscellaneous. XMISC (object) points to a union Lisp_Misc,
|
||||
@ -43,7 +43,7 @@ enum Lisp_Type
|
||||
Lisp_Misc,
|
||||
|
||||
/* String. XSTRING (object) points to a struct Lisp_String.
|
||||
The length of the string, and its contents, are stored therein. */
|
||||
The length of the string, and its contents, are stored therein. */
|
||||
Lisp_String,
|
||||
|
||||
/* Vector of Lisp objects, or something resembling it.
|
||||
@ -52,12 +52,9 @@ enum Lisp_Type
|
||||
information, if it's not a real vector object. */
|
||||
Lisp_Vectorlike,
|
||||
|
||||
/* Cons. XCONS (object) points to a struct Lisp_Cons. */
|
||||
/* Cons. XCONS (object) points to a struct Lisp_Cons. */
|
||||
Lisp_Cons,
|
||||
|
||||
/* Editor buffer. XBUFFER (obj) points to a struct buffer. */
|
||||
Lisp_Buffer,
|
||||
|
||||
#ifdef LISP_FLOAT_TYPE
|
||||
Lisp_Float,
|
||||
#endif /* LISP_FLOAT_TYPE */
|
||||
@ -78,7 +75,12 @@ enum Lisp_Misc_Type
|
||||
Lisp_Misc_Buffer_Objfwd,
|
||||
Lisp_Misc_Buffer_Local_Value,
|
||||
Lisp_Misc_Some_Buffer_Local_Value,
|
||||
Lisp_Misc_Overlay
|
||||
Lisp_Misc_Overlay,
|
||||
/* Currently floats are not a misc type,
|
||||
but let's define this in case we want to change that. */
|
||||
Lisp_Misc_Float,
|
||||
/* This is not a type code. It is for range checking. */
|
||||
Lisp_Misc_Limit
|
||||
};
|
||||
|
||||
#ifndef NO_UNION_TYPE
|
||||
@ -91,7 +93,7 @@ typedef
|
||||
union Lisp_Object
|
||||
{
|
||||
/* Used for comparing two Lisp_Objects;
|
||||
also, positive integers can be accessed fast this way. */
|
||||
also, positive integers can be accessed fast this way. */
|
||||
int i;
|
||||
|
||||
struct
|
||||
@ -121,7 +123,7 @@ typedef
|
||||
union Lisp_Object
|
||||
{
|
||||
/* Used for comparing two Lisp_Objects;
|
||||
also, positive integers can be accessed fast this way. */
|
||||
also, positive integers can be accessed fast this way. */
|
||||
int i;
|
||||
|
||||
struct
|
||||
@ -203,13 +205,19 @@ Lisp_Object;
|
||||
/* In a pseudo-vector, the size field actually contains a word with one
|
||||
PSEUDOVECTOR_FLAG bit set, and exactly one of the following bits to
|
||||
indicate the actual type. */
|
||||
#define PVEC_BUFFER 0x100
|
||||
#define PVEC_PROCESS 0x200
|
||||
#define PVEC_FRAME 0x400
|
||||
#define PVEC_COMPILED 0x800
|
||||
#define PVEC_WINDOW 0x1000
|
||||
#define PVEC_WINDOW_CONFIGURATION 0x2000
|
||||
#define PVEC_SUBR 0x4000
|
||||
enum pvec_type
|
||||
{
|
||||
PVEC_NORMAL_VECTOR = 0,
|
||||
PVEC_BUFFER = 0x100,
|
||||
PVEC_PROCESS = 0x200,
|
||||
PVEC_FRAME = 0x400,
|
||||
PVEC_COMPILED = 0x800,
|
||||
PVEC_WINDOW = 0x1000,
|
||||
PVEC_WINDOW_CONFIGURATION = 0x2000,
|
||||
PVEC_SUBR = 0x4000,
|
||||
PVEC_TYPE_MASK = 0x7f00,
|
||||
PVEC_FLAG = PSEUDOVECTOR_FLAG,
|
||||
};
|
||||
|
||||
/* For convenience, we also store the number of elements in these bits. */
|
||||
#define PSEUDOVECTOR_SIZE_MASK 0xff
|
||||
@ -222,7 +230,7 @@ you lose
|
||||
|
||||
/* These macros extract various sorts of values from a Lisp_Object.
|
||||
For example, if tem is a Lisp_Object whose type is Lisp_Cons,
|
||||
XCONS (tem) is the struct Lisp_Cons * pointing to the memory for that cons. */
|
||||
XCONS (tem) is the struct Lisp_Cons * pointing to the memory for that cons. */
|
||||
|
||||
#ifdef NO_UNION_TYPE
|
||||
|
||||
@ -355,9 +363,9 @@ extern int pure_size;
|
||||
|
||||
#endif /* NO_UNION_TYPE */
|
||||
|
||||
/* Extract a value or address from a Lisp_Object. */
|
||||
|
||||
#define XCONS(a) ((struct Lisp_Cons *) XPNTR(a))
|
||||
#define XBUFFER(a) ((struct buffer *) XPNTR(a))
|
||||
#define XVECTOR(a) ((struct Lisp_Vector *) XPNTR(a))
|
||||
#define XSTRING(a) ((struct Lisp_String *) XPNTR(a))
|
||||
#define XSYMBOL(a) ((struct Lisp_Symbol *) XPNTR(a))
|
||||
@ -377,10 +385,13 @@ extern int pure_size;
|
||||
#define XPROCESS(a) ((struct Lisp_Process *) XPNTR(a))
|
||||
#define XWINDOW(a) ((struct window *) XPNTR(a))
|
||||
#define XSUBR(a) ((struct Lisp_Subr *) XPNTR(a))
|
||||
#define XBUFFER(a) ((struct buffer *) XPNTR(a))
|
||||
|
||||
|
||||
/* Construct a Lisp_Object from a value or address. */
|
||||
|
||||
#define XSETINT(a, b) XSET (a, Lisp_Int, b)
|
||||
#define XSETCONS(a, b) XSET (a, Lisp_Cons, b)
|
||||
#define XSETBUFFER(a, b) XSET (a, Lisp_Buffer, b)
|
||||
#define XSETVECTOR(a, b) XSET (a, Lisp_Vectorlike, b)
|
||||
#define XSETSTRING(a, b) XSET (a, Lisp_String, b)
|
||||
#define XSETSYMBOL(a, b) XSET (a, Lisp_Symbol, b)
|
||||
@ -399,18 +410,19 @@ extern int pure_size;
|
||||
#define XSETWINDOW(a, b) (XSETPSEUDOVECTOR (a, b, PVEC_WINDOW))
|
||||
#define XSETSUBR(a, b) (XSETPSEUDOVECTOR (a, b, PVEC_SUBR))
|
||||
#define XSETCOMPILED(a, b) (XSETPSEUDOVECTOR (a, b, PVEC_COMPILED))
|
||||
#define XSETBUFFER(a, b) (XSETPSEUDOVECTOR (a, b, PVEC_BUFFER))
|
||||
|
||||
#ifdef USE_TEXT_PROPERTIES
|
||||
/* Basic data type for use of intervals. See the macros in intervals.h */
|
||||
/* Basic data type for use of intervals. See the macros in intervals.h. */
|
||||
|
||||
struct interval
|
||||
{
|
||||
/* The first group of entries deal with the tree structure. */
|
||||
/* The first group of entries deal with the tree structure. */
|
||||
|
||||
unsigned int total_length; /* Length of myself and both children. */
|
||||
unsigned int position; /* Cache of interval's character position */
|
||||
struct interval *left; /* Intervals which precede me. */
|
||||
struct interval *right; /* Intervals which succeed me. */
|
||||
unsigned int total_length; /* Length of myself and both children. */
|
||||
unsigned int position; /* Cache of interval's character position. */
|
||||
struct interval *left; /* Intervals which precede me. */
|
||||
struct interval *right; /* Intervals which succeed me. */
|
||||
|
||||
/* Parent in the tree, or the Lisp_Object containing this interval tree.
|
||||
|
||||
@ -426,13 +438,13 @@ struct interval
|
||||
|
||||
/* The remaining components are `properties' of the interval.
|
||||
The first four are duplicates for things which can be on the list,
|
||||
for purposes of speed. */
|
||||
for purposes of speed. */
|
||||
|
||||
unsigned char write_protect; /* Non-zero means can't modify. */
|
||||
unsigned char visible; /* Zero means don't display. */
|
||||
unsigned char visible; /* Zero means don't display. */
|
||||
unsigned char front_sticky; /* Non-zero means text inserted just
|
||||
before this interval goes into it. */
|
||||
unsigned char rear_sticky; /* Likewise for just after it. */
|
||||
before this interval goes into it. */
|
||||
unsigned char rear_sticky; /* Likewise for just after it. */
|
||||
|
||||
/* Properties of this interval.
|
||||
The mark bit on this field says whether this particular interval
|
||||
@ -449,16 +461,16 @@ typedef struct interval *INTERVAL;
|
||||
x = wrong_type_argument (Qbuffer_or_string_p, (x)); }
|
||||
|
||||
/* Macro used to conditionally compile intervals into certain data
|
||||
structures. See, e.g., struct Lisp_String below. */
|
||||
structures. See, e.g., struct Lisp_String below. */
|
||||
#define DECLARE_INTERVALS INTERVAL intervals;
|
||||
|
||||
/* Macro used to conditionally compile interval initialization into
|
||||
certain code. See, e.g., alloc.c. */
|
||||
certain code. See, e.g., alloc.c. */
|
||||
#define INITIALIZE_INTERVAL(ptr,val) ptr->intervals = val
|
||||
|
||||
#else /* No text properties */
|
||||
|
||||
/* If no intervals are used, make the above definitions go away. */
|
||||
/* If no intervals are used, make the above definitions go away. */
|
||||
|
||||
#define CHECK_STRING_OR_BUFFER(x, i)
|
||||
|
||||
@ -490,7 +502,7 @@ struct Lisp_Buffer_Cons
|
||||
struct Lisp_String
|
||||
{
|
||||
EMACS_INT size;
|
||||
DECLARE_INTERVALS /* `data' field must be last. */
|
||||
DECLARE_INTERVALS /* `data' field must be last. */
|
||||
unsigned char data[1];
|
||||
};
|
||||
|
||||
@ -611,7 +623,7 @@ struct Lisp_Buffer_Objfwd
|
||||
variable).
|
||||
|
||||
If we want to examine or set the value and BUFFER is current,
|
||||
we just examine or set REALVALUE. If BUFFER is not current, we
|
||||
we just examine or set REALVALUE. If BUFFER is not current, we
|
||||
store the current REALVALUE value into CURRENT-ALIST-ELEMENT,
|
||||
then find the appropriate alist element for the buffer now
|
||||
current and set up CURRENT-ALIST-ELEMENT. Then we set
|
||||
@ -671,7 +683,7 @@ struct Lisp_Float
|
||||
#endif /* LISP_FLOAT_TYPE */
|
||||
|
||||
/* A character, declared with the following typedef, is a member
|
||||
of some character set associated with the current buffer. */
|
||||
of some character set associated with the current buffer. */
|
||||
#ifndef _UCHAR_T /* Protect against something in ctab.h on AIX. */
|
||||
#define _UCHAR_T
|
||||
typedef unsigned char UCHAR;
|
||||
@ -790,8 +802,6 @@ typedef unsigned char UCHAR;
|
||||
#define GC_STRINGP(x) (XGCTYPE ((x)) == Lisp_String)
|
||||
#define CONSP(x) (XTYPE ((x)) == Lisp_Cons)
|
||||
#define GC_CONSP(x) (XGCTYPE ((x)) == Lisp_Cons)
|
||||
#define BUFFERP(x) (XTYPE ((x)) == Lisp_Buffer)
|
||||
#define GC_BUFFERP(x) (XGCTYPE ((x)) == Lisp_Buffer)
|
||||
|
||||
#ifdef LISP_FLOAT_TYPE
|
||||
#define FLOATP(x) (XTYPE ((x)) == Lisp_Float)
|
||||
@ -844,6 +854,8 @@ typedef unsigned char UCHAR;
|
||||
#define GC_SUBRP(x) GC_PSEUDOVECTORP (x, PVEC_SUBR)
|
||||
#define COMPILEDP(x) PSEUDOVECTORP (x, PVEC_COMPILED)
|
||||
#define GC_COMPILEDP(x) GC_PSEUDOVECTORP (x, PVEC_COMPILED)
|
||||
#define BUFFERP(x) PSEUDOVECTORP (x, PVEC_BUFFER)
|
||||
#define GC_BUFFERP(x) GC_PSEUDOVECTORP (x, PVEC_BUFFER)
|
||||
|
||||
#ifdef MULTI_FRAME
|
||||
#define FRAMEP(x) PSEUDOVECTORP (x, PVEC_FRAME)
|
||||
@ -983,7 +995,7 @@ typedef unsigned char UCHAR;
|
||||
#else
|
||||
|
||||
/* This version of DEFUN declares a function prototype with the right
|
||||
arguments, so we can catch errors with maxargs at compile-time. */
|
||||
arguments, so we can catch errors with maxargs at compile-time. */
|
||||
#define DEFUN(lname, fnname, sname, minargs, maxargs, prompt, doc) \
|
||||
Lisp_Object fnname DEFUN_ARGS_ ## maxargs ; \
|
||||
struct Lisp_Subr sname = \
|
||||
@ -992,7 +1004,7 @@ typedef unsigned char UCHAR;
|
||||
Lisp_Object fnname
|
||||
|
||||
/* Note that the weird token-substitution semantics of ANSI C makes
|
||||
this work for MANY and UNEVALLED. */
|
||||
this work for MANY and UNEVALLED. */
|
||||
#define DEFUN_ARGS_MANY (int, Lisp_Object *)
|
||||
#define DEFUN_ARGS_UNEVALLED (Lisp_Object)
|
||||
#define DEFUN_ARGS_0 (void)
|
||||
@ -1009,7 +1021,7 @@ typedef unsigned char UCHAR;
|
||||
#endif
|
||||
|
||||
/* defsubr (Sname);
|
||||
is how we define the symbol for function `name' at start-up time. */
|
||||
is how we define the symbol for function `name' at start-up time. */
|
||||
extern void defsubr ();
|
||||
|
||||
#define MANY -2
|
||||
@ -1082,7 +1094,7 @@ extern Lisp_Object memory_signal_data;
|
||||
Tells GC how to save a copy of the stack. */
|
||||
extern char *stack_bottom;
|
||||
|
||||
/* Check quit-flag and quit if it is non-nil. */
|
||||
/* Check quit-flag and quit if it is non-nil. */
|
||||
|
||||
#define QUIT \
|
||||
if (!NILP (Vquit_flag) && NILP (Vinhibit_quit)) \
|
||||
@ -1117,7 +1129,7 @@ extern char *stack_bottom;
|
||||
|
||||
#define UPCASE1(CH) (XSTRING (current_buffer->upcase_table)->data[CH])
|
||||
|
||||
/* Downcase a character, or make no change if that cannot be done. */
|
||||
/* Downcase a character, or make no change if that cannot be done. */
|
||||
|
||||
#define DOWNCASE(CH) (XSTRING (current_buffer->downcase_table)->data[CH])
|
||||
|
||||
@ -1132,15 +1144,15 @@ extern char *stack_bottom;
|
||||
extern Lisp_Object Vascii_downcase_table, Vascii_upcase_table;
|
||||
extern Lisp_Object Vascii_canon_table, Vascii_eqv_table;
|
||||
|
||||
/* number of bytes of structure consed since last GC */
|
||||
/* Number of bytes of structure consed since last GC. */
|
||||
|
||||
extern int consing_since_gc;
|
||||
|
||||
/* threshold for doing another gc */
|
||||
/* Threshold for doing another gc. */
|
||||
|
||||
extern int gc_cons_threshold;
|
||||
|
||||
/* Structure for recording stack slots that need marking */
|
||||
/* Structure for recording stack slots that need marking. */
|
||||
|
||||
/* This is a chain of structures, each of which points at a Lisp_Object variable
|
||||
whose value should be marked in garbage collection.
|
||||
@ -1151,7 +1163,7 @@ extern int gc_cons_threshold;
|
||||
link disappears.
|
||||
|
||||
Every function that can call Feval must protect in this fashion all
|
||||
Lisp_Object variables whose contents will be used again. */
|
||||
Lisp_Object variables whose contents will be used again. */
|
||||
|
||||
extern struct gcpro *gcprolist;
|
||||
|
||||
@ -1192,7 +1204,7 @@ struct gcpro
|
||||
gcpro5.next = &gcpro4; gcpro5.var = &varname5; gcpro5.nvars = 1; \
|
||||
gcprolist = &gcpro5; }
|
||||
|
||||
/* Call staticpro (&var) to protect static variable `var'. */
|
||||
/* Call staticpro (&var) to protect static variable `var'. */
|
||||
|
||||
void staticpro();
|
||||
|
||||
@ -1517,7 +1529,7 @@ void shut_down_emacs ( /* int signal, int no_x, Lisp_Object stuff */ );
|
||||
extern int noninteractive;
|
||||
/* Nonzero means don't do use window-system-specific display code */
|
||||
extern int inhibit_window_system;
|
||||
/* Nonzero means that a filter or a sentinel is running. */
|
||||
/* Nonzero means that a filter or a sentinel is running. */
|
||||
extern int running_asynch_code;
|
||||
|
||||
/* defined in process.c */
|
||||
|
Loading…
Reference in New Issue
Block a user