LCOV - code coverage report
Current view: top level - gcc/fortran - gfortran.h (source / functions) Coverage Total Hit
Test: gcc.info Lines: 100.0 % 17 17
Test Date: 2026-02-28 14:20:25 Functions: 100.0 % 2 2
Legend: Lines:     hit not hit

            Line data    Source code
       1              : /* gfortran header file
       2              :    Copyright (C) 2000-2026 Free Software Foundation, Inc.
       3              :    Contributed by Andy Vaught
       4              : 
       5              : This file is part of GCC.
       6              : 
       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
      10              : version.
      11              : 
      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
      15              : for more details.
      16              : 
      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/>.  */
      20              : 
      21              : #ifndef GCC_GFORTRAN_H
      22              : #define GCC_GFORTRAN_H
      23              : 
      24              : /* It's probably insane to have this large of a header file, but it
      25              :    seemed like everything had to be recompiled anyway when a change
      26              :    was made to a header file, and there were ordering issues with
      27              :    multiple header files.  Besides, Microsoft's winnt.h was 250k last
      28              :    time I looked, so by comparison this is perfectly reasonable.  */
      29              : 
      30              : #ifndef GCC_CORETYPES_H
      31              : #error "gfortran.h must be included after coretypes.h"
      32              : #endif
      33              : 
      34              : /* In order for the format checking to accept the Fortran front end
      35              :    diagnostic framework extensions, you must include this file before
      36              :    diagnostic-core.h, not after.  We override the definition of GCC_DIAG_STYLE
      37              :    in c-common.h.  */
      38              : #undef GCC_DIAG_STYLE
      39              : #define GCC_DIAG_STYLE __gcc_gfc__
      40              : #if defined(GCC_DIAGNOSTIC_CORE_H)
      41              : #error \
      42              : In order for the format checking to accept the Fortran front end diagnostic \
      43              : framework extensions, you must include this file before diagnostic-core.h, \
      44              : not after.
      45              : #endif
      46              : 
      47              : /* Declarations common to the front-end and library are put in
      48              :    libgfortran/libgfortran_frontend.h  */
      49              : #include "libgfortran.h"
      50              : 
      51              : 
      52              : #include "intl.h"
      53              : #include "splay-tree.h"
      54              : 
      55              : /* Major control parameters.  */
      56              : 
      57              : #define GFC_MAX_SYMBOL_LEN 63   /* Must be at least 63 for F2003.  */
      58              : #define GFC_LETTERS 26          /* Number of letters in the alphabet.  */
      59              : 
      60              : #define MAX_SUBRECORD_LENGTH 2147483639   /* 2**31-9 */
      61              : 
      62              : 
      63              : #define gfc_is_whitespace(c) ((c==' ') || (c=='\t') || (c=='\f'))
      64              : 
      65              : /* Macros to check for groups of structure-like types and flavors since
      66              :    derived types, structures, maps, unions are often treated similarly. */
      67              : #define gfc_bt_struct(t) \
      68              :   ((t) == BT_DERIVED || (t) == BT_UNION)
      69              : #define gfc_fl_struct(f) \
      70              :   ((f) == FL_DERIVED || (f) == FL_UNION || (f) == FL_STRUCT)
      71              : #define case_bt_struct case BT_DERIVED: case BT_UNION
      72              : #define case_fl_struct case FL_DERIVED: case FL_UNION: case FL_STRUCT
      73              : 
      74              : /* Stringization.  */
      75              : #define stringize(x) expand_macro(x)
      76              : #define expand_macro(x) # x
      77              : 
      78              : /* For the runtime library, a standard prefix is a requirement to
      79              :    avoid cluttering the namespace with things nobody asked for.  It's
      80              :    ugly to look at and a pain to type when you add the prefix by hand,
      81              :    so we hide it behind a macro.  */
      82              : #define PREFIX(x) "_gfortran_" x
      83              : #define PREFIX_LEN 10
      84              : 
      85              : /* A prefix for internal variables, which are not user-visible.  */
      86              : #if !defined (NO_DOT_IN_LABEL)
      87              : # define GFC_PREFIX(x) "_F." x
      88              : #elif !defined (NO_DOLLAR_IN_LABEL)
      89              : # define GFC_PREFIX(x) "_F$" x
      90              : #else
      91              : # define GFC_PREFIX(x) "_F_" x
      92              : #endif
      93              : 
      94              : #define BLANK_COMMON_NAME "__BLNK__"
      95              : 
      96              : /* Macro to initialize an mstring structure.  */
      97              : #define minit(s, t) { s, NULL, t }
      98              : 
      99              : /* Structure for storing strings to be matched by gfc_match_string.  */
     100              : typedef struct
     101              : {
     102              :   const char *string;
     103              :   const char *mp;
     104              :   int tag;
     105              : }
     106              : mstring;
     107              : 
     108              : /* ISO_Fortran_binding.h
     109              :    CAUTION: This has to be kept in sync with libgfortran.  */
     110              : 
     111              : #define CFI_type_kind_shift 8
     112              : #define CFI_type_mask 0xFF
     113              : #define CFI_type_from_type_kind(t, k) (t + (k << CFI_type_kind_shift))
     114              : 
     115              : /* Constants, defined as macros. */
     116              : #define CFI_VERSION 1
     117              : #define CFI_MAX_RANK 15
     118              : 
     119              : /* Attributes. */
     120              : #define CFI_attribute_pointer 0
     121              : #define CFI_attribute_allocatable 1
     122              : #define CFI_attribute_other 2
     123              : 
     124              : #define CFI_type_mask 0xFF
     125              : #define CFI_type_kind_shift 8
     126              : 
     127              : /* Intrinsic types. Their kind number defines their storage size. */
     128              : #define CFI_type_Integer 1
     129              : #define CFI_type_Logical 2
     130              : #define CFI_type_Real 3
     131              : #define CFI_type_Complex 4
     132              : #define CFI_type_Character 5
     133              : 
     134              : /* Combined type (for more, see ISO_Fortran_binding.h).  */
     135              : #define CFI_type_ucs4_char (CFI_type_Character + (4 << CFI_type_kind_shift))
     136              : 
     137              : /* Types with no kind. */
     138              : #define CFI_type_struct 6
     139              : #define CFI_type_cptr 7
     140              : #define CFI_type_cfunptr 8
     141              : #define CFI_type_other -1
     142              : 
     143              : 
     144              : /*************************** Enums *****************************/
     145              : 
     146              : /* Used when matching and resolving data I/O transfer statements.  */
     147              : 
     148              : enum io_kind
     149              : { M_READ, M_WRITE, M_PRINT, M_INQUIRE };
     150              : 
     151              : 
     152              : /* These are flags for identifying whether we are reading a character literal
     153              :    between quotes or normal source code.  */
     154              : 
     155              : enum gfc_instring
     156              : { NONSTRING = 0, INSTRING_WARN, INSTRING_NOWARN };
     157              : 
     158              : /* This is returned by gfc_notification_std to know if, given the flags
     159              :    that were given (-std=, -pedantic) we should issue an error, a warning
     160              :    or nothing.  */
     161              : 
     162              : enum notification
     163              : { SILENT, WARNING, ERROR };
     164              : 
     165              : /* Matchers return one of these three values.  The difference between
     166              :    MATCH_NO and MATCH_ERROR is that MATCH_ERROR means that a match was
     167              :    successful, but that something non-syntactic is wrong and an error
     168              :    has already been issued.  */
     169              : 
     170              : enum match
     171              : { MATCH_NO = 1, MATCH_YES, MATCH_ERROR };
     172              : 
     173              : /* Used for different Fortran source forms in places like scanner.cc.  */
     174              : enum gfc_source_form
     175              : { FORM_FREE, FORM_FIXED, FORM_UNKNOWN };
     176              : 
     177              : /* Expression node types.  */
     178              : enum expr_t
     179              : {
     180              :   EXPR_UNKNOWN = 0,
     181              :   EXPR_OP = 1,
     182              :   EXPR_FUNCTION,
     183              :   EXPR_CONSTANT,
     184              :   EXPR_VARIABLE,
     185              :   EXPR_SUBSTRING,
     186              :   EXPR_STRUCTURE,
     187              :   EXPR_ARRAY,
     188              :   EXPR_NULL,
     189              :   EXPR_COMPCALL,
     190              :   EXPR_PPC,
     191              :   EXPR_CONDITIONAL,
     192              : };
     193              : 
     194              : /* Array types.  */
     195              : enum array_type
     196              : { AS_EXPLICIT = 1, AS_ASSUMED_SHAPE, AS_DEFERRED,
     197              :   AS_ASSUMED_SIZE, AS_IMPLIED_SHAPE, AS_ASSUMED_RANK,
     198              :   AS_UNKNOWN
     199              : };
     200              : 
     201              : enum ar_type
     202              : { AR_FULL = 1, AR_ELEMENT, AR_SECTION, AR_UNKNOWN };
     203              : 
     204              : /* Statement label types. ST_LABEL_DO_TARGET is used for obsolescent warnings
     205              :    related to shared DO terminations and DO targets which are neither END DO
     206              :    nor CONTINUE; otherwise it is identical to ST_LABEL_TARGET.  */
     207              : enum gfc_sl_type
     208              : { ST_LABEL_UNKNOWN = 1, ST_LABEL_TARGET, ST_LABEL_DO_TARGET,
     209              :   ST_LABEL_BAD_TARGET, ST_LABEL_FORMAT
     210              : };
     211              : 
     212              : /* Intrinsic operators.  */
     213              : enum gfc_intrinsic_op
     214              : { GFC_INTRINSIC_BEGIN = 0,
     215              :   INTRINSIC_NONE = -1, INTRINSIC_UPLUS = GFC_INTRINSIC_BEGIN,
     216              :   INTRINSIC_UMINUS, INTRINSIC_PLUS, INTRINSIC_MINUS, INTRINSIC_TIMES,
     217              :   INTRINSIC_DIVIDE, INTRINSIC_POWER, INTRINSIC_CONCAT,
     218              :   INTRINSIC_AND, INTRINSIC_OR, INTRINSIC_EQV, INTRINSIC_NEQV,
     219              :   /* ==, /=, >, >=, <, <=  */
     220              :   INTRINSIC_EQ, INTRINSIC_NE, INTRINSIC_GT, INTRINSIC_GE,
     221              :   INTRINSIC_LT, INTRINSIC_LE,
     222              :   /* .EQ., .NE., .GT., .GE., .LT., .LE. (OS = Old-Style)  */
     223              :   INTRINSIC_EQ_OS, INTRINSIC_NE_OS, INTRINSIC_GT_OS, INTRINSIC_GE_OS,
     224              :   INTRINSIC_LT_OS, INTRINSIC_LE_OS,
     225              :   INTRINSIC_NOT, INTRINSIC_USER, INTRINSIC_ASSIGN, INTRINSIC_PARENTHESES,
     226              :   GFC_INTRINSIC_END, /* Sentinel */
     227              :   /* User defined derived type pseudo operators. These are set beyond the
     228              :      sentinel so that they are excluded from module_read and module_write.  */
     229              :   INTRINSIC_FORMATTED, INTRINSIC_UNFORMATTED
     230              : };
     231              : 
     232              : /* This macro is the number of intrinsic operators that exist.
     233              :    Assumptions are made about the numbering of the interface_op enums.  */
     234              : #define GFC_INTRINSIC_OPS GFC_INTRINSIC_END
     235              : 
     236              : /* Arithmetic results.  ARITH_NOT_REDUCED is used to keep track of expressions
     237              :    that were not reduced by the arithmetic evaluation code.  */
     238              : enum arith
     239              : { ARITH_OK = 1, ARITH_OVERFLOW, ARITH_UNDERFLOW, ARITH_NAN,
     240              :   ARITH_DIV0, ARITH_INCOMMENSURATE, ARITH_ASYMMETRIC, ARITH_PROHIBIT,
     241              :   ARITH_WRONGCONCAT, ARITH_INVALID_TYPE, ARITH_NOT_REDUCED,
     242              :   ARITH_UNSIGNED_TRUNCATED, ARITH_UNSIGNED_NEGATIVE
     243              : };
     244              : 
     245              : /* Statements.  */
     246              : enum gfc_statement
     247              : {
     248              :   ST_ARITHMETIC_IF, ST_ALLOCATE, ST_ATTR_DECL, ST_ASSOCIATE,
     249              :   ST_BACKSPACE, ST_BLOCK, ST_BLOCK_DATA,
     250              :   ST_CALL, ST_CASE, ST_CLOSE, ST_COMMON, ST_CONTINUE, ST_CONTAINS, ST_CYCLE,
     251              :   ST_DATA, ST_DATA_DECL, ST_DEALLOCATE, ST_DO, ST_ELSE, ST_ELSEIF,
     252              :   ST_ELSEWHERE, ST_END_ASSOCIATE, ST_END_BLOCK, ST_END_BLOCK_DATA,
     253              :   ST_ENDDO, ST_IMPLIED_ENDDO, ST_END_FILE, ST_FINAL, ST_FLUSH, ST_END_FORALL,
     254              :   ST_END_FUNCTION, ST_ENDIF, ST_END_INTERFACE, ST_END_MODULE, ST_END_SUBMODULE,
     255              :   ST_END_PROGRAM, ST_END_SELECT, ST_END_SUBROUTINE, ST_END_WHERE, ST_END_TYPE,
     256              :   ST_ENTRY, ST_EQUIVALENCE, ST_ERROR_STOP, ST_EXIT, ST_FORALL, ST_FORALL_BLOCK,
     257              :   ST_FORMAT, ST_FUNCTION, ST_GOTO, ST_IF_BLOCK, ST_IMPLICIT, ST_IMPLICIT_NONE,
     258              :   ST_IMPORT, ST_INQUIRE, ST_INTERFACE, ST_SYNC_ALL, ST_SYNC_MEMORY,
     259              :   ST_SYNC_IMAGES, ST_PARAMETER, ST_MODULE, ST_SUBMODULE, ST_MODULE_PROC,
     260              :   ST_NAMELIST, ST_NULLIFY, ST_OPEN, ST_PAUSE, ST_PRIVATE, ST_PROGRAM, ST_PUBLIC,
     261              :   ST_READ, ST_RETURN, ST_REWIND, ST_STOP, ST_SUBROUTINE, ST_TYPE, ST_USE,
     262              :   ST_WHERE_BLOCK, ST_WHERE, ST_WAIT, ST_WRITE, ST_ASSIGNMENT,
     263              :   ST_POINTER_ASSIGNMENT, ST_SELECT_CASE, ST_SEQUENCE, ST_SIMPLE_IF,
     264              :   ST_STATEMENT_FUNCTION, ST_DERIVED_DECL, ST_LABEL_ASSIGNMENT, ST_ENUM,
     265              :   ST_ENUMERATOR, ST_END_ENUM, ST_SELECT_TYPE, ST_TYPE_IS, ST_CLASS_IS,
     266              :   ST_SELECT_RANK, ST_RANK, ST_STRUCTURE_DECL, ST_END_STRUCTURE,
     267              :   ST_UNION, ST_END_UNION, ST_MAP, ST_END_MAP,
     268              :   ST_OACC_PARALLEL_LOOP, ST_OACC_END_PARALLEL_LOOP, ST_OACC_PARALLEL,
     269              :   ST_OACC_END_PARALLEL, ST_OACC_KERNELS, ST_OACC_END_KERNELS, ST_OACC_DATA,
     270              :   ST_OACC_END_DATA, ST_OACC_HOST_DATA, ST_OACC_END_HOST_DATA, ST_OACC_LOOP,
     271              :   ST_OACC_END_LOOP, ST_OACC_DECLARE, ST_OACC_UPDATE, ST_OACC_WAIT,
     272              :   ST_OACC_CACHE, ST_OACC_KERNELS_LOOP, ST_OACC_END_KERNELS_LOOP,
     273              :   ST_OACC_SERIAL_LOOP, ST_OACC_END_SERIAL_LOOP, ST_OACC_SERIAL,
     274              :   ST_OACC_END_SERIAL, ST_OACC_ENTER_DATA, ST_OACC_EXIT_DATA, ST_OACC_ROUTINE,
     275              :   ST_OACC_ATOMIC, ST_OACC_END_ATOMIC,
     276              :   ST_OMP_ATOMIC, ST_OMP_BARRIER, ST_OMP_CRITICAL, ST_OMP_END_ATOMIC,
     277              :   ST_OMP_END_CRITICAL, ST_OMP_END_DO, ST_OMP_END_MASTER, ST_OMP_END_ORDERED,
     278              :   ST_OMP_END_PARALLEL, ST_OMP_END_PARALLEL_DO, ST_OMP_END_PARALLEL_SECTIONS,
     279              :   ST_OMP_END_PARALLEL_WORKSHARE, ST_OMP_END_SECTIONS, ST_OMP_END_SINGLE,
     280              :   ST_OMP_END_WORKSHARE, ST_OMP_DO, ST_OMP_FLUSH, ST_OMP_MASTER, ST_OMP_ORDERED,
     281              :   ST_OMP_PARALLEL, ST_OMP_PARALLEL_DO, ST_OMP_PARALLEL_SECTIONS,
     282              :   ST_OMP_PARALLEL_WORKSHARE, ST_OMP_SECTIONS, ST_OMP_SECTION, ST_OMP_SINGLE,
     283              :   ST_OMP_THREADPRIVATE, ST_OMP_WORKSHARE, ST_OMP_TASK, ST_OMP_END_TASK,
     284              :   ST_OMP_TASKWAIT, ST_OMP_TASKYIELD, ST_OMP_CANCEL, ST_OMP_CANCELLATION_POINT,
     285              :   ST_OMP_TASKGROUP, ST_OMP_END_TASKGROUP, ST_OMP_SIMD, ST_OMP_END_SIMD,
     286              :   ST_OMP_DO_SIMD, ST_OMP_END_DO_SIMD, ST_OMP_PARALLEL_DO_SIMD,
     287              :   ST_OMP_END_PARALLEL_DO_SIMD, ST_OMP_DECLARE_SIMD, ST_OMP_DECLARE_REDUCTION,
     288              :   ST_OMP_TARGET, ST_OMP_END_TARGET, ST_OMP_TARGET_DATA, ST_OMP_END_TARGET_DATA,
     289              :   ST_OMP_TARGET_UPDATE, ST_OMP_DECLARE_TARGET, ST_OMP_DECLARE_VARIANT,
     290              :   ST_OMP_TEAMS, ST_OMP_END_TEAMS, ST_OMP_DISTRIBUTE, ST_OMP_END_DISTRIBUTE,
     291              :   ST_OMP_DISTRIBUTE_SIMD, ST_OMP_END_DISTRIBUTE_SIMD,
     292              :   ST_OMP_DISTRIBUTE_PARALLEL_DO, ST_OMP_END_DISTRIBUTE_PARALLEL_DO,
     293              :   ST_OMP_DISTRIBUTE_PARALLEL_DO_SIMD, ST_OMP_END_DISTRIBUTE_PARALLEL_DO_SIMD,
     294              :   ST_OMP_TARGET_TEAMS, ST_OMP_END_TARGET_TEAMS, ST_OMP_TEAMS_DISTRIBUTE,
     295              :   ST_OMP_END_TEAMS_DISTRIBUTE, ST_OMP_TEAMS_DISTRIBUTE_SIMD,
     296              :   ST_OMP_END_TEAMS_DISTRIBUTE_SIMD, ST_OMP_TARGET_TEAMS_DISTRIBUTE,
     297              :   ST_OMP_END_TARGET_TEAMS_DISTRIBUTE, ST_OMP_TARGET_TEAMS_DISTRIBUTE_SIMD,
     298              :   ST_OMP_END_TARGET_TEAMS_DISTRIBUTE_SIMD, ST_OMP_TEAMS_DISTRIBUTE_PARALLEL_DO,
     299              :   ST_OMP_END_TEAMS_DISTRIBUTE_PARALLEL_DO,
     300              :   ST_OMP_TARGET_TEAMS_DISTRIBUTE_PARALLEL_DO,
     301              :   ST_OMP_END_TARGET_TEAMS_DISTRIBUTE_PARALLEL_DO,
     302              :   ST_OMP_TEAMS_DISTRIBUTE_PARALLEL_DO_SIMD,
     303              :   ST_OMP_END_TEAMS_DISTRIBUTE_PARALLEL_DO_SIMD,
     304              :   ST_OMP_TARGET_TEAMS_DISTRIBUTE_PARALLEL_DO_SIMD,
     305              :   ST_OMP_END_TARGET_TEAMS_DISTRIBUTE_PARALLEL_DO_SIMD,
     306              :   ST_OMP_TARGET_PARALLEL, ST_OMP_END_TARGET_PARALLEL,
     307              :   ST_OMP_TARGET_PARALLEL_DO, ST_OMP_END_TARGET_PARALLEL_DO,
     308              :   ST_OMP_TARGET_PARALLEL_DO_SIMD, ST_OMP_END_TARGET_PARALLEL_DO_SIMD,
     309              :   ST_OMP_TARGET_ENTER_DATA, ST_OMP_TARGET_EXIT_DATA,
     310              :   ST_OMP_TARGET_SIMD, ST_OMP_END_TARGET_SIMD,
     311              :   ST_OMP_TASKLOOP, ST_OMP_END_TASKLOOP, ST_OMP_SCAN, ST_OMP_DEPOBJ,
     312              :   ST_OMP_TASKLOOP_SIMD, ST_OMP_END_TASKLOOP_SIMD, ST_OMP_ORDERED_DEPEND,
     313              :   ST_OMP_REQUIRES, ST_PROCEDURE, ST_GENERIC, ST_CRITICAL, ST_END_CRITICAL,
     314              :   ST_OMP_GROUPPRIVATE,
     315              :   ST_GET_FCN_CHARACTERISTICS, ST_LOCK, ST_UNLOCK, ST_EVENT_POST,
     316              :   ST_EVENT_WAIT, ST_FAIL_IMAGE, ST_FORM_TEAM, ST_CHANGE_TEAM,
     317              :   ST_END_TEAM, ST_SYNC_TEAM,  ST_OMP_PARALLEL_MASTER,
     318              :   ST_OMP_END_PARALLEL_MASTER, ST_OMP_PARALLEL_MASTER_TASKLOOP,
     319              :   ST_OMP_END_PARALLEL_MASTER_TASKLOOP, ST_OMP_PARALLEL_MASTER_TASKLOOP_SIMD,
     320              :   ST_OMP_END_PARALLEL_MASTER_TASKLOOP_SIMD, ST_OMP_MASTER_TASKLOOP,
     321              :   ST_OMP_END_MASTER_TASKLOOP, ST_OMP_MASTER_TASKLOOP_SIMD,
     322              :   ST_OMP_END_MASTER_TASKLOOP_SIMD, ST_OMP_LOOP, ST_OMP_END_LOOP,
     323              :   ST_OMP_PARALLEL_LOOP, ST_OMP_END_PARALLEL_LOOP, ST_OMP_TEAMS_LOOP,
     324              :   ST_OMP_END_TEAMS_LOOP, ST_OMP_TARGET_PARALLEL_LOOP,
     325              :   ST_OMP_END_TARGET_PARALLEL_LOOP, ST_OMP_TARGET_TEAMS_LOOP,
     326              :   ST_OMP_END_TARGET_TEAMS_LOOP, ST_OMP_MASKED, ST_OMP_END_MASKED,
     327              :   ST_OMP_PARALLEL_MASKED, ST_OMP_END_PARALLEL_MASKED,
     328              :   ST_OMP_PARALLEL_MASKED_TASKLOOP, ST_OMP_END_PARALLEL_MASKED_TASKLOOP,
     329              :   ST_OMP_PARALLEL_MASKED_TASKLOOP_SIMD,
     330              :   ST_OMP_END_PARALLEL_MASKED_TASKLOOP_SIMD, ST_OMP_MASKED_TASKLOOP,
     331              :   ST_OMP_END_MASKED_TASKLOOP, ST_OMP_MASKED_TASKLOOP_SIMD,
     332              :   ST_OMP_END_MASKED_TASKLOOP_SIMD, ST_OMP_SCOPE, ST_OMP_END_SCOPE,
     333              :   ST_OMP_METADIRECTIVE, ST_OMP_BEGIN_METADIRECTIVE, ST_OMP_END_METADIRECTIVE,
     334              :   ST_OMP_ERROR, ST_OMP_ASSUME, ST_OMP_END_ASSUME, ST_OMP_ASSUMES,
     335              :   ST_OMP_ALLOCATE, ST_OMP_ALLOCATE_EXEC,
     336              :   ST_OMP_ALLOCATORS, ST_OMP_END_ALLOCATORS,
     337              :   /* Note: gfc_match_omp_nothing returns ST_NONE. */
     338              :   ST_OMP_NOTHING, ST_NONE,
     339              :   ST_OMP_UNROLL, ST_OMP_END_UNROLL,
     340              :   ST_OMP_TILE, ST_OMP_END_TILE, ST_OMP_INTEROP, ST_OMP_DISPATCH,
     341              :   ST_OMP_END_DISPATCH
     342              : };
     343              : 
     344              : /* Types of interfaces that we can have.  Assignment interfaces are
     345              :    considered to be intrinsic operators.  */
     346              : enum interface_type
     347              : {
     348              :   INTERFACE_NAMELESS = 1, INTERFACE_GENERIC,
     349              :   INTERFACE_INTRINSIC_OP, INTERFACE_USER_OP, INTERFACE_ABSTRACT,
     350              :   INTERFACE_DTIO
     351              : };
     352              : 
     353              : /* Symbol flavors: these are all mutually exclusive.
     354              :    12 elements = 4 bits.  */
     355              : enum sym_flavor
     356              : {
     357              :   FL_UNKNOWN = 0, FL_PROGRAM, FL_BLOCK_DATA, FL_MODULE, FL_VARIABLE,
     358              :   FL_PARAMETER, FL_LABEL, FL_PROCEDURE, FL_DERIVED, FL_NAMELIST,
     359              :   FL_UNION, FL_STRUCT, FL_VOID
     360              : };
     361              : 
     362              : /* Procedure types.  7 elements = 3 bits.  */
     363              : enum procedure_type
     364              : { PROC_UNKNOWN, PROC_MODULE, PROC_INTERNAL, PROC_DUMMY,
     365              :   PROC_INTRINSIC, PROC_ST_FUNCTION, PROC_EXTERNAL
     366              : };
     367              : 
     368              : /* Intent types. Note that these values are also used in another enum in
     369              :    decl.cc (match_attr_spec).  */
     370              : enum sym_intent
     371              : { INTENT_UNKNOWN = 0, INTENT_IN, INTENT_OUT, INTENT_INOUT
     372              : };
     373              : 
     374              : /* Access types.  */
     375              : enum gfc_access
     376              : { ACCESS_UNKNOWN = 0, ACCESS_PUBLIC, ACCESS_PRIVATE
     377              : };
     378              : 
     379              : /* Flags to keep track of where an interface came from.
     380              :    3 elements = 2 bits.  */
     381              : enum ifsrc
     382              : { IFSRC_UNKNOWN = 0,    /* Interface unknown, only return type may be known.  */
     383              :   IFSRC_DECL,           /* FUNCTION or SUBROUTINE declaration.  */
     384              :   IFSRC_IFBODY          /* INTERFACE statement or PROCEDURE statement
     385              :                            with explicit interface.  */
     386              : };
     387              : 
     388              : /* Whether a SAVE attribute was set explicitly or implicitly.  */
     389              : enum save_state
     390              : { SAVE_NONE = 0, SAVE_EXPLICIT, SAVE_IMPLICIT
     391              : };
     392              : 
     393              : /* OpenACC 'routine' directive's level of parallelism.  */
     394              : enum oacc_routine_lop
     395              : { OACC_ROUTINE_LOP_NONE = 0,
     396              :   OACC_ROUTINE_LOP_GANG,
     397              :   OACC_ROUTINE_LOP_WORKER,
     398              :   OACC_ROUTINE_LOP_VECTOR,
     399              :   OACC_ROUTINE_LOP_SEQ,
     400              :   OACC_ROUTINE_LOP_ERROR
     401              : };
     402              : 
     403              : /* Strings for all symbol attributes.  We use these for dumping the
     404              :    parse tree, in error messages, and also when reading and writing
     405              :    modules.  In symbol.cc.  */
     406              : extern const mstring flavors[];
     407              : extern const mstring procedures[];
     408              : extern const mstring intents[];
     409              : extern const mstring access_types[];
     410              : extern const mstring ifsrc_types[];
     411              : extern const mstring save_status[];
     412              : 
     413              : /* Strings for DTIO procedure names.  In symbol.cc.  */
     414              : extern const mstring dtio_procs[];
     415              : 
     416              : enum dtio_codes
     417              : { DTIO_RF = 0, DTIO_WF, DTIO_RUF, DTIO_WUF };
     418              : 
     419              : /* Enumeration of all the generic intrinsic functions.  Used by the
     420              :    backend for identification of a function.  */
     421              : 
     422              : enum gfc_isym_id
     423              : {
     424              :   /* GFC_ISYM_NONE is used for intrinsics which will never be seen by
     425              :      the backend (e.g. KIND).  */
     426              :   GFC_ISYM_NONE = 0,
     427              :   GFC_ISYM_ABORT,
     428              :   GFC_ISYM_ABS,
     429              :   GFC_ISYM_ACCESS,
     430              :   GFC_ISYM_ACHAR,
     431              :   GFC_ISYM_ACOS,
     432              :   GFC_ISYM_ACOSD,
     433              :   GFC_ISYM_ACOSH,
     434              :   GFC_ISYM_ADJUSTL,
     435              :   GFC_ISYM_ADJUSTR,
     436              :   GFC_ISYM_AIMAG,
     437              :   GFC_ISYM_AINT,
     438              :   GFC_ISYM_ALARM,
     439              :   GFC_ISYM_ALL,
     440              :   GFC_ISYM_ALLOCATED,
     441              :   GFC_ISYM_AND,
     442              :   GFC_ISYM_ANINT,
     443              :   GFC_ISYM_ANY,
     444              :   GFC_ISYM_ASIN,
     445              :   GFC_ISYM_ASIND,
     446              :   GFC_ISYM_ASINH,
     447              :   GFC_ISYM_ASSOCIATED,
     448              :   GFC_ISYM_ATAN,
     449              :   GFC_ISYM_ATAN2,
     450              :   GFC_ISYM_ATAN2D,
     451              :   GFC_ISYM_ATAND,
     452              :   GFC_ISYM_ATANH,
     453              :   GFC_ISYM_ATOMIC_ADD,
     454              :   GFC_ISYM_ATOMIC_AND,
     455              :   GFC_ISYM_ATOMIC_CAS,
     456              :   GFC_ISYM_ATOMIC_DEF,
     457              :   GFC_ISYM_ATOMIC_FETCH_ADD,
     458              :   GFC_ISYM_ATOMIC_FETCH_AND,
     459              :   GFC_ISYM_ATOMIC_FETCH_OR,
     460              :   GFC_ISYM_ATOMIC_FETCH_XOR,
     461              :   GFC_ISYM_ATOMIC_OR,
     462              :   GFC_ISYM_ATOMIC_REF,
     463              :   GFC_ISYM_ATOMIC_XOR,
     464              :   GFC_ISYM_BGE,
     465              :   GFC_ISYM_BGT,
     466              :   GFC_ISYM_BIT_SIZE,
     467              :   GFC_ISYM_BLE,
     468              :   GFC_ISYM_BLT,
     469              :   GFC_ISYM_BTEST,
     470              :   GFC_ISYM_CAF_GET,
     471              :   GFC_ISYM_CAF_IS_PRESENT_ON_REMOTE,
     472              :   GFC_ISYM_CAF_SEND,
     473              :   GFC_ISYM_CAF_SENDGET,
     474              :   GFC_ISYM_CEILING,
     475              :   GFC_ISYM_CHAR,
     476              :   GFC_ISYM_CHDIR,
     477              :   GFC_ISYM_CHMOD,
     478              :   GFC_ISYM_CMPLX,
     479              :   GFC_ISYM_CO_BROADCAST,
     480              :   GFC_ISYM_CO_MAX,
     481              :   GFC_ISYM_CO_MIN,
     482              :   GFC_ISYM_CO_REDUCE,
     483              :   GFC_ISYM_CO_SUM,
     484              :   GFC_ISYM_COMMAND_ARGUMENT_COUNT,
     485              :   GFC_ISYM_COMPILER_OPTIONS,
     486              :   GFC_ISYM_COMPILER_VERSION,
     487              :   GFC_ISYM_COMPLEX,
     488              :   GFC_ISYM_CONJG,
     489              :   GFC_ISYM_CONVERSION,
     490              :   GFC_ISYM_COS,
     491              :   GFC_ISYM_COSD,
     492              :   GFC_ISYM_COSH,
     493              :   GFC_ISYM_COSHAPE,
     494              :   GFC_ISYM_COTAN,
     495              :   GFC_ISYM_COTAND,
     496              :   GFC_ISYM_COUNT,
     497              :   GFC_ISYM_CPU_TIME,
     498              :   GFC_ISYM_CSHIFT,
     499              :   GFC_ISYM_CTIME,
     500              :   GFC_ISYM_C_ASSOCIATED,
     501              :   GFC_ISYM_C_F_POINTER,
     502              :   GFC_ISYM_C_F_PROCPOINTER,
     503              :   GFC_ISYM_C_FUNLOC,
     504              :   GFC_ISYM_C_LOC,
     505              :   GFC_ISYM_C_SIZEOF,
     506              :   GFC_ISYM_DATE_AND_TIME,
     507              :   GFC_ISYM_DBLE,
     508              :   GFC_ISYM_DFLOAT,
     509              :   GFC_ISYM_DIGITS,
     510              :   GFC_ISYM_DIM,
     511              :   GFC_ISYM_DOT_PRODUCT,
     512              :   GFC_ISYM_DPROD,
     513              :   GFC_ISYM_DSHIFTL,
     514              :   GFC_ISYM_DSHIFTR,
     515              :   GFC_ISYM_DTIME,
     516              :   GFC_ISYM_EOSHIFT,
     517              :   GFC_ISYM_EPSILON,
     518              :   GFC_ISYM_ERF,
     519              :   GFC_ISYM_ERFC,
     520              :   GFC_ISYM_ERFC_SCALED,
     521              :   GFC_ISYM_ETIME,
     522              :   GFC_ISYM_EVENT_QUERY,
     523              :   GFC_ISYM_EXECUTE_COMMAND_LINE,
     524              :   GFC_ISYM_EXIT,
     525              :   GFC_ISYM_EXP,
     526              :   GFC_ISYM_EXPONENT,
     527              :   GFC_ISYM_EXTENDS_TYPE_OF,
     528              :   GFC_ISYM_F_C_STRING,
     529              :   GFC_ISYM_FAILED_IMAGES,
     530              :   GFC_ISYM_FDATE,
     531              :   GFC_ISYM_FE_RUNTIME_ERROR,
     532              :   GFC_ISYM_FGET,
     533              :   GFC_ISYM_FGETC,
     534              :   GFC_ISYM_FINDLOC,
     535              :   GFC_ISYM_FLOAT,
     536              :   GFC_ISYM_FLOOR,
     537              :   GFC_ISYM_FLUSH,
     538              :   GFC_ISYM_FNUM,
     539              :   GFC_ISYM_FPUT,
     540              :   GFC_ISYM_FPUTC,
     541              :   GFC_ISYM_FRACTION,
     542              :   GFC_ISYM_FREE,
     543              :   GFC_ISYM_FSEEK,
     544              :   GFC_ISYM_FSTAT,
     545              :   GFC_ISYM_FTELL,
     546              :   GFC_ISYM_TGAMMA,
     547              :   GFC_ISYM_GERROR,
     548              :   GFC_ISYM_GETARG,
     549              :   GFC_ISYM_GET_COMMAND,
     550              :   GFC_ISYM_GET_COMMAND_ARGUMENT,
     551              :   GFC_ISYM_GETCWD,
     552              :   GFC_ISYM_GETENV,
     553              :   GFC_ISYM_GET_ENVIRONMENT_VARIABLE,
     554              :   GFC_ISYM_GETGID,
     555              :   GFC_ISYM_GETLOG,
     556              :   GFC_ISYM_GETPID,
     557              :   GFC_ISYM_GET_TEAM,
     558              :   GFC_ISYM_GETUID,
     559              :   GFC_ISYM_GMTIME,
     560              :   GFC_ISYM_HOSTNM,
     561              :   GFC_ISYM_HUGE,
     562              :   GFC_ISYM_HYPOT,
     563              :   GFC_ISYM_IACHAR,
     564              :   GFC_ISYM_IALL,
     565              :   GFC_ISYM_IAND,
     566              :   GFC_ISYM_IANY,
     567              :   GFC_ISYM_IARGC,
     568              :   GFC_ISYM_IBCLR,
     569              :   GFC_ISYM_IBITS,
     570              :   GFC_ISYM_IBSET,
     571              :   GFC_ISYM_ICHAR,
     572              :   GFC_ISYM_IDATE,
     573              :   GFC_ISYM_IEOR,
     574              :   GFC_ISYM_IERRNO,
     575              :   GFC_ISYM_IMAGE_INDEX,
     576              :   GFC_ISYM_IMAGE_STATUS,
     577              :   GFC_ISYM_INDEX,
     578              :   GFC_ISYM_INT,
     579              :   GFC_ISYM_INT2,
     580              :   GFC_ISYM_INT8,
     581              :   GFC_ISYM_IOR,
     582              :   GFC_ISYM_IPARITY,
     583              :   GFC_ISYM_IRAND,
     584              :   GFC_ISYM_ISATTY,
     585              :   GFC_ISYM_IS_CONTIGUOUS,
     586              :   GFC_ISYM_IS_IOSTAT_END,
     587              :   GFC_ISYM_IS_IOSTAT_EOR,
     588              :   GFC_ISYM_ISNAN,
     589              :   GFC_ISYM_ISHFT,
     590              :   GFC_ISYM_ISHFTC,
     591              :   GFC_ISYM_ITIME,
     592              :   GFC_ISYM_J0,
     593              :   GFC_ISYM_J1,
     594              :   GFC_ISYM_JN,
     595              :   GFC_ISYM_JN2,
     596              :   GFC_ISYM_KILL,
     597              :   GFC_ISYM_KIND,
     598              :   GFC_ISYM_LBOUND,
     599              :   GFC_ISYM_LCOBOUND,
     600              :   GFC_ISYM_LEADZ,
     601              :   GFC_ISYM_LEN,
     602              :   GFC_ISYM_LEN_TRIM,
     603              :   GFC_ISYM_LGAMMA,
     604              :   GFC_ISYM_LGE,
     605              :   GFC_ISYM_LGT,
     606              :   GFC_ISYM_LINK,
     607              :   GFC_ISYM_LLE,
     608              :   GFC_ISYM_LLT,
     609              :   GFC_ISYM_LOC,
     610              :   GFC_ISYM_LOG,
     611              :   GFC_ISYM_LOG10,
     612              :   GFC_ISYM_LOGICAL,
     613              :   GFC_ISYM_LONG,
     614              :   GFC_ISYM_LSHIFT,
     615              :   GFC_ISYM_LSTAT,
     616              :   GFC_ISYM_LTIME,
     617              :   GFC_ISYM_MALLOC,
     618              :   GFC_ISYM_MASKL,
     619              :   GFC_ISYM_MASKR,
     620              :   GFC_ISYM_MATMUL,
     621              :   GFC_ISYM_MAX,
     622              :   GFC_ISYM_MAXEXPONENT,
     623              :   GFC_ISYM_MAXLOC,
     624              :   GFC_ISYM_MAXVAL,
     625              :   GFC_ISYM_MCLOCK,
     626              :   GFC_ISYM_MCLOCK8,
     627              :   GFC_ISYM_MERGE,
     628              :   GFC_ISYM_MERGE_BITS,
     629              :   GFC_ISYM_MIN,
     630              :   GFC_ISYM_MINEXPONENT,
     631              :   GFC_ISYM_MINLOC,
     632              :   GFC_ISYM_MINVAL,
     633              :   GFC_ISYM_MOD,
     634              :   GFC_ISYM_MODULO,
     635              :   GFC_ISYM_MOVE_ALLOC,
     636              :   GFC_ISYM_MVBITS,
     637              :   GFC_ISYM_NEAREST,
     638              :   GFC_ISYM_NEW_LINE,
     639              :   GFC_ISYM_NINT,
     640              :   GFC_ISYM_NORM2,
     641              :   GFC_ISYM_NOT,
     642              :   GFC_ISYM_NULL,
     643              :   GFC_ISYM_NUM_IMAGES,
     644              :   GFC_ISYM_OR,
     645              :   GFC_ISYM_OUT_OF_RANGE,
     646              :   GFC_ISYM_PACK,
     647              :   GFC_ISYM_PARITY,
     648              :   GFC_ISYM_PERROR,
     649              :   GFC_ISYM_POPCNT,
     650              :   GFC_ISYM_POPPAR,
     651              :   GFC_ISYM_PRECISION,
     652              :   GFC_ISYM_PRESENT,
     653              :   GFC_ISYM_PRODUCT,
     654              :   GFC_ISYM_RADIX,
     655              :   GFC_ISYM_RAND,
     656              :   GFC_ISYM_RANDOM_INIT,
     657              :   GFC_ISYM_RANDOM_NUMBER,
     658              :   GFC_ISYM_RANDOM_SEED,
     659              :   GFC_ISYM_RANGE,
     660              :   GFC_ISYM_RANK,
     661              :   GFC_ISYM_REAL,
     662              :   GFC_ISYM_REALPART,
     663              :   GFC_ISYM_REDUCE,
     664              :   GFC_ISYM_RENAME,
     665              :   GFC_ISYM_REPEAT,
     666              :   GFC_ISYM_RESHAPE,
     667              :   GFC_ISYM_RRSPACING,
     668              :   GFC_ISYM_RSHIFT,
     669              :   GFC_ISYM_SAME_TYPE_AS,
     670              :   GFC_ISYM_SC_KIND,
     671              :   GFC_ISYM_SCALE,
     672              :   GFC_ISYM_SCAN,
     673              :   GFC_ISYM_SECNDS,
     674              :   GFC_ISYM_SECOND,
     675              :   GFC_ISYM_SET_EXPONENT,
     676              :   GFC_ISYM_SHAPE,
     677              :   GFC_ISYM_SHIFTA,
     678              :   GFC_ISYM_SHIFTL,
     679              :   GFC_ISYM_SHIFTR,
     680              :   GFC_ISYM_BACKTRACE,
     681              :   GFC_ISYM_SIGN,
     682              :   GFC_ISYM_SIGNAL,
     683              :   GFC_ISYM_SI_KIND,
     684              :   GFC_ISYM_SIN,
     685              :   GFC_ISYM_SIND,
     686              :   GFC_ISYM_SINH,
     687              :   GFC_ISYM_SIZE,
     688              :   GFC_ISYM_SL_KIND,
     689              :   GFC_ISYM_SLEEP,
     690              :   GFC_ISYM_SIZEOF,
     691              :   GFC_ISYM_SNGL,
     692              :   GFC_ISYM_SPACING,
     693              :   GFC_ISYM_SPREAD,
     694              :   GFC_ISYM_SQRT,
     695              :   GFC_ISYM_SRAND,
     696              :   GFC_ISYM_SR_KIND,
     697              :   GFC_ISYM_STAT,
     698              :   GFC_ISYM_STOPPED_IMAGES,
     699              :   GFC_ISYM_STORAGE_SIZE,
     700              :   GFC_ISYM_STRIDE,
     701              :   GFC_ISYM_SUM,
     702              :   GFC_ISYM_SYMLINK,
     703              :   GFC_ISYM_SYMLNK,
     704              :   GFC_ISYM_SYSTEM,
     705              :   GFC_ISYM_SYSTEM_CLOCK,
     706              :   GFC_ISYM_TAN,
     707              :   GFC_ISYM_TAND,
     708              :   GFC_ISYM_TANH,
     709              :   GFC_ISYM_TEAM_NUMBER,
     710              :   GFC_ISYM_THIS_IMAGE,
     711              :   GFC_ISYM_TIME,
     712              :   GFC_ISYM_TIME8,
     713              :   GFC_ISYM_TINY,
     714              :   GFC_ISYM_TRAILZ,
     715              :   GFC_ISYM_TRANSFER,
     716              :   GFC_ISYM_TRANSPOSE,
     717              :   GFC_ISYM_TRIM,
     718              :   GFC_ISYM_TTYNAM,
     719              :   GFC_ISYM_UBOUND,
     720              :   GFC_ISYM_UCOBOUND,
     721              :   GFC_ISYM_UMASK,
     722              :   GFC_ISYM_UMASKL,
     723              :   GFC_ISYM_UMASKR,
     724              :   GFC_ISYM_UNLINK,
     725              :   GFC_ISYM_UNPACK,
     726              :   GFC_ISYM_VERIFY,
     727              :   GFC_ISYM_XOR,
     728              :   GFC_ISYM_Y0,
     729              :   GFC_ISYM_Y1,
     730              :   GFC_ISYM_YN,
     731              :   GFC_ISYM_YN2,
     732              : 
     733              :   /* Add this at the end, so maybe the module format
     734              :      remains compatible.  */
     735              :   GFC_ISYM_SU_KIND,
     736              :   GFC_ISYM_UINT,
     737              : 
     738              :   GFC_ISYM_ACOSPI,
     739              :   GFC_ISYM_ASINPI,
     740              :   GFC_ISYM_ATANPI,
     741              :   GFC_ISYM_ATAN2PI,
     742              :   GFC_ISYM_COSPI,
     743              :   GFC_ISYM_SINPI,
     744              :   GFC_ISYM_TANPI,
     745              : 
     746              :   GFC_ISYM_SPLIT,
     747              : };
     748              : 
     749              : enum init_local_logical
     750              : {
     751              :   GFC_INIT_LOGICAL_OFF = 0,
     752              :   GFC_INIT_LOGICAL_FALSE,
     753              :   GFC_INIT_LOGICAL_TRUE
     754              : };
     755              : 
     756              : enum init_local_character
     757              : {
     758              :   GFC_INIT_CHARACTER_OFF = 0,
     759              :   GFC_INIT_CHARACTER_ON
     760              : };
     761              : 
     762              : enum init_local_integer
     763              : {
     764              :   GFC_INIT_INTEGER_OFF = 0,
     765              :   GFC_INIT_INTEGER_ON
     766              : };
     767              : 
     768              : enum gfc_reverse
     769              : {
     770              :   GFC_ENABLE_REVERSE,
     771              :   GFC_FORWARD_SET,
     772              :   GFC_REVERSE_SET,
     773              :   GFC_INHIBIT_REVERSE
     774              : };
     775              : 
     776              : enum gfc_param_spec_type
     777              : {
     778              :   SPEC_EXPLICIT,
     779              :   SPEC_ASSUMED,
     780              :   SPEC_DEFERRED
     781              : };
     782              : 
     783              : /************************* Structures *****************************/
     784              : 
     785              : /* Used for keeping things in balanced binary trees.  */
     786              : #define BBT_HEADER(self) int priority; struct self *left, *right
     787              : 
     788              : #define NAMED_INTCST(a,b,c,d) a,
     789              : #define NAMED_UINTCST(a,b,c,d) a,
     790              : #define NAMED_KINDARRAY(a,b,c,d) a,
     791              : #define NAMED_FUNCTION(a,b,c,d) a,
     792              : #define NAMED_SUBROUTINE(a,b,c,d) a,
     793              : #define NAMED_DERIVED_TYPE(a,b,c,d) a,
     794              : enum iso_fortran_env_symbol
     795              : {
     796              :   ISOFORTRANENV_INVALID = -1,
     797              : #include "iso-fortran-env.def"
     798              :   ISOFORTRANENV_LAST, ISOFORTRANENV_NUMBER = ISOFORTRANENV_LAST
     799              : };
     800              : #undef NAMED_INTCST
     801              : #undef NANED_UINTCST
     802              : #undef NAMED_KINDARRAY
     803              : #undef NAMED_FUNCTION
     804              : #undef NAMED_SUBROUTINE
     805              : #undef NAMED_DERIVED_TYPE
     806              : 
     807              : #define NAMED_INTCST(a,b,c,d) a,
     808              : #define NAMED_REALCST(a,b,c,d) a,
     809              : #define NAMED_CMPXCST(a,b,c,d) a,
     810              : #define NAMED_LOGCST(a,b,c) a,
     811              : #define NAMED_CHARKNDCST(a,b,c) a,
     812              : #define NAMED_CHARCST(a,b,c) a,
     813              : #define DERIVED_TYPE(a,b,c) a,
     814              : #define NAMED_FUNCTION(a,b,c,d) a,
     815              : #define NAMED_SUBROUTINE(a,b,c,d) a,
     816              : #define NAMED_UINTCST(a,b,c,d) a,
     817              : enum iso_c_binding_symbol
     818              : {
     819              :   ISOCBINDING_INVALID = -1,
     820              : #include "iso-c-binding.def"
     821              :   ISOCBINDING_LAST,
     822              :   ISOCBINDING_NUMBER = ISOCBINDING_LAST
     823              : };
     824              : #undef NAMED_INTCST
     825              : #undef NAMED_REALCST
     826              : #undef NAMED_CMPXCST
     827              : #undef NAMED_LOGCST
     828              : #undef NAMED_CHARKNDCST
     829              : #undef NAMED_CHARCST
     830              : #undef DERIVED_TYPE
     831              : #undef NAMED_FUNCTION
     832              : #undef NAMED_SUBROUTINE
     833              : #undef NAMED_UINTCST
     834              : 
     835              : enum intmod_id
     836              : {
     837              :   INTMOD_NONE = 0, INTMOD_ISO_FORTRAN_ENV, INTMOD_ISO_C_BINDING,
     838              :   INTMOD_IEEE_FEATURES, INTMOD_IEEE_EXCEPTIONS, INTMOD_IEEE_ARITHMETIC
     839              : };
     840              : 
     841              : typedef struct
     842              : {
     843              :   char name[GFC_MAX_SYMBOL_LEN + 1];
     844              :   int value;  /* Used for both integer and character values.  */
     845              :   bt f90_type;
     846              : }
     847              : CInteropKind_t;
     848              : 
     849              : /* Array of structs, where the structs represent the C interop kinds.
     850              :    The list will be implemented based on a hash of the kind name since
     851              :    these could be accessed multiple times.
     852              :    Declared in trans-types.cc as a global, since it's in that file
     853              :    that the list is initialized.  */
     854              : extern CInteropKind_t c_interop_kinds_table[];
     855              : 
     856              : enum gfc_omp_device_type
     857              : {
     858              :   OMP_DEVICE_TYPE_UNSET,
     859              :   OMP_DEVICE_TYPE_HOST,
     860              :   OMP_DEVICE_TYPE_NOHOST,
     861              :   OMP_DEVICE_TYPE_ANY
     862              : };
     863              : 
     864              : enum gfc_omp_severity_type
     865              : {
     866              :   OMP_SEVERITY_UNSET,
     867              :   OMP_SEVERITY_WARNING,
     868              :   OMP_SEVERITY_FATAL
     869              : };
     870              : 
     871              : enum gfc_omp_at_type
     872              : {
     873              :   OMP_AT_UNSET,
     874              :   OMP_AT_COMPILATION,
     875              :   OMP_AT_EXECUTION
     876              : };
     877              : 
     878              : /* Structure and list of supported extension attributes.  */
     879              : typedef enum
     880              : {
     881              :   EXT_ATTR_DLLIMPORT = 0,
     882              :   EXT_ATTR_DLLEXPORT,
     883              :   EXT_ATTR_STDCALL,
     884              :   EXT_ATTR_CDECL,
     885              :   EXT_ATTR_FASTCALL,
     886              :   EXT_ATTR_NO_ARG_CHECK,
     887              :   EXT_ATTR_DEPRECATED,
     888              :   EXT_ATTR_NOINLINE,
     889              :   EXT_ATTR_NORETURN,
     890              :   EXT_ATTR_WEAK,
     891              :   EXT_ATTR_LAST, EXT_ATTR_NUM = EXT_ATTR_LAST
     892              : }
     893              : ext_attr_id_t;
     894              : 
     895              : typedef struct
     896              : {
     897              :   const char *name;
     898              :   unsigned id;
     899              :   const char *middle_end_name;
     900              : }
     901              : ext_attr_t;
     902              : 
     903              : extern const ext_attr_t ext_attr_list[];
     904              : 
     905              : /* Symbol attribute structure.  */
     906              : typedef struct
     907              : {
     908              :   /* Variable attributes.  */
     909              :   unsigned allocatable:1, dimension:1, codimension:1, external:1, intrinsic:1,
     910              :     optional:1, pointer:1, target:1, value:1, volatile_:1, temporary:1,
     911              :     dummy:1, result:1, assign:1, threadprivate:1, not_always_present:1,
     912              :     implied_index:1, subref_array_pointer:1, proc_pointer:1, asynchronous:1,
     913              :     contiguous:1, fe_temp: 1, automatic: 1;
     914              : 
     915              :   /* For CLASS containers, the pointer attribute is sometimes set internally
     916              :      even though it was not directly specified.  In this case, keep the
     917              :      "real" (original) value here.  */
     918              :   unsigned class_pointer:1;
     919              : 
     920              :   ENUM_BITFIELD (save_state) save:2;
     921              : 
     922              :   unsigned data:1,              /* Symbol is named in a DATA statement.  */
     923              :     is_protected:1,             /* Symbol has been marked as protected.  */
     924              :     use_assoc:1,                /* Symbol has been use-associated.  */
     925              :     used_in_submodule:1,        /* Symbol has been use-associated in a
     926              :                                    submodule. Needed since these entities must
     927              :                                    be set host associated to be compliant.  */
     928              :     use_only:1,                 /* Symbol has been use-associated, with ONLY.  */
     929              :     use_rename:1,               /* Symbol has been use-associated and renamed.  */
     930              :     imported:1,                 /* Symbol has been associated by IMPORT.  */
     931              :     host_assoc:1;               /* Symbol has been host associated.  */
     932              : 
     933              :   unsigned in_namelist:1, in_common:1, in_equivalence:1;
     934              :   unsigned function:1, subroutine:1, procedure:1;
     935              :   unsigned generic:1, generic_copy:1;
     936              :   unsigned implicit_type:1;     /* Type defined via implicit rules.  */
     937              :   unsigned untyped:1;           /* No implicit type could be found.  */
     938              : 
     939              :   unsigned is_bind_c:1;         /* say if is bound to C.  */
     940              :   unsigned extension:8;         /* extension level of a derived type.  */
     941              :   unsigned is_class:1;          /* is a CLASS container.  */
     942              :   unsigned class_ok:1;          /* is a CLASS object with correct attributes.  */
     943              :   unsigned vtab:1;              /* is a derived type vtab, pointed to by CLASS objects.  */
     944              :   unsigned vtype:1;             /* is a derived type of a vtab.  */
     945              : 
     946              :   /* These flags are both in the typespec and attribute.  The attribute
     947              :      list is what gets read from/written to a module file.  The typespec
     948              :      is created from a decl being processed.  */
     949              :   unsigned is_c_interop:1;      /* It's c interoperable.  */
     950              :   unsigned is_iso_c:1;          /* Symbol is from iso_c_binding.  */
     951              : 
     952              :   /* Function/subroutine attributes */
     953              :   unsigned sequence:1, elemental:1, pure:1, recursive:1;
     954              :   unsigned unmaskable:1, masked:1, contained:1, mod_proc:1, abstract:1;
     955              : 
     956              :   /* Set if this is a module function or subroutine. Note that it is an
     957              :      attribute because it appears as a prefix in the declaration like
     958              :      PURE, etc..  */
     959              :   unsigned module_procedure:1;
     960              : 
     961              :   /* Set if a (public) symbol [e.g. generic name] exposes this symbol,
     962              :      which is relevant for private module procedures.  */
     963              :   unsigned public_used:1;
     964              : 
     965              :   /* This is set if a contained procedure could be declared pure.  This is
     966              :      used for certain optimizations that require the result or arguments
     967              :      cannot alias.  Note that this is zero for PURE procedures.  */
     968              :   unsigned implicit_pure:1;
     969              : 
     970              :   /* This is set for a procedure that contains expressions referencing
     971              :      arrays coming from outside its namespace.
     972              :      This is used to force the creation of a temporary when the LHS of
     973              :      an array assignment may be used by an elemental procedure appearing
     974              :      on the RHS.  */
     975              :   unsigned array_outer_dependency:1;
     976              : 
     977              :   /* This is set if the subroutine doesn't return.  Currently, this
     978              :      is only possible for intrinsic subroutines.  */
     979              :   unsigned noreturn:1;
     980              : 
     981              :   /* Set if this procedure is an alternate entry point.  These procedures
     982              :      don't have any code associated, and the backend will turn them into
     983              :      thunks to the master function.  */
     984              :   unsigned entry:1;
     985              : 
     986              :   /* Set if this is the master function for a procedure with multiple
     987              :      entry points.  */
     988              :   unsigned entry_master:1;
     989              : 
     990              :   /* Set if this is the master function for a function with multiple
     991              :      entry points where characteristics of the entry points differ.  */
     992              :   unsigned mixed_entry_master:1;
     993              : 
     994              :   /* Set if a function must always be referenced by an explicit interface.  */
     995              :   unsigned always_explicit:1;
     996              : 
     997              :   /* Set if the symbol is generated and, hence, standard violations
     998              :      shouldn't be flaged.  */
     999              :   unsigned artificial:1;
    1000              : 
    1001              :   /* Set if the symbol has been referenced in an expression.  No further
    1002              :      modification of type or type parameters is permitted.  */
    1003              :   unsigned referenced:1;
    1004              : 
    1005              :   /* Set if this is the symbol for the main program.  */
    1006              :   unsigned is_main_program:1;
    1007              : 
    1008              :   /* Mutually exclusive multibit attributes.  */
    1009              :   ENUM_BITFIELD (gfc_access) access:2;
    1010              :   ENUM_BITFIELD (sym_intent) intent:2;
    1011              :   ENUM_BITFIELD (sym_flavor) flavor:4;
    1012              :   ENUM_BITFIELD (ifsrc) if_source:2;
    1013              : 
    1014              :   ENUM_BITFIELD (procedure_type) proc:3;
    1015              : 
    1016              :   /* Special attributes for Cray pointers, pointees.  */
    1017              :   unsigned cray_pointer:1, cray_pointee:1;
    1018              : 
    1019              :   /* The symbol is a derived type with allocatable components, pointer
    1020              :      components or private components, procedure pointer components,
    1021              :      possibly nested.  zero_comp is true if the derived type has no
    1022              :      component at all.  defined_assign_comp is true if the derived
    1023              :      type or a (sub-)component has a typebound defined assignment.
    1024              :      unlimited_polymorphic flags the type of the container for these
    1025              :      entities.  */
    1026              :   unsigned alloc_comp:1, pointer_comp:1, proc_pointer_comp:1,
    1027              :            private_comp:1, zero_comp:1, coarray_comp:1, lock_comp:1,
    1028              :            event_comp:1, defined_assign_comp:1, unlimited_polymorphic:1,
    1029              :            has_dtio_procs:1, caf_token:1;
    1030              : 
    1031              :   /* This is a temporary selector for SELECT TYPE/RANK or an associate
    1032              :      variable for SELECT TYPE/RANK or ASSOCIATE.  */
    1033              :   unsigned select_type_temporary:1, select_rank_temporary:1, associate_var:1;
    1034              : 
    1035              :   /* These are the attributes required for parameterized derived
    1036              :      types.  */
    1037              :   unsigned pdt_kind:1, pdt_len:1, pdt_type:1, pdt_template:1,
    1038              :            pdt_array:1, pdt_string:1, pdt_comp:1;
    1039              : 
    1040              :   /* This is omp_{out,in,priv,orig} artificial variable in
    1041              :      !$OMP DECLARE REDUCTION.  */
    1042              :   unsigned omp_udr_artificial_var:1;
    1043              : 
    1044              :   /* Mentioned in OMP DECLARE TARGET.  */
    1045              :   unsigned omp_declare_target:1;
    1046              :   unsigned omp_declare_target_link:1;
    1047              :   unsigned omp_declare_target_local:1;
    1048              :   unsigned omp_declare_target_indirect:1;
    1049              :   ENUM_BITFIELD (gfc_omp_device_type) omp_device_type:2;
    1050              :   unsigned omp_groupprivate:1;
    1051              :   unsigned omp_allocate:1;
    1052              : 
    1053              :   /* Mentioned in OACC DECLARE.  */
    1054              :   unsigned oacc_declare_create:1;
    1055              :   unsigned oacc_declare_copyin:1;
    1056              :   unsigned oacc_declare_deviceptr:1;
    1057              :   unsigned oacc_declare_device_resident:1;
    1058              :   unsigned oacc_declare_link:1;
    1059              : 
    1060              :   /* OpenACC 'routine' directive's level of parallelism.  */
    1061              :   ENUM_BITFIELD (oacc_routine_lop) oacc_routine_lop:3;
    1062              :   unsigned oacc_routine_nohost:1;
    1063              : 
    1064              :   /* Attributes set by compiler extensions (!GCC$ ATTRIBUTES).  */
    1065              :   unsigned ext_attr:EXT_ATTR_NUM;
    1066              : 
    1067              :   /* The namespace where the attribute has been set.  */
    1068              :   struct gfc_namespace *volatile_ns, *asynchronous_ns;
    1069              : }
    1070              : symbol_attribute;
    1071              : 
    1072              : 
    1073              : /* We need to store source lines as sequences of multibyte source
    1074              :    characters. We define here a type wide enough to hold any multibyte
    1075              :    source character, just like libcpp does.  A 32-bit type is enough.  */
    1076              : 
    1077              : #if HOST_BITS_PER_INT >= 32
    1078              : typedef unsigned int gfc_char_t;
    1079              : #elif HOST_BITS_PER_LONG >= 32
    1080              : typedef unsigned long gfc_char_t;
    1081              : #elif defined(HAVE_LONG_LONG) && (HOST_BITS_PER_LONGLONG >= 32)
    1082              : typedef unsigned long long gfc_char_t;
    1083              : #else
    1084              : # error "Cannot find an integer type with at least 32 bits"
    1085              : #endif
    1086              : 
    1087              : 
    1088              : /* The following three structures are used to identify a location in
    1089              :    the sources.
    1090              : 
    1091              :    gfc_file is used to maintain a tree of the source files and how
    1092              :    they include each other
    1093              : 
    1094              :    gfc_linebuf holds a single line of source code and information
    1095              :    which file it resides in
    1096              : 
    1097              :    locus point to the sourceline and the character in the source
    1098              :    line.
    1099              : */
    1100              : 
    1101              : typedef struct gfc_file
    1102              : {
    1103              :   struct gfc_file *next, *up;
    1104              :   int inclusion_line, line;
    1105              :   char *filename;
    1106              : } gfc_file;
    1107              : 
    1108              : typedef struct gfc_linebuf
    1109              : {
    1110              :   location_t location;
    1111              :   struct gfc_file *file;
    1112              :   struct gfc_linebuf *next;
    1113              : 
    1114              :   int truncated;
    1115              :   bool dbg_emitted;
    1116              : 
    1117              :   gfc_char_t line[1];
    1118              : } gfc_linebuf;
    1119              : 
    1120              : #define gfc_linebuf_header_size (offsetof (gfc_linebuf, line))
    1121              : 
    1122              : #define gfc_linebuf_linenum(LBUF) (LOCATION_LINE ((LBUF)->location))
    1123              : 
    1124              : /* If nextc = (gfc_char_t*) -1, 'location' is used.  */
    1125              : typedef struct
    1126              : {
    1127              :   gfc_char_t *nextc;
    1128              :   union
    1129              :     {
    1130              :       gfc_linebuf *lb;
    1131              :       location_t location;
    1132              :     } u;
    1133              : } locus;
    1134              : 
    1135              : #define GFC_LOCUS_IS_SET(loc) \
    1136              :   ((loc).nextc == (gfc_char_t *) -1 || (loc).u.lb != NULL)
    1137              : 
    1138              : /* In order for the "gfc" format checking to work correctly, you must
    1139              :    have declared a typedef locus first.  */
    1140              : #if GCC_VERSION >= 4001
    1141              : #define ATTRIBUTE_GCC_GFC(m, n) __attribute__ ((__format__ (__gcc_gfc__, m, n))) ATTRIBUTE_NONNULL(m)
    1142              : #else
    1143              : #define ATTRIBUTE_GCC_GFC(m, n) ATTRIBUTE_NONNULL(m)
    1144              : #endif
    1145              : 
    1146              : 
    1147              : /* Suppress error messages or re-enable them.  */
    1148              : 
    1149              : void gfc_push_suppress_errors (void);
    1150              : void gfc_pop_suppress_errors (void);
    1151              : bool gfc_query_suppress_errors (void);
    1152              : 
    1153              : 
    1154              : /* Character length structures hold the expression that gives the
    1155              :    length of a character variable.  We avoid putting these into
    1156              :    gfc_typespec because doing so prevents us from doing structure
    1157              :    copies and forces us to deallocate any typespecs we create, as well
    1158              :    as structures that contain typespecs.  They also can have multiple
    1159              :    character typespecs pointing to them.
    1160              : 
    1161              :    These structures form a singly linked list within the current
    1162              :    namespace and are deallocated with the namespace.  It is possible to
    1163              :    end up with gfc_charlen structures that have nothing pointing to them.  */
    1164              : 
    1165              : typedef struct gfc_charlen
    1166              : {
    1167              :   struct gfc_expr *length;
    1168              :   struct gfc_charlen *next;
    1169              :   bool length_from_typespec; /* Length from explicit array ctor typespec?  */
    1170              :   tree backend_decl;
    1171              :   tree passed_length; /* Length argument explicitly passed.  */
    1172              : 
    1173              :   int resolved;
    1174              : }
    1175              : gfc_charlen;
    1176              : 
    1177              : #define gfc_get_charlen() XCNEW (gfc_charlen)
    1178              : 
    1179              : /* Type specification structure.  */
    1180              : typedef struct
    1181              : {
    1182              :   bt type;
    1183              :   int kind;
    1184              : 
    1185              :   union
    1186              :   {
    1187              :     struct gfc_symbol *derived; /* For derived types only.  */
    1188              :     gfc_charlen *cl;            /* For character types only.  */
    1189              :     int pad;                    /* For hollerith types only.  */
    1190              :   }
    1191              :   u;
    1192              : 
    1193              :   struct gfc_symbol *interface; /* For PROCEDURE declarations.  */
    1194              :   int is_c_interop;
    1195              :   int is_iso_c;
    1196              :   bt f90_type;
    1197              :   bool deferred;
    1198              :   gfc_symbol *interop_kind;
    1199              : }
    1200              : gfc_typespec;
    1201              : 
    1202              : /* Array specification.  */
    1203              : typedef struct
    1204              : {
    1205              :   int rank;     /* A scalar has a rank of 0, an assumed-rank array has -1.  */
    1206              :   int corank;
    1207              :   array_type type, cotype;
    1208              :   struct gfc_expr *lower[GFC_MAX_DIMENSIONS], *upper[GFC_MAX_DIMENSIONS];
    1209              : 
    1210              :   /* These two fields are used with the Cray Pointer extension.  */
    1211              :   bool cray_pointee; /* True iff this spec belongs to a cray pointee.  */
    1212              :   bool cp_was_assumed; /* AS_ASSUMED_SIZE cp arrays are converted to
    1213              :                         AS_EXPLICIT, but we want to remember that we
    1214              :                         did this.  */
    1215              : 
    1216              :   bool resolved;
    1217              : }
    1218              : gfc_array_spec;
    1219              : 
    1220              : #define gfc_get_array_spec() XCNEW (gfc_array_spec)
    1221              : 
    1222              : 
    1223              : /* Components of derived types.  */
    1224              : typedef struct gfc_component
    1225              : {
    1226              :   const char *name;
    1227              :   gfc_typespec ts;
    1228              : 
    1229              :   symbol_attribute attr;
    1230              :   gfc_array_spec *as;
    1231              : 
    1232              :   tree backend_decl;
    1233              :   /* Used to cache a FIELD_DECL matching this same component
    1234              :      but applied to a different backend containing type that was
    1235              :      generated by gfc_nonrestricted_type.  */
    1236              :   tree norestrict_decl;
    1237              :   locus loc;
    1238              :   struct gfc_expr *initializer;
    1239              :   /* Used in parameterized derived type declarations to store parameterized
    1240              :      kind expressions.  */
    1241              :   struct gfc_expr *kind_expr;
    1242              :   struct gfc_actual_arglist *param_list;
    1243              : 
    1244              :   struct gfc_component *next;
    1245              : 
    1246              :   /* Needed for procedure pointer components.  */
    1247              :   struct gfc_typebound_proc *tb;
    1248              :   /* When allocatable/pointer and in a coarray the associated token.  */
    1249              :   struct gfc_component *caf_token;
    1250              : }
    1251              : gfc_component;
    1252              : 
    1253              : #define gfc_get_component() XCNEW (gfc_component)
    1254              : #define gfc_comp_caf_token(cm) (cm)->caf_token->backend_decl
    1255              : 
    1256              : /* Formal argument lists are lists of symbols.  */
    1257              : typedef struct gfc_formal_arglist
    1258              : {
    1259              :   /* Symbol representing the argument at this position in the arglist.  */
    1260              :   struct gfc_symbol *sym;
    1261              :   /* Points to the next formal argument.  */
    1262              :   struct gfc_formal_arglist *next;
    1263              : }
    1264              : gfc_formal_arglist;
    1265              : 
    1266              : #define gfc_get_formal_arglist() XCNEW (gfc_formal_arglist)
    1267              : 
    1268              : 
    1269              : struct gfc_dummy_arg;
    1270              : 
    1271              : 
    1272              : /* The gfc_actual_arglist structure is for actual arguments and
    1273              :    for type parameter specification lists.  */
    1274              : typedef struct gfc_actual_arglist
    1275              : {
    1276              :   const char *name;
    1277              :   /* Alternate return label when the expr member is null.  */
    1278              :   struct gfc_st_label *label;
    1279              : 
    1280              :   gfc_param_spec_type spec_type;
    1281              : 
    1282              :   struct gfc_expr *expr;
    1283              : 
    1284              :   /*  The dummy arg this actual arg is associated with, if the interface
    1285              :       is explicit.  NULL otherwise.  */
    1286              :   gfc_dummy_arg *associated_dummy;
    1287              : 
    1288              :   struct gfc_actual_arglist *next;
    1289              : }
    1290              : gfc_actual_arglist;
    1291              : 
    1292              : #define gfc_get_actual_arglist() XCNEW (gfc_actual_arglist)
    1293              : 
    1294              : 
    1295              : /* Because a symbol can belong to multiple namelists, they must be
    1296              :    linked externally to the symbol itself.  */
    1297              : typedef struct gfc_namelist
    1298              : {
    1299              :   struct gfc_symbol *sym;
    1300              :   struct gfc_namelist *next;
    1301              : }
    1302              : gfc_namelist;
    1303              : 
    1304              : #define gfc_get_namelist() XCNEW (gfc_namelist)
    1305              : 
    1306              : /* Likewise to gfc_namelist, but contains expressions.  */
    1307              : typedef struct gfc_expr_list
    1308              : {
    1309              :   struct gfc_expr *expr;
    1310              :   struct gfc_expr_list *next;
    1311              : }
    1312              : gfc_expr_list;
    1313              : 
    1314              : #define gfc_get_expr_list() XCNEW (gfc_expr_list)
    1315              : 
    1316              : enum gfc_omp_reduction_op
    1317              : {
    1318              :   OMP_REDUCTION_NONE = -1,
    1319              :   OMP_REDUCTION_PLUS = INTRINSIC_PLUS,
    1320              :   OMP_REDUCTION_MINUS = INTRINSIC_MINUS,
    1321              :   OMP_REDUCTION_TIMES = INTRINSIC_TIMES,
    1322              :   OMP_REDUCTION_AND = INTRINSIC_AND,
    1323              :   OMP_REDUCTION_OR = INTRINSIC_OR,
    1324              :   OMP_REDUCTION_EQV = INTRINSIC_EQV,
    1325              :   OMP_REDUCTION_NEQV = INTRINSIC_NEQV,
    1326              :   OMP_REDUCTION_MAX = GFC_INTRINSIC_END,
    1327              :   OMP_REDUCTION_MIN,
    1328              :   OMP_REDUCTION_IAND,
    1329              :   OMP_REDUCTION_IOR,
    1330              :   OMP_REDUCTION_IEOR,
    1331              :   OMP_REDUCTION_USER
    1332              : };
    1333              : 
    1334              : enum gfc_omp_depend_doacross_op
    1335              : {
    1336              :   OMP_DEPEND_UNSET,
    1337              :   OMP_DEPEND_IN,
    1338              :   OMP_DEPEND_OUT,
    1339              :   OMP_DEPEND_INOUT,
    1340              :   OMP_DEPEND_INOUTSET,
    1341              :   OMP_DEPEND_MUTEXINOUTSET,
    1342              :   OMP_DEPEND_DEPOBJ,
    1343              :   OMP_DEPEND_SINK_FIRST,
    1344              :   OMP_DOACROSS_SINK_FIRST,
    1345              :   OMP_DOACROSS_SINK
    1346              : };
    1347              : 
    1348              : enum gfc_omp_map_op
    1349              : {
    1350              :   OMP_MAP_ALLOC,
    1351              :   OMP_MAP_IF_PRESENT,
    1352              :   OMP_MAP_ATTACH,
    1353              :   OMP_MAP_TO,
    1354              :   OMP_MAP_FROM,
    1355              :   OMP_MAP_TOFROM,
    1356              :   OMP_MAP_DELETE,
    1357              :   OMP_MAP_DETACH,
    1358              :   OMP_MAP_FORCE_ALLOC,
    1359              :   OMP_MAP_FORCE_TO,
    1360              :   OMP_MAP_FORCE_FROM,
    1361              :   OMP_MAP_FORCE_TOFROM,
    1362              :   OMP_MAP_FORCE_PRESENT,
    1363              :   OMP_MAP_FORCE_DEVICEPTR,
    1364              :   OMP_MAP_DEVICE_RESIDENT,
    1365              :   OMP_MAP_LINK,
    1366              :   OMP_MAP_RELEASE,
    1367              :   OMP_MAP_ALWAYS_TO,
    1368              :   OMP_MAP_ALWAYS_FROM,
    1369              :   OMP_MAP_ALWAYS_TOFROM,
    1370              :   OMP_MAP_PRESENT_ALLOC,
    1371              :   OMP_MAP_PRESENT_TO,
    1372              :   OMP_MAP_PRESENT_FROM,
    1373              :   OMP_MAP_PRESENT_TOFROM,
    1374              :   OMP_MAP_ALWAYS_PRESENT_TO,
    1375              :   OMP_MAP_ALWAYS_PRESENT_FROM,
    1376              :   OMP_MAP_ALWAYS_PRESENT_TOFROM
    1377              : };
    1378              : 
    1379              : enum gfc_omp_defaultmap
    1380              : {
    1381              :   OMP_DEFAULTMAP_UNSET,
    1382              :   OMP_DEFAULTMAP_ALLOC,
    1383              :   OMP_DEFAULTMAP_TO,
    1384              :   OMP_DEFAULTMAP_FROM,
    1385              :   OMP_DEFAULTMAP_TOFROM,
    1386              :   OMP_DEFAULTMAP_FIRSTPRIVATE,
    1387              :   OMP_DEFAULTMAP_NONE,
    1388              :   OMP_DEFAULTMAP_DEFAULT,
    1389              :   OMP_DEFAULTMAP_PRESENT
    1390              : };
    1391              : 
    1392              : enum gfc_omp_defaultmap_category
    1393              : {
    1394              :   OMP_DEFAULTMAP_CAT_UNCATEGORIZED,
    1395              :   OMP_DEFAULTMAP_CAT_ALL,
    1396              :   OMP_DEFAULTMAP_CAT_SCALAR,
    1397              :   OMP_DEFAULTMAP_CAT_AGGREGATE,
    1398              :   OMP_DEFAULTMAP_CAT_ALLOCATABLE,
    1399              :   OMP_DEFAULTMAP_CAT_POINTER,
    1400              :   OMP_DEFAULTMAP_CAT_NUM
    1401              : };
    1402              : 
    1403              : enum gfc_omp_linear_op
    1404              : {
    1405              :   OMP_LINEAR_DEFAULT,
    1406              :   OMP_LINEAR_REF,
    1407              :   OMP_LINEAR_VAL,
    1408              :   OMP_LINEAR_UVAL
    1409              : };
    1410              : 
    1411              : /* For use in OpenMP clauses in case we need extra information
    1412              :    (aligned clause alignment, linear clause step, etc.).  */
    1413              : 
    1414              : typedef struct gfc_omp_namelist
    1415              : {
    1416              :   struct gfc_symbol *sym;
    1417              :   struct gfc_expr *expr;
    1418              :   union
    1419              :     {
    1420              :       gfc_omp_reduction_op reduction_op;
    1421              :       gfc_omp_depend_doacross_op depend_doacross_op;
    1422              :       struct
    1423              :         {
    1424              :           ENUM_BITFIELD (gfc_omp_map_op) op:8;
    1425              :           bool readonly;
    1426              :         } map;
    1427              :       gfc_expr *align;
    1428              :       struct
    1429              :         {
    1430              :           ENUM_BITFIELD (gfc_omp_linear_op) op:4;
    1431              :           bool old_modifier;
    1432              :         } linear;
    1433              :       struct gfc_common_head *common;
    1434              :       struct gfc_symbol *memspace_sym;
    1435              :       bool lastprivate_conditional;
    1436              :       bool present_modifier;
    1437              :       struct
    1438              :         {
    1439              :           int len;
    1440              :           bool target;
    1441              :           bool targetsync;
    1442              :         } init;
    1443              :       struct
    1444              :         {
    1445              :           bool need_ptr:1;
    1446              :           bool need_addr:1;
    1447              :           bool range_start:1;
    1448              :           bool omp_num_args_plus:1;
    1449              :           bool omp_num_args_minus:1;
    1450              :           bool error_p:1;
    1451              :         } adj_args;
    1452              :     } u;
    1453              :   union
    1454              :     {
    1455              :       struct gfc_omp_namelist_udr *udr;
    1456              :       gfc_namespace *ns;
    1457              :       gfc_expr *allocator;
    1458              :       struct gfc_symbol *traits_sym;
    1459              :       struct gfc_omp_namelist *duplicate_of;
    1460              :       char *init_interop;
    1461              :     } u2;
    1462              :   struct gfc_omp_namelist *next;
    1463              :   locus where;
    1464              : }
    1465              : gfc_omp_namelist;
    1466              : 
    1467              : #define gfc_get_omp_namelist() XCNEW (gfc_omp_namelist)
    1468              : 
    1469              : enum
    1470              : {
    1471              :   OMP_LIST_FIRST,
    1472              :   OMP_LIST_PRIVATE = OMP_LIST_FIRST,
    1473              :   OMP_LIST_FIRSTPRIVATE,
    1474              :   OMP_LIST_LASTPRIVATE,
    1475              :   OMP_LIST_COPYPRIVATE,
    1476              :   OMP_LIST_SHARED,
    1477              :   OMP_LIST_COPYIN,
    1478              :   OMP_LIST_UNIFORM,
    1479              :   OMP_LIST_AFFINITY,
    1480              :   OMP_LIST_ALIGNED,
    1481              :   OMP_LIST_LINEAR,
    1482              :   OMP_LIST_DEPEND,
    1483              :   OMP_LIST_MAP,
    1484              :   OMP_LIST_TO,
    1485              :   OMP_LIST_FROM,
    1486              :   OMP_LIST_SCAN_IN,
    1487              :   OMP_LIST_SCAN_EX,
    1488              :   OMP_LIST_REDUCTION,
    1489              :   OMP_LIST_REDUCTION_INSCAN,
    1490              :   OMP_LIST_REDUCTION_TASK,
    1491              :   OMP_LIST_IN_REDUCTION,
    1492              :   OMP_LIST_TASK_REDUCTION,
    1493              :   OMP_LIST_DEVICE_RESIDENT,
    1494              :   OMP_LIST_LINK,
    1495              :   OMP_LIST_LOCAL,
    1496              :   OMP_LIST_USE_DEVICE,
    1497              :   OMP_LIST_CACHE,
    1498              :   OMP_LIST_IS_DEVICE_PTR,
    1499              :   OMP_LIST_USE_DEVICE_PTR,
    1500              :   OMP_LIST_USE_DEVICE_ADDR,
    1501              :   OMP_LIST_NONTEMPORAL,
    1502              :   OMP_LIST_ALLOCATE,
    1503              :   OMP_LIST_HAS_DEVICE_ADDR,
    1504              :   OMP_LIST_ENTER,
    1505              :   OMP_LIST_USES_ALLOCATORS,
    1506              :   OMP_LIST_INIT,
    1507              :   OMP_LIST_USE,
    1508              :   OMP_LIST_DESTROY,
    1509              :   OMP_LIST_INTEROP,
    1510              :   OMP_LIST_ADJUST_ARGS,
    1511              :   OMP_LIST_NUM /* Must be the last.  */
    1512              : };
    1513              : 
    1514              : /* Because a symbol can belong to multiple namelists, they must be
    1515              :    linked externally to the symbol itself.  */
    1516              : 
    1517              : enum gfc_omp_sched_kind
    1518              : {
    1519              :   OMP_SCHED_NONE,
    1520              :   OMP_SCHED_STATIC,
    1521              :   OMP_SCHED_DYNAMIC,
    1522              :   OMP_SCHED_GUIDED,
    1523              :   OMP_SCHED_RUNTIME,
    1524              :   OMP_SCHED_AUTO
    1525              : };
    1526              : 
    1527              : enum gfc_omp_default_sharing
    1528              : {
    1529              :   OMP_DEFAULT_UNKNOWN,
    1530              :   OMP_DEFAULT_NONE,
    1531              :   OMP_DEFAULT_PRIVATE,
    1532              :   OMP_DEFAULT_SHARED,
    1533              :   OMP_DEFAULT_FIRSTPRIVATE,
    1534              :   OMP_DEFAULT_PRESENT
    1535              : };
    1536              : 
    1537              : enum gfc_omp_proc_bind_kind
    1538              : {
    1539              :   OMP_PROC_BIND_UNKNOWN,
    1540              :   OMP_PROC_BIND_PRIMARY,
    1541              :   OMP_PROC_BIND_MASTER,
    1542              :   OMP_PROC_BIND_SPREAD,
    1543              :   OMP_PROC_BIND_CLOSE
    1544              : };
    1545              : 
    1546              : enum gfc_omp_cancel_kind
    1547              : {
    1548              :   OMP_CANCEL_UNKNOWN,
    1549              :   OMP_CANCEL_PARALLEL,
    1550              :   OMP_CANCEL_SECTIONS,
    1551              :   OMP_CANCEL_DO,
    1552              :   OMP_CANCEL_TASKGROUP
    1553              : };
    1554              : 
    1555              : enum gfc_omp_if_kind
    1556              : {
    1557              :   OMP_IF_CANCEL,
    1558              :   OMP_IF_PARALLEL,
    1559              :   OMP_IF_SIMD,
    1560              :   OMP_IF_TASK,
    1561              :   OMP_IF_TASKLOOP,
    1562              :   OMP_IF_TARGET,
    1563              :   OMP_IF_TARGET_DATA,
    1564              :   OMP_IF_TARGET_UPDATE,
    1565              :   OMP_IF_TARGET_ENTER_DATA,
    1566              :   OMP_IF_TARGET_EXIT_DATA,
    1567              :   OMP_IF_LAST
    1568              : };
    1569              : 
    1570              : enum gfc_omp_atomic_op
    1571              : {
    1572              :   GFC_OMP_ATOMIC_UNSET = 0,
    1573              :   GFC_OMP_ATOMIC_UPDATE = 1,
    1574              :   GFC_OMP_ATOMIC_READ = 2,
    1575              :   GFC_OMP_ATOMIC_WRITE = 3,
    1576              :   GFC_OMP_ATOMIC_MASK = 3,
    1577              :   GFC_OMP_ATOMIC_SWAP = 16
    1578              : };
    1579              : 
    1580              : enum gfc_omp_requires_kind
    1581              : {
    1582              :   /* Keep gfc_namespace's omp_requires bitfield size in sync.  */
    1583              :   OMP_REQ_ATOMIC_MEM_ORDER_SEQ_CST = 1,  /* 001 */
    1584              :   OMP_REQ_ATOMIC_MEM_ORDER_ACQ_REL = 2,  /* 010 */
    1585              :   OMP_REQ_ATOMIC_MEM_ORDER_RELAXED = 3,  /* 011 */
    1586              :   OMP_REQ_ATOMIC_MEM_ORDER_ACQUIRE = 4,  /* 100 */
    1587              :   OMP_REQ_ATOMIC_MEM_ORDER_RELEASE = 5,  /* 101 */
    1588              :   OMP_REQ_REVERSE_OFFLOAD = (1 << 3),
    1589              :   OMP_REQ_UNIFIED_ADDRESS = (1 << 4),
    1590              :   OMP_REQ_UNIFIED_SHARED_MEMORY = (1 << 5),
    1591              :   OMP_REQ_SELF_MAPS = (1 << 6),
    1592              :   OMP_REQ_DYNAMIC_ALLOCATORS = (1 << 7),
    1593              :   OMP_REQ_TARGET_MASK = (OMP_REQ_REVERSE_OFFLOAD
    1594              :                          | OMP_REQ_UNIFIED_ADDRESS
    1595              :                          | OMP_REQ_UNIFIED_SHARED_MEMORY
    1596              :                          | OMP_REQ_SELF_MAPS),
    1597              :   OMP_REQ_ATOMIC_MEM_ORDER_MASK = (OMP_REQ_ATOMIC_MEM_ORDER_SEQ_CST
    1598              :                                    | OMP_REQ_ATOMIC_MEM_ORDER_ACQ_REL
    1599              :                                    | OMP_REQ_ATOMIC_MEM_ORDER_RELAXED
    1600              :                                    | OMP_REQ_ATOMIC_MEM_ORDER_ACQUIRE
    1601              :                                    | OMP_REQ_ATOMIC_MEM_ORDER_RELEASE)
    1602              : };
    1603              : 
    1604              : enum gfc_omp_memorder
    1605              : {
    1606              :   OMP_MEMORDER_UNSET,
    1607              :   OMP_MEMORDER_SEQ_CST,
    1608              :   OMP_MEMORDER_ACQ_REL,
    1609              :   OMP_MEMORDER_RELEASE,
    1610              :   OMP_MEMORDER_ACQUIRE,
    1611              :   OMP_MEMORDER_RELAXED
    1612              : };
    1613              : 
    1614              : enum gfc_omp_bind_type
    1615              : {
    1616              :   OMP_BIND_UNSET,
    1617              :   OMP_BIND_TEAMS,
    1618              :   OMP_BIND_PARALLEL,
    1619              :   OMP_BIND_THREAD
    1620              : };
    1621              : 
    1622              : enum gfc_omp_fallback
    1623              : {
    1624              :   OMP_FALLBACK_NONE,
    1625              :   OMP_FALLBACK_ABORT,
    1626              :   OMP_FALLBACK_DEFAULT_MEM,
    1627              :   OMP_FALLBACK_NULL
    1628              : };
    1629              : 
    1630              : typedef struct gfc_omp_assumptions
    1631              : {
    1632              :   int n_absent, n_contains;
    1633              :   enum gfc_statement *absent, *contains;
    1634              :   gfc_expr_list *holds;
    1635              :   bool no_openmp:1, no_openmp_routines:1, no_openmp_constructs:1;
    1636              :   bool no_parallelism:1;
    1637              : }
    1638              : gfc_omp_assumptions;
    1639              : 
    1640              : #define gfc_get_omp_assumptions() XCNEW (gfc_omp_assumptions)
    1641              : 
    1642              : 
    1643              : typedef struct gfc_omp_clauses
    1644              : {
    1645              :   gfc_omp_namelist *lists[OMP_LIST_NUM];
    1646              :   struct gfc_expr *if_expr;
    1647              :   struct gfc_expr *if_exprs[OMP_IF_LAST];
    1648              :   struct gfc_expr *self_expr;
    1649              :   struct gfc_expr *final_expr;
    1650              :   struct gfc_expr *num_threads;
    1651              :   struct gfc_expr *chunk_size;
    1652              :   struct gfc_expr *safelen_expr;
    1653              :   struct gfc_expr *simdlen_expr;
    1654              :   struct gfc_expr *num_teams_lower;
    1655              :   struct gfc_expr *num_teams_upper;
    1656              :   struct gfc_expr *device;
    1657              :   struct gfc_expr *thread_limit;
    1658              :   struct gfc_expr *grainsize;
    1659              :   struct gfc_expr *filter;
    1660              :   struct gfc_expr *hint;
    1661              :   struct gfc_expr *num_tasks;
    1662              :   struct gfc_expr *priority;
    1663              :   struct gfc_expr *detach;
    1664              :   struct gfc_expr *depobj;
    1665              :   struct gfc_expr *dist_chunk_size;
    1666              :   struct gfc_expr *dyn_groupprivate;
    1667              :   struct gfc_expr *message;
    1668              :   struct gfc_expr *novariants;
    1669              :   struct gfc_expr *nocontext;
    1670              :   struct gfc_omp_assumptions *assume;
    1671              :   struct gfc_expr_list *sizes_list;
    1672              :   const char *critical_name;
    1673              :   enum gfc_omp_default_sharing default_sharing;
    1674              :   enum gfc_omp_atomic_op atomic_op;
    1675              :   enum gfc_omp_defaultmap defaultmap[OMP_DEFAULTMAP_CAT_NUM];
    1676              :   int collapse, orderedc;
    1677              :   int partial;
    1678              :   unsigned nowait:1, ordered:1, untied:1, mergeable:1, ancestor:1;
    1679              :   unsigned inbranch:1, notinbranch:1, nogroup:1;
    1680              :   unsigned sched_simd:1, sched_monotonic:1, sched_nonmonotonic:1;
    1681              :   unsigned simd:1, threads:1, doacross_source:1, depend_source:1, destroy:1;
    1682              :   unsigned order_unconstrained:1, order_reproducible:1, capture:1;
    1683              :   unsigned grainsize_strict:1, num_tasks_strict:1, compare:1, weak:1;
    1684              :   unsigned non_rectangular:1, order_concurrent:1;
    1685              :   unsigned contains_teams_construct:1, target_first_st_is_teams_or_meta:1;
    1686              :   unsigned contained_in_target_construct:1, indirect:1;
    1687              :   unsigned full:1, erroneous:1;
    1688              :   ENUM_BITFIELD (gfc_omp_sched_kind) sched_kind:3;
    1689              :   ENUM_BITFIELD (gfc_omp_device_type) device_type:2;
    1690              :   ENUM_BITFIELD (gfc_omp_memorder) memorder:3;
    1691              :   ENUM_BITFIELD (gfc_omp_memorder) fail:3;
    1692              :   ENUM_BITFIELD (gfc_omp_cancel_kind) cancel:3;
    1693              :   ENUM_BITFIELD (gfc_omp_proc_bind_kind) proc_bind:3;
    1694              :   ENUM_BITFIELD (gfc_omp_depend_doacross_op) depobj_update:4;
    1695              :   ENUM_BITFIELD (gfc_omp_bind_type) bind:2;
    1696              :   ENUM_BITFIELD (gfc_omp_at_type) at:2;
    1697              :   ENUM_BITFIELD (gfc_omp_severity_type) severity:2;
    1698              :   ENUM_BITFIELD (gfc_omp_sched_kind) dist_sched_kind:3;
    1699              :   ENUM_BITFIELD (gfc_omp_fallback) fallback:2;
    1700              : 
    1701              :   /* OpenACC. */
    1702              :   struct gfc_expr *async_expr;
    1703              :   struct gfc_expr *gang_static_expr;
    1704              :   struct gfc_expr *gang_num_expr;
    1705              :   struct gfc_expr *worker_expr;
    1706              :   struct gfc_expr *vector_expr;
    1707              :   struct gfc_expr *num_gangs_expr;
    1708              :   struct gfc_expr *num_workers_expr;
    1709              :   struct gfc_expr *vector_length_expr;
    1710              :   gfc_expr_list *wait_list;
    1711              :   gfc_expr_list *tile_list;
    1712              :   unsigned async:1, gang:1, worker:1, vector:1, seq:1, independent:1;
    1713              :   unsigned par_auto:1, gang_static:1;
    1714              :   unsigned if_present:1, finalize:1;
    1715              :   unsigned nohost:1;
    1716              :   locus loc;
    1717              : }
    1718              : gfc_omp_clauses;
    1719              : 
    1720              : #define gfc_get_omp_clauses() XCNEW (gfc_omp_clauses)
    1721              : 
    1722              : 
    1723              : /* Node in the linked list used for storing !$oacc declare constructs.  */
    1724              : 
    1725              : typedef struct gfc_oacc_declare
    1726              : {
    1727              :   struct gfc_oacc_declare *next;
    1728              :   bool module_var;
    1729              :   gfc_omp_clauses *clauses;
    1730              :   locus loc;
    1731              : }
    1732              : gfc_oacc_declare;
    1733              : 
    1734              : #define gfc_get_oacc_declare() XCNEW (gfc_oacc_declare)
    1735              : 
    1736              : 
    1737              : /* Node in the linked list used for storing !$omp declare simd constructs.  */
    1738              : 
    1739              : typedef struct gfc_omp_declare_simd
    1740              : {
    1741              :   struct gfc_omp_declare_simd *next;
    1742              :   locus where; /* Where the !$omp declare simd construct occurred.  */
    1743              : 
    1744              :   gfc_symbol *proc_name;
    1745              : 
    1746              :   gfc_omp_clauses *clauses;
    1747              : }
    1748              : gfc_omp_declare_simd;
    1749              : #define gfc_get_omp_declare_simd() XCNEW (gfc_omp_declare_simd)
    1750              : 
    1751              : /* For OpenMP trait selector enum types and tables.  */
    1752              : #include "omp-selectors.h"
    1753              : 
    1754              : typedef struct gfc_omp_trait_property
    1755              : {
    1756              :   struct gfc_omp_trait_property *next;
    1757              :   enum omp_tp_type property_kind;
    1758              :   bool is_name : 1;
    1759              : 
    1760              :   union
    1761              :     {
    1762              :       gfc_expr *expr;
    1763              :       gfc_symbol *sym;
    1764              :       gfc_omp_clauses *clauses;
    1765              :       char *name;
    1766              :     };
    1767              : } gfc_omp_trait_property;
    1768              : #define gfc_get_omp_trait_property() XCNEW (gfc_omp_trait_property)
    1769              : 
    1770              : typedef struct gfc_omp_selector
    1771              : {
    1772              :   struct gfc_omp_selector *next;
    1773              :   enum omp_ts_code code;
    1774              :   gfc_expr *score;
    1775              :   struct gfc_omp_trait_property *properties;
    1776              : } gfc_omp_selector;
    1777              : #define gfc_get_omp_selector() XCNEW (gfc_omp_selector)
    1778              : 
    1779              : typedef struct gfc_omp_set_selector
    1780              : {
    1781              :   struct gfc_omp_set_selector *next;
    1782              :   enum omp_tss_code code;
    1783              :   struct gfc_omp_selector *trait_selectors;
    1784              : } gfc_omp_set_selector;
    1785              : #define gfc_get_omp_set_selector() XCNEW (gfc_omp_set_selector)
    1786              : 
    1787              : 
    1788              : /* Node in the linked list used for storing !$omp declare variant
    1789              :    constructs.  */
    1790              : 
    1791              : typedef struct gfc_omp_declare_variant
    1792              : {
    1793              :   struct gfc_omp_declare_variant *next;
    1794              :   locus where; /* Where the !$omp declare variant construct occurred.  */
    1795              : 
    1796              :   struct gfc_symtree *base_proc_symtree;
    1797              :   struct gfc_symtree *variant_proc_symtree;
    1798              : 
    1799              :   gfc_omp_set_selector *set_selectors;
    1800              :   gfc_omp_namelist *adjust_args_list;
    1801              :   gfc_omp_namelist *append_args_list;
    1802              : 
    1803              :   bool checked_p : 1; /* Set if previously checked for errors.  */
    1804              :   bool error_p : 1; /* Set if error found in directive.  */
    1805              : }
    1806              : gfc_omp_declare_variant;
    1807              : #define gfc_get_omp_declare_variant() XCNEW (gfc_omp_declare_variant)
    1808              : 
    1809              : typedef struct gfc_omp_variant
    1810              : {
    1811              :   struct gfc_omp_variant *next;
    1812              :   locus where; /* Where the metadirective clause occurred.  */
    1813              : 
    1814              :   gfc_omp_set_selector *selectors;
    1815              :   enum gfc_statement stmt;
    1816              :   struct gfc_code *code;
    1817              : 
    1818              : } gfc_omp_variant;
    1819              : #define gfc_get_omp_variant() XCNEW (gfc_omp_variant)
    1820              : 
    1821              : typedef struct gfc_omp_udr
    1822              : {
    1823              :   struct gfc_omp_udr *next;
    1824              :   locus where; /* Where the !$omp declare reduction construct occurred.  */
    1825              : 
    1826              :   const char *name;
    1827              :   gfc_typespec ts;
    1828              :   gfc_omp_reduction_op rop;
    1829              : 
    1830              :   struct gfc_symbol *omp_out;
    1831              :   struct gfc_symbol *omp_in;
    1832              :   struct gfc_namespace *combiner_ns;
    1833              : 
    1834              :   struct gfc_symbol *omp_priv;
    1835              :   struct gfc_symbol *omp_orig;
    1836              :   struct gfc_namespace *initializer_ns;
    1837              : }
    1838              : gfc_omp_udr;
    1839              : #define gfc_get_omp_udr() XCNEW (gfc_omp_udr)
    1840              : 
    1841              : typedef struct gfc_omp_namelist_udr
    1842              : {
    1843              :   struct gfc_omp_udr *udr;
    1844              :   struct gfc_code *combiner;
    1845              :   struct gfc_code *initializer;
    1846              : }
    1847              : gfc_omp_namelist_udr;
    1848              : #define gfc_get_omp_namelist_udr() XCNEW (gfc_omp_namelist_udr)
    1849              : 
    1850              : /* The gfc_st_label structure is a BBT attached to a namespace that
    1851              :    records the usage of statement labels within that space.  */
    1852              : 
    1853              : typedef struct gfc_st_label
    1854              : {
    1855              :   BBT_HEADER(gfc_st_label);
    1856              : 
    1857              :   int value;
    1858              : 
    1859              :   gfc_sl_type defined, referenced;
    1860              : 
    1861              :   struct gfc_expr *format;
    1862              : 
    1863              :   tree backend_decl;
    1864              : 
    1865              :   locus where;
    1866              : 
    1867              :   gfc_namespace *ns;
    1868              :   int omp_region;
    1869              : }
    1870              : gfc_st_label;
    1871              : 
    1872              : 
    1873              : /* gfc_interface()-- Interfaces are lists of symbols strung together.  */
    1874              : typedef struct gfc_interface
    1875              : {
    1876              :   struct gfc_symbol *sym;
    1877              :   locus where;
    1878              :   struct gfc_interface *next;
    1879              : }
    1880              : gfc_interface;
    1881              : 
    1882              : #define gfc_get_interface() XCNEW (gfc_interface)
    1883              : 
    1884              : /* User operator nodes.  These are like stripped down symbols.  */
    1885              : typedef struct
    1886              : {
    1887              :   const char *name;
    1888              : 
    1889              :   gfc_interface *op;
    1890              :   struct gfc_namespace *ns;
    1891              :   gfc_access access;
    1892              : }
    1893              : gfc_user_op;
    1894              : 
    1895              : 
    1896              : /* A list of specific bindings that are associated with a generic spec.  */
    1897              : typedef struct gfc_tbp_generic
    1898              : {
    1899              :   /* The parser sets specific_st, upon resolution we look for the corresponding
    1900              :      gfc_typebound_proc and set specific for further use.  */
    1901              :   struct gfc_symtree* specific_st;
    1902              :   struct gfc_typebound_proc* specific;
    1903              : 
    1904              :   struct gfc_tbp_generic* next;
    1905              :   bool is_operator;
    1906              : }
    1907              : gfc_tbp_generic;
    1908              : 
    1909              : #define gfc_get_tbp_generic() XCNEW (gfc_tbp_generic)
    1910              : 
    1911              : 
    1912              : /* Data needed for type-bound procedures.  */
    1913              : typedef struct gfc_typebound_proc
    1914              : {
    1915              :   locus where; /* Where the PROCEDURE/GENERIC definition was.  */
    1916              : 
    1917              :   union
    1918              :   {
    1919              :     struct gfc_symtree* specific; /* The interface if DEFERRED.  */
    1920              :     gfc_tbp_generic* generic;
    1921              :   }
    1922              :   u;
    1923              : 
    1924              :   gfc_access access;
    1925              :   const char* pass_arg; /* Argument-name for PASS.  NULL if not specified.  */
    1926              : 
    1927              :   /* The overridden type-bound proc (or GENERIC with this name in the
    1928              :      parent-type) or NULL if non.  */
    1929              :   struct gfc_typebound_proc* overridden;
    1930              : 
    1931              :   /* Once resolved, we use the position of pass_arg in the formal arglist of
    1932              :      the binding-target procedure to identify it.  The first argument has
    1933              :      number 1 here, the second 2, and so on.  */
    1934              :   unsigned pass_arg_num;
    1935              : 
    1936              :   unsigned nopass:1; /* Whether we have NOPASS (PASS otherwise).  */
    1937              :   unsigned non_overridable:1;
    1938              :   unsigned deferred:1;
    1939              :   unsigned is_generic:1;
    1940              :   unsigned function:1, subroutine:1;
    1941              :   unsigned error:1; /* Ignore it, when an error occurred during resolution.  */
    1942              :   unsigned ppc:1;
    1943              : }
    1944              : gfc_typebound_proc;
    1945              : 
    1946              : #define gfc_get_tbp() XCNEW (gfc_typebound_proc)
    1947              : 
    1948              : /* Symbol nodes.  These are important things.  They are what the
    1949              :    standard refers to as "entities".  The possibly multiple names that
    1950              :    refer to the same entity are accomplished by a binary tree of
    1951              :    symtree structures that is balanced by the red-black method-- more
    1952              :    than one symtree node can point to any given symbol.  */
    1953              : 
    1954              : typedef struct gfc_symbol
    1955              : {
    1956              :   const char *name;     /* Primary name, before renaming */
    1957              :   const char *module;   /* Module this symbol came from */
    1958              :   locus declared_at;
    1959              : 
    1960              :   gfc_typespec ts;
    1961              :   symbol_attribute attr;
    1962              : 
    1963              :   /* The formal member points to the formal argument list if the
    1964              :      symbol is a function or subroutine name.  If the symbol is a
    1965              :      generic name, the generic member points to the list of
    1966              :      interfaces.  */
    1967              : 
    1968              :   gfc_interface *generic;
    1969              :   gfc_access component_access;
    1970              : 
    1971              :   gfc_formal_arglist *formal;
    1972              :   struct gfc_namespace *formal_ns;
    1973              :   struct gfc_namespace *f2k_derived;
    1974              : 
    1975              :   /* List of PDT parameter expressions  */
    1976              :   struct gfc_actual_arglist *param_list;
    1977              :   struct gfc_symbol *template_sym;
    1978              : 
    1979              :   struct gfc_expr *value;       /* Parameter/Initializer value */
    1980              :   gfc_array_spec *as;
    1981              :   struct gfc_symbol *result;    /* function result symbol */
    1982              :   gfc_component *components;    /* Derived type components */
    1983              : 
    1984              :   /* Defined only for Cray pointees; points to their pointer.  */
    1985              :   struct gfc_symbol *cp_pointer;
    1986              : 
    1987              :   int entry_id;                 /* Used in resolve.cc for entries.  */
    1988              : 
    1989              :   /* CLASS hashed name for declared and dynamic types in the class.  */
    1990              :   int hash_value;
    1991              : 
    1992              :   struct gfc_symbol *common_next;       /* Links for COMMON syms */
    1993              : 
    1994              :   /* This is only used for pointer comparisons to check if symbols
    1995              :      are in the same common block.
    1996              :      In opposition to common_block, the common_head pointer takes into account
    1997              :      equivalences: if A is in a common block C and A and B are in equivalence,
    1998              :      then both A and B have common_head pointing to C, while A's common_block
    1999              :      points to C and B's is NULL.  */
    2000              :   struct gfc_common_head* common_head;
    2001              : 
    2002              :   /* Make sure initialization code is generated in the correct order.  */
    2003              :   int decl_order;
    2004              : 
    2005              :   gfc_namelist *namelist, *namelist_tail;
    2006              : 
    2007              :   /* The tlink field is used in the front end to carry the module
    2008              :      declaration of separate module procedures so that the characteristics
    2009              :      can be compared with the corresponding declaration in a submodule. In
    2010              :      translation this field carries a linked list of symbols that require
    2011              :      deferred initialization.  */
    2012              :   struct gfc_symbol *tlink;
    2013              : 
    2014              :   /* Change management fields.  Symbols that might be modified by the
    2015              :      current statement have the mark member nonzero.  Of these symbols,
    2016              :      symbols with old_symbol equal to NULL are symbols created within
    2017              :      the current statement.  Otherwise, old_symbol points to a copy of
    2018              :      the old symbol. gfc_new is used in symbol.cc to flag new symbols.
    2019              :      comp_mark is used to indicate variables which have component accesses
    2020              :      in OpenMP/OpenACC directive clauses (cf. c-typeck.cc:c_finish_omp_clauses,
    2021              :      map_field_head).
    2022              :      data_mark is used to check duplicate mappings for OpenMP data-sharing
    2023              :      clauses (see firstprivate_head/lastprivate_head in the above function).
    2024              :      dev_mark is used to check duplicate mappings for OpenMP
    2025              :      is_device_ptr/has_device_addr clauses (see is_on_device_head in above
    2026              :      function).
    2027              :      gen_mark is used to check duplicate mappings for OpenMP
    2028              :      use_device_ptr/use_device_addr/private/shared clauses (see generic_head in
    2029              :      above functon).
    2030              :      reduc_mark is used to check duplicate mappings for OpenMP reduction
    2031              :      clauses.  */
    2032              :   struct gfc_symbol *old_symbol;
    2033              :   unsigned mark:1, comp_mark:1, data_mark:1, dev_mark:1, gen_mark:1;
    2034              :   unsigned reduc_mark:1, gfc_new:1;
    2035              : 
    2036              :   /* Nonzero if all equivalences associated with this symbol have been
    2037              :      processed.  */
    2038              :   unsigned equiv_built:1;
    2039              :   /* Set if this variable is used as an index name in a FORALL.  */
    2040              :   unsigned forall_index:1;
    2041              :   /* Set if the symbol is used in a function result specification .  */
    2042              :   unsigned fn_result_spec:1;
    2043              :   /* Set if the symbol spec. depends on an old-style function result.  */
    2044              :   unsigned fn_result_dep:1;
    2045              :   /* Used to avoid multiple resolutions of a single symbol.  */
    2046              :   /* = 2 if this has already been resolved as an intrinsic,
    2047              :        in gfc_resolve_intrinsic,
    2048              :      = 1 if it has been resolved in resolve_symbol.  */
    2049              :   unsigned resolve_symbol_called:2;
    2050              :   /* Set if this is a module function or subroutine with the
    2051              :      abbreviated declaration in a submodule.  */
    2052              :   unsigned abr_modproc_decl:1;
    2053              :   /* Set if a previous error or warning has occurred and no other
    2054              :      should be reported.  */
    2055              :   unsigned error:1;
    2056              :   /* Set if the dummy argument of a procedure could be an array despite
    2057              :      being called with a scalar actual argument. */
    2058              :   unsigned maybe_array:1;
    2059              :   /* Set if this should be passed by value, but is not a VALUE argument
    2060              :      according to the Fortran standard.  */
    2061              :   unsigned pass_as_value:1;
    2062              :   /* Set if an external dummy argument is called with different argument lists.
    2063              :      This is legal in Fortran, but can cause problems with autogenerated
    2064              :      C prototypes for C23.  */
    2065              :   unsigned ext_dummy_arglist_mismatch:1;
    2066              :   /* Set if the formal arglist has already been resolved, to avoid
    2067              :      trying to generate it again from actual arguments.  */
    2068              :   unsigned formal_resolved:1;
    2069              : 
    2070              :   /* Reference counter, used for memory management.
    2071              : 
    2072              :      Some symbols may be present in more than one namespace, for example
    2073              :      function and subroutine symbols are present both in the outer namespace and
    2074              :      the procedure body namespace.  Freeing symbols with the namespaces they are
    2075              :      in would result in double free for those symbols.  This field counts
    2076              :      references and is used to delay the memory release until the last reference
    2077              :      to the symbol is removed.
    2078              : 
    2079              :      Not every symbol pointer is accounted for reference counting.  Fields
    2080              :      gfc_symtree::n::sym are, and gfc_finalizer::proc_sym as well.  But most of
    2081              :      them (dummy arguments, generic list elements, etc) are "weak" pointers;
    2082              :      the reference count isn't updated when they are assigned, and they are
    2083              :      ignored when the surrounding structure memory is released.  This is not a
    2084              :      problem because there is always a namespace as surrounding context and
    2085              :      symbols have a name they can be referred with in that context, so the
    2086              :      namespace keeps the symbol from being freed, keeping the pointer valid.
    2087              :      When the namespace ceases to exist, and the symbols with it, the other
    2088              :      structures referencing symbols cease to exist as well.  */
    2089              :   int refs;
    2090              : 
    2091              :   struct gfc_namespace *ns;     /* namespace containing this symbol */
    2092              : 
    2093              :   tree backend_decl;
    2094              : 
    2095              :   /* Identity of the intrinsic module the symbol comes from, or
    2096              :      INTMOD_NONE if it's not imported from a intrinsic module.  */
    2097              :   intmod_id from_intmod;
    2098              :   /* Identity of the symbol from intrinsic modules, from enums maintained
    2099              :      separately by each intrinsic module.  Used together with from_intmod,
    2100              :      it uniquely identifies a symbol from an intrinsic module.  */
    2101              :   int intmod_sym_id;
    2102              : 
    2103              :   /* This may be repetitive, since the typespec now has a binding
    2104              :      label field.  */
    2105              :   const char* binding_label;
    2106              :   /* Store a reference to the common_block, if this symbol is in one.  */
    2107              :   struct gfc_common_head *common_block;
    2108              : 
    2109              :   /* Link to corresponding association-list if this is an associate name.  */
    2110              :   struct gfc_association_list *assoc;
    2111              : 
    2112              :   /* Link to next entry in derived type list */
    2113              :   struct gfc_symbol *dt_next;
    2114              : 
    2115              :   /* This is for determining where the symbol has been used first, for better
    2116              :      location of error messages.  */
    2117              :   locus formal_at;
    2118              : }
    2119              : gfc_symbol;
    2120              : 
    2121              : 
    2122              : struct gfc_undo_change_set
    2123              : {
    2124              :   vec<gfc_symbol *> syms;
    2125              :   vec<gfc_typebound_proc *> tbps;
    2126              :   gfc_undo_change_set *previous;
    2127              : };
    2128              : 
    2129              : 
    2130              : /* This structure is used to keep track of symbols in common blocks.  */
    2131              : typedef struct gfc_common_head
    2132              : {
    2133              :   locus where;
    2134              :   char use_assoc, saved, threadprivate;
    2135              :   unsigned char omp_declare_target : 1;
    2136              :   unsigned char omp_declare_target_link : 1;
    2137              :   unsigned char omp_declare_target_local : 1;
    2138              :   unsigned char omp_groupprivate : 1;
    2139              :   ENUM_BITFIELD (gfc_omp_device_type) omp_device_type:2;
    2140              :   /* Provide sufficient space to hold "symbol.symbol.eq.1234567890".  */
    2141              :   char name[2*GFC_MAX_SYMBOL_LEN + 1 + 14 + 1];
    2142              :   struct gfc_symbol *head;
    2143              :   const char* binding_label;
    2144              :   int is_bind_c;
    2145              :   int refs;
    2146              : }
    2147              : gfc_common_head;
    2148              : 
    2149              : #define gfc_get_common_head() XCNEW (gfc_common_head)
    2150              : 
    2151              : 
    2152              : /* A list of all the alternate entry points for a procedure.  */
    2153              : 
    2154              : typedef struct gfc_entry_list
    2155              : {
    2156              :   /* The symbol for this entry point.  */
    2157              :   gfc_symbol *sym;
    2158              :   /* The zero-based id of this entry point.  */
    2159              :   int id;
    2160              :   /* The LABEL_EXPR marking this entry point.  */
    2161              :   tree label;
    2162              :   /* The next item in the list.  */
    2163              :   struct gfc_entry_list *next;
    2164              : }
    2165              : gfc_entry_list;
    2166              : 
    2167              : #define gfc_get_entry_list() XCNEW (gfc_entry_list)
    2168              : 
    2169              : /* Lists of rename info for the USE statement.  */
    2170              : 
    2171              : typedef struct gfc_use_rename
    2172              : {
    2173              :   char local_name[GFC_MAX_SYMBOL_LEN + 1], use_name[GFC_MAX_SYMBOL_LEN + 1];
    2174              :   struct gfc_use_rename *next;
    2175              :   int found;
    2176              :   gfc_intrinsic_op op;
    2177              :   locus where;
    2178              : }
    2179              : gfc_use_rename;
    2180              : 
    2181              : #define gfc_get_use_rename() XCNEW (gfc_use_rename);
    2182              : 
    2183              : /* A list of all USE statements in a namespace.  */
    2184              : 
    2185              : typedef struct gfc_use_list
    2186              : {
    2187              :   const char *module_name;
    2188              :   const char *submodule_name;
    2189              :   bool intrinsic;
    2190              :   bool non_intrinsic;
    2191              :   bool only_flag;
    2192              :   struct gfc_use_rename *rename;
    2193              :   locus where;
    2194              :   /* Next USE statement.  */
    2195              :   struct gfc_use_list *next;
    2196              : }
    2197              : gfc_use_list;
    2198              : 
    2199              : #define gfc_get_use_list() XCNEW (gfc_use_list)
    2200              : 
    2201              : /* Within a namespace, symbols are pointed to by symtree nodes that
    2202              :    are linked together in a balanced binary tree.  There can be
    2203              :    several symtrees pointing to the same symbol node via USE
    2204              :    statements.  */
    2205              : 
    2206              : typedef struct gfc_symtree
    2207              : {
    2208              :   BBT_HEADER (gfc_symtree);
    2209              :   const char *name;
    2210              :   int ambiguous;
    2211              :   union
    2212              :   {
    2213              :     gfc_symbol *sym;            /* Symbol associated with this node */
    2214              :     gfc_user_op *uop;
    2215              :     gfc_common_head *common;
    2216              :     gfc_typebound_proc *tb;
    2217              :     gfc_omp_udr *omp_udr;
    2218              :   }
    2219              :   n;
    2220              :   unsigned import_only:1;
    2221              : }
    2222              : gfc_symtree;
    2223              : 
    2224              : /* A list of all derived types.  */
    2225              : extern gfc_symbol *gfc_derived_types;
    2226              : 
    2227              : typedef struct gfc_oacc_routine_name
    2228              : {
    2229              :   struct gfc_symbol *sym;
    2230              :   struct gfc_omp_clauses *clauses;
    2231              :   struct gfc_oacc_routine_name *next;
    2232              :   locus loc;
    2233              : }
    2234              : gfc_oacc_routine_name;
    2235              : 
    2236              : #define gfc_get_oacc_routine_name() XCNEW (gfc_oacc_routine_name)
    2237              : 
    2238              : /* Node in linked list to see what has already been finalized
    2239              :    earlier.  */
    2240              : 
    2241              : typedef struct gfc_was_finalized {
    2242              :   gfc_expr *e;
    2243              :   gfc_component *c;
    2244              :   struct gfc_was_finalized *next;
    2245              : }
    2246              : gfc_was_finalized;
    2247              : 
    2248              : 
    2249              :   /* Flag F2018 import status */
    2250              : enum importstate
    2251              : { IMPORT_NOT_SET = 0,   /* Default condition.  */
    2252              :   IMPORT_F2008,         /* Old style IMPORT.  */
    2253              :   IMPORT_ONLY,          /* Import list used.  */
    2254              :   IMPORT_NONE,          /* No host association.  Unique in scoping unit.  */
    2255              :   IMPORT_ALL            /* Must be unique in the scoping unit.  */
    2256              : };
    2257              : 
    2258              : 
    2259              : /* A namespace describes the contents of procedure, module, interface block
    2260              :    or BLOCK construct.  */
    2261              : /* ??? Anything else use these?  */
    2262              : 
    2263              : typedef struct gfc_namespace
    2264              : {
    2265              :   /* Tree containing all the symbols in this namespace.  */
    2266              :   gfc_symtree *sym_root;
    2267              :   /* Tree containing all the user-defined operators in the namespace.  */
    2268              :   gfc_symtree *uop_root;
    2269              :   /* Tree containing all the common blocks.  */
    2270              :   gfc_symtree *common_root;
    2271              :   /* Tree containing all the OpenMP user defined reductions.  */
    2272              :   gfc_symtree *omp_udr_root;
    2273              : 
    2274              :   /* Tree containing type-bound procedures.  */
    2275              :   gfc_symtree *tb_sym_root;
    2276              :   /* Type-bound user operators.  */
    2277              :   gfc_symtree *tb_uop_root;
    2278              :   /* For derived-types, store type-bound intrinsic operators here.  */
    2279              :   gfc_typebound_proc *tb_op[GFC_INTRINSIC_OPS];
    2280              :   /* Linked list of finalizer procedures.  */
    2281              :   struct gfc_finalizer *finalizers;
    2282              : 
    2283              :   /* If set_flag[letter] is set, an implicit type has been set for letter.  */
    2284              :   int set_flag[GFC_LETTERS];
    2285              :   /* Keeps track of the implicit types associated with the letters.  */
    2286              :   gfc_typespec default_type[GFC_LETTERS];
    2287              :   /* Store the positions of IMPLICIT statements.  */
    2288              :   locus implicit_loc[GFC_LETTERS];
    2289              : 
    2290              :   /* If this is a namespace of a procedure, this points to the procedure.  */
    2291              :   struct gfc_symbol *proc_name;
    2292              :   /* If this is the namespace of a unit which contains executable
    2293              :      code, this points to it.  */
    2294              :   struct gfc_code *code;
    2295              : 
    2296              :   /* Points to the equivalences set up in this namespace.  */
    2297              :   struct gfc_equiv *equiv, *old_equiv;
    2298              : 
    2299              :   /* Points to the equivalence groups produced by trans_common.  */
    2300              :   struct gfc_equiv_list *equiv_lists;
    2301              : 
    2302              :   gfc_interface *op[GFC_INTRINSIC_OPS];
    2303              : 
    2304              :   /* Points to the parent namespace, i.e. the namespace of a module or
    2305              :      procedure in which the procedure belonging to this namespace is
    2306              :      contained. The parent namespace points to this namespace either
    2307              :      directly via CONTAINED, or indirectly via the chain built by
    2308              :      SIBLING.  */
    2309              :   struct gfc_namespace *parent;
    2310              :   /* CONTAINED points to the first contained namespace. Sibling
    2311              :      namespaces are chained via SIBLING.  */
    2312              :   struct gfc_namespace  *contained, *sibling;
    2313              : 
    2314              :   gfc_common_head blank_common;
    2315              :   gfc_access default_access, operator_access[GFC_INTRINSIC_OPS];
    2316              : 
    2317              :   gfc_st_label *st_labels;
    2318              :   /* This list holds information about all the data initializers in
    2319              :      this namespace.  */
    2320              :   struct gfc_data *data, *old_data;
    2321              : 
    2322              :   /* !$ACC DECLARE.  */
    2323              :   gfc_oacc_declare *oacc_declare;
    2324              : 
    2325              :   /* !$ACC ROUTINE clauses.  */
    2326              :   gfc_omp_clauses *oacc_routine_clauses;
    2327              : 
    2328              :   /* !$ACC TASK AFFINITY iterator symbols.  */
    2329              :   gfc_symbol *omp_affinity_iterators;
    2330              : 
    2331              :   /* !$ACC ROUTINE names.  */
    2332              :   gfc_oacc_routine_name *oacc_routine_names;
    2333              : 
    2334              :   gfc_charlen *cl_list;
    2335              : 
    2336              :   gfc_symbol *derived_types;
    2337              : 
    2338              :   int save_all, seen_save, seen_implicit_none;
    2339              : 
    2340              :   /* Normally we don't need to refcount namespaces.  However when we read
    2341              :      a module containing a function with multiple entry points, this
    2342              :      will appear as several functions with the same formal namespace.  */
    2343              :   int refs;
    2344              : 
    2345              :   /* A list of all alternate entry points to this procedure (or NULL).  */
    2346              :   gfc_entry_list *entries;
    2347              : 
    2348              :   /* A list of USE statements in this namespace.  */
    2349              :   gfc_use_list *use_stmts;
    2350              : 
    2351              :   /* Linked list of !$omp declare simd constructs.  */
    2352              :   struct gfc_omp_declare_simd *omp_declare_simd;
    2353              : 
    2354              :   /* Linked list of !$omp declare variant constructs.  */
    2355              :   struct gfc_omp_declare_variant *omp_declare_variant;
    2356              : 
    2357              :   /* OpenMP assumptions and allocate for static/stack vars.  */
    2358              :   struct gfc_omp_assumptions *omp_assumes;
    2359              :   struct gfc_omp_namelist *omp_allocate;
    2360              : 
    2361              :   /* A hash set for the gfc expressions that have already
    2362              :      been finalized in this namespace.  */
    2363              : 
    2364              :   gfc_was_finalized *was_finalized;
    2365              : 
    2366              :   /* Set to 1 if namespace is a BLOCK DATA program unit.  */
    2367              :   unsigned is_block_data:1;
    2368              : 
    2369              :   /* Set to 1 if namespace is an interface body with "IMPORT" used.  */
    2370              :   unsigned has_import_set:1;
    2371              : 
    2372              :   /* Flag F2018 import status */
    2373              :   ENUM_BITFIELD (importstate) import_state :3;
    2374              : 
    2375              : 
    2376              :   /* Set to 1 if the namespace uses "IMPLICIT NONE (export)".  */
    2377              :   unsigned has_implicit_none_export:1;
    2378              : 
    2379              :   /* Set to 1 if resolved has been called for this namespace.
    2380              :      Holds -1 during resolution.  */
    2381              :   signed resolved:2;
    2382              : 
    2383              :   /* Set when resolve_types has been called for this namespace.  */
    2384              :   unsigned types_resolved:1;
    2385              : 
    2386              :   /* Set if the associate_name in a select type statement is an
    2387              :      inferred type.  */
    2388              :   unsigned assoc_name_inferred:1;
    2389              : 
    2390              :   /* Set to 1 if code has been generated for this namespace.  */
    2391              :   unsigned translated:1;
    2392              : 
    2393              :   /* Set to 1 if symbols in this namespace should be 'construct entities',
    2394              :      i.e. for BLOCK local variables.  */
    2395              :   unsigned construct_entities:1;
    2396              : 
    2397              :   /* Set to 1 for !$OMP DECLARE REDUCTION namespaces.  */
    2398              :   unsigned omp_udr_ns:1;
    2399              : 
    2400              :   /* Set to 1 for !$ACC ROUTINE namespaces.  */
    2401              :   unsigned oacc_routine:1;
    2402              : 
    2403              :   /* Set to 1 if there are any calls to procedures with implicit interface.  */
    2404              :   unsigned implicit_interface_calls:1;
    2405              : 
    2406              :   /* OpenMP requires. */
    2407              :   unsigned omp_requires:8;
    2408              :   unsigned omp_target_seen:1;
    2409              : 
    2410              :   /* Set to 1 if this is an implicit OMP structured block.  */
    2411              :   unsigned omp_structured_block:1;
    2412              : }
    2413              : gfc_namespace;
    2414              : 
    2415              : extern gfc_namespace *gfc_current_ns;
    2416              : extern gfc_namespace *gfc_global_ns_list;
    2417              : 
    2418              : /* Global symbols are symbols of global scope. Currently we only use
    2419              :    this to detect collisions already when parsing.
    2420              :    TODO: Extend to verify procedure calls.  */
    2421              : 
    2422              : enum gfc_symbol_type
    2423              : {
    2424              :   GSYM_UNKNOWN=1, GSYM_PROGRAM, GSYM_FUNCTION, GSYM_SUBROUTINE,
    2425              :   GSYM_MODULE, GSYM_COMMON, GSYM_BLOCK_DATA
    2426              : };
    2427              : 
    2428              : typedef struct gfc_gsymbol
    2429              : {
    2430              :   BBT_HEADER(gfc_gsymbol);
    2431              : 
    2432              :   const char *name;
    2433              :   const char *sym_name;
    2434              :   const char *mod_name;
    2435              :   const char *binding_label;
    2436              :   enum gfc_symbol_type type;
    2437              : 
    2438              :   int defined, used;
    2439              :   bool bind_c;
    2440              :   locus where;
    2441              :   gfc_namespace *ns;
    2442              : }
    2443              : gfc_gsymbol;
    2444              : 
    2445              : extern gfc_gsymbol *gfc_gsym_root;
    2446              : 
    2447              : /* Information on interfaces being built.  */
    2448              : typedef struct
    2449              : {
    2450              :   interface_type type;
    2451              :   gfc_symbol *sym;
    2452              :   gfc_namespace *ns;
    2453              :   gfc_user_op *uop;
    2454              :   gfc_intrinsic_op op;
    2455              : }
    2456              : gfc_interface_info;
    2457              : 
    2458              : extern gfc_interface_info current_interface;
    2459              : 
    2460              : 
    2461              : /* Array reference.  */
    2462              : 
    2463              : enum gfc_array_ref_dimen_type
    2464              : {
    2465              :   DIMEN_ELEMENT = 1, DIMEN_RANGE, DIMEN_VECTOR, DIMEN_STAR, DIMEN_THIS_IMAGE, DIMEN_UNKNOWN
    2466              : };
    2467              : 
    2468              : enum gfc_array_ref_team_type
    2469              : {
    2470              :   TEAM_UNKNOWN = 0, TEAM_UNSET, TEAM_TEAM, TEAM_NUMBER
    2471              : };
    2472              : 
    2473              : typedef struct gfc_array_ref
    2474              : {
    2475              :   ar_type type;
    2476              :   int dimen;                    /* # of components in the reference */
    2477              :   int codimen;
    2478              :   bool in_allocate;             /* For coarray checks. */
    2479              :   enum gfc_array_ref_team_type team_type : 2;
    2480              :   gfc_expr *team;
    2481              :   gfc_expr *stat;
    2482              :   locus where;
    2483              :   gfc_array_spec *as;
    2484              : 
    2485              :   locus c_where[GFC_MAX_DIMENSIONS];    /* All expressions can be NULL */
    2486              :   struct gfc_expr *start[GFC_MAX_DIMENSIONS], *end[GFC_MAX_DIMENSIONS],
    2487              :     *stride[GFC_MAX_DIMENSIONS];
    2488              : 
    2489              :   enum gfc_array_ref_dimen_type dimen_type[GFC_MAX_DIMENSIONS];
    2490              : }
    2491              : gfc_array_ref;
    2492              : 
    2493              : #define gfc_get_array_ref() XCNEW (gfc_array_ref)
    2494              : 
    2495              : 
    2496              : /* Component reference nodes.  A variable is stored as an expression
    2497              :    node that points to the base symbol.  After that, a singly linked
    2498              :    list of component reference nodes gives the variable's complete
    2499              :    resolution.  The array_ref component may be present and comes
    2500              :    before the component component.  */
    2501              : 
    2502              : enum ref_type
    2503              :   { REF_ARRAY, REF_COMPONENT, REF_SUBSTRING, REF_INQUIRY };
    2504              : 
    2505              : enum inquiry_type
    2506              :   { INQUIRY_RE, INQUIRY_IM, INQUIRY_KIND, INQUIRY_LEN };
    2507              : 
    2508              : typedef struct gfc_ref
    2509              : {
    2510              :   ref_type type;
    2511              : 
    2512              :   union
    2513              :   {
    2514              :     struct gfc_array_ref ar;
    2515              : 
    2516              :     struct
    2517              :     {
    2518              :       gfc_component *component;
    2519              :       gfc_symbol *sym;
    2520              :     }
    2521              :     c;
    2522              : 
    2523              :     struct
    2524              :     {
    2525              :       struct gfc_expr *start, *end;     /* Substring */
    2526              :       gfc_charlen *length;
    2527              :     }
    2528              :     ss;
    2529              : 
    2530              :     inquiry_type i;
    2531              : 
    2532              :   }
    2533              :   u;
    2534              : 
    2535              :   struct gfc_ref *next;
    2536              : }
    2537              : gfc_ref;
    2538              : 
    2539              : #define gfc_get_ref() XCNEW (gfc_ref)
    2540              : 
    2541              : 
    2542              : /* Structures representing intrinsic symbols and their arguments lists.  */
    2543              : typedef struct gfc_intrinsic_arg
    2544              : {
    2545              :   char name[GFC_MAX_SYMBOL_LEN + 1];
    2546              : 
    2547              :   gfc_typespec ts;
    2548              :   unsigned optional:1, value:1;
    2549              :   ENUM_BITFIELD (sym_intent) intent:2;
    2550              : 
    2551              :   struct gfc_intrinsic_arg *next;
    2552              : }
    2553              : gfc_intrinsic_arg;
    2554              : 
    2555              : 
    2556              : typedef enum {
    2557              :   GFC_UNDEFINED_DUMMY_ARG = 0,
    2558              :   GFC_INTRINSIC_DUMMY_ARG,
    2559              :   GFC_NON_INTRINSIC_DUMMY_ARG
    2560              : }
    2561              : gfc_dummy_arg_intrinsicness;
    2562              : 
    2563              : /* dummy arg of either an intrinsic or a user-defined procedure.  */
    2564              : struct gfc_dummy_arg
    2565              : {
    2566              :   gfc_dummy_arg_intrinsicness intrinsicness;
    2567              : 
    2568              :   union {
    2569              :     gfc_intrinsic_arg *intrinsic;
    2570              :     gfc_formal_arglist *non_intrinsic;
    2571              :   } u;
    2572              : };
    2573              : 
    2574              : #define gfc_get_dummy_arg() XCNEW (gfc_dummy_arg)
    2575              : 
    2576              : 
    2577              : const char * gfc_dummy_arg_get_name (gfc_dummy_arg &);
    2578              : const gfc_typespec & gfc_dummy_arg_get_typespec (gfc_dummy_arg &);
    2579              : bool gfc_dummy_arg_is_optional (gfc_dummy_arg &);
    2580              : 
    2581              : 
    2582              : /* Specifies the various kinds of check functions used to verify the
    2583              :    argument lists of intrinsic functions. fX with X an integer refer
    2584              :    to check functions of intrinsics with X arguments. f1m is used for
    2585              :    the MAX and MIN intrinsics which can have an arbitrary number of
    2586              :    arguments, f4ml is used for the MINLOC and MAXLOC intrinsics as
    2587              :    these have special semantics.  */
    2588              : 
    2589              : typedef union
    2590              : {
    2591              :   bool (*f0)(void);
    2592              :   bool (*f1)(struct gfc_expr *);
    2593              :   bool (*f1m)(gfc_actual_arglist *);
    2594              :   bool (*f2)(struct gfc_expr *, struct gfc_expr *);
    2595              :   bool (*f3)(struct gfc_expr *, struct gfc_expr *, struct gfc_expr *);
    2596              :   bool (*f5ml)(gfc_actual_arglist *);
    2597              :   bool (*f6fl)(gfc_actual_arglist *);
    2598              :   bool (*f3red)(gfc_actual_arglist *);
    2599              :   bool (*f4)(struct gfc_expr *, struct gfc_expr *, struct gfc_expr *,
    2600              :             struct gfc_expr *);
    2601              :   bool (*f5)(struct gfc_expr *, struct gfc_expr *, struct gfc_expr *,
    2602              :             struct gfc_expr *, struct gfc_expr *);
    2603              :   bool (*f6)(struct gfc_expr *, struct gfc_expr *, struct gfc_expr *,
    2604              :             struct gfc_expr *, struct gfc_expr *, struct gfc_expr *);
    2605              : }
    2606              : gfc_check_f;
    2607              : 
    2608              : /* Like gfc_check_f, these specify the type of the simplification
    2609              :    function associated with an intrinsic. The fX are just like in
    2610              :    gfc_check_f. cc is used for type conversion functions.  */
    2611              : 
    2612              : typedef union
    2613              : {
    2614              :   struct gfc_expr *(*f0)(void);
    2615              :   struct gfc_expr *(*f1)(struct gfc_expr *);
    2616              :   struct gfc_expr *(*f2)(struct gfc_expr *, struct gfc_expr *);
    2617              :   struct gfc_expr *(*f3)(struct gfc_expr *, struct gfc_expr *,
    2618              :                          struct gfc_expr *);
    2619              :   struct gfc_expr *(*f4)(struct gfc_expr *, struct gfc_expr *,
    2620              :                          struct gfc_expr *, struct gfc_expr *);
    2621              :   struct gfc_expr *(*f5)(struct gfc_expr *, struct gfc_expr *,
    2622              :                          struct gfc_expr *, struct gfc_expr *,
    2623              :                          struct gfc_expr *);
    2624              :   struct gfc_expr *(*f6)(struct gfc_expr *, struct gfc_expr *,
    2625              :                          struct gfc_expr *, struct gfc_expr *,
    2626              :                          struct gfc_expr *, struct gfc_expr *);
    2627              :   struct gfc_expr *(*cc)(struct gfc_expr *, bt, int);
    2628              : }
    2629              : gfc_simplify_f;
    2630              : 
    2631              : /* Again like gfc_check_f, these specify the type of the resolution
    2632              :    function associated with an intrinsic. The fX are just like in
    2633              :    gfc_check_f. f1m is used for MIN and MAX, s1 is used for abort().  */
    2634              : 
    2635              : typedef union
    2636              : {
    2637              :   void (*f0)(struct gfc_expr *);
    2638              :   void (*f1)(struct gfc_expr *, struct gfc_expr *);
    2639              :   void (*f1m)(struct gfc_expr *, struct gfc_actual_arglist *);
    2640              :   void (*f2)(struct gfc_expr *, struct gfc_expr *, struct gfc_expr *);
    2641              :   void (*f3)(struct gfc_expr *, struct gfc_expr *, struct gfc_expr *,
    2642              :              struct gfc_expr *);
    2643              :   void (*f4)(struct gfc_expr *, struct gfc_expr *, struct gfc_expr *,
    2644              :              struct gfc_expr *, struct gfc_expr *);
    2645              :   void (*f5)(struct gfc_expr *, struct gfc_expr *, struct gfc_expr *,
    2646              :              struct gfc_expr *, struct gfc_expr *, struct gfc_expr *);
    2647              :   void (*f6)(struct gfc_expr *, struct gfc_expr *, struct gfc_expr *,
    2648              :              struct gfc_expr *, struct gfc_expr *, struct gfc_expr *,
    2649              :              struct gfc_expr *);
    2650              :   void (*s1)(struct gfc_code *);
    2651              : }
    2652              : gfc_resolve_f;
    2653              : 
    2654              : 
    2655              : typedef struct gfc_intrinsic_sym
    2656              : {
    2657              :   const char *name, *lib_name;
    2658              :   gfc_intrinsic_arg *formal;
    2659              :   gfc_typespec ts;
    2660              :   unsigned elemental:1, inquiry:1, transformational:1, pure:1,
    2661              :     generic:1, specific:1, actual_ok:1, noreturn:1, conversion:1,
    2662              :     from_module:1, vararg:1;
    2663              : 
    2664              :   int standard;
    2665              : 
    2666              :   gfc_simplify_f simplify;
    2667              :   gfc_check_f check;
    2668              :   gfc_resolve_f resolve;
    2669              :   struct gfc_intrinsic_sym *specific_head, *next;
    2670              :   gfc_isym_id id;
    2671              : 
    2672              : }
    2673              : gfc_intrinsic_sym;
    2674              : 
    2675              : 
    2676              : /* Expression nodes.  The expression node types deserve explanations,
    2677              :    since the last couple can be easily misconstrued:
    2678              : 
    2679              :    EXPR_OP         Operator node pointing to one or two other nodes
    2680              :    EXPR_FUNCTION   Function call, symbol points to function's name
    2681              :    EXPR_CONSTANT   A scalar constant: Logical, String, Real, Int or Complex
    2682              :    EXPR_VARIABLE   An Lvalue with a root symbol and possible reference list
    2683              :                    which expresses structure, array and substring refs.
    2684              :    EXPR_NULL       The NULL pointer value (which also has a basic type).
    2685              :    EXPR_SUBSTRING  A substring of a constant string
    2686              :    EXPR_STRUCTURE  A structure constructor
    2687              :    EXPR_ARRAY      An array constructor.
    2688              :    EXPR_COMPCALL   Function (or subroutine) call of a procedure pointer
    2689              :                    component or type-bound procedure.  */
    2690              : 
    2691              : #include <mpfr.h>
    2692              : #include <mpc.h>
    2693              : #define GFC_RND_MODE MPFR_RNDN
    2694              : #define GFC_MPC_RND_MODE MPC_RNDNN
    2695              : 
    2696              : typedef splay_tree gfc_constructor_base;
    2697              : 
    2698              : 
    2699              : /* This should be an unsigned variable of type size_t.  But to handle
    2700              :    compiling to a 64-bit target from a 32-bit host, we need to use a
    2701              :    HOST_WIDE_INT.  Also, occasionally the string length field is used
    2702              :    as a flag with values -1 and -2, see e.g. gfc_add_assign_aux_vars.
    2703              :    So it needs to be signed.  */
    2704              : typedef HOST_WIDE_INT gfc_charlen_t;
    2705              : 
    2706              : typedef struct gfc_expr
    2707              : {
    2708              :   expr_t expr_type;
    2709              : 
    2710              :   gfc_typespec ts;      /* These two refer to the overall expression */
    2711              : 
    2712              :   int rank;             /* 0 indicates a scalar, -1 an assumed-rank array.  */
    2713              :   int corank;           /* same as rank, but for coarrays.  */
    2714              :   mpz_t *shape;         /* Can be NULL if shape is unknown at compile time */
    2715              : 
    2716              :   /* Nonnull for functions and structure constructors, may also used to hold the
    2717              :      base-object for component calls.  */
    2718              :   gfc_symtree *symtree;
    2719              : 
    2720              :   gfc_ref *ref;
    2721              : 
    2722              :   locus where;
    2723              : 
    2724              :   /* Used to store the base expression in component calls, when the expression
    2725              :      is not a variable.  */
    2726              :   struct gfc_expr *base_expr;
    2727              : 
    2728              :   /* is_snan denotes a signalling not-a-number.  */
    2729              :   unsigned int is_snan : 1;
    2730              : 
    2731              :   /* Sometimes, when an error has been emitted, it is necessary to prevent
    2732              :       it from recurring.  */
    2733              :   unsigned int error : 1;
    2734              : 
    2735              :   /* Mark an expression where a user operator has been substituted by
    2736              :      a function call in interface.cc(gfc_extend_expr).  */
    2737              :   unsigned int user_operator : 1;
    2738              : 
    2739              :   /* Mark an expression as being a MOLD argument of ALLOCATE.  */
    2740              :   unsigned int mold : 1;
    2741              : 
    2742              :   /* Will require finalization after use.  */
    2743              :   unsigned int must_finalize : 1;
    2744              : 
    2745              :   /* Set this if no range check should be performed on this expression.  */
    2746              : 
    2747              :   unsigned int no_bounds_check : 1;
    2748              : 
    2749              :   /* Set this if a matmul expression has already been evaluated for conversion
    2750              :      to a BLAS call.  */
    2751              : 
    2752              :   unsigned int external_blas : 1;
    2753              : 
    2754              :   /* Set this if resolution has already happened. It could be harmful
    2755              :      if done again.  */
    2756              : 
    2757              :   unsigned int do_not_resolve_again : 1;
    2758              : 
    2759              :   /* Set this if no warning should be given somewhere in a lower level.  */
    2760              : 
    2761              :   unsigned int do_not_warn : 1;
    2762              : 
    2763              :   /* Set this if the expression came from expanding an array constructor.  */
    2764              :   unsigned int from_constructor : 1;
    2765              : 
    2766              :   /* If an expression comes from a Hollerith constant or compile-time
    2767              :      evaluation of a transfer statement, it may have a prescribed target-
    2768              :      memory representation, and these cannot always be backformed from
    2769              :      the value.  */
    2770              :   struct
    2771              :   {
    2772              :     gfc_charlen_t length;
    2773              :     char *string;
    2774              :   }
    2775              :   representation;
    2776              : 
    2777              :   struct
    2778              :   {
    2779              :     int len;    /* Length of BOZ string without terminating NULL.  */
    2780              :     int rdx;    /* Radix of BOZ.  */
    2781              :     char *str;  /* BOZ string with NULL terminating character.  */
    2782              :   }
    2783              :   boz;
    2784              : 
    2785              :   union
    2786              :   {
    2787              :     int logical;
    2788              : 
    2789              :     io_kind iokind;
    2790              : 
    2791              :     mpz_t integer;
    2792              : 
    2793              :     mpfr_t real;
    2794              : 
    2795              :     mpc_t complex;
    2796              : 
    2797              :     struct
    2798              :     {
    2799              :       gfc_intrinsic_op op;
    2800              :       gfc_user_op *uop;
    2801              :       struct gfc_expr *op1, *op2;
    2802              :     }
    2803              :     op;
    2804              : 
    2805              :     struct
    2806              :     {
    2807              :       gfc_actual_arglist *actual;
    2808              :       const char *name; /* Points to the ultimate name of the function */
    2809              :       gfc_intrinsic_sym *isym;
    2810              :       gfc_symbol *esym;
    2811              :     }
    2812              :     function;
    2813              : 
    2814              :     struct
    2815              :     {
    2816              :       gfc_actual_arglist* actual;
    2817              :       const char* name;
    2818              :       /* Base-object, whose component was called.  NULL means that it should
    2819              :          be taken from symtree/ref.  */
    2820              :       struct gfc_expr* base_object;
    2821              :       gfc_typebound_proc* tbp; /* Should overlap with esym.  */
    2822              : 
    2823              :       /* For type-bound operators, we want to call PASS procedures but already
    2824              :          have the full arglist; mark this, so that it is not extended by the
    2825              :          PASS argument.  */
    2826              :       unsigned ignore_pass:1;
    2827              : 
    2828              :       /* Do assign-calls rather than calls, that is appropriate dependency
    2829              :          checking.  */
    2830              :       unsigned assign:1;
    2831              :     }
    2832              :     compcall;
    2833              : 
    2834              :     struct
    2835              :     {
    2836              :       gfc_charlen_t length;
    2837              :       gfc_char_t *string;
    2838              :     }
    2839              :     character;
    2840              : 
    2841              :     gfc_constructor_base constructor;
    2842              : 
    2843              :     struct
    2844              :     {
    2845              :       struct gfc_expr *condition;
    2846              :       struct gfc_expr *true_expr;
    2847              :       struct gfc_expr *false_expr;
    2848              :     } conditional;
    2849              :   } value;
    2850              : 
    2851              :   /* Used to store PDT expression lists associated with expressions.  */
    2852              :   gfc_actual_arglist *param_list;
    2853              : 
    2854              : }
    2855              : gfc_expr;
    2856              : 
    2857              : 
    2858              : #define gfc_get_shape(rank) (XCNEWVEC (mpz_t, (rank)))
    2859              : 
    2860              : /* Structures for information associated with different kinds of
    2861              :    numbers.  The first set of integer parameters define all there is
    2862              :    to know about a particular kind.  The rest of the elements are
    2863              :    computed from the first elements.  */
    2864              : 
    2865              : typedef struct
    2866              : {
    2867              :   /* Values really representable by the target.  */
    2868              :   mpz_t huge, pedantic_min_int, min_int;
    2869              : 
    2870              :   int kind, radix, digits, bit_size, range;
    2871              : 
    2872              :   /* True if the C type of the given name maps to this precision.
    2873              :      Note that more than one bit can be set.  */
    2874              :   unsigned int c_char : 1;
    2875              :   unsigned int c_short : 1;
    2876              :   unsigned int c_int : 1;
    2877              :   unsigned int c_long : 1;
    2878              :   unsigned int c_long_long : 1;
    2879              : }
    2880              : gfc_integer_info;
    2881              : 
    2882              : extern gfc_integer_info gfc_integer_kinds[];
    2883              : 
    2884              : /* Unsigned numbers, experimental.  */
    2885              : 
    2886              : typedef struct
    2887              : {
    2888              :   mpz_t huge, int_min;
    2889              : 
    2890              :   int kind, radix, digits, bit_size, range;
    2891              : 
    2892              :   /* True if the C type of the given name maps to this precision.  Note that
    2893              :      more than one bit can be set.  We will use this later on.  */
    2894              :   unsigned int c_unsigned_char : 1;
    2895              :   unsigned int c_unsigned_short : 1;
    2896              :   unsigned int c_unsigned_int : 1;
    2897              :   unsigned int c_unsigned_long : 1;
    2898              :   unsigned int c_unsigned_long_long : 1;
    2899              : }
    2900              : gfc_unsigned_info;
    2901              : 
    2902              : extern gfc_unsigned_info gfc_unsigned_kinds[];
    2903              : 
    2904              : typedef struct
    2905              : {
    2906              :   int kind, bit_size;
    2907              : 
    2908              :   /* True if the C++ type bool, C99 type _Bool, maps to this precision.  */
    2909              :   unsigned int c_bool : 1;
    2910              : }
    2911              : gfc_logical_info;
    2912              : 
    2913              : extern gfc_logical_info gfc_logical_kinds[];
    2914              : 
    2915              : 
    2916              : typedef struct
    2917              : {
    2918              :   mpfr_t epsilon, huge, tiny, subnormal;
    2919              :   int kind, abi_kind, radix, digits, min_exponent, max_exponent;
    2920              :   int range, precision;
    2921              : 
    2922              :   /* The precision of the type as reported by GET_MODE_PRECISION.  */
    2923              :   int mode_precision;
    2924              : 
    2925              :   /* True if the C type of the given name maps to this precision.
    2926              :      Note that more than one bit can be set.  */
    2927              :   unsigned int c_float : 1;
    2928              :   unsigned int c_double : 1;
    2929              :   unsigned int c_long_double : 1;
    2930              :   unsigned int c_float128 : 1;
    2931              :   /* True if for _Float128 C23 IEC 60559 *f128 APIs should be used
    2932              :      instead of libquadmath *q APIs.  */
    2933              :   unsigned int use_iec_60559 : 1;
    2934              : }
    2935              : gfc_real_info;
    2936              : 
    2937              : extern gfc_real_info gfc_real_kinds[];
    2938              : 
    2939              : typedef struct
    2940              : {
    2941              :   int kind, bit_size;
    2942              :   const char *name;
    2943              : }
    2944              : gfc_character_info;
    2945              : 
    2946              : extern gfc_character_info gfc_character_kinds[];
    2947              : 
    2948              : 
    2949              : /* Equivalence structures.  Equivalent lvalues are linked along the
    2950              :    *eq pointer, equivalence sets are strung along the *next node.  */
    2951              : typedef struct gfc_equiv
    2952              : {
    2953              :   struct gfc_equiv *next, *eq;
    2954              :   gfc_expr *expr;
    2955              :   const char *module;
    2956              :   int used;
    2957              : }
    2958              : gfc_equiv;
    2959              : 
    2960              : #define gfc_get_equiv() XCNEW (gfc_equiv)
    2961              : 
    2962              : /* Holds a single equivalence member after processing.  */
    2963              : typedef struct gfc_equiv_info
    2964              : {
    2965              :   gfc_symbol *sym;
    2966              :   HOST_WIDE_INT offset;
    2967              :   HOST_WIDE_INT length;
    2968              :   struct gfc_equiv_info *next;
    2969              : } gfc_equiv_info;
    2970              : 
    2971              : /* Holds equivalence groups, after they have been processed.  */
    2972              : typedef struct gfc_equiv_list
    2973              : {
    2974              :   gfc_equiv_info *equiv;
    2975              :   struct gfc_equiv_list *next;
    2976              : } gfc_equiv_list;
    2977              : 
    2978              : /* gfc_case stores the selector list of a case statement.  The *low
    2979              :    and *high pointers can point to the same expression in the case of
    2980              :    a single value.  If *high is NULL, the selection is from *low
    2981              :    upwards, if *low is NULL the selection is *high downwards.
    2982              : 
    2983              :    This structure has separate fields to allow single and double linked
    2984              :    lists of CASEs at the same time.  The single linked list along the NEXT
    2985              :    field is a list of cases for a single CASE label.  The double linked
    2986              :    list along the LEFT/RIGHT fields is used to detect overlap and to
    2987              :    build a table of the cases for SELECT constructs with a CHARACTER
    2988              :    case expression.  */
    2989              : 
    2990              : typedef struct gfc_case
    2991              : {
    2992              :   /* Where we saw this case.  */
    2993              :   locus where;
    2994              :   int n;
    2995              : 
    2996              :   /* Case range values.  If (low == high), it's a single value.  If one of
    2997              :      the labels is NULL, it's an unbounded case.  If both are NULL, this
    2998              :      represents the default case.  */
    2999              :   gfc_expr *low, *high;
    3000              : 
    3001              :   /* Only used for SELECT TYPE.  */
    3002              :   gfc_typespec ts;
    3003              : 
    3004              :   /* Next case label in the list of cases for a single CASE label.  */
    3005              :   struct gfc_case *next;
    3006              : 
    3007              :   /* Used for detecting overlap, and for code generation.  */
    3008              :   struct gfc_case *left, *right;
    3009              : 
    3010              :   /* True if this case label can never be matched.  */
    3011              :   int unreachable;
    3012              : }
    3013              : gfc_case;
    3014              : 
    3015              : #define gfc_get_case() XCNEW (gfc_case)
    3016              : 
    3017              : 
    3018              : /* Annotations for loop constructs.  */
    3019              : typedef struct
    3020              : {
    3021              :   unsigned short unroll;
    3022              :   bool ivdep;
    3023              :   bool vector;
    3024              :   bool novector;
    3025              : }
    3026              : gfc_loop_annot;
    3027              : 
    3028              : 
    3029              : typedef struct
    3030              : {
    3031              :   gfc_expr *var, *start, *end, *step;
    3032              :   gfc_loop_annot annot;
    3033              : }
    3034              : gfc_iterator;
    3035              : 
    3036              : #define gfc_get_iterator() XCNEW (gfc_iterator)
    3037              : 
    3038              : 
    3039              : /* Allocation structure for ALLOCATE, DEALLOCATE and NULLIFY statements.  */
    3040              : 
    3041              : typedef struct gfc_alloc
    3042              : {
    3043              :   gfc_expr *expr;
    3044              :   struct gfc_alloc *next;
    3045              : }
    3046              : gfc_alloc;
    3047              : 
    3048              : #define gfc_get_alloc() XCNEW (gfc_alloc)
    3049              : 
    3050              : 
    3051              : typedef struct
    3052              : {
    3053              :   gfc_expr *unit, *file, *status, *access, *form, *recl,
    3054              :     *blank, *position, *action, *delim, *pad, *iostat, *iomsg, *convert,
    3055              :     *decimal, *encoding, *round, *sign, *asynchronous, *id, *newunit,
    3056              :     *share, *cc;
    3057              :   char readonly;
    3058              :   gfc_st_label *err;
    3059              : }
    3060              : gfc_open;
    3061              : 
    3062              : 
    3063              : typedef struct
    3064              : {
    3065              :   gfc_expr *unit, *status, *iostat, *iomsg;
    3066              :   gfc_st_label *err;
    3067              : }
    3068              : gfc_close;
    3069              : 
    3070              : 
    3071              : typedef struct
    3072              : {
    3073              :   gfc_expr *unit, *iostat, *iomsg;
    3074              :   gfc_st_label *err;
    3075              : }
    3076              : gfc_filepos;
    3077              : 
    3078              : 
    3079              : typedef struct
    3080              : {
    3081              :   gfc_expr *unit, *file, *iostat, *exist, *opened, *number, *named,
    3082              :     *name, *access, *sequential, *direct, *form, *formatted,
    3083              :     *unformatted, *recl, *nextrec, *blank, *position, *action, *read,
    3084              :     *write, *readwrite, *delim, *pad, *iolength, *iomsg, *convert, *strm_pos,
    3085              :     *asynchronous, *decimal, *encoding, *pending, *round, *sign, *size, *id,
    3086              :     *iqstream, *share, *cc;
    3087              : 
    3088              :   gfc_st_label *err;
    3089              : 
    3090              : }
    3091              : gfc_inquire;
    3092              : 
    3093              : 
    3094              : typedef struct
    3095              : {
    3096              :   gfc_expr *unit, *iostat, *iomsg, *id;
    3097              :   gfc_st_label *err, *end, *eor;
    3098              : }
    3099              : gfc_wait;
    3100              : 
    3101              : 
    3102              : typedef struct
    3103              : {
    3104              :   gfc_expr *io_unit, *format_expr, *rec, *advance, *iostat, *size, *iomsg,
    3105              :            *id, *pos, *asynchronous, *blank, *decimal, *delim, *pad, *round,
    3106              :            *sign, *extra_comma, *dt_io_kind, *udtio;
    3107              :   char dec_ext;
    3108              : 
    3109              :   gfc_symbol *namelist;
    3110              :   /* A format_label of `format_asterisk' indicates the "*" format */
    3111              :   gfc_st_label *format_label;
    3112              :   gfc_st_label *err, *end, *eor;
    3113              : 
    3114              :   locus eor_where, end_where, err_where;
    3115              : }
    3116              : gfc_dt;
    3117              : 
    3118              : 
    3119              : typedef struct gfc_forall_iterator
    3120              : {
    3121              :   gfc_expr *var, *start, *end, *stride;
    3122              :   gfc_loop_annot annot;
    3123              :   /* index-name shadows a variable from outer scope.  */
    3124              :   bool shadow;
    3125              :   struct gfc_forall_iterator *next;
    3126              : }
    3127              : gfc_forall_iterator;
    3128              : 
    3129              : 
    3130              : /* Linked list to store associations in an ASSOCIATE statement.  */
    3131              : 
    3132              : typedef struct gfc_association_list
    3133              : {
    3134              :   struct gfc_association_list *next;
    3135              : 
    3136              :   /* Whether this is association to a variable that can be changed; otherwise,
    3137              :      it's association to an expression and the name may not be used as
    3138              :      lvalue.  */
    3139              :   unsigned variable:1;
    3140              : 
    3141              :   /* True if this struct is currently only linked to from a gfc_symbol rather
    3142              :      than as part of a real list in gfc_code->ext.block.assoc.  This may
    3143              :      happen for SELECT TYPE temporaries and must be considered
    3144              :      for memory handling.  */
    3145              :   unsigned dangling:1;
    3146              : 
    3147              :   char name[GFC_MAX_SYMBOL_LEN + 1];
    3148              :   gfc_symtree *st; /* Symtree corresponding to name.  */
    3149              :   locus where;
    3150              : 
    3151              :   gfc_expr *target;
    3152              : 
    3153              :   gfc_array_ref *ar;
    3154              : 
    3155              :   /* Used for inferring the derived type of an associate name, whose selector
    3156              :      is a sibling derived type function that has not yet been parsed.  */
    3157              :   gfc_symbol *derived_types;
    3158              :   unsigned inferred_type:1;
    3159              : }
    3160              : gfc_association_list;
    3161              : #define gfc_get_association_list() XCNEW (gfc_association_list)
    3162              : 
    3163              : 
    3164              : /* Executable statements that fill gfc_code structures.  */
    3165              : enum gfc_exec_op
    3166              : {
    3167              :   EXEC_NOP = 1, EXEC_END_NESTED_BLOCK, EXEC_END_BLOCK, EXEC_ASSIGN,
    3168              :   EXEC_LABEL_ASSIGN, EXEC_POINTER_ASSIGN, EXEC_CRITICAL, EXEC_ERROR_STOP,
    3169              :   EXEC_GOTO, EXEC_CALL, EXEC_COMPCALL, EXEC_ASSIGN_CALL, EXEC_RETURN,
    3170              :   EXEC_ENTRY, EXEC_PAUSE, EXEC_STOP, EXEC_CONTINUE, EXEC_INIT_ASSIGN,
    3171              :   EXEC_IF, EXEC_ARITHMETIC_IF, EXEC_DO, EXEC_DO_CONCURRENT, EXEC_DO_WHILE,
    3172              :   EXEC_SELECT, EXEC_BLOCK, EXEC_FORALL, EXEC_WHERE, EXEC_CYCLE, EXEC_EXIT,
    3173              :   EXEC_CALL_PPC, EXEC_ALLOCATE, EXEC_DEALLOCATE, EXEC_END_PROCEDURE,
    3174              :   EXEC_SELECT_TYPE, EXEC_SELECT_RANK, EXEC_SYNC_ALL, EXEC_SYNC_MEMORY,
    3175              :   EXEC_SYNC_IMAGES, EXEC_OPEN, EXEC_CLOSE, EXEC_WAIT,
    3176              :   EXEC_READ, EXEC_WRITE, EXEC_IOLENGTH, EXEC_TRANSFER, EXEC_DT_END,
    3177              :   EXEC_BACKSPACE, EXEC_ENDFILE, EXEC_INQUIRE, EXEC_REWIND, EXEC_FLUSH,
    3178              :   EXEC_FORM_TEAM, EXEC_CHANGE_TEAM, EXEC_END_TEAM, EXEC_SYNC_TEAM,
    3179              :   EXEC_LOCK, EXEC_UNLOCK, EXEC_EVENT_POST, EXEC_EVENT_WAIT, EXEC_FAIL_IMAGE,
    3180              :   EXEC_OACC_KERNELS_LOOP, EXEC_OACC_PARALLEL_LOOP, EXEC_OACC_SERIAL_LOOP,
    3181              :   EXEC_OACC_ROUTINE, EXEC_OACC_PARALLEL, EXEC_OACC_KERNELS, EXEC_OACC_SERIAL,
    3182              :   EXEC_OACC_DATA, EXEC_OACC_HOST_DATA, EXEC_OACC_LOOP, EXEC_OACC_UPDATE,
    3183              :   EXEC_OACC_WAIT, EXEC_OACC_CACHE, EXEC_OACC_ENTER_DATA, EXEC_OACC_EXIT_DATA,
    3184              :   EXEC_OACC_ATOMIC, EXEC_OACC_DECLARE,
    3185              :   EXEC_OMP_CRITICAL, EXEC_OMP_FIRST_OPENMP_EXEC = EXEC_OMP_CRITICAL,
    3186              :   EXEC_OMP_DO, EXEC_OMP_FLUSH, EXEC_OMP_MASTER,
    3187              :   EXEC_OMP_ORDERED, EXEC_OMP_PARALLEL, EXEC_OMP_PARALLEL_DO,
    3188              :   EXEC_OMP_PARALLEL_SECTIONS, EXEC_OMP_PARALLEL_WORKSHARE,
    3189              :   EXEC_OMP_SECTIONS, EXEC_OMP_SINGLE, EXEC_OMP_WORKSHARE,
    3190              :   EXEC_OMP_ASSUME, EXEC_OMP_ATOMIC, EXEC_OMP_BARRIER, EXEC_OMP_END_NOWAIT,
    3191              :   EXEC_OMP_END_SINGLE, EXEC_OMP_TASK, EXEC_OMP_TASKWAIT,
    3192              :   EXEC_OMP_TASKYIELD, EXEC_OMP_CANCEL, EXEC_OMP_CANCELLATION_POINT,
    3193              :   EXEC_OMP_TASKGROUP, EXEC_OMP_SIMD, EXEC_OMP_DO_SIMD,
    3194              :   EXEC_OMP_PARALLEL_DO_SIMD, EXEC_OMP_TARGET, EXEC_OMP_TARGET_DATA,
    3195              :   EXEC_OMP_TEAMS, EXEC_OMP_DISTRIBUTE, EXEC_OMP_DISTRIBUTE_SIMD,
    3196              :   EXEC_OMP_DISTRIBUTE_PARALLEL_DO, EXEC_OMP_DISTRIBUTE_PARALLEL_DO_SIMD,
    3197              :   EXEC_OMP_TARGET_TEAMS, EXEC_OMP_TEAMS_DISTRIBUTE,
    3198              :   EXEC_OMP_TEAMS_DISTRIBUTE_SIMD, EXEC_OMP_TARGET_TEAMS_DISTRIBUTE,
    3199              :   EXEC_OMP_TARGET_TEAMS_DISTRIBUTE_SIMD,
    3200              :   EXEC_OMP_TEAMS_DISTRIBUTE_PARALLEL_DO,
    3201              :   EXEC_OMP_TARGET_TEAMS_DISTRIBUTE_PARALLEL_DO,
    3202              :   EXEC_OMP_TEAMS_DISTRIBUTE_PARALLEL_DO_SIMD,
    3203              :   EXEC_OMP_TARGET_TEAMS_DISTRIBUTE_PARALLEL_DO_SIMD,
    3204              :   EXEC_OMP_TARGET_UPDATE, EXEC_OMP_END_CRITICAL,
    3205              :   EXEC_OMP_TARGET_ENTER_DATA, EXEC_OMP_TARGET_EXIT_DATA,
    3206              :   EXEC_OMP_TARGET_PARALLEL, EXEC_OMP_TARGET_PARALLEL_DO,
    3207              :   EXEC_OMP_TARGET_PARALLEL_DO_SIMD, EXEC_OMP_TARGET_SIMD,
    3208              :   EXEC_OMP_TASKLOOP, EXEC_OMP_TASKLOOP_SIMD, EXEC_OMP_SCAN, EXEC_OMP_DEPOBJ,
    3209              :   EXEC_OMP_PARALLEL_MASTER, EXEC_OMP_PARALLEL_MASTER_TASKLOOP,
    3210              :   EXEC_OMP_PARALLEL_MASTER_TASKLOOP_SIMD, EXEC_OMP_MASTER_TASKLOOP,
    3211              :   EXEC_OMP_MASTER_TASKLOOP_SIMD, EXEC_OMP_LOOP, EXEC_OMP_PARALLEL_LOOP,
    3212              :   EXEC_OMP_TEAMS_LOOP, EXEC_OMP_TARGET_PARALLEL_LOOP,
    3213              :   EXEC_OMP_TARGET_TEAMS_LOOP, EXEC_OMP_MASKED, EXEC_OMP_PARALLEL_MASKED,
    3214              :   EXEC_OMP_PARALLEL_MASKED_TASKLOOP, EXEC_OMP_PARALLEL_MASKED_TASKLOOP_SIMD,
    3215              :   EXEC_OMP_MASKED_TASKLOOP, EXEC_OMP_MASKED_TASKLOOP_SIMD, EXEC_OMP_SCOPE,
    3216              :   EXEC_OMP_UNROLL, EXEC_OMP_TILE, EXEC_OMP_INTEROP, EXEC_OMP_METADIRECTIVE,
    3217              :   EXEC_OMP_ERROR, EXEC_OMP_ALLOCATE, EXEC_OMP_ALLOCATORS, EXEC_OMP_DISPATCH,
    3218              :   EXEC_OMP_LAST_OPENMP_EXEC = EXEC_OMP_DISPATCH
    3219              : };
    3220              : 
    3221              : /* Enum Definition for locality types.  */
    3222              : enum locality_type
    3223              : {
    3224              :   LOCALITY_LOCAL = 0,
    3225              :   LOCALITY_LOCAL_INIT,
    3226              :   LOCALITY_SHARED,
    3227              :   LOCALITY_REDUCE,
    3228              :   LOCALITY_NUM
    3229              : };
    3230              : 
    3231              : struct sync_stat
    3232              : {
    3233              :   gfc_expr *stat, *errmsg;
    3234              : };
    3235              : 
    3236              : typedef struct gfc_code
    3237              : {
    3238              :   gfc_exec_op op;
    3239              : 
    3240              :   struct gfc_code *block, *next;
    3241              :   locus loc;
    3242              : 
    3243              :   gfc_st_label *here, *label1, *label2, *label3;
    3244              :   gfc_symtree *symtree;
    3245              :   gfc_expr *expr1, *expr2, *expr3, *expr4;
    3246              :   /* A name isn't sufficient to identify a subroutine, we need the actual
    3247              :      symbol for the interface definition.
    3248              :   const char *sub_name;  */
    3249              :   gfc_symbol *resolved_sym;
    3250              :   gfc_intrinsic_sym *resolved_isym;
    3251              : 
    3252              :   union
    3253              :   {
    3254              :     gfc_actual_arglist *actual;
    3255              :     gfc_iterator *iterator;
    3256              :     gfc_open *open;
    3257              :     gfc_close *close;
    3258              :     gfc_filepos *filepos;
    3259              :     gfc_inquire *inquire;
    3260              :     gfc_wait *wait;
    3261              :     gfc_dt *dt;
    3262              :     struct gfc_code *which_construct;
    3263              :     gfc_entry_list *entry;
    3264              :     gfc_oacc_declare *oacc_declare;
    3265              :     gfc_omp_clauses *omp_clauses;
    3266              :     const char *omp_name;
    3267              :     gfc_omp_namelist *omp_namelist;
    3268              :     gfc_omp_variant *omp_variants;
    3269              :     bool omp_bool;
    3270              :     int stop_code;
    3271              :     struct sync_stat sync_stat;
    3272              : 
    3273              :     struct
    3274              :     {
    3275              :       gfc_typespec ts;
    3276              :       gfc_alloc *list;
    3277              :       /* Take the array specification from expr3 to allocate arrays
    3278              :          without an explicit array specification.  */
    3279              :       unsigned arr_spec_from_expr3:1;
    3280              :       /* expr3 is not explicit  */
    3281              :       unsigned expr3_not_explicit:1;
    3282              :       struct sync_stat sync_stat;
    3283              :     }
    3284              :     alloc;
    3285              : 
    3286              :     struct
    3287              :     {
    3288              :       gfc_namespace *ns;
    3289              :       gfc_association_list *assoc;
    3290              :       gfc_case *case_list;
    3291              :       struct sync_stat sync_stat;
    3292              :     }
    3293              :     block;
    3294              : 
    3295              :     struct
    3296              :     {
    3297              :       gfc_forall_iterator *forall_iterator;
    3298              :       gfc_expr_list *locality[LOCALITY_NUM];
    3299              :       bool default_none;
    3300              :     }
    3301              :     concur;
    3302              :   }
    3303              :   ext;          /* Points to additional structures required by statement */
    3304              : 
    3305              :   /* Cycle and break labels in constructs.  */
    3306              :   tree cycle_label;
    3307              :   tree exit_label;
    3308              : }
    3309              : gfc_code;
    3310              : 
    3311              : 
    3312              : /* Storage for DATA statements.  */
    3313              : typedef struct gfc_data_variable
    3314              : {
    3315              :   gfc_expr *expr;
    3316              :   gfc_iterator iter;
    3317              :   struct gfc_data_variable *list, *next;
    3318              : }
    3319              : gfc_data_variable;
    3320              : 
    3321              : 
    3322              : typedef struct gfc_data_value
    3323              : {
    3324              :   mpz_t repeat;
    3325              :   gfc_expr *expr;
    3326              :   struct gfc_data_value *next;
    3327              : }
    3328              : gfc_data_value;
    3329              : 
    3330              : 
    3331              : typedef struct gfc_data
    3332              : {
    3333              :   gfc_data_variable *var;
    3334              :   gfc_data_value *value;
    3335              :   locus where;
    3336              : 
    3337              :   struct gfc_data *next;
    3338              : }
    3339              : gfc_data;
    3340              : 
    3341              : 
    3342              : /* Structure for holding compile options */
    3343              : typedef struct
    3344              : {
    3345              :   char *module_dir;
    3346              :   gfc_source_form source_form;
    3347              :   int max_continue_fixed;
    3348              :   int max_continue_free;
    3349              :   int max_identifier_length;
    3350              : 
    3351              :   int max_errors;
    3352              : 
    3353              :   int flag_preprocessed;
    3354              :   int flag_d_lines;
    3355              :   int flag_init_integer;
    3356              :   long flag_init_integer_value;
    3357              :   int flag_init_logical;
    3358              :   int flag_init_character;
    3359              :   char flag_init_character_value;
    3360              :   bool disable_omp_is_initial_device:1;
    3361              :   bool disable_omp_get_initial_device:1;
    3362              :   bool disable_omp_get_num_devices:1;
    3363              :   bool disable_acc_on_device:1;
    3364              : 
    3365              :   int fpe;
    3366              :   int fpe_summary;
    3367              :   int rtcheck;
    3368              : 
    3369              :   int warn_std;
    3370              :   int allow_std;
    3371              : }
    3372              : gfc_option_t;
    3373              : 
    3374              : extern gfc_option_t gfc_option;
    3375              : 
    3376              : /* Constructor nodes for array and structure constructors.  */
    3377              : typedef struct gfc_constructor
    3378              : {
    3379              :   gfc_constructor_base base;
    3380              :   mpz_t offset;               /* Offset within a constructor, used as
    3381              :                                  key within base. */
    3382              : 
    3383              :   gfc_expr *expr;
    3384              :   gfc_iterator *iterator;
    3385              :   locus where;
    3386              : 
    3387              :   union
    3388              :   {
    3389              :      gfc_component *component; /* Record the component being initialized.  */
    3390              :   }
    3391              :   n;
    3392              :   mpz_t repeat; /* Record the repeat number of initial values in data
    3393              :                   statement like "data a/5*10/".  */
    3394              : }
    3395              : gfc_constructor;
    3396              : 
    3397              : 
    3398              : typedef struct iterator_stack
    3399              : {
    3400              :   gfc_symtree *variable;
    3401              :   mpz_t value;
    3402              :   struct iterator_stack *prev;
    3403              : }
    3404              : iterator_stack;
    3405              : extern iterator_stack *iter_stack;
    3406              : 
    3407              : 
    3408              : /* Used for (possibly nested) SELECT TYPE statements.  */
    3409              : typedef struct gfc_select_type_stack
    3410              : {
    3411              :   gfc_symbol *selector;                 /* Current selector variable.  */
    3412              :   gfc_symtree *tmp;                     /* Current temporary variable.  */
    3413              :   struct gfc_select_type_stack *prev;   /* Previous element on stack.  */
    3414              : }
    3415              : gfc_select_type_stack;
    3416              : extern gfc_select_type_stack *select_type_stack;
    3417              : #define gfc_get_select_type_stack() XCNEW (gfc_select_type_stack)
    3418              : 
    3419              : 
    3420              : /* Node in the linked list used for storing finalizer procedures.  */
    3421              : 
    3422              : typedef struct gfc_finalizer
    3423              : {
    3424              :   struct gfc_finalizer* next;
    3425              :   locus where; /* Where the FINAL declaration occurred.  */
    3426              : 
    3427              :   /* Up to resolution, we want the gfc_symbol, there we lookup the corresponding
    3428              :      symtree and later need only that.  This way, we can access and call the
    3429              :      finalizers from every context as they should be "always accessible".  I
    3430              :      don't make this a union because we need the information whether proc_sym is
    3431              :      still referenced or not for dereferencing it on deleting a gfc_finalizer
    3432              :      structure.  */
    3433              :   gfc_symbol*  proc_sym;
    3434              :   gfc_symtree* proc_tree;
    3435              : }
    3436              : gfc_finalizer;
    3437              : #define gfc_get_finalizer() XCNEW (gfc_finalizer)
    3438              : 
    3439              : 
    3440              : /************************ Function prototypes *************************/
    3441              : 
    3442              : 
    3443              : /* Returns true if the type specified in TS is a character type whose length
    3444              :    is the constant one.  Otherwise returns false.  */
    3445              : 
    3446              : inline bool
    3447        22216 : gfc_length_one_character_type_p (gfc_typespec *ts)
    3448              : {
    3449        22216 :   return ts->type == BT_CHARACTER
    3450          715 :          && ts->u.cl
    3451          715 :          && ts->u.cl->length
    3452          714 :          && ts->u.cl->length->expr_type == EXPR_CONSTANT
    3453          714 :          && ts->u.cl->length->ts.type == BT_INTEGER
    3454        22930 :          && mpz_cmp_ui (ts->u.cl->length->value.integer, 1) == 0;
    3455              : }
    3456              : 
    3457              : /* decl.cc */
    3458              : bool gfc_in_match_data (void);
    3459              : match gfc_match_char_spec (gfc_typespec *);
    3460              : extern int directive_unroll;
    3461              : extern bool directive_ivdep;
    3462              : extern bool directive_vector;
    3463              : extern bool directive_novector;
    3464              : 
    3465              : /* SIMD clause enum.  */
    3466              : enum gfc_simd_clause
    3467              : {
    3468              :   SIMD_NONE = (1 << 0),
    3469              :   SIMD_INBRANCH = (1 << 1),
    3470              :   SIMD_NOTINBRANCH = (1 << 2)
    3471              : };
    3472              : 
    3473              : /* Tuple for parsing of vectorized built-ins.  */
    3474              : struct gfc_vect_builtin_tuple
    3475              : {
    3476              :   gfc_vect_builtin_tuple (const char *n, gfc_simd_clause t)
    3477              :     : name (n), simd_type (t) {}
    3478              : 
    3479              :   const char *name;
    3480              :   gfc_simd_clause simd_type;
    3481              : };
    3482              : 
    3483              : /* Map of middle-end built-ins that should be vectorized.  */
    3484              : extern hash_map<nofree_string_hash, int> *gfc_vectorized_builtins;
    3485              : 
    3486              : /* Handling Parameterized Derived Types  */
    3487              : bool gfc_insert_parameter_exprs (gfc_expr *, gfc_actual_arglist *);
    3488              : void gfc_correct_parm_expr (gfc_symbol *, gfc_expr **);
    3489              : match gfc_get_pdt_instance (gfc_actual_arglist *, gfc_symbol **,
    3490              :                             gfc_actual_arglist **);
    3491              : 
    3492              : 
    3493              : /* Given a symbol, test whether it is a module procedure in a submodule */
    3494              : #define gfc_submodule_procedure(attr)                                \
    3495              :   (gfc_state_stack->previous && gfc_state_stack->previous->previous  \
    3496              :    && gfc_state_stack->previous->previous->state == COMP_SUBMODULE   \
    3497              :    && attr->module_procedure)
    3498              : 
    3499              : /* scanner.cc */
    3500              : void gfc_scanner_done_1 (void);
    3501              : void gfc_scanner_init_1 (void);
    3502              : 
    3503              : void gfc_add_include_path (const char *, bool, bool, bool, bool);
    3504              : void gfc_add_intrinsic_modules_path (const char *);
    3505              : void gfc_release_include_path (void);
    3506              : void gfc_check_include_dirs (bool);
    3507              : FILE *gfc_open_included_file (const char *, bool, bool);
    3508              : 
    3509              : bool gfc_at_end (void);
    3510              : bool gfc_at_eof (void);
    3511              : bool gfc_at_bol (void);
    3512              : bool gfc_at_eol (void);
    3513              : void gfc_advance_line (void);
    3514              : bool gfc_define_undef_line (void);
    3515              : 
    3516              : bool gfc_wide_is_printable (gfc_char_t);
    3517              : bool gfc_wide_is_digit (gfc_char_t);
    3518              : bool gfc_wide_fits_in_byte (gfc_char_t);
    3519              : gfc_char_t gfc_wide_tolower (gfc_char_t);
    3520              : gfc_char_t gfc_wide_toupper (gfc_char_t);
    3521              : size_t gfc_wide_strlen (const gfc_char_t *);
    3522              : int gfc_wide_strncasecmp (const gfc_char_t *, const char *, size_t);
    3523              : gfc_char_t *gfc_wide_memset (gfc_char_t *, gfc_char_t, size_t);
    3524              : char *gfc_widechar_to_char (const gfc_char_t *, int);
    3525              : gfc_char_t *gfc_char_to_widechar (const char *);
    3526              : 
    3527              : #define gfc_get_wide_string(n) XCNEWVEC (gfc_char_t, n)
    3528              : 
    3529              : void gfc_skip_comments (void);
    3530              : gfc_char_t gfc_next_char_literal (gfc_instring);
    3531              : gfc_char_t gfc_next_char (void);
    3532              : char gfc_next_ascii_char (void);
    3533              : gfc_char_t gfc_peek_char (void);
    3534              : char gfc_peek_ascii_char (void);
    3535              : void gfc_error_recovery (void);
    3536              : void gfc_gobble_whitespace (void);
    3537              : void gfc_new_file (void);
    3538              : const char * gfc_read_orig_filename (const char *, const char **);
    3539              : 
    3540              : extern gfc_source_form gfc_current_form;
    3541              : extern const char *gfc_source_file;
    3542              : extern locus gfc_current_locus;
    3543              : 
    3544              : void gfc_start_source_files (void);
    3545              : void gfc_end_source_files (void);
    3546              : 
    3547              : /* misc.cc */
    3548              : void gfc_clear_ts (gfc_typespec *);
    3549              : FILE *gfc_open_file (const char *);
    3550              : const char *gfc_basic_typename (bt);
    3551              : const char *gfc_dummy_typename (gfc_typespec *);
    3552              : const char *gfc_typename (gfc_typespec *, bool for_hash = false);
    3553              : const char *gfc_typename (gfc_expr *);
    3554              : const char *gfc_op2string (gfc_intrinsic_op);
    3555              : const char *gfc_code2string (const mstring *, int);
    3556              : int gfc_string2code (const mstring *, const char *);
    3557              : const char *gfc_intent_string (sym_intent);
    3558              : 
    3559              : void gfc_init_1 (void);
    3560              : void gfc_init_2 (void);
    3561              : void gfc_done_1 (void);
    3562              : void gfc_done_2 (void);
    3563              : 
    3564              : int get_c_kind (const char *, CInteropKind_t *);
    3565              : 
    3566              : const char * gfc_var_name_for_select_type_temp (gfc_expr *);
    3567              : 
    3568              : const char *gfc_closest_fuzzy_match (const char *, char **);
    3569              : inline void
    3570          601 : vec_push (char **&optr, size_t &osz, const char *elt)
    3571              : {
    3572              :   /* {auto,}vec.safe_push () replacement.  Don't ask..  */
    3573              :   // if (strlen (elt) < 4) return; premature optimization: eliminated by cutoff
    3574          601 :   optr = XRESIZEVEC (char *, optr, osz + 2);
    3575          601 :   optr[osz] =
    3576              : #ifdef __cplusplus
    3577              :     const_cast<char *> (elt);
    3578              : #else
    3579              :     (__extension__ (union {const char *_q; const char *_nq;})(elt))._nq;
    3580              : #endif
    3581          601 :   optr[++osz] = NULL;
    3582          601 : }
    3583              : 
    3584              : HOST_WIDE_INT gfc_mpz_get_hwi (mpz_t);
    3585              : void gfc_mpz_set_hwi (mpz_t, const HOST_WIDE_INT);
    3586              : 
    3587              : /* options.cc */
    3588              : unsigned int gfc_option_lang_mask (void);
    3589              : void gfc_init_options_struct (struct gcc_options *);
    3590              : void gfc_init_options (unsigned int,
    3591              :                        struct cl_decoded_option *);
    3592              : bool gfc_handle_option (size_t, const char *, HOST_WIDE_INT, int, location_t,
    3593              :                         const struct cl_option_handlers *);
    3594              : bool gfc_post_options (const char **);
    3595              : char *gfc_get_option_string (void);
    3596              : 
    3597              : /* f95-lang.cc */
    3598              : void gfc_maybe_initialize_eh (void);
    3599              : 
    3600              : /* iresolve.cc */
    3601              : const char * gfc_get_string (const char *, ...) ATTRIBUTE_PRINTF_1;
    3602              : bool gfc_find_sym_in_expr (gfc_symbol *, gfc_expr *);
    3603              : 
    3604              : /* error.cc */
    3605              : locus gfc_get_location_range (locus *, unsigned, locus *, unsigned, locus *);
    3606              : location_t gfc_get_location_with_offset (locus *, unsigned);
    3607              : inline location_t
    3608      3774084 : gfc_get_location (locus *loc)
    3609              : {
    3610      3774013 :   return gfc_get_location_with_offset (loc, 0);
    3611              : }
    3612              : 
    3613              : void gfc_error_init_1 (void);
    3614              : void gfc_diagnostics_init (void);
    3615              : void gfc_diagnostics_finish (void);
    3616              : void gfc_buffer_error (bool);
    3617              : 
    3618              : const char *gfc_print_wide_char (gfc_char_t);
    3619              : 
    3620              : bool gfc_warning (int opt, const char *, ...) ATTRIBUTE_GCC_GFC(2,3);
    3621              : bool gfc_warning_now (int opt, const char *, ...) ATTRIBUTE_GCC_GFC(2,3);
    3622              : bool gfc_warning_internal (int opt, const char *, ...) ATTRIBUTE_GCC_GFC(2,3);
    3623              : bool gfc_warning_now_at (location_t loc, int opt, const char *gmsgid, ...)
    3624              :   ATTRIBUTE_GCC_GFC(3,4);
    3625              : 
    3626              : void gfc_clear_warning (void);
    3627              : void gfc_warning_check (void);
    3628              : 
    3629              : void gfc_error_opt (int opt, const char *, ...) ATTRIBUTE_GCC_GFC(2,3);
    3630              : void gfc_error (const char *, ...) ATTRIBUTE_GCC_GFC(1,2);
    3631              : void gfc_error_now (const char *, ...) ATTRIBUTE_GCC_GFC(1,2);
    3632              : void gfc_fatal_error (const char *, ...) ATTRIBUTE_NORETURN ATTRIBUTE_GCC_GFC(1,2);
    3633              : void gfc_internal_error (const char *, ...) ATTRIBUTE_NORETURN ATTRIBUTE_GCC_GFC(1,2);
    3634              : void gfc_clear_error (void);
    3635              : bool gfc_error_check (void);
    3636              : bool gfc_error_flag_test (void);
    3637              : bool gfc_buffered_p (void);
    3638              : 
    3639              : notification gfc_notification_std (int);
    3640              : bool gfc_notify_std (int, const char *, ...) ATTRIBUTE_GCC_GFC(2,3);
    3641              : 
    3642              : /* A general purpose syntax error.  */
    3643              : #define gfc_syntax_error(ST)    \
    3644              :   gfc_error ("Syntax error in %s statement at %C", gfc_ascii_statement (ST));
    3645              : 
    3646              : #include "diagnostics/buffering.h"  /* For diagnostics::buffer.  */
    3647      8506373 : struct gfc_error_buffer
    3648              : {
    3649              :   bool flag;
    3650              :   diagnostics::buffer buffer;
    3651              : 
    3652              :   gfc_error_buffer();
    3653              : };
    3654              : 
    3655              : void gfc_push_error (gfc_error_buffer *);
    3656              : void gfc_pop_error (gfc_error_buffer *);
    3657              : void gfc_free_error (gfc_error_buffer *);
    3658              : 
    3659              : void gfc_get_errors (int *, int *);
    3660              : void gfc_errors_to_warnings (bool);
    3661              : 
    3662              : /* arith.cc */
    3663              : void gfc_arith_init_1 (void);
    3664              : void gfc_arith_done_1 (void);
    3665              : arith gfc_check_integer_range (mpz_t p, int kind);
    3666              : arith gfc_check_unsigned_range (mpz_t p, int kind);
    3667              : bool gfc_check_character_range (gfc_char_t, int);
    3668              : const char *gfc_arith_error (arith);
    3669              : void gfc_reduce_unsigned (gfc_expr *e);
    3670              : 
    3671              : extern bool gfc_seen_div0;
    3672              : 
    3673              : /* trans-types.cc */
    3674              : int gfc_validate_kind (bt, int, bool);
    3675              : int gfc_get_int_kind_from_width_isofortranenv (int size);
    3676              : int gfc_get_uint_kind_from_width_isofortranenv (int size);
    3677              : int gfc_get_real_kind_from_width_isofortranenv (int size);
    3678              : tree gfc_get_union_type (gfc_symbol *);
    3679              : tree gfc_get_derived_type (gfc_symbol * derived, int codimen = 0);
    3680              : extern int gfc_index_integer_kind;
    3681              : extern int gfc_default_integer_kind;
    3682              : extern int gfc_default_unsigned_kind;
    3683              : extern int gfc_max_integer_kind;
    3684              : extern int gfc_default_real_kind;
    3685              : extern int gfc_default_double_kind;
    3686              : extern int gfc_default_character_kind;
    3687              : extern int gfc_default_logical_kind;
    3688              : extern int gfc_default_complex_kind;
    3689              : extern int gfc_c_int_kind;
    3690              : extern int gfc_c_uint_kind;
    3691              : extern int gfc_c_intptr_kind;
    3692              : extern int gfc_atomic_int_kind;
    3693              : extern int gfc_atomic_logical_kind;
    3694              : extern int gfc_intio_kind;
    3695              : extern int gfc_charlen_int_kind;
    3696              : extern int gfc_size_kind;
    3697              : extern int gfc_numeric_storage_size;
    3698              : extern int gfc_character_storage_size;
    3699              : 
    3700              : #define gfc_logical_4_kind 4
    3701              : #define gfc_integer_4_kind 4
    3702              : #define gfc_real_4_kind 4
    3703              : 
    3704              : #define gfc_integer_8_kind 8
    3705              : 
    3706              : /* symbol.cc */
    3707              : void gfc_clear_new_implicit (void);
    3708              : bool gfc_add_new_implicit_range (int, int);
    3709              : bool gfc_merge_new_implicit (gfc_typespec *);
    3710              : void gfc_set_implicit_none (bool, bool, locus *);
    3711              : void gfc_check_function_type (gfc_namespace *);
    3712              : bool gfc_is_intrinsic_typename (const char *);
    3713              : bool gfc_check_conflict (symbol_attribute *, const char *, locus *);
    3714              : 
    3715              : gfc_typespec *gfc_get_default_type (const char *, gfc_namespace *);
    3716              : bool gfc_set_default_type (gfc_symbol *, int, gfc_namespace *);
    3717              : 
    3718              : void gfc_set_sym_referenced (gfc_symbol *);
    3719              : 
    3720              : bool gfc_add_attribute (symbol_attribute *, locus *);
    3721              : bool gfc_add_ext_attribute (symbol_attribute *, ext_attr_id_t, locus *);
    3722              : bool gfc_add_allocatable (symbol_attribute *, locus *);
    3723              : bool gfc_add_codimension (symbol_attribute *, const char *, locus *);
    3724              : bool gfc_add_contiguous (symbol_attribute *, const char *, locus *);
    3725              : bool gfc_add_dimension (symbol_attribute *, const char *, locus *);
    3726              : bool gfc_add_external (symbol_attribute *, locus *);
    3727              : bool gfc_add_intrinsic (symbol_attribute *, locus *);
    3728              : bool gfc_add_optional (symbol_attribute *, locus *);
    3729              : bool gfc_add_kind (symbol_attribute *, locus *);
    3730              : bool gfc_add_len (symbol_attribute *, locus *);
    3731              : bool gfc_add_pointer (symbol_attribute *, locus *);
    3732              : bool gfc_add_cray_pointer (symbol_attribute *, locus *);
    3733              : bool gfc_add_cray_pointee (symbol_attribute *, locus *);
    3734              : match gfc_mod_pointee_as (gfc_array_spec *);
    3735              : bool gfc_add_protected (symbol_attribute *, const char *, locus *);
    3736              : bool gfc_add_result (symbol_attribute *, const char *, locus *);
    3737              : bool gfc_add_automatic (symbol_attribute *, const char *, locus *);
    3738              : bool gfc_add_save (symbol_attribute *, save_state, const char *, locus *);
    3739              : bool gfc_add_threadprivate (symbol_attribute *, const char *, locus *);
    3740              : bool gfc_add_omp_declare_target (symbol_attribute *, const char *, locus *);
    3741              : bool gfc_add_omp_declare_target_link (symbol_attribute *, const char *,
    3742              :                                       locus *);
    3743              : bool gfc_add_omp_declare_target_local (symbol_attribute *, const char *,
    3744              :                                        locus *);
    3745              : bool gfc_add_omp_groupprivate (symbol_attribute *, const char *, locus *);
    3746              : bool gfc_add_target (symbol_attribute *, locus *);
    3747              : bool gfc_add_dummy (symbol_attribute *, const char *, locus *);
    3748              : bool gfc_add_generic (symbol_attribute *, const char *, locus *);
    3749              : bool gfc_add_in_common (symbol_attribute *, const char *, locus *);
    3750              : bool gfc_add_in_equivalence (symbol_attribute *, const char *, locus *);
    3751              : bool gfc_add_data (symbol_attribute *, const char *, locus *);
    3752              : bool gfc_add_in_namelist (symbol_attribute *, const char *, locus *);
    3753              : bool gfc_add_sequence (symbol_attribute *, const char *, locus *);
    3754              : bool gfc_add_elemental (symbol_attribute *, locus *);
    3755              : bool gfc_add_pure (symbol_attribute *, locus *);
    3756              : bool gfc_add_recursive (symbol_attribute *, locus *);
    3757              : bool gfc_add_function (symbol_attribute *, const char *, locus *);
    3758              : bool gfc_add_subroutine (symbol_attribute *, const char *, locus *);
    3759              : bool gfc_add_volatile (symbol_attribute *, const char *, locus *);
    3760              : bool gfc_add_asynchronous (symbol_attribute *, const char *, locus *);
    3761              : bool gfc_add_proc (symbol_attribute *attr, const char *name, locus *where);
    3762              : bool gfc_add_abstract (symbol_attribute* attr, locus* where);
    3763              : 
    3764              : bool gfc_add_access (symbol_attribute *, gfc_access, const char *, locus *);
    3765              : bool gfc_add_is_bind_c (symbol_attribute *, const char *, locus *, int);
    3766              : bool gfc_add_extension (symbol_attribute *, locus *);
    3767              : bool gfc_add_value (symbol_attribute *, const char *, locus *);
    3768              : bool gfc_add_flavor (symbol_attribute *, sym_flavor, const char *, locus *);
    3769              : bool gfc_add_entry (symbol_attribute *, const char *, locus *);
    3770              : bool gfc_add_procedure (symbol_attribute *, procedure_type,
    3771              :                        const char *, locus *);
    3772              : bool gfc_add_intent (symbol_attribute *, sym_intent, locus *);
    3773              : bool gfc_add_explicit_interface (gfc_symbol *, ifsrc,
    3774              :                                 gfc_formal_arglist *, locus *);
    3775              : bool gfc_add_type (gfc_symbol *, gfc_typespec *, locus *);
    3776              : 
    3777              : void gfc_clear_attr (symbol_attribute *);
    3778              : bool gfc_missing_attr (symbol_attribute *, locus *);
    3779              : bool gfc_copy_attr (symbol_attribute *, symbol_attribute *, locus *);
    3780              : int gfc_copy_dummy_sym (gfc_symbol **, gfc_symbol *, int);
    3781              : bool gfc_add_component (gfc_symbol *, const char *, gfc_component **);
    3782              : gfc_symbol *gfc_use_derived (gfc_symbol *);
    3783              : gfc_component *gfc_find_component (gfc_symbol *, const char *, bool, bool,
    3784              :                                    gfc_ref **);
    3785              : int gfc_find_derived_types (gfc_symbol *, gfc_namespace *, const char *,
    3786              :                             bool stash = false);
    3787              : 
    3788              : gfc_st_label *gfc_get_st_label (int);
    3789              : void gfc_free_st_label (gfc_st_label *);
    3790              : void gfc_define_st_label (gfc_st_label *, gfc_sl_type, locus *);
    3791              : bool gfc_reference_st_label (gfc_st_label *, gfc_sl_type);
    3792              : gfc_st_label *gfc_rebind_label (gfc_st_label *, int);
    3793              : 
    3794              : gfc_namespace *gfc_get_namespace (gfc_namespace *, int);
    3795              : gfc_symtree *gfc_new_symtree (gfc_symtree **, const char *);
    3796              : gfc_symtree *gfc_find_symtree (gfc_symtree *, const char *);
    3797              : gfc_symtree *gfc_get_unique_symtree (gfc_namespace *);
    3798              : gfc_user_op *gfc_get_uop (const char *);
    3799              : gfc_user_op *gfc_find_uop (const char *, gfc_namespace *);
    3800              : void gfc_free_symbol (gfc_symbol *&);
    3801              : bool gfc_release_symbol (gfc_symbol *&);
    3802              : gfc_symbol *gfc_new_symbol (const char *, gfc_namespace *, locus * = NULL);
    3803              : gfc_symtree* gfc_find_symtree_in_proc (const char *, gfc_namespace *);
    3804              : int gfc_find_symbol (const char *, gfc_namespace *, int, gfc_symbol **);
    3805              : bool gfc_find_sym_tree (const char *, gfc_namespace *, int, gfc_symtree **);
    3806              : int gfc_get_symbol (const char *, gfc_namespace *, gfc_symbol **,
    3807              :                     locus * = NULL);
    3808              : bool gfc_verify_c_interop (gfc_typespec *);
    3809              : bool gfc_verify_c_interop_param (gfc_symbol *);
    3810              : bool verify_bind_c_sym (gfc_symbol *, gfc_typespec *, int, gfc_common_head *);
    3811              : bool verify_bind_c_derived_type (gfc_symbol *);
    3812              : bool verify_com_block_vars_c_interop (gfc_common_head *);
    3813              : gfc_symtree *generate_isocbinding_symbol (const char *, iso_c_binding_symbol,
    3814              :                                           const char *, gfc_symtree *, bool);
    3815              : void gfc_save_symbol_data (gfc_symbol *);
    3816              : int gfc_get_sym_tree (const char *, gfc_namespace *, gfc_symtree **, bool,
    3817              :                      locus * = NULL);
    3818              : int gfc_get_ha_symbol (const char *, gfc_symbol **, locus * = NULL);
    3819              : int gfc_get_ha_sym_tree (const char *, gfc_symtree **, locus * = NULL);
    3820              : 
    3821              : void gfc_drop_last_undo_checkpoint (void);
    3822              : void gfc_restore_last_undo_checkpoint (void);
    3823              : void gfc_undo_symbols (void);
    3824              : void gfc_commit_symbols (void);
    3825              : void gfc_commit_symbol (gfc_symbol *);
    3826              : gfc_charlen *gfc_new_charlen (gfc_namespace *, gfc_charlen *);
    3827              : void gfc_free_namespace (gfc_namespace *&);
    3828              : 
    3829              : void gfc_symbol_init_2 (void);
    3830              : void gfc_symbol_done_2 (void);
    3831              : 
    3832              : void gfc_traverse_symtree (gfc_symtree *, void (*)(gfc_symtree *));
    3833              : void gfc_traverse_ns (gfc_namespace *, void (*)(gfc_symbol *));
    3834              : void gfc_traverse_user_op (gfc_namespace *, void (*)(gfc_user_op *));
    3835              : void gfc_save_all (gfc_namespace *);
    3836              : 
    3837              : void gfc_enforce_clean_symbol_state (void);
    3838              : 
    3839              : gfc_gsymbol *gfc_get_gsymbol (const char *, bool bind_c);
    3840              : gfc_gsymbol *gfc_find_gsymbol (gfc_gsymbol *, const char *);
    3841              : gfc_gsymbol *gfc_find_case_gsymbol (gfc_gsymbol *, const char *);
    3842              : void gfc_traverse_gsymbol (gfc_gsymbol *, void (*)(gfc_gsymbol *, void *), void *);
    3843              : 
    3844              : gfc_typebound_proc* gfc_get_typebound_proc (gfc_typebound_proc*);
    3845              : gfc_symbol* gfc_get_derived_super_type (gfc_symbol*);
    3846              : bool gfc_type_is_extension_of (gfc_symbol *, gfc_symbol *);
    3847              : bool gfc_pdt_is_instance_of (gfc_symbol *, gfc_symbol *);
    3848              : bool gfc_type_compatible (gfc_typespec *, gfc_typespec *);
    3849              : 
    3850              : void gfc_copy_formal_args_intr (gfc_symbol *, gfc_intrinsic_sym *,
    3851              :                                 gfc_actual_arglist *, bool copy_type = false);
    3852              : 
    3853              : void gfc_free_finalizer (gfc_finalizer *el); /* Needed in resolve.cc, too  */
    3854              : 
    3855              : bool gfc_check_symbol_typed (gfc_symbol*, gfc_namespace*, bool, locus);
    3856              : gfc_namespace* gfc_find_proc_namespace (gfc_namespace*);
    3857              : 
    3858              : bool gfc_is_associate_pointer (gfc_symbol*);
    3859              : gfc_symbol * gfc_find_dt_in_generic (gfc_symbol *);
    3860              : gfc_formal_arglist *gfc_sym_get_dummy_args (gfc_symbol *);
    3861              : 
    3862              : gfc_namespace * gfc_get_procedure_ns (gfc_symbol *);
    3863              : gfc_namespace * gfc_get_spec_ns (gfc_symbol *);
    3864              : 
    3865              : /* intrinsic.cc -- true if working in an init-expr, false otherwise.  */
    3866              : extern bool gfc_init_expr_flag;
    3867              : 
    3868              : /* Given a symbol that we have decided is intrinsic, mark it as such
    3869              :    by placing it into a special module that is otherwise impossible to
    3870              :    read or write.  */
    3871              : 
    3872              : #define gfc_intrinsic_symbol(SYM) SYM->module = gfc_get_string ("(intrinsic)")
    3873              : 
    3874              : void gfc_intrinsic_init_1 (void);
    3875              : void gfc_intrinsic_done_1 (void);
    3876              : 
    3877              : char gfc_type_letter (bt, bool logical_equals_int = false);
    3878              : int gfc_type_abi_kind (bt, int);
    3879              : inline int
    3880     15810192 : gfc_type_abi_kind (gfc_typespec *ts)
    3881              : {
    3882     15810192 :   return gfc_type_abi_kind (ts->type, ts->kind);
    3883              : }
    3884              : gfc_symbol * gfc_get_intrinsic_sub_symbol (const char *);
    3885              : gfc_symbol *gfc_get_intrinsic_function_symbol (gfc_expr *);
    3886              : gfc_symbol *gfc_find_intrinsic_symbol (gfc_expr *);
    3887              : bool gfc_convert_type (gfc_expr *, gfc_typespec *, int);
    3888              : bool gfc_convert_type_warn (gfc_expr *, gfc_typespec *, int, int,
    3889              :                             bool array = false);
    3890              : bool gfc_convert_chartype (gfc_expr *, gfc_typespec *);
    3891              : bool gfc_generic_intrinsic (const char *);
    3892              : bool gfc_specific_intrinsic (const char *);
    3893              : bool gfc_is_intrinsic (gfc_symbol*, int, locus);
    3894              : bool gfc_intrinsic_actual_ok (const char *, const bool);
    3895              : gfc_intrinsic_sym *gfc_find_function (const char *);
    3896              : gfc_intrinsic_sym *gfc_find_subroutine (const char *);
    3897              : gfc_intrinsic_sym *gfc_intrinsic_function_by_id (gfc_isym_id);
    3898              : gfc_intrinsic_sym *gfc_intrinsic_subroutine_by_id (gfc_isym_id);
    3899              : gfc_isym_id gfc_isym_id_by_intmod (intmod_id, int);
    3900              : gfc_isym_id gfc_isym_id_by_intmod_sym (gfc_symbol *);
    3901              : 
    3902              : 
    3903              : match gfc_intrinsic_func_interface (gfc_expr *, int);
    3904              : match gfc_intrinsic_sub_interface (gfc_code *, int);
    3905              : 
    3906              : void gfc_warn_intrinsic_shadow (const gfc_symbol*, bool, bool);
    3907              : bool gfc_check_intrinsic_standard (const gfc_intrinsic_sym*, const char**,
    3908              :                                       bool, locus);
    3909              : 
    3910              : /* match.cc -- FIXME */
    3911              : void gfc_free_iterator (gfc_iterator *, int);
    3912              : void gfc_free_forall_iterator (gfc_forall_iterator *);
    3913              : void gfc_free_alloc_list (gfc_alloc *);
    3914              : void gfc_free_namelist (gfc_namelist *);
    3915              : void gfc_free_omp_namelist (gfc_omp_namelist *, bool, bool, bool, bool);
    3916              : void gfc_free_equiv (gfc_equiv *);
    3917              : void gfc_free_equiv_until (gfc_equiv *, gfc_equiv *);
    3918              : void gfc_free_data (gfc_data *);
    3919              : void gfc_reject_data (gfc_namespace *);
    3920              : void gfc_free_case_list (gfc_case *);
    3921              : 
    3922              : /* matchexp.cc -- FIXME too?  */
    3923              : gfc_expr *gfc_get_parentheses (gfc_expr *);
    3924              : 
    3925              : /* openmp.cc */
    3926              : struct gfc_omp_saved_state { void *ptrs[2]; int ints[1]; };
    3927              : bool gfc_omp_requires_add_clause (gfc_omp_requires_kind, const char *,
    3928              :                                   locus *, const char *);
    3929              : void gfc_check_omp_requires (gfc_namespace *, int);
    3930              : void gfc_free_omp_clauses (gfc_omp_clauses *);
    3931              : void gfc_free_oacc_declare_clauses (struct gfc_oacc_declare *);
    3932              : void gfc_free_omp_declare_variant_list (gfc_omp_declare_variant *list);
    3933              : void gfc_free_omp_declare_simd (gfc_omp_declare_simd *);
    3934              : void gfc_free_omp_declare_simd_list (gfc_omp_declare_simd *);
    3935              : void gfc_free_omp_udr (gfc_omp_udr *);
    3936              : void gfc_free_omp_variants (gfc_omp_variant *);
    3937              : gfc_omp_udr *gfc_omp_udr_find (gfc_symtree *, gfc_typespec *);
    3938              : void gfc_resolve_omp_allocate (gfc_namespace *, gfc_omp_namelist *);
    3939              : void gfc_resolve_omp_assumptions (gfc_omp_assumptions *);
    3940              : void gfc_resolve_omp_directive (gfc_code *, gfc_namespace *);
    3941              : void gfc_resolve_do_iterator (gfc_code *, gfc_symbol *, bool);
    3942              : void gfc_resolve_omp_local_vars (gfc_namespace *);
    3943              : void gfc_resolve_omp_parallel_blocks (gfc_code *, gfc_namespace *);
    3944              : void gfc_resolve_omp_do_blocks (gfc_code *, gfc_namespace *);
    3945              : void gfc_resolve_omp_declare (gfc_namespace *);
    3946              : void gfc_resolve_omp_udrs (gfc_symtree *);
    3947              : void gfc_omp_save_and_clear_state (struct gfc_omp_saved_state *);
    3948              : void gfc_omp_restore_state (struct gfc_omp_saved_state *);
    3949              : void gfc_free_expr_list (gfc_expr_list *);
    3950              : void gfc_resolve_oacc_directive (gfc_code *, gfc_namespace *);
    3951              : void gfc_resolve_oacc_declare (gfc_namespace *);
    3952              : void gfc_resolve_oacc_blocks (gfc_code *, gfc_namespace *);
    3953              : void gfc_resolve_oacc_routines (gfc_namespace *);
    3954              : 
    3955              : /* expr.cc */
    3956              : void gfc_free_actual_arglist (gfc_actual_arglist *);
    3957              : gfc_actual_arglist *gfc_copy_actual_arglist (gfc_actual_arglist *);
    3958              : 
    3959              : bool gfc_extract_int (gfc_expr *, int *, int = 0);
    3960              : bool gfc_extract_hwi (gfc_expr *, HOST_WIDE_INT *, int = 0);
    3961              : 
    3962              : bool is_CFI_desc (gfc_symbol *, gfc_expr *);
    3963              : bool is_subref_array (gfc_expr *);
    3964              : bool gfc_is_simply_contiguous (gfc_expr *, bool, bool);
    3965              : bool gfc_is_not_contiguous (gfc_expr *);
    3966              : bool gfc_check_init_expr (gfc_expr *);
    3967              : 
    3968              : gfc_expr *gfc_build_conversion (gfc_expr *);
    3969              : void gfc_free_ref_list (gfc_ref *);
    3970              : void gfc_type_convert_binary (gfc_expr *, int);
    3971              : bool gfc_is_constant_expr (gfc_expr *);
    3972              : bool gfc_simplify_expr (gfc_expr *, int);
    3973              : bool gfc_try_simplify_expr (gfc_expr *, int);
    3974              : bool gfc_has_vector_index (gfc_expr *);
    3975              : bool gfc_is_ptr_fcn (gfc_expr *);
    3976              : 
    3977              : gfc_expr *gfc_get_expr (void);
    3978              : gfc_expr *gfc_get_array_expr (bt type, int kind, locus *);
    3979              : gfc_expr *gfc_get_null_expr (locus *);
    3980              : gfc_expr *gfc_get_operator_expr (locus *, gfc_intrinsic_op, gfc_expr *,
    3981              :                                  gfc_expr *);
    3982              : gfc_expr *gfc_get_conditional_expr (locus *, gfc_expr *, gfc_expr *,
    3983              :                                     gfc_expr *);
    3984              : gfc_expr *gfc_get_structure_constructor_expr (bt, int, locus *);
    3985              : gfc_expr *gfc_get_constant_expr (bt, int, locus *);
    3986              : gfc_expr *gfc_get_character_expr (int, locus *, const char *, gfc_charlen_t len);
    3987              : gfc_expr *gfc_get_int_expr (int, locus *, HOST_WIDE_INT);
    3988              : gfc_expr *gfc_get_unsigned_expr (int, locus *, HOST_WIDE_INT);
    3989              : gfc_expr *gfc_get_logical_expr (int, locus *, bool);
    3990              : gfc_expr *gfc_get_iokind_expr (locus *, io_kind);
    3991              : 
    3992              : void gfc_clear_shape (mpz_t *shape, int rank);
    3993              : void gfc_free_shape (mpz_t **shape, int rank);
    3994              : void gfc_free_expr (gfc_expr *);
    3995              : void gfc_replace_expr (gfc_expr *, gfc_expr *);
    3996              : mpz_t *gfc_copy_shape (mpz_t *, int);
    3997              : mpz_t *gfc_copy_shape_excluding (mpz_t *, int, gfc_expr *);
    3998              : gfc_expr *gfc_copy_expr (gfc_expr *);
    3999              : gfc_ref* gfc_copy_ref (gfc_ref*);
    4000              : 
    4001              : bool gfc_specification_expr (gfc_expr *);
    4002              : 
    4003              : bool gfc_numeric_ts (gfc_typespec *);
    4004              : int gfc_kind_max (gfc_expr *, gfc_expr *);
    4005              : 
    4006              : bool gfc_check_conformance (gfc_expr *, gfc_expr *, const char *, ...) ATTRIBUTE_PRINTF_3;
    4007              : bool gfc_check_type_spec_parms (gfc_expr *, gfc_expr *, const char *);
    4008              : bool gfc_check_assign (gfc_expr *, gfc_expr *, int, bool c = true);
    4009              : bool gfc_check_pointer_assign (gfc_expr *lvalue, gfc_expr *rvalue,
    4010              :                                bool suppres_type_test = false,
    4011              :                                bool is_init_expr = false);
    4012              : bool gfc_check_assign_symbol (gfc_symbol *, gfc_component *, gfc_expr *);
    4013              : 
    4014              : gfc_expr *gfc_build_default_init_expr (gfc_typespec *, locus *);
    4015              : void gfc_apply_init (gfc_typespec *, symbol_attribute *, gfc_expr *);
    4016              : bool gfc_has_default_initializer (gfc_symbol *);
    4017              : gfc_expr *gfc_default_initializer (gfc_typespec *);
    4018              : gfc_expr *gfc_generate_initializer (gfc_typespec *, bool);
    4019              : gfc_expr *gfc_get_variable_expr (gfc_symtree *);
    4020              : void gfc_add_full_array_ref (gfc_expr *, gfc_array_spec *);
    4021              : gfc_expr * gfc_lval_expr_from_sym (gfc_symbol *);
    4022              : 
    4023              : gfc_array_spec *gfc_get_full_arrayspec_from_expr (gfc_expr *expr);
    4024              : 
    4025              : bool gfc_traverse_expr (gfc_expr *, gfc_symbol *,
    4026              :                         bool (*)(gfc_expr *, gfc_symbol *, int*),
    4027              :                         int);
    4028              : void gfc_expr_set_symbols_referenced (gfc_expr *);
    4029              : bool gfc_expr_check_typed (gfc_expr*, gfc_namespace*, bool);
    4030              : bool gfc_derived_parameter_expr (gfc_expr *);
    4031              : gfc_param_spec_type gfc_spec_list_type (gfc_actual_arglist *, gfc_symbol *);
    4032              : gfc_component * gfc_get_proc_ptr_comp (gfc_expr *);
    4033              : bool gfc_is_proc_ptr_comp (gfc_expr *);
    4034              : bool gfc_is_alloc_class_scalar_function (gfc_expr *);
    4035              : bool gfc_is_class_array_function (gfc_expr *);
    4036              : 
    4037              : bool gfc_ref_this_image (gfc_ref *ref);
    4038              : bool gfc_is_coindexed (gfc_expr *);
    4039              : bool gfc_is_coarray (gfc_expr *);
    4040              : bool gfc_has_ultimate_allocatable (gfc_expr *);
    4041              : bool gfc_has_ultimate_pointer (gfc_expr *);
    4042              : gfc_expr *gfc_find_team_co (gfc_expr *,
    4043              :                             gfc_array_ref_team_type req_team_type = TEAM_TEAM);
    4044              : gfc_expr* gfc_find_stat_co (gfc_expr *);
    4045              : gfc_expr* gfc_build_intrinsic_call (gfc_namespace *, gfc_isym_id, const char*,
    4046              :                                     locus, unsigned, ...);
    4047              : bool gfc_check_vardef_context (gfc_expr*, bool, bool, bool, const char*);
    4048              : gfc_expr* gfc_pdt_find_component_copy_initializer (gfc_symbol *, const char *);
    4049              : 
    4050              : 
    4051              : /* st.cc */
    4052              : extern gfc_code new_st;
    4053              : 
    4054              : void gfc_clear_new_st (void);
    4055              : gfc_code *gfc_get_code (gfc_exec_op);
    4056              : gfc_code *gfc_append_code (gfc_code *, gfc_code *);
    4057              : void gfc_free_statement (gfc_code *);
    4058              : void gfc_free_statements (gfc_code *);
    4059              : void gfc_free_association_list (gfc_association_list *);
    4060              : 
    4061              : /* resolve.cc */
    4062              : void gfc_resolve_symbol (gfc_symbol *);
    4063              : void gfc_expression_rank (gfc_expr *);
    4064              : bool gfc_op_rank_conformable (gfc_expr *, gfc_expr *);
    4065              : bool gfc_resolve_ref (gfc_expr *);
    4066              : void gfc_fixup_inferred_type_refs (gfc_expr *);
    4067              : bool gfc_resolve_expr (gfc_expr *);
    4068              : void gfc_resolve (gfc_namespace *);
    4069              : void gfc_resolve_code (gfc_code *, gfc_namespace *);
    4070              : void gfc_resolve_blocks (gfc_code *, gfc_namespace *);
    4071              : void gfc_resolve_formal_arglist (gfc_symbol *);
    4072              : bool gfc_impure_variable (gfc_symbol *);
    4073              : bool gfc_pure (gfc_symbol *);
    4074              : bool gfc_implicit_pure (gfc_symbol *);
    4075              : void gfc_unset_implicit_pure (gfc_symbol *);
    4076              : bool gfc_elemental (gfc_symbol *);
    4077              : bool gfc_resolve_iterator (gfc_iterator *, bool, bool);
    4078              : bool find_forall_index (gfc_expr *, gfc_symbol *, int);
    4079              : bool gfc_resolve_index (gfc_expr *, int);
    4080              : bool gfc_resolve_dim_arg (gfc_expr *);
    4081              : bool gfc_resolve_substring (gfc_ref *, bool *);
    4082              : void gfc_resolve_substring_charlen (gfc_expr *);
    4083              : void gfc_resolve_sync_stat (struct sync_stat *);
    4084              : gfc_expr *gfc_expr_to_initialize (gfc_expr *);
    4085              : bool gfc_type_is_extensible (gfc_symbol *);
    4086              : bool gfc_resolve_intrinsic (gfc_symbol *, locus *);
    4087              : bool gfc_explicit_interface_required (gfc_symbol *, char *, int);
    4088              : extern int gfc_do_concurrent_flag;
    4089              : const char* gfc_lookup_function_fuzzy (const char *, gfc_symtree *);
    4090              : bool gfc_pure_function (gfc_expr *e, const char **name);
    4091              : bool gfc_implicit_pure_function (gfc_expr *e);
    4092              : 
    4093              : /* coarray.cc */
    4094              : void gfc_coarray_rewrite (gfc_namespace *);
    4095              : 
    4096              : /* array.cc */
    4097              : gfc_iterator *gfc_copy_iterator (gfc_iterator *);
    4098              : 
    4099              : void gfc_free_array_spec (gfc_array_spec *);
    4100              : gfc_array_ref *gfc_copy_array_ref (gfc_array_ref *);
    4101              : 
    4102              : bool gfc_set_array_spec (gfc_symbol *, gfc_array_spec *, locus *);
    4103              : gfc_array_spec *gfc_copy_array_spec (gfc_array_spec *);
    4104              : bool gfc_resolve_array_spec (gfc_array_spec *, int);
    4105              : 
    4106              : bool gfc_compare_array_spec (gfc_array_spec *, gfc_array_spec *);
    4107              : 
    4108              : void gfc_simplify_iterator_var (gfc_expr *);
    4109              : bool gfc_expand_constructor (gfc_expr *, bool);
    4110              : bool gfc_constant_ac (gfc_expr *);
    4111              : bool gfc_expanded_ac (gfc_expr *);
    4112              : bool gfc_resolve_character_array_constructor (gfc_expr *);
    4113              : bool gfc_resolve_array_constructor (gfc_expr *);
    4114              : bool gfc_check_constructor_type (gfc_expr *);
    4115              : bool gfc_check_iter_variable (gfc_expr *);
    4116              : bool gfc_check_constructor (gfc_expr *, bool (*)(gfc_expr *));
    4117              : bool gfc_array_size (gfc_expr *, mpz_t *);
    4118              : bool gfc_array_dimen_size (gfc_expr *, int, mpz_t *);
    4119              : bool gfc_array_ref_shape (gfc_array_ref *, mpz_t *);
    4120              : gfc_array_ref *gfc_find_array_ref (gfc_expr *, bool a = false);
    4121              : tree gfc_conv_array_initializer (tree type, gfc_expr *);
    4122              : bool spec_size (gfc_array_spec *, mpz_t *);
    4123              : bool spec_dimen_size (gfc_array_spec *, int, mpz_t *);
    4124              : bool gfc_is_compile_time_shape (gfc_array_spec *);
    4125              : 
    4126              : bool gfc_ref_dimen_size (gfc_array_ref *, int dimen, mpz_t *, mpz_t *);
    4127              : 
    4128              : /* interface.cc -- FIXME: some of these should be in symbol.cc */
    4129              : void gfc_free_interface (gfc_interface *);
    4130              : void gfc_drop_interface_elements_before (gfc_interface **, gfc_interface *);
    4131              : bool gfc_compare_derived_types (gfc_symbol *, gfc_symbol *);
    4132              : bool gfc_compare_types (gfc_typespec *, gfc_typespec *);
    4133              : bool gfc_check_dummy_characteristics (gfc_symbol *, gfc_symbol *,
    4134              :                                       bool, char *, int);
    4135              : bool gfc_check_result_characteristics (gfc_symbol *, gfc_symbol *,
    4136              :                                        char *, int);
    4137              : bool gfc_compare_interfaces (gfc_symbol*, gfc_symbol*, const char *, int, int,
    4138              :                              char *, int, const char *, const char *,
    4139              :                              bool *bad_result_characteristics = NULL);
    4140              : void gfc_check_interfaces (gfc_namespace *);
    4141              : bool gfc_procedure_use (gfc_symbol *, gfc_actual_arglist **, locus *);
    4142              : void gfc_ppc_use (gfc_component *, gfc_actual_arglist **, locus *);
    4143              : gfc_symbol *gfc_search_interface (gfc_interface *, int,
    4144              :                                   gfc_actual_arglist **);
    4145              : match gfc_extend_expr (gfc_expr *);
    4146              : void gfc_free_formal_arglist (gfc_formal_arglist *);
    4147              : bool gfc_extend_assign (gfc_code *, gfc_namespace *);
    4148              : bool gfc_check_new_interface (gfc_interface *, gfc_symbol *, locus);
    4149              : bool gfc_add_interface (gfc_symbol *);
    4150              : gfc_interface *&gfc_current_interface_head (void);
    4151              : void gfc_set_current_interface_head (gfc_interface *);
    4152              : gfc_symtree* gfc_find_sym_in_symtree (gfc_symbol*);
    4153              : bool gfc_arglist_matches_symbol (gfc_actual_arglist**, gfc_symbol*);
    4154              : bool gfc_check_operator_interface (gfc_symbol*, gfc_intrinsic_op, locus);
    4155              : bool gfc_has_vector_subscript (gfc_expr*);
    4156              : gfc_intrinsic_op gfc_equivalent_op (gfc_intrinsic_op);
    4157              : bool gfc_check_typebound_override (gfc_symtree*, gfc_symtree*);
    4158              : void gfc_check_dtio_interfaces (gfc_symbol*);
    4159              : gfc_symtree* gfc_find_typebound_dtio_proc (gfc_symbol *, bool, bool);
    4160              : gfc_symbol* gfc_find_specific_dtio_proc (gfc_symbol*, bool, bool);
    4161              : void gfc_get_formal_from_actual_arglist (gfc_symbol *, gfc_actual_arglist *);
    4162              : bool gfc_compare_actual_formal (gfc_actual_arglist **, gfc_formal_arglist *,
    4163              :                                 int, int, bool, locus *);
    4164              : 
    4165              : 
    4166              : /* io.cc */
    4167              : extern gfc_st_label format_asterisk;
    4168              : 
    4169              : void gfc_free_open (gfc_open *);
    4170              : bool gfc_resolve_open (gfc_open *, locus *);
    4171              : void gfc_free_close (gfc_close *);
    4172              : bool gfc_resolve_close (gfc_close *, locus *);
    4173              : void gfc_free_filepos (gfc_filepos *);
    4174              : bool gfc_resolve_filepos (gfc_filepos *, locus *);
    4175              : void gfc_free_inquire (gfc_inquire *);
    4176              : bool gfc_resolve_inquire (gfc_inquire *);
    4177              : void gfc_free_dt (gfc_dt *);
    4178              : bool gfc_resolve_dt (gfc_code *, gfc_dt *, locus *);
    4179              : void gfc_free_wait (gfc_wait *);
    4180              : bool gfc_resolve_wait (gfc_wait *);
    4181              : 
    4182              : /* module.cc */
    4183              : void gfc_module_init_2 (void);
    4184              : void gfc_module_done_2 (void);
    4185              : void gfc_dump_module (const char *, int);
    4186              : bool gfc_check_symbol_access (gfc_symbol *);
    4187              : void gfc_free_use_stmts (gfc_use_list *);
    4188              : void gfc_save_module_list ();
    4189              : void gfc_restore_old_module_list ();
    4190              : const char *gfc_dt_lower_string (const char *);
    4191              : const char *gfc_dt_upper_string (const char *);
    4192              : 
    4193              : /* primary.cc */
    4194              : symbol_attribute gfc_variable_attr (gfc_expr *, gfc_typespec *);
    4195              : symbol_attribute gfc_expr_attr (gfc_expr *);
    4196              : symbol_attribute gfc_caf_attr (gfc_expr *, bool i = false, bool *r = NULL);
    4197              : bool is_inquiry_ref (const char *, gfc_ref **);
    4198              : match gfc_match_rvalue (gfc_expr **);
    4199              : match gfc_match_varspec (gfc_expr*, int, bool, bool);
    4200              : bool gfc_check_digit (char, int);
    4201              : bool gfc_is_function_return_value (gfc_symbol *, gfc_namespace *);
    4202              : bool gfc_convert_to_structure_constructor (gfc_expr *, gfc_symbol *,
    4203              :                                               gfc_expr **,
    4204              :                                               gfc_actual_arglist **, bool);
    4205              : 
    4206              : /* trans.cc */
    4207              : void gfc_generate_code (gfc_namespace *);
    4208              : void gfc_generate_module_code (gfc_namespace *);
    4209              : 
    4210              : /* trans-intrinsic.cc */
    4211              : bool gfc_inline_intrinsic_function_p (gfc_expr *);
    4212              : 
    4213              : /* trans-openmp.cc */
    4214              : int gfc_expr_list_len (gfc_expr_list *);
    4215              : 
    4216              : /* bbt.cc */
    4217              : typedef int (*compare_fn) (void *, void *);
    4218              : void gfc_insert_bbt (void *, void *, compare_fn);
    4219              : void * gfc_delete_bbt (void *, void *, compare_fn);
    4220              : 
    4221              : /* dump-parse-tree.cc */
    4222              : void gfc_dump_parse_tree (gfc_namespace *, FILE *);
    4223              : void gfc_dump_c_prototypes (FILE *);
    4224              : void gfc_dump_external_c_prototypes (FILE *);
    4225              : void gfc_dump_global_symbols (FILE *);
    4226              : void debug (gfc_symbol *);
    4227              : void debug (gfc_expr *);
    4228              : 
    4229              : /* parse.cc */
    4230              : bool gfc_parse_file (void);
    4231              : void gfc_global_used (gfc_gsymbol *, locus *);
    4232              : gfc_namespace* gfc_build_block_ns (gfc_namespace *);
    4233              : gfc_statement match_omp_directive (void);
    4234              : bool is_omp_declarative_stmt (gfc_statement);
    4235              : 
    4236              : /* dependency.cc */
    4237              : int gfc_dep_compare_functions (gfc_expr *, gfc_expr *, bool);
    4238              : int gfc_dep_compare_expr (gfc_expr *, gfc_expr *);
    4239              : bool gfc_dep_difference (gfc_expr *, gfc_expr *, mpz_t *);
    4240              : 
    4241              : /* check.cc */
    4242              : bool gfc_check_same_strlen (const gfc_expr*, const gfc_expr*, const char*);
    4243              : bool gfc_calculate_transfer_sizes (gfc_expr*, gfc_expr*, gfc_expr*,
    4244              :                                       size_t*, size_t*, size_t*);
    4245              : bool gfc_boz2int (gfc_expr *, int);
    4246              : bool gfc_boz2uint (gfc_expr *, int);
    4247              : bool gfc_boz2real (gfc_expr *, int);
    4248              : bool gfc_invalid_boz (const char *, locus *);
    4249              : bool gfc_invalid_null_arg (gfc_expr *);
    4250              : 
    4251              : bool gfc_invalid_unsigned_ops (gfc_expr *, gfc_expr *);
    4252              : 
    4253              : /* class.cc */
    4254              : void gfc_fix_class_refs (gfc_expr *e);
    4255              : void gfc_add_component_ref (gfc_expr *, const char *);
    4256              : void gfc_add_class_array_ref (gfc_expr *);
    4257              : #define gfc_add_data_component(e)     gfc_add_component_ref(e,"_data")
    4258              : #define gfc_add_vptr_component(e)     gfc_add_component_ref(e,"_vptr")
    4259              : #define gfc_add_len_component(e)      gfc_add_component_ref(e,"_len")
    4260              : #define gfc_add_hash_component(e)     gfc_add_component_ref(e,"_hash")
    4261              : #define gfc_add_size_component(e)     gfc_add_component_ref(e,"_size")
    4262              : #define gfc_add_def_init_component(e) gfc_add_component_ref(e,"_def_init")
    4263              : #define gfc_add_final_component(e)    gfc_add_component_ref(e,"_final")
    4264              : bool gfc_is_class_array_ref (gfc_expr *, bool *);
    4265              : bool gfc_is_class_scalar_expr (gfc_expr *);
    4266              : bool gfc_is_class_container_ref (gfc_expr *e);
    4267              : gfc_expr *gfc_class_initializer (gfc_typespec *, gfc_expr *);
    4268              : unsigned int gfc_hash_value (gfc_symbol *);
    4269              : gfc_expr *gfc_get_len_component (gfc_expr *e, int);
    4270              : bool gfc_build_class_symbol (gfc_typespec *, symbol_attribute *,
    4271              :                              gfc_array_spec **);
    4272              : void gfc_change_class (gfc_typespec *, symbol_attribute *,
    4273              :                        gfc_array_spec *, int, int);
    4274              : gfc_symbol *gfc_find_derived_vtab (gfc_symbol *);
    4275              : gfc_symbol *gfc_find_vtab (gfc_typespec *);
    4276              : gfc_symtree* gfc_find_typebound_proc (gfc_symbol*, bool*,
    4277              :                                       const char*, bool, locus*);
    4278              : gfc_symtree* gfc_find_typebound_user_op (gfc_symbol*, bool*,
    4279              :                                          const char*, bool, locus*);
    4280              : gfc_typebound_proc* gfc_find_typebound_intrinsic_op (gfc_symbol*, bool*,
    4281              :                                                      gfc_intrinsic_op, bool,
    4282              :                                                      locus*);
    4283              : gfc_symtree* gfc_get_tbp_symtree (gfc_symtree**, const char*);
    4284              : bool gfc_is_finalizable (gfc_symbol *, gfc_expr **);
    4285              : bool gfc_may_be_finalized (gfc_typespec);
    4286              : 
    4287              : #define CLASS_DATA(sym) sym->ts.u.derived->components
    4288              : #define UNLIMITED_POLY(sym) \
    4289              :         (sym != NULL && sym->ts.type == BT_CLASS \
    4290              :          && CLASS_DATA (sym) \
    4291              :          && CLASS_DATA (sym)->ts.u.derived \
    4292              :          && CLASS_DATA (sym)->ts.u.derived->attr.unlimited_polymorphic)
    4293              : #define IS_CLASS_ARRAY(sym) \
    4294              :         (sym->ts.type == BT_CLASS \
    4295              :          && CLASS_DATA (sym) \
    4296              :          && CLASS_DATA (sym)->attr.dimension \
    4297              :          && !CLASS_DATA (sym)->attr.class_pointer)
    4298              : #define IS_CLASS_COARRAY_OR_ARRAY(sym) \
    4299              :         (sym->ts.type == BT_CLASS && CLASS_DATA (sym) \
    4300              :          && (CLASS_DATA (sym)->attr.dimension \
    4301              :              || CLASS_DATA (sym)->attr.codimension) \
    4302              :          && !CLASS_DATA (sym)->attr.class_pointer)
    4303              : #define IS_POINTER(sym) \
    4304              :         (sym->ts.type == BT_CLASS && sym->attr.class_ok && CLASS_DATA (sym) \
    4305              :          ? CLASS_DATA (sym)->attr.class_pointer : sym->attr.pointer)
    4306              : #define IS_PROC_POINTER(sym) \
    4307              :         (sym->ts.type == BT_CLASS && sym->attr.class_ok && CLASS_DATA (sym) \
    4308              :          ? CLASS_DATA (sym)->attr.proc_pointer : sym->attr.proc_pointer)
    4309              : #define IS_INFERRED_TYPE(expr) \
    4310              :         (expr && expr->expr_type == EXPR_VARIABLE \
    4311              :          && expr->symtree->n.sym->assoc \
    4312              :          && expr->symtree->n.sym->assoc->inferred_type)
    4313              : #define PDT_PREFIX "PDT"
    4314              : #define PDT_PREFIX_LEN 3
    4315              : #define IS_PDT(sym) \
    4316              :         (sym != NULL && sym->ts.type == BT_DERIVED \
    4317              :          && sym->ts.u.derived \
    4318              :          && sym->ts.u.derived->attr.pdt_type)
    4319              : #define IS_CLASS_PDT(sym) \
    4320              :         (sym != NULL && sym->ts.type == BT_CLASS \
    4321              :          && CLASS_DATA (sym) \
    4322              :          && CLASS_DATA (sym)->ts.u.derived \
    4323              :          && CLASS_DATA (sym)->ts.u.derived->attr.pdt_type)
    4324              : 
    4325              : /* frontend-passes.cc */
    4326              : 
    4327              : void gfc_run_passes (gfc_namespace *);
    4328              : 
    4329              : typedef int (*walk_code_fn_t) (gfc_code **, int *, void *);
    4330              : typedef int (*walk_expr_fn_t) (gfc_expr **, int *, void *);
    4331              : 
    4332              : int gfc_dummy_code_callback (gfc_code **, int *, void *);
    4333              : int gfc_expr_walker (gfc_expr **, walk_expr_fn_t, void *);
    4334              : int gfc_code_walker (gfc_code **, walk_code_fn_t, walk_expr_fn_t, void *);
    4335              : bool gfc_has_dimen_vector_ref (gfc_expr *e);
    4336              : void gfc_check_externals (gfc_namespace *);
    4337              : bool gfc_fix_implicit_pure (gfc_namespace *);
    4338              : 
    4339              : /* simplify.cc */
    4340              : 
    4341              : void gfc_convert_mpz_to_signed (mpz_t, int);
    4342              : gfc_expr *gfc_simplify_ieee_functions (gfc_expr *);
    4343              : bool gfc_is_constant_array_expr (gfc_expr *);
    4344              : bool gfc_is_size_zero_array (gfc_expr *);
    4345              : void gfc_convert_mpz_to_unsigned (mpz_t, int, bool sign = true);
    4346              : 
    4347              : /* trans-array.cc  */
    4348              : 
    4349              : bool gfc_is_reallocatable_lhs (gfc_expr *);
    4350              : 
    4351              : /* trans-decl.cc */
    4352              : 
    4353              : void finish_oacc_declare (gfc_namespace *, gfc_symbol *, bool);
    4354              : void gfc_adjust_builtins (void);
    4355              : void gfc_add_caf_accessor (gfc_expr *, gfc_expr *);
    4356              : 
    4357              : #endif /* GCC_GFORTRAN_H  */
        

Generated by: LCOV version 2.4-beta

LCOV profile is generated on x86_64 machine using following configure options: configure --disable-bootstrap --enable-coverage=opt --enable-languages=c,c++,fortran,go,jit,lto,rust,m2 --enable-host-shared. GCC test suite is run with the built compiler.