re PR fortran/13930 (derived type with intent(in) attribute not accepted)
[gcc.git] / gcc / fortran / gfortran.h
1 /* gfortran header file
2 Copyright (C) 2000, 2001, 2002, 2003, 2004 Free Software Foundation,
3 Inc.
4 Contributed by Andy Vaught
5
6 This file is part of GCC.
7
8 GCC is free software; you can redistribute it and/or modify it under
9 the terms of the GNU General Public License as published by the Free
10 Software Foundation; either version 2, or (at your option) any later
11 version.
12
13 GCC is distributed in the hope that it will be useful, but WITHOUT ANY
14 WARRANTY; without even the implied warranty of MERCHANTABILITY or
15 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
16 for more details.
17
18 You should have received a copy of the GNU General Public License
19 along with GCC; see the file COPYING. If not, write to the Free
20 Software Foundation, 59 Temple Place - Suite 330, Boston, MA
21 02111-1307, USA. */
22
23 #ifndef GCC_GFORTRAN_H
24 #define GCC_GFORTRAN_H
25
26 /* It's probably insane to have this large of a header file, but it
27 seemed like everything had to be recompiled anyway when a change
28 was made to a header file, and there were ordering issues with
29 multiple header files. Besides, Microsoft's winnt.h was 250k last
30 time I looked, so by comparison this is perfectly reasonable. */
31
32 /* We need system.h for HOST_WIDE_INT. Including hwint.h by itself doesn't
33 seem to be sufficient on some systems. */
34 #include "system.h"
35 #include "coretypes.h"
36
37 /* The following ifdefs are recommended by the autoconf documentation
38 for any code using alloca. */
39
40 /* AIX requires this to be the first thing in the file. */
41 #ifdef __GNUC__
42 #else /* not __GNUC__ */
43 #ifdef HAVE_ALLOCA_H
44 #include <alloca.h>
45 #else /* do not HAVE_ALLOCA_H */
46 #ifdef _AIX
47 #pragma alloca
48 #else
49 #ifndef alloca /* predefined by HP cc +Olibcalls */
50 char *alloca ();
51 #endif /* not predefined */
52 #endif /* not _AIX */
53 #endif /* do not HAVE_ALLOCA_H */
54 #endif /* not __GNUC__ */
55
56
57 #include <stdio.h> /* need FILE * here */
58
59 /* Major control parameters. */
60
61 #define GFC_VERSION "0.23"
62 #define GFC_MAX_SYMBOL_LEN 63
63 #define GFC_REAL_BITS 100 /* Number of bits in g95's floating point numbers. */
64 #define GFC_MAX_LINE 132 /* Characters beyond this are not seen. */
65 #define GFC_MAX_DIMENSIONS 7 /* Maximum dimensions in an array. */
66 #define GFC_LETTERS 26 /* Number of letters in the alphabet. */
67 #define MAX_ERROR_MESSAGE 1000 /* Maximum length of an error message. */
68
69 #define free(x) Use_gfc_free_instead_of_free()
70 #define gfc_is_whitespace(c) ((c==' ') || (c=='\t'))
71
72 #ifndef NULL
73 #define NULL ((void *) 0)
74 #endif
75
76 /* Stringization. */
77 #define stringize(x) expand_macro(x)
78 #define expand_macro(x) # x
79
80 /* For a the runtime library, a standard prefix is a requirement to
81 avoid cluttering the namespace with things nobody asked for. It's
82 ugly to look at and a pain to type when you add the prefix by hand,
83 so we hide it behind a macro. */
84 #define PREFIX(x) "_gfortran_" x
85
86 /* Macro to initialize an mstring structure. */
87 #define minit(s, t) { s, NULL, t }
88
89 /* Structure for storing strings to be matched by gfc_match_string. */
90 typedef struct
91 {
92 const char *string;
93 const char *mp;
94 int tag;
95 }
96 mstring;
97
98
99 /* Flags to specify which standardi/extension contains a feature. */
100 #define GFC_STD_GNU (1<<5) /* GNU Fortran extension. */
101 #define GFC_STD_F2003 (1<<4) /* New in F2003. */
102 #define GFC_STD_F2003_DEL (1<<3) /* Deleted in F2003. */
103 #define GFC_STD_F2003_OBS (1<<2) /* Obsoleted in F2003. */
104 #define GFC_STD_F95_DEL (1<<1) /* Deleted in F95. */
105 #define GFC_STD_F95_OBS (1<<0) /* Obsoleted in F95. */
106
107 /*************************** Enums *****************************/
108
109 /* The author remains confused to this day about the convention of
110 returning '0' for 'SUCCESS'... or was it the other way around? The
111 following enum makes things much more readable. We also start
112 values off at one instead of zero. */
113
114 typedef enum
115 { SUCCESS = 1, FAILURE }
116 try;
117
118 /* Matchers return one of these three values. The difference between
119 MATCH_NO and MATCH_ERROR is that MATCH_ERROR means that a match was
120 successful, but that something non-syntactic is wrong and an error
121 has already been issued. */
122
123 typedef enum
124 { MATCH_NO = 1, MATCH_YES, MATCH_ERROR }
125 match;
126
127 typedef enum
128 { FORM_FREE, FORM_FIXED, FORM_UNKNOWN }
129 gfc_source_form;
130
131 typedef enum
132 { BT_UNKNOWN = 1, BT_INTEGER, BT_REAL, BT_COMPLEX,
133 BT_LOGICAL, BT_CHARACTER, BT_DERIVED, BT_PROCEDURE
134 }
135 bt;
136
137 /* Expression node types. */
138 typedef enum
139 { EXPR_OP = 1, EXPR_FUNCTION, EXPR_CONSTANT, EXPR_VARIABLE,
140 EXPR_SUBSTRING, EXPR_STRUCTURE, EXPR_ARRAY, EXPR_NULL
141 }
142 expr_t;
143
144 /* Array types. */
145 typedef enum
146 { AS_EXPLICIT = 1, AS_ASSUMED_SHAPE, AS_DEFERRED,
147 AS_ASSUMED_SIZE, AS_UNKNOWN
148 }
149 array_type;
150
151 typedef enum
152 { AR_FULL = 1, AR_ELEMENT, AR_SECTION, AR_UNKNOWN }
153 ar_type;
154
155 /* Statement label types. */
156 typedef enum
157 { ST_LABEL_UNKNOWN = 1, ST_LABEL_TARGET,
158 ST_LABEL_BAD_TARGET, ST_LABEL_FORMAT
159 }
160 gfc_sl_type;
161
162 /* Intrinsic operators. */
163 typedef enum
164 { GFC_INTRINSIC_BEGIN = 0,
165 INTRINSIC_NONE = -1, INTRINSIC_UPLUS = GFC_INTRINSIC_BEGIN,
166 INTRINSIC_UMINUS, INTRINSIC_PLUS, INTRINSIC_MINUS, INTRINSIC_TIMES,
167 INTRINSIC_DIVIDE, INTRINSIC_POWER, INTRINSIC_CONCAT,
168 INTRINSIC_AND, INTRINSIC_OR, INTRINSIC_EQV, INTRINSIC_NEQV,
169 INTRINSIC_EQ, INTRINSIC_NE, INTRINSIC_GT, INTRINSIC_GE,
170 INTRINSIC_LT, INTRINSIC_LE, INTRINSIC_NOT, INTRINSIC_USER,
171 INTRINSIC_ASSIGN,
172 GFC_INTRINSIC_END /* Sentinel */
173 }
174 gfc_intrinsic_op;
175
176
177 /* Strings for all intrinsic operators. */
178 extern mstring intrinsic_operators[];
179
180
181 /* This macro is the number of intrinsic operators that exist.
182 Assumptions are made about the numbering of the interface_op enums. */
183 #define GFC_INTRINSIC_OPS GFC_INTRINSIC_END
184
185 /* Arithmetic results. */
186 typedef enum
187 { ARITH_OK = 1, ARITH_OVERFLOW, ARITH_UNDERFLOW,
188 ARITH_DIV0, ARITH_0TO0, ARITH_INCOMMENSURATE
189 }
190 arith;
191
192 /* Statements. */
193 typedef enum
194 {
195 ST_ARITHMETIC_IF, ST_ALLOCATE, ST_ATTR_DECL, ST_BACKSPACE, ST_BLOCK_DATA,
196 ST_CALL, ST_CASE, ST_CLOSE, ST_COMMON, ST_CONTINUE, ST_CONTAINS, ST_CYCLE,
197 ST_DATA, ST_DATA_DECL, ST_DEALLOCATE, ST_DO, ST_ELSE, ST_ELSEIF,
198 ST_ELSEWHERE, ST_END_BLOCK_DATA, ST_ENDDO, ST_IMPLIED_ENDDO,
199 ST_END_FILE, ST_END_FORALL, ST_END_FUNCTION, ST_ENDIF, ST_END_INTERFACE,
200 ST_END_MODULE, ST_END_PROGRAM, ST_END_SELECT, ST_END_SUBROUTINE,
201 ST_END_WHERE, ST_END_TYPE, ST_ENTRY, ST_EQUIVALENCE, ST_EXIT, ST_FORALL,
202 ST_FORALL_BLOCK, ST_FORMAT, ST_FUNCTION, ST_GOTO, ST_IF_BLOCK, ST_IMPLICIT,
203 ST_IMPLICIT_NONE, ST_INQUIRE, ST_INTERFACE, ST_PARAMETER, ST_MODULE,
204 ST_MODULE_PROC, ST_NAMELIST, ST_NULLIFY, ST_OPEN, ST_PAUSE, ST_PRIVATE,
205 ST_PROGRAM, ST_PUBLIC, ST_READ, ST_RETURN, ST_REWIND, ST_STOP,
206 ST_SUBROUTINE,
207 ST_TYPE, ST_USE, ST_WHERE_BLOCK, ST_WHERE, ST_WRITE, ST_ASSIGNMENT,
208 ST_POINTER_ASSIGNMENT, ST_SELECT_CASE, ST_SEQUENCE, ST_SIMPLE_IF,
209 ST_STATEMENT_FUNCTION, ST_DERIVED_DECL, ST_LABEL_ASSIGNMENT, ST_NONE
210 }
211 gfc_statement;
212
213
214 /* Types of interfaces that we can have. Assignment interfaces are
215 considered to be intrinsic operators. */
216 typedef enum
217 {
218 INTERFACE_NAMELESS = 1, INTERFACE_GENERIC,
219 INTERFACE_INTRINSIC_OP, INTERFACE_USER_OP
220 }
221 interface_type;
222
223 /* Symbol flavors: these are all mutually exclusive.
224 10 elements = 4 bits. */
225 typedef enum
226 {
227 FL_UNKNOWN = 0, FL_PROGRAM, FL_BLOCK_DATA, FL_MODULE, FL_VARIABLE,
228 FL_PARAMETER, FL_LABEL, FL_PROCEDURE, FL_DERIVED, FL_NAMELIST
229 }
230 sym_flavor;
231
232 /* Procedure types. 7 elements = 3 bits. */
233 typedef enum
234 { PROC_UNKNOWN, PROC_MODULE, PROC_INTERNAL, PROC_DUMMY,
235 PROC_INTRINSIC, PROC_ST_FUNCTION, PROC_EXTERNAL
236 }
237 procedure_type;
238
239 /* Intent types. */
240 typedef enum
241 { INTENT_UNKNOWN = 0, INTENT_IN, INTENT_OUT, INTENT_INOUT
242 }
243 sym_intent;
244
245 /* Access types. */
246 typedef enum
247 { ACCESS_PUBLIC = 1, ACCESS_PRIVATE, ACCESS_UNKNOWN
248 }
249 gfc_access;
250
251 /* Flags to keep track of where an interface came from.
252 4 elements = 2 bits. */
253 typedef enum
254 { IFSRC_UNKNOWN = 0, IFSRC_DECL, IFSRC_IFBODY, IFSRC_USAGE
255 }
256 ifsrc;
257
258 /* Strings for all symbol attributes. We use these for dumping the
259 parse tree, in error messages, and also when reading and writing
260 modules. In symbol.c. */
261 extern const mstring flavors[];
262 extern const mstring procedures[];
263 extern const mstring intents[];
264 extern const mstring access_types[];
265 extern const mstring ifsrc_types[];
266
267 /* Enumeration of all the generic intrinsic functions. Used by the
268 backend for identification of a function. */
269
270 enum gfc_generic_isym_id
271 {
272 /* GFC_ISYM_NONE is used for intrinsics which will never be seen by
273 the backend (eg. KIND). */
274 GFC_ISYM_NONE = 0,
275 GFC_ISYM_ABS,
276 GFC_ISYM_ACHAR,
277 GFC_ISYM_ACOS,
278 GFC_ISYM_ADJUSTL,
279 GFC_ISYM_ADJUSTR,
280 GFC_ISYM_AIMAG,
281 GFC_ISYM_AINT,
282 GFC_ISYM_ALL,
283 GFC_ISYM_ALLOCATED,
284 GFC_ISYM_ANINT,
285 GFC_ISYM_ANY,
286 GFC_ISYM_ASIN,
287 GFC_ISYM_ASSOCIATED,
288 GFC_ISYM_ATAN,
289 GFC_ISYM_ATAN2,
290 GFC_ISYM_BTEST,
291 GFC_ISYM_CEILING,
292 GFC_ISYM_CHAR,
293 GFC_ISYM_CMPLX,
294 GFC_ISYM_CONJG,
295 GFC_ISYM_COS,
296 GFC_ISYM_COSH,
297 GFC_ISYM_COUNT,
298 GFC_ISYM_CSHIFT,
299 GFC_ISYM_DBLE,
300 GFC_ISYM_DIM,
301 GFC_ISYM_DOT_PRODUCT,
302 GFC_ISYM_DPROD,
303 GFC_ISYM_EOSHIFT,
304 GFC_ISYM_EXP,
305 GFC_ISYM_EXPONENT,
306 GFC_ISYM_FLOOR,
307 GFC_ISYM_FRACTION,
308 GFC_ISYM_IACHAR,
309 GFC_ISYM_IAND,
310 GFC_ISYM_IBCLR,
311 GFC_ISYM_IBITS,
312 GFC_ISYM_IBSET,
313 GFC_ISYM_ICHAR,
314 GFC_ISYM_IEOR,
315 GFC_ISYM_INDEX,
316 GFC_ISYM_INT,
317 GFC_ISYM_IOR,
318 GFC_ISYM_ISHFT,
319 GFC_ISYM_ISHFTC,
320 GFC_ISYM_LBOUND,
321 GFC_ISYM_LEN,
322 GFC_ISYM_LEN_TRIM,
323 GFC_ISYM_LGE,
324 GFC_ISYM_LGT,
325 GFC_ISYM_LLE,
326 GFC_ISYM_LLT,
327 GFC_ISYM_LOG,
328 GFC_ISYM_LOG10,
329 GFC_ISYM_LOGICAL,
330 GFC_ISYM_MATMUL,
331 GFC_ISYM_MAX,
332 GFC_ISYM_MAXLOC,
333 GFC_ISYM_MAXVAL,
334 GFC_ISYM_MERGE,
335 GFC_ISYM_MIN,
336 GFC_ISYM_MINLOC,
337 GFC_ISYM_MINVAL,
338 GFC_ISYM_MOD,
339 GFC_ISYM_MODULO,
340 GFC_ISYM_NEAREST,
341 GFC_ISYM_NINT,
342 GFC_ISYM_NOT,
343 GFC_ISYM_PACK,
344 GFC_ISYM_PRESENT,
345 GFC_ISYM_PRODUCT,
346 GFC_ISYM_REAL,
347 GFC_ISYM_REPEAT,
348 GFC_ISYM_RESHAPE,
349 GFC_ISYM_RRSPACING,
350 GFC_ISYM_SCALE,
351 GFC_ISYM_SCAN,
352 GFC_ISYM_SET_EXPONENT,
353 GFC_ISYM_SHAPE,
354 GFC_ISYM_SI_KIND,
355 GFC_ISYM_SIGN,
356 GFC_ISYM_SIN,
357 GFC_ISYM_SINH,
358 GFC_ISYM_SIZE,
359 GFC_ISYM_SPACING,
360 GFC_ISYM_SPREAD,
361 GFC_ISYM_SQRT,
362 GFC_ISYM_SR_KIND,
363 GFC_ISYM_SUM,
364 GFC_ISYM_TAN,
365 GFC_ISYM_TANH,
366 GFC_ISYM_TRANSFER,
367 GFC_ISYM_TRANSPOSE,
368 GFC_ISYM_TRIM,
369 GFC_ISYM_UBOUND,
370 GFC_ISYM_UNPACK,
371 GFC_ISYM_VERIFY,
372 GFC_ISYM_CONVERSION
373 };
374 typedef enum gfc_generic_isym_id gfc_generic_isym_id;
375
376 /************************* Structures *****************************/
377
378 /* Symbol attribute structure. */
379 typedef struct
380 {
381 /* Variable attributes. */
382 unsigned allocatable:1, dimension:1, external:1, intrinsic:1,
383 optional:1, pointer:1, save:1, target:1,
384 dummy:1, common:1, result:1, entry:1, assign:1;
385
386 unsigned data:1, /* Symbol is named in a DATA statement. */
387 use_assoc:1; /* Symbol has been use-associated. */
388
389 unsigned in_namelist:1, in_common:1, saved_common:1;
390 unsigned function:1, subroutine:1, generic:1;
391 unsigned implicit_type:1; /* Type defined via implicit rules */
392
393 /* Function/subroutine attributes */
394 unsigned sequence:1, elemental:1, pure:1, recursive:1;
395 unsigned unmaskable:1, masked:1, contained:1;
396
397 /* Set if a function must always be referenced by an explicit interface. */
398 unsigned always_explicit:1;
399
400 /* Set if the symbol has been referenced in an expression. No further
401 modification of type or type parameters is permitted. */
402 unsigned referenced:1;
403
404 /* Mutually exclusive multibit attributes. */
405 gfc_access access:2;
406 sym_intent intent:2;
407 sym_flavor flavor:4;
408 ifsrc if_source:2;
409
410 procedure_type proc:3;
411
412 }
413 symbol_attribute;
414
415
416 /* The following three structures are used to identify a location in
417 the sources.
418
419 gfc_file is used to maintain a tree of the source files and how
420 they include each other
421
422 gfc_linebuf holds a single line of source code and information
423 which file it resides in
424
425 locus point to the sourceline and the character in the source
426 line.
427 */
428
429 typedef struct gfc_file
430 {
431 struct gfc_file *included_by, *next, *up;
432 int inclusion_line, line;
433 char *filename;
434 } gfc_file;
435
436 typedef struct gfc_linebuf
437 {
438 int linenum;
439 struct gfc_file *file;
440 struct gfc_linebuf *next;
441
442 char line[];
443 } gfc_linebuf;
444
445 typedef struct
446 {
447 char *nextc;
448 gfc_linebuf *lb;
449 } locus;
450
451
452 #include <limits.h>
453 #ifndef PATH_MAX
454 # include <sys/param.h>
455 # define PATH_MAX MAXPATHLEN
456 #endif
457
458
459 extern int gfc_suppress_error;
460
461
462 /* Character length structures hold the expression that gives the
463 length of a character variable. We avoid putting these into
464 gfc_typespec because doing so prevents us from doing structure
465 copies and forces us to deallocate any typespecs we create, as well
466 as structures that contain typespecs. They also can have multiple
467 character typespecs pointing to them.
468
469 These structures form a singly linked list within the current
470 namespace and are deallocated with the namespace. It is possible to
471 end up with gfc_charlen structures that have nothing pointing to them. */
472
473 typedef struct gfc_charlen
474 {
475 struct gfc_expr *length;
476 struct gfc_charlen *next;
477 tree backend_decl;
478 }
479 gfc_charlen;
480
481 #define gfc_get_charlen() gfc_getmem(sizeof(gfc_charlen))
482
483 /* Type specification structure. FIXME: derived and cl could be union??? */
484 typedef struct
485 {
486 bt type;
487 int kind;
488 struct gfc_symbol *derived;
489 gfc_charlen *cl; /* For character types only. */
490 }
491 gfc_typespec;
492
493 /* Array specification. */
494 typedef struct
495 {
496 int rank; /* A rank of zero means that a variable is a scalar. */
497 array_type type;
498 struct gfc_expr *lower[GFC_MAX_DIMENSIONS], *upper[GFC_MAX_DIMENSIONS];
499 }
500 gfc_array_spec;
501
502 #define gfc_get_array_spec() gfc_getmem(sizeof(gfc_array_spec))
503
504
505 /* Components of derived types. */
506 typedef struct gfc_component
507 {
508 char name[GFC_MAX_SYMBOL_LEN + 1];
509 gfc_typespec ts;
510
511 int pointer, dimension;
512 gfc_array_spec *as;
513
514 tree backend_decl;
515 locus loc;
516 struct gfc_expr *initializer;
517 struct gfc_component *next;
518 }
519 gfc_component;
520
521 #define gfc_get_component() gfc_getmem(sizeof(gfc_component))
522
523 /* Formal argument lists are lists of symbols. */
524 typedef struct gfc_formal_arglist
525 {
526 struct gfc_symbol *sym;
527 struct gfc_formal_arglist *next;
528 }
529 gfc_formal_arglist;
530
531 #define gfc_get_formal_arglist() gfc_getmem(sizeof(gfc_formal_arglist))
532
533
534 /* The gfc_actual_arglist structure is for actual arguments. */
535 typedef struct gfc_actual_arglist
536 {
537 char name[GFC_MAX_SYMBOL_LEN + 1];
538 /* Alternate return label when the expr member is null. */
539 struct gfc_st_label *label;
540
541 struct gfc_expr *expr;
542 struct gfc_actual_arglist *next;
543 }
544 gfc_actual_arglist;
545
546 #define gfc_get_actual_arglist() gfc_getmem(sizeof(gfc_actual_arglist))
547
548
549 /* Because a symbol can belong to multiple namelists, they must be
550 linked externally to the symbol itself. */
551 typedef struct gfc_namelist
552 {
553 struct gfc_symbol *sym;
554 struct gfc_namelist *next;
555 }
556 gfc_namelist;
557
558 #define gfc_get_namelist() gfc_getmem(sizeof(gfc_namelist))
559
560
561 /* The gfc_st_label structure is a doubly linked list attached to a
562 namespace that records the usage of statement labels within that
563 space. */
564 /* TODO: Make format/statement specifics a union. */
565 typedef struct gfc_st_label
566 {
567 int value;
568
569 gfc_sl_type defined, referenced;
570
571 struct gfc_expr *format;
572
573 tree backend_decl;
574
575 locus where;
576
577 struct gfc_st_label *prev, *next;
578 }
579 gfc_st_label;
580
581
582 /* gfc_interface()-- Interfaces are lists of symbols strung together. */
583 typedef struct gfc_interface
584 {
585 struct gfc_symbol *sym;
586 locus where;
587 struct gfc_interface *next;
588 }
589 gfc_interface;
590
591 #define gfc_get_interface() gfc_getmem(sizeof(gfc_interface))
592
593
594 /* User operator nodes. These are like stripped down symbols. */
595 typedef struct
596 {
597 char name[GFC_MAX_SYMBOL_LEN + 1];
598
599 gfc_interface *operator;
600 struct gfc_namespace *ns;
601 gfc_access access;
602 }
603 gfc_user_op;
604
605 /* Symbol nodes. These are important things. They are what the
606 standard refers to as "entities". The possibly multiple names that
607 refer to the same entity are accomplished by a binary tree of
608 symtree structures that is balanced by the red-black method-- more
609 than one symtree node can point to any given symbol. */
610
611 typedef struct gfc_symbol
612 {
613 char name[GFC_MAX_SYMBOL_LEN + 1]; /* Primary name, before renaming */
614 char module[GFC_MAX_SYMBOL_LEN + 1]; /* Module this symbol came from */
615 locus declared_at;
616
617 gfc_typespec ts;
618 symbol_attribute attr;
619
620 /* The interface member points to the formal argument list if the
621 symbol is a function or subroutine name. If the symbol is a
622 generic name, the generic member points to the list of
623 interfaces. */
624
625 gfc_interface *generic;
626 gfc_access component_access;
627
628 gfc_formal_arglist *formal;
629 struct gfc_namespace *formal_ns;
630
631 struct gfc_expr *value; /* Parameter/Initializer value */
632 gfc_array_spec *as;
633 struct gfc_symbol *result; /* function result symbol */
634 gfc_component *components; /* Derived type components */
635
636 /* TODO: These three fields are mutually exclusive. */
637 struct gfc_symbol *common_head, *common_next; /* Links for COMMON syms */
638 /* Make sure setup code for dummy arguments is generated in the correct
639 order. */
640 int dummy_order;
641
642 gfc_namelist *namelist, *namelist_tail;
643
644 /* Change management fields. Symbols that might be modified by the
645 current statement have the mark member nonzero and are kept in a
646 singly linked list through the tlink field. Of these symbols,
647 symbols with old_symbol equal to NULL are symbols created within
648 the current statement. Otherwise, old_symbol points to a copy of
649 the old symbol. */
650
651 struct gfc_symbol *old_symbol, *tlink;
652 unsigned mark:1, new:1;
653 int refs;
654 struct gfc_namespace *ns; /* namespace containing this symbol */
655
656 tree backend_decl;
657
658 }
659 gfc_symbol;
660
661
662 /* Within a namespace, symbols are pointed to by symtree nodes that
663 are linked together in a balanced binary tree. There can be
664 several symtrees pointing to the same symbol node via USE
665 statements. */
666
667 #define BBT_HEADER(self) int priority; struct self *left, *right
668
669 typedef struct gfc_symtree
670 {
671 BBT_HEADER (gfc_symtree);
672 char name[GFC_MAX_SYMBOL_LEN + 1];
673 int ambiguous;
674 union
675 {
676 gfc_symbol *sym; /* Symbol associated with this node */
677 gfc_user_op *uop;
678 }
679 n;
680
681 }
682 gfc_symtree;
683
684
685 typedef struct gfc_namespace
686 {
687 gfc_symtree *sym_root, *uop_root; /* Roots of the red/black symbol trees */
688
689 int set_flag[GFC_LETTERS];
690 gfc_typespec default_type[GFC_LETTERS]; /* IMPLICIT typespecs */
691
692 struct gfc_symbol *proc_name;
693 gfc_interface *operator[GFC_INTRINSIC_OPS];
694 struct gfc_namespace *parent, *contained, *sibling;
695 struct gfc_code *code;
696 gfc_symbol *blank_common;
697 struct gfc_equiv *equiv;
698 gfc_access default_access, operator_access[GFC_INTRINSIC_OPS];
699
700 gfc_st_label *st_labels;
701 struct gfc_data *data;
702
703 gfc_charlen *cl_list;
704
705 int save_all, seen_save;
706 }
707 gfc_namespace;
708
709 extern gfc_namespace *gfc_current_ns;
710
711
712 /* Information on interfaces being built. */
713 typedef struct
714 {
715 interface_type type;
716 gfc_symbol *sym;
717 gfc_namespace *ns;
718 gfc_user_op *uop;
719 gfc_intrinsic_op op;
720 }
721 gfc_interface_info;
722
723 extern gfc_interface_info current_interface;
724
725
726 /* Array reference. */
727 typedef struct gfc_array_ref
728 {
729 ar_type type;
730 int dimen; /* # of components in the reference */
731 locus where;
732 gfc_array_spec *as;
733
734 locus c_where[GFC_MAX_DIMENSIONS]; /* All expressions can be NULL */
735 struct gfc_expr *start[GFC_MAX_DIMENSIONS], *end[GFC_MAX_DIMENSIONS],
736 *stride[GFC_MAX_DIMENSIONS];
737
738 enum
739 { DIMEN_ELEMENT = 1, DIMEN_RANGE, DIMEN_VECTOR, DIMEN_UNKNOWN }
740 dimen_type[GFC_MAX_DIMENSIONS];
741
742 struct gfc_expr *offset;
743 }
744 gfc_array_ref;
745
746 #define gfc_get_array_ref() gfc_getmem(sizeof(gfc_array_ref))
747
748
749 /* Component reference nodes. A variable is stored as an expression
750 node that points to the base symbol. After that, a singly linked
751 list of component reference nodes gives the variable's complete
752 resolution. The array_ref component may be present and comes
753 before the component component. */
754
755 typedef enum
756 { REF_ARRAY, REF_COMPONENT, REF_SUBSTRING }
757 ref_type;
758
759 typedef struct gfc_ref
760 {
761 ref_type type;
762
763 union
764 {
765 struct gfc_array_ref ar;
766
767 struct
768 {
769 gfc_component *component;
770 gfc_symbol *sym;
771 }
772 c;
773
774 struct
775 {
776 struct gfc_expr *start, *end; /* Substring */
777 gfc_charlen *length;
778 }
779 ss;
780
781 }
782 u;
783
784 struct gfc_ref *next;
785 }
786 gfc_ref;
787
788 #define gfc_get_ref() gfc_getmem(sizeof(gfc_ref))
789
790
791 /* Structures representing intrinsic symbols and their arguments lists. */
792 typedef struct gfc_intrinsic_arg
793 {
794 char name[GFC_MAX_SYMBOL_LEN + 1];
795
796 gfc_typespec ts;
797 int optional;
798 gfc_actual_arglist *actual;
799
800 struct gfc_intrinsic_arg *next;
801
802 }
803 gfc_intrinsic_arg;
804
805
806 typedef union
807 {
808 try (*f1)(struct gfc_expr *);
809 try (*f1m)(gfc_actual_arglist *);
810 try (*f2)(struct gfc_expr *, struct gfc_expr *);
811 try (*f3)(struct gfc_expr *, struct gfc_expr *, struct gfc_expr *);
812 try (*f4)(struct gfc_expr *, struct gfc_expr *, struct gfc_expr *,
813 struct gfc_expr *);
814 try (*f5)(struct gfc_expr *, struct gfc_expr *, struct gfc_expr *,
815 struct gfc_expr *, struct gfc_expr *);
816 }
817 gfc_check_f;
818
819
820 typedef union
821 {
822 struct gfc_expr *(*f1)(struct gfc_expr *);
823 struct gfc_expr *(*f2)(struct gfc_expr *, struct gfc_expr *);
824 struct gfc_expr *(*f3)(struct gfc_expr *, struct gfc_expr *,
825 struct gfc_expr *);
826 struct gfc_expr *(*f4)(struct gfc_expr *, struct gfc_expr *,
827 struct gfc_expr *, struct gfc_expr *);
828 struct gfc_expr *(*f5)(struct gfc_expr *, struct gfc_expr *,
829 struct gfc_expr *, struct gfc_expr *,
830 struct gfc_expr *);
831 struct gfc_expr *(*cc)(struct gfc_expr *, bt, int);
832 }
833 gfc_simplify_f;
834
835
836 typedef union
837 {
838 void (*f0)(struct gfc_expr *);
839 void (*f1)(struct gfc_expr *, struct gfc_expr *);
840 void (*f1m)(struct gfc_expr *, struct gfc_actual_arglist *);
841 void (*f2)(struct gfc_expr *, struct gfc_expr *, struct gfc_expr *);
842 void (*f3)(struct gfc_expr *, struct gfc_expr *, struct gfc_expr *,
843 struct gfc_expr *);
844 void (*f4)(struct gfc_expr *, struct gfc_expr *, struct gfc_expr *,
845 struct gfc_expr *, struct gfc_expr *);
846 void (*f5)(struct gfc_expr *, struct gfc_expr *, struct gfc_expr *,
847 struct gfc_expr *, struct gfc_expr *, struct gfc_expr *);
848 void (*s1)(struct gfc_code *);
849 }
850 gfc_resolve_f;
851
852
853 typedef struct gfc_intrinsic_sym
854 {
855 char name[GFC_MAX_SYMBOL_LEN + 1], lib_name[GFC_MAX_SYMBOL_LEN + 1];
856 gfc_intrinsic_arg *formal;
857 gfc_typespec ts;
858 int elemental, pure, generic, specific, actual_ok;
859
860 gfc_simplify_f simplify;
861 gfc_check_f check;
862 gfc_resolve_f resolve;
863 struct gfc_intrinsic_sym *specific_head, *next;
864 gfc_generic_isym_id generic_id;
865
866 }
867 gfc_intrinsic_sym;
868
869
870 /* Expression nodes. The expression node types deserve explanations,
871 since the last couple can be easily misconstrued:
872
873 EXPR_OP Operator node pointing to one or two other nodes
874 EXPR_FUNCTION Function call, symbol points to function's name
875 EXPR_CONSTANT A scalar constant: Logical, String, Real, Int or Complex
876 EXPR_VARIABLE An Lvalue with a root symbol and possible reference list
877 which expresses structure, array and substring refs.
878 EXPR_NULL The NULL pointer value (which also has a basic type).
879 EXPR_SUBSTRING A substring of a constant string
880 EXPR_STRUCTURE A structure constructor
881 EXPR_ARRAY An array constructor. */
882
883 #include <gmp.h>
884
885 typedef struct gfc_expr
886 {
887 expr_t expr_type;
888
889 gfc_typespec ts; /* These two refer to the overall expression */
890
891 int rank;
892 mpz_t *shape; /* Can be NULL if shape is unknown at compile time */
893
894 gfc_intrinsic_op operator;
895
896 /* Nonnull for functions and structure constructors */
897 gfc_symtree *symtree;
898
899 gfc_user_op *uop;
900 gfc_ref *ref;
901
902 struct gfc_expr *op1, *op2;
903 locus where;
904
905 union
906 {
907 mpz_t integer;
908 mpf_t real;
909 int logical;
910
911 struct
912 {
913 mpf_t r, i;
914 }
915 complex;
916
917 struct
918 {
919 gfc_actual_arglist *actual;
920 char *name; /* Points to the ultimate name of the function */
921 gfc_intrinsic_sym *isym;
922 gfc_symbol *esym;
923 }
924 function;
925
926 struct
927 {
928 int length;
929 char *string;
930 }
931 character;
932
933 struct gfc_constructor *constructor;
934 }
935 value;
936
937 }
938 gfc_expr;
939
940
941 #define gfc_get_shape(rank) ((mpz_t *) gfc_getmem(rank*sizeof(mpz_t)))
942
943 /* Structures for information associated with different kinds of
944 numbers. The first set of integer parameters define all there is
945 to know about a particular kind. The rest of the elements are
946 computed from the first elements. */
947
948 typedef struct
949 {
950 int kind, radix, digits, bit_size;
951
952 int range;
953 mpz_t huge;
954
955 mpz_t min_int, max_int; /* Values really representable by the target */
956 }
957 gfc_integer_info;
958
959 extern gfc_integer_info gfc_integer_kinds[];
960
961
962 typedef struct
963 {
964 int kind, bit_size;
965
966 }
967 gfc_logical_info;
968
969 extern gfc_logical_info gfc_logical_kinds[];
970
971
972 typedef struct
973 {
974 int kind, radix, digits, min_exponent, max_exponent;
975
976 int range, precision;
977 mpf_t epsilon, huge, tiny;
978 }
979 gfc_real_info;
980
981 extern gfc_real_info gfc_real_kinds[];
982
983
984 /* Equivalence structures. Equivalent lvalues are linked along the
985 *eq pointer, equivalence sets are strung along the *next node. */
986 typedef struct gfc_equiv
987 {
988 struct gfc_equiv *next, *eq;
989 gfc_expr *expr;
990 int used;
991 }
992 gfc_equiv;
993
994 #define gfc_get_equiv() gfc_getmem(sizeof(gfc_equiv))
995
996
997 /* gfc_case stores the selector list of a case statement. The *low
998 and *high pointers can point to the same expression in the case of
999 a single value. If *high is NULL, the selection is from *low
1000 upwards, if *low is NULL the selection is *high downwards.
1001
1002 This structure has separate fields to allow singe and double linked
1003 lists of CASEs the same time. The singe linked list along the NEXT
1004 field is a list of cases for a single CASE label. The double linked
1005 list along the LEFT/RIGHT fields is used to detect overlap and to
1006 build a table of the cases for SELECT constructs with a CHARACTER
1007 case expression. */
1008
1009 typedef struct gfc_case
1010 {
1011 /* Where we saw this case. */
1012 locus where;
1013 int n;
1014
1015 /* Case range values. If (low == high), it's a single value. If one of
1016 the labels is NULL, it's an unbounded case. If both are NULL, this
1017 represents the default case. */
1018 gfc_expr *low, *high;
1019
1020 /* Next case label in the list of cases for a single CASE label. */
1021 struct gfc_case *next;
1022
1023 /* Used for detecting overlap, and for code generation. */
1024 struct gfc_case *left, *right;
1025
1026 /* True if this case label can never be matched. */
1027 int unreachable;
1028 }
1029 gfc_case;
1030
1031 #define gfc_get_case() gfc_getmem(sizeof(gfc_case))
1032
1033
1034 typedef struct
1035 {
1036 gfc_expr *var, *start, *end, *step;
1037 }
1038 gfc_iterator;
1039
1040 #define gfc_get_iterator() gfc_getmem(sizeof(gfc_iterator))
1041
1042
1043 /* Allocation structure for ALLOCATE, DEALLOCATE and NULLIFY statements. */
1044
1045 typedef struct gfc_alloc
1046 {
1047 gfc_expr *expr;
1048 struct gfc_alloc *next;
1049 }
1050 gfc_alloc;
1051
1052 #define gfc_get_alloc() gfc_getmem(sizeof(gfc_alloc))
1053
1054
1055 typedef struct
1056 {
1057 gfc_expr *unit, *file, *status, *access, *form, *recl,
1058 *blank, *position, *action, *delim, *pad, *iostat;
1059 gfc_st_label *err;
1060 }
1061 gfc_open;
1062
1063
1064 typedef struct
1065 {
1066 gfc_expr *unit, *status, *iostat;
1067 gfc_st_label *err;
1068 }
1069 gfc_close;
1070
1071
1072 typedef struct
1073 {
1074 gfc_expr *unit, *iostat;
1075 gfc_st_label *err;
1076 }
1077 gfc_filepos;
1078
1079
1080 typedef struct
1081 {
1082 gfc_expr *unit, *file, *iostat, *exist, *opened, *number, *named,
1083 *name, *access, *sequential, *direct, *form, *formatted,
1084 *unformatted, *recl, *nextrec, *blank, *position, *action, *read,
1085 *write, *readwrite, *delim, *pad, *iolength;
1086
1087 gfc_st_label *err;
1088
1089 }
1090 gfc_inquire;
1091
1092
1093 typedef struct
1094 {
1095 gfc_expr *io_unit, *format_expr, *rec, *advance, *iostat, *size;
1096
1097 gfc_symbol *namelist;
1098 /* A format_label of `format_asterisk' indicates the "*" format */
1099 gfc_st_label *format_label;
1100 gfc_st_label *err, *end, *eor;
1101
1102 locus eor_where, end_where;
1103 }
1104 gfc_dt;
1105
1106
1107 typedef struct gfc_forall_iterator
1108 {
1109 gfc_expr *var, *start, *end, *stride;
1110 struct gfc_forall_iterator *next;
1111 }
1112 gfc_forall_iterator;
1113
1114
1115 /* Executable statements that fill gfc_code structures. */
1116 typedef enum
1117 {
1118 EXEC_NOP = 1, EXEC_ASSIGN, EXEC_LABEL_ASSIGN, EXEC_POINTER_ASSIGN,
1119 EXEC_GOTO, EXEC_CALL, EXEC_RETURN, EXEC_PAUSE, EXEC_STOP, EXEC_CONTINUE,
1120 EXEC_IF, EXEC_ARITHMETIC_IF, EXEC_DO, EXEC_DO_WHILE, EXEC_SELECT,
1121 EXEC_FORALL, EXEC_WHERE, EXEC_CYCLE, EXEC_EXIT,
1122 EXEC_ALLOCATE, EXEC_DEALLOCATE,
1123 EXEC_OPEN, EXEC_CLOSE,
1124 EXEC_READ, EXEC_WRITE, EXEC_IOLENGTH, EXEC_TRANSFER, EXEC_DT_END,
1125 EXEC_BACKSPACE, EXEC_ENDFILE, EXEC_INQUIRE, EXEC_REWIND
1126 }
1127 gfc_exec_op;
1128
1129 typedef struct gfc_code
1130 {
1131 gfc_exec_op op;
1132
1133 struct gfc_code *block, *next;
1134 locus loc;
1135
1136 gfc_st_label *here, *label, *label2, *label3;
1137 gfc_symtree *symtree;
1138 gfc_expr *expr, *expr2;
1139 /* A name isn't sufficient to identify a subroutine, we need the actual
1140 symbol for the interface definition.
1141 const char *sub_name; */
1142 gfc_symbol *resolved_sym;
1143
1144 union
1145 {
1146 gfc_actual_arglist *actual;
1147 gfc_case *case_list;
1148 gfc_iterator *iterator;
1149 gfc_alloc *alloc_list;
1150 gfc_open *open;
1151 gfc_close *close;
1152 gfc_filepos *filepos;
1153 gfc_inquire *inquire;
1154 gfc_dt *dt;
1155 gfc_forall_iterator *forall_iterator;
1156 struct gfc_code *whichloop;
1157 int stop_code;
1158 }
1159 ext; /* Points to additional structures required by statement */
1160
1161 /* Backend_decl is used for cycle and break labels in do loops, and
1162 * probably for other constructs as well, once we translate them. */
1163 tree backend_decl;
1164 }
1165 gfc_code;
1166
1167
1168 /* Storage for DATA statements. */
1169 typedef struct gfc_data_variable
1170 {
1171 gfc_expr *expr;
1172 gfc_iterator iter;
1173 struct gfc_data_variable *list, *next;
1174 }
1175 gfc_data_variable;
1176
1177
1178 typedef struct gfc_data_value
1179 {
1180 int repeat;
1181 gfc_expr *expr;
1182
1183 struct gfc_data_value *next;
1184 }
1185 gfc_data_value;
1186
1187
1188 typedef struct gfc_data
1189 {
1190 gfc_data_variable *var;
1191 gfc_data_value *value;
1192 locus where;
1193
1194 struct gfc_data *next;
1195 }
1196 gfc_data;
1197
1198 #define gfc_get_data_variable() gfc_getmem(sizeof(gfc_data_variable))
1199 #define gfc_get_data_value() gfc_getmem(sizeof(gfc_data_value))
1200 #define gfc_get_data() gfc_getmem(sizeof(gfc_data))
1201
1202
1203 /* Structure for holding compile options */
1204 typedef struct
1205 {
1206 const char *source;
1207 char *module_dir;
1208 gfc_source_form source_form;
1209 int fixed_line_length;
1210 int max_identifier_length;
1211 int verbose;
1212
1213 int warn_aliasing;
1214 int warn_conversion;
1215 int warn_implicit_interface;
1216 int warn_line_truncation;
1217 int warn_surprising;
1218 int warn_unused_labels;
1219
1220 int flag_dollar_ok;
1221 int flag_underscoring;
1222 int flag_second_underscore;
1223 int flag_implicit_none;
1224 int flag_max_stack_var_size;
1225 int flag_module_access_private;
1226 int flag_no_backend;
1227 int flag_pack_derived;
1228 int flag_repack_arrays;
1229
1230 int q_kind;
1231 int r8;
1232 int i8;
1233 int d8;
1234 int warn_std;
1235 int allow_std;
1236 }
1237 gfc_option_t;
1238
1239 extern gfc_option_t gfc_option;
1240
1241
1242 /* Constructor nodes for array and structure constructors. */
1243 typedef struct gfc_constructor
1244 {
1245 gfc_expr *expr;
1246 gfc_iterator *iterator;
1247 locus where;
1248 struct gfc_constructor *next;
1249 struct
1250 {
1251 mpz_t offset; /* Record the offset of array element which appears in
1252 data statement like "data a(5)/4/". */
1253 gfc_component *component; /* Record the component being initialized. */
1254 }
1255 n;
1256 mpz_t repeat; /* Record the repeat number of initial values in data
1257 statement like "data a/5*10/". */
1258 }
1259 gfc_constructor;
1260
1261
1262 typedef struct iterator_stack
1263 {
1264 gfc_symtree *variable;
1265 mpz_t value;
1266 struct iterator_stack *prev;
1267 }
1268 iterator_stack;
1269 extern iterator_stack *iter_stack;
1270
1271 /************************ Function prototypes *************************/
1272
1273 /* data.c */
1274 void gfc_formalize_init_value (gfc_symbol *);
1275 void gfc_get_section_index (gfc_array_ref *, mpz_t *, mpz_t *);
1276 void gfc_assign_data_value (gfc_expr *, gfc_expr *, mpz_t);
1277 void gfc_advance_section (mpz_t *, gfc_array_ref *, mpz_t *);
1278
1279 /* scanner.c */
1280 void gfc_scanner_done_1 (void);
1281 void gfc_scanner_init_1 (void);
1282
1283 void gfc_add_include_path (const char *);
1284 void gfc_release_include_path (void);
1285 FILE *gfc_open_included_file (const char *);
1286
1287 locus *gfc_current_locus (void);
1288 void gfc_set_locus (locus *);
1289
1290 int gfc_at_end (void);
1291 int gfc_at_eof (void);
1292 int gfc_at_bol (void);
1293 int gfc_at_eol (void);
1294 void gfc_advance_line (void);
1295 int gfc_check_include (void);
1296
1297 void gfc_skip_comments (void);
1298 int gfc_next_char_literal (int);
1299 int gfc_next_char (void);
1300 int gfc_peek_char (void);
1301 void gfc_error_recovery (void);
1302 void gfc_gobble_whitespace (void);
1303 try gfc_new_file (const char *, gfc_source_form);
1304
1305 extern gfc_source_form gfc_current_form;
1306 extern char *gfc_source_file;
1307 /* extern locus gfc_current_locus; */
1308
1309 /* misc.c */
1310 void *gfc_getmem (size_t) ATTRIBUTE_MALLOC;
1311 void gfc_free (void *);
1312 int gfc_terminal_width(void);
1313 void gfc_clear_ts (gfc_typespec *);
1314 FILE *gfc_open_file (const char *);
1315 const char *gfc_article (const char *);
1316 const char *gfc_basic_typename (bt);
1317 const char *gfc_typename (gfc_typespec *);
1318
1319 #define gfc_op2string(OP) (OP == INTRINSIC_ASSIGN ? \
1320 "=" : gfc_code2string (intrinsic_operators, OP))
1321
1322 const char *gfc_code2string (const mstring *, int);
1323 int gfc_string2code (const mstring *, const char *);
1324 const char *gfc_intent_string (sym_intent);
1325
1326 void gfc_init_1 (void);
1327 void gfc_init_2 (void);
1328 void gfc_done_1 (void);
1329 void gfc_done_2 (void);
1330
1331 /* options.c */
1332 unsigned int gfc_init_options (unsigned int, const char **);
1333 int gfc_handle_option (size_t, const char *, int);
1334 bool gfc_post_options (const char **);
1335
1336 /* iresolve.c */
1337 char * gfc_get_string (const char *, ...) ATTRIBUTE_PRINTF_1;
1338 void gfc_iresolve_init_1 (void);
1339 void gfc_iresolve_done_1 (void);
1340
1341 /* error.c */
1342
1343 typedef struct gfc_error_buf
1344 {
1345 int flag;
1346 char message[MAX_ERROR_MESSAGE];
1347 } gfc_error_buf;
1348
1349 void gfc_error_init_1 (void);
1350 void gfc_buffer_error (int);
1351
1352 void gfc_warning (const char *, ...);
1353 void gfc_warning_now (const char *, ...);
1354 void gfc_clear_warning (void);
1355 void gfc_warning_check (void);
1356
1357 void gfc_error (const char *, ...);
1358 void gfc_error_now (const char *, ...);
1359 void gfc_fatal_error (const char *, ...) ATTRIBUTE_NORETURN;
1360 void gfc_internal_error (const char *, ...) ATTRIBUTE_NORETURN;
1361 void gfc_clear_error (void);
1362 int gfc_error_check (void);
1363
1364 try gfc_notify_std (int, const char *, ...);
1365
1366 /* A general purpose syntax error. */
1367 #define gfc_syntax_error(ST) \
1368 gfc_error ("Syntax error in %s statement at %C", gfc_ascii_statement (ST));
1369
1370 void gfc_push_error (gfc_error_buf *);
1371 void gfc_pop_error (gfc_error_buf *);
1372
1373 void gfc_status (const char *, ...) ATTRIBUTE_PRINTF_1;
1374 void gfc_status_char (char);
1375
1376 void gfc_get_errors (int *, int *);
1377
1378 /* arith.c */
1379 void gfc_arith_init_1 (void);
1380 void gfc_arith_done_1 (void);
1381
1382 /* FIXME: These should go to symbol.c, really... */
1383 int gfc_default_integer_kind (void);
1384 int gfc_default_real_kind (void);
1385 int gfc_default_double_kind (void);
1386 int gfc_default_character_kind (void);
1387 int gfc_default_logical_kind (void);
1388 int gfc_default_complex_kind (void);
1389 int gfc_validate_kind (bt, int);
1390 extern int gfc_index_integer_kind;
1391
1392 /* symbol.c */
1393 void gfc_clear_new_implicit (void);
1394 try gfc_add_new_implicit_range (int, int, gfc_typespec *);
1395 try gfc_merge_new_implicit (void);
1396 void gfc_set_implicit_none (void);
1397 void gfc_set_implicit (void);
1398
1399 gfc_typespec *gfc_get_default_type (gfc_symbol *, gfc_namespace *);
1400 try gfc_set_default_type (gfc_symbol *, int, gfc_namespace *);
1401
1402 void gfc_set_component_attr (gfc_component *, symbol_attribute *);
1403 void gfc_get_component_attr (symbol_attribute *, gfc_component *);
1404
1405 void gfc_set_sym_referenced (gfc_symbol * sym);
1406
1407 try gfc_add_allocatable (symbol_attribute *, locus *);
1408 try gfc_add_dimension (symbol_attribute *, locus *);
1409 try gfc_add_external (symbol_attribute *, locus *);
1410 try gfc_add_intrinsic (symbol_attribute *, locus *);
1411 try gfc_add_optional (symbol_attribute *, locus *);
1412 try gfc_add_pointer (symbol_attribute *, locus *);
1413 try gfc_add_result (symbol_attribute *, locus *);
1414 try gfc_add_save (symbol_attribute *, locus *);
1415 try gfc_add_saved_common (symbol_attribute *, locus *);
1416 try gfc_add_target (symbol_attribute *, locus *);
1417 try gfc_add_dummy (symbol_attribute *, locus *);
1418 try gfc_add_generic (symbol_attribute *, locus *);
1419 try gfc_add_common (symbol_attribute *, locus *);
1420 try gfc_add_in_common (symbol_attribute *, locus *);
1421 try gfc_add_in_namelist (symbol_attribute *, locus *);
1422 try gfc_add_sequence (symbol_attribute *, locus *);
1423 try gfc_add_elemental (symbol_attribute *, locus *);
1424 try gfc_add_pure (symbol_attribute *, locus *);
1425 try gfc_add_recursive (symbol_attribute *, locus *);
1426 try gfc_add_function (symbol_attribute *, locus *);
1427 try gfc_add_subroutine (symbol_attribute *, locus *);
1428
1429 try gfc_add_access (symbol_attribute *, gfc_access, locus *);
1430 try gfc_add_flavor (symbol_attribute *, sym_flavor, locus *);
1431 try gfc_add_entry (symbol_attribute *, locus *);
1432 try gfc_add_procedure (symbol_attribute *, procedure_type, locus *);
1433 try gfc_add_intent (symbol_attribute *, sym_intent, locus *);
1434 try gfc_add_explicit_interface (gfc_symbol *, ifsrc,
1435 gfc_formal_arglist *, locus *);
1436 try gfc_add_type (gfc_symbol *, gfc_typespec *, locus *);
1437
1438 void gfc_clear_attr (symbol_attribute *);
1439 try gfc_missing_attr (symbol_attribute *, locus *);
1440 try gfc_copy_attr (symbol_attribute *, symbol_attribute *, locus *);
1441
1442 try gfc_add_component (gfc_symbol *, const char *, gfc_component **);
1443 gfc_symbol *gfc_use_derived (gfc_symbol *);
1444 gfc_symtree *gfc_use_derived_tree (gfc_symtree *);
1445 gfc_component *gfc_find_component (gfc_symbol *, const char *);
1446
1447 gfc_st_label *gfc_get_st_label (int);
1448 void gfc_free_st_label (gfc_st_label *);
1449 void gfc_define_st_label (gfc_st_label *, gfc_sl_type, locus *);
1450 try gfc_reference_st_label (gfc_st_label *, gfc_sl_type);
1451
1452 gfc_namespace *gfc_get_namespace (gfc_namespace *);
1453 gfc_symtree *gfc_new_symtree (gfc_symtree **, const char *);
1454 gfc_symtree *gfc_find_symtree (gfc_symtree *, const char *);
1455 gfc_user_op *gfc_get_uop (const char *);
1456 gfc_user_op *gfc_find_uop (const char *, gfc_namespace *);
1457 void gfc_free_symbol (gfc_symbol *);
1458 gfc_symbol *gfc_new_symbol (const char *, gfc_namespace *);
1459 int gfc_find_symbol (const char *, gfc_namespace *, int, gfc_symbol **);
1460 int gfc_find_sym_tree (const char *, gfc_namespace *, int, gfc_symtree **);
1461 int gfc_get_symbol (const char *, gfc_namespace *, gfc_symbol **);
1462 int gfc_get_sym_tree (const char *, gfc_namespace *, gfc_symtree **);
1463 int gfc_get_ha_symbol (const char *, gfc_symbol **);
1464 int gfc_get_ha_sym_tree (const char *, gfc_symtree **);
1465
1466 int gfc_symbols_could_alias (gfc_symbol *, gfc_symbol *);
1467
1468 void gfc_undo_symbols (void);
1469 void gfc_commit_symbols (void);
1470 void gfc_free_namespace (gfc_namespace *);
1471
1472 void gfc_symbol_init_2 (void);
1473 void gfc_symbol_done_2 (void);
1474
1475 void gfc_traverse_symtree (gfc_namespace *, void (*)(gfc_symtree *));
1476 void gfc_traverse_ns (gfc_namespace *, void (*)(gfc_symbol *));
1477 void gfc_traverse_user_op (gfc_namespace *, void (*)(gfc_user_op *));
1478 void gfc_save_all (gfc_namespace *);
1479
1480 void gfc_symbol_state (void);
1481
1482 /* intrinsic.c */
1483 extern int gfc_init_expr;
1484
1485 /* Given a symbol that we have decided is intrinsic, mark it as such
1486 by placing it into a special module that is otherwise impossible to
1487 read or write. */
1488
1489 #define gfc_intrinsic_symbol(SYM) strcpy (SYM->module, "(intrinsic)")
1490
1491 void gfc_intrinsic_init_1 (void);
1492 void gfc_intrinsic_done_1 (void);
1493
1494 char gfc_type_letter (bt);
1495 gfc_symbol * gfc_get_intrinsic_sub_symbol (const char *);
1496 try gfc_convert_type (gfc_expr *, gfc_typespec *, int);
1497 try gfc_convert_type_warn (gfc_expr *, gfc_typespec *, int, int);
1498 int gfc_generic_intrinsic (const char *);
1499 int gfc_specific_intrinsic (const char *);
1500 int gfc_intrinsic_name (const char *, int);
1501 gfc_intrinsic_sym *gfc_find_function (const char *);
1502
1503 match gfc_intrinsic_func_interface (gfc_expr *, int);
1504 match gfc_intrinsic_sub_interface (gfc_code *, int);
1505
1506 /* simplify.c */
1507 void gfc_simplify_init_1 (void);
1508 void gfc_simplify_done_1 (void);
1509
1510 /* match.c -- FIXME */
1511 void gfc_free_iterator (gfc_iterator *, int);
1512 void gfc_free_forall_iterator (gfc_forall_iterator *);
1513 void gfc_free_alloc_list (gfc_alloc *);
1514 void gfc_free_namelist (gfc_namelist *);
1515 void gfc_free_equiv (gfc_equiv *);
1516 void gfc_free_data (gfc_data *);
1517 void gfc_free_case_list (gfc_case *);
1518
1519 /* expr.c */
1520 void gfc_free_actual_arglist (gfc_actual_arglist *);
1521 gfc_actual_arglist *gfc_copy_actual_arglist (gfc_actual_arglist *);
1522 const char *gfc_extract_int (gfc_expr *, int *);
1523
1524 gfc_expr *gfc_build_conversion (gfc_expr *);
1525 void gfc_free_ref_list (gfc_ref *);
1526 void gfc_type_convert_binary (gfc_expr *);
1527 int gfc_is_constant_expr (gfc_expr *);
1528 try gfc_simplify_expr (gfc_expr *, int);
1529
1530 gfc_expr *gfc_get_expr (void);
1531 void gfc_free_expr (gfc_expr *);
1532 void gfc_replace_expr (gfc_expr *, gfc_expr *);
1533 gfc_expr *gfc_int_expr (int);
1534 gfc_expr *gfc_logical_expr (int, locus *);
1535 mpz_t *gfc_copy_shape (mpz_t *, int);
1536 gfc_expr *gfc_copy_expr (gfc_expr *);
1537
1538 try gfc_specification_expr (gfc_expr *);
1539
1540 int gfc_numeric_ts (gfc_typespec *);
1541 int gfc_kind_max (gfc_expr *, gfc_expr *);
1542
1543 try gfc_check_conformance (const char *, gfc_expr *, gfc_expr *);
1544 try gfc_check_assign (gfc_expr *, gfc_expr *, int);
1545 try gfc_check_pointer_assign (gfc_expr *, gfc_expr *);
1546 try gfc_check_assign_symbol (gfc_symbol *, gfc_expr *);
1547
1548 gfc_expr *gfc_default_initializer (gfc_typespec *);
1549
1550 /* st.c */
1551 extern gfc_code new_st;
1552
1553 void gfc_clear_new_st (void);
1554 gfc_code *gfc_get_code (void);
1555 gfc_code *gfc_append_code (gfc_code *, gfc_code *);
1556 void gfc_free_statement (gfc_code *);
1557 void gfc_free_statements (gfc_code *);
1558
1559 /* resolve.c */
1560 try gfc_resolve_expr (gfc_expr *);
1561 void gfc_resolve (gfc_namespace *);
1562 int gfc_impure_variable (gfc_symbol *);
1563 int gfc_pure (gfc_symbol *);
1564 int gfc_elemental (gfc_symbol *);
1565 try gfc_resolve_iterator (gfc_iterator *);
1566 try gfc_resolve_index (gfc_expr *, int);
1567
1568 /* array.c */
1569 void gfc_free_array_spec (gfc_array_spec *);
1570 gfc_array_ref *gfc_copy_array_ref (gfc_array_ref *);
1571
1572 try gfc_set_array_spec (gfc_symbol *, gfc_array_spec *, locus *);
1573 gfc_array_spec *gfc_copy_array_spec (gfc_array_spec *);
1574 try gfc_resolve_array_spec (gfc_array_spec *, int);
1575
1576 int gfc_compare_array_spec (gfc_array_spec *, gfc_array_spec *);
1577
1578 gfc_expr *gfc_start_constructor (bt, int, locus *);
1579 void gfc_append_constructor (gfc_expr *, gfc_expr *);
1580 void gfc_free_constructor (gfc_constructor *);
1581 void gfc_simplify_iterator_var (gfc_expr *);
1582 try gfc_expand_constructor (gfc_expr *);
1583 int gfc_constant_ac (gfc_expr *);
1584 int gfc_expanded_ac (gfc_expr *);
1585 try gfc_resolve_array_constructor (gfc_expr *);
1586 try gfc_check_constructor_type (gfc_expr *);
1587 try gfc_check_iter_variable (gfc_expr *);
1588 try gfc_check_constructor (gfc_expr *, try (*)(gfc_expr *));
1589 gfc_constructor *gfc_copy_constructor (gfc_constructor * src);
1590 gfc_expr *gfc_get_array_element (gfc_expr *, int);
1591 try gfc_array_size (gfc_expr *, mpz_t *);
1592 try gfc_array_dimen_size (gfc_expr *, int, mpz_t *);
1593 try gfc_array_ref_shape (gfc_array_ref *, mpz_t *);
1594 gfc_array_ref *gfc_find_array_ref (gfc_expr *);
1595 void gfc_insert_constructor (gfc_expr *, gfc_constructor *);
1596 gfc_constructor *gfc_get_constructor (void);
1597 tree gfc_conv_array_initializer (tree type, gfc_expr * expr);
1598 try spec_size (gfc_array_spec *, mpz_t *);
1599
1600 /* interface.c -- FIXME: some of these should be in symbol.c */
1601 void gfc_free_interface (gfc_interface *);
1602 int gfc_compare_types (gfc_typespec *, gfc_typespec *);
1603 void gfc_check_interfaces (gfc_namespace *);
1604 void gfc_procedure_use (gfc_symbol *, gfc_actual_arglist **, locus *);
1605 gfc_symbol *gfc_search_interface (gfc_interface *, int,
1606 gfc_actual_arglist **);
1607 try gfc_extend_expr (gfc_expr *);
1608 void gfc_free_formal_arglist (gfc_formal_arglist *);
1609 try gfc_extend_assign (gfc_code *, gfc_namespace *);
1610 try gfc_add_interface (gfc_symbol * sym);
1611
1612 /* io.c */
1613 extern gfc_st_label format_asterisk;
1614
1615 void gfc_free_open (gfc_open *);
1616 try gfc_resolve_open (gfc_open *);
1617 void gfc_free_close (gfc_close *);
1618 try gfc_resolve_close (gfc_close *);
1619 void gfc_free_filepos (gfc_filepos *);
1620 try gfc_resolve_filepos (gfc_filepos *);
1621 void gfc_free_inquire (gfc_inquire *);
1622 try gfc_resolve_inquire (gfc_inquire *);
1623 void gfc_free_dt (gfc_dt *);
1624 try gfc_resolve_dt (gfc_dt *);
1625
1626 /* module.c */
1627 void gfc_module_init_2 (void);
1628 void gfc_module_done_2 (void);
1629 void gfc_dump_module (const char *, int);
1630
1631 /* primary.c */
1632 symbol_attribute gfc_variable_attr (gfc_expr *, gfc_typespec *);
1633 symbol_attribute gfc_expr_attr (gfc_expr *);
1634
1635 /* trans.c */
1636 void gfc_generate_code (gfc_namespace *);
1637 void gfc_generate_module_code (gfc_namespace *);
1638
1639 /* bbt.c */
1640 typedef int (*compare_fn) (void *, void *);
1641 void gfc_insert_bbt (void *, void *, compare_fn);
1642 void gfc_delete_bbt (void *, void *, compare_fn);
1643
1644 /* dump-parse-tree.c */
1645 void gfc_show_namespace (gfc_namespace *);
1646
1647 /* parse.c */
1648 try gfc_parse_file (void);
1649
1650 #endif /* GFC_GFC_H */