2003-08-19 15:19:38 -04:00
|
|
|
/* Miscellaneous macros for type-checking Scheme objects.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#define Check_Type(x,t) {\
|
|
|
|
if (TYPE(x) != t) Wrong_Type (x, t);\
|
|
|
|
}
|
|
|
|
|
|
|
|
#define Check_List(x) {\
|
|
|
|
if (TYPE(x) != T_Pair && !Nullp (x)) Wrong_Type_Combination (x, "list");\
|
|
|
|
}
|
|
|
|
|
|
|
|
#define Check_Number(x) {\
|
2003-08-19 15:24:23 -04:00
|
|
|
register int t = TYPE(x);\
|
2003-08-19 15:19:38 -04:00
|
|
|
if (!Numeric (t)) Wrong_Type_Combination (x, "number");\
|
|
|
|
}
|
|
|
|
|
|
|
|
/* This should be renamed; it checks whether x is an *exact* integer.
|
|
|
|
*/
|
|
|
|
#define Check_Integer(x) {\
|
2003-08-19 15:24:23 -04:00
|
|
|
register int t = TYPE(x);\
|
2003-08-19 15:19:38 -04:00
|
|
|
if (t != T_Fixnum && t != T_Bignum) Wrong_Type (x, T_Fixnum);\
|
|
|
|
}
|
|
|
|
|
|
|
|
#define Check_Mutable(x) {\
|
|
|
|
if (ISCONST(x))\
|
|
|
|
Primitive_Error ("attempt to modify constant");\
|
|
|
|
}
|