DataMuseum.dk

Presents historical artifacts from the history of:

DKUUG/EUUG Conference tapes

This is an automatic "excavation" of a thematic subset of
artifacts from Datamuseum.dk's BitArchive.

See our Wiki for more about DKUUG/EUUG Conference tapes

Excavated with: AutoArchaeologist - Free & Open Source Software.


top - download
Index: ┃ T p

⟦cf1e435ba⟧ TextFile

    Length: 5605 (0x15e5)
    Types: TextFile
    Names: »primitive.h«

Derivation

└─⟦a0efdde77⟧ Bits:30001252 EUUGD11 Tape, 1987 Spring Conference Helsinki
    └─ ⟦this⟧ »EUUGD11/gnu-31mar87/scheme/microcode/primitive.h« 

TextFile

/*          Hey EMACS, this is -*- C -*- code!                 */

/****************************************************************
*                                                               *
*                         Copyright (c) 1984                    *
*               Massachusetts Institute of Technology           *
*                                                               *
* This material was developed by the Scheme project at the      *
* Massachusetts Institute of Technology, Department of          *
* Electrical Engineering and Computer Science.  Permission to   *
* copy this software, to redistribute it, and to use it for any *
* purpose is granted, subject to the following restrictions and *
* understandings.                                               *
*                                                               *
* 1. Any copy made of this software must include this copyright *
* notice in full.                                               *
*                                                               *
* 2. Users of this software agree to make their best efforts (a)*
* to return to the MIT Scheme project any improvements or       *
* extensions that they make, so that these may be included in   *
* future releases; and (b) to inform MIT of noteworthy uses of  *
* this software.                                                *
*                                                               *
* 3.  All materials developed as a consequence of the use of    *
* this software shall duly acknowledge such use, in accordance  *
* with the usual standards of acknowledging credit in academic  *
* research.                                                     *
*                                                               *
* 4. MIT has made no warrantee or representation that the       *
* operation of this software will be error-free, and MIT is     *
* under no obligation to provide any services, by way of        *
* maintenance, update, or otherwise.                            *
*                                                               *
* 5.  In conjunction with products arising from the use of this *
* material, there shall be no use of the name of the            *
* Massachusetts Institute of Technology nor of any adaptation   *
* thereof in any advertising, promotional, or sales literature  *
* without prior written consent from MIT in each case.          *
*                                                               *
****************************************************************/

/* File: PRIMITIVE.H
 * This file contains some macros for defining primitives,
 * for argument type or value checking, and for accessing
 * the arguments.
 */

\f


/* Definition of primitives.  See storage.c for some information. */

#define Define_Primitive(C_Name, Number_of_args, Scheme_Name)	\
extern Pointer C_Name();					\
Pointer C_Name()

#define Built_In_Primitive(C_Name, Number_of_args, Scheme_Name)	\
Define_Primitive(C_Name, Number_of_args, Scheme_Name)

extern Pointer Not_Implemented_Yet();

#define NIY(C_Name, Number_of_args, Scheme_Name)		\
Built_In_Primitive(C_Name, Number_of_args, Scheme_Name)		\
{ return Not_Implemented_Yet(Scheme_Name);			\
}

/* Preambles for primitive procedures.  These store the arguments into
 * local variables for fast access.
 */

#define Primitive_0_Args()

#define Primitive_1_Args()	fast Pointer Arg1;		\
                                Arg1 = Stack_Pointer[0]

#define Primitive_2_Args()      fast Pointer Arg1, Arg2;	\
                                Arg1 = Stack_Pointer[0];	\
                                Arg2 = Stack_Pointer[1]

#define Primitive_3_Args()      fast Pointer Arg1, Arg2, Arg3;	\
                                Arg1 = Stack_Pointer[0];	\
                                Arg2 = Stack_Pointer[1];	\
                                Arg3 = Stack_Pointer[2]

#define Primitive_1_Arg()	Primitive_1_Args()
\f


/* Various utilities */

#define Primitive_Error(Err_No)					\
        { Back_Out_Of_Primitive();				\
          longjmp(*Back_To_Eval, Err_No);			\
        }

#define Primitive_Interrupt()					\
        { Back_Out_Of_Primitive();				\
          longjmp(*Back_To_Eval, PRIM_INTERRUPT);		\
        }

#define Primitive_GC()						\
        { Request_GC();						\
          Primitive_Interrupt();				\
        }

#define Primitive_GC_If_Needed(Check_Addr)			\
        if (GC_Check(Check_Addr))				\
	  Primitive_GC()

#define Arg_1_Type(TC)  					\
if (Type_Code(Arg1) != (TC)) Primitive_Error(ERR_ARG_1_WRONG_TYPE)

#define Arg_2_Type(TC)  					\
if (Type_Code(Arg2) != (TC)) Primitive_Error(ERR_ARG_2_WRONG_TYPE)

#define Arg_3_Type(TC)						\
if (Type_Code(Arg3) != (TC)) Primitive_Error(ERR_ARG_3_WRONG_TYPE)


#define Arg_1_GC_Type(GCTC)                                     \
if (GC_Type(Arg1) != GCTC) Primitive_Error(ERR_ARG_1_WRONG_TYPE)

#define Arg_2_GC_Type(GCTC)                                     \
if (GC_Type(Arg2) != GCTC) Primitive_Error(ERR_ARG_2_WRONG_TYPE)

#define Arg_3_GC_Type(GCTC)                                     \
if (GC_Type(Arg3) != GCTC) Primitive_Error(ERR_ARG_3_WRONG_TYPE)


/* And a procedure or two for range checking */

#define Range_Check(To_Where, P, Low, High, Error)		\
        { To_Where = Get_Integer(P);				\
          if ((To_Where < (Low)) || (To_Where > (High)))	\
            Primitive_Error(Error); }

#define Sign_Extend_Range_Check(To_Where, P, Low, High, Error)	\
        { Sign_Extend(P,To_Where);				\
          if ((To_Where < (Low)) || (To_Where > (High)))	\
            Primitive_Error(Error); }