2 Copyright (C) 2003-2022 Free Software Foundation, Inc.
3 Contributed by Steven Bosscher
5 This file is part of GCC.
7 GCC is free software; you can redistribute it and/or modify it under
8 the terms of the GNU General Public License as published by the Free
9 Software Foundation; either version 3, or (at your option) any later
12 GCC is distributed in the hope that it will be useful, but WITHOUT ANY
13 WARRANTY; without even the implied warranty of MERCHANTABILITY or
14 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
17 You should have received a copy of the GNU General Public License
18 along with GCC; see the file COPYING3. If not see
19 <http://www.gnu.org/licenses/>. */
25 /* Enum for what the compiler is currently doing. */
26 enum gfc_compile_state
28 COMP_NONE
, COMP_PROGRAM
, COMP_MODULE
, COMP_SUBMODULE
, COMP_SUBROUTINE
,
29 COMP_FUNCTION
, COMP_BLOCK_DATA
, COMP_INTERFACE
, COMP_DERIVED
,
30 COMP_DERIVED_CONTAINS
, COMP_BLOCK
, COMP_ASSOCIATE
, COMP_IF
,
31 COMP_STRUCTURE
, COMP_UNION
, COMP_MAP
,
32 COMP_DO
, COMP_SELECT
, COMP_FORALL
, COMP_WHERE
, COMP_CONTAINS
, COMP_ENUM
,
33 COMP_SELECT_TYPE
, COMP_SELECT_RANK
, COMP_OMP_STRUCTURED_BLOCK
, COMP_CRITICAL
,
34 COMP_DO_CONCURRENT
, COMP_OMP_STRICTLY_STRUCTURED_BLOCK
37 /* Stack element for the current compilation state. These structures
38 are allocated as automatic variables. */
39 typedef struct gfc_state_data
41 gfc_compile_state state
;
42 gfc_symbol
*sym
; /* Block name associated with this level */
43 gfc_symtree
*do_variable
; /* For DO blocks the iterator variable. */
45 struct gfc_code
*construct
;
46 struct gfc_code
*head
, *tail
;
47 struct gfc_state_data
*previous
;
49 /* Block-specific state data. */
52 gfc_st_label
*end_do_label
;
53 gfc_oacc_declare
*oacc_declare_clauses
;
59 extern gfc_state_data
*gfc_state_stack
;
61 #define gfc_current_block() (gfc_state_stack->sym)
62 #define gfc_current_state() (gfc_state_stack->state)
63 #define gfc_comp_struct(s) \
64 ((s) == COMP_DERIVED || (s) == COMP_STRUCTURE || (s) == COMP_MAP)
66 int gfc_check_do_variable (gfc_symtree
*);
67 bool gfc_find_state (gfc_compile_state
);
68 gfc_state_data
*gfc_enclosing_unit (gfc_compile_state
*);
69 const char *gfc_ascii_statement (gfc_statement
);
70 match
gfc_match_enum (void);
71 match
gfc_match_enumerator_def (void);
72 void gfc_free_enum_history (void);
73 extern bool gfc_matching_function
;
74 match
gfc_match_prefix (gfc_typespec
*);
75 bool is_oacc (gfc_state_data
*);
76 #endif /* GFC_PARSE_H */