diff options
Diffstat (limited to 'gnu/usr.bin/gcc/f/stw.h')
-rw-r--r-- | gnu/usr.bin/gcc/f/stw.h | 184 |
1 files changed, 184 insertions, 0 deletions
diff --git a/gnu/usr.bin/gcc/f/stw.h b/gnu/usr.bin/gcc/f/stw.h new file mode 100644 index 00000000000..54643b833d4 --- /dev/null +++ b/gnu/usr.bin/gcc/f/stw.h @@ -0,0 +1,184 @@ +/* stw.h -- Private #include File (module.h template V1.0) + Copyright (C) 1995 Free Software Foundation, Inc. + Contributed by James Craig Burley (burley@gnu.ai.mit.edu). + +This file is part of GNU Fortran. + +GNU Fortran is free software; you can redistribute it and/or modify +it under the terms of the GNU General Public License as published by +the Free Software Foundation; either version 2, or (at your option) +any later version. + +GNU Fortran is distributed in the hope that it will be useful, +but WITHOUT ANY WARRANTY; without even the implied warranty of +MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +GNU General Public License for more details. + +You should have received a copy of the GNU General Public License +along with GNU Fortran; see the file COPYING. If not, write to +the Free Software Foundation, 59 Temple Place - Suite 330, Boston, MA +02111-1307, USA. + + Owning Modules: + stw.c + + Modifications: +*/ + +/* Allow multiple inclusion to work. */ + +#ifndef _H_f_stw +#define _H_f_stw + +/* Simple definitions and enumerations. */ + + +/* Typedefs. */ + +typedef struct _ffestw_ *ffestw; +typedef struct _ffestw_case_ *ffestwCase; +typedef struct _ffestw_select_ *ffestwSelect; +typedef void (*ffestwShriek) (bool ok); + +/* Include files needed by this one. */ + +#include "bld.h" +#include "com.h" +#include "info.h" +#include "lab.h" +#include "lex.h" +#include "malloc.h" +#include "stv.h" +#include "symbol.h" +#include "where.h" + +/* Structure definitions. */ + +struct _ffestw_ + { + ffestw next_; /* Next (unused) block, or NULL. */ + ffestw previous_; /* Previous block, NULL if this is NIL state. */ + ffestw top_do_; /* Previous or current DO state, or NULL. */ + unsigned long blocknum_; /* Block # w/in procedure/program. */ + ffestwShriek shriek_; /* Call me to pop block in a hurry. */ + ffesymbol sym_; /* Related symbol (if there is one). */ + ffelexToken name_; /* Construct name (IFTHEN, SELECT, DO only). */ + ffestwSelect select_; /* Info for SELECT CASE blocks. */ + ffelab label_; /* For DO blocks w/labels, the target label. */ + ffesymbol do_iter_var_; /* For iter DO blocks, the iter var or NULL. */ + ffelexToken do_iter_var_t_; /* The token for do_iter_var. */ + ffewhereLine line_; /* Where first token of statement triggering + state */ + ffewhereColumn col_; /* was seen in source file. */ + char uses_; /* # uses (new+use-kill calls). */ + ffestvState state_; + int substate_; /* Used on a per-block-state basis. */ +#if FFECOM_targetCURRENT == FFECOM_targetGCC + struct nesting *do_hook_; /* backend id for given loop (EXIT/CYCLE). */ + tree do_tvar_; /* tree form of do_iter_var. */ + tree do_incr_saved_; /* tree SAVED_EXPR of incr expr. */ + tree do_count_var_; /* tree of countdown variable. */ + tree select_texpr_; /* tree for end case. */ + bool select_break_; /* TRUE when CASE should start with gen + "break;". */ +#endif /* FFECOM_targetCURRENT == FFECOM_targetGCC*/ + }; + +struct _ffestw_case_ + { + ffestwCase next_rel; /* Next case range in relational order. */ + ffestwCase previous_rel; /* Previous case range in relational order. */ + ffestwCase next_stmt; /* Next range in stmt or first in next stmt. */ + ffestwCase previous_stmt; /* Previous range. */ + ffebldConstant low; /* Low value in range. */ + ffebldConstant high; /* High value in range. */ + unsigned long casenum; /* CASE stmt index for this range/value. */ + ffelexToken t; /* Token for this range/value; ffestc only. */ + }; + +struct _ffestw_select_ + { + ffestwCase first_rel; /* First CASE range (after low) in order. */ + ffestwCase last_rel; /* Last CASE range (before high) in order. */ + ffestwCase first_stmt; /* First range in first CASE stmt. */ + ffestwCase last_stmt; /* Last range in last CASE stmt. */ + mallocPool pool; /* Pool in which this and all cases are + allocated. */ + unsigned long cases; /* Number of CASE stmts seen so far. */ + ffelexToken t; /* First token of selected expression; ffestc + only. */ + ffeinfoBasictype type; /* Basic type (integer, character, or + logical). */ + ffeinfoKindtype kindtype; /* Kind type. */ + }; + +/* Global objects accessed by users of this module. */ + +extern ffestw ffestw_stack_top_; + +/* Declare functions with prototypes. */ + +void ffestw_display_state (); +void ffestw_kill (ffestw block); +void ffestw_init_0 (void); +ffestw ffestw_new (); +ffestw ffestw_pop (); +ffestw ffestw_push (ffestw block); +ffestw ffestw_update (ffestw block); +ffestw ffestw_use (ffestw block); + +/* Define macros. */ + +#define ffestw_blocknum(b) ((b)->blocknum_) +#define ffestw_col(b) ((b)->col_) +#define ffestw_do_count_var(b) ((b)->do_count_var_) +#define ffestw_do_hook(b) ((b)->do_hook_) +#define ffestw_do_incr_saved(b) ((b)->do_incr_saved_) +#define ffestw_do_iter_var(b) ((b)->do_iter_var_) +#define ffestw_do_iter_var_t(b) ((b)->do_iter_var_t_) +#define ffestw_do_tvar(b) ((b)->do_tvar_) +#define ffestw_init_1() +#define ffestw_init_2() +#define ffestw_init_3() +#define ffestw_init_4() +#define ffestw_label(b) ((b)->label_) +#define ffestw_line(b) ((b)->line_) +#define ffestw_name(b) ((b)->name_) +#define ffestw_previous(b) ((b)->previous_) +#define ffestw_select(b) ((b)->select_) +#define ffestw_select_break(b) ((b)->select_break_) +#define ffestw_select_texpr(b) ((b)->select_texpr_) +#define ffestw_set_blocknum(b,bl) ((b)->blocknum_ = (bl)) +#define ffestw_set_col(b,c) ((b)->col_ = (c)) +#define ffestw_set_do_count_var(b,d) ((b)->do_count_var_ = (d)) +#define ffestw_set_do_hook(b,d) ((b)->do_hook_ = (d)) +#define ffestw_set_do_incr_saved(b,d) ((b)->do_incr_saved_ = (d)) +#define ffestw_set_do_iter_var(b,v) ((b)->do_iter_var_ = (v)) +#define ffestw_set_do_iter_var_t(b,t) ((b)->do_iter_var_t_ = (t)) +#define ffestw_set_do_tvar(b,d) ((b)->do_tvar_ = (d)) +#define ffestw_set_label(b,l) ((b)->label_ = (l)) +#define ffestw_set_line(b,l) ((b)->line_ = (l)) +#define ffestw_set_name(b,n) ((b)->name_ = (n)) +#define ffestw_set_select(b,s) ((b)->select_ = (s)) +#define ffestw_set_select_break(b,br) ((b)->select_break_ = (br)) +#define ffestw_set_select_texpr(b,t) ((b)->select_texpr_ = (t)) +#define ffestw_set_shriek(b,s) ((b)->shriek_ = (s)) +#define ffestw_set_state(b,s) ((b)->state_ = (s)) +#define ffestw_set_substate(b,s) ((b)->substate_ = (s)) +#define ffestw_set_sym(b,s) ((b)->sym_= (s)) +#define ffestw_set_top_do(b,t) ((b)->top_do_ = (t)) +#define ffestw_shriek(b) ((b)->shriek_) +#define ffestw_stack_top() ffestw_stack_top_ +#define ffestw_state(b) ((b)->state_) +#define ffestw_substate(b) ((b)->substate_) +#define ffestw_sym(b) ((b)->sym_) +#define ffestw_terminate_0() +#define ffestw_terminate_1() +#define ffestw_terminate_2() +#define ffestw_terminate_3() +#define ffestw_terminate_4() +#define ffestw_top_do(b) ((b)->top_do_) + +/* End of #include file. */ + +#endif |