1991-02-19 20:39:46 +08:00
|
|
|
/***********************************************************
|
1993-03-29 18:43:31 +08:00
|
|
|
Copyright 1991, 1992, 1993 by Stichting Mathematisch Centrum,
|
|
|
|
Amsterdam, The Netherlands.
|
1991-02-19 20:39:46 +08:00
|
|
|
|
|
|
|
All Rights Reserved
|
|
|
|
|
|
|
|
Permission to use, copy, modify, and distribute this software and its
|
|
|
|
documentation for any purpose and without fee is hereby granted,
|
|
|
|
provided that the above copyright notice appear in all copies and that
|
|
|
|
both that copyright notice and this permission notice appear in
|
|
|
|
supporting documentation, and that the names of Stichting Mathematisch
|
|
|
|
Centrum or CWI not be used in advertising or publicity pertaining to
|
|
|
|
distribution of the software without specific, written prior permission.
|
|
|
|
|
|
|
|
STICHTING MATHEMATISCH CENTRUM DISCLAIMS ALL WARRANTIES WITH REGARD TO
|
|
|
|
THIS SOFTWARE, INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND
|
|
|
|
FITNESS, IN NO EVENT SHALL STICHTING MATHEMATISCH CENTRUM BE LIABLE
|
|
|
|
FOR ANY SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
|
|
|
|
WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
|
|
|
|
ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT
|
|
|
|
OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
|
|
|
|
|
|
|
|
******************************************************************/
|
|
|
|
|
1990-12-20 23:06:42 +08:00
|
|
|
/* Frame object interface */
|
|
|
|
|
|
|
|
typedef struct {
|
|
|
|
int b_type; /* what kind of block this is */
|
|
|
|
int b_handler; /* where to jump to find handler */
|
|
|
|
int b_level; /* value stack level to pop to */
|
|
|
|
} block;
|
|
|
|
|
|
|
|
typedef struct _frame {
|
|
|
|
OB_HEAD
|
|
|
|
struct _frame *f_back; /* previous frame, or NULL */
|
|
|
|
codeobject *f_code; /* code segment */
|
|
|
|
object *f_globals; /* global symbol table (dictobject) */
|
|
|
|
object *f_locals; /* local symbol table (dictobject) */
|
1993-03-30 21:18:41 +08:00
|
|
|
object *f_fastlocals; /* fast local variables (listobject) */
|
|
|
|
object *f_localmap; /* local variable names (dictobject) */
|
1990-12-20 23:06:42 +08:00
|
|
|
object **f_valuestack; /* malloc'ed array */
|
|
|
|
block *f_blockstack; /* malloc'ed array */
|
|
|
|
int f_nvalues; /* size of f_valuestack */
|
|
|
|
int f_nblocks; /* size of f_blockstack */
|
|
|
|
int f_iblock; /* index in f_blockstack */
|
1992-01-15 02:32:11 +08:00
|
|
|
int f_lasti; /* Last instruction if called */
|
|
|
|
int f_lineno; /* Current line number */
|
1990-12-20 23:06:42 +08:00
|
|
|
} frameobject;
|
|
|
|
|
|
|
|
|
|
|
|
/* Standard object interface */
|
|
|
|
|
|
|
|
extern typeobject Frametype;
|
|
|
|
|
|
|
|
#define is_frameobject(op) ((op)->ob_type == &Frametype)
|
|
|
|
|
|
|
|
frameobject * newframeobject PROTO(
|
|
|
|
(frameobject *, codeobject *, object *, object *, int, int));
|
|
|
|
|
|
|
|
|
|
|
|
/* The rest of the interface is specific for frame objects */
|
|
|
|
|
|
|
|
/* List access macros */
|
|
|
|
|
|
|
|
#ifdef NDEBUG
|
|
|
|
#define GETITEM(v, i) GETLISTITEM((listobject *)(v), (i))
|
|
|
|
#define GETITEMNAME(v, i) GETSTRINGVALUE((stringobject *)GETITEM((v), (i)))
|
|
|
|
#else
|
|
|
|
#define GETITEM(v, i) getlistitem((v), (i))
|
|
|
|
#define GETITEMNAME(v, i) getstringvalue(getlistitem((v), (i)))
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#define GETUSTRINGVALUE(s) ((unsigned char *)GETSTRINGVALUE(s))
|
|
|
|
|
|
|
|
/* Code access macros */
|
|
|
|
|
|
|
|
#define Getconst(f, i) (GETITEM((f)->f_code->co_consts, (i)))
|
|
|
|
#define Getname(f, i) (GETITEMNAME((f)->f_code->co_names, (i)))
|
1991-04-04 03:03:22 +08:00
|
|
|
#define Getnamev(f, i) (GETITEM((f)->f_code->co_names, (i)))
|
1990-12-20 23:06:42 +08:00
|
|
|
|
|
|
|
|
|
|
|
/* Block management functions */
|
|
|
|
|
|
|
|
void setup_block PROTO((frameobject *, int, int, int));
|
|
|
|
block *pop_block PROTO((frameobject *));
|
1992-10-19 02:53:57 +08:00
|
|
|
|
|
|
|
/* Extend the value stack */
|
|
|
|
|
|
|
|
object **extend_stack PROTO((frameobject *, int, int));
|