/* * (c) copyright 1987 by the Vrije Universiteit, Amsterdam, The Netherlands. * See the copyright notice in the ACK home directory, in the file "Copyright". */ /* $Header$ */ /* Lint state stack */ /* These datastructures are used to implement a stack on which the * state of automatic variables (including register variables) is * kept. * In this way it is possible to account for the flow of * control of the program. */ struct switch_states { struct state *sws_case; struct state *sws_break; int sws_default_met; }; struct lint_stack_entry { struct lint_stack_entry *next; struct lint_stack_entry *ls_previous; short ls_class; /* IF, WHILE, DO, FOR, SWITCH, CASE */ int ls_level; struct state *ls_current; /* used by all classes */ union { struct state *u_if_state; /* used for IF-class */ struct state *u_end; /* used for loop-classes */ struct switch_states u_switch; } ls_states; /* not used for CASE-class */ }; /* macros to access the union */ #define LS_IF_STATE ls_states.u_if_state #define LS_END ls_states.u_end #define LS_CASE ls_states.u_switch.sws_case #define LS_BREAK ls_states.u_switch.sws_break #define LS_DEFAULT_MET ls_states.u_switch.sws_default_met /* ALLOCDEF "lint_stack_entry" 10 */ struct state { struct state *next; /* only used by memory allocator */ struct auto_def *st_auto_list; int st_notreached; /* set if not reached */ int st_warned; /* set if warning issued */ }; /* ALLOCDEF "state" 15 */ struct auto_def { struct auto_def *next; struct idf *ad_idf; struct def *ad_def; int ad_used; int ad_set; int ad_maybe_set; }; /* ALLOCDEF "auto_def" 20 */ struct expr_state { struct expr_state *next; struct idf *es_idf; arith es_offset; int es_used; int es_referred; int es_set; }; /* ALLOCDEF "expr_state" 20 */