| 
									
										
										
										
											1991-02-19 12:39:46 +00:00
										 |  |  | /***********************************************************
 | 
					
						
							| 
									
										
										
										
											1993-03-29 10:43:31 +00:00
										 |  |  | Copyright 1991, 1992, 1993 by Stichting Mathematisch Centrum, | 
					
						
							|  |  |  | Amsterdam, The Netherlands. | 
					
						
							| 
									
										
										
										
											1991-02-19 12:39:46 +00: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 15:06:42 +00: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) */ | 
					
						
							|  |  |  | 	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-14 18:32:11 +00:00
										 |  |  | 	int f_lasti;		/* Last instruction if called */ | 
					
						
							|  |  |  | 	int f_lineno;		/* Current line number */ | 
					
						
							| 
									
										
										
										
											1990-12-20 15:06:42 +00: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-03 19:03:22 +00:00
										 |  |  | #define Getnamev(f, i)	(GETITEM((f)->f_code->co_names, (i)))
 | 
					
						
							| 
									
										
										
										
											1990-12-20 15:06:42 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Block management functions */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void setup_block PROTO((frameobject *, int, int, int)); | 
					
						
							|  |  |  | block *pop_block PROTO((frameobject *)); | 
					
						
							| 
									
										
										
										
											1992-10-18 18:53:57 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* Extend the value stack */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | object **extend_stack PROTO((frameobject *, int, int)); |