Move entry to proper file.
[official-gcc.git] / gcc / fortran / symbol.c
blob63e45ecb5fe7ae58fcf7800ff941afd6836305c2
1 /* Maintain binary trees of symbols.
2 Copyright (C) 2000, 2001, 2002, 2003, 2004, 2005, 2006 Free Software
3 Foundation, Inc.
4 Contributed by Andy Vaught
6 This file is part of GCC.
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.
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.
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, 51 Franklin Street, Fifth Floor, Boston, MA
21 02110-1301, USA. */
24 #include "config.h"
25 #include "system.h"
26 #include "flags.h"
27 #include "gfortran.h"
28 #include "parse.h"
30 /* Strings for all symbol attributes. We use these for dumping the
31 parse tree, in error messages, and also when reading and writing
32 modules. */
34 const mstring flavors[] =
36 minit ("UNKNOWN-FL", FL_UNKNOWN), minit ("PROGRAM", FL_PROGRAM),
37 minit ("BLOCK-DATA", FL_BLOCK_DATA), minit ("MODULE", FL_MODULE),
38 minit ("VARIABLE", FL_VARIABLE), minit ("PARAMETER", FL_PARAMETER),
39 minit ("LABEL", FL_LABEL), minit ("PROCEDURE", FL_PROCEDURE),
40 minit ("DERIVED", FL_DERIVED), minit ("NAMELIST", FL_NAMELIST),
41 minit (NULL, -1)
44 const mstring procedures[] =
46 minit ("UNKNOWN-PROC", PROC_UNKNOWN),
47 minit ("MODULE-PROC", PROC_MODULE),
48 minit ("INTERNAL-PROC", PROC_INTERNAL),
49 minit ("DUMMY-PROC", PROC_DUMMY),
50 minit ("INTRINSIC-PROC", PROC_INTRINSIC),
51 minit ("EXTERNAL-PROC", PROC_EXTERNAL),
52 minit ("STATEMENT-PROC", PROC_ST_FUNCTION),
53 minit (NULL, -1)
56 const mstring intents[] =
58 minit ("UNKNOWN-INTENT", INTENT_UNKNOWN),
59 minit ("IN", INTENT_IN),
60 minit ("OUT", INTENT_OUT),
61 minit ("INOUT", INTENT_INOUT),
62 minit (NULL, -1)
65 const mstring access_types[] =
67 minit ("UNKNOWN-ACCESS", ACCESS_UNKNOWN),
68 minit ("PUBLIC", ACCESS_PUBLIC),
69 minit ("PRIVATE", ACCESS_PRIVATE),
70 minit (NULL, -1)
73 const mstring ifsrc_types[] =
75 minit ("UNKNOWN", IFSRC_UNKNOWN),
76 minit ("DECL", IFSRC_DECL),
77 minit ("BODY", IFSRC_IFBODY),
78 minit ("USAGE", IFSRC_USAGE)
82 /* This is to make sure the backend generates setup code in the correct
83 order. */
85 static int next_dummy_order = 1;
88 gfc_namespace *gfc_current_ns;
90 gfc_gsymbol *gfc_gsym_root = NULL;
92 static gfc_symbol *changed_syms = NULL;
95 /*********** IMPLICIT NONE and IMPLICIT statement handlers ***********/
97 /* The following static variable indicates whether a particular element has
98 been explicitly set or not. */
100 static int new_flag[GFC_LETTERS];
103 /* Handle a correctly parsed IMPLICIT NONE. */
105 void
106 gfc_set_implicit_none (void)
108 int i;
110 if (gfc_current_ns->seen_implicit_none)
112 gfc_error ("Duplicate IMPLICIT NONE statement at %C");
113 return;
116 gfc_current_ns->seen_implicit_none = 1;
118 for (i = 0; i < GFC_LETTERS; i++)
120 gfc_clear_ts (&gfc_current_ns->default_type[i]);
121 gfc_current_ns->set_flag[i] = 1;
126 /* Reset the implicit range flags. */
128 void
129 gfc_clear_new_implicit (void)
131 int i;
133 for (i = 0; i < GFC_LETTERS; i++)
134 new_flag[i] = 0;
138 /* Prepare for a new implicit range. Sets flags in new_flag[]. */
141 gfc_add_new_implicit_range (int c1, int c2)
143 int i;
145 c1 -= 'a';
146 c2 -= 'a';
148 for (i = c1; i <= c2; i++)
150 if (new_flag[i])
152 gfc_error ("Letter '%c' already set in IMPLICIT statement at %C",
153 i + 'A');
154 return FAILURE;
157 new_flag[i] = 1;
160 return SUCCESS;
164 /* Add a matched implicit range for gfc_set_implicit(). Check if merging
165 the new implicit types back into the existing types will work. */
168 gfc_merge_new_implicit (gfc_typespec * ts)
170 int i;
172 if (gfc_current_ns->seen_implicit_none)
174 gfc_error ("Cannot specify IMPLICIT at %C after IMPLICIT NONE");
175 return FAILURE;
178 for (i = 0; i < GFC_LETTERS; i++)
180 if (new_flag[i])
183 if (gfc_current_ns->set_flag[i])
185 gfc_error ("Letter %c already has an IMPLICIT type at %C",
186 i + 'A');
187 return FAILURE;
189 gfc_current_ns->default_type[i] = *ts;
190 gfc_current_ns->set_flag[i] = 1;
193 return SUCCESS;
197 /* Given a symbol, return a pointer to the typespec for its default type. */
199 gfc_typespec *
200 gfc_get_default_type (gfc_symbol * sym, gfc_namespace * ns)
202 char letter;
204 letter = sym->name[0];
205 if (letter < 'a' || letter > 'z')
206 gfc_internal_error ("gfc_get_default_type(): Bad symbol");
208 if (ns == NULL)
209 ns = gfc_current_ns;
211 return &ns->default_type[letter - 'a'];
215 /* Given a pointer to a symbol, set its type according to the first
216 letter of its name. Fails if the letter in question has no default
217 type. */
220 gfc_set_default_type (gfc_symbol * sym, int error_flag, gfc_namespace * ns)
222 gfc_typespec *ts;
224 if (sym->ts.type != BT_UNKNOWN)
225 gfc_internal_error ("gfc_set_default_type(): symbol already has a type");
227 ts = gfc_get_default_type (sym, ns);
229 if (ts->type == BT_UNKNOWN)
231 if (error_flag && !sym->attr.untyped)
233 gfc_error ("Symbol '%s' at %L has no IMPLICIT type",
234 sym->name, &sym->declared_at);
235 sym->attr.untyped = 1; /* Ensure we only give an error once. */
238 return FAILURE;
241 sym->ts = *ts;
242 sym->attr.implicit_type = 1;
244 return SUCCESS;
248 /******************** Symbol attribute stuff *********************/
250 /* This is a generic conflict-checker. We do this to avoid having a
251 single conflict in two places. */
253 #define conf(a, b) if (attr->a && attr->b) { a1 = a; a2 = b; goto conflict; }
254 #define conf2(a) if (attr->a) { a2 = a; goto conflict; }
255 #define conf_std(a, b, std) if (attr->a && attr->b)\
257 a1 = a;\
258 a2 = b;\
259 standard = std;\
260 goto conflict_std;\
263 static try
264 check_conflict (symbol_attribute * attr, const char * name, locus * where)
266 static const char *dummy = "DUMMY", *save = "SAVE", *pointer = "POINTER",
267 *target = "TARGET", *external = "EXTERNAL", *intent = "INTENT",
268 *intrinsic = "INTRINSIC", *allocatable = "ALLOCATABLE",
269 *elemental = "ELEMENTAL", *private = "PRIVATE", *recursive = "RECURSIVE",
270 *in_common = "COMMON", *result = "RESULT", *in_namelist = "NAMELIST",
271 *public = "PUBLIC", *optional = "OPTIONAL", *entry = "ENTRY",
272 *function = "FUNCTION", *subroutine = "SUBROUTINE",
273 *dimension = "DIMENSION", *in_equivalence = "EQUIVALENCE",
274 *use_assoc = "USE ASSOCIATED", *cray_pointer = "CRAY POINTER",
275 *cray_pointee = "CRAY POINTEE", *data = "DATA";
276 static const char *threadprivate = "THREADPRIVATE";
278 const char *a1, *a2;
279 int standard;
281 if (where == NULL)
282 where = &gfc_current_locus;
284 if (attr->pointer && attr->intent != INTENT_UNKNOWN)
286 a1 = pointer;
287 a2 = intent;
288 goto conflict;
291 /* Check for attributes not allowed in a BLOCK DATA. */
292 if (gfc_current_state () == COMP_BLOCK_DATA)
294 a1 = NULL;
296 if (attr->in_namelist)
297 a1 = in_namelist;
298 if (attr->allocatable)
299 a1 = allocatable;
300 if (attr->external)
301 a1 = external;
302 if (attr->optional)
303 a1 = optional;
304 if (attr->access == ACCESS_PRIVATE)
305 a1 = private;
306 if (attr->access == ACCESS_PUBLIC)
307 a1 = public;
308 if (attr->intent != INTENT_UNKNOWN)
309 a1 = intent;
311 if (a1 != NULL)
313 gfc_error
314 ("%s attribute not allowed in BLOCK DATA program unit at %L", a1,
315 where);
316 return FAILURE;
320 conf (dummy, save);
321 conf (dummy, threadprivate);
322 conf (pointer, target);
323 conf (pointer, external);
324 conf (pointer, intrinsic);
325 conf (pointer, elemental);
326 conf (allocatable, elemental);
328 conf (target, external);
329 conf (target, intrinsic);
330 conf (external, dimension); /* See Fortran 95's R504. */
332 conf (external, intrinsic);
334 if (attr->if_source || attr->contained)
336 conf (external, subroutine);
337 conf (external, function);
340 conf (allocatable, pointer);
341 conf_std (allocatable, dummy, GFC_STD_F2003);
342 conf_std (allocatable, function, GFC_STD_F2003);
343 conf_std (allocatable, result, GFC_STD_F2003);
344 conf (elemental, recursive);
346 conf (in_common, dummy);
347 conf (in_common, allocatable);
348 conf (in_common, result);
349 conf (in_common, save);
350 conf (result, save);
352 conf (dummy, result);
354 conf (in_equivalence, use_assoc);
355 conf (in_equivalence, dummy);
356 conf (in_equivalence, target);
357 conf (in_equivalence, pointer);
358 conf (in_equivalence, function);
359 conf (in_equivalence, result);
360 conf (in_equivalence, entry);
361 conf (in_equivalence, allocatable);
362 conf (in_equivalence, threadprivate);
364 conf (in_namelist, pointer);
365 conf (in_namelist, allocatable);
367 conf (entry, result);
369 conf (function, subroutine);
371 /* Cray pointer/pointee conflicts. */
372 conf (cray_pointer, cray_pointee);
373 conf (cray_pointer, dimension);
374 conf (cray_pointer, pointer);
375 conf (cray_pointer, target);
376 conf (cray_pointer, allocatable);
377 conf (cray_pointer, external);
378 conf (cray_pointer, intrinsic);
379 conf (cray_pointer, in_namelist);
380 conf (cray_pointer, function);
381 conf (cray_pointer, subroutine);
382 conf (cray_pointer, entry);
384 conf (cray_pointee, allocatable);
385 conf (cray_pointee, intent);
386 conf (cray_pointee, optional);
387 conf (cray_pointee, dummy);
388 conf (cray_pointee, target);
389 conf (cray_pointee, intrinsic);
390 conf (cray_pointee, pointer);
391 conf (cray_pointee, entry);
392 conf (cray_pointee, in_common);
393 conf (cray_pointee, in_equivalence);
394 conf (cray_pointee, threadprivate);
396 conf (data, dummy);
397 conf (data, function);
398 conf (data, result);
399 conf (data, allocatable);
400 conf (data, use_assoc);
402 a1 = gfc_code2string (flavors, attr->flavor);
404 if (attr->in_namelist
405 && attr->flavor != FL_VARIABLE
406 && attr->flavor != FL_UNKNOWN)
409 a2 = in_namelist;
410 goto conflict;
413 switch (attr->flavor)
415 case FL_PROGRAM:
416 case FL_BLOCK_DATA:
417 case FL_MODULE:
418 case FL_LABEL:
419 conf2 (dummy);
420 conf2 (save);
421 conf2 (pointer);
422 conf2 (target);
423 conf2 (external);
424 conf2 (intrinsic);
425 conf2 (allocatable);
426 conf2 (result);
427 conf2 (in_namelist);
428 conf2 (optional);
429 conf2 (function);
430 conf2 (subroutine);
431 conf2 (threadprivate);
432 break;
434 case FL_VARIABLE:
435 case FL_NAMELIST:
436 break;
438 case FL_PROCEDURE:
439 conf2 (intent);
441 if (attr->subroutine)
443 conf2(save);
444 conf2(pointer);
445 conf2(target);
446 conf2(allocatable);
447 conf2(result);
448 conf2(in_namelist);
449 conf2(function);
450 conf2(threadprivate);
453 switch (attr->proc)
455 case PROC_ST_FUNCTION:
456 conf2 (in_common);
457 conf2 (dummy);
458 break;
460 case PROC_MODULE:
461 conf2 (dummy);
462 break;
464 case PROC_DUMMY:
465 conf2 (result);
466 conf2 (in_common);
467 conf2 (save);
468 conf2 (threadprivate);
469 break;
471 default:
472 break;
475 break;
477 case FL_DERIVED:
478 conf2 (dummy);
479 conf2 (save);
480 conf2 (pointer);
481 conf2 (target);
482 conf2 (external);
483 conf2 (intrinsic);
484 conf2 (allocatable);
485 conf2 (optional);
486 conf2 (entry);
487 conf2 (function);
488 conf2 (subroutine);
489 conf2 (threadprivate);
491 if (attr->intent != INTENT_UNKNOWN)
493 a2 = intent;
494 goto conflict;
496 break;
498 case FL_PARAMETER:
499 conf2 (external);
500 conf2 (intrinsic);
501 conf2 (optional);
502 conf2 (allocatable);
503 conf2 (function);
504 conf2 (subroutine);
505 conf2 (entry);
506 conf2 (pointer);
507 conf2 (target);
508 conf2 (dummy);
509 conf2 (in_common);
510 conf2 (save);
511 conf2 (threadprivate);
512 break;
514 default:
515 break;
518 return SUCCESS;
520 conflict:
521 if (name == NULL)
522 gfc_error ("%s attribute conflicts with %s attribute at %L",
523 a1, a2, where);
524 else
525 gfc_error ("%s attribute conflicts with %s attribute in '%s' at %L",
526 a1, a2, name, where);
528 return FAILURE;
530 conflict_std:
531 if (name == NULL)
533 return gfc_notify_std (standard, "In the selected standard, %s attribute "
534 "conflicts with %s attribute at %L", a1, a2,
535 where);
537 else
539 return gfc_notify_std (standard, "In the selected standard, %s attribute "
540 "conflicts with %s attribute in '%s' at %L",
541 a1, a2, name, where);
545 #undef conf
546 #undef conf2
547 #undef conf_std
550 /* Mark a symbol as referenced. */
552 void
553 gfc_set_sym_referenced (gfc_symbol * sym)
555 if (sym->attr.referenced)
556 return;
558 sym->attr.referenced = 1;
560 /* Remember which order dummy variables are accessed in. */
561 if (sym->attr.dummy)
562 sym->dummy_order = next_dummy_order++;
566 /* Common subroutine called by attribute changing subroutines in order
567 to prevent them from changing a symbol that has been
568 use-associated. Returns zero if it is OK to change the symbol,
569 nonzero if not. */
571 static int
572 check_used (symbol_attribute * attr, const char * name, locus * where)
575 if (attr->use_assoc == 0)
576 return 0;
578 if (where == NULL)
579 where = &gfc_current_locus;
581 if (name == NULL)
582 gfc_error ("Cannot change attributes of USE-associated symbol at %L",
583 where);
584 else
585 gfc_error ("Cannot change attributes of USE-associated symbol %s at %L",
586 name, where);
588 return 1;
592 /* Used to prevent changing the attributes of a symbol after it has been
593 used. This check is only done for dummy variables as only these can be
594 used in specification expressions. Applying this to all symbols causes
595 an error when we reach the body of a contained function. */
597 static int
598 check_done (symbol_attribute * attr, locus * where)
601 if (!(attr->dummy && attr->referenced))
602 return 0;
604 if (where == NULL)
605 where = &gfc_current_locus;
607 gfc_error ("Cannot change attributes of symbol at %L"
608 " after it has been used", where);
610 return 1;
614 /* Generate an error because of a duplicate attribute. */
616 static void
617 duplicate_attr (const char *attr, locus * where)
620 if (where == NULL)
621 where = &gfc_current_locus;
623 gfc_error ("Duplicate %s attribute specified at %L", attr, where);
626 /* Called from decl.c (attr_decl1) to check attributes, when declared separately. */
629 gfc_add_attribute (symbol_attribute * attr, locus * where,
630 unsigned int attr_intent)
633 if (check_used (attr, NULL, where)
634 || (attr_intent == 0 && check_done (attr, where)))
635 return FAILURE;
637 return check_conflict (attr, NULL, where);
641 gfc_add_allocatable (symbol_attribute * attr, locus * where)
644 if (check_used (attr, NULL, where) || check_done (attr, where))
645 return FAILURE;
647 if (attr->allocatable)
649 duplicate_attr ("ALLOCATABLE", where);
650 return FAILURE;
653 attr->allocatable = 1;
654 return check_conflict (attr, NULL, where);
659 gfc_add_dimension (symbol_attribute * attr, const char *name, locus * where)
662 if (check_used (attr, name, where) || check_done (attr, where))
663 return FAILURE;
665 if (attr->dimension)
667 duplicate_attr ("DIMENSION", where);
668 return FAILURE;
671 attr->dimension = 1;
672 return check_conflict (attr, name, where);
677 gfc_add_external (symbol_attribute * attr, locus * where)
680 if (check_used (attr, NULL, where) || check_done (attr, where))
681 return FAILURE;
683 if (attr->external)
685 duplicate_attr ("EXTERNAL", where);
686 return FAILURE;
689 attr->external = 1;
691 return check_conflict (attr, NULL, where);
696 gfc_add_intrinsic (symbol_attribute * attr, locus * where)
699 if (check_used (attr, NULL, where) || check_done (attr, where))
700 return FAILURE;
702 if (attr->intrinsic)
704 duplicate_attr ("INTRINSIC", where);
705 return FAILURE;
708 attr->intrinsic = 1;
710 return check_conflict (attr, NULL, where);
715 gfc_add_optional (symbol_attribute * attr, locus * where)
718 if (check_used (attr, NULL, where) || check_done (attr, where))
719 return FAILURE;
721 if (attr->optional)
723 duplicate_attr ("OPTIONAL", where);
724 return FAILURE;
727 attr->optional = 1;
728 return check_conflict (attr, NULL, where);
733 gfc_add_pointer (symbol_attribute * attr, locus * where)
736 if (check_used (attr, NULL, where) || check_done (attr, where))
737 return FAILURE;
739 attr->pointer = 1;
740 return check_conflict (attr, NULL, where);
745 gfc_add_cray_pointer (symbol_attribute * attr, locus * where)
748 if (check_used (attr, NULL, where) || check_done (attr, where))
749 return FAILURE;
751 attr->cray_pointer = 1;
752 return check_conflict (attr, NULL, where);
757 gfc_add_cray_pointee (symbol_attribute * attr, locus * where)
760 if (check_used (attr, NULL, where) || check_done (attr, where))
761 return FAILURE;
763 if (attr->cray_pointee)
765 gfc_error ("Cray Pointee at %L appears in multiple pointer()"
766 " statements.", where);
767 return FAILURE;
770 attr->cray_pointee = 1;
771 return check_conflict (attr, NULL, where);
776 gfc_add_result (symbol_attribute * attr, const char *name, locus * where)
779 if (check_used (attr, name, where) || check_done (attr, where))
780 return FAILURE;
782 attr->result = 1;
783 return check_conflict (attr, name, where);
788 gfc_add_save (symbol_attribute * attr, const char *name, locus * where)
791 if (check_used (attr, name, where))
792 return FAILURE;
794 if (gfc_pure (NULL))
796 gfc_error
797 ("SAVE attribute at %L cannot be specified in a PURE procedure",
798 where);
799 return FAILURE;
802 if (attr->save)
804 if (gfc_notify_std (GFC_STD_LEGACY,
805 "Duplicate SAVE attribute specified at %L",
806 where)
807 == FAILURE)
808 return FAILURE;
811 attr->save = 1;
812 return check_conflict (attr, name, where);
817 gfc_add_threadprivate (symbol_attribute * attr, const char *name, locus * where)
819 if (check_used (attr, name, where))
820 return FAILURE;
822 if (attr->threadprivate)
824 duplicate_attr ("THREADPRIVATE", where);
825 return FAILURE;
828 attr->threadprivate = 1;
829 return check_conflict (attr, name, where);
834 gfc_add_target (symbol_attribute * attr, locus * where)
837 if (check_used (attr, NULL, where) || check_done (attr, where))
838 return FAILURE;
840 if (attr->target)
842 duplicate_attr ("TARGET", where);
843 return FAILURE;
846 attr->target = 1;
847 return check_conflict (attr, NULL, where);
852 gfc_add_dummy (symbol_attribute * attr, const char *name, locus * where)
855 if (check_used (attr, name, where))
856 return FAILURE;
858 /* Duplicate dummy arguments are allowed due to ENTRY statements. */
859 attr->dummy = 1;
860 return check_conflict (attr, name, where);
865 gfc_add_in_common (symbol_attribute * attr, const char *name, locus * where)
868 if (check_used (attr, name, where) || check_done (attr, where))
869 return FAILURE;
871 /* Duplicate attribute already checked for. */
872 attr->in_common = 1;
873 if (check_conflict (attr, name, where) == FAILURE)
874 return FAILURE;
876 if (attr->flavor == FL_VARIABLE)
877 return SUCCESS;
879 return gfc_add_flavor (attr, FL_VARIABLE, name, where);
883 gfc_add_in_equivalence (symbol_attribute * attr, const char *name, locus * where)
886 /* Duplicate attribute already checked for. */
887 attr->in_equivalence = 1;
888 if (check_conflict (attr, name, where) == FAILURE)
889 return FAILURE;
891 if (attr->flavor == FL_VARIABLE)
892 return SUCCESS;
894 return gfc_add_flavor (attr, FL_VARIABLE, name, where);
899 gfc_add_data (symbol_attribute *attr, const char *name, locus *where)
902 if (check_used (attr, name, where))
903 return FAILURE;
905 attr->data = 1;
906 return check_conflict (attr, name, where);
911 gfc_add_in_namelist (symbol_attribute * attr, const char *name,
912 locus * where)
915 attr->in_namelist = 1;
916 return check_conflict (attr, name, where);
921 gfc_add_sequence (symbol_attribute * attr, const char *name, locus * where)
924 if (check_used (attr, name, where))
925 return FAILURE;
927 attr->sequence = 1;
928 return check_conflict (attr, name, where);
933 gfc_add_elemental (symbol_attribute * attr, locus * where)
936 if (check_used (attr, NULL, where) || check_done (attr, where))
937 return FAILURE;
939 attr->elemental = 1;
940 return check_conflict (attr, NULL, where);
945 gfc_add_pure (symbol_attribute * attr, locus * where)
948 if (check_used (attr, NULL, where) || check_done (attr, where))
949 return FAILURE;
951 attr->pure = 1;
952 return check_conflict (attr, NULL, where);
957 gfc_add_recursive (symbol_attribute * attr, locus * where)
960 if (check_used (attr, NULL, where) || check_done (attr, where))
961 return FAILURE;
963 attr->recursive = 1;
964 return check_conflict (attr, NULL, where);
969 gfc_add_entry (symbol_attribute * attr, const char *name, locus * where)
972 if (check_used (attr, name, where))
973 return FAILURE;
975 if (attr->entry)
977 duplicate_attr ("ENTRY", where);
978 return FAILURE;
981 attr->entry = 1;
982 return check_conflict (attr, name, where);
987 gfc_add_function (symbol_attribute * attr, const char *name, locus * where)
990 if (attr->flavor != FL_PROCEDURE
991 && gfc_add_flavor (attr, FL_PROCEDURE, name, where) == FAILURE)
992 return FAILURE;
994 attr->function = 1;
995 return check_conflict (attr, name, where);
1000 gfc_add_subroutine (symbol_attribute * attr, const char *name, locus * where)
1003 if (attr->flavor != FL_PROCEDURE
1004 && gfc_add_flavor (attr, FL_PROCEDURE, name, where) == FAILURE)
1005 return FAILURE;
1007 attr->subroutine = 1;
1008 return check_conflict (attr, name, where);
1013 gfc_add_generic (symbol_attribute * attr, const char *name, locus * where)
1016 if (attr->flavor != FL_PROCEDURE
1017 && gfc_add_flavor (attr, FL_PROCEDURE, name, where) == FAILURE)
1018 return FAILURE;
1020 attr->generic = 1;
1021 return check_conflict (attr, name, where);
1025 /* Flavors are special because some flavors are not what Fortran
1026 considers attributes and can be reaffirmed multiple times. */
1029 gfc_add_flavor (symbol_attribute * attr, sym_flavor f, const char *name,
1030 locus * where)
1033 if ((f == FL_PROGRAM || f == FL_BLOCK_DATA || f == FL_MODULE
1034 || f == FL_PARAMETER || f == FL_LABEL || f == FL_DERIVED
1035 || f == FL_NAMELIST) && check_used (attr, name, where))
1036 return FAILURE;
1038 if (attr->flavor == f && f == FL_VARIABLE)
1039 return SUCCESS;
1041 if (attr->flavor != FL_UNKNOWN)
1043 if (where == NULL)
1044 where = &gfc_current_locus;
1046 gfc_error ("%s attribute conflicts with %s attribute at %L",
1047 gfc_code2string (flavors, attr->flavor),
1048 gfc_code2string (flavors, f), where);
1050 return FAILURE;
1053 attr->flavor = f;
1055 return check_conflict (attr, name, where);
1060 gfc_add_procedure (symbol_attribute * attr, procedure_type t,
1061 const char *name, locus * where)
1064 if (check_used (attr, name, where) || check_done (attr, where))
1065 return FAILURE;
1067 if (attr->flavor != FL_PROCEDURE
1068 && gfc_add_flavor (attr, FL_PROCEDURE, name, where) == FAILURE)
1069 return FAILURE;
1071 if (where == NULL)
1072 where = &gfc_current_locus;
1074 if (attr->proc != PROC_UNKNOWN)
1076 gfc_error ("%s procedure at %L is already declared as %s procedure",
1077 gfc_code2string (procedures, t), where,
1078 gfc_code2string (procedures, attr->proc));
1080 return FAILURE;
1083 attr->proc = t;
1085 /* Statement functions are always scalar and functions. */
1086 if (t == PROC_ST_FUNCTION
1087 && ((!attr->function && gfc_add_function (attr, name, where) == FAILURE)
1088 || attr->dimension))
1089 return FAILURE;
1091 return check_conflict (attr, name, where);
1096 gfc_add_intent (symbol_attribute * attr, sym_intent intent, locus * where)
1099 if (check_used (attr, NULL, where))
1100 return FAILURE;
1102 if (attr->intent == INTENT_UNKNOWN)
1104 attr->intent = intent;
1105 return check_conflict (attr, NULL, where);
1108 if (where == NULL)
1109 where = &gfc_current_locus;
1111 gfc_error ("INTENT (%s) conflicts with INTENT(%s) at %L",
1112 gfc_intent_string (attr->intent),
1113 gfc_intent_string (intent), where);
1115 return FAILURE;
1119 /* No checks for use-association in public and private statements. */
1122 gfc_add_access (symbol_attribute * attr, gfc_access access,
1123 const char *name, locus * where)
1126 if (attr->access == ACCESS_UNKNOWN)
1128 attr->access = access;
1129 return check_conflict (attr, name, where);
1132 if (where == NULL)
1133 where = &gfc_current_locus;
1134 gfc_error ("ACCESS specification at %L was already specified", where);
1136 return FAILURE;
1141 gfc_add_explicit_interface (gfc_symbol * sym, ifsrc source,
1142 gfc_formal_arglist * formal, locus * where)
1145 if (check_used (&sym->attr, sym->name, where))
1146 return FAILURE;
1148 if (where == NULL)
1149 where = &gfc_current_locus;
1151 if (sym->attr.if_source != IFSRC_UNKNOWN
1152 && sym->attr.if_source != IFSRC_DECL)
1154 gfc_error ("Symbol '%s' at %L already has an explicit interface",
1155 sym->name, where);
1156 return FAILURE;
1159 sym->formal = formal;
1160 sym->attr.if_source = source;
1162 return SUCCESS;
1166 /* Add a type to a symbol. */
1169 gfc_add_type (gfc_symbol * sym, gfc_typespec * ts, locus * where)
1171 sym_flavor flavor;
1173 /* TODO: This is legal if it is reaffirming an implicit type.
1174 if (check_done (&sym->attr, where))
1175 return FAILURE;*/
1177 if (where == NULL)
1178 where = &gfc_current_locus;
1180 if (sym->ts.type != BT_UNKNOWN)
1182 const char *msg = "Symbol '%s' at %L already has basic type of %s";
1183 if (!(sym->ts.type == ts->type
1184 && (sym->attr.flavor == FL_PROCEDURE || sym->attr.result))
1185 || gfc_notification_std (GFC_STD_GNU) == ERROR
1186 || pedantic)
1188 gfc_error (msg, sym->name, where, gfc_basic_typename (sym->ts.type));
1189 return FAILURE;
1191 else if (gfc_notify_std (GFC_STD_GNU, msg, sym->name, where,
1192 gfc_basic_typename (sym->ts.type)) == FAILURE)
1193 return FAILURE;
1196 flavor = sym->attr.flavor;
1198 if (flavor == FL_PROGRAM || flavor == FL_BLOCK_DATA || flavor == FL_MODULE
1199 || flavor == FL_LABEL || (flavor == FL_PROCEDURE
1200 && sym->attr.subroutine)
1201 || flavor == FL_DERIVED || flavor == FL_NAMELIST)
1203 gfc_error ("Symbol '%s' at %L cannot have a type", sym->name, where);
1204 return FAILURE;
1207 sym->ts = *ts;
1208 return SUCCESS;
1212 /* Clears all attributes. */
1214 void
1215 gfc_clear_attr (symbol_attribute * attr)
1217 memset (attr, 0, sizeof(symbol_attribute));
1221 /* Check for missing attributes in the new symbol. Currently does
1222 nothing, but it's not clear that it is unnecessary yet. */
1225 gfc_missing_attr (symbol_attribute * attr ATTRIBUTE_UNUSED,
1226 locus * where ATTRIBUTE_UNUSED)
1229 return SUCCESS;
1233 /* Copy an attribute to a symbol attribute, bit by bit. Some
1234 attributes have a lot of side-effects but cannot be present given
1235 where we are called from, so we ignore some bits. */
1238 gfc_copy_attr (symbol_attribute * dest, symbol_attribute * src, locus * where)
1241 if (src->allocatable && gfc_add_allocatable (dest, where) == FAILURE)
1242 goto fail;
1244 if (src->dimension && gfc_add_dimension (dest, NULL, where) == FAILURE)
1245 goto fail;
1246 if (src->optional && gfc_add_optional (dest, where) == FAILURE)
1247 goto fail;
1248 if (src->pointer && gfc_add_pointer (dest, where) == FAILURE)
1249 goto fail;
1250 if (src->save && gfc_add_save (dest, NULL, where) == FAILURE)
1251 goto fail;
1252 if (src->threadprivate && gfc_add_threadprivate (dest, NULL, where) == FAILURE)
1253 goto fail;
1254 if (src->target && gfc_add_target (dest, where) == FAILURE)
1255 goto fail;
1256 if (src->dummy && gfc_add_dummy (dest, NULL, where) == FAILURE)
1257 goto fail;
1258 if (src->result && gfc_add_result (dest, NULL, where) == FAILURE)
1259 goto fail;
1260 if (src->entry)
1261 dest->entry = 1;
1263 if (src->in_namelist && gfc_add_in_namelist (dest, NULL, where) == FAILURE)
1264 goto fail;
1266 if (src->in_common && gfc_add_in_common (dest, NULL, where) == FAILURE)
1267 goto fail;
1269 if (src->generic && gfc_add_generic (dest, NULL, where) == FAILURE)
1270 goto fail;
1271 if (src->function && gfc_add_function (dest, NULL, where) == FAILURE)
1272 goto fail;
1273 if (src->subroutine && gfc_add_subroutine (dest, NULL, where) == FAILURE)
1274 goto fail;
1276 if (src->sequence && gfc_add_sequence (dest, NULL, where) == FAILURE)
1277 goto fail;
1278 if (src->elemental && gfc_add_elemental (dest, where) == FAILURE)
1279 goto fail;
1280 if (src->pure && gfc_add_pure (dest, where) == FAILURE)
1281 goto fail;
1282 if (src->recursive && gfc_add_recursive (dest, where) == FAILURE)
1283 goto fail;
1285 if (src->flavor != FL_UNKNOWN
1286 && gfc_add_flavor (dest, src->flavor, NULL, where) == FAILURE)
1287 goto fail;
1289 if (src->intent != INTENT_UNKNOWN
1290 && gfc_add_intent (dest, src->intent, where) == FAILURE)
1291 goto fail;
1293 if (src->access != ACCESS_UNKNOWN
1294 && gfc_add_access (dest, src->access, NULL, where) == FAILURE)
1295 goto fail;
1297 if (gfc_missing_attr (dest, where) == FAILURE)
1298 goto fail;
1300 if (src->cray_pointer && gfc_add_cray_pointer (dest, where) == FAILURE)
1301 goto fail;
1302 if (src->cray_pointee && gfc_add_cray_pointee (dest, where) == FAILURE)
1303 goto fail;
1305 /* The subroutines that set these bits also cause flavors to be set,
1306 and that has already happened in the original, so don't let it
1307 happen again. */
1308 if (src->external)
1309 dest->external = 1;
1310 if (src->intrinsic)
1311 dest->intrinsic = 1;
1313 return SUCCESS;
1315 fail:
1316 return FAILURE;
1320 /************** Component name management ************/
1322 /* Component names of a derived type form their own little namespaces
1323 that are separate from all other spaces. The space is composed of
1324 a singly linked list of gfc_component structures whose head is
1325 located in the parent symbol. */
1328 /* Add a component name to a symbol. The call fails if the name is
1329 already present. On success, the component pointer is modified to
1330 point to the additional component structure. */
1333 gfc_add_component (gfc_symbol * sym, const char *name, gfc_component ** component)
1335 gfc_component *p, *tail;
1337 tail = NULL;
1339 for (p = sym->components; p; p = p->next)
1341 if (strcmp (p->name, name) == 0)
1343 gfc_error ("Component '%s' at %C already declared at %L",
1344 name, &p->loc);
1345 return FAILURE;
1348 tail = p;
1351 /* Allocate a new component. */
1352 p = gfc_get_component ();
1354 if (tail == NULL)
1355 sym->components = p;
1356 else
1357 tail->next = p;
1359 p->name = gfc_get_string (name);
1360 p->loc = gfc_current_locus;
1362 *component = p;
1363 return SUCCESS;
1367 /* Recursive function to switch derived types of all symbol in a
1368 namespace. */
1370 static void
1371 switch_types (gfc_symtree * st, gfc_symbol * from, gfc_symbol * to)
1373 gfc_symbol *sym;
1375 if (st == NULL)
1376 return;
1378 sym = st->n.sym;
1379 if (sym->ts.type == BT_DERIVED && sym->ts.derived == from)
1380 sym->ts.derived = to;
1382 switch_types (st->left, from, to);
1383 switch_types (st->right, from, to);
1387 /* This subroutine is called when a derived type is used in order to
1388 make the final determination about which version to use. The
1389 standard requires that a type be defined before it is 'used', but
1390 such types can appear in IMPLICIT statements before the actual
1391 definition. 'Using' in this context means declaring a variable to
1392 be that type or using the type constructor.
1394 If a type is used and the components haven't been defined, then we
1395 have to have a derived type in a parent unit. We find the node in
1396 the other namespace and point the symtree node in this namespace to
1397 that node. Further reference to this name point to the correct
1398 node. If we can't find the node in a parent namespace, then we have
1399 an error.
1401 This subroutine takes a pointer to a symbol node and returns a
1402 pointer to the translated node or NULL for an error. Usually there
1403 is no translation and we return the node we were passed. */
1405 gfc_symbol *
1406 gfc_use_derived (gfc_symbol * sym)
1408 gfc_symbol *s;
1409 gfc_typespec *t;
1410 gfc_symtree *st;
1411 int i;
1413 if (sym->components != NULL)
1414 return sym; /* Already defined. */
1416 if (sym->ns->parent == NULL)
1417 goto bad;
1419 if (gfc_find_symbol (sym->name, sym->ns->parent, 1, &s))
1421 gfc_error ("Symbol '%s' at %C is ambiguous", sym->name);
1422 return NULL;
1425 if (s == NULL || s->attr.flavor != FL_DERIVED)
1426 goto bad;
1428 /* Get rid of symbol sym, translating all references to s. */
1429 for (i = 0; i < GFC_LETTERS; i++)
1431 t = &sym->ns->default_type[i];
1432 if (t->derived == sym)
1433 t->derived = s;
1436 st = gfc_find_symtree (sym->ns->sym_root, sym->name);
1437 st->n.sym = s;
1439 s->refs++;
1441 /* Unlink from list of modified symbols. */
1442 gfc_commit_symbol (sym);
1444 switch_types (sym->ns->sym_root, sym, s);
1446 /* TODO: Also have to replace sym -> s in other lists like
1447 namelists, common lists and interface lists. */
1448 gfc_free_symbol (sym);
1450 return s;
1452 bad:
1453 gfc_error ("Derived type '%s' at %C is being used before it is defined",
1454 sym->name);
1455 return NULL;
1459 /* Given a derived type node and a component name, try to locate the
1460 component structure. Returns the NULL pointer if the component is
1461 not found or the components are private. */
1463 gfc_component *
1464 gfc_find_component (gfc_symbol * sym, const char *name)
1466 gfc_component *p;
1468 if (name == NULL)
1469 return NULL;
1471 sym = gfc_use_derived (sym);
1473 if (sym == NULL)
1474 return NULL;
1476 for (p = sym->components; p; p = p->next)
1477 if (strcmp (p->name, name) == 0)
1478 break;
1480 if (p == NULL)
1481 gfc_error ("'%s' at %C is not a member of the '%s' structure",
1482 name, sym->name);
1483 else
1485 if (sym->attr.use_assoc && sym->component_access == ACCESS_PRIVATE)
1487 gfc_error ("Component '%s' at %C is a PRIVATE component of '%s'",
1488 name, sym->name);
1489 p = NULL;
1493 return p;
1497 /* Given a symbol, free all of the component structures and everything
1498 they point to. */
1500 static void
1501 free_components (gfc_component * p)
1503 gfc_component *q;
1505 for (; p; p = q)
1507 q = p->next;
1509 gfc_free_array_spec (p->as);
1510 gfc_free_expr (p->initializer);
1512 gfc_free (p);
1517 /* Set component attributes from a standard symbol attribute
1518 structure. */
1520 void
1521 gfc_set_component_attr (gfc_component * c, symbol_attribute * attr)
1524 c->dimension = attr->dimension;
1525 c->pointer = attr->pointer;
1529 /* Get a standard symbol attribute structure given the component
1530 structure. */
1532 void
1533 gfc_get_component_attr (symbol_attribute * attr, gfc_component * c)
1536 gfc_clear_attr (attr);
1537 attr->dimension = c->dimension;
1538 attr->pointer = c->pointer;
1542 /******************** Statement label management ********************/
1544 /* Comparison function for statement labels, used for managing the
1545 binary tree. */
1547 static int
1548 compare_st_labels (void * a1, void * b1)
1550 int a = ((gfc_st_label *)a1)->value;
1551 int b = ((gfc_st_label *)b1)->value;
1553 return (b - a);
1557 /* Free a single gfc_st_label structure, making sure the tree is not
1558 messed up. This function is called only when some parse error
1559 occurs. */
1561 void
1562 gfc_free_st_label (gfc_st_label * label)
1564 if (label == NULL)
1565 return;
1567 gfc_delete_bbt (&gfc_current_ns->st_labels, label, compare_st_labels);
1569 if (label->format != NULL)
1570 gfc_free_expr (label->format);
1572 gfc_free (label);
1575 /* Free a whole tree of gfc_st_label structures. */
1577 static void
1578 free_st_labels (gfc_st_label * label)
1580 if (label == NULL)
1581 return;
1583 free_st_labels (label->left);
1584 free_st_labels (label->right);
1586 if (label->format != NULL)
1587 gfc_free_expr (label->format);
1588 gfc_free (label);
1592 /* Given a label number, search for and return a pointer to the label
1593 structure, creating it if it does not exist. */
1595 gfc_st_label *
1596 gfc_get_st_label (int labelno)
1598 gfc_st_label *lp;
1600 /* First see if the label is already in this namespace. */
1601 lp = gfc_current_ns->st_labels;
1602 while (lp)
1604 if (lp->value == labelno)
1605 return lp;
1607 if (lp->value < labelno)
1608 lp = lp->left;
1609 else
1610 lp = lp->right;
1613 lp = gfc_getmem (sizeof (gfc_st_label));
1615 lp->value = labelno;
1616 lp->defined = ST_LABEL_UNKNOWN;
1617 lp->referenced = ST_LABEL_UNKNOWN;
1619 gfc_insert_bbt (&gfc_current_ns->st_labels, lp, compare_st_labels);
1621 return lp;
1625 /* Called when a statement with a statement label is about to be
1626 accepted. We add the label to the list of the current namespace,
1627 making sure it hasn't been defined previously and referenced
1628 correctly. */
1630 void
1631 gfc_define_st_label (gfc_st_label * lp, gfc_sl_type type, locus * label_locus)
1633 int labelno;
1635 labelno = lp->value;
1637 if (lp->defined != ST_LABEL_UNKNOWN)
1638 gfc_error ("Duplicate statement label %d at %L and %L", labelno,
1639 &lp->where, label_locus);
1640 else
1642 lp->where = *label_locus;
1644 switch (type)
1646 case ST_LABEL_FORMAT:
1647 if (lp->referenced == ST_LABEL_TARGET)
1648 gfc_error ("Label %d at %C already referenced as branch target",
1649 labelno);
1650 else
1651 lp->defined = ST_LABEL_FORMAT;
1653 break;
1655 case ST_LABEL_TARGET:
1656 if (lp->referenced == ST_LABEL_FORMAT)
1657 gfc_error ("Label %d at %C already referenced as a format label",
1658 labelno);
1659 else
1660 lp->defined = ST_LABEL_TARGET;
1662 break;
1664 default:
1665 lp->defined = ST_LABEL_BAD_TARGET;
1666 lp->referenced = ST_LABEL_BAD_TARGET;
1672 /* Reference a label. Given a label and its type, see if that
1673 reference is consistent with what is known about that label,
1674 updating the unknown state. Returns FAILURE if something goes
1675 wrong. */
1678 gfc_reference_st_label (gfc_st_label * lp, gfc_sl_type type)
1680 gfc_sl_type label_type;
1681 int labelno;
1682 try rc;
1684 if (lp == NULL)
1685 return SUCCESS;
1687 labelno = lp->value;
1689 if (lp->defined != ST_LABEL_UNKNOWN)
1690 label_type = lp->defined;
1691 else
1693 label_type = lp->referenced;
1694 lp->where = gfc_current_locus;
1697 if (label_type == ST_LABEL_FORMAT && type == ST_LABEL_TARGET)
1699 gfc_error ("Label %d at %C previously used as a FORMAT label", labelno);
1700 rc = FAILURE;
1701 goto done;
1704 if ((label_type == ST_LABEL_TARGET || label_type == ST_LABEL_BAD_TARGET)
1705 && type == ST_LABEL_FORMAT)
1707 gfc_error ("Label %d at %C previously used as branch target", labelno);
1708 rc = FAILURE;
1709 goto done;
1712 lp->referenced = type;
1713 rc = SUCCESS;
1715 done:
1716 return rc;
1720 /************** Symbol table management subroutines ****************/
1722 /* Basic details: Fortran 95 requires a potentially unlimited number
1723 of distinct namespaces when compiling a program unit. This case
1724 occurs during a compilation of internal subprograms because all of
1725 the internal subprograms must be read before we can start
1726 generating code for the host.
1728 Given the tricky nature of the Fortran grammar, we must be able to
1729 undo changes made to a symbol table if the current interpretation
1730 of a statement is found to be incorrect. Whenever a symbol is
1731 looked up, we make a copy of it and link to it. All of these
1732 symbols are kept in a singly linked list so that we can commit or
1733 undo the changes at a later time.
1735 A symtree may point to a symbol node outside of its namespace. In
1736 this case, that symbol has been used as a host associated variable
1737 at some previous time. */
1739 /* Allocate a new namespace structure. Copies the implicit types from
1740 PARENT if PARENT_TYPES is set. */
1742 gfc_namespace *
1743 gfc_get_namespace (gfc_namespace * parent, int parent_types)
1745 gfc_namespace *ns;
1746 gfc_typespec *ts;
1747 gfc_intrinsic_op in;
1748 int i;
1750 ns = gfc_getmem (sizeof (gfc_namespace));
1751 ns->sym_root = NULL;
1752 ns->uop_root = NULL;
1753 ns->default_access = ACCESS_UNKNOWN;
1754 ns->parent = parent;
1756 for (in = GFC_INTRINSIC_BEGIN; in != GFC_INTRINSIC_END; in++)
1757 ns->operator_access[in] = ACCESS_UNKNOWN;
1759 /* Initialize default implicit types. */
1760 for (i = 'a'; i <= 'z'; i++)
1762 ns->set_flag[i - 'a'] = 0;
1763 ts = &ns->default_type[i - 'a'];
1765 if (parent_types && ns->parent != NULL)
1767 /* Copy parent settings */
1768 *ts = ns->parent->default_type[i - 'a'];
1769 continue;
1772 if (gfc_option.flag_implicit_none != 0)
1774 gfc_clear_ts (ts);
1775 continue;
1778 if ('i' <= i && i <= 'n')
1780 ts->type = BT_INTEGER;
1781 ts->kind = gfc_default_integer_kind;
1783 else
1785 ts->type = BT_REAL;
1786 ts->kind = gfc_default_real_kind;
1790 ns->refs = 1;
1792 return ns;
1796 /* Comparison function for symtree nodes. */
1798 static int
1799 compare_symtree (void * _st1, void * _st2)
1801 gfc_symtree *st1, *st2;
1803 st1 = (gfc_symtree *) _st1;
1804 st2 = (gfc_symtree *) _st2;
1806 return strcmp (st1->name, st2->name);
1810 /* Allocate a new symtree node and associate it with the new symbol. */
1812 gfc_symtree *
1813 gfc_new_symtree (gfc_symtree ** root, const char *name)
1815 gfc_symtree *st;
1817 st = gfc_getmem (sizeof (gfc_symtree));
1818 st->name = gfc_get_string (name);
1820 gfc_insert_bbt (root, st, compare_symtree);
1821 return st;
1825 /* Delete a symbol from the tree. Does not free the symbol itself! */
1827 static void
1828 delete_symtree (gfc_symtree ** root, const char *name)
1830 gfc_symtree st, *st0;
1832 st0 = gfc_find_symtree (*root, name);
1834 st.name = gfc_get_string (name);
1835 gfc_delete_bbt (root, &st, compare_symtree);
1837 gfc_free (st0);
1841 /* Given a root symtree node and a name, try to find the symbol within
1842 the namespace. Returns NULL if the symbol is not found. */
1844 gfc_symtree *
1845 gfc_find_symtree (gfc_symtree * st, const char *name)
1847 int c;
1849 while (st != NULL)
1851 c = strcmp (name, st->name);
1852 if (c == 0)
1853 return st;
1855 st = (c < 0) ? st->left : st->right;
1858 return NULL;
1862 /* Given a name find a user operator node, creating it if it doesn't
1863 exist. These are much simpler than symbols because they can't be
1864 ambiguous with one another. */
1866 gfc_user_op *
1867 gfc_get_uop (const char *name)
1869 gfc_user_op *uop;
1870 gfc_symtree *st;
1872 st = gfc_find_symtree (gfc_current_ns->uop_root, name);
1873 if (st != NULL)
1874 return st->n.uop;
1876 st = gfc_new_symtree (&gfc_current_ns->uop_root, name);
1878 uop = st->n.uop = gfc_getmem (sizeof (gfc_user_op));
1879 uop->name = gfc_get_string (name);
1880 uop->access = ACCESS_UNKNOWN;
1881 uop->ns = gfc_current_ns;
1883 return uop;
1887 /* Given a name find the user operator node. Returns NULL if it does
1888 not exist. */
1890 gfc_user_op *
1891 gfc_find_uop (const char *name, gfc_namespace * ns)
1893 gfc_symtree *st;
1895 if (ns == NULL)
1896 ns = gfc_current_ns;
1898 st = gfc_find_symtree (ns->uop_root, name);
1899 return (st == NULL) ? NULL : st->n.uop;
1903 /* Remove a gfc_symbol structure and everything it points to. */
1905 void
1906 gfc_free_symbol (gfc_symbol * sym)
1909 if (sym == NULL)
1910 return;
1912 gfc_free_array_spec (sym->as);
1914 free_components (sym->components);
1916 gfc_free_expr (sym->value);
1918 gfc_free_namelist (sym->namelist);
1920 gfc_free_namespace (sym->formal_ns);
1922 gfc_free_interface (sym->generic);
1924 gfc_free_formal_arglist (sym->formal);
1926 gfc_free (sym);
1930 /* Allocate and initialize a new symbol node. */
1932 gfc_symbol *
1933 gfc_new_symbol (const char *name, gfc_namespace * ns)
1935 gfc_symbol *p;
1937 p = gfc_getmem (sizeof (gfc_symbol));
1939 gfc_clear_ts (&p->ts);
1940 gfc_clear_attr (&p->attr);
1941 p->ns = ns;
1943 p->declared_at = gfc_current_locus;
1945 if (strlen (name) > GFC_MAX_SYMBOL_LEN)
1946 gfc_internal_error ("new_symbol(): Symbol name too long");
1948 p->name = gfc_get_string (name);
1949 return p;
1953 /* Generate an error if a symbol is ambiguous. */
1955 static void
1956 ambiguous_symbol (const char *name, gfc_symtree * st)
1959 if (st->n.sym->module)
1960 gfc_error ("Name '%s' at %C is an ambiguous reference to '%s' "
1961 "from module '%s'", name, st->n.sym->name, st->n.sym->module);
1962 else
1963 gfc_error ("Name '%s' at %C is an ambiguous reference to '%s' "
1964 "from current program unit", name, st->n.sym->name);
1968 /* Search for a symtree starting in the current namespace, resorting to
1969 any parent namespaces if requested by a nonzero parent_flag.
1970 Returns nonzero if the name is ambiguous. */
1973 gfc_find_sym_tree (const char *name, gfc_namespace * ns, int parent_flag,
1974 gfc_symtree ** result)
1976 gfc_symtree *st;
1978 if (ns == NULL)
1979 ns = gfc_current_ns;
1983 st = gfc_find_symtree (ns->sym_root, name);
1984 if (st != NULL)
1986 *result = st;
1987 if (st->ambiguous)
1989 ambiguous_symbol (name, st);
1990 return 1;
1993 return 0;
1996 if (!parent_flag)
1997 break;
1999 ns = ns->parent;
2001 while (ns != NULL);
2003 *result = NULL;
2004 return 0;
2008 /* Same, but returns the symbol instead. */
2011 gfc_find_symbol (const char *name, gfc_namespace * ns, int parent_flag,
2012 gfc_symbol ** result)
2014 gfc_symtree *st;
2015 int i;
2017 i = gfc_find_sym_tree (name, ns, parent_flag, &st);
2019 if (st == NULL)
2020 *result = NULL;
2021 else
2022 *result = st->n.sym;
2024 return i;
2028 /* Save symbol with the information necessary to back it out. */
2030 static void
2031 save_symbol_data (gfc_symbol * sym)
2034 if (sym->new || sym->old_symbol != NULL)
2035 return;
2037 sym->old_symbol = gfc_getmem (sizeof (gfc_symbol));
2038 *(sym->old_symbol) = *sym;
2040 sym->tlink = changed_syms;
2041 changed_syms = sym;
2045 /* Given a name, find a symbol, or create it if it does not exist yet
2046 in the current namespace. If the symbol is found we make sure that
2047 it's OK.
2049 The integer return code indicates
2050 0 All OK
2051 1 The symbol name was ambiguous
2052 2 The name meant to be established was already host associated.
2054 So if the return value is nonzero, then an error was issued. */
2057 gfc_get_sym_tree (const char *name, gfc_namespace * ns, gfc_symtree ** result)
2059 gfc_symtree *st;
2060 gfc_symbol *p;
2062 /* This doesn't usually happen during resolution. */
2063 if (ns == NULL)
2064 ns = gfc_current_ns;
2066 /* Try to find the symbol in ns. */
2067 st = gfc_find_symtree (ns->sym_root, name);
2069 if (st == NULL)
2071 /* If not there, create a new symbol. */
2072 p = gfc_new_symbol (name, ns);
2074 /* Add to the list of tentative symbols. */
2075 p->old_symbol = NULL;
2076 p->tlink = changed_syms;
2077 p->mark = 1;
2078 p->new = 1;
2079 changed_syms = p;
2081 st = gfc_new_symtree (&ns->sym_root, name);
2082 st->n.sym = p;
2083 p->refs++;
2086 else
2088 /* Make sure the existing symbol is OK. */
2089 if (st->ambiguous)
2091 ambiguous_symbol (name, st);
2092 return 1;
2095 p = st->n.sym;
2097 if (p->ns != ns && (!p->attr.function || ns->proc_name != p))
2099 /* Symbol is from another namespace. */
2100 gfc_error ("Symbol '%s' at %C has already been host associated",
2101 name);
2102 return 2;
2105 p->mark = 1;
2107 /* Copy in case this symbol is changed. */
2108 save_symbol_data (p);
2111 *result = st;
2112 return 0;
2117 gfc_get_symbol (const char *name, gfc_namespace * ns, gfc_symbol ** result)
2119 gfc_symtree *st;
2120 int i;
2123 i = gfc_get_sym_tree (name, ns, &st);
2124 if (i != 0)
2125 return i;
2127 if (st)
2128 *result = st->n.sym;
2129 else
2130 *result = NULL;
2131 return i;
2135 /* Subroutine that searches for a symbol, creating it if it doesn't
2136 exist, but tries to host-associate the symbol if possible. */
2139 gfc_get_ha_sym_tree (const char *name, gfc_symtree ** result)
2141 gfc_symtree *st;
2142 int i;
2144 i = gfc_find_sym_tree (name, gfc_current_ns, 0, &st);
2145 if (st != NULL)
2147 save_symbol_data (st->n.sym);
2149 *result = st;
2150 return i;
2153 if (gfc_current_ns->parent != NULL)
2155 i = gfc_find_sym_tree (name, gfc_current_ns->parent, 1, &st);
2156 if (i)
2157 return i;
2159 if (st != NULL)
2161 *result = st;
2162 return 0;
2166 return gfc_get_sym_tree (name, gfc_current_ns, result);
2171 gfc_get_ha_symbol (const char *name, gfc_symbol ** result)
2173 int i;
2174 gfc_symtree *st;
2176 i = gfc_get_ha_sym_tree (name, &st);
2178 if (st)
2179 *result = st->n.sym;
2180 else
2181 *result = NULL;
2183 return i;
2186 /* Return true if both symbols could refer to the same data object. Does
2187 not take account of aliasing due to equivalence statements. */
2190 gfc_symbols_could_alias (gfc_symbol * lsym, gfc_symbol * rsym)
2192 /* Aliasing isn't possible if the symbols have different base types. */
2193 if (gfc_compare_types (&lsym->ts, &rsym->ts) == 0)
2194 return 0;
2196 /* Pointers can point to other pointers, target objects and allocatable
2197 objects. Two allocatable objects cannot share the same storage. */
2198 if (lsym->attr.pointer
2199 && (rsym->attr.pointer || rsym->attr.allocatable || rsym->attr.target))
2200 return 1;
2201 if (lsym->attr.target && rsym->attr.pointer)
2202 return 1;
2203 if (lsym->attr.allocatable && rsym->attr.pointer)
2204 return 1;
2206 return 0;
2210 /* Undoes all the changes made to symbols in the current statement.
2211 This subroutine is made simpler due to the fact that attributes are
2212 never removed once added. */
2214 void
2215 gfc_undo_symbols (void)
2217 gfc_symbol *p, *q, *old;
2219 for (p = changed_syms; p; p = q)
2221 q = p->tlink;
2223 if (p->new)
2225 /* Symbol was new. */
2226 delete_symtree (&p->ns->sym_root, p->name);
2228 p->refs--;
2229 if (p->refs < 0)
2230 gfc_internal_error ("gfc_undo_symbols(): Negative refs");
2231 if (p->refs == 0)
2232 gfc_free_symbol (p);
2233 continue;
2236 /* Restore previous state of symbol. Just copy simple stuff. */
2237 p->mark = 0;
2238 old = p->old_symbol;
2240 p->ts.type = old->ts.type;
2241 p->ts.kind = old->ts.kind;
2243 p->attr = old->attr;
2245 if (p->value != old->value)
2247 gfc_free_expr (old->value);
2248 p->value = NULL;
2251 if (p->as != old->as)
2253 if (p->as)
2254 gfc_free_array_spec (p->as);
2255 p->as = old->as;
2258 p->generic = old->generic;
2259 p->component_access = old->component_access;
2261 if (p->namelist != NULL && old->namelist == NULL)
2263 gfc_free_namelist (p->namelist);
2264 p->namelist = NULL;
2266 else
2269 if (p->namelist_tail != old->namelist_tail)
2271 gfc_free_namelist (old->namelist_tail);
2272 old->namelist_tail->next = NULL;
2276 p->namelist_tail = old->namelist_tail;
2278 if (p->formal != old->formal)
2280 gfc_free_formal_arglist (p->formal);
2281 p->formal = old->formal;
2284 gfc_free (p->old_symbol);
2285 p->old_symbol = NULL;
2286 p->tlink = NULL;
2289 changed_syms = NULL;
2293 /* Free sym->old_symbol. sym->old_symbol is mostly a shallow copy of sym; the
2294 components of old_symbol that might need deallocation are the "allocatables"
2295 that are restored in gfc_undo_symbols(), with two exceptions: namelist and
2296 namelist_tail. In case these differ between old_symbol and sym, it's just
2297 because sym->namelist has gotten a few more items. */
2299 static void
2300 free_old_symbol (gfc_symbol * sym)
2302 if (sym->old_symbol == NULL)
2303 return;
2305 if (sym->old_symbol->as != sym->as)
2306 gfc_free_array_spec (sym->old_symbol->as);
2308 if (sym->old_symbol->value != sym->value)
2309 gfc_free_expr (sym->old_symbol->value);
2311 if (sym->old_symbol->formal != sym->formal)
2312 gfc_free_formal_arglist (sym->old_symbol->formal);
2314 gfc_free (sym->old_symbol);
2315 sym->old_symbol = NULL;
2319 /* Makes the changes made in the current statement permanent-- gets
2320 rid of undo information. */
2322 void
2323 gfc_commit_symbols (void)
2325 gfc_symbol *p, *q;
2327 for (p = changed_syms; p; p = q)
2329 q = p->tlink;
2330 p->tlink = NULL;
2331 p->mark = 0;
2332 p->new = 0;
2334 free_old_symbol (p);
2336 changed_syms = NULL;
2340 /* Makes the changes made in one symbol permanent -- gets rid of undo
2341 information. */
2343 void
2344 gfc_commit_symbol (gfc_symbol * sym)
2346 gfc_symbol *p;
2348 if (changed_syms == sym)
2349 changed_syms = sym->tlink;
2350 else
2352 for (p = changed_syms; p; p = p->tlink)
2353 if (p->tlink == sym)
2355 p->tlink = sym->tlink;
2356 break;
2360 sym->tlink = NULL;
2361 sym->mark = 0;
2362 sym->new = 0;
2364 free_old_symbol (sym);
2368 /* Recursive function that deletes an entire tree and all the common
2369 head structures it points to. */
2371 static void
2372 free_common_tree (gfc_symtree * common_tree)
2374 if (common_tree == NULL)
2375 return;
2377 free_common_tree (common_tree->left);
2378 free_common_tree (common_tree->right);
2380 gfc_free (common_tree);
2384 /* Recursive function that deletes an entire tree and all the user
2385 operator nodes that it contains. */
2387 static void
2388 free_uop_tree (gfc_symtree * uop_tree)
2391 if (uop_tree == NULL)
2392 return;
2394 free_uop_tree (uop_tree->left);
2395 free_uop_tree (uop_tree->right);
2397 gfc_free_interface (uop_tree->n.uop->operator);
2399 gfc_free (uop_tree->n.uop);
2400 gfc_free (uop_tree);
2404 /* Recursive function that deletes an entire tree and all the symbols
2405 that it contains. */
2407 static void
2408 free_sym_tree (gfc_symtree * sym_tree)
2410 gfc_namespace *ns;
2411 gfc_symbol *sym;
2413 if (sym_tree == NULL)
2414 return;
2416 free_sym_tree (sym_tree->left);
2417 free_sym_tree (sym_tree->right);
2419 sym = sym_tree->n.sym;
2421 sym->refs--;
2422 if (sym->refs < 0)
2423 gfc_internal_error ("free_sym_tree(): Negative refs");
2425 if (sym->formal_ns != NULL && sym->refs == 1)
2427 /* As formal_ns contains a reference to sym, delete formal_ns just
2428 before the deletion of sym. */
2429 ns = sym->formal_ns;
2430 sym->formal_ns = NULL;
2431 gfc_free_namespace (ns);
2433 else if (sym->refs == 0)
2435 /* Go ahead and delete the symbol. */
2436 gfc_free_symbol (sym);
2439 gfc_free (sym_tree);
2443 /* Free a derived type list. */
2445 static void
2446 gfc_free_dt_list (gfc_dt_list * dt)
2448 gfc_dt_list *n;
2450 for (; dt; dt = n)
2452 n = dt->next;
2453 gfc_free (dt);
2458 /* Free the gfc_equiv_info's. */
2460 static void
2461 gfc_free_equiv_infos (gfc_equiv_info * s)
2463 if (s == NULL)
2464 return;
2465 gfc_free_equiv_infos (s->next);
2466 gfc_free (s);
2470 /* Free the gfc_equiv_lists. */
2472 static void
2473 gfc_free_equiv_lists (gfc_equiv_list * l)
2475 if (l == NULL)
2476 return;
2477 gfc_free_equiv_lists (l->next);
2478 gfc_free_equiv_infos (l->equiv);
2479 gfc_free (l);
2483 /* Free a namespace structure and everything below it. Interface
2484 lists associated with intrinsic operators are not freed. These are
2485 taken care of when a specific name is freed. */
2487 void
2488 gfc_free_namespace (gfc_namespace * ns)
2490 gfc_charlen *cl, *cl2;
2491 gfc_namespace *p, *q;
2492 gfc_intrinsic_op i;
2494 if (ns == NULL)
2495 return;
2497 ns->refs--;
2498 if (ns->refs > 0)
2499 return;
2500 gcc_assert (ns->refs == 0);
2502 gfc_free_statements (ns->code);
2504 free_sym_tree (ns->sym_root);
2505 free_uop_tree (ns->uop_root);
2506 free_common_tree (ns->common_root);
2508 for (cl = ns->cl_list; cl; cl = cl2)
2510 cl2 = cl->next;
2511 gfc_free_expr (cl->length);
2512 gfc_free (cl);
2515 free_st_labels (ns->st_labels);
2517 gfc_free_equiv (ns->equiv);
2518 gfc_free_equiv_lists (ns->equiv_lists);
2520 gfc_free_dt_list (ns->derived_types);
2522 for (i = GFC_INTRINSIC_BEGIN; i != GFC_INTRINSIC_END; i++)
2523 gfc_free_interface (ns->operator[i]);
2525 gfc_free_data (ns->data);
2526 p = ns->contained;
2527 gfc_free (ns);
2529 /* Recursively free any contained namespaces. */
2530 while (p != NULL)
2532 q = p;
2533 p = p->sibling;
2535 gfc_free_namespace (q);
2540 void
2541 gfc_symbol_init_2 (void)
2544 gfc_current_ns = gfc_get_namespace (NULL, 0);
2548 void
2549 gfc_symbol_done_2 (void)
2552 gfc_free_namespace (gfc_current_ns);
2553 gfc_current_ns = NULL;
2557 /* Clear mark bits from symbol nodes associated with a symtree node. */
2559 static void
2560 clear_sym_mark (gfc_symtree * st)
2563 st->n.sym->mark = 0;
2567 /* Recursively traverse the symtree nodes. */
2569 void
2570 gfc_traverse_symtree (gfc_symtree * st, void (*func) (gfc_symtree *))
2572 if (st != NULL)
2574 (*func) (st);
2576 gfc_traverse_symtree (st->left, func);
2577 gfc_traverse_symtree (st->right, func);
2582 /* Recursive namespace traversal function. */
2584 static void
2585 traverse_ns (gfc_symtree * st, void (*func) (gfc_symbol *))
2588 if (st == NULL)
2589 return;
2591 if (st->n.sym->mark == 0)
2592 (*func) (st->n.sym);
2593 st->n.sym->mark = 1;
2595 traverse_ns (st->left, func);
2596 traverse_ns (st->right, func);
2600 /* Call a given function for all symbols in the namespace. We take
2601 care that each gfc_symbol node is called exactly once. */
2603 void
2604 gfc_traverse_ns (gfc_namespace * ns, void (*func) (gfc_symbol *))
2607 gfc_traverse_symtree (ns->sym_root, clear_sym_mark);
2609 traverse_ns (ns->sym_root, func);
2613 /* Return TRUE if the symbol is an automatic variable. */
2614 static bool
2615 gfc_is_var_automatic (gfc_symbol * sym)
2617 /* Pointer and allocatable variables are never automatic. */
2618 if (sym->attr.pointer || sym->attr.allocatable)
2619 return false;
2620 /* Check for arrays with non-constant size. */
2621 if (sym->attr.dimension && sym->as
2622 && !gfc_is_compile_time_shape (sym->as))
2623 return true;
2624 /* Check for non-constant length character variables. */
2625 if (sym->ts.type == BT_CHARACTER
2626 && sym->ts.cl
2627 && !gfc_is_constant_expr (sym->ts.cl->length))
2628 return true;
2629 return false;
2632 /* Given a symbol, mark it as SAVEd if it is allowed. */
2634 static void
2635 save_symbol (gfc_symbol * sym)
2638 if (sym->attr.use_assoc)
2639 return;
2641 if (sym->attr.in_common
2642 || sym->attr.dummy
2643 || sym->attr.flavor != FL_VARIABLE)
2644 return;
2645 /* Automatic objects are not saved. */
2646 if (gfc_is_var_automatic (sym))
2647 return;
2648 gfc_add_save (&sym->attr, sym->name, &sym->declared_at);
2652 /* Mark those symbols which can be SAVEd as such. */
2654 void
2655 gfc_save_all (gfc_namespace * ns)
2658 gfc_traverse_ns (ns, save_symbol);
2662 #ifdef GFC_DEBUG
2663 /* Make sure that no changes to symbols are pending. */
2665 void
2666 gfc_symbol_state(void) {
2668 if (changed_syms != NULL)
2669 gfc_internal_error("Symbol changes still pending!");
2671 #endif
2674 /************** Global symbol handling ************/
2677 /* Search a tree for the global symbol. */
2679 gfc_gsymbol *
2680 gfc_find_gsymbol (gfc_gsymbol *symbol, const char *name)
2682 gfc_gsymbol *s;
2684 if (symbol == NULL)
2685 return NULL;
2686 if (strcmp (symbol->name, name) == 0)
2687 return symbol;
2689 s = gfc_find_gsymbol (symbol->left, name);
2690 if (s != NULL)
2691 return s;
2693 s = gfc_find_gsymbol (symbol->right, name);
2694 if (s != NULL)
2695 return s;
2697 return NULL;
2701 /* Compare two global symbols. Used for managing the BB tree. */
2703 static int
2704 gsym_compare (void * _s1, void * _s2)
2706 gfc_gsymbol *s1, *s2;
2708 s1 = (gfc_gsymbol *)_s1;
2709 s2 = (gfc_gsymbol *)_s2;
2710 return strcmp(s1->name, s2->name);
2714 /* Get a global symbol, creating it if it doesn't exist. */
2716 gfc_gsymbol *
2717 gfc_get_gsymbol (const char *name)
2719 gfc_gsymbol *s;
2721 s = gfc_find_gsymbol (gfc_gsym_root, name);
2722 if (s != NULL)
2723 return s;
2725 s = gfc_getmem (sizeof (gfc_gsymbol));
2726 s->type = GSYM_UNKNOWN;
2727 s->name = gfc_get_string (name);
2729 gfc_insert_bbt (&gfc_gsym_root, s, gsym_compare);
2731 return s;