aboutsummaryrefslogtreecommitdiff
path: root/gcc/f/stw.h
diff options
context:
space:
mode:
Diffstat (limited to 'gcc/f/stw.h')
-rw-r--r--gcc/f/stw.h184
1 files changed, 184 insertions, 0 deletions
diff --git a/gcc/f/stw.h b/gcc/f/stw.h
new file mode 100644
index 00000000000..54643b833d4
--- /dev/null
+++ b/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