151 lines
		
	
	
	
		
			5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			151 lines
		
	
	
	
		
			5 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /* I D E N T I F I E R   D E S C R I P T O R   S T R U C T U R E */
 | |
| 
 | |
| struct constant	{
 | |
| 	struct node *co_const;	/* result of a constant expression */
 | |
| #define con_const	df_value.df_constant.co_const
 | |
| };
 | |
| 
 | |
| struct variable	{
 | |
| 	arith va_off;		/* address of variable */
 | |
| 	char *va_name;		/* name of variable if given */
 | |
| #define var_off		df_value.df_variable.va_off
 | |
| #define var_name	df_value.df_variable.va_name
 | |
| };
 | |
| 
 | |
| struct bound	{
 | |
| 	struct type *bo_type;	/* type of conformant array */
 | |
| #define bnd_type	df_value.df_bound.bo_type
 | |
| };
 | |
| 
 | |
| struct enumval	{
 | |
| 	unsigned int en_val;	/* value of this enumeration literal */
 | |
| 	struct def *en_next;	/* next enumeration literal */
 | |
| #define enm_val		df_value.df_enum.en_val
 | |
| #define enm_next	df_value.df_enum.en_next
 | |
| };
 | |
| 
 | |
| struct field	{
 | |
| 	arith fd_off;
 | |
| 	unsigned short fd_flags;
 | |
| #define F_SELECTOR	0x1	/* set if field is a variant selector */
 | |
| #define F_PACKED	0x2	/* set if record is packed */
 | |
| 
 | |
| #define fld_off		df_value.df_field.fd_off
 | |
| #define fld_flags	df_value.df_field.fd_flags
 | |
| };
 | |
| 
 | |
| struct lab	{
 | |
| 	struct lab *lb_next;	/* list of goto statements to this label */
 | |
| 	int lb_level;		/* level of nesting */
 | |
| 	label lb_no;		/* instruction label */
 | |
| 	label lb_descr;		/* label of goto descriptor */
 | |
| #define lab_next	df_value.df_label.lb_next
 | |
| #define lab_level	df_value.df_label.lb_level
 | |
| #define lab_no		df_value.df_label.lb_no
 | |
| #define lab_descr	df_value.df_label.lb_descr
 | |
| };
 | |
| 
 | |
| /* ALLOCDEF "lab" 10 */
 | |
| 
 | |
| struct used	{
 | |
| 	struct def *us_def;	/* used definition */
 | |
| #define usd_def		df_value.df_used.us_def
 | |
| };
 | |
| 
 | |
| struct forwtype	{
 | |
| 	struct forwtype *f_next;
 | |
| 	struct node *f_node;
 | |
| 	struct type *f_type;
 | |
| };
 | |
| 
 | |
| /* ALLOCDEF "forwtype" 50 */
 | |
| 
 | |
| struct dfproc	{			/* used for procedures and functions */
 | |
| 	struct scopelist *pc_vis;	/* scope of this procedure/function */
 | |
| 	char *pc_name;			/* internal name */
 | |
| 	label pc_label;			/* label of name (for tracing) */
 | |
| 	arith pc_res;			/* offset of function result */
 | |
| 	arith pc_bool;			/* offset of run-time boolean */
 | |
| #define prc_vis		df_value.df_proc.pc_vis
 | |
| #define prc_name	df_value.df_proc.pc_name
 | |
| #define prc_label	df_value.df_proc.pc_label
 | |
| #define prc_res		df_value.df_proc.pc_res
 | |
| #define prc_bool	df_value.df_proc.pc_bool
 | |
| };
 | |
| 
 | |
| struct def	{		/* list of definitions for a name */
 | |
| 	struct def *df_next;	/* next definition in definitions chain */
 | |
| 	struct def *df_nextinscope;
 | |
| 				/* link all definitions in a scope */
 | |
| 	struct idf *df_idf;	/* link back to the name */
 | |
| 	struct scope *df_scope;	/* scope in which this definition resides */
 | |
| 	long df_kind;		/* the kind of this definition: */
 | |
| #define D_PROCEDURE	0x000001	/* procedure */
 | |
| #define D_FUNCTION	0x000002	/* function */
 | |
| #define D_TYPE		0x000004	/* a type */
 | |
| #define D_CONST		0x000008	/* a constant */
 | |
| #define D_ENUM		0x000010	/* an enumeration literal */
 | |
| #define D_FIELD		0x000020	/* a field in a record */
 | |
| #define D_PROGRAM	0x000040	/* the program */
 | |
| #define D_VARIABLE	0x000080	/* a variable */
 | |
| #define D_PARAMETER	0x000100	/* program parameter */
 | |
| #define D_FORWTYPE	0x000200	/* forward type */
 | |
| #define D_FTYPE		0x000400	/* resolved forward type */
 | |
| #define D_FWPROCEDURE	0x000800	/* forward procedure */
 | |
| #define D_FWFUNCTION	0x001000	/* forward function */
 | |
| #define D_LABEL		0x002000	/* a label */
 | |
| #define D_LBOUND	0x004000	/* lower bound id. in conform. array */
 | |
| #define D_UBOUND	0x008000	/* upper bound id. in conform. array */
 | |
| #define D_FORWARD	0x010000	/* directive "forward" */
 | |
| #define D_EXTERN	0x020000	/* directive "extern" */
 | |
| #define D_ERROR		0x040000	/* a compiler generated definition
 | |
| 					 * for an undefined variable */
 | |
| #define D_MODULE	0x080000	/* the module */
 | |
| #define D_INUSE		0x100000	/* variable is in use */
 | |
| 
 | |
| #define D_VALUE		(D_FUNCTION | D_CONST | D_ENUM | D_FIELD | D_VARIABLE\
 | |
| 			 | D_FWFUNCTION | D_LBOUND | D_UBOUND)
 | |
| #define D_ROUTINE      (D_FUNCTION | D_FWFUNCTION | D_PROCEDURE | D_FWPROCEDURE)
 | |
| 	unsigned short df_flags;
 | |
| #define D_NOREG		0x001	/* set if it may not reside in a register */
 | |
| #define D_VALPAR	0x002	/* set if it is a value parameter */
 | |
| #define D_VARPAR	0x004	/* set if it is a var parameter */
 | |
| #define D_LOOPVAR	0x008	/* set if it is a control-variable */
 | |
| #define D_EXTERNAL	0x010	/* set if proc/func is external declared */
 | |
| #define D_PROGPAR	0x020	/* set if input/output was mentioned in
 | |
| 				 * the program-heading */
 | |
| #define D_USED		0x040	/* set when the variable is used */
 | |
| #define D_SET		0x080	/* set when the variable is set */
 | |
| #define D_INLOOP	0x100	/* set when we are inside a loop */
 | |
| #define D_WITH		0x200	/* set inside a with statement */
 | |
| #define D_SETINHIGH	0x400	/* set in a higher scope level (for loops) */
 | |
| 
 | |
| 	struct type *df_type;
 | |
| 	union {
 | |
| 		struct constant df_constant;
 | |
| 		struct variable df_variable;
 | |
| 		struct bound df_bound;
 | |
| 		struct enumval df_enum;
 | |
| 		struct field df_field;
 | |
| 		struct lab df_label;
 | |
| 		struct used df_used;
 | |
| 		struct forwtype *df_fwtype;
 | |
| 		struct dfproc df_proc;
 | |
| 		int df_reqname;	/* define for required name */
 | |
| 	} df_value;
 | |
| #define df_fortype	df_value.df_fwtype
 | |
| };
 | |
| 
 | |
| /* ALLOCDEF "def" 50 */
 | |
| 
 | |
| extern struct def
 | |
| 	*define(),
 | |
| 	*MkDef(),
 | |
| 	*DeclProc(),
 | |
| 	*DeclFunc();
 | |
| 
 | |
| extern struct def
 | |
| 	*lookup(),
 | |
| 	*lookfor();
 | |
| 
 | |
| #define NULLDEF ((struct def *) 0)
 |