2 Copyright (C) 2003-2025 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
,
35 COMP_OMP_METADIRECTIVE
, COMP_OMP_BEGIN_METADIRECTIVE
, COMP_CHANGE_TEAM
38 /* Stack element for the current compilation state. These structures
39 are allocated as automatic variables. */
40 typedef struct gfc_state_data
42 gfc_compile_state state
;
43 gfc_symbol
*sym
; /* Block name associated with this level */
44 gfc_symtree
*do_variable
; /* For DO blocks the iterator variable. */
46 struct gfc_code
*construct
;
47 struct gfc_code
*head
, *tail
;
48 struct gfc_state_data
*previous
;
50 /* Block-specific state data. */
53 gfc_st_label
*end_do_label
;
54 gfc_oacc_declare
*oacc_declare_clauses
;
60 extern gfc_state_data
*gfc_state_stack
;
62 #define gfc_current_block() (gfc_state_stack->sym)
63 #define gfc_current_state() (gfc_state_stack->state)
64 #define gfc_comp_struct(s) \
65 ((s) == COMP_DERIVED || (s) == COMP_STRUCTURE || (s) == COMP_MAP)
67 bool gfc_check_do_variable (gfc_symtree
*);
68 bool gfc_find_state (gfc_compile_state
);
69 gfc_state_data
*gfc_enclosing_unit (gfc_compile_state
*);
70 const char *gfc_ascii_statement (gfc_statement
, bool strip_sentinel
= false) ;
71 gfc_statement
gfc_omp_end_stmt (gfc_statement
, bool = true, bool = true);
72 match
gfc_match_enum (void);
73 match
gfc_match_enumerator_def (void);
74 void gfc_free_enum_history (void);
75 extern bool gfc_matching_function
;
76 extern bool gfc_matching_omp_context_selector
;
77 extern bool gfc_in_omp_metadirective_body
;
78 extern int gfc_omp_metadirective_region_count
;
80 match
gfc_match_prefix (gfc_typespec
*);
81 bool is_oacc (gfc_state_data
*);
82 #endif /* GFC_PARSE_H */