2003-08-30 12:47:54 -04:00
|
|
|
/* misc.h
|
|
|
|
*
|
|
|
|
* $Id$
|
|
|
|
*
|
|
|
|
* Copyright 1990, 1991, 1992, 1993, 1994, 1995, Oliver Laumann, Berlin
|
|
|
|
* Copyright 2002, 2003 Sam Hocevar <sam@zoy.org>, Paris
|
|
|
|
*
|
|
|
|
* This software was derived from Elk 1.2, which was Copyright 1987, 1988,
|
|
|
|
* 1989, Nixdorf Computer AG and TELES GmbH, Berlin (Elk 1.2 has been written
|
|
|
|
* by Oliver Laumann for TELES Telematic Services, Berlin, in a joint project
|
|
|
|
* between TELES and Nixdorf Microprocessor Engineering, Berlin).
|
|
|
|
*
|
|
|
|
* Oliver Laumann, TELES GmbH, Nixdorf Computer AG and Sam Hocevar, as co-
|
|
|
|
* owners or individual owners of copyright in this software, grant to any
|
|
|
|
* person or company a worldwide, royalty free, license to
|
|
|
|
*
|
|
|
|
* i) copy this software,
|
|
|
|
* ii) prepare derivative works based on this software,
|
|
|
|
* iii) distribute copies of this software or derivative works,
|
|
|
|
* iv) perform this software, or
|
|
|
|
* v) display this software,
|
|
|
|
*
|
|
|
|
* provided that this notice is not removed and that neither Oliver Laumann
|
|
|
|
* nor Teles nor Nixdorf are deemed to have made any representations as to
|
|
|
|
* the suitability of this software for any purpose nor are held responsible
|
|
|
|
* for any defects of this software.
|
|
|
|
*
|
|
|
|
* THERE IS ABSOLUTELY NO WARRANTY FOR THIS SOFTWARE.
|
|
|
|
*/
|
|
|
|
|
2003-09-17 09:18:59 -04:00
|
|
|
extern_c Object elk_import False2;
|
2003-08-19 15:19:38 -04:00
|
|
|
|
|
|
|
#define Nullp(x) (TYPE(x) == T_Null)
|
|
|
|
#define Truep(x) (!EQ(x,False) && !EQ(x,False2))
|
|
|
|
#define Car(x) PAIR(x)->car
|
|
|
|
#define Cdr(x) PAIR(x)->cdr
|
|
|
|
#define Cons P_Cons
|
|
|
|
#define Begin P_Begin
|
|
|
|
#define Assq(x,y) General_Assoc(x,y,0)
|
|
|
|
#define Print(x) General_Print_Object (x, Curr_Output_Port, 0)
|
|
|
|
#define Numeric(t) (t == T_Fixnum || t == T_Flonum || t == T_Bignum)
|
|
|
|
|
2003-09-26 08:17:33 -04:00
|
|
|
#define Whitespace(c) (c == ' ' || c == '\t' || c == '\014' || c == '\n' || c == '\r')
|
2003-08-19 15:19:38 -04:00
|
|
|
#define Delimiter(c) (c == ';' || c == ')' || c == '(' || c == '"')
|
|
|
|
|
|
|
|
|
|
|
|
/* Align heap addresses */
|
|
|
|
#ifdef ALIGN_8BYTE
|
2003-09-26 11:02:53 -04:00
|
|
|
# define ELK_ALIGN(ptr) ((ptr) = (void *)(((intptr_t)(ptr) + 7) & ~7))
|
2003-08-19 15:19:38 -04:00
|
|
|
#else
|
2003-09-26 11:02:53 -04:00
|
|
|
# define ELK_ALIGN(ptr) ((ptr) = (void *)(((intptr_t)(ptr) + 3) & ~3))
|
2003-08-19 15:19:38 -04:00
|
|
|
#endif
|
|
|
|
|
|
|
|
/* Normalize stack addresses */
|
2003-09-06 11:30:43 -04:00
|
|
|
#define NORM(addr) ((intptr_t)(addr) + delta)
|
2003-08-19 15:19:38 -04:00
|
|
|
|
|
|
|
|
|
|
|
/* Used in special forms: */
|
|
|
|
extern int Tail_Call;
|
|
|
|
|
2003-08-19 15:24:23 -04:00
|
|
|
#define TC_Prolog register int _t = Tail_Call
|
2003-08-19 15:19:38 -04:00
|
|
|
#define TC_Disable Tail_Call = 0
|
|
|
|
#define TC_Enable Tail_Call = _t
|
|
|
|
|
|
|
|
|
|
|
|
/* Macros to be used by readers registered with Define_Reader().
|
|
|
|
* They operate on variables c, port, f, and str.
|
|
|
|
*/
|
|
|
|
#define Reader_Getc {\
|
|
|
|
c = str ? String_Getc (port) : getc (f);\
|
|
|
|
if (c == '\n') PORT(port)->lno++;\
|
|
|
|
}
|
|
|
|
|
|
|
|
#define Reader_Ungetc {\
|
|
|
|
if (str) String_Ungetc (port,c); else (void)ungetc (c,f);\
|
|
|
|
if (c == '\n') if (PORT(port)->lno > 1) PORT(port)->lno--;\
|
|
|
|
}
|
|
|
|
|
|
|
|
#define Reader_Tweak_Stream {\
|
|
|
|
if (!str && (feof (f) || ferror (f))) clearerr (f);\
|
|
|
|
}
|
|
|
|
|
|
|
|
#define Reader_Sharp_Eof {\
|
|
|
|
Reader_Tweak_Stream;\
|
|
|
|
Reader_Error (port, "end of file after `#'");\
|
|
|
|
}
|