28 lines
		
	
	
		
			659 B
		
	
	
	
		
			C
		
	
	
	
			
		
		
	
	
			28 lines
		
	
	
		
			659 B
		
	
	
	
		
			C
		
	
	
	
| /* 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) {\
 | |
|     register t = TYPE(x);\
 | |
|     if (!Numeric (t)) Wrong_Type_Combination (x, "number");\
 | |
| }
 | |
| 
 | |
| /* This should be renamed; it checks whether x is an *exact* integer.
 | |
|  */
 | |
| #define Check_Integer(x) {\
 | |
|     register t = TYPE(x);\
 | |
|     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");\
 | |
| }
 |