gfortran.h (gfc_actual_arglist): New field missing_arg_type.
[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_MAX_SYMBOL_LEN 63
62 #define GFC_REAL_BITS 100 /* Number of bits in g95's floating point numbers. */
63 #define GFC_MAX_LINE 132 /* Characters beyond this are not seen. */
64 #define GFC_MAX_DIMENSIONS 7 /* Maximum dimensions in an array. */
65 #define GFC_LETTERS 26 /* Number of letters in the alphabet. */
66 #define MAX_ERROR_MESSAGE 1000 /* Maximum length of an error message. */
67
68 #define free(x) Use_gfc_free_instead_of_free()
69 #define gfc_is_whitespace(c) ((c==' ') || (c=='\t'))
70
71 #ifndef NULL
72 #define NULL ((void *) 0)
73 #endif
74
75 /* Stringization. */
76 #define stringize(x) expand_macro(x)
77 #define expand_macro(x) # x
78
79 /* For a the runtime library, a standard prefix is a requirement to
80 avoid cluttering the namespace with things nobody asked for. It's
81 ugly to look at and a pain to type when you add the prefix by hand,
82 so we hide it behind a macro. */
83 #define PREFIX(x) "_gfortran_" x
84 #define PREFIX_LEN 10
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 /* This is set to the type of an eventual omitted optional
542 argument. This is used to determine if a hidden string length
543 argument has to be added to a function call. */
544 bt missing_arg_type;
545
546 struct gfc_expr *expr;
547 struct gfc_actual_arglist *next;
548 }
549 gfc_actual_arglist;
550
551 #define gfc_get_actual_arglist() gfc_getmem(sizeof(gfc_actual_arglist))
552
553
554 /* Because a symbol can belong to multiple namelists, they must be
555 linked externally to the symbol itself. */
556 typedef struct gfc_namelist
557 {
558 struct gfc_symbol *sym;
559 struct gfc_namelist *next;
560 }
561 gfc_namelist;
562
563 #define gfc_get_namelist() gfc_getmem(sizeof(gfc_namelist))
564
565
566 /* The gfc_st_label structure is a doubly linked list attached to a
567 namespace that records the usage of statement labels within that
568 space. */
569 /* TODO: Make format/statement specifics a union. */
570 typedef struct gfc_st_label
571 {
572 int value;
573
574 gfc_sl_type defined, referenced;
575
576 struct gfc_expr *format;
577
578 tree backend_decl;
579
580 locus where;
581
582 struct gfc_st_label *prev, *next;
583 }
584 gfc_st_label;
585
586
587 /* gfc_interface()-- Interfaces are lists of symbols strung together. */
588 typedef struct gfc_interface
589 {
590 struct gfc_symbol *sym;
591 locus where;
592 struct gfc_interface *next;
593 }
594 gfc_interface;
595
596 #define gfc_get_interface() gfc_getmem(sizeof(gfc_interface))
597
598
599 /* User operator nodes. These are like stripped down symbols. */
600 typedef struct
601 {
602 char name[GFC_MAX_SYMBOL_LEN + 1];
603
604 gfc_interface *operator;
605 struct gfc_namespace *ns;
606 gfc_access access;
607 }
608 gfc_user_op;
609
610 /* Symbol nodes. These are important things. They are what the
611 standard refers to as "entities". The possibly multiple names that
612 refer to the same entity are accomplished by a binary tree of
613 symtree structures that is balanced by the red-black method-- more
614 than one symtree node can point to any given symbol. */
615
616 typedef struct gfc_symbol
617 {
618 char name[GFC_MAX_SYMBOL_LEN + 1]; /* Primary name, before renaming */
619 char module[GFC_MAX_SYMBOL_LEN + 1]; /* Module this symbol came from */
620 locus declared_at;
621
622 gfc_typespec ts;
623 symbol_attribute attr;
624
625 /* The interface member points to the formal argument list if the
626 symbol is a function or subroutine name. If the symbol is a
627 generic name, the generic member points to the list of
628 interfaces. */
629
630 gfc_interface *generic;
631 gfc_access component_access;
632
633 gfc_formal_arglist *formal;
634 struct gfc_namespace *formal_ns;
635
636 struct gfc_expr *value; /* Parameter/Initializer value */
637 gfc_array_spec *as;
638 struct gfc_symbol *result; /* function result symbol */
639 gfc_component *components; /* Derived type components */
640
641 /* TODO: These three fields are mutually exclusive. */
642 struct gfc_symbol *common_head, *common_next; /* Links for COMMON syms */
643 /* Make sure setup code for dummy arguments is generated in the correct
644 order. */
645 int dummy_order;
646
647 gfc_namelist *namelist, *namelist_tail;
648
649 /* Change management fields. Symbols that might be modified by the
650 current statement have the mark member nonzero and are kept in a
651 singly linked list through the tlink field. Of these symbols,
652 symbols with old_symbol equal to NULL are symbols created within
653 the current statement. Otherwise, old_symbol points to a copy of
654 the old symbol. */
655
656 struct gfc_symbol *old_symbol, *tlink;
657 unsigned mark:1, new:1;
658 /* Nonzero if all equivalences associated with this symbol have been
659 processed. */
660 unsigned equiv_built:1;
661 int refs;
662 struct gfc_namespace *ns; /* namespace containing this symbol */
663
664 tree backend_decl;
665
666 }
667 gfc_symbol;
668
669
670 /* Within a namespace, symbols are pointed to by symtree nodes that
671 are linked together in a balanced binary tree. There can be
672 several symtrees pointing to the same symbol node via USE
673 statements. */
674
675 #define BBT_HEADER(self) int priority; struct self *left, *right
676
677 typedef struct gfc_symtree
678 {
679 BBT_HEADER (gfc_symtree);
680 char name[GFC_MAX_SYMBOL_LEN + 1];
681 int ambiguous;
682 union
683 {
684 gfc_symbol *sym; /* Symbol associated with this node */
685 gfc_user_op *uop;
686 }
687 n;
688
689 }
690 gfc_symtree;
691
692
693 typedef struct gfc_namespace
694 {
695 gfc_symtree *sym_root, *uop_root; /* Roots of the red/black symbol trees */
696
697 int set_flag[GFC_LETTERS];
698 gfc_typespec default_type[GFC_LETTERS]; /* IMPLICIT typespecs */
699
700 struct gfc_symbol *proc_name;
701 gfc_interface *operator[GFC_INTRINSIC_OPS];
702 struct gfc_namespace *parent, *contained, *sibling;
703 struct gfc_code *code;
704 gfc_symbol *blank_common;
705 struct gfc_equiv *equiv;
706 gfc_access default_access, operator_access[GFC_INTRINSIC_OPS];
707
708 gfc_st_label *st_labels;
709 struct gfc_data *data;
710
711 gfc_charlen *cl_list;
712
713 int save_all, seen_save;
714 }
715 gfc_namespace;
716
717 extern gfc_namespace *gfc_current_ns;
718
719
720 /* Information on interfaces being built. */
721 typedef struct
722 {
723 interface_type type;
724 gfc_symbol *sym;
725 gfc_namespace *ns;
726 gfc_user_op *uop;
727 gfc_intrinsic_op op;
728 }
729 gfc_interface_info;
730
731 extern gfc_interface_info current_interface;
732
733
734 /* Array reference. */
735 typedef struct gfc_array_ref
736 {
737 ar_type type;
738 int dimen; /* # of components in the reference */
739 locus where;
740 gfc_array_spec *as;
741
742 locus c_where[GFC_MAX_DIMENSIONS]; /* All expressions can be NULL */
743 struct gfc_expr *start[GFC_MAX_DIMENSIONS], *end[GFC_MAX_DIMENSIONS],
744 *stride[GFC_MAX_DIMENSIONS];
745
746 enum
747 { DIMEN_ELEMENT = 1, DIMEN_RANGE, DIMEN_VECTOR, DIMEN_UNKNOWN }
748 dimen_type[GFC_MAX_DIMENSIONS];
749
750 struct gfc_expr *offset;
751 }
752 gfc_array_ref;
753
754 #define gfc_get_array_ref() gfc_getmem(sizeof(gfc_array_ref))
755
756
757 /* Component reference nodes. A variable is stored as an expression
758 node that points to the base symbol. After that, a singly linked
759 list of component reference nodes gives the variable's complete
760 resolution. The array_ref component may be present and comes
761 before the component component. */
762
763 typedef enum
764 { REF_ARRAY, REF_COMPONENT, REF_SUBSTRING }
765 ref_type;
766
767 typedef struct gfc_ref
768 {
769 ref_type type;
770
771 union
772 {
773 struct gfc_array_ref ar;
774
775 struct
776 {
777 gfc_component *component;
778 gfc_symbol *sym;
779 }
780 c;
781
782 struct
783 {
784 struct gfc_expr *start, *end; /* Substring */
785 gfc_charlen *length;
786 }
787 ss;
788
789 }
790 u;
791
792 struct gfc_ref *next;
793 }
794 gfc_ref;
795
796 #define gfc_get_ref() gfc_getmem(sizeof(gfc_ref))
797
798
799 /* Structures representing intrinsic symbols and their arguments lists. */
800 typedef struct gfc_intrinsic_arg
801 {
802 char name[GFC_MAX_SYMBOL_LEN + 1];
803
804 gfc_typespec ts;
805 int optional;
806 gfc_actual_arglist *actual;
807
808 struct gfc_intrinsic_arg *next;
809
810 }
811 gfc_intrinsic_arg;
812
813
814 typedef union
815 {
816 try (*f1)(struct gfc_expr *);
817 try (*f1m)(gfc_actual_arglist *);
818 try (*f2)(struct gfc_expr *, struct gfc_expr *);
819 try (*f3)(struct gfc_expr *, struct gfc_expr *, struct gfc_expr *);
820 try (*f4)(struct gfc_expr *, struct gfc_expr *, struct gfc_expr *,
821 struct gfc_expr *);
822 try (*f5)(struct gfc_expr *, struct gfc_expr *, struct gfc_expr *,
823 struct gfc_expr *, struct gfc_expr *);
824 }
825 gfc_check_f;
826
827
828 typedef union
829 {
830 struct gfc_expr *(*f1)(struct gfc_expr *);
831 struct gfc_expr *(*f2)(struct gfc_expr *, struct gfc_expr *);
832 struct gfc_expr *(*f3)(struct gfc_expr *, struct gfc_expr *,
833 struct gfc_expr *);
834 struct gfc_expr *(*f4)(struct gfc_expr *, struct gfc_expr *,
835 struct gfc_expr *, struct gfc_expr *);
836 struct gfc_expr *(*f5)(struct gfc_expr *, struct gfc_expr *,
837 struct gfc_expr *, struct gfc_expr *,
838 struct gfc_expr *);
839 struct gfc_expr *(*cc)(struct gfc_expr *, bt, int);
840 }
841 gfc_simplify_f;
842
843
844 typedef union
845 {
846 void (*f0)(struct gfc_expr *);
847 void (*f1)(struct gfc_expr *, struct gfc_expr *);
848 void (*f1m)(struct gfc_expr *, struct gfc_actual_arglist *);
849 void (*f2)(struct gfc_expr *, struct gfc_expr *, struct gfc_expr *);
850 void (*f3)(struct gfc_expr *, struct gfc_expr *, struct gfc_expr *,
851 struct gfc_expr *);
852 void (*f4)(struct gfc_expr *, struct gfc_expr *, struct gfc_expr *,
853 struct gfc_expr *, struct gfc_expr *);
854 void (*f5)(struct gfc_expr *, struct gfc_expr *, struct gfc_expr *,
855 struct gfc_expr *, struct gfc_expr *, struct gfc_expr *);
856 void (*s1)(struct gfc_code *);
857 }
858 gfc_resolve_f;
859
860
861 typedef struct gfc_intrinsic_sym
862 {
863 char name[GFC_MAX_SYMBOL_LEN + 1], lib_name[GFC_MAX_SYMBOL_LEN + 1];
864 gfc_intrinsic_arg *formal;
865 gfc_typespec ts;
866 int elemental, pure, generic, specific, actual_ok;
867
868 gfc_simplify_f simplify;
869 gfc_check_f check;
870 gfc_resolve_f resolve;
871 struct gfc_intrinsic_sym *specific_head, *next;
872 gfc_generic_isym_id generic_id;
873
874 }
875 gfc_intrinsic_sym;
876
877
878 /* Expression nodes. The expression node types deserve explanations,
879 since the last couple can be easily misconstrued:
880
881 EXPR_OP Operator node pointing to one or two other nodes
882 EXPR_FUNCTION Function call, symbol points to function's name
883 EXPR_CONSTANT A scalar constant: Logical, String, Real, Int or Complex
884 EXPR_VARIABLE An Lvalue with a root symbol and possible reference list
885 which expresses structure, array and substring refs.
886 EXPR_NULL The NULL pointer value (which also has a basic type).
887 EXPR_SUBSTRING A substring of a constant string
888 EXPR_STRUCTURE A structure constructor
889 EXPR_ARRAY An array constructor. */
890
891 #include <gmp.h>
892
893 typedef struct gfc_expr
894 {
895 expr_t expr_type;
896
897 gfc_typespec ts; /* These two refer to the overall expression */
898
899 int rank;
900 mpz_t *shape; /* Can be NULL if shape is unknown at compile time */
901
902 gfc_intrinsic_op operator;
903
904 /* Nonnull for functions and structure constructors */
905 gfc_symtree *symtree;
906
907 gfc_user_op *uop;
908 gfc_ref *ref;
909
910 struct gfc_expr *op1, *op2;
911 locus where;
912
913 union
914 {
915 mpz_t integer;
916 mpf_t real;
917 int logical;
918
919 struct
920 {
921 mpf_t r, i;
922 }
923 complex;
924
925 struct
926 {
927 gfc_actual_arglist *actual;
928 char *name; /* Points to the ultimate name of the function */
929 gfc_intrinsic_sym *isym;
930 gfc_symbol *esym;
931 }
932 function;
933
934 struct
935 {
936 int length;
937 char *string;
938 }
939 character;
940
941 struct gfc_constructor *constructor;
942 }
943 value;
944
945 }
946 gfc_expr;
947
948
949 #define gfc_get_shape(rank) ((mpz_t *) gfc_getmem(rank*sizeof(mpz_t)))
950
951 /* Structures for information associated with different kinds of
952 numbers. The first set of integer parameters define all there is
953 to know about a particular kind. The rest of the elements are
954 computed from the first elements. */
955
956 typedef struct
957 {
958 int kind, radix, digits, bit_size;
959
960 int range;
961 mpz_t huge;
962
963 mpz_t min_int, max_int; /* Values really representable by the target */
964 }
965 gfc_integer_info;
966
967 extern gfc_integer_info gfc_integer_kinds[];
968
969
970 typedef struct
971 {
972 int kind, bit_size;
973
974 }
975 gfc_logical_info;
976
977 extern gfc_logical_info gfc_logical_kinds[];
978
979
980 typedef struct
981 {
982 int kind, radix, digits, min_exponent, max_exponent;
983
984 int range, precision;
985 mpf_t epsilon, huge, tiny;
986 }
987 gfc_real_info;
988
989 extern gfc_real_info gfc_real_kinds[];
990
991
992 /* Equivalence structures. Equivalent lvalues are linked along the
993 *eq pointer, equivalence sets are strung along the *next node. */
994 typedef struct gfc_equiv
995 {
996 struct gfc_equiv *next, *eq;
997 gfc_expr *expr;
998 int used;
999 }
1000 gfc_equiv;
1001
1002 #define gfc_get_equiv() gfc_getmem(sizeof(gfc_equiv))
1003
1004
1005 /* gfc_case stores the selector list of a case statement. The *low
1006 and *high pointers can point to the same expression in the case of
1007 a single value. If *high is NULL, the selection is from *low
1008 upwards, if *low is NULL the selection is *high downwards.
1009
1010 This structure has separate fields to allow singe and double linked
1011 lists of CASEs the same time. The singe linked list along the NEXT
1012 field is a list of cases for a single CASE label. The double linked
1013 list along the LEFT/RIGHT fields is used to detect overlap and to
1014 build a table of the cases for SELECT constructs with a CHARACTER
1015 case expression. */
1016
1017 typedef struct gfc_case
1018 {
1019 /* Where we saw this case. */
1020 locus where;
1021 int n;
1022
1023 /* Case range values. If (low == high), it's a single value. If one of
1024 the labels is NULL, it's an unbounded case. If both are NULL, this
1025 represents the default case. */
1026 gfc_expr *low, *high;
1027
1028 /* Next case label in the list of cases for a single CASE label. */
1029 struct gfc_case *next;
1030
1031 /* Used for detecting overlap, and for code generation. */
1032 struct gfc_case *left, *right;
1033
1034 /* True if this case label can never be matched. */
1035 int unreachable;
1036 }
1037 gfc_case;
1038
1039 #define gfc_get_case() gfc_getmem(sizeof(gfc_case))
1040
1041
1042 typedef struct
1043 {
1044 gfc_expr *var, *start, *end, *step;
1045 }
1046 gfc_iterator;
1047
1048 #define gfc_get_iterator() gfc_getmem(sizeof(gfc_iterator))
1049
1050
1051 /* Allocation structure for ALLOCATE, DEALLOCATE and NULLIFY statements. */
1052
1053 typedef struct gfc_alloc
1054 {
1055 gfc_expr *expr;
1056 struct gfc_alloc *next;
1057 }
1058 gfc_alloc;
1059
1060 #define gfc_get_alloc() gfc_getmem(sizeof(gfc_alloc))
1061
1062
1063 typedef struct
1064 {
1065 gfc_expr *unit, *file, *status, *access, *form, *recl,
1066 *blank, *position, *action, *delim, *pad, *iostat;
1067 gfc_st_label *err;
1068 }
1069 gfc_open;
1070
1071
1072 typedef struct
1073 {
1074 gfc_expr *unit, *status, *iostat;
1075 gfc_st_label *err;
1076 }
1077 gfc_close;
1078
1079
1080 typedef struct
1081 {
1082 gfc_expr *unit, *iostat;
1083 gfc_st_label *err;
1084 }
1085 gfc_filepos;
1086
1087
1088 typedef struct
1089 {
1090 gfc_expr *unit, *file, *iostat, *exist, *opened, *number, *named,
1091 *name, *access, *sequential, *direct, *form, *formatted,
1092 *unformatted, *recl, *nextrec, *blank, *position, *action, *read,
1093 *write, *readwrite, *delim, *pad, *iolength;
1094
1095 gfc_st_label *err;
1096
1097 }
1098 gfc_inquire;
1099
1100
1101 typedef struct
1102 {
1103 gfc_expr *io_unit, *format_expr, *rec, *advance, *iostat, *size;
1104
1105 gfc_symbol *namelist;
1106 /* A format_label of `format_asterisk' indicates the "*" format */
1107 gfc_st_label *format_label;
1108 gfc_st_label *err, *end, *eor;
1109
1110 locus eor_where, end_where;
1111 }
1112 gfc_dt;
1113
1114
1115 typedef struct gfc_forall_iterator
1116 {
1117 gfc_expr *var, *start, *end, *stride;
1118 struct gfc_forall_iterator *next;
1119 }
1120 gfc_forall_iterator;
1121
1122
1123 /* Executable statements that fill gfc_code structures. */
1124 typedef enum
1125 {
1126 EXEC_NOP = 1, EXEC_ASSIGN, EXEC_LABEL_ASSIGN, EXEC_POINTER_ASSIGN,
1127 EXEC_GOTO, EXEC_CALL, EXEC_RETURN, EXEC_PAUSE, EXEC_STOP, EXEC_CONTINUE,
1128 EXEC_IF, EXEC_ARITHMETIC_IF, EXEC_DO, EXEC_DO_WHILE, EXEC_SELECT,
1129 EXEC_FORALL, EXEC_WHERE, EXEC_CYCLE, EXEC_EXIT,
1130 EXEC_ALLOCATE, EXEC_DEALLOCATE,
1131 EXEC_OPEN, EXEC_CLOSE,
1132 EXEC_READ, EXEC_WRITE, EXEC_IOLENGTH, EXEC_TRANSFER, EXEC_DT_END,
1133 EXEC_BACKSPACE, EXEC_ENDFILE, EXEC_INQUIRE, EXEC_REWIND
1134 }
1135 gfc_exec_op;
1136
1137 typedef struct gfc_code
1138 {
1139 gfc_exec_op op;
1140
1141 struct gfc_code *block, *next;
1142 locus loc;
1143
1144 gfc_st_label *here, *label, *label2, *label3;
1145 gfc_symtree *symtree;
1146 gfc_expr *expr, *expr2;
1147 /* A name isn't sufficient to identify a subroutine, we need the actual
1148 symbol for the interface definition.
1149 const char *sub_name; */
1150 gfc_symbol *resolved_sym;
1151
1152 union
1153 {
1154 gfc_actual_arglist *actual;
1155 gfc_case *case_list;
1156 gfc_iterator *iterator;
1157 gfc_alloc *alloc_list;
1158 gfc_open *open;
1159 gfc_close *close;
1160 gfc_filepos *filepos;
1161 gfc_inquire *inquire;
1162 gfc_dt *dt;
1163 gfc_forall_iterator *forall_iterator;
1164 struct gfc_code *whichloop;
1165 int stop_code;
1166 }
1167 ext; /* Points to additional structures required by statement */
1168
1169 /* Backend_decl is used for cycle and break labels in do loops, and
1170 * probably for other constructs as well, once we translate them. */
1171 tree backend_decl;
1172 }
1173 gfc_code;
1174
1175
1176 /* Storage for DATA statements. */
1177 typedef struct gfc_data_variable
1178 {
1179 gfc_expr *expr;
1180 gfc_iterator iter;
1181 struct gfc_data_variable *list, *next;
1182 }
1183 gfc_data_variable;
1184
1185
1186 typedef struct gfc_data_value
1187 {
1188 int repeat;
1189 gfc_expr *expr;
1190
1191 struct gfc_data_value *next;
1192 }
1193 gfc_data_value;
1194
1195
1196 typedef struct gfc_data
1197 {
1198 gfc_data_variable *var;
1199 gfc_data_value *value;
1200 locus where;
1201
1202 struct gfc_data *next;
1203 }
1204 gfc_data;
1205
1206 #define gfc_get_data_variable() gfc_getmem(sizeof(gfc_data_variable))
1207 #define gfc_get_data_value() gfc_getmem(sizeof(gfc_data_value))
1208 #define gfc_get_data() gfc_getmem(sizeof(gfc_data))
1209
1210
1211 /* Structure for holding compile options */
1212 typedef struct
1213 {
1214 const char *source;
1215 char *module_dir;
1216 gfc_source_form source_form;
1217 int fixed_line_length;
1218 int max_identifier_length;
1219 int verbose;
1220
1221 int warn_aliasing;
1222 int warn_conversion;
1223 int warn_implicit_interface;
1224 int warn_line_truncation;
1225 int warn_underflow;
1226 int warn_surprising;
1227 int warn_unused_labels;
1228
1229 int flag_dollar_ok;
1230 int flag_underscoring;
1231 int flag_second_underscore;
1232 int flag_implicit_none;
1233 int flag_max_stack_var_size;
1234 int flag_module_access_private;
1235 int flag_no_backend;
1236 int flag_pack_derived;
1237 int flag_repack_arrays;
1238
1239 int q_kind;
1240 int r8;
1241 int i8;
1242 int d8;
1243 int warn_std;
1244 int allow_std;
1245 }
1246 gfc_option_t;
1247
1248 extern gfc_option_t gfc_option;
1249
1250
1251 /* Constructor nodes for array and structure constructors. */
1252 typedef struct gfc_constructor
1253 {
1254 gfc_expr *expr;
1255 gfc_iterator *iterator;
1256 locus where;
1257 struct gfc_constructor *next;
1258 struct
1259 {
1260 mpz_t offset; /* Record the offset of array element which appears in
1261 data statement like "data a(5)/4/". */
1262 gfc_component *component; /* Record the component being initialized. */
1263 }
1264 n;
1265 mpz_t repeat; /* Record the repeat number of initial values in data
1266 statement like "data a/5*10/". */
1267 }
1268 gfc_constructor;
1269
1270
1271 typedef struct iterator_stack
1272 {
1273 gfc_symtree *variable;
1274 mpz_t value;
1275 struct iterator_stack *prev;
1276 }
1277 iterator_stack;
1278 extern iterator_stack *iter_stack;
1279
1280 /************************ Function prototypes *************************/
1281
1282 /* data.c */
1283 void gfc_formalize_init_value (gfc_symbol *);
1284 void gfc_get_section_index (gfc_array_ref *, mpz_t *, mpz_t *);
1285 void gfc_assign_data_value (gfc_expr *, gfc_expr *, mpz_t);
1286 void gfc_advance_section (mpz_t *, gfc_array_ref *, mpz_t *);
1287
1288 /* scanner.c */
1289 void gfc_scanner_done_1 (void);
1290 void gfc_scanner_init_1 (void);
1291
1292 void gfc_add_include_path (const char *);
1293 void gfc_release_include_path (void);
1294 FILE *gfc_open_included_file (const char *);
1295
1296 int gfc_at_end (void);
1297 int gfc_at_eof (void);
1298 int gfc_at_bol (void);
1299 int gfc_at_eol (void);
1300 void gfc_advance_line (void);
1301 int gfc_check_include (void);
1302
1303 void gfc_skip_comments (void);
1304 int gfc_next_char_literal (int);
1305 int gfc_next_char (void);
1306 int gfc_peek_char (void);
1307 void gfc_error_recovery (void);
1308 void gfc_gobble_whitespace (void);
1309 try gfc_new_file (const char *, gfc_source_form);
1310
1311 extern gfc_source_form gfc_current_form;
1312 extern char *gfc_source_file;
1313 extern locus gfc_current_locus;
1314
1315 /* misc.c */
1316 void *gfc_getmem (size_t) ATTRIBUTE_MALLOC;
1317 void gfc_free (void *);
1318 int gfc_terminal_width(void);
1319 void gfc_clear_ts (gfc_typespec *);
1320 FILE *gfc_open_file (const char *);
1321 const char *gfc_article (const char *);
1322 const char *gfc_basic_typename (bt);
1323 const char *gfc_typename (gfc_typespec *);
1324
1325 #define gfc_op2string(OP) (OP == INTRINSIC_ASSIGN ? \
1326 "=" : gfc_code2string (intrinsic_operators, OP))
1327
1328 const char *gfc_code2string (const mstring *, int);
1329 int gfc_string2code (const mstring *, const char *);
1330 const char *gfc_intent_string (sym_intent);
1331
1332 void gfc_init_1 (void);
1333 void gfc_init_2 (void);
1334 void gfc_done_1 (void);
1335 void gfc_done_2 (void);
1336
1337 /* options.c */
1338 unsigned int gfc_init_options (unsigned int, const char **);
1339 int gfc_handle_option (size_t, const char *, int);
1340 bool gfc_post_options (const char **);
1341
1342 /* iresolve.c */
1343 char * gfc_get_string (const char *, ...) ATTRIBUTE_PRINTF_1;
1344 void gfc_iresolve_init_1 (void);
1345 void gfc_iresolve_done_1 (void);
1346
1347 /* error.c */
1348
1349 typedef struct gfc_error_buf
1350 {
1351 int flag;
1352 char message[MAX_ERROR_MESSAGE];
1353 } gfc_error_buf;
1354
1355 void gfc_error_init_1 (void);
1356 void gfc_buffer_error (int);
1357
1358 void gfc_warning (const char *, ...);
1359 void gfc_warning_now (const char *, ...);
1360 void gfc_clear_warning (void);
1361 void gfc_warning_check (void);
1362
1363 void gfc_error (const char *, ...);
1364 void gfc_error_now (const char *, ...);
1365 void gfc_fatal_error (const char *, ...) ATTRIBUTE_NORETURN;
1366 void gfc_internal_error (const char *, ...) ATTRIBUTE_NORETURN;
1367 void gfc_clear_error (void);
1368 int gfc_error_check (void);
1369
1370 try gfc_notify_std (int, const char *, ...);
1371
1372 /* A general purpose syntax error. */
1373 #define gfc_syntax_error(ST) \
1374 gfc_error ("Syntax error in %s statement at %C", gfc_ascii_statement (ST));
1375
1376 void gfc_push_error (gfc_error_buf *);
1377 void gfc_pop_error (gfc_error_buf *);
1378
1379 void gfc_status (const char *, ...) ATTRIBUTE_PRINTF_1;
1380 void gfc_status_char (char);
1381
1382 void gfc_get_errors (int *, int *);
1383
1384 /* arith.c */
1385 void gfc_arith_init_1 (void);
1386 void gfc_arith_done_1 (void);
1387
1388 /* FIXME: These should go to symbol.c, really... */
1389 int gfc_default_integer_kind (void);
1390 int gfc_default_real_kind (void);
1391 int gfc_default_double_kind (void);
1392 int gfc_default_character_kind (void);
1393 int gfc_default_logical_kind (void);
1394 int gfc_default_complex_kind (void);
1395 int gfc_validate_kind (bt, int);
1396 extern int gfc_index_integer_kind;
1397
1398 /* symbol.c */
1399 void gfc_clear_new_implicit (void);
1400 try gfc_add_new_implicit_range (int, int, gfc_typespec *);
1401 try gfc_merge_new_implicit (void);
1402 void gfc_set_implicit_none (void);
1403 void gfc_set_implicit (void);
1404
1405 gfc_typespec *gfc_get_default_type (gfc_symbol *, gfc_namespace *);
1406 try gfc_set_default_type (gfc_symbol *, int, gfc_namespace *);
1407
1408 void gfc_set_component_attr (gfc_component *, symbol_attribute *);
1409 void gfc_get_component_attr (symbol_attribute *, gfc_component *);
1410
1411 void gfc_set_sym_referenced (gfc_symbol * sym);
1412
1413 try gfc_add_allocatable (symbol_attribute *, locus *);
1414 try gfc_add_dimension (symbol_attribute *, locus *);
1415 try gfc_add_external (symbol_attribute *, locus *);
1416 try gfc_add_intrinsic (symbol_attribute *, locus *);
1417 try gfc_add_optional (symbol_attribute *, locus *);
1418 try gfc_add_pointer (symbol_attribute *, locus *);
1419 try gfc_add_result (symbol_attribute *, locus *);
1420 try gfc_add_save (symbol_attribute *, locus *);
1421 try gfc_add_saved_common (symbol_attribute *, locus *);
1422 try gfc_add_target (symbol_attribute *, locus *);
1423 try gfc_add_dummy (symbol_attribute *, locus *);
1424 try gfc_add_generic (symbol_attribute *, locus *);
1425 try gfc_add_common (symbol_attribute *, locus *);
1426 try gfc_add_in_common (symbol_attribute *, locus *);
1427 try gfc_add_in_namelist (symbol_attribute *, locus *);
1428 try gfc_add_sequence (symbol_attribute *, locus *);
1429 try gfc_add_elemental (symbol_attribute *, locus *);
1430 try gfc_add_pure (symbol_attribute *, locus *);
1431 try gfc_add_recursive (symbol_attribute *, locus *);
1432 try gfc_add_function (symbol_attribute *, locus *);
1433 try gfc_add_subroutine (symbol_attribute *, locus *);
1434
1435 try gfc_add_access (symbol_attribute *, gfc_access, locus *);
1436 try gfc_add_flavor (symbol_attribute *, sym_flavor, locus *);
1437 try gfc_add_entry (symbol_attribute *, locus *);
1438 try gfc_add_procedure (symbol_attribute *, procedure_type, locus *);
1439 try gfc_add_intent (symbol_attribute *, sym_intent, locus *);
1440 try gfc_add_explicit_interface (gfc_symbol *, ifsrc,
1441 gfc_formal_arglist *, locus *);
1442 try gfc_add_type (gfc_symbol *, gfc_typespec *, locus *);
1443
1444 void gfc_clear_attr (symbol_attribute *);
1445 try gfc_missing_attr (symbol_attribute *, locus *);
1446 try gfc_copy_attr (symbol_attribute *, symbol_attribute *, locus *);
1447
1448 try gfc_add_component (gfc_symbol *, const char *, gfc_component **);
1449 gfc_symbol *gfc_use_derived (gfc_symbol *);
1450 gfc_symtree *gfc_use_derived_tree (gfc_symtree *);
1451 gfc_component *gfc_find_component (gfc_symbol *, const char *);
1452
1453 gfc_st_label *gfc_get_st_label (int);
1454 void gfc_free_st_label (gfc_st_label *);
1455 void gfc_define_st_label (gfc_st_label *, gfc_sl_type, locus *);
1456 try gfc_reference_st_label (gfc_st_label *, gfc_sl_type);
1457
1458 gfc_namespace *gfc_get_namespace (gfc_namespace *);
1459 gfc_symtree *gfc_new_symtree (gfc_symtree **, const char *);
1460 gfc_symtree *gfc_find_symtree (gfc_symtree *, const char *);
1461 gfc_user_op *gfc_get_uop (const char *);
1462 gfc_user_op *gfc_find_uop (const char *, gfc_namespace *);
1463 void gfc_free_symbol (gfc_symbol *);
1464 gfc_symbol *gfc_new_symbol (const char *, gfc_namespace *);
1465 int gfc_find_symbol (const char *, gfc_namespace *, int, gfc_symbol **);
1466 int gfc_find_sym_tree (const char *, gfc_namespace *, int, gfc_symtree **);
1467 int gfc_get_symbol (const char *, gfc_namespace *, gfc_symbol **);
1468 int gfc_get_sym_tree (const char *, gfc_namespace *, gfc_symtree **);
1469 int gfc_get_ha_symbol (const char *, gfc_symbol **);
1470 int gfc_get_ha_sym_tree (const char *, gfc_symtree **);
1471
1472 int gfc_symbols_could_alias (gfc_symbol *, gfc_symbol *);
1473
1474 void gfc_undo_symbols (void);
1475 void gfc_commit_symbols (void);
1476 void gfc_free_namespace (gfc_namespace *);
1477
1478 void gfc_symbol_init_2 (void);
1479 void gfc_symbol_done_2 (void);
1480
1481 void gfc_traverse_symtree (gfc_namespace *, void (*)(gfc_symtree *));
1482 void gfc_traverse_ns (gfc_namespace *, void (*)(gfc_symbol *));
1483 void gfc_traverse_user_op (gfc_namespace *, void (*)(gfc_user_op *));
1484 void gfc_save_all (gfc_namespace *);
1485
1486 void gfc_symbol_state (void);
1487
1488 /* intrinsic.c */
1489 extern int gfc_init_expr;
1490
1491 /* Given a symbol that we have decided is intrinsic, mark it as such
1492 by placing it into a special module that is otherwise impossible to
1493 read or write. */
1494
1495 #define gfc_intrinsic_symbol(SYM) strcpy (SYM->module, "(intrinsic)")
1496
1497 void gfc_intrinsic_init_1 (void);
1498 void gfc_intrinsic_done_1 (void);
1499
1500 char gfc_type_letter (bt);
1501 gfc_symbol * gfc_get_intrinsic_sub_symbol (const char *);
1502 try gfc_convert_type (gfc_expr *, gfc_typespec *, int);
1503 try gfc_convert_type_warn (gfc_expr *, gfc_typespec *, int, int);
1504 int gfc_generic_intrinsic (const char *);
1505 int gfc_specific_intrinsic (const char *);
1506 int gfc_intrinsic_name (const char *, int);
1507 gfc_intrinsic_sym *gfc_find_function (const char *);
1508
1509 match gfc_intrinsic_func_interface (gfc_expr *, int);
1510 match gfc_intrinsic_sub_interface (gfc_code *, int);
1511
1512 /* simplify.c */
1513 void gfc_simplify_init_1 (void);
1514 void gfc_simplify_done_1 (void);
1515
1516 /* match.c -- FIXME */
1517 void gfc_free_iterator (gfc_iterator *, int);
1518 void gfc_free_forall_iterator (gfc_forall_iterator *);
1519 void gfc_free_alloc_list (gfc_alloc *);
1520 void gfc_free_namelist (gfc_namelist *);
1521 void gfc_free_equiv (gfc_equiv *);
1522 void gfc_free_data (gfc_data *);
1523 void gfc_free_case_list (gfc_case *);
1524
1525 /* expr.c */
1526 void gfc_free_actual_arglist (gfc_actual_arglist *);
1527 gfc_actual_arglist *gfc_copy_actual_arglist (gfc_actual_arglist *);
1528 const char *gfc_extract_int (gfc_expr *, int *);
1529
1530 gfc_expr *gfc_build_conversion (gfc_expr *);
1531 void gfc_free_ref_list (gfc_ref *);
1532 void gfc_type_convert_binary (gfc_expr *);
1533 int gfc_is_constant_expr (gfc_expr *);
1534 try gfc_simplify_expr (gfc_expr *, int);
1535
1536 gfc_expr *gfc_get_expr (void);
1537 void gfc_free_expr (gfc_expr *);
1538 void gfc_replace_expr (gfc_expr *, gfc_expr *);
1539 gfc_expr *gfc_int_expr (int);
1540 gfc_expr *gfc_logical_expr (int, locus *);
1541 mpz_t *gfc_copy_shape (mpz_t *, int);
1542 gfc_expr *gfc_copy_expr (gfc_expr *);
1543
1544 try gfc_specification_expr (gfc_expr *);
1545
1546 int gfc_numeric_ts (gfc_typespec *);
1547 int gfc_kind_max (gfc_expr *, gfc_expr *);
1548
1549 try gfc_check_conformance (const char *, gfc_expr *, gfc_expr *);
1550 try gfc_check_assign (gfc_expr *, gfc_expr *, int);
1551 try gfc_check_pointer_assign (gfc_expr *, gfc_expr *);
1552 try gfc_check_assign_symbol (gfc_symbol *, gfc_expr *);
1553
1554 gfc_expr *gfc_default_initializer (gfc_typespec *);
1555
1556 /* st.c */
1557 extern gfc_code new_st;
1558
1559 void gfc_clear_new_st (void);
1560 gfc_code *gfc_get_code (void);
1561 gfc_code *gfc_append_code (gfc_code *, gfc_code *);
1562 void gfc_free_statement (gfc_code *);
1563 void gfc_free_statements (gfc_code *);
1564
1565 /* resolve.c */
1566 try gfc_resolve_expr (gfc_expr *);
1567 void gfc_resolve (gfc_namespace *);
1568 int gfc_impure_variable (gfc_symbol *);
1569 int gfc_pure (gfc_symbol *);
1570 int gfc_elemental (gfc_symbol *);
1571 try gfc_resolve_iterator (gfc_iterator *);
1572 try gfc_resolve_index (gfc_expr *, int);
1573
1574 /* array.c */
1575 void gfc_free_array_spec (gfc_array_spec *);
1576 gfc_array_ref *gfc_copy_array_ref (gfc_array_ref *);
1577
1578 try gfc_set_array_spec (gfc_symbol *, gfc_array_spec *, locus *);
1579 gfc_array_spec *gfc_copy_array_spec (gfc_array_spec *);
1580 try gfc_resolve_array_spec (gfc_array_spec *, int);
1581
1582 int gfc_compare_array_spec (gfc_array_spec *, gfc_array_spec *);
1583
1584 gfc_expr *gfc_start_constructor (bt, int, locus *);
1585 void gfc_append_constructor (gfc_expr *, gfc_expr *);
1586 void gfc_free_constructor (gfc_constructor *);
1587 void gfc_simplify_iterator_var (gfc_expr *);
1588 try gfc_expand_constructor (gfc_expr *);
1589 int gfc_constant_ac (gfc_expr *);
1590 int gfc_expanded_ac (gfc_expr *);
1591 try gfc_resolve_array_constructor (gfc_expr *);
1592 try gfc_check_constructor_type (gfc_expr *);
1593 try gfc_check_iter_variable (gfc_expr *);
1594 try gfc_check_constructor (gfc_expr *, try (*)(gfc_expr *));
1595 gfc_constructor *gfc_copy_constructor (gfc_constructor * src);
1596 gfc_expr *gfc_get_array_element (gfc_expr *, int);
1597 try gfc_array_size (gfc_expr *, mpz_t *);
1598 try gfc_array_dimen_size (gfc_expr *, int, mpz_t *);
1599 try gfc_array_ref_shape (gfc_array_ref *, mpz_t *);
1600 gfc_array_ref *gfc_find_array_ref (gfc_expr *);
1601 void gfc_insert_constructor (gfc_expr *, gfc_constructor *);
1602 gfc_constructor *gfc_get_constructor (void);
1603 tree gfc_conv_array_initializer (tree type, gfc_expr * expr);
1604 try spec_size (gfc_array_spec *, mpz_t *);
1605
1606 /* interface.c -- FIXME: some of these should be in symbol.c */
1607 void gfc_free_interface (gfc_interface *);
1608 int gfc_compare_types (gfc_typespec *, gfc_typespec *);
1609 void gfc_check_interfaces (gfc_namespace *);
1610 void gfc_procedure_use (gfc_symbol *, gfc_actual_arglist **, locus *);
1611 gfc_symbol *gfc_search_interface (gfc_interface *, int,
1612 gfc_actual_arglist **);
1613 try gfc_extend_expr (gfc_expr *);
1614 void gfc_free_formal_arglist (gfc_formal_arglist *);
1615 try gfc_extend_assign (gfc_code *, gfc_namespace *);
1616 try gfc_add_interface (gfc_symbol * sym);
1617
1618 /* io.c */
1619 extern gfc_st_label format_asterisk;
1620
1621 void gfc_free_open (gfc_open *);
1622 try gfc_resolve_open (gfc_open *);
1623 void gfc_free_close (gfc_close *);
1624 try gfc_resolve_close (gfc_close *);
1625 void gfc_free_filepos (gfc_filepos *);
1626 try gfc_resolve_filepos (gfc_filepos *);
1627 void gfc_free_inquire (gfc_inquire *);
1628 try gfc_resolve_inquire (gfc_inquire *);
1629 void gfc_free_dt (gfc_dt *);
1630 try gfc_resolve_dt (gfc_dt *);
1631
1632 /* module.c */
1633 void gfc_module_init_2 (void);
1634 void gfc_module_done_2 (void);
1635 void gfc_dump_module (const char *, int);
1636
1637 /* primary.c */
1638 symbol_attribute gfc_variable_attr (gfc_expr *, gfc_typespec *);
1639 symbol_attribute gfc_expr_attr (gfc_expr *);
1640
1641 /* trans.c */
1642 void gfc_generate_code (gfc_namespace *);
1643 void gfc_generate_module_code (gfc_namespace *);
1644
1645 /* bbt.c */
1646 typedef int (*compare_fn) (void *, void *);
1647 void gfc_insert_bbt (void *, void *, compare_fn);
1648 void gfc_delete_bbt (void *, void *, compare_fn);
1649
1650 /* dump-parse-tree.c */
1651 void gfc_show_namespace (gfc_namespace *);
1652
1653 /* parse.c */
1654 try gfc_parse_file (void);
1655
1656 #endif /* GFC_GFC_H */