Mercurial > hg > xemacs-beta
diff src/lisp-union.h @ 442:abe6d1db359e r21-2-36
Import from CVS: tag r21-2-36
author | cvs |
---|---|
date | Mon, 13 Aug 2007 11:35:02 +0200 |
parents | 3ecd8885ac67 |
children | af57a77cbc92 |
line wrap: on
line diff
--- a/src/lisp-union.h Mon Aug 13 11:33:40 2007 +0200 +++ b/src/lisp-union.h Mon Aug 13 11:35:02 2007 +0200 @@ -30,7 +30,7 @@ union Lisp_Object { /* if non-valbits are at lower addresses */ -#if defined(WORDS_BIGENDIAN) +#ifdef WORDS_BIGENDIAN struct { EMACS_UINT val : VALBITS; @@ -76,7 +76,7 @@ GCC to accept any (yes, any) pointer as the argument of a function declared to accept a Lisp_Object. */ struct nosuchstruct *v; - CONST struct nosuchstruct *cv; + const struct nosuchstruct *cv; } Lisp_Object; @@ -94,27 +94,36 @@ xset_var->gu.type = Lisp_Type_Char; \ xset_var->gu.val = xset_value; \ } while (0) -# define XSETOBJ(var, vartype, value) do { \ +# define XSETOBJ(var, value) do { \ EMACS_UINT xset_value = (EMACS_UINT) (value); \ (var).ui = xset_value; \ } while (0) # define XPNTRVAL(x) ((x).ui) -INLINE Lisp_Object make_int (EMACS_INT val); -INLINE Lisp_Object +INLINE_HEADER Lisp_Object make_int (EMACS_INT val); +INLINE_HEADER Lisp_Object make_int (EMACS_INT val) { Lisp_Object obj; - XSETINT(obj, val); + XSETINT (obj, val); return obj; } -INLINE Lisp_Object make_char (Emchar val); -INLINE Lisp_Object +INLINE_HEADER Lisp_Object make_char (Emchar val); +INLINE_HEADER Lisp_Object make_char (Emchar val) { Lisp_Object obj; - XSETCHAR(obj, val); + XSETCHAR (obj, val); + return obj; +} + +INLINE_HEADER Lisp_Object wrap_object (void *ptr); +INLINE_HEADER Lisp_Object +wrap_object (void *ptr) +{ + Lisp_Object obj; + XSETOBJ (obj, ptr); return obj; } @@ -136,9 +145,9 @@ #define VOID_TO_LISP(larg,varg) \ ((void) ((larg).v = (struct nosuchstruct *) (varg))) #define CVOID_TO_LISP(larg,varg) \ - ((void) ((larg).cv = (CONST struct nosuchstruct *) (varg))) + ((void) ((larg).cv = (const struct nosuchstruct *) (varg))) #define LISP_TO_VOID(larg) ((void *) ((larg).v)) -#define LISP_TO_CVOID(larg) ((CONST void *) ((larg).cv)) +#define LISP_TO_CVOID(larg) ((const void *) ((larg).cv)) /* Convert a Lisp_Object into something that can't be used as an lvalue. Useful for type-checking. */