re PR fortran/49540 (Memory-hog with large DATA stmt)
[gcc.git] / gcc / fortran / resolve.c
1 /* Perform type resolution on the various structures.
2 Copyright (C) 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008, 2009,
3 2010, 2011
4 Free Software Foundation, Inc.
5 Contributed by Andy Vaught
6
7 This file is part of GCC.
8
9 GCC is free software; you can redistribute it and/or modify it under
10 the terms of the GNU General Public License as published by the Free
11 Software Foundation; either version 3, or (at your option) any later
12 version.
13
14 GCC is distributed in the hope that it will be useful, but WITHOUT ANY
15 WARRANTY; without even the implied warranty of MERCHANTABILITY or
16 FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
17 for more details.
18
19 You should have received a copy of the GNU General Public License
20 along with GCC; see the file COPYING3. If not see
21 <http://www.gnu.org/licenses/>. */
22
23 #include "config.h"
24 #include "system.h"
25 #include "flags.h"
26 #include "gfortran.h"
27 #include "obstack.h"
28 #include "bitmap.h"
29 #include "arith.h" /* For gfc_compare_expr(). */
30 #include "dependency.h"
31 #include "data.h"
32 #include "target-memory.h" /* for gfc_simplify_transfer */
33 #include "constructor.h"
34
35 /* Types used in equivalence statements. */
36
37 typedef enum seq_type
38 {
39 SEQ_NONDEFAULT, SEQ_NUMERIC, SEQ_CHARACTER, SEQ_MIXED
40 }
41 seq_type;
42
43 /* Stack to keep track of the nesting of blocks as we move through the
44 code. See resolve_branch() and resolve_code(). */
45
46 typedef struct code_stack
47 {
48 struct gfc_code *head, *current;
49 struct code_stack *prev;
50
51 /* This bitmap keeps track of the targets valid for a branch from
52 inside this block except for END {IF|SELECT}s of enclosing
53 blocks. */
54 bitmap reachable_labels;
55 }
56 code_stack;
57
58 static code_stack *cs_base = NULL;
59
60
61 /* Nonzero if we're inside a FORALL block. */
62
63 static int forall_flag;
64
65 /* Nonzero if we're inside a OpenMP WORKSHARE or PARALLEL WORKSHARE block. */
66
67 static int omp_workshare_flag;
68
69 /* Nonzero if we are processing a formal arglist. The corresponding function
70 resets the flag each time that it is read. */
71 static int formal_arg_flag = 0;
72
73 /* True if we are resolving a specification expression. */
74 static int specification_expr = 0;
75
76 /* The id of the last entry seen. */
77 static int current_entry_id;
78
79 /* We use bitmaps to determine if a branch target is valid. */
80 static bitmap_obstack labels_obstack;
81
82 /* True when simplifying a EXPR_VARIABLE argument to an inquiry function. */
83 static bool inquiry_argument = false;
84
85 int
86 gfc_is_formal_arg (void)
87 {
88 return formal_arg_flag;
89 }
90
91 /* Is the symbol host associated? */
92 static bool
93 is_sym_host_assoc (gfc_symbol *sym, gfc_namespace *ns)
94 {
95 for (ns = ns->parent; ns; ns = ns->parent)
96 {
97 if (sym->ns == ns)
98 return true;
99 }
100
101 return false;
102 }
103
104 /* Ensure a typespec used is valid; for instance, TYPE(t) is invalid if t is
105 an ABSTRACT derived-type. If where is not NULL, an error message with that
106 locus is printed, optionally using name. */
107
108 static gfc_try
109 resolve_typespec_used (gfc_typespec* ts, locus* where, const char* name)
110 {
111 if (ts->type == BT_DERIVED && ts->u.derived->attr.abstract)
112 {
113 if (where)
114 {
115 if (name)
116 gfc_error ("'%s' at %L is of the ABSTRACT type '%s'",
117 name, where, ts->u.derived->name);
118 else
119 gfc_error ("ABSTRACT type '%s' used at %L",
120 ts->u.derived->name, where);
121 }
122
123 return FAILURE;
124 }
125
126 return SUCCESS;
127 }
128
129
130 static void resolve_symbol (gfc_symbol *sym);
131 static gfc_try resolve_intrinsic (gfc_symbol *sym, locus *loc);
132
133
134 /* Resolve the interface for a PROCEDURE declaration or procedure pointer. */
135
136 static gfc_try
137 resolve_procedure_interface (gfc_symbol *sym)
138 {
139 if (sym->ts.interface == sym)
140 {
141 gfc_error ("PROCEDURE '%s' at %L may not be used as its own interface",
142 sym->name, &sym->declared_at);
143 return FAILURE;
144 }
145 if (sym->ts.interface->attr.procedure)
146 {
147 gfc_error ("Interface '%s', used by procedure '%s' at %L, is declared "
148 "in a later PROCEDURE statement", sym->ts.interface->name,
149 sym->name, &sym->declared_at);
150 return FAILURE;
151 }
152
153 /* Get the attributes from the interface (now resolved). */
154 if (sym->ts.interface->attr.if_source || sym->ts.interface->attr.intrinsic)
155 {
156 gfc_symbol *ifc = sym->ts.interface;
157 resolve_symbol (ifc);
158
159 if (ifc->attr.intrinsic)
160 resolve_intrinsic (ifc, &ifc->declared_at);
161
162 if (ifc->result)
163 {
164 sym->ts = ifc->result->ts;
165 sym->result = sym;
166 }
167 else
168 sym->ts = ifc->ts;
169 sym->ts.interface = ifc;
170 sym->attr.function = ifc->attr.function;
171 sym->attr.subroutine = ifc->attr.subroutine;
172 gfc_copy_formal_args (sym, ifc);
173
174 sym->attr.allocatable = ifc->attr.allocatable;
175 sym->attr.pointer = ifc->attr.pointer;
176 sym->attr.pure = ifc->attr.pure;
177 sym->attr.elemental = ifc->attr.elemental;
178 sym->attr.dimension = ifc->attr.dimension;
179 sym->attr.contiguous = ifc->attr.contiguous;
180 sym->attr.recursive = ifc->attr.recursive;
181 sym->attr.always_explicit = ifc->attr.always_explicit;
182 sym->attr.ext_attr |= ifc->attr.ext_attr;
183 sym->attr.is_bind_c = ifc->attr.is_bind_c;
184 /* Copy array spec. */
185 sym->as = gfc_copy_array_spec (ifc->as);
186 if (sym->as)
187 {
188 int i;
189 for (i = 0; i < sym->as->rank; i++)
190 {
191 gfc_expr_replace_symbols (sym->as->lower[i], sym);
192 gfc_expr_replace_symbols (sym->as->upper[i], sym);
193 }
194 }
195 /* Copy char length. */
196 if (ifc->ts.type == BT_CHARACTER && ifc->ts.u.cl)
197 {
198 sym->ts.u.cl = gfc_new_charlen (sym->ns, ifc->ts.u.cl);
199 gfc_expr_replace_symbols (sym->ts.u.cl->length, sym);
200 if (sym->ts.u.cl->length && !sym->ts.u.cl->resolved
201 && gfc_resolve_expr (sym->ts.u.cl->length) == FAILURE)
202 return FAILURE;
203 }
204 }
205 else if (sym->ts.interface->name[0] != '\0')
206 {
207 gfc_error ("Interface '%s' of procedure '%s' at %L must be explicit",
208 sym->ts.interface->name, sym->name, &sym->declared_at);
209 return FAILURE;
210 }
211
212 return SUCCESS;
213 }
214
215
216 /* Resolve types of formal argument lists. These have to be done early so that
217 the formal argument lists of module procedures can be copied to the
218 containing module before the individual procedures are resolved
219 individually. We also resolve argument lists of procedures in interface
220 blocks because they are self-contained scoping units.
221
222 Since a dummy argument cannot be a non-dummy procedure, the only
223 resort left for untyped names are the IMPLICIT types. */
224
225 static void
226 resolve_formal_arglist (gfc_symbol *proc)
227 {
228 gfc_formal_arglist *f;
229 gfc_symbol *sym;
230 int i;
231
232 if (proc->result != NULL)
233 sym = proc->result;
234 else
235 sym = proc;
236
237 if (gfc_elemental (proc)
238 || sym->attr.pointer || sym->attr.allocatable
239 || (sym->as && sym->as->rank > 0))
240 {
241 proc->attr.always_explicit = 1;
242 sym->attr.always_explicit = 1;
243 }
244
245 formal_arg_flag = 1;
246
247 for (f = proc->formal; f; f = f->next)
248 {
249 sym = f->sym;
250
251 if (sym == NULL)
252 {
253 /* Alternate return placeholder. */
254 if (gfc_elemental (proc))
255 gfc_error ("Alternate return specifier in elemental subroutine "
256 "'%s' at %L is not allowed", proc->name,
257 &proc->declared_at);
258 if (proc->attr.function)
259 gfc_error ("Alternate return specifier in function "
260 "'%s' at %L is not allowed", proc->name,
261 &proc->declared_at);
262 continue;
263 }
264 else if (sym->attr.procedure && sym->ts.interface
265 && sym->attr.if_source != IFSRC_DECL)
266 resolve_procedure_interface (sym);
267
268 if (sym->attr.if_source != IFSRC_UNKNOWN)
269 resolve_formal_arglist (sym);
270
271 if (sym->attr.subroutine || sym->attr.external || sym->attr.intrinsic)
272 {
273 if (gfc_pure (proc) && !gfc_pure (sym))
274 {
275 gfc_error ("Dummy procedure '%s' of PURE procedure at %L must "
276 "also be PURE", sym->name, &sym->declared_at);
277 continue;
278 }
279
280 if (proc->attr.implicit_pure && !gfc_pure(sym))
281 proc->attr.implicit_pure = 0;
282
283 if (gfc_elemental (proc))
284 {
285 gfc_error ("Dummy procedure at %L not allowed in ELEMENTAL "
286 "procedure", &sym->declared_at);
287 continue;
288 }
289
290 if (sym->attr.function
291 && sym->ts.type == BT_UNKNOWN
292 && sym->attr.intrinsic)
293 {
294 gfc_intrinsic_sym *isym;
295 isym = gfc_find_function (sym->name);
296 if (isym == NULL || !isym->specific)
297 {
298 gfc_error ("Unable to find a specific INTRINSIC procedure "
299 "for the reference '%s' at %L", sym->name,
300 &sym->declared_at);
301 }
302 sym->ts = isym->ts;
303 }
304
305 continue;
306 }
307
308 if (sym->ts.type == BT_UNKNOWN && !proc->attr.intrinsic
309 && (!sym->attr.function || sym->result == sym))
310 gfc_set_default_type (sym, 1, sym->ns);
311
312 gfc_resolve_array_spec (sym->as, 0);
313
314 /* We can't tell if an array with dimension (:) is assumed or deferred
315 shape until we know if it has the pointer or allocatable attributes.
316 */
317 if (sym->as && sym->as->rank > 0 && sym->as->type == AS_DEFERRED
318 && !(sym->attr.pointer || sym->attr.allocatable)
319 && sym->attr.flavor != FL_PROCEDURE)
320 {
321 sym->as->type = AS_ASSUMED_SHAPE;
322 for (i = 0; i < sym->as->rank; i++)
323 sym->as->lower[i] = gfc_get_int_expr (gfc_default_integer_kind,
324 NULL, 1);
325 }
326
327 if ((sym->as && sym->as->rank > 0 && sym->as->type == AS_ASSUMED_SHAPE)
328 || sym->attr.pointer || sym->attr.allocatable || sym->attr.target
329 || sym->attr.optional)
330 {
331 proc->attr.always_explicit = 1;
332 if (proc->result)
333 proc->result->attr.always_explicit = 1;
334 }
335
336 /* If the flavor is unknown at this point, it has to be a variable.
337 A procedure specification would have already set the type. */
338
339 if (sym->attr.flavor == FL_UNKNOWN)
340 gfc_add_flavor (&sym->attr, FL_VARIABLE, sym->name, &sym->declared_at);
341
342 if (gfc_pure (proc) && !sym->attr.pointer
343 && sym->attr.flavor != FL_PROCEDURE)
344 {
345 if (proc->attr.function && sym->attr.intent != INTENT_IN)
346 {
347 if (sym->attr.value)
348 gfc_notify_std (GFC_STD_F2008, "Fortran 2008: Argument '%s' "
349 "of pure function '%s' at %L with VALUE "
350 "attribute but without INTENT(IN)", sym->name,
351 proc->name, &sym->declared_at);
352 else
353 gfc_error ("Argument '%s' of pure function '%s' at %L must be "
354 "INTENT(IN) or VALUE", sym->name, proc->name,
355 &sym->declared_at);
356 }
357
358 if (proc->attr.subroutine && sym->attr.intent == INTENT_UNKNOWN)
359 {
360 if (sym->attr.value)
361 gfc_notify_std (GFC_STD_F2008, "Fortran 2008: Argument '%s' "
362 "of pure subroutine '%s' at %L with VALUE "
363 "attribute but without INTENT", sym->name,
364 proc->name, &sym->declared_at);
365 else
366 gfc_error ("Argument '%s' of pure subroutine '%s' at %L must "
367 "have its INTENT specified or have the VALUE "
368 "attribute", sym->name, proc->name, &sym->declared_at);
369 }
370 }
371
372 if (proc->attr.implicit_pure && !sym->attr.pointer
373 && sym->attr.flavor != FL_PROCEDURE)
374 {
375 if (proc->attr.function && sym->attr.intent != INTENT_IN)
376 proc->attr.implicit_pure = 0;
377
378 if (proc->attr.subroutine && sym->attr.intent == INTENT_UNKNOWN)
379 proc->attr.implicit_pure = 0;
380 }
381
382 if (gfc_elemental (proc))
383 {
384 /* F2008, C1289. */
385 if (sym->attr.codimension)
386 {
387 gfc_error ("Coarray dummy argument '%s' at %L to elemental "
388 "procedure", sym->name, &sym->declared_at);
389 continue;
390 }
391
392 if (sym->as != NULL)
393 {
394 gfc_error ("Argument '%s' of elemental procedure at %L must "
395 "be scalar", sym->name, &sym->declared_at);
396 continue;
397 }
398
399 if (sym->attr.allocatable)
400 {
401 gfc_error ("Argument '%s' of elemental procedure at %L cannot "
402 "have the ALLOCATABLE attribute", sym->name,
403 &sym->declared_at);
404 continue;
405 }
406
407 if (sym->attr.pointer)
408 {
409 gfc_error ("Argument '%s' of elemental procedure at %L cannot "
410 "have the POINTER attribute", sym->name,
411 &sym->declared_at);
412 continue;
413 }
414
415 if (sym->attr.flavor == FL_PROCEDURE)
416 {
417 gfc_error ("Dummy procedure '%s' not allowed in elemental "
418 "procedure '%s' at %L", sym->name, proc->name,
419 &sym->declared_at);
420 continue;
421 }
422
423 if (sym->attr.intent == INTENT_UNKNOWN)
424 {
425 gfc_error ("Argument '%s' of elemental procedure '%s' at %L must "
426 "have its INTENT specified", sym->name, proc->name,
427 &sym->declared_at);
428 continue;
429 }
430 }
431
432 /* Each dummy shall be specified to be scalar. */
433 if (proc->attr.proc == PROC_ST_FUNCTION)
434 {
435 if (sym->as != NULL)
436 {
437 gfc_error ("Argument '%s' of statement function at %L must "
438 "be scalar", sym->name, &sym->declared_at);
439 continue;
440 }
441
442 if (sym->ts.type == BT_CHARACTER)
443 {
444 gfc_charlen *cl = sym->ts.u.cl;
445 if (!cl || !cl->length || cl->length->expr_type != EXPR_CONSTANT)
446 {
447 gfc_error ("Character-valued argument '%s' of statement "
448 "function at %L must have constant length",
449 sym->name, &sym->declared_at);
450 continue;
451 }
452 }
453 }
454 }
455 formal_arg_flag = 0;
456 }
457
458
459 /* Work function called when searching for symbols that have argument lists
460 associated with them. */
461
462 static void
463 find_arglists (gfc_symbol *sym)
464 {
465 if (sym->attr.if_source == IFSRC_UNKNOWN || sym->ns != gfc_current_ns)
466 return;
467
468 resolve_formal_arglist (sym);
469 }
470
471
472 /* Given a namespace, resolve all formal argument lists within the namespace.
473 */
474
475 static void
476 resolve_formal_arglists (gfc_namespace *ns)
477 {
478 if (ns == NULL)
479 return;
480
481 gfc_traverse_ns (ns, find_arglists);
482 }
483
484
485 static void
486 resolve_contained_fntype (gfc_symbol *sym, gfc_namespace *ns)
487 {
488 gfc_try t;
489
490 /* If this namespace is not a function or an entry master function,
491 ignore it. */
492 if (! sym || !(sym->attr.function || sym->attr.flavor == FL_VARIABLE)
493 || sym->attr.entry_master)
494 return;
495
496 /* Try to find out of what the return type is. */
497 if (sym->result->ts.type == BT_UNKNOWN && sym->result->ts.interface == NULL)
498 {
499 t = gfc_set_default_type (sym->result, 0, ns);
500
501 if (t == FAILURE && !sym->result->attr.untyped)
502 {
503 if (sym->result == sym)
504 gfc_error ("Contained function '%s' at %L has no IMPLICIT type",
505 sym->name, &sym->declared_at);
506 else if (!sym->result->attr.proc_pointer)
507 gfc_error ("Result '%s' of contained function '%s' at %L has "
508 "no IMPLICIT type", sym->result->name, sym->name,
509 &sym->result->declared_at);
510 sym->result->attr.untyped = 1;
511 }
512 }
513
514 /* Fortran 95 Draft Standard, page 51, Section 5.1.1.5, on the Character
515 type, lists the only ways a character length value of * can be used:
516 dummy arguments of procedures, named constants, and function results
517 in external functions. Internal function results and results of module
518 procedures are not on this list, ergo, not permitted. */
519
520 if (sym->result->ts.type == BT_CHARACTER)
521 {
522 gfc_charlen *cl = sym->result->ts.u.cl;
523 if ((!cl || !cl->length) && !sym->result->ts.deferred)
524 {
525 /* See if this is a module-procedure and adapt error message
526 accordingly. */
527 bool module_proc;
528 gcc_assert (ns->parent && ns->parent->proc_name);
529 module_proc = (ns->parent->proc_name->attr.flavor == FL_MODULE);
530
531 gfc_error ("Character-valued %s '%s' at %L must not be"
532 " assumed length",
533 module_proc ? _("module procedure")
534 : _("internal function"),
535 sym->name, &sym->declared_at);
536 }
537 }
538 }
539
540
541 /* Add NEW_ARGS to the formal argument list of PROC, taking care not to
542 introduce duplicates. */
543
544 static void
545 merge_argument_lists (gfc_symbol *proc, gfc_formal_arglist *new_args)
546 {
547 gfc_formal_arglist *f, *new_arglist;
548 gfc_symbol *new_sym;
549
550 for (; new_args != NULL; new_args = new_args->next)
551 {
552 new_sym = new_args->sym;
553 /* See if this arg is already in the formal argument list. */
554 for (f = proc->formal; f; f = f->next)
555 {
556 if (new_sym == f->sym)
557 break;
558 }
559
560 if (f)
561 continue;
562
563 /* Add a new argument. Argument order is not important. */
564 new_arglist = gfc_get_formal_arglist ();
565 new_arglist->sym = new_sym;
566 new_arglist->next = proc->formal;
567 proc->formal = new_arglist;
568 }
569 }
570
571
572 /* Flag the arguments that are not present in all entries. */
573
574 static void
575 check_argument_lists (gfc_symbol *proc, gfc_formal_arglist *new_args)
576 {
577 gfc_formal_arglist *f, *head;
578 head = new_args;
579
580 for (f = proc->formal; f; f = f->next)
581 {
582 if (f->sym == NULL)
583 continue;
584
585 for (new_args = head; new_args; new_args = new_args->next)
586 {
587 if (new_args->sym == f->sym)
588 break;
589 }
590
591 if (new_args)
592 continue;
593
594 f->sym->attr.not_always_present = 1;
595 }
596 }
597
598
599 /* Resolve alternate entry points. If a symbol has multiple entry points we
600 create a new master symbol for the main routine, and turn the existing
601 symbol into an entry point. */
602
603 static void
604 resolve_entries (gfc_namespace *ns)
605 {
606 gfc_namespace *old_ns;
607 gfc_code *c;
608 gfc_symbol *proc;
609 gfc_entry_list *el;
610 char name[GFC_MAX_SYMBOL_LEN + 1];
611 static int master_count = 0;
612
613 if (ns->proc_name == NULL)
614 return;
615
616 /* No need to do anything if this procedure doesn't have alternate entry
617 points. */
618 if (!ns->entries)
619 return;
620
621 /* We may already have resolved alternate entry points. */
622 if (ns->proc_name->attr.entry_master)
623 return;
624
625 /* If this isn't a procedure something has gone horribly wrong. */
626 gcc_assert (ns->proc_name->attr.flavor == FL_PROCEDURE);
627
628 /* Remember the current namespace. */
629 old_ns = gfc_current_ns;
630
631 gfc_current_ns = ns;
632
633 /* Add the main entry point to the list of entry points. */
634 el = gfc_get_entry_list ();
635 el->sym = ns->proc_name;
636 el->id = 0;
637 el->next = ns->entries;
638 ns->entries = el;
639 ns->proc_name->attr.entry = 1;
640
641 /* If it is a module function, it needs to be in the right namespace
642 so that gfc_get_fake_result_decl can gather up the results. The
643 need for this arose in get_proc_name, where these beasts were
644 left in their own namespace, to keep prior references linked to
645 the entry declaration.*/
646 if (ns->proc_name->attr.function
647 && ns->parent && ns->parent->proc_name->attr.flavor == FL_MODULE)
648 el->sym->ns = ns;
649
650 /* Do the same for entries where the master is not a module
651 procedure. These are retained in the module namespace because
652 of the module procedure declaration. */
653 for (el = el->next; el; el = el->next)
654 if (el->sym->ns->proc_name->attr.flavor == FL_MODULE
655 && el->sym->attr.mod_proc)
656 el->sym->ns = ns;
657 el = ns->entries;
658
659 /* Add an entry statement for it. */
660 c = gfc_get_code ();
661 c->op = EXEC_ENTRY;
662 c->ext.entry = el;
663 c->next = ns->code;
664 ns->code = c;
665
666 /* Create a new symbol for the master function. */
667 /* Give the internal function a unique name (within this file).
668 Also include the function name so the user has some hope of figuring
669 out what is going on. */
670 snprintf (name, GFC_MAX_SYMBOL_LEN, "master.%d.%s",
671 master_count++, ns->proc_name->name);
672 gfc_get_ha_symbol (name, &proc);
673 gcc_assert (proc != NULL);
674
675 gfc_add_procedure (&proc->attr, PROC_INTERNAL, proc->name, NULL);
676 if (ns->proc_name->attr.subroutine)
677 gfc_add_subroutine (&proc->attr, proc->name, NULL);
678 else
679 {
680 gfc_symbol *sym;
681 gfc_typespec *ts, *fts;
682 gfc_array_spec *as, *fas;
683 gfc_add_function (&proc->attr, proc->name, NULL);
684 proc->result = proc;
685 fas = ns->entries->sym->as;
686 fas = fas ? fas : ns->entries->sym->result->as;
687 fts = &ns->entries->sym->result->ts;
688 if (fts->type == BT_UNKNOWN)
689 fts = gfc_get_default_type (ns->entries->sym->result->name, NULL);
690 for (el = ns->entries->next; el; el = el->next)
691 {
692 ts = &el->sym->result->ts;
693 as = el->sym->as;
694 as = as ? as : el->sym->result->as;
695 if (ts->type == BT_UNKNOWN)
696 ts = gfc_get_default_type (el->sym->result->name, NULL);
697
698 if (! gfc_compare_types (ts, fts)
699 || (el->sym->result->attr.dimension
700 != ns->entries->sym->result->attr.dimension)
701 || (el->sym->result->attr.pointer
702 != ns->entries->sym->result->attr.pointer))
703 break;
704 else if (as && fas && ns->entries->sym->result != el->sym->result
705 && gfc_compare_array_spec (as, fas) == 0)
706 gfc_error ("Function %s at %L has entries with mismatched "
707 "array specifications", ns->entries->sym->name,
708 &ns->entries->sym->declared_at);
709 /* The characteristics need to match and thus both need to have
710 the same string length, i.e. both len=*, or both len=4.
711 Having both len=<variable> is also possible, but difficult to
712 check at compile time. */
713 else if (ts->type == BT_CHARACTER && ts->u.cl && fts->u.cl
714 && (((ts->u.cl->length && !fts->u.cl->length)
715 ||(!ts->u.cl->length && fts->u.cl->length))
716 || (ts->u.cl->length
717 && ts->u.cl->length->expr_type
718 != fts->u.cl->length->expr_type)
719 || (ts->u.cl->length
720 && ts->u.cl->length->expr_type == EXPR_CONSTANT
721 && mpz_cmp (ts->u.cl->length->value.integer,
722 fts->u.cl->length->value.integer) != 0)))
723 gfc_notify_std (GFC_STD_GNU, "Extension: Function %s at %L with "
724 "entries returning variables of different "
725 "string lengths", ns->entries->sym->name,
726 &ns->entries->sym->declared_at);
727 }
728
729 if (el == NULL)
730 {
731 sym = ns->entries->sym->result;
732 /* All result types the same. */
733 proc->ts = *fts;
734 if (sym->attr.dimension)
735 gfc_set_array_spec (proc, gfc_copy_array_spec (sym->as), NULL);
736 if (sym->attr.pointer)
737 gfc_add_pointer (&proc->attr, NULL);
738 }
739 else
740 {
741 /* Otherwise the result will be passed through a union by
742 reference. */
743 proc->attr.mixed_entry_master = 1;
744 for (el = ns->entries; el; el = el->next)
745 {
746 sym = el->sym->result;
747 if (sym->attr.dimension)
748 {
749 if (el == ns->entries)
750 gfc_error ("FUNCTION result %s can't be an array in "
751 "FUNCTION %s at %L", sym->name,
752 ns->entries->sym->name, &sym->declared_at);
753 else
754 gfc_error ("ENTRY result %s can't be an array in "
755 "FUNCTION %s at %L", sym->name,
756 ns->entries->sym->name, &sym->declared_at);
757 }
758 else if (sym->attr.pointer)
759 {
760 if (el == ns->entries)
761 gfc_error ("FUNCTION result %s can't be a POINTER in "
762 "FUNCTION %s at %L", sym->name,
763 ns->entries->sym->name, &sym->declared_at);
764 else
765 gfc_error ("ENTRY result %s can't be a POINTER in "
766 "FUNCTION %s at %L", sym->name,
767 ns->entries->sym->name, &sym->declared_at);
768 }
769 else
770 {
771 ts = &sym->ts;
772 if (ts->type == BT_UNKNOWN)
773 ts = gfc_get_default_type (sym->name, NULL);
774 switch (ts->type)
775 {
776 case BT_INTEGER:
777 if (ts->kind == gfc_default_integer_kind)
778 sym = NULL;
779 break;
780 case BT_REAL:
781 if (ts->kind == gfc_default_real_kind
782 || ts->kind == gfc_default_double_kind)
783 sym = NULL;
784 break;
785 case BT_COMPLEX:
786 if (ts->kind == gfc_default_complex_kind)
787 sym = NULL;
788 break;
789 case BT_LOGICAL:
790 if (ts->kind == gfc_default_logical_kind)
791 sym = NULL;
792 break;
793 case BT_UNKNOWN:
794 /* We will issue error elsewhere. */
795 sym = NULL;
796 break;
797 default:
798 break;
799 }
800 if (sym)
801 {
802 if (el == ns->entries)
803 gfc_error ("FUNCTION result %s can't be of type %s "
804 "in FUNCTION %s at %L", sym->name,
805 gfc_typename (ts), ns->entries->sym->name,
806 &sym->declared_at);
807 else
808 gfc_error ("ENTRY result %s can't be of type %s "
809 "in FUNCTION %s at %L", sym->name,
810 gfc_typename (ts), ns->entries->sym->name,
811 &sym->declared_at);
812 }
813 }
814 }
815 }
816 }
817 proc->attr.access = ACCESS_PRIVATE;
818 proc->attr.entry_master = 1;
819
820 /* Merge all the entry point arguments. */
821 for (el = ns->entries; el; el = el->next)
822 merge_argument_lists (proc, el->sym->formal);
823
824 /* Check the master formal arguments for any that are not
825 present in all entry points. */
826 for (el = ns->entries; el; el = el->next)
827 check_argument_lists (proc, el->sym->formal);
828
829 /* Use the master function for the function body. */
830 ns->proc_name = proc;
831
832 /* Finalize the new symbols. */
833 gfc_commit_symbols ();
834
835 /* Restore the original namespace. */
836 gfc_current_ns = old_ns;
837 }
838
839
840 /* Resolve common variables. */
841 static void
842 resolve_common_vars (gfc_symbol *sym, bool named_common)
843 {
844 gfc_symbol *csym = sym;
845
846 for (; csym; csym = csym->common_next)
847 {
848 if (csym->value || csym->attr.data)
849 {
850 if (!csym->ns->is_block_data)
851 gfc_notify_std (GFC_STD_GNU, "Variable '%s' at %L is in COMMON "
852 "but only in BLOCK DATA initialization is "
853 "allowed", csym->name, &csym->declared_at);
854 else if (!named_common)
855 gfc_notify_std (GFC_STD_GNU, "Initialized variable '%s' at %L is "
856 "in a blank COMMON but initialization is only "
857 "allowed in named common blocks", csym->name,
858 &csym->declared_at);
859 }
860
861 if (csym->ts.type != BT_DERIVED)
862 continue;
863
864 if (!(csym->ts.u.derived->attr.sequence
865 || csym->ts.u.derived->attr.is_bind_c))
866 gfc_error_now ("Derived type variable '%s' in COMMON at %L "
867 "has neither the SEQUENCE nor the BIND(C) "
868 "attribute", csym->name, &csym->declared_at);
869 if (csym->ts.u.derived->attr.alloc_comp)
870 gfc_error_now ("Derived type variable '%s' in COMMON at %L "
871 "has an ultimate component that is "
872 "allocatable", csym->name, &csym->declared_at);
873 if (gfc_has_default_initializer (csym->ts.u.derived))
874 gfc_error_now ("Derived type variable '%s' in COMMON at %L "
875 "may not have default initializer", csym->name,
876 &csym->declared_at);
877
878 if (csym->attr.flavor == FL_UNKNOWN && !csym->attr.proc_pointer)
879 gfc_add_flavor (&csym->attr, FL_VARIABLE, csym->name, &csym->declared_at);
880 }
881 }
882
883 /* Resolve common blocks. */
884 static void
885 resolve_common_blocks (gfc_symtree *common_root)
886 {
887 gfc_symbol *sym;
888
889 if (common_root == NULL)
890 return;
891
892 if (common_root->left)
893 resolve_common_blocks (common_root->left);
894 if (common_root->right)
895 resolve_common_blocks (common_root->right);
896
897 resolve_common_vars (common_root->n.common->head, true);
898
899 gfc_find_symbol (common_root->name, gfc_current_ns, 0, &sym);
900 if (sym == NULL)
901 return;
902
903 if (sym->attr.flavor == FL_PARAMETER)
904 gfc_error ("COMMON block '%s' at %L is used as PARAMETER at %L",
905 sym->name, &common_root->n.common->where, &sym->declared_at);
906
907 if (sym->attr.intrinsic)
908 gfc_error ("COMMON block '%s' at %L is also an intrinsic procedure",
909 sym->name, &common_root->n.common->where);
910 else if (sym->attr.result
911 || gfc_is_function_return_value (sym, gfc_current_ns))
912 gfc_notify_std (GFC_STD_F2003, "Fortran 2003: COMMON block '%s' at %L "
913 "that is also a function result", sym->name,
914 &common_root->n.common->where);
915 else if (sym->attr.flavor == FL_PROCEDURE && sym->attr.proc != PROC_INTERNAL
916 && sym->attr.proc != PROC_ST_FUNCTION)
917 gfc_notify_std (GFC_STD_F2003, "Fortran 2003: COMMON block '%s' at %L "
918 "that is also a global procedure", sym->name,
919 &common_root->n.common->where);
920 }
921
922
923 /* Resolve contained function types. Because contained functions can call one
924 another, they have to be worked out before any of the contained procedures
925 can be resolved.
926
927 The good news is that if a function doesn't already have a type, the only
928 way it can get one is through an IMPLICIT type or a RESULT variable, because
929 by definition contained functions are contained namespace they're contained
930 in, not in a sibling or parent namespace. */
931
932 static void
933 resolve_contained_functions (gfc_namespace *ns)
934 {
935 gfc_namespace *child;
936 gfc_entry_list *el;
937
938 resolve_formal_arglists (ns);
939
940 for (child = ns->contained; child; child = child->sibling)
941 {
942 /* Resolve alternate entry points first. */
943 resolve_entries (child);
944
945 /* Then check function return types. */
946 resolve_contained_fntype (child->proc_name, child);
947 for (el = child->entries; el; el = el->next)
948 resolve_contained_fntype (el->sym, child);
949 }
950 }
951
952
953 /* Resolve all of the elements of a structure constructor and make sure that
954 the types are correct. The 'init' flag indicates that the given
955 constructor is an initializer. */
956
957 static gfc_try
958 resolve_structure_cons (gfc_expr *expr, int init)
959 {
960 gfc_constructor *cons;
961 gfc_component *comp;
962 gfc_try t;
963 symbol_attribute a;
964
965 t = SUCCESS;
966
967 if (expr->ts.type == BT_DERIVED)
968 resolve_symbol (expr->ts.u.derived);
969
970 cons = gfc_constructor_first (expr->value.constructor);
971 /* A constructor may have references if it is the result of substituting a
972 parameter variable. In this case we just pull out the component we
973 want. */
974 if (expr->ref)
975 comp = expr->ref->u.c.sym->components;
976 else
977 comp = expr->ts.u.derived->components;
978
979 /* See if the user is trying to invoke a structure constructor for one of
980 the iso_c_binding derived types. */
981 if (expr->ts.type == BT_DERIVED && expr->ts.u.derived
982 && expr->ts.u.derived->ts.is_iso_c && cons
983 && (cons->expr == NULL || cons->expr->expr_type != EXPR_NULL))
984 {
985 gfc_error ("Components of structure constructor '%s' at %L are PRIVATE",
986 expr->ts.u.derived->name, &(expr->where));
987 return FAILURE;
988 }
989
990 /* Return if structure constructor is c_null_(fun)prt. */
991 if (expr->ts.type == BT_DERIVED && expr->ts.u.derived
992 && expr->ts.u.derived->ts.is_iso_c && cons
993 && cons->expr && cons->expr->expr_type == EXPR_NULL)
994 return SUCCESS;
995
996 for (; comp && cons; comp = comp->next, cons = gfc_constructor_next (cons))
997 {
998 int rank;
999
1000 if (!cons->expr)
1001 continue;
1002
1003 if (gfc_resolve_expr (cons->expr) == FAILURE)
1004 {
1005 t = FAILURE;
1006 continue;
1007 }
1008
1009 rank = comp->as ? comp->as->rank : 0;
1010 if (cons->expr->expr_type != EXPR_NULL && rank != cons->expr->rank
1011 && (comp->attr.allocatable || cons->expr->rank))
1012 {
1013 gfc_error ("The rank of the element in the derived type "
1014 "constructor at %L does not match that of the "
1015 "component (%d/%d)", &cons->expr->where,
1016 cons->expr->rank, rank);
1017 t = FAILURE;
1018 }
1019
1020 /* If we don't have the right type, try to convert it. */
1021
1022 if (!comp->attr.proc_pointer &&
1023 !gfc_compare_types (&cons->expr->ts, &comp->ts))
1024 {
1025 t = FAILURE;
1026 if (strcmp (comp->name, "_extends") == 0)
1027 {
1028 /* Can afford to be brutal with the _extends initializer.
1029 The derived type can get lost because it is PRIVATE
1030 but it is not usage constrained by the standard. */
1031 cons->expr->ts = comp->ts;
1032 t = SUCCESS;
1033 }
1034 else if (comp->attr.pointer && cons->expr->ts.type != BT_UNKNOWN)
1035 gfc_error ("The element in the derived type constructor at %L, "
1036 "for pointer component '%s', is %s but should be %s",
1037 &cons->expr->where, comp->name,
1038 gfc_basic_typename (cons->expr->ts.type),
1039 gfc_basic_typename (comp->ts.type));
1040 else
1041 t = gfc_convert_type (cons->expr, &comp->ts, 1);
1042 }
1043
1044 /* For strings, the length of the constructor should be the same as
1045 the one of the structure, ensure this if the lengths are known at
1046 compile time and when we are dealing with PARAMETER or structure
1047 constructors. */
1048 if (cons->expr->ts.type == BT_CHARACTER && comp->ts.u.cl
1049 && comp->ts.u.cl->length
1050 && comp->ts.u.cl->length->expr_type == EXPR_CONSTANT
1051 && cons->expr->ts.u.cl && cons->expr->ts.u.cl->length
1052 && cons->expr->ts.u.cl->length->expr_type == EXPR_CONSTANT
1053 && mpz_cmp (cons->expr->ts.u.cl->length->value.integer,
1054 comp->ts.u.cl->length->value.integer) != 0)
1055 {
1056 if (cons->expr->expr_type == EXPR_VARIABLE
1057 && cons->expr->symtree->n.sym->attr.flavor == FL_PARAMETER)
1058 {
1059 /* Wrap the parameter in an array constructor (EXPR_ARRAY)
1060 to make use of the gfc_resolve_character_array_constructor
1061 machinery. The expression is later simplified away to
1062 an array of string literals. */
1063 gfc_expr *para = cons->expr;
1064 cons->expr = gfc_get_expr ();
1065 cons->expr->ts = para->ts;
1066 cons->expr->where = para->where;
1067 cons->expr->expr_type = EXPR_ARRAY;
1068 cons->expr->rank = para->rank;
1069 cons->expr->shape = gfc_copy_shape (para->shape, para->rank);
1070 gfc_constructor_append_expr (&cons->expr->value.constructor,
1071 para, &cons->expr->where);
1072 }
1073 if (cons->expr->expr_type == EXPR_ARRAY)
1074 {
1075 gfc_constructor *p;
1076 p = gfc_constructor_first (cons->expr->value.constructor);
1077 if (cons->expr->ts.u.cl != p->expr->ts.u.cl)
1078 {
1079 gfc_charlen *cl, *cl2;
1080
1081 cl2 = NULL;
1082 for (cl = gfc_current_ns->cl_list; cl; cl = cl->next)
1083 {
1084 if (cl == cons->expr->ts.u.cl)
1085 break;
1086 cl2 = cl;
1087 }
1088
1089 gcc_assert (cl);
1090
1091 if (cl2)
1092 cl2->next = cl->next;
1093
1094 gfc_free_expr (cl->length);
1095 free (cl);
1096 }
1097
1098 cons->expr->ts.u.cl = gfc_new_charlen (gfc_current_ns, NULL);
1099 cons->expr->ts.u.cl->length_from_typespec = true;
1100 cons->expr->ts.u.cl->length = gfc_copy_expr (comp->ts.u.cl->length);
1101 gfc_resolve_character_array_constructor (cons->expr);
1102 }
1103 }
1104
1105 if (cons->expr->expr_type == EXPR_NULL
1106 && !(comp->attr.pointer || comp->attr.allocatable
1107 || comp->attr.proc_pointer
1108 || (comp->ts.type == BT_CLASS
1109 && (CLASS_DATA (comp)->attr.class_pointer
1110 || CLASS_DATA (comp)->attr.allocatable))))
1111 {
1112 t = FAILURE;
1113 gfc_error ("The NULL in the derived type constructor at %L is "
1114 "being applied to component '%s', which is neither "
1115 "a POINTER nor ALLOCATABLE", &cons->expr->where,
1116 comp->name);
1117 }
1118
1119 if (!comp->attr.pointer || comp->attr.proc_pointer
1120 || cons->expr->expr_type == EXPR_NULL)
1121 continue;
1122
1123 a = gfc_expr_attr (cons->expr);
1124
1125 if (!a.pointer && !a.target)
1126 {
1127 t = FAILURE;
1128 gfc_error ("The element in the derived type constructor at %L, "
1129 "for pointer component '%s' should be a POINTER or "
1130 "a TARGET", &cons->expr->where, comp->name);
1131 }
1132
1133 if (init)
1134 {
1135 /* F08:C461. Additional checks for pointer initialization. */
1136 if (a.allocatable)
1137 {
1138 t = FAILURE;
1139 gfc_error ("Pointer initialization target at %L "
1140 "must not be ALLOCATABLE ", &cons->expr->where);
1141 }
1142 if (!a.save)
1143 {
1144 t = FAILURE;
1145 gfc_error ("Pointer initialization target at %L "
1146 "must have the SAVE attribute", &cons->expr->where);
1147 }
1148 }
1149
1150 /* F2003, C1272 (3). */
1151 if (gfc_pure (NULL) && cons->expr->expr_type == EXPR_VARIABLE
1152 && (gfc_impure_variable (cons->expr->symtree->n.sym)
1153 || gfc_is_coindexed (cons->expr)))
1154 {
1155 t = FAILURE;
1156 gfc_error ("Invalid expression in the derived type constructor for "
1157 "pointer component '%s' at %L in PURE procedure",
1158 comp->name, &cons->expr->where);
1159 }
1160
1161 if (gfc_implicit_pure (NULL)
1162 && cons->expr->expr_type == EXPR_VARIABLE
1163 && (gfc_impure_variable (cons->expr->symtree->n.sym)
1164 || gfc_is_coindexed (cons->expr)))
1165 gfc_current_ns->proc_name->attr.implicit_pure = 0;
1166
1167 }
1168
1169 return t;
1170 }
1171
1172
1173 /****************** Expression name resolution ******************/
1174
1175 /* Returns 0 if a symbol was not declared with a type or
1176 attribute declaration statement, nonzero otherwise. */
1177
1178 static int
1179 was_declared (gfc_symbol *sym)
1180 {
1181 symbol_attribute a;
1182
1183 a = sym->attr;
1184
1185 if (!a.implicit_type && sym->ts.type != BT_UNKNOWN)
1186 return 1;
1187
1188 if (a.allocatable || a.dimension || a.dummy || a.external || a.intrinsic
1189 || a.optional || a.pointer || a.save || a.target || a.volatile_
1190 || a.value || a.access != ACCESS_UNKNOWN || a.intent != INTENT_UNKNOWN
1191 || a.asynchronous || a.codimension)
1192 return 1;
1193
1194 return 0;
1195 }
1196
1197
1198 /* Determine if a symbol is generic or not. */
1199
1200 static int
1201 generic_sym (gfc_symbol *sym)
1202 {
1203 gfc_symbol *s;
1204
1205 if (sym->attr.generic ||
1206 (sym->attr.intrinsic && gfc_generic_intrinsic (sym->name)))
1207 return 1;
1208
1209 if (was_declared (sym) || sym->ns->parent == NULL)
1210 return 0;
1211
1212 gfc_find_symbol (sym->name, sym->ns->parent, 1, &s);
1213
1214 if (s != NULL)
1215 {
1216 if (s == sym)
1217 return 0;
1218 else
1219 return generic_sym (s);
1220 }
1221
1222 return 0;
1223 }
1224
1225
1226 /* Determine if a symbol is specific or not. */
1227
1228 static int
1229 specific_sym (gfc_symbol *sym)
1230 {
1231 gfc_symbol *s;
1232
1233 if (sym->attr.if_source == IFSRC_IFBODY
1234 || sym->attr.proc == PROC_MODULE
1235 || sym->attr.proc == PROC_INTERNAL
1236 || sym->attr.proc == PROC_ST_FUNCTION
1237 || (sym->attr.intrinsic && gfc_specific_intrinsic (sym->name))
1238 || sym->attr.external)
1239 return 1;
1240
1241 if (was_declared (sym) || sym->ns->parent == NULL)
1242 return 0;
1243
1244 gfc_find_symbol (sym->name, sym->ns->parent, 1, &s);
1245
1246 return (s == NULL) ? 0 : specific_sym (s);
1247 }
1248
1249
1250 /* Figure out if the procedure is specific, generic or unknown. */
1251
1252 typedef enum
1253 { PTYPE_GENERIC = 1, PTYPE_SPECIFIC, PTYPE_UNKNOWN }
1254 proc_type;
1255
1256 static proc_type
1257 procedure_kind (gfc_symbol *sym)
1258 {
1259 if (generic_sym (sym))
1260 return PTYPE_GENERIC;
1261
1262 if (specific_sym (sym))
1263 return PTYPE_SPECIFIC;
1264
1265 return PTYPE_UNKNOWN;
1266 }
1267
1268 /* Check references to assumed size arrays. The flag need_full_assumed_size
1269 is nonzero when matching actual arguments. */
1270
1271 static int need_full_assumed_size = 0;
1272
1273 static bool
1274 check_assumed_size_reference (gfc_symbol *sym, gfc_expr *e)
1275 {
1276 if (need_full_assumed_size || !(sym->as && sym->as->type == AS_ASSUMED_SIZE))
1277 return false;
1278
1279 /* FIXME: The comparison "e->ref->u.ar.type == AR_FULL" is wrong.
1280 What should it be? */
1281 if ((e->ref->u.ar.end[e->ref->u.ar.as->rank - 1] == NULL)
1282 && (e->ref->u.ar.as->type == AS_ASSUMED_SIZE)
1283 && (e->ref->u.ar.type == AR_FULL))
1284 {
1285 gfc_error ("The upper bound in the last dimension must "
1286 "appear in the reference to the assumed size "
1287 "array '%s' at %L", sym->name, &e->where);
1288 return true;
1289 }
1290 return false;
1291 }
1292
1293
1294 /* Look for bad assumed size array references in argument expressions
1295 of elemental and array valued intrinsic procedures. Since this is
1296 called from procedure resolution functions, it only recurses at
1297 operators. */
1298
1299 static bool
1300 resolve_assumed_size_actual (gfc_expr *e)
1301 {
1302 if (e == NULL)
1303 return false;
1304
1305 switch (e->expr_type)
1306 {
1307 case EXPR_VARIABLE:
1308 if (e->symtree && check_assumed_size_reference (e->symtree->n.sym, e))
1309 return true;
1310 break;
1311
1312 case EXPR_OP:
1313 if (resolve_assumed_size_actual (e->value.op.op1)
1314 || resolve_assumed_size_actual (e->value.op.op2))
1315 return true;
1316 break;
1317
1318 default:
1319 break;
1320 }
1321 return false;
1322 }
1323
1324
1325 /* Check a generic procedure, passed as an actual argument, to see if
1326 there is a matching specific name. If none, it is an error, and if
1327 more than one, the reference is ambiguous. */
1328 static int
1329 count_specific_procs (gfc_expr *e)
1330 {
1331 int n;
1332 gfc_interface *p;
1333 gfc_symbol *sym;
1334
1335 n = 0;
1336 sym = e->symtree->n.sym;
1337
1338 for (p = sym->generic; p; p = p->next)
1339 if (strcmp (sym->name, p->sym->name) == 0)
1340 {
1341 e->symtree = gfc_find_symtree (p->sym->ns->sym_root,
1342 sym->name);
1343 n++;
1344 }
1345
1346 if (n > 1)
1347 gfc_error ("'%s' at %L is ambiguous", e->symtree->n.sym->name,
1348 &e->where);
1349
1350 if (n == 0)
1351 gfc_error ("GENERIC procedure '%s' is not allowed as an actual "
1352 "argument at %L", sym->name, &e->where);
1353
1354 return n;
1355 }
1356
1357
1358 /* See if a call to sym could possibly be a not allowed RECURSION because of
1359 a missing RECURIVE declaration. This means that either sym is the current
1360 context itself, or sym is the parent of a contained procedure calling its
1361 non-RECURSIVE containing procedure.
1362 This also works if sym is an ENTRY. */
1363
1364 static bool
1365 is_illegal_recursion (gfc_symbol* sym, gfc_namespace* context)
1366 {
1367 gfc_symbol* proc_sym;
1368 gfc_symbol* context_proc;
1369 gfc_namespace* real_context;
1370
1371 if (sym->attr.flavor == FL_PROGRAM)
1372 return false;
1373
1374 gcc_assert (sym->attr.flavor == FL_PROCEDURE);
1375
1376 /* If we've got an ENTRY, find real procedure. */
1377 if (sym->attr.entry && sym->ns->entries)
1378 proc_sym = sym->ns->entries->sym;
1379 else
1380 proc_sym = sym;
1381
1382 /* If sym is RECURSIVE, all is well of course. */
1383 if (proc_sym->attr.recursive || gfc_option.flag_recursive)
1384 return false;
1385
1386 /* Find the context procedure's "real" symbol if it has entries.
1387 We look for a procedure symbol, so recurse on the parents if we don't
1388 find one (like in case of a BLOCK construct). */
1389 for (real_context = context; ; real_context = real_context->parent)
1390 {
1391 /* We should find something, eventually! */
1392 gcc_assert (real_context);
1393
1394 context_proc = (real_context->entries ? real_context->entries->sym
1395 : real_context->proc_name);
1396
1397 /* In some special cases, there may not be a proc_name, like for this
1398 invalid code:
1399 real(bad_kind()) function foo () ...
1400 when checking the call to bad_kind ().
1401 In these cases, we simply return here and assume that the
1402 call is ok. */
1403 if (!context_proc)
1404 return false;
1405
1406 if (context_proc->attr.flavor != FL_LABEL)
1407 break;
1408 }
1409
1410 /* A call from sym's body to itself is recursion, of course. */
1411 if (context_proc == proc_sym)
1412 return true;
1413
1414 /* The same is true if context is a contained procedure and sym the
1415 containing one. */
1416 if (context_proc->attr.contained)
1417 {
1418 gfc_symbol* parent_proc;
1419
1420 gcc_assert (context->parent);
1421 parent_proc = (context->parent->entries ? context->parent->entries->sym
1422 : context->parent->proc_name);
1423
1424 if (parent_proc == proc_sym)
1425 return true;
1426 }
1427
1428 return false;
1429 }
1430
1431
1432 /* Resolve an intrinsic procedure: Set its function/subroutine attribute,
1433 its typespec and formal argument list. */
1434
1435 static gfc_try
1436 resolve_intrinsic (gfc_symbol *sym, locus *loc)
1437 {
1438 gfc_intrinsic_sym* isym = NULL;
1439 const char* symstd;
1440
1441 if (sym->formal)
1442 return SUCCESS;
1443
1444 /* Already resolved. */
1445 if (sym->from_intmod && sym->ts.type != BT_UNKNOWN)
1446 return SUCCESS;
1447
1448 /* We already know this one is an intrinsic, so we don't call
1449 gfc_is_intrinsic for full checking but rather use gfc_find_function and
1450 gfc_find_subroutine directly to check whether it is a function or
1451 subroutine. */
1452
1453 if (sym->intmod_sym_id)
1454 isym = gfc_intrinsic_function_by_id ((gfc_isym_id) sym->intmod_sym_id);
1455 else
1456 isym = gfc_find_function (sym->name);
1457
1458 if (isym)
1459 {
1460 if (sym->ts.type != BT_UNKNOWN && gfc_option.warn_surprising
1461 && !sym->attr.implicit_type)
1462 gfc_warning ("Type specified for intrinsic function '%s' at %L is"
1463 " ignored", sym->name, &sym->declared_at);
1464
1465 if (!sym->attr.function &&
1466 gfc_add_function (&sym->attr, sym->name, loc) == FAILURE)
1467 return FAILURE;
1468
1469 sym->ts = isym->ts;
1470 }
1471 else if ((isym = gfc_find_subroutine (sym->name)))
1472 {
1473 if (sym->ts.type != BT_UNKNOWN && !sym->attr.implicit_type)
1474 {
1475 gfc_error ("Intrinsic subroutine '%s' at %L shall not have a type"
1476 " specifier", sym->name, &sym->declared_at);
1477 return FAILURE;
1478 }
1479
1480 if (!sym->attr.subroutine &&
1481 gfc_add_subroutine (&sym->attr, sym->name, loc) == FAILURE)
1482 return FAILURE;
1483 }
1484 else
1485 {
1486 gfc_error ("'%s' declared INTRINSIC at %L does not exist", sym->name,
1487 &sym->declared_at);
1488 return FAILURE;
1489 }
1490
1491 gfc_copy_formal_args_intr (sym, isym);
1492
1493 /* Check it is actually available in the standard settings. */
1494 if (gfc_check_intrinsic_standard (isym, &symstd, false, sym->declared_at)
1495 == FAILURE)
1496 {
1497 gfc_error ("The intrinsic '%s' declared INTRINSIC at %L is not"
1498 " available in the current standard settings but %s. Use"
1499 " an appropriate -std=* option or enable -fall-intrinsics"
1500 " in order to use it.",
1501 sym->name, &sym->declared_at, symstd);
1502 return FAILURE;
1503 }
1504
1505 return SUCCESS;
1506 }
1507
1508
1509 /* Resolve a procedure expression, like passing it to a called procedure or as
1510 RHS for a procedure pointer assignment. */
1511
1512 static gfc_try
1513 resolve_procedure_expression (gfc_expr* expr)
1514 {
1515 gfc_symbol* sym;
1516
1517 if (expr->expr_type != EXPR_VARIABLE)
1518 return SUCCESS;
1519 gcc_assert (expr->symtree);
1520
1521 sym = expr->symtree->n.sym;
1522
1523 if (sym->attr.intrinsic)
1524 resolve_intrinsic (sym, &expr->where);
1525
1526 if (sym->attr.flavor != FL_PROCEDURE
1527 || (sym->attr.function && sym->result == sym))
1528 return SUCCESS;
1529
1530 /* A non-RECURSIVE procedure that is used as procedure expression within its
1531 own body is in danger of being called recursively. */
1532 if (is_illegal_recursion (sym, gfc_current_ns))
1533 gfc_warning ("Non-RECURSIVE procedure '%s' at %L is possibly calling"
1534 " itself recursively. Declare it RECURSIVE or use"
1535 " -frecursive", sym->name, &expr->where);
1536
1537 return SUCCESS;
1538 }
1539
1540
1541 /* Resolve an actual argument list. Most of the time, this is just
1542 resolving the expressions in the list.
1543 The exception is that we sometimes have to decide whether arguments
1544 that look like procedure arguments are really simple variable
1545 references. */
1546
1547 static gfc_try
1548 resolve_actual_arglist (gfc_actual_arglist *arg, procedure_type ptype,
1549 bool no_formal_args)
1550 {
1551 gfc_symbol *sym;
1552 gfc_symtree *parent_st;
1553 gfc_expr *e;
1554 int save_need_full_assumed_size;
1555
1556 for (; arg; arg = arg->next)
1557 {
1558 e = arg->expr;
1559 if (e == NULL)
1560 {
1561 /* Check the label is a valid branching target. */
1562 if (arg->label)
1563 {
1564 if (arg->label->defined == ST_LABEL_UNKNOWN)
1565 {
1566 gfc_error ("Label %d referenced at %L is never defined",
1567 arg->label->value, &arg->label->where);
1568 return FAILURE;
1569 }
1570 }
1571 continue;
1572 }
1573
1574 if (e->expr_type == EXPR_VARIABLE
1575 && e->symtree->n.sym->attr.generic
1576 && no_formal_args
1577 && count_specific_procs (e) != 1)
1578 return FAILURE;
1579
1580 if (e->ts.type != BT_PROCEDURE)
1581 {
1582 save_need_full_assumed_size = need_full_assumed_size;
1583 if (e->expr_type != EXPR_VARIABLE)
1584 need_full_assumed_size = 0;
1585 if (gfc_resolve_expr (e) != SUCCESS)
1586 return FAILURE;
1587 need_full_assumed_size = save_need_full_assumed_size;
1588 goto argument_list;
1589 }
1590
1591 /* See if the expression node should really be a variable reference. */
1592
1593 sym = e->symtree->n.sym;
1594
1595 if (sym->attr.flavor == FL_PROCEDURE
1596 || sym->attr.intrinsic
1597 || sym->attr.external)
1598 {
1599 int actual_ok;
1600
1601 /* If a procedure is not already determined to be something else
1602 check if it is intrinsic. */
1603 if (!sym->attr.intrinsic
1604 && !(sym->attr.external || sym->attr.use_assoc
1605 || sym->attr.if_source == IFSRC_IFBODY)
1606 && gfc_is_intrinsic (sym, sym->attr.subroutine, e->where))
1607 sym->attr.intrinsic = 1;
1608
1609 if (sym->attr.proc == PROC_ST_FUNCTION)
1610 {
1611 gfc_error ("Statement function '%s' at %L is not allowed as an "
1612 "actual argument", sym->name, &e->where);
1613 }
1614
1615 actual_ok = gfc_intrinsic_actual_ok (sym->name,
1616 sym->attr.subroutine);
1617 if (sym->attr.intrinsic && actual_ok == 0)
1618 {
1619 gfc_error ("Intrinsic '%s' at %L is not allowed as an "
1620 "actual argument", sym->name, &e->where);
1621 }
1622
1623 if (sym->attr.contained && !sym->attr.use_assoc
1624 && sym->ns->proc_name->attr.flavor != FL_MODULE)
1625 {
1626 if (gfc_notify_std (GFC_STD_F2008,
1627 "Fortran 2008: Internal procedure '%s' is"
1628 " used as actual argument at %L",
1629 sym->name, &e->where) == FAILURE)
1630 return FAILURE;
1631 }
1632
1633 if (sym->attr.elemental && !sym->attr.intrinsic)
1634 {
1635 gfc_error ("ELEMENTAL non-INTRINSIC procedure '%s' is not "
1636 "allowed as an actual argument at %L", sym->name,
1637 &e->where);
1638 }
1639
1640 /* Check if a generic interface has a specific procedure
1641 with the same name before emitting an error. */
1642 if (sym->attr.generic && count_specific_procs (e) != 1)
1643 return FAILURE;
1644
1645 /* Just in case a specific was found for the expression. */
1646 sym = e->symtree->n.sym;
1647
1648 /* If the symbol is the function that names the current (or
1649 parent) scope, then we really have a variable reference. */
1650
1651 if (gfc_is_function_return_value (sym, sym->ns))
1652 goto got_variable;
1653
1654 /* If all else fails, see if we have a specific intrinsic. */
1655 if (sym->ts.type == BT_UNKNOWN && sym->attr.intrinsic)
1656 {
1657 gfc_intrinsic_sym *isym;
1658
1659 isym = gfc_find_function (sym->name);
1660 if (isym == NULL || !isym->specific)
1661 {
1662 gfc_error ("Unable to find a specific INTRINSIC procedure "
1663 "for the reference '%s' at %L", sym->name,
1664 &e->where);
1665 return FAILURE;
1666 }
1667 sym->ts = isym->ts;
1668 sym->attr.intrinsic = 1;
1669 sym->attr.function = 1;
1670 }
1671
1672 if (gfc_resolve_expr (e) == FAILURE)
1673 return FAILURE;
1674 goto argument_list;
1675 }
1676
1677 /* See if the name is a module procedure in a parent unit. */
1678
1679 if (was_declared (sym) || sym->ns->parent == NULL)
1680 goto got_variable;
1681
1682 if (gfc_find_sym_tree (sym->name, sym->ns->parent, 1, &parent_st))
1683 {
1684 gfc_error ("Symbol '%s' at %L is ambiguous", sym->name, &e->where);
1685 return FAILURE;
1686 }
1687
1688 if (parent_st == NULL)
1689 goto got_variable;
1690
1691 sym = parent_st->n.sym;
1692 e->symtree = parent_st; /* Point to the right thing. */
1693
1694 if (sym->attr.flavor == FL_PROCEDURE
1695 || sym->attr.intrinsic
1696 || sym->attr.external)
1697 {
1698 if (gfc_resolve_expr (e) == FAILURE)
1699 return FAILURE;
1700 goto argument_list;
1701 }
1702
1703 got_variable:
1704 e->expr_type = EXPR_VARIABLE;
1705 e->ts = sym->ts;
1706 if (sym->as != NULL)
1707 {
1708 e->rank = sym->as->rank;
1709 e->ref = gfc_get_ref ();
1710 e->ref->type = REF_ARRAY;
1711 e->ref->u.ar.type = AR_FULL;
1712 e->ref->u.ar.as = sym->as;
1713 }
1714
1715 /* Expressions are assigned a default ts.type of BT_PROCEDURE in
1716 primary.c (match_actual_arg). If above code determines that it
1717 is a variable instead, it needs to be resolved as it was not
1718 done at the beginning of this function. */
1719 save_need_full_assumed_size = need_full_assumed_size;
1720 if (e->expr_type != EXPR_VARIABLE)
1721 need_full_assumed_size = 0;
1722 if (gfc_resolve_expr (e) != SUCCESS)
1723 return FAILURE;
1724 need_full_assumed_size = save_need_full_assumed_size;
1725
1726 argument_list:
1727 /* Check argument list functions %VAL, %LOC and %REF. There is
1728 nothing to do for %REF. */
1729 if (arg->name && arg->name[0] == '%')
1730 {
1731 if (strncmp ("%VAL", arg->name, 4) == 0)
1732 {
1733 if (e->ts.type == BT_CHARACTER || e->ts.type == BT_DERIVED)
1734 {
1735 gfc_error ("By-value argument at %L is not of numeric "
1736 "type", &e->where);
1737 return FAILURE;
1738 }
1739
1740 if (e->rank)
1741 {
1742 gfc_error ("By-value argument at %L cannot be an array or "
1743 "an array section", &e->where);
1744 return FAILURE;
1745 }
1746
1747 /* Intrinsics are still PROC_UNKNOWN here. However,
1748 since same file external procedures are not resolvable
1749 in gfortran, it is a good deal easier to leave them to
1750 intrinsic.c. */
1751 if (ptype != PROC_UNKNOWN
1752 && ptype != PROC_DUMMY
1753 && ptype != PROC_EXTERNAL
1754 && ptype != PROC_MODULE)
1755 {
1756 gfc_error ("By-value argument at %L is not allowed "
1757 "in this context", &e->where);
1758 return FAILURE;
1759 }
1760 }
1761
1762 /* Statement functions have already been excluded above. */
1763 else if (strncmp ("%LOC", arg->name, 4) == 0
1764 && e->ts.type == BT_PROCEDURE)
1765 {
1766 if (e->symtree->n.sym->attr.proc == PROC_INTERNAL)
1767 {
1768 gfc_error ("Passing internal procedure at %L by location "
1769 "not allowed", &e->where);
1770 return FAILURE;
1771 }
1772 }
1773 }
1774
1775 /* Fortran 2008, C1237. */
1776 if (e->expr_type == EXPR_VARIABLE && gfc_is_coindexed (e)
1777 && gfc_has_ultimate_pointer (e))
1778 {
1779 gfc_error ("Coindexed actual argument at %L with ultimate pointer "
1780 "component", &e->where);
1781 return FAILURE;
1782 }
1783 }
1784
1785 return SUCCESS;
1786 }
1787
1788
1789 /* Do the checks of the actual argument list that are specific to elemental
1790 procedures. If called with c == NULL, we have a function, otherwise if
1791 expr == NULL, we have a subroutine. */
1792
1793 static gfc_try
1794 resolve_elemental_actual (gfc_expr *expr, gfc_code *c)
1795 {
1796 gfc_actual_arglist *arg0;
1797 gfc_actual_arglist *arg;
1798 gfc_symbol *esym = NULL;
1799 gfc_intrinsic_sym *isym = NULL;
1800 gfc_expr *e = NULL;
1801 gfc_intrinsic_arg *iformal = NULL;
1802 gfc_formal_arglist *eformal = NULL;
1803 bool formal_optional = false;
1804 bool set_by_optional = false;
1805 int i;
1806 int rank = 0;
1807
1808 /* Is this an elemental procedure? */
1809 if (expr && expr->value.function.actual != NULL)
1810 {
1811 if (expr->value.function.esym != NULL
1812 && expr->value.function.esym->attr.elemental)
1813 {
1814 arg0 = expr->value.function.actual;
1815 esym = expr->value.function.esym;
1816 }
1817 else if (expr->value.function.isym != NULL
1818 && expr->value.function.isym->elemental)
1819 {
1820 arg0 = expr->value.function.actual;
1821 isym = expr->value.function.isym;
1822 }
1823 else
1824 return SUCCESS;
1825 }
1826 else if (c && c->ext.actual != NULL)
1827 {
1828 arg0 = c->ext.actual;
1829
1830 if (c->resolved_sym)
1831 esym = c->resolved_sym;
1832 else
1833 esym = c->symtree->n.sym;
1834 gcc_assert (esym);
1835
1836 if (!esym->attr.elemental)
1837 return SUCCESS;
1838 }
1839 else
1840 return SUCCESS;
1841
1842 /* The rank of an elemental is the rank of its array argument(s). */
1843 for (arg = arg0; arg; arg = arg->next)
1844 {
1845 if (arg->expr != NULL && arg->expr->rank > 0)
1846 {
1847 rank = arg->expr->rank;
1848 if (arg->expr->expr_type == EXPR_VARIABLE
1849 && arg->expr->symtree->n.sym->attr.optional)
1850 set_by_optional = true;
1851
1852 /* Function specific; set the result rank and shape. */
1853 if (expr)
1854 {
1855 expr->rank = rank;
1856 if (!expr->shape && arg->expr->shape)
1857 {
1858 expr->shape = gfc_get_shape (rank);
1859 for (i = 0; i < rank; i++)
1860 mpz_init_set (expr->shape[i], arg->expr->shape[i]);
1861 }
1862 }
1863 break;
1864 }
1865 }
1866
1867 /* If it is an array, it shall not be supplied as an actual argument
1868 to an elemental procedure unless an array of the same rank is supplied
1869 as an actual argument corresponding to a nonoptional dummy argument of
1870 that elemental procedure(12.4.1.5). */
1871 formal_optional = false;
1872 if (isym)
1873 iformal = isym->formal;
1874 else
1875 eformal = esym->formal;
1876
1877 for (arg = arg0; arg; arg = arg->next)
1878 {
1879 if (eformal)
1880 {
1881 if (eformal->sym && eformal->sym->attr.optional)
1882 formal_optional = true;
1883 eformal = eformal->next;
1884 }
1885 else if (isym && iformal)
1886 {
1887 if (iformal->optional)
1888 formal_optional = true;
1889 iformal = iformal->next;
1890 }
1891 else if (isym)
1892 formal_optional = true;
1893
1894 if (pedantic && arg->expr != NULL
1895 && arg->expr->expr_type == EXPR_VARIABLE
1896 && arg->expr->symtree->n.sym->attr.optional
1897 && formal_optional
1898 && arg->expr->rank
1899 && (set_by_optional || arg->expr->rank != rank)
1900 && !(isym && isym->id == GFC_ISYM_CONVERSION))
1901 {
1902 gfc_warning ("'%s' at %L is an array and OPTIONAL; IF IT IS "
1903 "MISSING, it cannot be the actual argument of an "
1904 "ELEMENTAL procedure unless there is a non-optional "
1905 "argument with the same rank (12.4.1.5)",
1906 arg->expr->symtree->n.sym->name, &arg->expr->where);
1907 return FAILURE;
1908 }
1909 }
1910
1911 for (arg = arg0; arg; arg = arg->next)
1912 {
1913 if (arg->expr == NULL || arg->expr->rank == 0)
1914 continue;
1915
1916 /* Being elemental, the last upper bound of an assumed size array
1917 argument must be present. */
1918 if (resolve_assumed_size_actual (arg->expr))
1919 return FAILURE;
1920
1921 /* Elemental procedure's array actual arguments must conform. */
1922 if (e != NULL)
1923 {
1924 if (gfc_check_conformance (arg->expr, e,
1925 "elemental procedure") == FAILURE)
1926 return FAILURE;
1927 }
1928 else
1929 e = arg->expr;
1930 }
1931
1932 /* INTENT(OUT) is only allowed for subroutines; if any actual argument
1933 is an array, the intent inout/out variable needs to be also an array. */
1934 if (rank > 0 && esym && expr == NULL)
1935 for (eformal = esym->formal, arg = arg0; arg && eformal;
1936 arg = arg->next, eformal = eformal->next)
1937 if ((eformal->sym->attr.intent == INTENT_OUT
1938 || eformal->sym->attr.intent == INTENT_INOUT)
1939 && arg->expr && arg->expr->rank == 0)
1940 {
1941 gfc_error ("Actual argument at %L for INTENT(%s) dummy '%s' of "
1942 "ELEMENTAL subroutine '%s' is a scalar, but another "
1943 "actual argument is an array", &arg->expr->where,
1944 (eformal->sym->attr.intent == INTENT_OUT) ? "OUT"
1945 : "INOUT", eformal->sym->name, esym->name);
1946 return FAILURE;
1947 }
1948 return SUCCESS;
1949 }
1950
1951
1952 /* This function does the checking of references to global procedures
1953 as defined in sections 18.1 and 14.1, respectively, of the Fortran
1954 77 and 95 standards. It checks for a gsymbol for the name, making
1955 one if it does not already exist. If it already exists, then the
1956 reference being resolved must correspond to the type of gsymbol.
1957 Otherwise, the new symbol is equipped with the attributes of the
1958 reference. The corresponding code that is called in creating
1959 global entities is parse.c.
1960
1961 In addition, for all but -std=legacy, the gsymbols are used to
1962 check the interfaces of external procedures from the same file.
1963 The namespace of the gsymbol is resolved and then, once this is
1964 done the interface is checked. */
1965
1966
1967 static bool
1968 not_in_recursive (gfc_symbol *sym, gfc_namespace *gsym_ns)
1969 {
1970 if (!gsym_ns->proc_name->attr.recursive)
1971 return true;
1972
1973 if (sym->ns == gsym_ns)
1974 return false;
1975
1976 if (sym->ns->parent && sym->ns->parent == gsym_ns)
1977 return false;
1978
1979 return true;
1980 }
1981
1982 static bool
1983 not_entry_self_reference (gfc_symbol *sym, gfc_namespace *gsym_ns)
1984 {
1985 if (gsym_ns->entries)
1986 {
1987 gfc_entry_list *entry = gsym_ns->entries;
1988
1989 for (; entry; entry = entry->next)
1990 {
1991 if (strcmp (sym->name, entry->sym->name) == 0)
1992 {
1993 if (strcmp (gsym_ns->proc_name->name,
1994 sym->ns->proc_name->name) == 0)
1995 return false;
1996
1997 if (sym->ns->parent
1998 && strcmp (gsym_ns->proc_name->name,
1999 sym->ns->parent->proc_name->name) == 0)
2000 return false;
2001 }
2002 }
2003 }
2004 return true;
2005 }
2006
2007 static void
2008 resolve_global_procedure (gfc_symbol *sym, locus *where,
2009 gfc_actual_arglist **actual, int sub)
2010 {
2011 gfc_gsymbol * gsym;
2012 gfc_namespace *ns;
2013 enum gfc_symbol_type type;
2014
2015 type = sub ? GSYM_SUBROUTINE : GSYM_FUNCTION;
2016
2017 gsym = gfc_get_gsymbol (sym->name);
2018
2019 if ((gsym->type != GSYM_UNKNOWN && gsym->type != type))
2020 gfc_global_used (gsym, where);
2021
2022 if (gfc_option.flag_whole_file
2023 && (sym->attr.if_source == IFSRC_UNKNOWN
2024 || sym->attr.if_source == IFSRC_IFBODY)
2025 && gsym->type != GSYM_UNKNOWN
2026 && gsym->ns
2027 && gsym->ns->resolved != -1
2028 && gsym->ns->proc_name
2029 && not_in_recursive (sym, gsym->ns)
2030 && not_entry_self_reference (sym, gsym->ns))
2031 {
2032 gfc_symbol *def_sym;
2033
2034 /* Resolve the gsymbol namespace if needed. */
2035 if (!gsym->ns->resolved)
2036 {
2037 gfc_dt_list *old_dt_list;
2038 struct gfc_omp_saved_state old_omp_state;
2039
2040 /* Stash away derived types so that the backend_decls do not
2041 get mixed up. */
2042 old_dt_list = gfc_derived_types;
2043 gfc_derived_types = NULL;
2044 /* And stash away openmp state. */
2045 gfc_omp_save_and_clear_state (&old_omp_state);
2046
2047 gfc_resolve (gsym->ns);
2048
2049 /* Store the new derived types with the global namespace. */
2050 if (gfc_derived_types)
2051 gsym->ns->derived_types = gfc_derived_types;
2052
2053 /* Restore the derived types of this namespace. */
2054 gfc_derived_types = old_dt_list;
2055 /* And openmp state. */
2056 gfc_omp_restore_state (&old_omp_state);
2057 }
2058
2059 /* Make sure that translation for the gsymbol occurs before
2060 the procedure currently being resolved. */
2061 ns = gfc_global_ns_list;
2062 for (; ns && ns != gsym->ns; ns = ns->sibling)
2063 {
2064 if (ns->sibling == gsym->ns)
2065 {
2066 ns->sibling = gsym->ns->sibling;
2067 gsym->ns->sibling = gfc_global_ns_list;
2068 gfc_global_ns_list = gsym->ns;
2069 break;
2070 }
2071 }
2072
2073 def_sym = gsym->ns->proc_name;
2074 if (def_sym->attr.entry_master)
2075 {
2076 gfc_entry_list *entry;
2077 for (entry = gsym->ns->entries; entry; entry = entry->next)
2078 if (strcmp (entry->sym->name, sym->name) == 0)
2079 {
2080 def_sym = entry->sym;
2081 break;
2082 }
2083 }
2084
2085 /* Differences in constant character lengths. */
2086 if (sym->attr.function && sym->ts.type == BT_CHARACTER)
2087 {
2088 long int l1 = 0, l2 = 0;
2089 gfc_charlen *cl1 = sym->ts.u.cl;
2090 gfc_charlen *cl2 = def_sym->ts.u.cl;
2091
2092 if (cl1 != NULL
2093 && cl1->length != NULL
2094 && cl1->length->expr_type == EXPR_CONSTANT)
2095 l1 = mpz_get_si (cl1->length->value.integer);
2096
2097 if (cl2 != NULL
2098 && cl2->length != NULL
2099 && cl2->length->expr_type == EXPR_CONSTANT)
2100 l2 = mpz_get_si (cl2->length->value.integer);
2101
2102 if (l1 && l2 && l1 != l2)
2103 gfc_error ("Character length mismatch in return type of "
2104 "function '%s' at %L (%ld/%ld)", sym->name,
2105 &sym->declared_at, l1, l2);
2106 }
2107
2108 /* Type mismatch of function return type and expected type. */
2109 if (sym->attr.function
2110 && !gfc_compare_types (&sym->ts, &def_sym->ts))
2111 gfc_error ("Return type mismatch of function '%s' at %L (%s/%s)",
2112 sym->name, &sym->declared_at, gfc_typename (&sym->ts),
2113 gfc_typename (&def_sym->ts));
2114
2115 if (def_sym->formal && sym->attr.if_source != IFSRC_IFBODY)
2116 {
2117 gfc_formal_arglist *arg = def_sym->formal;
2118 for ( ; arg; arg = arg->next)
2119 if (!arg->sym)
2120 continue;
2121 /* F2003, 12.3.1.1 (2a); F2008, 12.4.2.2 (2a) */
2122 else if (arg->sym->attr.allocatable
2123 || arg->sym->attr.asynchronous
2124 || arg->sym->attr.optional
2125 || arg->sym->attr.pointer
2126 || arg->sym->attr.target
2127 || arg->sym->attr.value
2128 || arg->sym->attr.volatile_)
2129 {
2130 gfc_error ("Dummy argument '%s' of procedure '%s' at %L "
2131 "has an attribute that requires an explicit "
2132 "interface for this procedure", arg->sym->name,
2133 sym->name, &sym->declared_at);
2134 break;
2135 }
2136 /* F2003, 12.3.1.1 (2b); F2008, 12.4.2.2 (2b) */
2137 else if (arg->sym && arg->sym->as
2138 && arg->sym->as->type == AS_ASSUMED_SHAPE)
2139 {
2140 gfc_error ("Procedure '%s' at %L with assumed-shape dummy "
2141 "argument '%s' must have an explicit interface",
2142 sym->name, &sym->declared_at, arg->sym->name);
2143 break;
2144 }
2145 /* F2008, 12.4.2.2 (2c) */
2146 else if (arg->sym->attr.codimension)
2147 {
2148 gfc_error ("Procedure '%s' at %L with coarray dummy argument "
2149 "'%s' must have an explicit interface",
2150 sym->name, &sym->declared_at, arg->sym->name);
2151 break;
2152 }
2153 /* F2003, 12.3.1.1 (2c); F2008, 12.4.2.2 (2d) */
2154 else if (false) /* TODO: is a parametrized derived type */
2155 {
2156 gfc_error ("Procedure '%s' at %L with parametrized derived "
2157 "type argument '%s' must have an explicit "
2158 "interface", sym->name, &sym->declared_at,
2159 arg->sym->name);
2160 break;
2161 }
2162 /* F2003, 12.3.1.1 (2d); F2008, 12.4.2.2 (2e) */
2163 else if (arg->sym->ts.type == BT_CLASS)
2164 {
2165 gfc_error ("Procedure '%s' at %L with polymorphic dummy "
2166 "argument '%s' must have an explicit interface",
2167 sym->name, &sym->declared_at, arg->sym->name);
2168 break;
2169 }
2170 }
2171
2172 if (def_sym->attr.function)
2173 {
2174 /* F2003, 12.3.1.1 (3a); F2008, 12.4.2.2 (3a) */
2175 if (def_sym->as && def_sym->as->rank
2176 && (!sym->as || sym->as->rank != def_sym->as->rank))
2177 gfc_error ("The reference to function '%s' at %L either needs an "
2178 "explicit INTERFACE or the rank is incorrect", sym->name,
2179 where);
2180
2181 /* F2003, 12.3.1.1 (3b); F2008, 12.4.2.2 (3b) */
2182 if ((def_sym->result->attr.pointer
2183 || def_sym->result->attr.allocatable)
2184 && (sym->attr.if_source != IFSRC_IFBODY
2185 || def_sym->result->attr.pointer
2186 != sym->result->attr.pointer
2187 || def_sym->result->attr.allocatable
2188 != sym->result->attr.allocatable))
2189 gfc_error ("Function '%s' at %L with a POINTER or ALLOCATABLE "
2190 "result must have an explicit interface", sym->name,
2191 where);
2192
2193 /* F2003, 12.3.1.1 (3c); F2008, 12.4.2.2 (3c) */
2194 if (sym->ts.type == BT_CHARACTER && sym->attr.if_source != IFSRC_IFBODY
2195 && def_sym->ts.type == BT_CHARACTER && def_sym->ts.u.cl->length != NULL)
2196 {
2197 gfc_charlen *cl = sym->ts.u.cl;
2198
2199 if (!sym->attr.entry_master && sym->attr.if_source == IFSRC_UNKNOWN
2200 && cl && cl->length && cl->length->expr_type != EXPR_CONSTANT)
2201 {
2202 gfc_error ("Nonconstant character-length function '%s' at %L "
2203 "must have an explicit interface", sym->name,
2204 &sym->declared_at);
2205 }
2206 }
2207 }
2208
2209 /* F2003, 12.3.1.1 (4); F2008, 12.4.2.2 (4) */
2210 if (def_sym->attr.elemental && !sym->attr.elemental)
2211 {
2212 gfc_error ("ELEMENTAL procedure '%s' at %L must have an explicit "
2213 "interface", sym->name, &sym->declared_at);
2214 }
2215
2216 /* F2003, 12.3.1.1 (5); F2008, 12.4.2.2 (5) */
2217 if (def_sym->attr.is_bind_c && !sym->attr.is_bind_c)
2218 {
2219 gfc_error ("Procedure '%s' at %L with BIND(C) attribute must have "
2220 "an explicit interface", sym->name, &sym->declared_at);
2221 }
2222
2223 if (gfc_option.flag_whole_file == 1
2224 || ((gfc_option.warn_std & GFC_STD_LEGACY)
2225 && !(gfc_option.warn_std & GFC_STD_GNU)))
2226 gfc_errors_to_warnings (1);
2227
2228 if (sym->attr.if_source != IFSRC_IFBODY)
2229 gfc_procedure_use (def_sym, actual, where);
2230
2231 gfc_errors_to_warnings (0);
2232 }
2233
2234 if (gsym->type == GSYM_UNKNOWN)
2235 {
2236 gsym->type = type;
2237 gsym->where = *where;
2238 }
2239
2240 gsym->used = 1;
2241 }
2242
2243
2244 /************* Function resolution *************/
2245
2246 /* Resolve a function call known to be generic.
2247 Section 14.1.2.4.1. */
2248
2249 static match
2250 resolve_generic_f0 (gfc_expr *expr, gfc_symbol *sym)
2251 {
2252 gfc_symbol *s;
2253
2254 if (sym->attr.generic)
2255 {
2256 s = gfc_search_interface (sym->generic, 0, &expr->value.function.actual);
2257 if (s != NULL)
2258 {
2259 expr->value.function.name = s->name;
2260 expr->value.function.esym = s;
2261
2262 if (s->ts.type != BT_UNKNOWN)
2263 expr->ts = s->ts;
2264 else if (s->result != NULL && s->result->ts.type != BT_UNKNOWN)
2265 expr->ts = s->result->ts;
2266
2267 if (s->as != NULL)
2268 expr->rank = s->as->rank;
2269 else if (s->result != NULL && s->result->as != NULL)
2270 expr->rank = s->result->as->rank;
2271
2272 gfc_set_sym_referenced (expr->value.function.esym);
2273
2274 return MATCH_YES;
2275 }
2276
2277 /* TODO: Need to search for elemental references in generic
2278 interface. */
2279 }
2280
2281 if (sym->attr.intrinsic)
2282 return gfc_intrinsic_func_interface (expr, 0);
2283
2284 return MATCH_NO;
2285 }
2286
2287
2288 static gfc_try
2289 resolve_generic_f (gfc_expr *expr)
2290 {
2291 gfc_symbol *sym;
2292 match m;
2293
2294 sym = expr->symtree->n.sym;
2295
2296 for (;;)
2297 {
2298 m = resolve_generic_f0 (expr, sym);
2299 if (m == MATCH_YES)
2300 return SUCCESS;
2301 else if (m == MATCH_ERROR)
2302 return FAILURE;
2303
2304 generic:
2305 if (sym->ns->parent == NULL)
2306 break;
2307 gfc_find_symbol (sym->name, sym->ns->parent, 1, &sym);
2308
2309 if (sym == NULL)
2310 break;
2311 if (!generic_sym (sym))
2312 goto generic;
2313 }
2314
2315 /* Last ditch attempt. See if the reference is to an intrinsic
2316 that possesses a matching interface. 14.1.2.4 */
2317 if (sym && !gfc_is_intrinsic (sym, 0, expr->where))
2318 {
2319 gfc_error ("There is no specific function for the generic '%s' at %L",
2320 expr->symtree->n.sym->name, &expr->where);
2321 return FAILURE;
2322 }
2323
2324 m = gfc_intrinsic_func_interface (expr, 0);
2325 if (m == MATCH_YES)
2326 return SUCCESS;
2327 if (m == MATCH_NO)
2328 gfc_error ("Generic function '%s' at %L is not consistent with a "
2329 "specific intrinsic interface", expr->symtree->n.sym->name,
2330 &expr->where);
2331
2332 return FAILURE;
2333 }
2334
2335
2336 /* Resolve a function call known to be specific. */
2337
2338 static match
2339 resolve_specific_f0 (gfc_symbol *sym, gfc_expr *expr)
2340 {
2341 match m;
2342
2343 if (sym->attr.external || sym->attr.if_source == IFSRC_IFBODY)
2344 {
2345 if (sym->attr.dummy)
2346 {
2347 sym->attr.proc = PROC_DUMMY;
2348 goto found;
2349 }
2350
2351 sym->attr.proc = PROC_EXTERNAL;
2352 goto found;
2353 }
2354
2355 if (sym->attr.proc == PROC_MODULE
2356 || sym->attr.proc == PROC_ST_FUNCTION
2357 || sym->attr.proc == PROC_INTERNAL)
2358 goto found;
2359
2360 if (sym->attr.intrinsic)
2361 {
2362 m = gfc_intrinsic_func_interface (expr, 1);
2363 if (m == MATCH_YES)
2364 return MATCH_YES;
2365 if (m == MATCH_NO)
2366 gfc_error ("Function '%s' at %L is INTRINSIC but is not compatible "
2367 "with an intrinsic", sym->name, &expr->where);
2368
2369 return MATCH_ERROR;
2370 }
2371
2372 return MATCH_NO;
2373
2374 found:
2375 gfc_procedure_use (sym, &expr->value.function.actual, &expr->where);
2376
2377 if (sym->result)
2378 expr->ts = sym->result->ts;
2379 else
2380 expr->ts = sym->ts;
2381 expr->value.function.name = sym->name;
2382 expr->value.function.esym = sym;
2383 if (sym->as != NULL)
2384 expr->rank = sym->as->rank;
2385
2386 return MATCH_YES;
2387 }
2388
2389
2390 static gfc_try
2391 resolve_specific_f (gfc_expr *expr)
2392 {
2393 gfc_symbol *sym;
2394 match m;
2395
2396 sym = expr->symtree->n.sym;
2397
2398 for (;;)
2399 {
2400 m = resolve_specific_f0 (sym, expr);
2401 if (m == MATCH_YES)
2402 return SUCCESS;
2403 if (m == MATCH_ERROR)
2404 return FAILURE;
2405
2406 if (sym->ns->parent == NULL)
2407 break;
2408
2409 gfc_find_symbol (sym->name, sym->ns->parent, 1, &sym);
2410
2411 if (sym == NULL)
2412 break;
2413 }
2414
2415 gfc_error ("Unable to resolve the specific function '%s' at %L",
2416 expr->symtree->n.sym->name, &expr->where);
2417
2418 return SUCCESS;
2419 }
2420
2421
2422 /* Resolve a procedure call not known to be generic nor specific. */
2423
2424 static gfc_try
2425 resolve_unknown_f (gfc_expr *expr)
2426 {
2427 gfc_symbol *sym;
2428 gfc_typespec *ts;
2429
2430 sym = expr->symtree->n.sym;
2431
2432 if (sym->attr.dummy)
2433 {
2434 sym->attr.proc = PROC_DUMMY;
2435 expr->value.function.name = sym->name;
2436 goto set_type;
2437 }
2438
2439 /* See if we have an intrinsic function reference. */
2440
2441 if (gfc_is_intrinsic (sym, 0, expr->where))
2442 {
2443 if (gfc_intrinsic_func_interface (expr, 1) == MATCH_YES)
2444 return SUCCESS;
2445 return FAILURE;
2446 }
2447
2448 /* The reference is to an external name. */
2449
2450 sym->attr.proc = PROC_EXTERNAL;
2451 expr->value.function.name = sym->name;
2452 expr->value.function.esym = expr->symtree->n.sym;
2453
2454 if (sym->as != NULL)
2455 expr->rank = sym->as->rank;
2456
2457 /* Type of the expression is either the type of the symbol or the
2458 default type of the symbol. */
2459
2460 set_type:
2461 gfc_procedure_use (sym, &expr->value.function.actual, &expr->where);
2462
2463 if (sym->ts.type != BT_UNKNOWN)
2464 expr->ts = sym->ts;
2465 else
2466 {
2467 ts = gfc_get_default_type (sym->name, sym->ns);
2468
2469 if (ts->type == BT_UNKNOWN)
2470 {
2471 gfc_error ("Function '%s' at %L has no IMPLICIT type",
2472 sym->name, &expr->where);
2473 return FAILURE;
2474 }
2475 else
2476 expr->ts = *ts;
2477 }
2478
2479 return SUCCESS;
2480 }
2481
2482
2483 /* Return true, if the symbol is an external procedure. */
2484 static bool
2485 is_external_proc (gfc_symbol *sym)
2486 {
2487 if (!sym->attr.dummy && !sym->attr.contained
2488 && !(sym->attr.intrinsic
2489 || gfc_is_intrinsic (sym, sym->attr.subroutine, sym->declared_at))
2490 && sym->attr.proc != PROC_ST_FUNCTION
2491 && !sym->attr.proc_pointer
2492 && !sym->attr.use_assoc
2493 && sym->name)
2494 return true;
2495
2496 return false;
2497 }
2498
2499
2500 /* Figure out if a function reference is pure or not. Also set the name
2501 of the function for a potential error message. Return nonzero if the
2502 function is PURE, zero if not. */
2503 static int
2504 pure_stmt_function (gfc_expr *, gfc_symbol *);
2505
2506 static int
2507 pure_function (gfc_expr *e, const char **name)
2508 {
2509 int pure;
2510
2511 *name = NULL;
2512
2513 if (e->symtree != NULL
2514 && e->symtree->n.sym != NULL
2515 && e->symtree->n.sym->attr.proc == PROC_ST_FUNCTION)
2516 return pure_stmt_function (e, e->symtree->n.sym);
2517
2518 if (e->value.function.esym)
2519 {
2520 pure = gfc_pure (e->value.function.esym);
2521 *name = e->value.function.esym->name;
2522 }
2523 else if (e->value.function.isym)
2524 {
2525 pure = e->value.function.isym->pure
2526 || e->value.function.isym->elemental;
2527 *name = e->value.function.isym->name;
2528 }
2529 else
2530 {
2531 /* Implicit functions are not pure. */
2532 pure = 0;
2533 *name = e->value.function.name;
2534 }
2535
2536 return pure;
2537 }
2538
2539
2540 static bool
2541 impure_stmt_fcn (gfc_expr *e, gfc_symbol *sym,
2542 int *f ATTRIBUTE_UNUSED)
2543 {
2544 const char *name;
2545
2546 /* Don't bother recursing into other statement functions
2547 since they will be checked individually for purity. */
2548 if (e->expr_type != EXPR_FUNCTION
2549 || !e->symtree
2550 || e->symtree->n.sym == sym
2551 || e->symtree->n.sym->attr.proc == PROC_ST_FUNCTION)
2552 return false;
2553
2554 return pure_function (e, &name) ? false : true;
2555 }
2556
2557
2558 static int
2559 pure_stmt_function (gfc_expr *e, gfc_symbol *sym)
2560 {
2561 return gfc_traverse_expr (e, sym, impure_stmt_fcn, 0) ? 0 : 1;
2562 }
2563
2564
2565 static gfc_try
2566 is_scalar_expr_ptr (gfc_expr *expr)
2567 {
2568 gfc_try retval = SUCCESS;
2569 gfc_ref *ref;
2570 int start;
2571 int end;
2572
2573 /* See if we have a gfc_ref, which means we have a substring, array
2574 reference, or a component. */
2575 if (expr->ref != NULL)
2576 {
2577 ref = expr->ref;
2578 while (ref->next != NULL)
2579 ref = ref->next;
2580
2581 switch (ref->type)
2582 {
2583 case REF_SUBSTRING:
2584 if (ref->u.ss.start == NULL || ref->u.ss.end == NULL
2585 || gfc_dep_compare_expr (ref->u.ss.start, ref->u.ss.end) != 0)
2586 retval = FAILURE;
2587 break;
2588
2589 case REF_ARRAY:
2590 if (ref->u.ar.type == AR_ELEMENT)
2591 retval = SUCCESS;
2592 else if (ref->u.ar.type == AR_FULL)
2593 {
2594 /* The user can give a full array if the array is of size 1. */
2595 if (ref->u.ar.as != NULL
2596 && ref->u.ar.as->rank == 1
2597 && ref->u.ar.as->type == AS_EXPLICIT
2598 && ref->u.ar.as->lower[0] != NULL
2599 && ref->u.ar.as->lower[0]->expr_type == EXPR_CONSTANT
2600 && ref->u.ar.as->upper[0] != NULL
2601 && ref->u.ar.as->upper[0]->expr_type == EXPR_CONSTANT)
2602 {
2603 /* If we have a character string, we need to check if
2604 its length is one. */
2605 if (expr->ts.type == BT_CHARACTER)
2606 {
2607 if (expr->ts.u.cl == NULL
2608 || expr->ts.u.cl->length == NULL
2609 || mpz_cmp_si (expr->ts.u.cl->length->value.integer, 1)
2610 != 0)
2611 retval = FAILURE;
2612 }
2613 else
2614 {
2615 /* We have constant lower and upper bounds. If the
2616 difference between is 1, it can be considered a
2617 scalar.
2618 FIXME: Use gfc_dep_compare_expr instead. */
2619 start = (int) mpz_get_si
2620 (ref->u.ar.as->lower[0]->value.integer);
2621 end = (int) mpz_get_si
2622 (ref->u.ar.as->upper[0]->value.integer);
2623 if (end - start + 1 != 1)
2624 retval = FAILURE;
2625 }
2626 }
2627 else
2628 retval = FAILURE;
2629 }
2630 else
2631 retval = FAILURE;
2632 break;
2633 default:
2634 retval = SUCCESS;
2635 break;
2636 }
2637 }
2638 else if (expr->ts.type == BT_CHARACTER && expr->rank == 0)
2639 {
2640 /* Character string. Make sure it's of length 1. */
2641 if (expr->ts.u.cl == NULL
2642 || expr->ts.u.cl->length == NULL
2643 || mpz_cmp_si (expr->ts.u.cl->length->value.integer, 1) != 0)
2644 retval = FAILURE;
2645 }
2646 else if (expr->rank != 0)
2647 retval = FAILURE;
2648
2649 return retval;
2650 }
2651
2652
2653 /* Match one of the iso_c_binding functions (c_associated or c_loc)
2654 and, in the case of c_associated, set the binding label based on
2655 the arguments. */
2656
2657 static gfc_try
2658 gfc_iso_c_func_interface (gfc_symbol *sym, gfc_actual_arglist *args,
2659 gfc_symbol **new_sym)
2660 {
2661 char name[GFC_MAX_SYMBOL_LEN + 1];
2662 char binding_label[GFC_MAX_BINDING_LABEL_LEN + 1];
2663 int optional_arg = 0;
2664 gfc_try retval = SUCCESS;
2665 gfc_symbol *args_sym;
2666 gfc_typespec *arg_ts;
2667 symbol_attribute arg_attr;
2668
2669 if (args->expr->expr_type == EXPR_CONSTANT
2670 || args->expr->expr_type == EXPR_OP
2671 || args->expr->expr_type == EXPR_NULL)
2672 {
2673 gfc_error ("Argument to '%s' at %L is not a variable",
2674 sym->name, &(args->expr->where));
2675 return FAILURE;
2676 }
2677
2678 args_sym = args->expr->symtree->n.sym;
2679
2680 /* The typespec for the actual arg should be that stored in the expr
2681 and not necessarily that of the expr symbol (args_sym), because
2682 the actual expression could be a part-ref of the expr symbol. */
2683 arg_ts = &(args->expr->ts);
2684 arg_attr = gfc_expr_attr (args->expr);
2685
2686 if (sym->intmod_sym_id == ISOCBINDING_ASSOCIATED)
2687 {
2688 /* If the user gave two args then they are providing something for
2689 the optional arg (the second cptr). Therefore, set the name and
2690 binding label to the c_associated for two cptrs. Otherwise,
2691 set c_associated to expect one cptr. */
2692 if (args->next)
2693 {
2694 /* two args. */
2695 sprintf (name, "%s_2", sym->name);
2696 sprintf (binding_label, "%s_2", sym->binding_label);
2697 optional_arg = 1;
2698 }
2699 else
2700 {
2701 /* one arg. */
2702 sprintf (name, "%s_1", sym->name);
2703 sprintf (binding_label, "%s_1", sym->binding_label);
2704 optional_arg = 0;
2705 }
2706
2707 /* Get a new symbol for the version of c_associated that
2708 will get called. */
2709 *new_sym = get_iso_c_sym (sym, name, binding_label, optional_arg);
2710 }
2711 else if (sym->intmod_sym_id == ISOCBINDING_LOC
2712 || sym->intmod_sym_id == ISOCBINDING_FUNLOC)
2713 {
2714 sprintf (name, "%s", sym->name);
2715 sprintf (binding_label, "%s", sym->binding_label);
2716
2717 /* Error check the call. */
2718 if (args->next != NULL)
2719 {
2720 gfc_error_now ("More actual than formal arguments in '%s' "
2721 "call at %L", name, &(args->expr->where));
2722 retval = FAILURE;
2723 }
2724 else if (sym->intmod_sym_id == ISOCBINDING_LOC)
2725 {
2726 gfc_ref *ref;
2727 bool seen_section;
2728
2729 /* Make sure we have either the target or pointer attribute. */
2730 if (!arg_attr.target && !arg_attr.pointer)
2731 {
2732 gfc_error_now ("Parameter '%s' to '%s' at %L must be either "
2733 "a TARGET or an associated pointer",
2734 args_sym->name,
2735 sym->name, &(args->expr->where));
2736 retval = FAILURE;
2737 }
2738
2739 if (gfc_is_coindexed (args->expr))
2740 {
2741 gfc_error_now ("Coindexed argument not permitted"
2742 " in '%s' call at %L", name,
2743 &(args->expr->where));
2744 retval = FAILURE;
2745 }
2746
2747 /* Follow references to make sure there are no array
2748 sections. */
2749 seen_section = false;
2750
2751 for (ref=args->expr->ref; ref; ref = ref->next)
2752 {
2753 if (ref->type == REF_ARRAY)
2754 {
2755 if (ref->u.ar.type == AR_SECTION)
2756 seen_section = true;
2757
2758 if (ref->u.ar.type != AR_ELEMENT)
2759 {
2760 gfc_ref *r;
2761 for (r = ref->next; r; r=r->next)
2762 if (r->type == REF_COMPONENT)
2763 {
2764 gfc_error_now ("Array section not permitted"
2765 " in '%s' call at %L", name,
2766 &(args->expr->where));
2767 retval = FAILURE;
2768 break;
2769 }
2770 }
2771 }
2772 }
2773
2774 if (seen_section && retval == SUCCESS)
2775 gfc_warning ("Array section in '%s' call at %L", name,
2776 &(args->expr->where));
2777
2778 /* See if we have interoperable type and type param. */
2779 if (verify_c_interop (arg_ts) == SUCCESS
2780 || gfc_check_any_c_kind (arg_ts) == SUCCESS)
2781 {
2782 if (args_sym->attr.target == 1)
2783 {
2784 /* Case 1a, section 15.1.2.5, J3/04-007: variable that
2785 has the target attribute and is interoperable. */
2786 /* Case 1b, section 15.1.2.5, J3/04-007: allocated
2787 allocatable variable that has the TARGET attribute and
2788 is not an array of zero size. */
2789 if (args_sym->attr.allocatable == 1)
2790 {
2791 if (args_sym->attr.dimension != 0
2792 && (args_sym->as && args_sym->as->rank == 0))
2793 {
2794 gfc_error_now ("Allocatable variable '%s' used as a "
2795 "parameter to '%s' at %L must not be "
2796 "an array of zero size",
2797 args_sym->name, sym->name,
2798 &(args->expr->where));
2799 retval = FAILURE;
2800 }
2801 }
2802 else
2803 {
2804 /* A non-allocatable target variable with C
2805 interoperable type and type parameters must be
2806 interoperable. */
2807 if (args_sym && args_sym->attr.dimension)
2808 {
2809 if (args_sym->as->type == AS_ASSUMED_SHAPE)
2810 {
2811 gfc_error ("Assumed-shape array '%s' at %L "
2812 "cannot be an argument to the "
2813 "procedure '%s' because "
2814 "it is not C interoperable",
2815 args_sym->name,
2816 &(args->expr->where), sym->name);
2817 retval = FAILURE;
2818 }
2819 else if (args_sym->as->type == AS_DEFERRED)
2820 {
2821 gfc_error ("Deferred-shape array '%s' at %L "
2822 "cannot be an argument to the "
2823 "procedure '%s' because "
2824 "it is not C interoperable",
2825 args_sym->name,
2826 &(args->expr->where), sym->name);
2827 retval = FAILURE;
2828 }
2829 }
2830
2831 /* Make sure it's not a character string. Arrays of
2832 any type should be ok if the variable is of a C
2833 interoperable type. */
2834 if (arg_ts->type == BT_CHARACTER)
2835 if (arg_ts->u.cl != NULL
2836 && (arg_ts->u.cl->length == NULL
2837 || arg_ts->u.cl->length->expr_type
2838 != EXPR_CONSTANT
2839 || mpz_cmp_si
2840 (arg_ts->u.cl->length->value.integer, 1)
2841 != 0)
2842 && is_scalar_expr_ptr (args->expr) != SUCCESS)
2843 {
2844 gfc_error_now ("CHARACTER argument '%s' to '%s' "
2845 "at %L must have a length of 1",
2846 args_sym->name, sym->name,
2847 &(args->expr->where));
2848 retval = FAILURE;
2849 }
2850 }
2851 }
2852 else if (arg_attr.pointer
2853 && is_scalar_expr_ptr (args->expr) != SUCCESS)
2854 {
2855 /* Case 1c, section 15.1.2.5, J3/04-007: an associated
2856 scalar pointer. */
2857 gfc_error_now ("Argument '%s' to '%s' at %L must be an "
2858 "associated scalar POINTER", args_sym->name,
2859 sym->name, &(args->expr->where));
2860 retval = FAILURE;
2861 }
2862 }
2863 else
2864 {
2865 /* The parameter is not required to be C interoperable. If it
2866 is not C interoperable, it must be a nonpolymorphic scalar
2867 with no length type parameters. It still must have either
2868 the pointer or target attribute, and it can be
2869 allocatable (but must be allocated when c_loc is called). */
2870 if (args->expr->rank != 0
2871 && is_scalar_expr_ptr (args->expr) != SUCCESS)
2872 {
2873 gfc_error_now ("Parameter '%s' to '%s' at %L must be a "
2874 "scalar", args_sym->name, sym->name,
2875 &(args->expr->where));
2876 retval = FAILURE;
2877 }
2878 else if (arg_ts->type == BT_CHARACTER
2879 && is_scalar_expr_ptr (args->expr) != SUCCESS)
2880 {
2881 gfc_error_now ("CHARACTER argument '%s' to '%s' at "
2882 "%L must have a length of 1",
2883 args_sym->name, sym->name,
2884 &(args->expr->where));
2885 retval = FAILURE;
2886 }
2887 else if (arg_ts->type == BT_CLASS)
2888 {
2889 gfc_error_now ("Parameter '%s' to '%s' at %L must not be "
2890 "polymorphic", args_sym->name, sym->name,
2891 &(args->expr->where));
2892 retval = FAILURE;
2893 }
2894 }
2895 }
2896 else if (sym->intmod_sym_id == ISOCBINDING_FUNLOC)
2897 {
2898 if (args_sym->attr.flavor != FL_PROCEDURE)
2899 {
2900 /* TODO: Update this error message to allow for procedure
2901 pointers once they are implemented. */
2902 gfc_error_now ("Parameter '%s' to '%s' at %L must be a "
2903 "procedure",
2904 args_sym->name, sym->name,
2905 &(args->expr->where));
2906 retval = FAILURE;
2907 }
2908 else if (args_sym->attr.is_bind_c != 1)
2909 {
2910 gfc_error_now ("Parameter '%s' to '%s' at %L must be "
2911 "BIND(C)",
2912 args_sym->name, sym->name,
2913 &(args->expr->where));
2914 retval = FAILURE;
2915 }
2916 }
2917
2918 /* for c_loc/c_funloc, the new symbol is the same as the old one */
2919 *new_sym = sym;
2920 }
2921 else
2922 {
2923 gfc_internal_error ("gfc_iso_c_func_interface(): Unhandled "
2924 "iso_c_binding function: '%s'!\n", sym->name);
2925 }
2926
2927 return retval;
2928 }
2929
2930
2931 /* Resolve a function call, which means resolving the arguments, then figuring
2932 out which entity the name refers to. */
2933
2934 static gfc_try
2935 resolve_function (gfc_expr *expr)
2936 {
2937 gfc_actual_arglist *arg;
2938 gfc_symbol *sym;
2939 const char *name;
2940 gfc_try t;
2941 int temp;
2942 procedure_type p = PROC_INTRINSIC;
2943 bool no_formal_args;
2944
2945 sym = NULL;
2946 if (expr->symtree)
2947 sym = expr->symtree->n.sym;
2948
2949 /* If this is a procedure pointer component, it has already been resolved. */
2950 if (gfc_is_proc_ptr_comp (expr, NULL))
2951 return SUCCESS;
2952
2953 if (sym && sym->attr.intrinsic
2954 && resolve_intrinsic (sym, &expr->where) == FAILURE)
2955 return FAILURE;
2956
2957 if (sym && (sym->attr.flavor == FL_VARIABLE || sym->attr.subroutine))
2958 {
2959 gfc_error ("'%s' at %L is not a function", sym->name, &expr->where);
2960 return FAILURE;
2961 }
2962
2963 /* If this ia a deferred TBP with an abstract interface (which may
2964 of course be referenced), expr->value.function.esym will be set. */
2965 if (sym && sym->attr.abstract && !expr->value.function.esym)
2966 {
2967 gfc_error ("ABSTRACT INTERFACE '%s' must not be referenced at %L",
2968 sym->name, &expr->where);
2969 return FAILURE;
2970 }
2971
2972 /* Switch off assumed size checking and do this again for certain kinds
2973 of procedure, once the procedure itself is resolved. */
2974 need_full_assumed_size++;
2975
2976 if (expr->symtree && expr->symtree->n.sym)
2977 p = expr->symtree->n.sym->attr.proc;
2978
2979 if (expr->value.function.isym && expr->value.function.isym->inquiry)
2980 inquiry_argument = true;
2981 no_formal_args = sym && is_external_proc (sym) && sym->formal == NULL;
2982
2983 if (resolve_actual_arglist (expr->value.function.actual,
2984 p, no_formal_args) == FAILURE)
2985 {
2986 inquiry_argument = false;
2987 return FAILURE;
2988 }
2989
2990 inquiry_argument = false;
2991
2992 /* Need to setup the call to the correct c_associated, depending on
2993 the number of cptrs to user gives to compare. */
2994 if (sym && sym->attr.is_iso_c == 1)
2995 {
2996 if (gfc_iso_c_func_interface (sym, expr->value.function.actual, &sym)
2997 == FAILURE)
2998 return FAILURE;
2999
3000 /* Get the symtree for the new symbol (resolved func).
3001 the old one will be freed later, when it's no longer used. */
3002 gfc_find_sym_tree (sym->name, sym->ns, 1, &(expr->symtree));
3003 }
3004
3005 /* Resume assumed_size checking. */
3006 need_full_assumed_size--;
3007
3008 /* If the procedure is external, check for usage. */
3009 if (sym && is_external_proc (sym))
3010 resolve_global_procedure (sym, &expr->where,
3011 &expr->value.function.actual, 0);
3012
3013 if (sym && sym->ts.type == BT_CHARACTER
3014 && sym->ts.u.cl
3015 && sym->ts.u.cl->length == NULL
3016 && !sym->attr.dummy
3017 && !sym->ts.deferred
3018 && expr->value.function.esym == NULL
3019 && !sym->attr.contained)
3020 {
3021 /* Internal procedures are taken care of in resolve_contained_fntype. */
3022 gfc_error ("Function '%s' is declared CHARACTER(*) and cannot "
3023 "be used at %L since it is not a dummy argument",
3024 sym->name, &expr->where);
3025 return FAILURE;
3026 }
3027
3028 /* See if function is already resolved. */
3029
3030 if (expr->value.function.name != NULL)
3031 {
3032 if (expr->ts.type == BT_UNKNOWN)
3033 expr->ts = sym->ts;
3034 t = SUCCESS;
3035 }
3036 else
3037 {
3038 /* Apply the rules of section 14.1.2. */
3039
3040 switch (procedure_kind (sym))
3041 {
3042 case PTYPE_GENERIC:
3043 t = resolve_generic_f (expr);
3044 break;
3045
3046 case PTYPE_SPECIFIC:
3047 t = resolve_specific_f (expr);
3048 break;
3049
3050 case PTYPE_UNKNOWN:
3051 t = resolve_unknown_f (expr);
3052 break;
3053
3054 default:
3055 gfc_internal_error ("resolve_function(): bad function type");
3056 }
3057 }
3058
3059 /* If the expression is still a function (it might have simplified),
3060 then we check to see if we are calling an elemental function. */
3061
3062 if (expr->expr_type != EXPR_FUNCTION)
3063 return t;
3064
3065 temp = need_full_assumed_size;
3066 need_full_assumed_size = 0;
3067
3068 if (resolve_elemental_actual (expr, NULL) == FAILURE)
3069 return FAILURE;
3070
3071 if (omp_workshare_flag
3072 && expr->value.function.esym
3073 && ! gfc_elemental (expr->value.function.esym))
3074 {
3075 gfc_error ("User defined non-ELEMENTAL function '%s' at %L not allowed "
3076 "in WORKSHARE construct", expr->value.function.esym->name,
3077 &expr->where);
3078 t = FAILURE;
3079 }
3080
3081 #define GENERIC_ID expr->value.function.isym->id
3082 else if (expr->value.function.actual != NULL
3083 && expr->value.function.isym != NULL
3084 && GENERIC_ID != GFC_ISYM_LBOUND
3085 && GENERIC_ID != GFC_ISYM_LEN
3086 && GENERIC_ID != GFC_ISYM_LOC
3087 && GENERIC_ID != GFC_ISYM_PRESENT)
3088 {
3089 /* Array intrinsics must also have the last upper bound of an
3090 assumed size array argument. UBOUND and SIZE have to be
3091 excluded from the check if the second argument is anything
3092 than a constant. */
3093
3094 for (arg = expr->value.function.actual; arg; arg = arg->next)
3095 {
3096 if ((GENERIC_ID == GFC_ISYM_UBOUND || GENERIC_ID == GFC_ISYM_SIZE)
3097 && arg->next != NULL && arg->next->expr)
3098 {
3099 if (arg->next->expr->expr_type != EXPR_CONSTANT)
3100 break;
3101
3102 if (arg->next->name && strncmp(arg->next->name, "kind", 4) == 0)
3103 break;
3104
3105 if ((int)mpz_get_si (arg->next->expr->value.integer)
3106 < arg->expr->rank)
3107 break;
3108 }
3109
3110 if (arg->expr != NULL
3111 && arg->expr->rank > 0
3112 && resolve_assumed_size_actual (arg->expr))
3113 return FAILURE;
3114 }
3115 }
3116 #undef GENERIC_ID
3117
3118 need_full_assumed_size = temp;
3119 name = NULL;
3120
3121 if (!pure_function (expr, &name) && name)
3122 {
3123 if (forall_flag)
3124 {
3125 gfc_error ("reference to non-PURE function '%s' at %L inside a "
3126 "FORALL %s", name, &expr->where,
3127 forall_flag == 2 ? "mask" : "block");
3128 t = FAILURE;
3129 }
3130 else if (gfc_pure (NULL))
3131 {
3132 gfc_error ("Function reference to '%s' at %L is to a non-PURE "
3133 "procedure within a PURE procedure", name, &expr->where);
3134 t = FAILURE;
3135 }
3136 }
3137
3138 if (!pure_function (expr, &name) && name && gfc_implicit_pure (NULL))
3139 gfc_current_ns->proc_name->attr.implicit_pure = 0;
3140
3141 /* Functions without the RECURSIVE attribution are not allowed to
3142 * call themselves. */
3143 if (expr->value.function.esym && !expr->value.function.esym->attr.recursive)
3144 {
3145 gfc_symbol *esym;
3146 esym = expr->value.function.esym;
3147
3148 if (is_illegal_recursion (esym, gfc_current_ns))
3149 {
3150 if (esym->attr.entry && esym->ns->entries)
3151 gfc_error ("ENTRY '%s' at %L cannot be called recursively, as"
3152 " function '%s' is not RECURSIVE",
3153 esym->name, &expr->where, esym->ns->entries->sym->name);
3154 else
3155 gfc_error ("Function '%s' at %L cannot be called recursively, as it"
3156 " is not RECURSIVE", esym->name, &expr->where);
3157
3158 t = FAILURE;
3159 }
3160 }
3161
3162 /* Character lengths of use associated functions may contains references to
3163 symbols not referenced from the current program unit otherwise. Make sure
3164 those symbols are marked as referenced. */
3165
3166 if (expr->ts.type == BT_CHARACTER && expr->value.function.esym
3167 && expr->value.function.esym->attr.use_assoc)
3168 {
3169 gfc_expr_set_symbols_referenced (expr->ts.u.cl->length);
3170 }
3171
3172 /* Make sure that the expression has a typespec that works. */
3173 if (expr->ts.type == BT_UNKNOWN)
3174 {
3175 if (expr->symtree->n.sym->result
3176 && expr->symtree->n.sym->result->ts.type != BT_UNKNOWN
3177 && !expr->symtree->n.sym->result->attr.proc_pointer)
3178 expr->ts = expr->symtree->n.sym->result->ts;
3179 }
3180
3181 return t;
3182 }
3183
3184
3185 /************* Subroutine resolution *************/
3186
3187 static void
3188 pure_subroutine (gfc_code *c, gfc_symbol *sym)
3189 {
3190 if (gfc_pure (sym))
3191 return;
3192
3193 if (forall_flag)
3194 gfc_error ("Subroutine call to '%s' in FORALL block at %L is not PURE",
3195 sym->name, &c->loc);
3196 else if (gfc_pure (NULL))
3197 gfc_error ("Subroutine call to '%s' at %L is not PURE", sym->name,
3198 &c->loc);
3199 }
3200
3201
3202 static match
3203 resolve_generic_s0 (gfc_code *c, gfc_symbol *sym)
3204 {
3205 gfc_symbol *s;
3206
3207 if (sym->attr.generic)
3208 {
3209 s = gfc_search_interface (sym->generic, 1, &c->ext.actual);
3210 if (s != NULL)
3211 {
3212 c->resolved_sym = s;
3213 pure_subroutine (c, s);
3214 return MATCH_YES;
3215 }
3216
3217 /* TODO: Need to search for elemental references in generic interface. */
3218 }
3219
3220 if (sym->attr.intrinsic)
3221 return gfc_intrinsic_sub_interface (c, 0);
3222
3223 return MATCH_NO;
3224 }
3225
3226
3227 static gfc_try
3228 resolve_generic_s (gfc_code *c)
3229 {
3230 gfc_symbol *sym;
3231 match m;
3232
3233 sym = c->symtree->n.sym;
3234
3235 for (;;)
3236 {
3237 m = resolve_generic_s0 (c, sym);
3238 if (m == MATCH_YES)
3239 return SUCCESS;
3240 else if (m == MATCH_ERROR)
3241 return FAILURE;
3242
3243 generic:
3244 if (sym->ns->parent == NULL)
3245 break;
3246 gfc_find_symbol (sym->name, sym->ns->parent, 1, &sym);
3247
3248 if (sym == NULL)
3249 break;
3250 if (!generic_sym (sym))
3251 goto generic;
3252 }
3253
3254 /* Last ditch attempt. See if the reference is to an intrinsic
3255 that possesses a matching interface. 14.1.2.4 */
3256 sym = c->symtree->n.sym;
3257
3258 if (!gfc_is_intrinsic (sym, 1, c->loc))
3259 {
3260 gfc_error ("There is no specific subroutine for the generic '%s' at %L",
3261 sym->name, &c->loc);
3262 return FAILURE;
3263 }
3264
3265 m = gfc_intrinsic_sub_interface (c, 0);
3266 if (m == MATCH_YES)
3267 return SUCCESS;
3268 if (m == MATCH_NO)
3269 gfc_error ("Generic subroutine '%s' at %L is not consistent with an "
3270 "intrinsic subroutine interface", sym->name, &c->loc);
3271
3272 return FAILURE;
3273 }
3274
3275
3276 /* Set the name and binding label of the subroutine symbol in the call
3277 expression represented by 'c' to include the type and kind of the
3278 second parameter. This function is for resolving the appropriate
3279 version of c_f_pointer() and c_f_procpointer(). For example, a
3280 call to c_f_pointer() for a default integer pointer could have a
3281 name of c_f_pointer_i4. If no second arg exists, which is an error
3282 for these two functions, it defaults to the generic symbol's name
3283 and binding label. */
3284
3285 static void
3286 set_name_and_label (gfc_code *c, gfc_symbol *sym,
3287 char *name, char *binding_label)
3288 {
3289 gfc_expr *arg = NULL;
3290 char type;
3291 int kind;
3292
3293 /* The second arg of c_f_pointer and c_f_procpointer determines
3294 the type and kind for the procedure name. */
3295 arg = c->ext.actual->next->expr;
3296
3297 if (arg != NULL)
3298 {
3299 /* Set up the name to have the given symbol's name,
3300 plus the type and kind. */
3301 /* a derived type is marked with the type letter 'u' */
3302 if (arg->ts.type == BT_DERIVED)
3303 {
3304 type = 'd';
3305 kind = 0; /* set the kind as 0 for now */
3306 }
3307 else
3308 {
3309 type = gfc_type_letter (arg->ts.type);
3310 kind = arg->ts.kind;
3311 }
3312
3313 if (arg->ts.type == BT_CHARACTER)
3314 /* Kind info for character strings not needed. */
3315 kind = 0;
3316
3317 sprintf (name, "%s_%c%d", sym->name, type, kind);
3318 /* Set up the binding label as the given symbol's label plus
3319 the type and kind. */
3320 sprintf (binding_label, "%s_%c%d", sym->binding_label, type, kind);
3321 }
3322 else
3323 {
3324 /* If the second arg is missing, set the name and label as
3325 was, cause it should at least be found, and the missing
3326 arg error will be caught by compare_parameters(). */
3327 sprintf (name, "%s", sym->name);
3328 sprintf (binding_label, "%s", sym->binding_label);
3329 }
3330
3331 return;
3332 }
3333
3334
3335 /* Resolve a generic version of the iso_c_binding procedure given
3336 (sym) to the specific one based on the type and kind of the
3337 argument(s). Currently, this function resolves c_f_pointer() and
3338 c_f_procpointer based on the type and kind of the second argument
3339 (FPTR). Other iso_c_binding procedures aren't specially handled.
3340 Upon successfully exiting, c->resolved_sym will hold the resolved
3341 symbol. Returns MATCH_ERROR if an error occurred; MATCH_YES
3342 otherwise. */
3343
3344 match
3345 gfc_iso_c_sub_interface (gfc_code *c, gfc_symbol *sym)
3346 {
3347 gfc_symbol *new_sym;
3348 /* this is fine, since we know the names won't use the max */
3349 char name[GFC_MAX_SYMBOL_LEN + 1];
3350 char binding_label[GFC_MAX_BINDING_LABEL_LEN + 1];
3351 /* default to success; will override if find error */
3352 match m = MATCH_YES;
3353
3354 /* Make sure the actual arguments are in the necessary order (based on the
3355 formal args) before resolving. */
3356 gfc_procedure_use (sym, &c->ext.actual, &(c->loc));
3357
3358 if ((sym->intmod_sym_id == ISOCBINDING_F_POINTER) ||
3359 (sym->intmod_sym_id == ISOCBINDING_F_PROCPOINTER))
3360 {
3361 set_name_and_label (c, sym, name, binding_label);
3362
3363 if (sym->intmod_sym_id == ISOCBINDING_F_POINTER)
3364 {
3365 if (c->ext.actual != NULL && c->ext.actual->next != NULL)
3366 {
3367 /* Make sure we got a third arg if the second arg has non-zero
3368 rank. We must also check that the type and rank are
3369 correct since we short-circuit this check in
3370 gfc_procedure_use() (called above to sort actual args). */
3371 if (c->ext.actual->next->expr->rank != 0)
3372 {
3373 if(c->ext.actual->next->next == NULL
3374 || c->ext.actual->next->next->expr == NULL)
3375 {
3376 m = MATCH_ERROR;
3377 gfc_error ("Missing SHAPE parameter for call to %s "
3378 "at %L", sym->name, &(c->loc));
3379 }
3380 else if (c->ext.actual->next->next->expr->ts.type
3381 != BT_INTEGER
3382 || c->ext.actual->next->next->expr->rank != 1)
3383 {
3384 m = MATCH_ERROR;
3385 gfc_error ("SHAPE parameter for call to %s at %L must "
3386 "be a rank 1 INTEGER array", sym->name,
3387 &(c->loc));
3388 }
3389 }
3390 }
3391 }
3392
3393 if (m != MATCH_ERROR)
3394 {
3395 /* the 1 means to add the optional arg to formal list */
3396 new_sym = get_iso_c_sym (sym, name, binding_label, 1);
3397
3398 /* for error reporting, say it's declared where the original was */
3399 new_sym->declared_at = sym->declared_at;
3400 }
3401 }
3402 else
3403 {
3404 /* no differences for c_loc or c_funloc */
3405 new_sym = sym;
3406 }
3407
3408 /* set the resolved symbol */
3409 if (m != MATCH_ERROR)
3410 c->resolved_sym = new_sym;
3411 else
3412 c->resolved_sym = sym;
3413
3414 return m;
3415 }
3416
3417
3418 /* Resolve a subroutine call known to be specific. */
3419
3420 static match
3421 resolve_specific_s0 (gfc_code *c, gfc_symbol *sym)
3422 {
3423 match m;
3424
3425 if(sym->attr.is_iso_c)
3426 {
3427 m = gfc_iso_c_sub_interface (c,sym);
3428 return m;
3429 }
3430
3431 if (sym->attr.external || sym->attr.if_source == IFSRC_IFBODY)
3432 {
3433 if (sym->attr.dummy)
3434 {
3435 sym->attr.proc = PROC_DUMMY;
3436 goto found;
3437 }
3438
3439 sym->attr.proc = PROC_EXTERNAL;
3440 goto found;
3441 }
3442
3443 if (sym->attr.proc == PROC_MODULE || sym->attr.proc == PROC_INTERNAL)
3444 goto found;
3445
3446 if (sym->attr.intrinsic)
3447 {
3448 m = gfc_intrinsic_sub_interface (c, 1);
3449 if (m == MATCH_YES)
3450 return MATCH_YES;
3451 if (m == MATCH_NO)
3452 gfc_error ("Subroutine '%s' at %L is INTRINSIC but is not compatible "
3453 "with an intrinsic", sym->name, &c->loc);
3454
3455 return MATCH_ERROR;
3456 }
3457
3458 return MATCH_NO;
3459
3460 found:
3461 gfc_procedure_use (sym, &c->ext.actual, &c->loc);
3462
3463 c->resolved_sym = sym;
3464 pure_subroutine (c, sym);
3465
3466 return MATCH_YES;
3467 }
3468
3469
3470 static gfc_try
3471 resolve_specific_s (gfc_code *c)
3472 {
3473 gfc_symbol *sym;
3474 match m;
3475
3476 sym = c->symtree->n.sym;
3477
3478 for (;;)
3479 {
3480 m = resolve_specific_s0 (c, sym);
3481 if (m == MATCH_YES)
3482 return SUCCESS;
3483 if (m == MATCH_ERROR)
3484 return FAILURE;
3485
3486 if (sym->ns->parent == NULL)
3487 break;
3488
3489 gfc_find_symbol (sym->name, sym->ns->parent, 1, &sym);
3490
3491 if (sym == NULL)
3492 break;
3493 }
3494
3495 sym = c->symtree->n.sym;
3496 gfc_error ("Unable to resolve the specific subroutine '%s' at %L",
3497 sym->name, &c->loc);
3498
3499 return FAILURE;
3500 }
3501
3502
3503 /* Resolve a subroutine call not known to be generic nor specific. */
3504
3505 static gfc_try
3506 resolve_unknown_s (gfc_code *c)
3507 {
3508 gfc_symbol *sym;
3509
3510 sym = c->symtree->n.sym;
3511
3512 if (sym->attr.dummy)
3513 {
3514 sym->attr.proc = PROC_DUMMY;
3515 goto found;
3516 }
3517
3518 /* See if we have an intrinsic function reference. */
3519
3520 if (gfc_is_intrinsic (sym, 1, c->loc))
3521 {
3522 if (gfc_intrinsic_sub_interface (c, 1) == MATCH_YES)
3523 return SUCCESS;
3524 return FAILURE;
3525 }
3526
3527 /* The reference is to an external name. */
3528
3529 found:
3530 gfc_procedure_use (sym, &c->ext.actual, &c->loc);
3531
3532 c->resolved_sym = sym;
3533
3534 pure_subroutine (c, sym);
3535
3536 return SUCCESS;
3537 }
3538
3539
3540 /* Resolve a subroutine call. Although it was tempting to use the same code
3541 for functions, subroutines and functions are stored differently and this
3542 makes things awkward. */
3543
3544 static gfc_try
3545 resolve_call (gfc_code *c)
3546 {
3547 gfc_try t;
3548 procedure_type ptype = PROC_INTRINSIC;
3549 gfc_symbol *csym, *sym;
3550 bool no_formal_args;
3551
3552 csym = c->symtree ? c->symtree->n.sym : NULL;
3553
3554 if (csym && csym->ts.type != BT_UNKNOWN)
3555 {
3556 gfc_error ("'%s' at %L has a type, which is not consistent with "
3557 "the CALL at %L", csym->name, &csym->declared_at, &c->loc);
3558 return FAILURE;
3559 }
3560
3561 if (csym && gfc_current_ns->parent && csym->ns != gfc_current_ns)
3562 {
3563 gfc_symtree *st;
3564 gfc_find_sym_tree (csym->name, gfc_current_ns, 1, &st);
3565 sym = st ? st->n.sym : NULL;
3566 if (sym && csym != sym
3567 && sym->ns == gfc_current_ns
3568 && sym->attr.flavor == FL_PROCEDURE
3569 && sym->attr.contained)
3570 {
3571 sym->refs++;
3572 if (csym->attr.generic)
3573 c->symtree->n.sym = sym;
3574 else
3575 c->symtree = st;
3576 csym = c->symtree->n.sym;
3577 }
3578 }
3579
3580 /* If this ia a deferred TBP with an abstract interface
3581 (which may of course be referenced), c->expr1 will be set. */
3582 if (csym && csym->attr.abstract && !c->expr1)
3583 {
3584 gfc_error ("ABSTRACT INTERFACE '%s' must not be referenced at %L",
3585 csym->name, &c->loc);
3586 return FAILURE;
3587 }
3588
3589 /* Subroutines without the RECURSIVE attribution are not allowed to
3590 * call themselves. */
3591 if (csym && is_illegal_recursion (csym, gfc_current_ns))
3592 {
3593 if (csym->attr.entry && csym->ns->entries)
3594 gfc_error ("ENTRY '%s' at %L cannot be called recursively, as"
3595 " subroutine '%s' is not RECURSIVE",
3596 csym->name, &c->loc, csym->ns->entries->sym->name);
3597 else
3598 gfc_error ("SUBROUTINE '%s' at %L cannot be called recursively, as it"
3599 " is not RECURSIVE", csym->name, &c->loc);
3600
3601 t = FAILURE;
3602 }
3603
3604 /* Switch off assumed size checking and do this again for certain kinds
3605 of procedure, once the procedure itself is resolved. */
3606 need_full_assumed_size++;
3607
3608 if (csym)
3609 ptype = csym->attr.proc;
3610
3611 no_formal_args = csym && is_external_proc (csym) && csym->formal == NULL;
3612 if (resolve_actual_arglist (c->ext.actual, ptype,
3613 no_formal_args) == FAILURE)
3614 return FAILURE;
3615
3616 /* Resume assumed_size checking. */
3617 need_full_assumed_size--;
3618
3619 /* If external, check for usage. */
3620 if (csym && is_external_proc (csym))
3621 resolve_global_procedure (csym, &c->loc, &c->ext.actual, 1);
3622
3623 t = SUCCESS;
3624 if (c->resolved_sym == NULL)
3625 {
3626 c->resolved_isym = NULL;
3627 switch (procedure_kind (csym))
3628 {
3629 case PTYPE_GENERIC:
3630 t = resolve_generic_s (c);
3631 break;
3632
3633 case PTYPE_SPECIFIC:
3634 t = resolve_specific_s (c);
3635 break;
3636
3637 case PTYPE_UNKNOWN:
3638 t = resolve_unknown_s (c);
3639 break;
3640
3641 default:
3642 gfc_internal_error ("resolve_subroutine(): bad function type");
3643 }
3644 }
3645
3646 /* Some checks of elemental subroutine actual arguments. */
3647 if (resolve_elemental_actual (NULL, c) == FAILURE)
3648 return FAILURE;
3649
3650 return t;
3651 }
3652
3653
3654 /* Compare the shapes of two arrays that have non-NULL shapes. If both
3655 op1->shape and op2->shape are non-NULL return SUCCESS if their shapes
3656 match. If both op1->shape and op2->shape are non-NULL return FAILURE
3657 if their shapes do not match. If either op1->shape or op2->shape is
3658 NULL, return SUCCESS. */
3659
3660 static gfc_try
3661 compare_shapes (gfc_expr *op1, gfc_expr *op2)
3662 {
3663 gfc_try t;
3664 int i;
3665
3666 t = SUCCESS;
3667
3668 if (op1->shape != NULL && op2->shape != NULL)
3669 {
3670 for (i = 0; i < op1->rank; i++)
3671 {
3672 if (mpz_cmp (op1->shape[i], op2->shape[i]) != 0)
3673 {
3674 gfc_error ("Shapes for operands at %L and %L are not conformable",
3675 &op1->where, &op2->where);
3676 t = FAILURE;
3677 break;
3678 }
3679 }
3680 }
3681
3682 return t;
3683 }
3684
3685
3686 /* Resolve an operator expression node. This can involve replacing the
3687 operation with a user defined function call. */
3688
3689 static gfc_try
3690 resolve_operator (gfc_expr *e)
3691 {
3692 gfc_expr *op1, *op2;
3693 char msg[200];
3694 bool dual_locus_error;
3695 gfc_try t;
3696
3697 /* Resolve all subnodes-- give them types. */
3698
3699 switch (e->value.op.op)
3700 {
3701 default:
3702 if (gfc_resolve_expr (e->value.op.op2) == FAILURE)
3703 return FAILURE;
3704
3705 /* Fall through... */
3706
3707 case INTRINSIC_NOT:
3708 case INTRINSIC_UPLUS:
3709 case INTRINSIC_UMINUS:
3710 case INTRINSIC_PARENTHESES:
3711 if (gfc_resolve_expr (e->value.op.op1) == FAILURE)
3712 return FAILURE;
3713 break;
3714 }
3715
3716 /* Typecheck the new node. */
3717
3718 op1 = e->value.op.op1;
3719 op2 = e->value.op.op2;
3720 dual_locus_error = false;
3721
3722 if ((op1 && op1->expr_type == EXPR_NULL)
3723 || (op2 && op2->expr_type == EXPR_NULL))
3724 {
3725 sprintf (msg, _("Invalid context for NULL() pointer at %%L"));
3726 goto bad_op;
3727 }
3728
3729 switch (e->value.op.op)
3730 {
3731 case INTRINSIC_UPLUS:
3732 case INTRINSIC_UMINUS:
3733 if (op1->ts.type == BT_INTEGER
3734 || op1->ts.type == BT_REAL
3735 || op1->ts.type == BT_COMPLEX)
3736 {
3737 e->ts = op1->ts;
3738 break;
3739 }
3740
3741 sprintf (msg, _("Operand of unary numeric operator '%s' at %%L is %s"),
3742 gfc_op2string (e->value.op.op), gfc_typename (&e->ts));
3743 goto bad_op;
3744
3745 case INTRINSIC_PLUS:
3746 case INTRINSIC_MINUS:
3747 case INTRINSIC_TIMES:
3748 case INTRINSIC_DIVIDE:
3749 case INTRINSIC_POWER:
3750 if (gfc_numeric_ts (&op1->ts) && gfc_numeric_ts (&op2->ts))
3751 {
3752 gfc_type_convert_binary (e, 1);
3753 break;
3754 }
3755
3756 sprintf (msg,
3757 _("Operands of binary numeric operator '%s' at %%L are %s/%s"),
3758 gfc_op2string (e->value.op.op), gfc_typename (&op1->ts),
3759 gfc_typename (&op2->ts));
3760 goto bad_op;
3761
3762 case INTRINSIC_CONCAT:
3763 if (op1->ts.type == BT_CHARACTER && op2->ts.type == BT_CHARACTER
3764 && op1->ts.kind == op2->ts.kind)
3765 {
3766 e->ts.type = BT_CHARACTER;
3767 e->ts.kind = op1->ts.kind;
3768 break;
3769 }
3770
3771 sprintf (msg,
3772 _("Operands of string concatenation operator at %%L are %s/%s"),
3773 gfc_typename (&op1->ts), gfc_typename (&op2->ts));
3774 goto bad_op;
3775
3776 case INTRINSIC_AND:
3777 case INTRINSIC_OR:
3778 case INTRINSIC_EQV:
3779 case INTRINSIC_NEQV:
3780 if (op1->ts.type == BT_LOGICAL && op2->ts.type == BT_LOGICAL)
3781 {
3782 e->ts.type = BT_LOGICAL;
3783 e->ts.kind = gfc_kind_max (op1, op2);
3784 if (op1->ts.kind < e->ts.kind)
3785 gfc_convert_type (op1, &e->ts, 2);
3786 else if (op2->ts.kind < e->ts.kind)
3787 gfc_convert_type (op2, &e->ts, 2);
3788 break;
3789 }
3790
3791 sprintf (msg, _("Operands of logical operator '%s' at %%L are %s/%s"),
3792 gfc_op2string (e->value.op.op), gfc_typename (&op1->ts),
3793 gfc_typename (&op2->ts));
3794
3795 goto bad_op;
3796
3797 case INTRINSIC_NOT:
3798 if (op1->ts.type == BT_LOGICAL)
3799 {
3800 e->ts.type = BT_LOGICAL;
3801 e->ts.kind = op1->ts.kind;
3802 break;
3803 }
3804
3805 sprintf (msg, _("Operand of .not. operator at %%L is %s"),
3806 gfc_typename (&op1->ts));
3807 goto bad_op;
3808
3809 case INTRINSIC_GT:
3810 case INTRINSIC_GT_OS:
3811 case INTRINSIC_GE:
3812 case INTRINSIC_GE_OS:
3813 case INTRINSIC_LT:
3814 case INTRINSIC_LT_OS:
3815 case INTRINSIC_LE:
3816 case INTRINSIC_LE_OS:
3817 if (op1->ts.type == BT_COMPLEX || op2->ts.type == BT_COMPLEX)
3818 {
3819 strcpy (msg, _("COMPLEX quantities cannot be compared at %L"));
3820 goto bad_op;
3821 }
3822
3823 /* Fall through... */
3824
3825 case INTRINSIC_EQ:
3826 case INTRINSIC_EQ_OS:
3827 case INTRINSIC_NE:
3828 case INTRINSIC_NE_OS:
3829 if (op1->ts.type == BT_CHARACTER && op2->ts.type == BT_CHARACTER
3830 && op1->ts.kind == op2->ts.kind)
3831 {
3832 e->ts.type = BT_LOGICAL;
3833 e->ts.kind = gfc_default_logical_kind;
3834 break;
3835 }
3836
3837 if (gfc_numeric_ts (&op1->ts) && gfc_numeric_ts (&op2->ts))
3838 {
3839 gfc_type_convert_binary (e, 1);
3840
3841 e->ts.type = BT_LOGICAL;
3842 e->ts.kind = gfc_default_logical_kind;
3843 break;
3844 }
3845
3846 if (op1->ts.type == BT_LOGICAL && op2->ts.type == BT_LOGICAL)
3847 sprintf (msg,
3848 _("Logicals at %%L must be compared with %s instead of %s"),
3849 (e->value.op.op == INTRINSIC_EQ
3850 || e->value.op.op == INTRINSIC_EQ_OS)
3851 ? ".eqv." : ".neqv.", gfc_op2string (e->value.op.op));
3852 else
3853 sprintf (msg,
3854 _("Operands of comparison operator '%s' at %%L are %s/%s"),
3855 gfc_op2string (e->value.op.op), gfc_typename (&op1->ts),
3856 gfc_typename (&op2->ts));
3857
3858 goto bad_op;
3859
3860 case INTRINSIC_USER:
3861 if (e->value.op.uop->op == NULL)
3862 sprintf (msg, _("Unknown operator '%s' at %%L"), e->value.op.uop->name);
3863 else if (op2 == NULL)
3864 sprintf (msg, _("Operand of user operator '%s' at %%L is %s"),
3865 e->value.op.uop->name, gfc_typename (&op1->ts));
3866 else
3867 {
3868 sprintf (msg, _("Operands of user operator '%s' at %%L are %s/%s"),
3869 e->value.op.uop->name, gfc_typename (&op1->ts),
3870 gfc_typename (&op2->ts));
3871 e->value.op.uop->op->sym->attr.referenced = 1;
3872 }
3873
3874 goto bad_op;
3875
3876 case INTRINSIC_PARENTHESES:
3877 e->ts = op1->ts;
3878 if (e->ts.type == BT_CHARACTER)
3879 e->ts.u.cl = op1->ts.u.cl;
3880 break;
3881
3882 default:
3883 gfc_internal_error ("resolve_operator(): Bad intrinsic");
3884 }
3885
3886 /* Deal with arrayness of an operand through an operator. */
3887
3888 t = SUCCESS;
3889
3890 switch (e->value.op.op)
3891 {
3892 case INTRINSIC_PLUS:
3893 case INTRINSIC_MINUS:
3894 case INTRINSIC_TIMES:
3895 case INTRINSIC_DIVIDE:
3896 case INTRINSIC_POWER:
3897 case INTRINSIC_CONCAT:
3898 case INTRINSIC_AND:
3899 case INTRINSIC_OR:
3900 case INTRINSIC_EQV:
3901 case INTRINSIC_NEQV:
3902 case INTRINSIC_EQ:
3903 case INTRINSIC_EQ_OS:
3904 case INTRINSIC_NE:
3905 case INTRINSIC_NE_OS:
3906 case INTRINSIC_GT:
3907 case INTRINSIC_GT_OS:
3908 case INTRINSIC_GE:
3909 case INTRINSIC_GE_OS:
3910 case INTRINSIC_LT:
3911 case INTRINSIC_LT_OS:
3912 case INTRINSIC_LE:
3913 case INTRINSIC_LE_OS:
3914
3915 if (op1->rank == 0 && op2->rank == 0)
3916 e->rank = 0;
3917
3918 if (op1->rank == 0 && op2->rank != 0)
3919 {
3920 e->rank = op2->rank;
3921
3922 if (e->shape == NULL)
3923 e->shape = gfc_copy_shape (op2->shape, op2->rank);
3924 }
3925
3926 if (op1->rank != 0 && op2->rank == 0)
3927 {
3928 e->rank = op1->rank;
3929
3930 if (e->shape == NULL)
3931 e->shape = gfc_copy_shape (op1->shape, op1->rank);
3932 }
3933
3934 if (op1->rank != 0 && op2->rank != 0)
3935 {
3936 if (op1->rank == op2->rank)
3937 {
3938 e->rank = op1->rank;
3939 if (e->shape == NULL)
3940 {
3941 t = compare_shapes (op1, op2);
3942 if (t == FAILURE)
3943 e->shape = NULL;
3944 else
3945 e->shape = gfc_copy_shape (op1->shape, op1->rank);
3946 }
3947 }
3948 else
3949 {
3950 /* Allow higher level expressions to work. */
3951 e->rank = 0;
3952
3953 /* Try user-defined operators, and otherwise throw an error. */
3954 dual_locus_error = true;
3955 sprintf (msg,
3956 _("Inconsistent ranks for operator at %%L and %%L"));
3957 goto bad_op;
3958 }
3959 }
3960
3961 break;
3962
3963 case INTRINSIC_PARENTHESES:
3964 case INTRINSIC_NOT:
3965 case INTRINSIC_UPLUS:
3966 case INTRINSIC_UMINUS:
3967 /* Simply copy arrayness attribute */
3968 e->rank = op1->rank;
3969
3970 if (e->shape == NULL)
3971 e->shape = gfc_copy_shape (op1->shape, op1->rank);
3972
3973 break;
3974
3975 default:
3976 break;
3977 }
3978
3979 /* Attempt to simplify the expression. */
3980 if (t == SUCCESS)
3981 {
3982 t = gfc_simplify_expr (e, 0);
3983 /* Some calls do not succeed in simplification and return FAILURE
3984 even though there is no error; e.g. variable references to
3985 PARAMETER arrays. */
3986 if (!gfc_is_constant_expr (e))
3987 t = SUCCESS;
3988 }
3989 return t;
3990
3991 bad_op:
3992
3993 {
3994 bool real_error;
3995 if (gfc_extend_expr (e, &real_error) == SUCCESS)
3996 return SUCCESS;
3997
3998 if (real_error)
3999 return FAILURE;
4000 }
4001
4002 if (dual_locus_error)
4003 gfc_error (msg, &op1->where, &op2->where);
4004 else
4005 gfc_error (msg, &e->where);
4006
4007 return FAILURE;
4008 }
4009
4010
4011 /************** Array resolution subroutines **************/
4012
4013 typedef enum
4014 { CMP_LT, CMP_EQ, CMP_GT, CMP_UNKNOWN }
4015 comparison;
4016
4017 /* Compare two integer expressions. */
4018
4019 static comparison
4020 compare_bound (gfc_expr *a, gfc_expr *b)
4021 {
4022 int i;
4023
4024 if (a == NULL || a->expr_type != EXPR_CONSTANT
4025 || b == NULL || b->expr_type != EXPR_CONSTANT)
4026 return CMP_UNKNOWN;
4027
4028 /* If either of the types isn't INTEGER, we must have
4029 raised an error earlier. */
4030
4031 if (a->ts.type != BT_INTEGER || b->ts.type != BT_INTEGER)
4032 return CMP_UNKNOWN;
4033
4034 i = mpz_cmp (a->value.integer, b->value.integer);
4035
4036 if (i < 0)
4037 return CMP_LT;
4038 if (i > 0)
4039 return CMP_GT;
4040 return CMP_EQ;
4041 }
4042
4043
4044 /* Compare an integer expression with an integer. */
4045
4046 static comparison
4047 compare_bound_int (gfc_expr *a, int b)
4048 {
4049 int i;
4050
4051 if (a == NULL || a->expr_type != EXPR_CONSTANT)
4052 return CMP_UNKNOWN;
4053
4054 if (a->ts.type != BT_INTEGER)
4055 gfc_internal_error ("compare_bound_int(): Bad expression");
4056
4057 i = mpz_cmp_si (a->value.integer, b);
4058
4059 if (i < 0)
4060 return CMP_LT;
4061 if (i > 0)
4062 return CMP_GT;
4063 return CMP_EQ;
4064 }
4065
4066
4067 /* Compare an integer expression with a mpz_t. */
4068
4069 static comparison
4070 compare_bound_mpz_t (gfc_expr *a, mpz_t b)
4071 {
4072 int i;
4073
4074 if (a == NULL || a->expr_type != EXPR_CONSTANT)
4075 return CMP_UNKNOWN;
4076
4077 if (a->ts.type != BT_INTEGER)
4078 gfc_internal_error ("compare_bound_int(): Bad expression");
4079
4080 i = mpz_cmp (a->value.integer, b);
4081
4082 if (i < 0)
4083 return CMP_LT;
4084 if (i > 0)
4085 return CMP_GT;
4086 return CMP_EQ;
4087 }
4088
4089
4090 /* Compute the last value of a sequence given by a triplet.
4091 Return 0 if it wasn't able to compute the last value, or if the
4092 sequence if empty, and 1 otherwise. */
4093
4094 static int
4095 compute_last_value_for_triplet (gfc_expr *start, gfc_expr *end,
4096 gfc_expr *stride, mpz_t last)
4097 {
4098 mpz_t rem;
4099
4100 if (start == NULL || start->expr_type != EXPR_CONSTANT
4101 || end == NULL || end->expr_type != EXPR_CONSTANT
4102 || (stride != NULL && stride->expr_type != EXPR_CONSTANT))
4103 return 0;
4104
4105 if (start->ts.type != BT_INTEGER || end->ts.type != BT_INTEGER
4106 || (stride != NULL && stride->ts.type != BT_INTEGER))
4107 return 0;
4108
4109 if (stride == NULL || compare_bound_int(stride, 1) == CMP_EQ)
4110 {
4111 if (compare_bound (start, end) == CMP_GT)
4112 return 0;
4113 mpz_set (last, end->value.integer);
4114 return 1;
4115 }
4116
4117 if (compare_bound_int (stride, 0) == CMP_GT)
4118 {
4119 /* Stride is positive */
4120 if (mpz_cmp (start->value.integer, end->value.integer) > 0)
4121 return 0;
4122 }
4123 else
4124 {
4125 /* Stride is negative */
4126 if (mpz_cmp (start->value.integer, end->value.integer) < 0)
4127 return 0;
4128 }
4129
4130 mpz_init (rem);
4131 mpz_sub (rem, end->value.integer, start->value.integer);
4132 mpz_tdiv_r (rem, rem, stride->value.integer);
4133 mpz_sub (last, end->value.integer, rem);
4134 mpz_clear (rem);
4135
4136 return 1;
4137 }
4138
4139
4140 /* Compare a single dimension of an array reference to the array
4141 specification. */
4142
4143 static gfc_try
4144 check_dimension (int i, gfc_array_ref *ar, gfc_array_spec *as)
4145 {
4146 mpz_t last_value;
4147
4148 if (ar->dimen_type[i] == DIMEN_STAR)
4149 {
4150 gcc_assert (ar->stride[i] == NULL);
4151 /* This implies [*] as [*:] and [*:3] are not possible. */
4152 if (ar->start[i] == NULL)
4153 {
4154 gcc_assert (ar->end[i] == NULL);
4155 return SUCCESS;
4156 }
4157 }
4158
4159 /* Given start, end and stride values, calculate the minimum and
4160 maximum referenced indexes. */
4161
4162 switch (ar->dimen_type[i])
4163 {
4164 case DIMEN_VECTOR:
4165 case DIMEN_THIS_IMAGE:
4166 break;
4167
4168 case DIMEN_STAR:
4169 case DIMEN_ELEMENT:
4170 if (compare_bound (ar->start[i], as->lower[i]) == CMP_LT)
4171 {
4172 if (i < as->rank)
4173 gfc_warning ("Array reference at %L is out of bounds "
4174 "(%ld < %ld) in dimension %d", &ar->c_where[i],
4175 mpz_get_si (ar->start[i]->value.integer),
4176 mpz_get_si (as->lower[i]->value.integer), i+1);
4177 else
4178 gfc_warning ("Array reference at %L is out of bounds "
4179 "(%ld < %ld) in codimension %d", &ar->c_where[i],
4180 mpz_get_si (ar->start[i]->value.integer),
4181 mpz_get_si (as->lower[i]->value.integer),
4182 i + 1 - as->rank);
4183 return SUCCESS;
4184 }
4185 if (compare_bound (ar->start[i], as->upper[i]) == CMP_GT)
4186 {
4187 if (i < as->rank)
4188 gfc_warning ("Array reference at %L is out of bounds "
4189 "(%ld > %ld) in dimension %d", &ar->c_where[i],
4190 mpz_get_si (ar->start[i]->value.integer),
4191 mpz_get_si (as->upper[i]->value.integer), i+1);
4192 else
4193 gfc_warning ("Array reference at %L is out of bounds "
4194 "(%ld > %ld) in codimension %d", &ar->c_where[i],
4195 mpz_get_si (ar->start[i]->value.integer),
4196 mpz_get_si (as->upper[i]->value.integer),
4197 i + 1 - as->rank);
4198 return SUCCESS;
4199 }
4200
4201 break;
4202
4203 case DIMEN_RANGE:
4204 {
4205 #define AR_START (ar->start[i] ? ar->start[i] : as->lower[i])
4206 #define AR_END (ar->end[i] ? ar->end[i] : as->upper[i])
4207
4208 comparison comp_start_end = compare_bound (AR_START, AR_END);
4209
4210 /* Check for zero stride, which is not allowed. */
4211 if (compare_bound_int (ar->stride[i], 0) == CMP_EQ)
4212 {
4213 gfc_error ("Illegal stride of zero at %L", &ar->c_where[i]);
4214 return FAILURE;
4215 }
4216
4217 /* if start == len || (stride > 0 && start < len)
4218 || (stride < 0 && start > len),
4219 then the array section contains at least one element. In this
4220 case, there is an out-of-bounds access if
4221 (start < lower || start > upper). */
4222 if (compare_bound (AR_START, AR_END) == CMP_EQ
4223 || ((compare_bound_int (ar->stride[i], 0) == CMP_GT
4224 || ar->stride[i] == NULL) && comp_start_end == CMP_LT)
4225 || (compare_bound_int (ar->stride[i], 0) == CMP_LT
4226 && comp_start_end == CMP_GT))
4227 {
4228 if (compare_bound (AR_START, as->lower[i]) == CMP_LT)
4229 {
4230 gfc_warning ("Lower array reference at %L is out of bounds "
4231 "(%ld < %ld) in dimension %d", &ar->c_where[i],
4232 mpz_get_si (AR_START->value.integer),
4233 mpz_get_si (as->lower[i]->value.integer), i+1);
4234 return SUCCESS;
4235 }
4236 if (compare_bound (AR_START, as->upper[i]) == CMP_GT)
4237 {
4238 gfc_warning ("Lower array reference at %L is out of bounds "
4239 "(%ld > %ld) in dimension %d", &ar->c_where[i],
4240 mpz_get_si (AR_START->value.integer),
4241 mpz_get_si (as->upper[i]->value.integer), i+1);
4242 return SUCCESS;
4243 }
4244 }
4245
4246 /* If we can compute the highest index of the array section,
4247 then it also has to be between lower and upper. */
4248 mpz_init (last_value);
4249 if (compute_last_value_for_triplet (AR_START, AR_END, ar->stride[i],
4250 last_value))
4251 {
4252 if (compare_bound_mpz_t (as->lower[i], last_value) == CMP_GT)
4253 {
4254 gfc_warning ("Upper array reference at %L is out of bounds "
4255 "(%ld < %ld) in dimension %d", &ar->c_where[i],
4256 mpz_get_si (last_value),
4257 mpz_get_si (as->lower[i]->value.integer), i+1);
4258 mpz_clear (last_value);
4259 return SUCCESS;
4260 }
4261 if (compare_bound_mpz_t (as->upper[i], last_value) == CMP_LT)
4262 {
4263 gfc_warning ("Upper array reference at %L is out of bounds "
4264 "(%ld > %ld) in dimension %d", &ar->c_where[i],
4265 mpz_get_si (last_value),
4266 mpz_get_si (as->upper[i]->value.integer), i+1);
4267 mpz_clear (last_value);
4268 return SUCCESS;
4269 }
4270 }
4271 mpz_clear (last_value);
4272
4273 #undef AR_START
4274 #undef AR_END
4275 }
4276 break;
4277
4278 default:
4279 gfc_internal_error ("check_dimension(): Bad array reference");
4280 }
4281
4282 return SUCCESS;
4283 }
4284
4285
4286 /* Compare an array reference with an array specification. */
4287
4288 static gfc_try
4289 compare_spec_to_ref (gfc_array_ref *ar)
4290 {
4291 gfc_array_spec *as;
4292 int i;
4293
4294 as = ar->as;
4295 i = as->rank - 1;
4296 /* TODO: Full array sections are only allowed as actual parameters. */
4297 if (as->type == AS_ASSUMED_SIZE
4298 && (/*ar->type == AR_FULL
4299 ||*/ (ar->type == AR_SECTION
4300 && ar->dimen_type[i] == DIMEN_RANGE && ar->end[i] == NULL)))
4301 {
4302 gfc_error ("Rightmost upper bound of assumed size array section "
4303 "not specified at %L", &ar->where);
4304 return FAILURE;
4305 }
4306
4307 if (ar->type == AR_FULL)
4308 return SUCCESS;
4309
4310 if (as->rank != ar->dimen)
4311 {
4312 gfc_error ("Rank mismatch in array reference at %L (%d/%d)",
4313 &ar->where, ar->dimen, as->rank);
4314 return FAILURE;
4315 }
4316
4317 /* ar->codimen == 0 is a local array. */
4318 if (as->corank != ar->codimen && ar->codimen != 0)
4319 {
4320 gfc_error ("Coindex rank mismatch in array reference at %L (%d/%d)",
4321 &ar->where, ar->codimen, as->corank);
4322 return FAILURE;
4323 }
4324
4325 for (i = 0; i < as->rank; i++)
4326 if (check_dimension (i, ar, as) == FAILURE)
4327 return FAILURE;
4328
4329 /* Local access has no coarray spec. */
4330 if (ar->codimen != 0)
4331 for (i = as->rank; i < as->rank + as->corank; i++)
4332 {
4333 if (ar->dimen_type[i] != DIMEN_ELEMENT && !ar->in_allocate
4334 && ar->dimen_type[i] != DIMEN_THIS_IMAGE)
4335 {
4336 gfc_error ("Coindex of codimension %d must be a scalar at %L",
4337 i + 1 - as->rank, &ar->where);
4338 return FAILURE;
4339 }
4340 if (check_dimension (i, ar, as) == FAILURE)
4341 return FAILURE;
4342 }
4343
4344 if (as->corank && ar->codimen == 0)
4345 {
4346 int n;
4347 ar->codimen = as->corank;
4348 for (n = ar->dimen; n < ar->dimen + ar->codimen; n++)
4349 ar->dimen_type[n] = DIMEN_THIS_IMAGE;
4350 }
4351
4352 return SUCCESS;
4353 }
4354
4355
4356 /* Resolve one part of an array index. */
4357
4358 static gfc_try
4359 gfc_resolve_index_1 (gfc_expr *index, int check_scalar,
4360 int force_index_integer_kind)
4361 {
4362 gfc_typespec ts;
4363
4364 if (index == NULL)
4365 return SUCCESS;
4366
4367 if (gfc_resolve_expr (index) == FAILURE)
4368 return FAILURE;
4369
4370 if (check_scalar && index->rank != 0)
4371 {
4372 gfc_error ("Array index at %L must be scalar", &index->where);
4373 return FAILURE;
4374 }
4375
4376 if (index->ts.type != BT_INTEGER && index->ts.type != BT_REAL)
4377 {
4378 gfc_error ("Array index at %L must be of INTEGER type, found %s",
4379 &index->where, gfc_basic_typename (index->ts.type));
4380 return FAILURE;
4381 }
4382
4383 if (index->ts.type == BT_REAL)
4384 if (gfc_notify_std (GFC_STD_LEGACY, "Extension: REAL array index at %L",
4385 &index->where) == FAILURE)
4386 return FAILURE;
4387
4388 if ((index->ts.kind != gfc_index_integer_kind
4389 && force_index_integer_kind)
4390 || index->ts.type != BT_INTEGER)
4391 {
4392 gfc_clear_ts (&ts);
4393 ts.type = BT_INTEGER;
4394 ts.kind = gfc_index_integer_kind;
4395
4396 gfc_convert_type_warn (index, &ts, 2, 0);
4397 }
4398
4399 return SUCCESS;
4400 }
4401
4402 /* Resolve one part of an array index. */
4403
4404 gfc_try
4405 gfc_resolve_index (gfc_expr *index, int check_scalar)
4406 {
4407 return gfc_resolve_index_1 (index, check_scalar, 1);
4408 }
4409
4410 /* Resolve a dim argument to an intrinsic function. */
4411
4412 gfc_try
4413 gfc_resolve_dim_arg (gfc_expr *dim)
4414 {
4415 if (dim == NULL)
4416 return SUCCESS;
4417
4418 if (gfc_resolve_expr (dim) == FAILURE)
4419 return FAILURE;
4420
4421 if (dim->rank != 0)
4422 {
4423 gfc_error ("Argument dim at %L must be scalar", &dim->where);
4424 return FAILURE;
4425
4426 }
4427
4428 if (dim->ts.type != BT_INTEGER)
4429 {
4430 gfc_error ("Argument dim at %L must be of INTEGER type", &dim->where);
4431 return FAILURE;
4432 }
4433
4434 if (dim->ts.kind != gfc_index_integer_kind)
4435 {
4436 gfc_typespec ts;
4437
4438 gfc_clear_ts (&ts);
4439 ts.type = BT_INTEGER;
4440 ts.kind = gfc_index_integer_kind;
4441
4442 gfc_convert_type_warn (dim, &ts, 2, 0);
4443 }
4444
4445 return SUCCESS;
4446 }
4447
4448 /* Given an expression that contains array references, update those array
4449 references to point to the right array specifications. While this is
4450 filled in during matching, this information is difficult to save and load
4451 in a module, so we take care of it here.
4452
4453 The idea here is that the original array reference comes from the
4454 base symbol. We traverse the list of reference structures, setting
4455 the stored reference to references. Component references can
4456 provide an additional array specification. */
4457
4458 static void
4459 find_array_spec (gfc_expr *e)
4460 {
4461 gfc_array_spec *as;
4462 gfc_component *c;
4463 gfc_symbol *derived;
4464 gfc_ref *ref;
4465
4466 if (e->symtree->n.sym->ts.type == BT_CLASS)
4467 as = CLASS_DATA (e->symtree->n.sym)->as;
4468 else
4469 as = e->symtree->n.sym->as;
4470 derived = NULL;
4471
4472 for (ref = e->ref; ref; ref = ref->next)
4473 switch (ref->type)
4474 {
4475 case REF_ARRAY:
4476 if (as == NULL)
4477 gfc_internal_error ("find_array_spec(): Missing spec");
4478
4479 ref->u.ar.as = as;
4480 as = NULL;
4481 break;
4482
4483 case REF_COMPONENT:
4484 if (derived == NULL)
4485 derived = e->symtree->n.sym->ts.u.derived;
4486
4487 if (derived->attr.is_class)
4488 derived = derived->components->ts.u.derived;
4489
4490 c = derived->components;
4491
4492 for (; c; c = c->next)
4493 if (c == ref->u.c.component)
4494 {
4495 /* Track the sequence of component references. */
4496 if (c->ts.type == BT_DERIVED)
4497 derived = c->ts.u.derived;
4498 break;
4499 }
4500
4501 if (c == NULL)
4502 gfc_internal_error ("find_array_spec(): Component not found");
4503
4504 if (c->attr.dimension)
4505 {
4506 if (as != NULL)
4507 gfc_internal_error ("find_array_spec(): unused as(1)");
4508 as = c->as;
4509 }
4510
4511 break;
4512
4513 case REF_SUBSTRING:
4514 break;
4515 }
4516
4517 if (as != NULL)
4518 gfc_internal_error ("find_array_spec(): unused as(2)");
4519 }
4520
4521
4522 /* Resolve an array reference. */
4523
4524 static gfc_try
4525 resolve_array_ref (gfc_array_ref *ar)
4526 {
4527 int i, check_scalar;
4528 gfc_expr *e;
4529
4530 for (i = 0; i < ar->dimen + ar->codimen; i++)
4531 {
4532 check_scalar = ar->dimen_type[i] == DIMEN_RANGE;
4533
4534 /* Do not force gfc_index_integer_kind for the start. We can
4535 do fine with any integer kind. This avoids temporary arrays
4536 created for indexing with a vector. */
4537 if (gfc_resolve_index_1 (ar->start[i], check_scalar, 0) == FAILURE)
4538 return FAILURE;
4539 if (gfc_resolve_index (ar->end[i], check_scalar) == FAILURE)
4540 return FAILURE;
4541 if (gfc_resolve_index (ar->stride[i], check_scalar) == FAILURE)
4542 return FAILURE;
4543
4544 e = ar->start[i];
4545
4546 if (ar->dimen_type[i] == DIMEN_UNKNOWN)
4547 switch (e->rank)
4548 {
4549 case 0:
4550 ar->dimen_type[i] = DIMEN_ELEMENT;
4551 break;
4552
4553 case 1:
4554 ar->dimen_type[i] = DIMEN_VECTOR;
4555 if (e->expr_type == EXPR_VARIABLE
4556 && e->symtree->n.sym->ts.type == BT_DERIVED)
4557 ar->start[i] = gfc_get_parentheses (e);
4558 break;
4559
4560 default:
4561 gfc_error ("Array index at %L is an array of rank %d",
4562 &ar->c_where[i], e->rank);
4563 return FAILURE;
4564 }
4565
4566 /* Fill in the upper bound, which may be lower than the
4567 specified one for something like a(2:10:5), which is
4568 identical to a(2:7:5). Only relevant for strides not equal
4569 to one. */
4570 if (ar->dimen_type[i] == DIMEN_RANGE
4571 && ar->stride[i] != NULL && ar->stride[i]->expr_type == EXPR_CONSTANT
4572 && mpz_cmp_si (ar->stride[i]->value.integer, 1L) != 0)
4573 {
4574 mpz_t size, end;
4575
4576 if (gfc_ref_dimen_size (ar, i, &size, &end) == SUCCESS)
4577 {
4578 if (ar->end[i] == NULL)
4579 {
4580 ar->end[i] =
4581 gfc_get_constant_expr (BT_INTEGER, gfc_index_integer_kind,
4582 &ar->where);
4583 mpz_set (ar->end[i]->value.integer, end);
4584 }
4585 else if (ar->end[i]->ts.type == BT_INTEGER
4586 && ar->end[i]->expr_type == EXPR_CONSTANT)
4587 {
4588 mpz_set (ar->end[i]->value.integer, end);
4589 }
4590 else
4591 gcc_unreachable ();
4592
4593 mpz_clear (size);
4594 mpz_clear (end);
4595 }
4596 }
4597 }
4598
4599 if (ar->type == AR_FULL && ar->as->rank == 0)
4600 ar->type = AR_ELEMENT;
4601
4602 /* If the reference type is unknown, figure out what kind it is. */
4603
4604 if (ar->type == AR_UNKNOWN)
4605 {
4606 ar->type = AR_ELEMENT;
4607 for (i = 0; i < ar->dimen; i++)
4608 if (ar->dimen_type[i] == DIMEN_RANGE
4609 || ar->dimen_type[i] == DIMEN_VECTOR)
4610 {
4611 ar->type = AR_SECTION;
4612 break;
4613 }
4614 }
4615
4616 if (!ar->as->cray_pointee && compare_spec_to_ref (ar) == FAILURE)
4617 return FAILURE;
4618
4619 return SUCCESS;
4620 }
4621
4622
4623 static gfc_try
4624 resolve_substring (gfc_ref *ref)
4625 {
4626 int k = gfc_validate_kind (BT_INTEGER, gfc_charlen_int_kind, false);
4627
4628 if (ref->u.ss.start != NULL)
4629 {
4630 if (gfc_resolve_expr (ref->u.ss.start) == FAILURE)
4631 return FAILURE;
4632
4633 if (ref->u.ss.start->ts.type != BT_INTEGER)
4634 {
4635 gfc_error ("Substring start index at %L must be of type INTEGER",
4636 &ref->u.ss.start->where);
4637 return FAILURE;
4638 }
4639
4640 if (ref->u.ss.start->rank != 0)
4641 {
4642 gfc_error ("Substring start index at %L must be scalar",
4643 &ref->u.ss.start->where);
4644 return FAILURE;
4645 }
4646
4647 if (compare_bound_int (ref->u.ss.start, 1) == CMP_LT
4648 && (compare_bound (ref->u.ss.end, ref->u.ss.start) == CMP_EQ
4649 || compare_bound (ref->u.ss.end, ref->u.ss.start) == CMP_GT))
4650 {
4651 gfc_error ("Substring start index at %L is less than one",
4652 &ref->u.ss.start->where);
4653 return FAILURE;
4654 }
4655 }
4656
4657 if (ref->u.ss.end != NULL)
4658 {
4659 if (gfc_resolve_expr (ref->u.ss.end) == FAILURE)
4660 return FAILURE;
4661
4662 if (ref->u.ss.end->ts.type != BT_INTEGER)
4663 {
4664 gfc_error ("Substring end index at %L must be of type INTEGER",
4665 &ref->u.ss.end->where);
4666 return FAILURE;
4667 }
4668
4669 if (ref->u.ss.end->rank != 0)
4670 {
4671 gfc_error ("Substring end index at %L must be scalar",
4672 &ref->u.ss.end->where);
4673 return FAILURE;
4674 }
4675
4676 if (ref->u.ss.length != NULL
4677 && compare_bound (ref->u.ss.end, ref->u.ss.length->length) == CMP_GT
4678 && (compare_bound (ref->u.ss.end, ref->u.ss.start) == CMP_EQ
4679 || compare_bound (ref->u.ss.end, ref->u.ss.start) == CMP_GT))
4680 {
4681 gfc_error ("Substring end index at %L exceeds the string length",
4682 &ref->u.ss.start->where);
4683 return FAILURE;
4684 }
4685
4686 if (compare_bound_mpz_t (ref->u.ss.end,
4687 gfc_integer_kinds[k].huge) == CMP_GT
4688 && (compare_bound (ref->u.ss.end, ref->u.ss.start) == CMP_EQ
4689 || compare_bound (ref->u.ss.end, ref->u.ss.start) == CMP_GT))
4690 {
4691 gfc_error ("Substring end index at %L is too large",
4692 &ref->u.ss.end->where);
4693 return FAILURE;
4694 }
4695 }
4696
4697 return SUCCESS;
4698 }
4699
4700
4701 /* This function supplies missing substring charlens. */
4702
4703 void
4704 gfc_resolve_substring_charlen (gfc_expr *e)
4705 {
4706 gfc_ref *char_ref;
4707 gfc_expr *start, *end;
4708
4709 for (char_ref = e->ref; char_ref; char_ref = char_ref->next)
4710 if (char_ref->type == REF_SUBSTRING)
4711 break;
4712
4713 if (!char_ref)
4714 return;
4715
4716 gcc_assert (char_ref->next == NULL);
4717
4718 if (e->ts.u.cl)
4719 {
4720 if (e->ts.u.cl->length)
4721 gfc_free_expr (e->ts.u.cl->length);
4722 else if (e->expr_type == EXPR_VARIABLE
4723 && e->symtree->n.sym->attr.dummy)
4724 return;
4725 }
4726
4727 e->ts.type = BT_CHARACTER;
4728 e->ts.kind = gfc_default_character_kind;
4729
4730 if (!e->ts.u.cl)
4731 e->ts.u.cl = gfc_new_charlen (gfc_current_ns, NULL);
4732
4733 if (char_ref->u.ss.start)
4734 start = gfc_copy_expr (char_ref->u.ss.start);
4735 else
4736 start = gfc_get_int_expr (gfc_default_integer_kind, NULL, 1);
4737
4738 if (char_ref->u.ss.end)
4739 end = gfc_copy_expr (char_ref->u.ss.end);
4740 else if (e->expr_type == EXPR_VARIABLE)
4741 end = gfc_copy_expr (e->symtree->n.sym->ts.u.cl->length);
4742 else
4743 end = NULL;
4744
4745 if (!start || !end)
4746 return;
4747
4748 /* Length = (end - start +1). */
4749 e->ts.u.cl->length = gfc_subtract (end, start);
4750 e->ts.u.cl->length = gfc_add (e->ts.u.cl->length,
4751 gfc_get_int_expr (gfc_default_integer_kind,
4752 NULL, 1));
4753
4754 e->ts.u.cl->length->ts.type = BT_INTEGER;
4755 e->ts.u.cl->length->ts.kind = gfc_charlen_int_kind;
4756
4757 /* Make sure that the length is simplified. */
4758 gfc_simplify_expr (e->ts.u.cl->length, 1);
4759 gfc_resolve_expr (e->ts.u.cl->length);
4760 }
4761
4762
4763 /* Resolve subtype references. */
4764
4765 static gfc_try
4766 resolve_ref (gfc_expr *expr)
4767 {
4768 int current_part_dimension, n_components, seen_part_dimension;
4769 gfc_ref *ref;
4770
4771 for (ref = expr->ref; ref; ref = ref->next)
4772 if (ref->type == REF_ARRAY && ref->u.ar.as == NULL)
4773 {
4774 find_array_spec (expr);
4775 break;
4776 }
4777
4778 for (ref = expr->ref; ref; ref = ref->next)
4779 switch (ref->type)
4780 {
4781 case REF_ARRAY:
4782 if (resolve_array_ref (&ref->u.ar) == FAILURE)
4783 return FAILURE;
4784 break;
4785
4786 case REF_COMPONENT:
4787 break;
4788
4789 case REF_SUBSTRING:
4790 resolve_substring (ref);
4791 break;
4792 }
4793
4794 /* Check constraints on part references. */
4795
4796 current_part_dimension = 0;
4797 seen_part_dimension = 0;
4798 n_components = 0;
4799
4800 for (ref = expr->ref; ref; ref = ref->next)
4801 {
4802 switch (ref->type)
4803 {
4804 case REF_ARRAY:
4805 switch (ref->u.ar.type)
4806 {
4807 case AR_FULL:
4808 /* Coarray scalar. */
4809 if (ref->u.ar.as->rank == 0)
4810 {
4811 current_part_dimension = 0;
4812 break;
4813 }
4814 /* Fall through. */
4815 case AR_SECTION:
4816 current_part_dimension = 1;
4817 break;
4818
4819 case AR_ELEMENT:
4820 current_part_dimension = 0;
4821 break;
4822
4823 case AR_UNKNOWN:
4824 gfc_internal_error ("resolve_ref(): Bad array reference");
4825 }
4826
4827 break;
4828
4829 case REF_COMPONENT:
4830 if (current_part_dimension || seen_part_dimension)
4831 {
4832 /* F03:C614. */
4833 if (ref->u.c.component->attr.pointer
4834 || ref->u.c.component->attr.proc_pointer)
4835 {
4836 gfc_error ("Component to the right of a part reference "
4837 "with nonzero rank must not have the POINTER "
4838 "attribute at %L", &expr->where);
4839 return FAILURE;
4840 }
4841 else if (ref->u.c.component->attr.allocatable)
4842 {
4843 gfc_error ("Component to the right of a part reference "
4844 "with nonzero rank must not have the ALLOCATABLE "
4845 "attribute at %L", &expr->where);
4846 return FAILURE;
4847 }
4848 }
4849
4850 n_components++;
4851 break;
4852
4853 case REF_SUBSTRING:
4854 break;
4855 }
4856
4857 if (((ref->type == REF_COMPONENT && n_components > 1)
4858 || ref->next == NULL)
4859 && current_part_dimension
4860 && seen_part_dimension)
4861 {
4862 gfc_error ("Two or more part references with nonzero rank must "
4863 "not be specified at %L", &expr->where);
4864 return FAILURE;
4865 }
4866
4867 if (ref->type == REF_COMPONENT)
4868 {
4869 if (current_part_dimension)
4870 seen_part_dimension = 1;
4871
4872 /* reset to make sure */
4873 current_part_dimension = 0;
4874 }
4875 }
4876
4877 return SUCCESS;
4878 }
4879
4880
4881 /* Given an expression, determine its shape. This is easier than it sounds.
4882 Leaves the shape array NULL if it is not possible to determine the shape. */
4883
4884 static void
4885 expression_shape (gfc_expr *e)
4886 {
4887 mpz_t array[GFC_MAX_DIMENSIONS];
4888 int i;
4889
4890 if (e->rank == 0 || e->shape != NULL)
4891 return;
4892
4893 for (i = 0; i < e->rank; i++)
4894 if (gfc_array_dimen_size (e, i, &array[i]) == FAILURE)
4895 goto fail;
4896
4897 e->shape = gfc_get_shape (e->rank);
4898
4899 memcpy (e->shape, array, e->rank * sizeof (mpz_t));
4900
4901 return;
4902
4903 fail:
4904 for (i--; i >= 0; i--)
4905 mpz_clear (array[i]);
4906 }
4907
4908
4909 /* Given a variable expression node, compute the rank of the expression by
4910 examining the base symbol and any reference structures it may have. */
4911
4912 static void
4913 expression_rank (gfc_expr *e)
4914 {
4915 gfc_ref *ref;
4916 int i, rank;
4917
4918 /* Just to make sure, because EXPR_COMPCALL's also have an e->ref and that
4919 could lead to serious confusion... */
4920 gcc_assert (e->expr_type != EXPR_COMPCALL);
4921
4922 if (e->ref == NULL)
4923 {
4924 if (e->expr_type == EXPR_ARRAY)
4925 goto done;
4926 /* Constructors can have a rank different from one via RESHAPE(). */
4927
4928 if (e->symtree == NULL)
4929 {
4930 e->rank = 0;
4931 goto done;
4932 }
4933
4934 e->rank = (e->symtree->n.sym->as == NULL)
4935 ? 0 : e->symtree->n.sym->as->rank;
4936 goto done;
4937 }
4938
4939 rank = 0;
4940
4941 for (ref = e->ref; ref; ref = ref->next)
4942 {
4943 if (ref->type == REF_COMPONENT && ref->u.c.component->attr.proc_pointer
4944 && ref->u.c.component->attr.function && !ref->next)
4945 rank = ref->u.c.component->as ? ref->u.c.component->as->rank : 0;
4946
4947 if (ref->type != REF_ARRAY)
4948 continue;
4949
4950 if (ref->u.ar.type == AR_FULL)
4951 {
4952 rank = ref->u.ar.as->rank;
4953 break;
4954 }
4955
4956 if (ref->u.ar.type == AR_SECTION)
4957 {
4958 /* Figure out the rank of the section. */
4959 if (rank != 0)
4960 gfc_internal_error ("expression_rank(): Two array specs");
4961
4962 for (i = 0; i < ref->u.ar.dimen; i++)
4963 if (ref->u.ar.dimen_type[i] == DIMEN_RANGE
4964 || ref->u.ar.dimen_type[i] == DIMEN_VECTOR)
4965 rank++;
4966
4967 break;
4968 }
4969 }
4970
4971 e->rank = rank;
4972
4973 done:
4974 expression_shape (e);
4975 }
4976
4977
4978 /* Resolve a variable expression. */
4979
4980 static gfc_try
4981 resolve_variable (gfc_expr *e)
4982 {
4983 gfc_symbol *sym;
4984 gfc_try t;
4985
4986 t = SUCCESS;
4987
4988 if (e->symtree == NULL)
4989 return FAILURE;
4990 sym = e->symtree->n.sym;
4991
4992 /* If this is an associate-name, it may be parsed with an array reference
4993 in error even though the target is scalar. Fail directly in this case. */
4994 if (sym->assoc && !sym->attr.dimension && e->ref && e->ref->type == REF_ARRAY)
4995 return FAILURE;
4996
4997 /* On the other hand, the parser may not have known this is an array;
4998 in this case, we have to add a FULL reference. */
4999 if (sym->assoc && sym->attr.dimension && !e->ref)
5000 {
5001 e->ref = gfc_get_ref ();
5002 e->ref->type = REF_ARRAY;
5003 e->ref->u.ar.type = AR_FULL;
5004 e->ref->u.ar.dimen = 0;
5005 }
5006
5007 if (e->ref && resolve_ref (e) == FAILURE)
5008 return FAILURE;
5009
5010 if (sym->attr.flavor == FL_PROCEDURE
5011 && (!sym->attr.function
5012 || (sym->attr.function && sym->result
5013 && sym->result->attr.proc_pointer
5014 && !sym->result->attr.function)))
5015 {
5016 e->ts.type = BT_PROCEDURE;
5017 goto resolve_procedure;
5018 }
5019
5020 if (sym->ts.type != BT_UNKNOWN)
5021 gfc_variable_attr (e, &e->ts);
5022 else
5023 {
5024 /* Must be a simple variable reference. */
5025 if (gfc_set_default_type (sym, 1, sym->ns) == FAILURE)
5026 return FAILURE;
5027 e->ts = sym->ts;
5028 }
5029
5030 if (check_assumed_size_reference (sym, e))
5031 return FAILURE;
5032
5033 /* Deal with forward references to entries during resolve_code, to
5034 satisfy, at least partially, 12.5.2.5. */
5035 if (gfc_current_ns->entries
5036 && current_entry_id == sym->entry_id
5037 && cs_base
5038 && cs_base->current
5039 && cs_base->current->op != EXEC_ENTRY)
5040 {
5041 gfc_entry_list *entry;
5042 gfc_formal_arglist *formal;
5043 int n;
5044 bool seen;
5045
5046 /* If the symbol is a dummy... */
5047 if (sym->attr.dummy && sym->ns == gfc_current_ns)
5048 {
5049 entry = gfc_current_ns->entries;
5050 seen = false;
5051
5052 /* ...test if the symbol is a parameter of previous entries. */
5053 for (; entry && entry->id <= current_entry_id; entry = entry->next)
5054 for (formal = entry->sym->formal; formal; formal = formal->next)
5055 {
5056 if (formal->sym && sym->name == formal->sym->name)
5057 seen = true;
5058 }
5059
5060 /* If it has not been seen as a dummy, this is an error. */
5061 if (!seen)
5062 {
5063 if (specification_expr)
5064 gfc_error ("Variable '%s', used in a specification expression"
5065 ", is referenced at %L before the ENTRY statement "
5066 "in which it is a parameter",
5067 sym->name, &cs_base->current->loc);
5068 else
5069 gfc_error ("Variable '%s' is used at %L before the ENTRY "
5070 "statement in which it is a parameter",
5071 sym->name, &cs_base->current->loc);
5072 t = FAILURE;
5073 }
5074 }
5075
5076 /* Now do the same check on the specification expressions. */
5077 specification_expr = 1;
5078 if (sym->ts.type == BT_CHARACTER
5079 && gfc_resolve_expr (sym->ts.u.cl->length) == FAILURE)
5080 t = FAILURE;
5081
5082 if (sym->as)
5083 for (n = 0; n < sym->as->rank; n++)
5084 {
5085 specification_expr = 1;
5086 if (gfc_resolve_expr (sym->as->lower[n]) == FAILURE)
5087 t = FAILURE;
5088 specification_expr = 1;
5089 if (gfc_resolve_expr (sym->as->upper[n]) == FAILURE)
5090 t = FAILURE;
5091 }
5092 specification_expr = 0;
5093
5094 if (t == SUCCESS)
5095 /* Update the symbol's entry level. */
5096 sym->entry_id = current_entry_id + 1;
5097 }
5098
5099 /* If a symbol has been host_associated mark it. This is used latter,
5100 to identify if aliasing is possible via host association. */
5101 if (sym->attr.flavor == FL_VARIABLE
5102 && gfc_current_ns->parent
5103 && (gfc_current_ns->parent == sym->ns
5104 || (gfc_current_ns->parent->parent
5105 && gfc_current_ns->parent->parent == sym->ns)))
5106 sym->attr.host_assoc = 1;
5107
5108 resolve_procedure:
5109 if (t == SUCCESS && resolve_procedure_expression (e) == FAILURE)
5110 t = FAILURE;
5111
5112 /* F2008, C617 and C1229. */
5113 if (!inquiry_argument && (e->ts.type == BT_CLASS || e->ts.type == BT_DERIVED)
5114 && gfc_is_coindexed (e))
5115 {
5116 gfc_ref *ref, *ref2 = NULL;
5117
5118 for (ref = e->ref; ref; ref = ref->next)
5119 {
5120 if (ref->type == REF_COMPONENT)
5121 ref2 = ref;
5122 if (ref->type == REF_ARRAY && ref->u.ar.codimen > 0)
5123 break;
5124 }
5125
5126 for ( ; ref; ref = ref->next)
5127 if (ref->type == REF_COMPONENT)
5128 break;
5129
5130 /* Expression itself is not coindexed object. */
5131 if (ref && e->ts.type == BT_CLASS)
5132 {
5133 gfc_error ("Polymorphic subobject of coindexed object at %L",
5134 &e->where);
5135 t = FAILURE;
5136 }
5137
5138 /* Expression itself is coindexed object. */
5139 if (ref == NULL)
5140 {
5141 gfc_component *c;
5142 c = ref2 ? ref2->u.c.component : e->symtree->n.sym->components;
5143 for ( ; c; c = c->next)
5144 if (c->attr.allocatable && c->ts.type == BT_CLASS)
5145 {
5146 gfc_error ("Coindexed object with polymorphic allocatable "
5147 "subcomponent at %L", &e->where);
5148 t = FAILURE;
5149 break;
5150 }
5151 }
5152 }
5153
5154 return t;
5155 }
5156
5157
5158 /* Checks to see that the correct symbol has been host associated.
5159 The only situation where this arises is that in which a twice
5160 contained function is parsed after the host association is made.
5161 Therefore, on detecting this, change the symbol in the expression
5162 and convert the array reference into an actual arglist if the old
5163 symbol is a variable. */
5164 static bool
5165 check_host_association (gfc_expr *e)
5166 {
5167 gfc_symbol *sym, *old_sym;
5168 gfc_symtree *st;
5169 int n;
5170 gfc_ref *ref;
5171 gfc_actual_arglist *arg, *tail = NULL;
5172 bool retval = e->expr_type == EXPR_FUNCTION;
5173
5174 /* If the expression is the result of substitution in
5175 interface.c(gfc_extend_expr) because there is no way in
5176 which the host association can be wrong. */
5177 if (e->symtree == NULL
5178 || e->symtree->n.sym == NULL
5179 || e->user_operator)
5180 return retval;
5181
5182 old_sym = e->symtree->n.sym;
5183
5184 if (gfc_current_ns->parent
5185 && old_sym->ns != gfc_current_ns)
5186 {
5187 /* Use the 'USE' name so that renamed module symbols are
5188 correctly handled. */
5189 gfc_find_symbol (e->symtree->name, gfc_current_ns, 1, &sym);
5190
5191 if (sym && old_sym != sym
5192 && sym->ts.type == old_sym->ts.type
5193 && sym->attr.flavor == FL_PROCEDURE
5194 && sym->attr.contained)
5195 {
5196 /* Clear the shape, since it might not be valid. */
5197 if (e->shape != NULL)
5198 {
5199 for (n = 0; n < e->rank; n++)
5200 mpz_clear (e->shape[n]);
5201
5202 free (e->shape);
5203 }
5204
5205 /* Give the expression the right symtree! */
5206 gfc_find_sym_tree (e->symtree->name, NULL, 1, &st);
5207 gcc_assert (st != NULL);
5208
5209 if (old_sym->attr.flavor == FL_PROCEDURE
5210 || e->expr_type == EXPR_FUNCTION)
5211 {
5212 /* Original was function so point to the new symbol, since
5213 the actual argument list is already attached to the
5214 expression. */
5215 e->value.function.esym = NULL;
5216 e->symtree = st;
5217 }
5218 else
5219 {
5220 /* Original was variable so convert array references into
5221 an actual arglist. This does not need any checking now
5222 since gfc_resolve_function will take care of it. */
5223 e->value.function.actual = NULL;
5224 e->expr_type = EXPR_FUNCTION;
5225 e->symtree = st;
5226
5227 /* Ambiguity will not arise if the array reference is not
5228 the last reference. */
5229 for (ref = e->ref; ref; ref = ref->next)
5230 if (ref->type == REF_ARRAY && ref->next == NULL)
5231 break;
5232
5233 gcc_assert (ref->type == REF_ARRAY);
5234
5235 /* Grab the start expressions from the array ref and
5236 copy them into actual arguments. */
5237 for (n = 0; n < ref->u.ar.dimen; n++)
5238 {
5239 arg = gfc_get_actual_arglist ();
5240 arg->expr = gfc_copy_expr (ref->u.ar.start[n]);
5241 if (e->value.function.actual == NULL)
5242 tail = e->value.function.actual = arg;
5243 else
5244 {
5245 tail->next = arg;
5246 tail = arg;
5247 }
5248 }
5249
5250 /* Dump the reference list and set the rank. */
5251 gfc_free_ref_list (e->ref);
5252 e->ref = NULL;
5253 e->rank = sym->as ? sym->as->rank : 0;
5254 }
5255
5256 gfc_resolve_expr (e);
5257 sym->refs++;
5258 }
5259 }
5260 /* This might have changed! */
5261 return e->expr_type == EXPR_FUNCTION;
5262 }
5263
5264
5265 static void
5266 gfc_resolve_character_operator (gfc_expr *e)
5267 {
5268 gfc_expr *op1 = e->value.op.op1;
5269 gfc_expr *op2 = e->value.op.op2;
5270 gfc_expr *e1 = NULL;
5271 gfc_expr *e2 = NULL;
5272
5273 gcc_assert (e->value.op.op == INTRINSIC_CONCAT);
5274
5275 if (op1->ts.u.cl && op1->ts.u.cl->length)
5276 e1 = gfc_copy_expr (op1->ts.u.cl->length);
5277 else if (op1->expr_type == EXPR_CONSTANT)
5278 e1 = gfc_get_int_expr (gfc_default_integer_kind, NULL,
5279 op1->value.character.length);
5280
5281 if (op2->ts.u.cl && op2->ts.u.cl->length)
5282 e2 = gfc_copy_expr (op2->ts.u.cl->length);
5283 else if (op2->expr_type == EXPR_CONSTANT)
5284 e2 = gfc_get_int_expr (gfc_default_integer_kind, NULL,
5285 op2->value.character.length);
5286
5287 e->ts.u.cl = gfc_new_charlen (gfc_current_ns, NULL);
5288
5289 if (!e1 || !e2)
5290 return;
5291
5292 e->ts.u.cl->length = gfc_add (e1, e2);
5293 e->ts.u.cl->length->ts.type = BT_INTEGER;
5294 e->ts.u.cl->length->ts.kind = gfc_charlen_int_kind;
5295 gfc_simplify_expr (e->ts.u.cl->length, 0);
5296 gfc_resolve_expr (e->ts.u.cl->length);
5297
5298 return;
5299 }
5300
5301
5302 /* Ensure that an character expression has a charlen and, if possible, a
5303 length expression. */
5304
5305 static void
5306 fixup_charlen (gfc_expr *e)
5307 {
5308 /* The cases fall through so that changes in expression type and the need
5309 for multiple fixes are picked up. In all circumstances, a charlen should
5310 be available for the middle end to hang a backend_decl on. */
5311 switch (e->expr_type)
5312 {
5313 case EXPR_OP:
5314 gfc_resolve_character_operator (e);
5315
5316 case EXPR_ARRAY:
5317 if (e->expr_type == EXPR_ARRAY)
5318 gfc_resolve_character_array_constructor (e);
5319
5320 case EXPR_SUBSTRING:
5321 if (!e->ts.u.cl && e->ref)
5322 gfc_resolve_substring_charlen (e);
5323
5324 default:
5325 if (!e->ts.u.cl)
5326 e->ts.u.cl = gfc_new_charlen (gfc_current_ns, NULL);
5327
5328 break;
5329 }
5330 }
5331
5332
5333 /* Update an actual argument to include the passed-object for type-bound
5334 procedures at the right position. */
5335
5336 static gfc_actual_arglist*
5337 update_arglist_pass (gfc_actual_arglist* lst, gfc_expr* po, unsigned argpos,
5338 const char *name)
5339 {
5340 gcc_assert (argpos > 0);
5341
5342 if (argpos == 1)
5343 {
5344 gfc_actual_arglist* result;
5345
5346 result = gfc_get_actual_arglist ();
5347 result->expr = po;
5348 result->next = lst;
5349 if (name)
5350 result->name = name;
5351
5352 return result;
5353 }
5354
5355 if (lst)
5356 lst->next = update_arglist_pass (lst->next, po, argpos - 1, name);
5357 else
5358 lst = update_arglist_pass (NULL, po, argpos - 1, name);
5359 return lst;
5360 }
5361
5362
5363 /* Extract the passed-object from an EXPR_COMPCALL (a copy of it). */
5364
5365 static gfc_expr*
5366 extract_compcall_passed_object (gfc_expr* e)
5367 {
5368 gfc_expr* po;
5369
5370 gcc_assert (e->expr_type == EXPR_COMPCALL);
5371
5372 if (e->value.compcall.base_object)
5373 po = gfc_copy_expr (e->value.compcall.base_object);
5374 else
5375 {
5376 po = gfc_get_expr ();
5377 po->expr_type = EXPR_VARIABLE;
5378 po->symtree = e->symtree;
5379 po->ref = gfc_copy_ref (e->ref);
5380 po->where = e->where;
5381 }
5382
5383 if (gfc_resolve_expr (po) == FAILURE)
5384 return NULL;
5385
5386 return po;
5387 }
5388
5389
5390 /* Update the arglist of an EXPR_COMPCALL expression to include the
5391 passed-object. */
5392
5393 static gfc_try
5394 update_compcall_arglist (gfc_expr* e)
5395 {
5396 gfc_expr* po;
5397 gfc_typebound_proc* tbp;
5398
5399 tbp = e->value.compcall.tbp;
5400
5401 if (tbp->error)
5402 return FAILURE;
5403
5404 po = extract_compcall_passed_object (e);
5405 if (!po)
5406 return FAILURE;
5407
5408 if (tbp->nopass || e->value.compcall.ignore_pass)
5409 {
5410 gfc_free_expr (po);
5411 return SUCCESS;
5412 }
5413
5414 gcc_assert (tbp->pass_arg_num > 0);
5415 e->value.compcall.actual = update_arglist_pass (e->value.compcall.actual, po,
5416 tbp->pass_arg_num,
5417 tbp->pass_arg);
5418
5419 return SUCCESS;
5420 }
5421
5422
5423 /* Extract the passed object from a PPC call (a copy of it). */
5424
5425 static gfc_expr*
5426 extract_ppc_passed_object (gfc_expr *e)
5427 {
5428 gfc_expr *po;
5429 gfc_ref **ref;
5430
5431 po = gfc_get_expr ();
5432 po->expr_type = EXPR_VARIABLE;
5433 po->symtree = e->symtree;
5434 po->ref = gfc_copy_ref (e->ref);
5435 po->where = e->where;
5436
5437 /* Remove PPC reference. */
5438 ref = &po->ref;
5439 while ((*ref)->next)
5440 ref = &(*ref)->next;
5441 gfc_free_ref_list (*ref);
5442 *ref = NULL;
5443
5444 if (gfc_resolve_expr (po) == FAILURE)
5445 return NULL;
5446
5447 return po;
5448 }
5449
5450
5451 /* Update the actual arglist of a procedure pointer component to include the
5452 passed-object. */
5453
5454 static gfc_try
5455 update_ppc_arglist (gfc_expr* e)
5456 {
5457 gfc_expr* po;
5458 gfc_component *ppc;
5459 gfc_typebound_proc* tb;
5460
5461 if (!gfc_is_proc_ptr_comp (e, &ppc))
5462 return FAILURE;
5463
5464 tb = ppc->tb;
5465
5466 if (tb->error)
5467 return FAILURE;
5468 else if (tb->nopass)
5469 return SUCCESS;
5470
5471 po = extract_ppc_passed_object (e);
5472 if (!po)
5473 return FAILURE;
5474
5475 /* F08:R739. */
5476 if (po->rank > 0)
5477 {
5478 gfc_error ("Passed-object at %L must be scalar", &e->where);
5479 return FAILURE;
5480 }
5481
5482 /* F08:C611. */
5483 if (po->ts.type == BT_DERIVED && po->ts.u.derived->attr.abstract)
5484 {
5485 gfc_error ("Base object for procedure-pointer component call at %L is of"
5486 " ABSTRACT type '%s'", &e->where, po->ts.u.derived->name);
5487 return FAILURE;
5488 }
5489
5490 gcc_assert (tb->pass_arg_num > 0);
5491 e->value.compcall.actual = update_arglist_pass (e->value.compcall.actual, po,
5492 tb->pass_arg_num,
5493 tb->pass_arg);
5494
5495 return SUCCESS;
5496 }
5497
5498
5499 /* Check that the object a TBP is called on is valid, i.e. it must not be
5500 of ABSTRACT type (as in subobject%abstract_parent%tbp()). */
5501
5502 static gfc_try
5503 check_typebound_baseobject (gfc_expr* e)
5504 {
5505 gfc_expr* base;
5506 gfc_try return_value = FAILURE;
5507
5508 base = extract_compcall_passed_object (e);
5509 if (!base)
5510 return FAILURE;
5511
5512 gcc_assert (base->ts.type == BT_DERIVED || base->ts.type == BT_CLASS);
5513
5514 /* F08:C611. */
5515 if (base->ts.type == BT_DERIVED && base->ts.u.derived->attr.abstract)
5516 {
5517 gfc_error ("Base object for type-bound procedure call at %L is of"
5518 " ABSTRACT type '%s'", &e->where, base->ts.u.derived->name);
5519 goto cleanup;
5520 }
5521
5522 /* F08:C1230. If the procedure called is NOPASS,
5523 the base object must be scalar. */
5524 if (e->value.compcall.tbp->nopass && base->rank > 0)
5525 {
5526 gfc_error ("Base object for NOPASS type-bound procedure call at %L must"
5527 " be scalar", &e->where);
5528 goto cleanup;
5529 }
5530
5531 /* FIXME: Remove once PR 43214 is fixed (TBP with non-scalar PASS). */
5532 if (base->rank > 0)
5533 {
5534 gfc_error ("Non-scalar base object at %L currently not implemented",
5535 &e->where);
5536 goto cleanup;
5537 }
5538
5539 return_value = SUCCESS;
5540
5541 cleanup:
5542 gfc_free_expr (base);
5543 return return_value;
5544 }
5545
5546
5547 /* Resolve a call to a type-bound procedure, either function or subroutine,
5548 statically from the data in an EXPR_COMPCALL expression. The adapted
5549 arglist and the target-procedure symtree are returned. */
5550
5551 static gfc_try
5552 resolve_typebound_static (gfc_expr* e, gfc_symtree** target,
5553 gfc_actual_arglist** actual)
5554 {
5555 gcc_assert (e->expr_type == EXPR_COMPCALL);
5556 gcc_assert (!e->value.compcall.tbp->is_generic);
5557
5558 /* Update the actual arglist for PASS. */
5559 if (update_compcall_arglist (e) == FAILURE)
5560 return FAILURE;
5561
5562 *actual = e->value.compcall.actual;
5563 *target = e->value.compcall.tbp->u.specific;
5564
5565 gfc_free_ref_list (e->ref);
5566 e->ref = NULL;
5567 e->value.compcall.actual = NULL;
5568
5569 return SUCCESS;
5570 }
5571
5572
5573 /* Get the ultimate declared type from an expression. In addition,
5574 return the last class/derived type reference and the copy of the
5575 reference list. */
5576 static gfc_symbol*
5577 get_declared_from_expr (gfc_ref **class_ref, gfc_ref **new_ref,
5578 gfc_expr *e)
5579 {
5580 gfc_symbol *declared;
5581 gfc_ref *ref;
5582
5583 declared = NULL;
5584 if (class_ref)
5585 *class_ref = NULL;
5586 if (new_ref)
5587 *new_ref = gfc_copy_ref (e->ref);
5588
5589 for (ref = e->ref; ref; ref = ref->next)
5590 {
5591 if (ref->type != REF_COMPONENT)
5592 continue;
5593
5594 if (ref->u.c.component->ts.type == BT_CLASS
5595 || ref->u.c.component->ts.type == BT_DERIVED)
5596 {
5597 declared = ref->u.c.component->ts.u.derived;
5598 if (class_ref)
5599 *class_ref = ref;
5600 }
5601 }
5602
5603 if (declared == NULL)
5604 declared = e->symtree->n.sym->ts.u.derived;
5605
5606 return declared;
5607 }
5608
5609
5610 /* Given an EXPR_COMPCALL calling a GENERIC typebound procedure, figure out
5611 which of the specific bindings (if any) matches the arglist and transform
5612 the expression into a call of that binding. */
5613
5614 static gfc_try
5615 resolve_typebound_generic_call (gfc_expr* e, const char **name)
5616 {
5617 gfc_typebound_proc* genproc;
5618 const char* genname;
5619 gfc_symtree *st;
5620 gfc_symbol *derived;
5621
5622 gcc_assert (e->expr_type == EXPR_COMPCALL);
5623 genname = e->value.compcall.name;
5624 genproc = e->value.compcall.tbp;
5625
5626 if (!genproc->is_generic)
5627 return SUCCESS;
5628
5629 /* Try the bindings on this type and in the inheritance hierarchy. */
5630 for (; genproc; genproc = genproc->overridden)
5631 {
5632 gfc_tbp_generic* g;
5633
5634 gcc_assert (genproc->is_generic);
5635 for (g = genproc->u.generic; g; g = g->next)
5636 {
5637 gfc_symbol* target;
5638 gfc_actual_arglist* args;
5639 bool matches;
5640
5641 gcc_assert (g->specific);
5642
5643 if (g->specific->error)
5644 continue;
5645
5646 target = g->specific->u.specific->n.sym;
5647
5648 /* Get the right arglist by handling PASS/NOPASS. */
5649 args = gfc_copy_actual_arglist (e->value.compcall.actual);
5650 if (!g->specific->nopass)
5651 {
5652 gfc_expr* po;
5653 po = extract_compcall_passed_object (e);
5654 if (!po)
5655 return FAILURE;
5656
5657 gcc_assert (g->specific->pass_arg_num > 0);
5658 gcc_assert (!g->specific->error);
5659 args = update_arglist_pass (args, po, g->specific->pass_arg_num,
5660 g->specific->pass_arg);
5661 }
5662 resolve_actual_arglist (args, target->attr.proc,
5663 is_external_proc (target) && !target->formal);
5664
5665 /* Check if this arglist matches the formal. */
5666 matches = gfc_arglist_matches_symbol (&args, target);
5667
5668 /* Clean up and break out of the loop if we've found it. */
5669 gfc_free_actual_arglist (args);
5670 if (matches)
5671 {
5672 e->value.compcall.tbp = g->specific;
5673 genname = g->specific_st->name;
5674 /* Pass along the name for CLASS methods, where the vtab
5675 procedure pointer component has to be referenced. */
5676 if (name)
5677 *name = genname;
5678 goto success;
5679 }
5680 }
5681 }
5682
5683 /* Nothing matching found! */
5684 gfc_error ("Found no matching specific binding for the call to the GENERIC"
5685 " '%s' at %L", genname, &e->where);
5686 return FAILURE;
5687
5688 success:
5689 /* Make sure that we have the right specific instance for the name. */
5690 derived = get_declared_from_expr (NULL, NULL, e);
5691
5692 st = gfc_find_typebound_proc (derived, NULL, genname, true, &e->where);
5693 if (st)
5694 e->value.compcall.tbp = st->n.tb;
5695
5696 return SUCCESS;
5697 }
5698
5699
5700 /* Resolve a call to a type-bound subroutine. */
5701
5702 static gfc_try
5703 resolve_typebound_call (gfc_code* c, const char **name)
5704 {
5705 gfc_actual_arglist* newactual;
5706 gfc_symtree* target;
5707
5708 /* Check that's really a SUBROUTINE. */
5709 if (!c->expr1->value.compcall.tbp->subroutine)
5710 {
5711 gfc_error ("'%s' at %L should be a SUBROUTINE",
5712 c->expr1->value.compcall.name, &c->loc);
5713 return FAILURE;
5714 }
5715
5716 if (check_typebound_baseobject (c->expr1) == FAILURE)
5717 return FAILURE;
5718
5719 /* Pass along the name for CLASS methods, where the vtab
5720 procedure pointer component has to be referenced. */
5721 if (name)
5722 *name = c->expr1->value.compcall.name;
5723
5724 if (resolve_typebound_generic_call (c->expr1, name) == FAILURE)
5725 return FAILURE;
5726
5727 /* Transform into an ordinary EXEC_CALL for now. */
5728
5729 if (resolve_typebound_static (c->expr1, &target, &newactual) == FAILURE)
5730 return FAILURE;
5731
5732 c->ext.actual = newactual;
5733 c->symtree = target;
5734 c->op = (c->expr1->value.compcall.assign ? EXEC_ASSIGN_CALL : EXEC_CALL);
5735
5736 gcc_assert (!c->expr1->ref && !c->expr1->value.compcall.actual);
5737
5738 gfc_free_expr (c->expr1);
5739 c->expr1 = gfc_get_expr ();
5740 c->expr1->expr_type = EXPR_FUNCTION;
5741 c->expr1->symtree = target;
5742 c->expr1->where = c->loc;
5743
5744 return resolve_call (c);
5745 }
5746
5747
5748 /* Resolve a component-call expression. */
5749 static gfc_try
5750 resolve_compcall (gfc_expr* e, const char **name)
5751 {
5752 gfc_actual_arglist* newactual;
5753 gfc_symtree* target;
5754
5755 /* Check that's really a FUNCTION. */
5756 if (!e->value.compcall.tbp->function)
5757 {
5758 gfc_error ("'%s' at %L should be a FUNCTION",
5759 e->value.compcall.name, &e->where);
5760 return FAILURE;
5761 }
5762
5763 /* These must not be assign-calls! */
5764 gcc_assert (!e->value.compcall.assign);
5765
5766 if (check_typebound_baseobject (e) == FAILURE)
5767 return FAILURE;
5768
5769 /* Pass along the name for CLASS methods, where the vtab
5770 procedure pointer component has to be referenced. */
5771 if (name)
5772 *name = e->value.compcall.name;
5773
5774 if (resolve_typebound_generic_call (e, name) == FAILURE)
5775 return FAILURE;
5776 gcc_assert (!e->value.compcall.tbp->is_generic);
5777
5778 /* Take the rank from the function's symbol. */
5779 if (e->value.compcall.tbp->u.specific->n.sym->as)
5780 e->rank = e->value.compcall.tbp->u.specific->n.sym->as->rank;
5781
5782 /* For now, we simply transform it into an EXPR_FUNCTION call with the same
5783 arglist to the TBP's binding target. */
5784
5785 if (resolve_typebound_static (e, &target, &newactual) == FAILURE)
5786 return FAILURE;
5787
5788 e->value.function.actual = newactual;
5789 e->value.function.name = NULL;
5790 e->value.function.esym = target->n.sym;
5791 e->value.function.isym = NULL;
5792 e->symtree = target;
5793 e->ts = target->n.sym->ts;
5794 e->expr_type = EXPR_FUNCTION;
5795
5796 /* Resolution is not necessary if this is a class subroutine; this
5797 function only has to identify the specific proc. Resolution of
5798 the call will be done next in resolve_typebound_call. */
5799 return gfc_resolve_expr (e);
5800 }
5801
5802
5803
5804 /* Resolve a typebound function, or 'method'. First separate all
5805 the non-CLASS references by calling resolve_compcall directly. */
5806
5807 static gfc_try
5808 resolve_typebound_function (gfc_expr* e)
5809 {
5810 gfc_symbol *declared;
5811 gfc_component *c;
5812 gfc_ref *new_ref;
5813 gfc_ref *class_ref;
5814 gfc_symtree *st;
5815 const char *name;
5816 gfc_typespec ts;
5817 gfc_expr *expr;
5818
5819 st = e->symtree;
5820
5821 /* Deal with typebound operators for CLASS objects. */
5822 expr = e->value.compcall.base_object;
5823 if (expr && expr->ts.type == BT_CLASS && e->value.compcall.name)
5824 {
5825 /* Since the typebound operators are generic, we have to ensure
5826 that any delays in resolution are corrected and that the vtab
5827 is present. */
5828 ts = expr->ts;
5829 declared = ts.u.derived;
5830 c = gfc_find_component (declared, "_vptr", true, true);
5831 if (c->ts.u.derived == NULL)
5832 c->ts.u.derived = gfc_find_derived_vtab (declared);
5833
5834 if (resolve_compcall (e, &name) == FAILURE)
5835 return FAILURE;
5836
5837 /* Use the generic name if it is there. */
5838 name = name ? name : e->value.function.esym->name;
5839 e->symtree = expr->symtree;
5840 e->ref = gfc_copy_ref (expr->ref);
5841 gfc_add_vptr_component (e);
5842 gfc_add_component_ref (e, name);
5843 e->value.function.esym = NULL;
5844 return SUCCESS;
5845 }
5846
5847 if (st == NULL)
5848 return resolve_compcall (e, NULL);
5849
5850 if (resolve_ref (e) == FAILURE)
5851 return FAILURE;
5852
5853 /* Get the CLASS declared type. */
5854 declared = get_declared_from_expr (&class_ref, &new_ref, e);
5855
5856 /* Weed out cases of the ultimate component being a derived type. */
5857 if ((class_ref && class_ref->u.c.component->ts.type == BT_DERIVED)
5858 || (!class_ref && st->n.sym->ts.type != BT_CLASS))
5859 {
5860 gfc_free_ref_list (new_ref);
5861 return resolve_compcall (e, NULL);
5862 }
5863
5864 c = gfc_find_component (declared, "_data", true, true);
5865 declared = c->ts.u.derived;
5866
5867 /* Treat the call as if it is a typebound procedure, in order to roll
5868 out the correct name for the specific function. */
5869 if (resolve_compcall (e, &name) == FAILURE)
5870 return FAILURE;
5871 ts = e->ts;
5872
5873 /* Then convert the expression to a procedure pointer component call. */
5874 e->value.function.esym = NULL;
5875 e->symtree = st;
5876
5877 if (new_ref)
5878 e->ref = new_ref;
5879
5880 /* '_vptr' points to the vtab, which contains the procedure pointers. */
5881 gfc_add_vptr_component (e);
5882 gfc_add_component_ref (e, name);
5883
5884 /* Recover the typespec for the expression. This is really only
5885 necessary for generic procedures, where the additional call
5886 to gfc_add_component_ref seems to throw the collection of the
5887 correct typespec. */
5888 e->ts = ts;
5889 return SUCCESS;
5890 }
5891
5892 /* Resolve a typebound subroutine, or 'method'. First separate all
5893 the non-CLASS references by calling resolve_typebound_call
5894 directly. */
5895
5896 static gfc_try
5897 resolve_typebound_subroutine (gfc_code *code)
5898 {
5899 gfc_symbol *declared;
5900 gfc_component *c;
5901 gfc_ref *new_ref;
5902 gfc_ref *class_ref;
5903 gfc_symtree *st;
5904 const char *name;
5905 gfc_typespec ts;
5906 gfc_expr *expr;
5907
5908 st = code->expr1->symtree;
5909
5910 /* Deal with typebound operators for CLASS objects. */
5911 expr = code->expr1->value.compcall.base_object;
5912 if (expr && expr->ts.type == BT_CLASS && code->expr1->value.compcall.name)
5913 {
5914 /* Since the typebound operators are generic, we have to ensure
5915 that any delays in resolution are corrected and that the vtab
5916 is present. */
5917 declared = expr->ts.u.derived;
5918 c = gfc_find_component (declared, "_vptr", true, true);
5919 if (c->ts.u.derived == NULL)
5920 c->ts.u.derived = gfc_find_derived_vtab (declared);
5921
5922 if (resolve_typebound_call (code, &name) == FAILURE)
5923 return FAILURE;
5924
5925 /* Use the generic name if it is there. */
5926 name = name ? name : code->expr1->value.function.esym->name;
5927 code->expr1->symtree = expr->symtree;
5928 code->expr1->ref = gfc_copy_ref (expr->ref);
5929 gfc_add_vptr_component (code->expr1);
5930 gfc_add_component_ref (code->expr1, name);
5931 code->expr1->value.function.esym = NULL;
5932 return SUCCESS;
5933 }
5934
5935 if (st == NULL)
5936 return resolve_typebound_call (code, NULL);
5937
5938 if (resolve_ref (code->expr1) == FAILURE)
5939 return FAILURE;
5940
5941 /* Get the CLASS declared type. */
5942 get_declared_from_expr (&class_ref, &new_ref, code->expr1);
5943
5944 /* Weed out cases of the ultimate component being a derived type. */
5945 if ((class_ref && class_ref->u.c.component->ts.type == BT_DERIVED)
5946 || (!class_ref && st->n.sym->ts.type != BT_CLASS))
5947 {
5948 gfc_free_ref_list (new_ref);
5949 return resolve_typebound_call (code, NULL);
5950 }
5951
5952 if (resolve_typebound_call (code, &name) == FAILURE)
5953 return FAILURE;
5954 ts = code->expr1->ts;
5955
5956 /* Then convert the expression to a procedure pointer component call. */
5957 code->expr1->value.function.esym = NULL;
5958 code->expr1->symtree = st;
5959
5960 if (new_ref)
5961 code->expr1->ref = new_ref;
5962
5963 /* '_vptr' points to the vtab, which contains the procedure pointers. */
5964 gfc_add_vptr_component (code->expr1);
5965 gfc_add_component_ref (code->expr1, name);
5966
5967 /* Recover the typespec for the expression. This is really only
5968 necessary for generic procedures, where the additional call
5969 to gfc_add_component_ref seems to throw the collection of the
5970 correct typespec. */
5971 code->expr1->ts = ts;
5972 return SUCCESS;
5973 }
5974
5975
5976 /* Resolve a CALL to a Procedure Pointer Component (Subroutine). */
5977
5978 static gfc_try
5979 resolve_ppc_call (gfc_code* c)
5980 {
5981 gfc_component *comp;
5982 bool b;
5983
5984 b = gfc_is_proc_ptr_comp (c->expr1, &comp);
5985 gcc_assert (b);
5986
5987 c->resolved_sym = c->expr1->symtree->n.sym;
5988 c->expr1->expr_type = EXPR_VARIABLE;
5989
5990 if (!comp->attr.subroutine)
5991 gfc_add_subroutine (&comp->attr, comp->name, &c->expr1->where);
5992
5993 if (resolve_ref (c->expr1) == FAILURE)
5994 return FAILURE;
5995
5996 if (update_ppc_arglist (c->expr1) == FAILURE)
5997 return FAILURE;
5998
5999 c->ext.actual = c->expr1->value.compcall.actual;
6000
6001 if (resolve_actual_arglist (c->ext.actual, comp->attr.proc,
6002 comp->formal == NULL) == FAILURE)
6003 return FAILURE;
6004
6005 gfc_ppc_use (comp, &c->expr1->value.compcall.actual, &c->expr1->where);
6006
6007 return SUCCESS;
6008 }
6009
6010
6011 /* Resolve a Function Call to a Procedure Pointer Component (Function). */
6012
6013 static gfc_try
6014 resolve_expr_ppc (gfc_expr* e)
6015 {
6016 gfc_component *comp;
6017 bool b;
6018
6019 b = gfc_is_proc_ptr_comp (e, &comp);
6020 gcc_assert (b);
6021
6022 /* Convert to EXPR_FUNCTION. */
6023 e->expr_type = EXPR_FUNCTION;
6024 e->value.function.isym = NULL;
6025 e->value.function.actual = e->value.compcall.actual;
6026 e->ts = comp->ts;
6027 if (comp->as != NULL)
6028 e->rank = comp->as->rank;
6029
6030 if (!comp->attr.function)
6031 gfc_add_function (&comp->attr, comp->name, &e->where);
6032
6033 if (resolve_ref (e) == FAILURE)
6034 return FAILURE;
6035
6036 if (resolve_actual_arglist (e->value.function.actual, comp->attr.proc,
6037 comp->formal == NULL) == FAILURE)
6038 return FAILURE;
6039
6040 if (update_ppc_arglist (e) == FAILURE)
6041 return FAILURE;
6042
6043 gfc_ppc_use (comp, &e->value.compcall.actual, &e->where);
6044
6045 return SUCCESS;
6046 }
6047
6048
6049 static bool
6050 gfc_is_expandable_expr (gfc_expr *e)
6051 {
6052 gfc_constructor *con;
6053
6054 if (e->expr_type == EXPR_ARRAY)
6055 {
6056 /* Traverse the constructor looking for variables that are flavor
6057 parameter. Parameters must be expanded since they are fully used at
6058 compile time. */
6059 con = gfc_constructor_first (e->value.constructor);
6060 for (; con; con = gfc_constructor_next (con))
6061 {
6062 if (con->expr->expr_type == EXPR_VARIABLE
6063 && con->expr->symtree
6064 && (con->expr->symtree->n.sym->attr.flavor == FL_PARAMETER
6065 || con->expr->symtree->n.sym->attr.flavor == FL_VARIABLE))
6066 return true;
6067 if (con->expr->expr_type == EXPR_ARRAY
6068 && gfc_is_expandable_expr (con->expr))
6069 return true;
6070 }
6071 }
6072
6073 return false;
6074 }
6075
6076 /* Resolve an expression. That is, make sure that types of operands agree
6077 with their operators, intrinsic operators are converted to function calls
6078 for overloaded types and unresolved function references are resolved. */
6079
6080 gfc_try
6081 gfc_resolve_expr (gfc_expr *e)
6082 {
6083 gfc_try t;
6084 bool inquiry_save;
6085
6086 if (e == NULL)
6087 return SUCCESS;
6088
6089 /* inquiry_argument only applies to variables. */
6090 inquiry_save = inquiry_argument;
6091 if (e->expr_type != EXPR_VARIABLE)
6092 inquiry_argument = false;
6093
6094 switch (e->expr_type)
6095 {
6096 case EXPR_OP:
6097 t = resolve_operator (e);
6098 break;
6099
6100 case EXPR_FUNCTION:
6101 case EXPR_VARIABLE:
6102
6103 if (check_host_association (e))
6104 t = resolve_function (e);
6105 else
6106 {
6107 t = resolve_variable (e);
6108 if (t == SUCCESS)
6109 expression_rank (e);
6110 }
6111
6112 if (e->ts.type == BT_CHARACTER && e->ts.u.cl == NULL && e->ref
6113 && e->ref->type != REF_SUBSTRING)
6114 gfc_resolve_substring_charlen (e);
6115
6116 break;
6117
6118 case EXPR_COMPCALL:
6119 t = resolve_typebound_function (e);
6120 break;
6121
6122 case EXPR_SUBSTRING:
6123 t = resolve_ref (e);
6124 break;
6125
6126 case EXPR_CONSTANT:
6127 case EXPR_NULL:
6128 t = SUCCESS;
6129 break;
6130
6131 case EXPR_PPC:
6132 t = resolve_expr_ppc (e);
6133 break;
6134
6135 case EXPR_ARRAY:
6136 t = FAILURE;
6137 if (resolve_ref (e) == FAILURE)
6138 break;
6139
6140 t = gfc_resolve_array_constructor (e);
6141 /* Also try to expand a constructor. */
6142 if (t == SUCCESS)
6143 {
6144 expression_rank (e);
6145 if (gfc_is_constant_expr (e) || gfc_is_expandable_expr (e))
6146 gfc_expand_constructor (e, false);
6147 }
6148
6149 /* This provides the opportunity for the length of constructors with
6150 character valued function elements to propagate the string length
6151 to the expression. */
6152 if (t == SUCCESS && e->ts.type == BT_CHARACTER)
6153 {
6154 /* For efficiency, we call gfc_expand_constructor for BT_CHARACTER
6155 here rather then add a duplicate test for it above. */
6156 gfc_expand_constructor (e, false);
6157 t = gfc_resolve_character_array_constructor (e);
6158 }
6159
6160 break;
6161
6162 case EXPR_STRUCTURE:
6163 t = resolve_ref (e);
6164 if (t == FAILURE)
6165 break;
6166
6167 t = resolve_structure_cons (e, 0);
6168 if (t == FAILURE)
6169 break;
6170
6171 t = gfc_simplify_expr (e, 0);
6172 break;
6173
6174 default:
6175 gfc_internal_error ("gfc_resolve_expr(): Bad expression type");
6176 }
6177
6178 if (e->ts.type == BT_CHARACTER && t == SUCCESS && !e->ts.u.cl)
6179 fixup_charlen (e);
6180
6181 inquiry_argument = inquiry_save;
6182
6183 return t;
6184 }
6185
6186
6187 /* Resolve an expression from an iterator. They must be scalar and have
6188 INTEGER or (optionally) REAL type. */
6189
6190 static gfc_try
6191 gfc_resolve_iterator_expr (gfc_expr *expr, bool real_ok,
6192 const char *name_msgid)
6193 {
6194 if (gfc_resolve_expr (expr) == FAILURE)
6195 return FAILURE;
6196
6197 if (expr->rank != 0)
6198 {
6199 gfc_error ("%s at %L must be a scalar", _(name_msgid), &expr->where);
6200 return FAILURE;
6201 }
6202
6203 if (expr->ts.type != BT_INTEGER)
6204 {
6205 if (expr->ts.type == BT_REAL)
6206 {
6207 if (real_ok)
6208 return gfc_notify_std (GFC_STD_F95_DEL,
6209 "Deleted feature: %s at %L must be integer",
6210 _(name_msgid), &expr->where);
6211 else
6212 {
6213 gfc_error ("%s at %L must be INTEGER", _(name_msgid),
6214 &expr->where);
6215 return FAILURE;
6216 }
6217 }
6218 else
6219 {
6220 gfc_error ("%s at %L must be INTEGER", _(name_msgid), &expr->where);
6221 return FAILURE;
6222 }
6223 }
6224 return SUCCESS;
6225 }
6226
6227
6228 /* Resolve the expressions in an iterator structure. If REAL_OK is
6229 false allow only INTEGER type iterators, otherwise allow REAL types. */
6230
6231 gfc_try
6232 gfc_resolve_iterator (gfc_iterator *iter, bool real_ok)
6233 {
6234 if (gfc_resolve_iterator_expr (iter->var, real_ok, "Loop variable")
6235 == FAILURE)
6236 return FAILURE;
6237
6238 if (gfc_check_vardef_context (iter->var, false, false, _("iterator variable"))
6239 == FAILURE)
6240 return FAILURE;
6241
6242 if (gfc_resolve_iterator_expr (iter->start, real_ok,
6243 "Start expression in DO loop") == FAILURE)
6244 return FAILURE;
6245
6246 if (gfc_resolve_iterator_expr (iter->end, real_ok,
6247 "End expression in DO loop") == FAILURE)
6248 return FAILURE;
6249
6250 if (gfc_resolve_iterator_expr (iter->step, real_ok,
6251 "Step expression in DO loop") == FAILURE)
6252 return FAILURE;
6253
6254 if (iter->step->expr_type == EXPR_CONSTANT)
6255 {
6256 if ((iter->step->ts.type == BT_INTEGER
6257 && mpz_cmp_ui (iter->step->value.integer, 0) == 0)
6258 || (iter->step->ts.type == BT_REAL
6259 && mpfr_sgn (iter->step->value.real) == 0))
6260 {
6261 gfc_error ("Step expression in DO loop at %L cannot be zero",
6262 &iter->step->where);
6263 return FAILURE;
6264 }
6265 }
6266
6267 /* Convert start, end, and step to the same type as var. */
6268 if (iter->start->ts.kind != iter->var->ts.kind
6269 || iter->start->ts.type != iter->var->ts.type)
6270 gfc_convert_type (iter->start, &iter->var->ts, 2);
6271
6272 if (iter->end->ts.kind != iter->var->ts.kind
6273 || iter->end->ts.type != iter->var->ts.type)
6274 gfc_convert_type (iter->end, &iter->var->ts, 2);
6275
6276 if (iter->step->ts.kind != iter->var->ts.kind
6277 || iter->step->ts.type != iter->var->ts.type)
6278 gfc_convert_type (iter->step, &iter->var->ts, 2);
6279
6280 if (iter->start->expr_type == EXPR_CONSTANT
6281 && iter->end->expr_type == EXPR_CONSTANT
6282 && iter->step->expr_type == EXPR_CONSTANT)
6283 {
6284 int sgn, cmp;
6285 if (iter->start->ts.type == BT_INTEGER)
6286 {
6287 sgn = mpz_cmp_ui (iter->step->value.integer, 0);
6288 cmp = mpz_cmp (iter->end->value.integer, iter->start->value.integer);
6289 }
6290 else
6291 {
6292 sgn = mpfr_sgn (iter->step->value.real);
6293 cmp = mpfr_cmp (iter->end->value.real, iter->start->value.real);
6294 }
6295 if ((sgn > 0 && cmp < 0) || (sgn < 0 && cmp > 0))
6296 gfc_warning ("DO loop at %L will be executed zero times",
6297 &iter->step->where);
6298 }
6299
6300 return SUCCESS;
6301 }
6302
6303
6304 /* Traversal function for find_forall_index. f == 2 signals that
6305 that variable itself is not to be checked - only the references. */
6306
6307 static bool
6308 forall_index (gfc_expr *expr, gfc_symbol *sym, int *f)
6309 {
6310 if (expr->expr_type != EXPR_VARIABLE)
6311 return false;
6312
6313 /* A scalar assignment */
6314 if (!expr->ref || *f == 1)
6315 {
6316 if (expr->symtree->n.sym == sym)
6317 return true;
6318 else
6319 return false;
6320 }
6321
6322 if (*f == 2)
6323 *f = 1;
6324 return false;
6325 }
6326
6327
6328 /* Check whether the FORALL index appears in the expression or not.
6329 Returns SUCCESS if SYM is found in EXPR. */
6330
6331 gfc_try
6332 find_forall_index (gfc_expr *expr, gfc_symbol *sym, int f)
6333 {
6334 if (gfc_traverse_expr (expr, sym, forall_index, f))
6335 return SUCCESS;
6336 else
6337 return FAILURE;
6338 }
6339
6340
6341 /* Resolve a list of FORALL iterators. The FORALL index-name is constrained
6342 to be a scalar INTEGER variable. The subscripts and stride are scalar
6343 INTEGERs, and if stride is a constant it must be nonzero.
6344 Furthermore "A subscript or stride in a forall-triplet-spec shall
6345 not contain a reference to any index-name in the
6346 forall-triplet-spec-list in which it appears." (7.5.4.1) */
6347
6348 static void
6349 resolve_forall_iterators (gfc_forall_iterator *it)
6350 {
6351 gfc_forall_iterator *iter, *iter2;
6352
6353 for (iter = it; iter; iter = iter->next)
6354 {
6355 if (gfc_resolve_expr (iter->var) == SUCCESS
6356 && (iter->var->ts.type != BT_INTEGER || iter->var->rank != 0))
6357 gfc_error ("FORALL index-name at %L must be a scalar INTEGER",
6358 &iter->var->where);
6359
6360 if (gfc_resolve_expr (iter->start) == SUCCESS
6361 && (iter->start->ts.type != BT_INTEGER || iter->start->rank != 0))
6362 gfc_error ("FORALL start expression at %L must be a scalar INTEGER",
6363 &iter->start->where);
6364 if (iter->var->ts.kind != iter->start->ts.kind)
6365 gfc_convert_type (iter->start, &iter->var->ts, 2);
6366
6367 if (gfc_resolve_expr (iter->end) == SUCCESS
6368 && (iter->end->ts.type != BT_INTEGER || iter->end->rank != 0))
6369 gfc_error ("FORALL end expression at %L must be a scalar INTEGER",
6370 &iter->end->where);
6371 if (iter->var->ts.kind != iter->end->ts.kind)
6372 gfc_convert_type (iter->end, &iter->var->ts, 2);
6373
6374 if (gfc_resolve_expr (iter->stride) == SUCCESS)
6375 {
6376 if (iter->stride->ts.type != BT_INTEGER || iter->stride->rank != 0)
6377 gfc_error ("FORALL stride expression at %L must be a scalar %s",
6378 &iter->stride->where, "INTEGER");
6379
6380 if (iter->stride->expr_type == EXPR_CONSTANT
6381 && mpz_cmp_ui(iter->stride->value.integer, 0) == 0)
6382 gfc_error ("FORALL stride expression at %L cannot be zero",
6383 &iter->stride->where);
6384 }
6385 if (iter->var->ts.kind != iter->stride->ts.kind)
6386 gfc_convert_type (iter->stride, &iter->var->ts, 2);
6387 }
6388
6389 for (iter = it; iter; iter = iter->next)
6390 for (iter2 = iter; iter2; iter2 = iter2->next)
6391 {
6392 if (find_forall_index (iter2->start,
6393 iter->var->symtree->n.sym, 0) == SUCCESS
6394 || find_forall_index (iter2->end,
6395 iter->var->symtree->n.sym, 0) == SUCCESS
6396 || find_forall_index (iter2->stride,
6397 iter->var->symtree->n.sym, 0) == SUCCESS)
6398 gfc_error ("FORALL index '%s' may not appear in triplet "
6399 "specification at %L", iter->var->symtree->name,
6400 &iter2->start->where);
6401 }
6402 }
6403
6404
6405 /* Given a pointer to a symbol that is a derived type, see if it's
6406 inaccessible, i.e. if it's defined in another module and the components are
6407 PRIVATE. The search is recursive if necessary. Returns zero if no
6408 inaccessible components are found, nonzero otherwise. */
6409
6410 static int
6411 derived_inaccessible (gfc_symbol *sym)
6412 {
6413 gfc_component *c;
6414
6415 if (sym->attr.use_assoc && sym->attr.private_comp)
6416 return 1;
6417
6418 for (c = sym->components; c; c = c->next)
6419 {
6420 if (c->ts.type == BT_DERIVED && derived_inaccessible (c->ts.u.derived))
6421 return 1;
6422 }
6423
6424 return 0;
6425 }
6426
6427
6428 /* Resolve the argument of a deallocate expression. The expression must be
6429 a pointer or a full array. */
6430
6431 static gfc_try
6432 resolve_deallocate_expr (gfc_expr *e)
6433 {
6434 symbol_attribute attr;
6435 int allocatable, pointer;
6436 gfc_ref *ref;
6437 gfc_symbol *sym;
6438 gfc_component *c;
6439
6440 if (gfc_resolve_expr (e) == FAILURE)
6441 return FAILURE;
6442
6443 if (e->expr_type != EXPR_VARIABLE)
6444 goto bad;
6445
6446 sym = e->symtree->n.sym;
6447
6448 if (sym->ts.type == BT_CLASS)
6449 {
6450 allocatable = CLASS_DATA (sym)->attr.allocatable;
6451 pointer = CLASS_DATA (sym)->attr.class_pointer;
6452 }
6453 else
6454 {
6455 allocatable = sym->attr.allocatable;
6456 pointer = sym->attr.pointer;
6457 }
6458 for (ref = e->ref; ref; ref = ref->next)
6459 {
6460 switch (ref->type)
6461 {
6462 case REF_ARRAY:
6463 if (ref->u.ar.type != AR_FULL)
6464 allocatable = 0;
6465 break;
6466
6467 case REF_COMPONENT:
6468 c = ref->u.c.component;
6469 if (c->ts.type == BT_CLASS)
6470 {
6471 allocatable = CLASS_DATA (c)->attr.allocatable;
6472 pointer = CLASS_DATA (c)->attr.class_pointer;
6473 }
6474 else
6475 {
6476 allocatable = c->attr.allocatable;
6477 pointer = c->attr.pointer;
6478 }
6479 break;
6480
6481 case REF_SUBSTRING:
6482 allocatable = 0;
6483 break;
6484 }
6485 }
6486
6487 attr = gfc_expr_attr (e);
6488
6489 if (allocatable == 0 && attr.pointer == 0)
6490 {
6491 bad:
6492 gfc_error ("Allocate-object at %L must be ALLOCATABLE or a POINTER",
6493 &e->where);
6494 return FAILURE;
6495 }
6496
6497 /* F2008, C644. */
6498 if (gfc_is_coindexed (e))
6499 {
6500 gfc_error ("Coindexed allocatable object at %L", &e->where);
6501 return FAILURE;
6502 }
6503
6504 if (pointer
6505 && gfc_check_vardef_context (e, true, true, _("DEALLOCATE object"))
6506 == FAILURE)
6507 return FAILURE;
6508 if (gfc_check_vardef_context (e, false, true, _("DEALLOCATE object"))
6509 == FAILURE)
6510 return FAILURE;
6511
6512 return SUCCESS;
6513 }
6514
6515
6516 /* Returns true if the expression e contains a reference to the symbol sym. */
6517 static bool
6518 sym_in_expr (gfc_expr *e, gfc_symbol *sym, int *f ATTRIBUTE_UNUSED)
6519 {
6520 if (e->expr_type == EXPR_VARIABLE && e->symtree->n.sym == sym)
6521 return true;
6522
6523 return false;
6524 }
6525
6526 bool
6527 gfc_find_sym_in_expr (gfc_symbol *sym, gfc_expr *e)
6528 {
6529 return gfc_traverse_expr (e, sym, sym_in_expr, 0);
6530 }
6531
6532
6533 /* Given the expression node e for an allocatable/pointer of derived type to be
6534 allocated, get the expression node to be initialized afterwards (needed for
6535 derived types with default initializers, and derived types with allocatable
6536 components that need nullification.) */
6537
6538 gfc_expr *
6539 gfc_expr_to_initialize (gfc_expr *e)
6540 {
6541 gfc_expr *result;
6542 gfc_ref *ref;
6543 int i;
6544
6545 result = gfc_copy_expr (e);
6546
6547 /* Change the last array reference from AR_ELEMENT to AR_FULL. */
6548 for (ref = result->ref; ref; ref = ref->next)
6549 if (ref->type == REF_ARRAY && ref->next == NULL)
6550 {
6551 ref->u.ar.type = AR_FULL;
6552
6553 for (i = 0; i < ref->u.ar.dimen; i++)
6554 ref->u.ar.start[i] = ref->u.ar.end[i] = ref->u.ar.stride[i] = NULL;
6555
6556 result->rank = ref->u.ar.dimen;
6557 break;
6558 }
6559
6560 return result;
6561 }
6562
6563
6564 /* If the last ref of an expression is an array ref, return a copy of the
6565 expression with that one removed. Otherwise, a copy of the original
6566 expression. This is used for allocate-expressions and pointer assignment
6567 LHS, where there may be an array specification that needs to be stripped
6568 off when using gfc_check_vardef_context. */
6569
6570 static gfc_expr*
6571 remove_last_array_ref (gfc_expr* e)
6572 {
6573 gfc_expr* e2;
6574 gfc_ref** r;
6575
6576 e2 = gfc_copy_expr (e);
6577 for (r = &e2->ref; *r; r = &(*r)->next)
6578 if ((*r)->type == REF_ARRAY && !(*r)->next)
6579 {
6580 gfc_free_ref_list (*r);
6581 *r = NULL;
6582 break;
6583 }
6584
6585 return e2;
6586 }
6587
6588
6589 /* Used in resolve_allocate_expr to check that a allocation-object and
6590 a source-expr are conformable. This does not catch all possible
6591 cases; in particular a runtime checking is needed. */
6592
6593 static gfc_try
6594 conformable_arrays (gfc_expr *e1, gfc_expr *e2)
6595 {
6596 gfc_ref *tail;
6597 for (tail = e2->ref; tail && tail->next; tail = tail->next);
6598
6599 /* First compare rank. */
6600 if (tail && e1->rank != tail->u.ar.as->rank)
6601 {
6602 gfc_error ("Source-expr at %L must be scalar or have the "
6603 "same rank as the allocate-object at %L",
6604 &e1->where, &e2->where);
6605 return FAILURE;
6606 }
6607
6608 if (e1->shape)
6609 {
6610 int i;
6611 mpz_t s;
6612
6613 mpz_init (s);
6614
6615 for (i = 0; i < e1->rank; i++)
6616 {
6617 if (tail->u.ar.end[i])
6618 {
6619 mpz_set (s, tail->u.ar.end[i]->value.integer);
6620 mpz_sub (s, s, tail->u.ar.start[i]->value.integer);
6621 mpz_add_ui (s, s, 1);
6622 }
6623 else
6624 {
6625 mpz_set (s, tail->u.ar.start[i]->value.integer);
6626 }
6627
6628 if (mpz_cmp (e1->shape[i], s) != 0)
6629 {
6630 gfc_error ("Source-expr at %L and allocate-object at %L must "
6631 "have the same shape", &e1->where, &e2->where);
6632 mpz_clear (s);
6633 return FAILURE;
6634 }
6635 }
6636
6637 mpz_clear (s);
6638 }
6639
6640 return SUCCESS;
6641 }
6642
6643
6644 /* Resolve the expression in an ALLOCATE statement, doing the additional
6645 checks to see whether the expression is OK or not. The expression must
6646 have a trailing array reference that gives the size of the array. */
6647
6648 static gfc_try
6649 resolve_allocate_expr (gfc_expr *e, gfc_code *code)
6650 {
6651 int i, pointer, allocatable, dimension, is_abstract;
6652 int codimension;
6653 bool coindexed;
6654 symbol_attribute attr;
6655 gfc_ref *ref, *ref2;
6656 gfc_expr *e2;
6657 gfc_array_ref *ar;
6658 gfc_symbol *sym = NULL;
6659 gfc_alloc *a;
6660 gfc_component *c;
6661 gfc_try t;
6662
6663 /* Mark the ultimost array component as being in allocate to allow DIMEN_STAR
6664 checking of coarrays. */
6665 for (ref = e->ref; ref; ref = ref->next)
6666 if (ref->next == NULL)
6667 break;
6668
6669 if (ref && ref->type == REF_ARRAY)
6670 ref->u.ar.in_allocate = true;
6671
6672 if (gfc_resolve_expr (e) == FAILURE)
6673 goto failure;
6674
6675 /* Make sure the expression is allocatable or a pointer. If it is
6676 pointer, the next-to-last reference must be a pointer. */
6677
6678 ref2 = NULL;
6679 if (e->symtree)
6680 sym = e->symtree->n.sym;
6681
6682 /* Check whether ultimate component is abstract and CLASS. */
6683 is_abstract = 0;
6684
6685 if (e->expr_type != EXPR_VARIABLE)
6686 {
6687 allocatable = 0;
6688 attr = gfc_expr_attr (e);
6689 pointer = attr.pointer;
6690 dimension = attr.dimension;
6691 codimension = attr.codimension;
6692 }
6693 else
6694 {
6695 if (sym->ts.type == BT_CLASS)
6696 {
6697 allocatable = CLASS_DATA (sym)->attr.allocatable;
6698 pointer = CLASS_DATA (sym)->attr.class_pointer;
6699 dimension = CLASS_DATA (sym)->attr.dimension;
6700 codimension = CLASS_DATA (sym)->attr.codimension;
6701 is_abstract = CLASS_DATA (sym)->attr.abstract;
6702 }
6703 else
6704 {
6705 allocatable = sym->attr.allocatable;
6706 pointer = sym->attr.pointer;
6707 dimension = sym->attr.dimension;
6708 codimension = sym->attr.codimension;
6709 }
6710
6711 coindexed = false;
6712
6713 for (ref = e->ref; ref; ref2 = ref, ref = ref->next)
6714 {
6715 switch (ref->type)
6716 {
6717 case REF_ARRAY:
6718 if (ref->u.ar.codimen > 0)
6719 {
6720 int n;
6721 for (n = ref->u.ar.dimen;
6722 n < ref->u.ar.dimen + ref->u.ar.codimen; n++)
6723 if (ref->u.ar.dimen_type[n] != DIMEN_THIS_IMAGE)
6724 {
6725 coindexed = true;
6726 break;
6727 }
6728 }
6729
6730 if (ref->next != NULL)
6731 pointer = 0;
6732 break;
6733
6734 case REF_COMPONENT:
6735 /* F2008, C644. */
6736 if (coindexed)
6737 {
6738 gfc_error ("Coindexed allocatable object at %L",
6739 &e->where);
6740 goto failure;
6741 }
6742
6743 c = ref->u.c.component;
6744 if (c->ts.type == BT_CLASS)
6745 {
6746 allocatable = CLASS_DATA (c)->attr.allocatable;
6747 pointer = CLASS_DATA (c)->attr.class_pointer;
6748 dimension = CLASS_DATA (c)->attr.dimension;
6749 codimension = CLASS_DATA (c)->attr.codimension;
6750 is_abstract = CLASS_DATA (c)->attr.abstract;
6751 }
6752 else
6753 {
6754 allocatable = c->attr.allocatable;
6755 pointer = c->attr.pointer;
6756 dimension = c->attr.dimension;
6757 codimension = c->attr.codimension;
6758 is_abstract = c->attr.abstract;
6759 }
6760 break;
6761
6762 case REF_SUBSTRING:
6763 allocatable = 0;
6764 pointer = 0;
6765 break;
6766 }
6767 }
6768 }
6769
6770 if (allocatable == 0 && pointer == 0)
6771 {
6772 gfc_error ("Allocate-object at %L must be ALLOCATABLE or a POINTER",
6773 &e->where);
6774 goto failure;
6775 }
6776
6777 /* Some checks for the SOURCE tag. */
6778 if (code->expr3)
6779 {
6780 /* Check F03:C631. */
6781 if (!gfc_type_compatible (&e->ts, &code->expr3->ts))
6782 {
6783 gfc_error ("Type of entity at %L is type incompatible with "
6784 "source-expr at %L", &e->where, &code->expr3->where);
6785 goto failure;
6786 }
6787
6788 /* Check F03:C632 and restriction following Note 6.18. */
6789 if (code->expr3->rank > 0
6790 && conformable_arrays (code->expr3, e) == FAILURE)
6791 goto failure;
6792
6793 /* Check F03:C633. */
6794 if (code->expr3->ts.kind != e->ts.kind)
6795 {
6796 gfc_error ("The allocate-object at %L and the source-expr at %L "
6797 "shall have the same kind type parameter",
6798 &e->where, &code->expr3->where);
6799 goto failure;
6800 }
6801
6802 /* Check F2008, C642. */
6803 if (code->expr3->ts.type == BT_DERIVED
6804 && ((codimension && gfc_expr_attr (code->expr3).lock_comp)
6805 || (code->expr3->ts.u.derived->from_intmod
6806 == INTMOD_ISO_FORTRAN_ENV
6807 && code->expr3->ts.u.derived->intmod_sym_id
6808 == ISOFORTRAN_LOCK_TYPE)))
6809 {
6810 gfc_error ("The source-expr at %L shall neither be of type "
6811 "LOCK_TYPE nor have a LOCK_TYPE component if "
6812 "allocate-object at %L is a coarray",
6813 &code->expr3->where, &e->where);
6814 goto failure;
6815 }
6816 }
6817
6818 /* Check F08:C629. */
6819 if (is_abstract && code->ext.alloc.ts.type == BT_UNKNOWN
6820 && !code->expr3)
6821 {
6822 gcc_assert (e->ts.type == BT_CLASS);
6823 gfc_error ("Allocating %s of ABSTRACT base type at %L requires a "
6824 "type-spec or source-expr", sym->name, &e->where);
6825 goto failure;
6826 }
6827
6828 /* In the variable definition context checks, gfc_expr_attr is used
6829 on the expression. This is fooled by the array specification
6830 present in e, thus we have to eliminate that one temporarily. */
6831 e2 = remove_last_array_ref (e);
6832 t = SUCCESS;
6833 if (t == SUCCESS && pointer)
6834 t = gfc_check_vardef_context (e2, true, true, _("ALLOCATE object"));
6835 if (t == SUCCESS)
6836 t = gfc_check_vardef_context (e2, false, true, _("ALLOCATE object"));
6837 gfc_free_expr (e2);
6838 if (t == FAILURE)
6839 goto failure;
6840
6841 if (!code->expr3)
6842 {
6843 /* Set up default initializer if needed. */
6844 gfc_typespec ts;
6845 gfc_expr *init_e;
6846
6847 if (code->ext.alloc.ts.type == BT_DERIVED)
6848 ts = code->ext.alloc.ts;
6849 else
6850 ts = e->ts;
6851
6852 if (ts.type == BT_CLASS)
6853 ts = ts.u.derived->components->ts;
6854
6855 if (ts.type == BT_DERIVED && (init_e = gfc_default_initializer (&ts)))
6856 {
6857 gfc_code *init_st = gfc_get_code ();
6858 init_st->loc = code->loc;
6859 init_st->op = EXEC_INIT_ASSIGN;
6860 init_st->expr1 = gfc_expr_to_initialize (e);
6861 init_st->expr2 = init_e;
6862 init_st->next = code->next;
6863 code->next = init_st;
6864 }
6865 }
6866 else if (code->expr3->mold && code->expr3->ts.type == BT_DERIVED)
6867 {
6868 /* Default initialization via MOLD (non-polymorphic). */
6869 gfc_expr *rhs = gfc_default_initializer (&code->expr3->ts);
6870 gfc_resolve_expr (rhs);
6871 gfc_free_expr (code->expr3);
6872 code->expr3 = rhs;
6873 }
6874
6875 if (e->ts.type == BT_CLASS)
6876 {
6877 /* Make sure the vtab symbol is present when
6878 the module variables are generated. */
6879 gfc_typespec ts = e->ts;
6880 if (code->expr3)
6881 ts = code->expr3->ts;
6882 else if (code->ext.alloc.ts.type == BT_DERIVED)
6883 ts = code->ext.alloc.ts;
6884 gfc_find_derived_vtab (ts.u.derived);
6885 }
6886
6887 if (pointer || (dimension == 0 && codimension == 0))
6888 goto success;
6889
6890 /* Make sure the last reference node is an array specifiction. */
6891
6892 if (!ref2 || ref2->type != REF_ARRAY || ref2->u.ar.type == AR_FULL
6893 || (dimension && ref2->u.ar.dimen == 0))
6894 {
6895 gfc_error ("Array specification required in ALLOCATE statement "
6896 "at %L", &e->where);
6897 goto failure;
6898 }
6899
6900 /* Make sure that the array section reference makes sense in the
6901 context of an ALLOCATE specification. */
6902
6903 ar = &ref2->u.ar;
6904
6905 if (codimension)
6906 for (i = ar->dimen; i < ar->dimen + ar->codimen; i++)
6907 if (ar->dimen_type[i] == DIMEN_THIS_IMAGE)
6908 {
6909 gfc_error ("Coarray specification required in ALLOCATE statement "
6910 "at %L", &e->where);
6911 goto failure;
6912 }
6913
6914 for (i = 0; i < ar->dimen; i++)
6915 {
6916 if (ref2->u.ar.type == AR_ELEMENT)
6917 goto check_symbols;
6918
6919 switch (ar->dimen_type[i])
6920 {
6921 case DIMEN_ELEMENT:
6922 break;
6923
6924 case DIMEN_RANGE:
6925 if (ar->start[i] != NULL
6926 && ar->end[i] != NULL
6927 && ar->stride[i] == NULL)
6928 break;
6929
6930 /* Fall Through... */
6931
6932 case DIMEN_UNKNOWN:
6933 case DIMEN_VECTOR:
6934 case DIMEN_STAR:
6935 case DIMEN_THIS_IMAGE:
6936 gfc_error ("Bad array specification in ALLOCATE statement at %L",
6937 &e->where);
6938 goto failure;
6939 }
6940
6941 check_symbols:
6942 for (a = code->ext.alloc.list; a; a = a->next)
6943 {
6944 sym = a->expr->symtree->n.sym;
6945
6946 /* TODO - check derived type components. */
6947 if (sym->ts.type == BT_DERIVED || sym->ts.type == BT_CLASS)
6948 continue;
6949
6950 if ((ar->start[i] != NULL
6951 && gfc_find_sym_in_expr (sym, ar->start[i]))
6952 || (ar->end[i] != NULL
6953 && gfc_find_sym_in_expr (sym, ar->end[i])))
6954 {
6955 gfc_error ("'%s' must not appear in the array specification at "
6956 "%L in the same ALLOCATE statement where it is "
6957 "itself allocated", sym->name, &ar->where);
6958 goto failure;
6959 }
6960 }
6961 }
6962
6963 for (i = ar->dimen; i < ar->codimen + ar->dimen; i++)
6964 {
6965 if (ar->dimen_type[i] == DIMEN_ELEMENT
6966 || ar->dimen_type[i] == DIMEN_RANGE)
6967 {
6968 if (i == (ar->dimen + ar->codimen - 1))
6969 {
6970 gfc_error ("Expected '*' in coindex specification in ALLOCATE "
6971 "statement at %L", &e->where);
6972 goto failure;
6973 }
6974 break;
6975 }
6976
6977 if (ar->dimen_type[i] == DIMEN_STAR && i == (ar->dimen + ar->codimen - 1)
6978 && ar->stride[i] == NULL)
6979 break;
6980
6981 gfc_error ("Bad coarray specification in ALLOCATE statement at %L",
6982 &e->where);
6983 goto failure;
6984 }
6985
6986 if (codimension && ar->as->rank == 0)
6987 {
6988 gfc_error ("Sorry, allocatable scalar coarrays are not yet supported "
6989 "at %L", &e->where);
6990 goto failure;
6991 }
6992
6993 success:
6994 return SUCCESS;
6995
6996 failure:
6997 return FAILURE;
6998 }
6999
7000 static void
7001 resolve_allocate_deallocate (gfc_code *code, const char *fcn)
7002 {
7003 gfc_expr *stat, *errmsg, *pe, *qe;
7004 gfc_alloc *a, *p, *q;
7005
7006 stat = code->expr1;
7007 errmsg = code->expr2;
7008
7009 /* Check the stat variable. */
7010 if (stat)
7011 {
7012 gfc_check_vardef_context (stat, false, false, _("STAT variable"));
7013
7014 if ((stat->ts.type != BT_INTEGER
7015 && !(stat->ref && (stat->ref->type == REF_ARRAY
7016 || stat->ref->type == REF_COMPONENT)))
7017 || stat->rank > 0)
7018 gfc_error ("Stat-variable at %L must be a scalar INTEGER "
7019 "variable", &stat->where);
7020
7021 for (p = code->ext.alloc.list; p; p = p->next)
7022 if (p->expr->symtree->n.sym->name == stat->symtree->n.sym->name)
7023 {
7024 gfc_ref *ref1, *ref2;
7025 bool found = true;
7026
7027 for (ref1 = p->expr->ref, ref2 = stat->ref; ref1 && ref2;
7028 ref1 = ref1->next, ref2 = ref2->next)
7029 {
7030 if (ref1->type != REF_COMPONENT || ref2->type != REF_COMPONENT)
7031 continue;
7032 if (ref1->u.c.component->name != ref2->u.c.component->name)
7033 {
7034 found = false;
7035 break;
7036 }
7037 }
7038
7039 if (found)
7040 {
7041 gfc_error ("Stat-variable at %L shall not be %sd within "
7042 "the same %s statement", &stat->where, fcn, fcn);
7043 break;
7044 }
7045 }
7046 }
7047
7048 /* Check the errmsg variable. */
7049 if (errmsg)
7050 {
7051 if (!stat)
7052 gfc_warning ("ERRMSG at %L is useless without a STAT tag",
7053 &errmsg->where);
7054
7055 gfc_check_vardef_context (errmsg, false, false, _("ERRMSG variable"));
7056
7057 if ((errmsg->ts.type != BT_CHARACTER
7058 && !(errmsg->ref
7059 && (errmsg->ref->type == REF_ARRAY
7060 || errmsg->ref->type == REF_COMPONENT)))
7061 || errmsg->rank > 0 )
7062 gfc_error ("Errmsg-variable at %L must be a scalar CHARACTER "
7063 "variable", &errmsg->where);
7064
7065 for (p = code->ext.alloc.list; p; p = p->next)
7066 if (p->expr->symtree->n.sym->name == errmsg->symtree->n.sym->name)
7067 {
7068 gfc_ref *ref1, *ref2;
7069 bool found = true;
7070
7071 for (ref1 = p->expr->ref, ref2 = errmsg->ref; ref1 && ref2;
7072 ref1 = ref1->next, ref2 = ref2->next)
7073 {
7074 if (ref1->type != REF_COMPONENT || ref2->type != REF_COMPONENT)
7075 continue;
7076 if (ref1->u.c.component->name != ref2->u.c.component->name)
7077 {
7078 found = false;
7079 break;
7080 }
7081 }
7082
7083 if (found)
7084 {
7085 gfc_error ("Errmsg-variable at %L shall not be %sd within "
7086 "the same %s statement", &errmsg->where, fcn, fcn);
7087 break;
7088 }
7089 }
7090 }
7091
7092 /* Check that an allocate-object appears only once in the statement.
7093 FIXME: Checking derived types is disabled. */
7094 for (p = code->ext.alloc.list; p; p = p->next)
7095 {
7096 pe = p->expr;
7097 for (q = p->next; q; q = q->next)
7098 {
7099 qe = q->expr;
7100 if (pe->symtree->n.sym->name == qe->symtree->n.sym->name)
7101 {
7102 /* This is a potential collision. */
7103 gfc_ref *pr = pe->ref;
7104 gfc_ref *qr = qe->ref;
7105
7106 /* Follow the references until
7107 a) They start to differ, in which case there is no error;
7108 you can deallocate a%b and a%c in a single statement
7109 b) Both of them stop, which is an error
7110 c) One of them stops, which is also an error. */
7111 while (1)
7112 {
7113 if (pr == NULL && qr == NULL)
7114 {
7115 gfc_error ("Allocate-object at %L also appears at %L",
7116 &pe->where, &qe->where);
7117 break;
7118 }
7119 else if (pr != NULL && qr == NULL)
7120 {
7121 gfc_error ("Allocate-object at %L is subobject of"
7122 " object at %L", &pe->where, &qe->where);
7123 break;
7124 }
7125 else if (pr == NULL && qr != NULL)
7126 {
7127 gfc_error ("Allocate-object at %L is subobject of"
7128 " object at %L", &qe->where, &pe->where);
7129 break;
7130 }
7131 /* Here, pr != NULL && qr != NULL */
7132 gcc_assert(pr->type == qr->type);
7133 if (pr->type == REF_ARRAY)
7134 {
7135 /* Handle cases like allocate(v(3)%x(3), v(2)%x(3)),
7136 which are legal. */
7137 gcc_assert (qr->type == REF_ARRAY);
7138
7139 if (pr->next && qr->next)
7140 {
7141 gfc_array_ref *par = &(pr->u.ar);
7142 gfc_array_ref *qar = &(qr->u.ar);
7143 if (gfc_dep_compare_expr (par->start[0],
7144 qar->start[0]) != 0)
7145 break;
7146 }
7147 }
7148 else
7149 {
7150 if (pr->u.c.component->name != qr->u.c.component->name)
7151 break;
7152 }
7153
7154 pr = pr->next;
7155 qr = qr->next;
7156 }
7157 }
7158 }
7159 }
7160
7161 if (strcmp (fcn, "ALLOCATE") == 0)
7162 {
7163 for (a = code->ext.alloc.list; a; a = a->next)
7164 resolve_allocate_expr (a->expr, code);
7165 }
7166 else
7167 {
7168 for (a = code->ext.alloc.list; a; a = a->next)
7169 resolve_deallocate_expr (a->expr);
7170 }
7171 }
7172
7173
7174 /************ SELECT CASE resolution subroutines ************/
7175
7176 /* Callback function for our mergesort variant. Determines interval
7177 overlaps for CASEs. Return <0 if op1 < op2, 0 for overlap, >0 for
7178 op1 > op2. Assumes we're not dealing with the default case.
7179 We have op1 = (:L), (K:L) or (K:) and op2 = (:N), (M:N) or (M:).
7180 There are nine situations to check. */
7181
7182 static int
7183 compare_cases (const gfc_case *op1, const gfc_case *op2)
7184 {
7185 int retval;
7186
7187 if (op1->low == NULL) /* op1 = (:L) */
7188 {
7189 /* op2 = (:N), so overlap. */
7190 retval = 0;
7191 /* op2 = (M:) or (M:N), L < M */
7192 if (op2->low != NULL
7193 && gfc_compare_expr (op1->high, op2->low, INTRINSIC_LT) < 0)
7194 retval = -1;
7195 }
7196 else if (op1->high == NULL) /* op1 = (K:) */
7197 {
7198 /* op2 = (M:), so overlap. */
7199 retval = 0;
7200 /* op2 = (:N) or (M:N), K > N */
7201 if (op2->high != NULL
7202 && gfc_compare_expr (op1->low, op2->high, INTRINSIC_GT) > 0)
7203 retval = 1;
7204 }
7205 else /* op1 = (K:L) */
7206 {
7207 if (op2->low == NULL) /* op2 = (:N), K > N */
7208 retval = (gfc_compare_expr (op1->low, op2->high, INTRINSIC_GT) > 0)
7209 ? 1 : 0;
7210 else if (op2->high == NULL) /* op2 = (M:), L < M */
7211 retval = (gfc_compare_expr (op1->high, op2->low, INTRINSIC_LT) < 0)
7212 ? -1 : 0;
7213 else /* op2 = (M:N) */
7214 {
7215 retval = 0;
7216 /* L < M */
7217 if (gfc_compare_expr (op1->high, op2->low, INTRINSIC_LT) < 0)
7218 retval = -1;
7219 /* K > N */
7220 else if (gfc_compare_expr (op1->low, op2->high, INTRINSIC_GT) > 0)
7221 retval = 1;
7222 }
7223 }
7224
7225 return retval;
7226 }
7227
7228
7229 /* Merge-sort a double linked case list, detecting overlap in the
7230 process. LIST is the head of the double linked case list before it
7231 is sorted. Returns the head of the sorted list if we don't see any
7232 overlap, or NULL otherwise. */
7233
7234 static gfc_case *
7235 check_case_overlap (gfc_case *list)
7236 {
7237 gfc_case *p, *q, *e, *tail;
7238 int insize, nmerges, psize, qsize, cmp, overlap_seen;
7239
7240 /* If the passed list was empty, return immediately. */
7241 if (!list)
7242 return NULL;
7243
7244 overlap_seen = 0;
7245 insize = 1;
7246
7247 /* Loop unconditionally. The only exit from this loop is a return
7248 statement, when we've finished sorting the case list. */
7249 for (;;)
7250 {
7251 p = list;
7252 list = NULL;
7253 tail = NULL;
7254
7255 /* Count the number of merges we do in this pass. */
7256 nmerges = 0;
7257
7258 /* Loop while there exists a merge to be done. */
7259 while (p)
7260 {
7261 int i;
7262
7263 /* Count this merge. */
7264 nmerges++;
7265
7266 /* Cut the list in two pieces by stepping INSIZE places
7267 forward in the list, starting from P. */
7268 psize = 0;
7269 q = p;
7270 for (i = 0; i < insize; i++)
7271 {
7272 psize++;
7273 q = q->right;
7274 if (!q)
7275 break;
7276 }
7277 qsize = insize;
7278
7279 /* Now we have two lists. Merge them! */
7280 while (psize > 0 || (qsize > 0 && q != NULL))
7281 {
7282 /* See from which the next case to merge comes from. */
7283 if (psize == 0)
7284 {
7285 /* P is empty so the next case must come from Q. */
7286 e = q;
7287 q = q->right;
7288 qsize--;
7289 }
7290 else if (qsize == 0 || q == NULL)
7291 {
7292 /* Q is empty. */
7293 e = p;
7294 p = p->right;
7295 psize--;
7296 }
7297 else
7298 {
7299 cmp = compare_cases (p, q);
7300 if (cmp < 0)
7301 {
7302 /* The whole case range for P is less than the
7303 one for Q. */
7304 e = p;
7305 p = p->right;
7306 psize--;
7307 }
7308 else if (cmp > 0)
7309 {
7310 /* The whole case range for Q is greater than
7311 the case range for P. */
7312 e = q;
7313 q = q->right;
7314 qsize--;
7315 }
7316 else
7317 {
7318 /* The cases overlap, or they are the same
7319 element in the list. Either way, we must
7320 issue an error and get the next case from P. */
7321 /* FIXME: Sort P and Q by line number. */
7322 gfc_error ("CASE label at %L overlaps with CASE "
7323 "label at %L", &p->where, &q->where);
7324 overlap_seen = 1;
7325 e = p;
7326 p = p->right;
7327 psize--;
7328 }
7329 }
7330
7331 /* Add the next element to the merged list. */
7332 if (tail)
7333 tail->right = e;
7334 else
7335 list = e;
7336 e->left = tail;
7337 tail = e;
7338 }
7339
7340 /* P has now stepped INSIZE places along, and so has Q. So
7341 they're the same. */
7342 p = q;
7343 }
7344 tail->right = NULL;
7345
7346 /* If we have done only one merge or none at all, we've
7347 finished sorting the cases. */
7348 if (nmerges <= 1)
7349 {
7350 if (!overlap_seen)
7351 return list;
7352 else
7353 return NULL;
7354 }
7355
7356 /* Otherwise repeat, merging lists twice the size. */
7357 insize *= 2;
7358 }
7359 }
7360
7361
7362 /* Check to see if an expression is suitable for use in a CASE statement.
7363 Makes sure that all case expressions are scalar constants of the same
7364 type. Return FAILURE if anything is wrong. */
7365
7366 static gfc_try
7367 validate_case_label_expr (gfc_expr *e, gfc_expr *case_expr)
7368 {
7369 if (e == NULL) return SUCCESS;
7370
7371 if (e->ts.type != case_expr->ts.type)
7372 {
7373 gfc_error ("Expression in CASE statement at %L must be of type %s",
7374 &e->where, gfc_basic_typename (case_expr->ts.type));
7375 return FAILURE;
7376 }
7377
7378 /* C805 (R808) For a given case-construct, each case-value shall be of
7379 the same type as case-expr. For character type, length differences
7380 are allowed, but the kind type parameters shall be the same. */
7381
7382 if (case_expr->ts.type == BT_CHARACTER && e->ts.kind != case_expr->ts.kind)
7383 {
7384 gfc_error ("Expression in CASE statement at %L must be of kind %d",
7385 &e->where, case_expr->ts.kind);
7386 return FAILURE;
7387 }
7388
7389 /* Convert the case value kind to that of case expression kind,
7390 if needed */
7391
7392 if (e->ts.kind != case_expr->ts.kind)
7393 gfc_convert_type_warn (e, &case_expr->ts, 2, 0);
7394
7395 if (e->rank != 0)
7396 {
7397 gfc_error ("Expression in CASE statement at %L must be scalar",
7398 &e->where);
7399 return FAILURE;
7400 }
7401
7402 return SUCCESS;
7403 }
7404
7405
7406 /* Given a completely parsed select statement, we:
7407
7408 - Validate all expressions and code within the SELECT.
7409 - Make sure that the selection expression is not of the wrong type.
7410 - Make sure that no case ranges overlap.
7411 - Eliminate unreachable cases and unreachable code resulting from
7412 removing case labels.
7413
7414 The standard does allow unreachable cases, e.g. CASE (5:3). But
7415 they are a hassle for code generation, and to prevent that, we just
7416 cut them out here. This is not necessary for overlapping cases
7417 because they are illegal and we never even try to generate code.
7418
7419 We have the additional caveat that a SELECT construct could have
7420 been a computed GOTO in the source code. Fortunately we can fairly
7421 easily work around that here: The case_expr for a "real" SELECT CASE
7422 is in code->expr1, but for a computed GOTO it is in code->expr2. All
7423 we have to do is make sure that the case_expr is a scalar integer
7424 expression. */
7425
7426 static void
7427 resolve_select (gfc_code *code)
7428 {
7429 gfc_code *body;
7430 gfc_expr *case_expr;
7431 gfc_case *cp, *default_case, *tail, *head;
7432 int seen_unreachable;
7433 int seen_logical;
7434 int ncases;
7435 bt type;
7436 gfc_try t;
7437
7438 if (code->expr1 == NULL)
7439 {
7440 /* This was actually a computed GOTO statement. */
7441 case_expr = code->expr2;
7442 if (case_expr->ts.type != BT_INTEGER|| case_expr->rank != 0)
7443 gfc_error ("Selection expression in computed GOTO statement "
7444 "at %L must be a scalar integer expression",
7445 &case_expr->where);
7446
7447 /* Further checking is not necessary because this SELECT was built
7448 by the compiler, so it should always be OK. Just move the
7449 case_expr from expr2 to expr so that we can handle computed
7450 GOTOs as normal SELECTs from here on. */
7451 code->expr1 = code->expr2;
7452 code->expr2 = NULL;
7453 return;
7454 }
7455
7456 case_expr = code->expr1;
7457
7458 type = case_expr->ts.type;
7459 if (type != BT_LOGICAL && type != BT_INTEGER && type != BT_CHARACTER)
7460 {
7461 gfc_error ("Argument of SELECT statement at %L cannot be %s",
7462 &case_expr->where, gfc_typename (&case_expr->ts));
7463
7464 /* Punt. Going on here just produce more garbage error messages. */
7465 return;
7466 }
7467
7468 if (case_expr->rank != 0)
7469 {
7470 gfc_error ("Argument of SELECT statement at %L must be a scalar "
7471 "expression", &case_expr->where);
7472
7473 /* Punt. */
7474 return;
7475 }
7476
7477
7478 /* Raise a warning if an INTEGER case value exceeds the range of
7479 the case-expr. Later, all expressions will be promoted to the
7480 largest kind of all case-labels. */
7481
7482 if (type == BT_INTEGER)
7483 for (body = code->block; body; body = body->block)
7484 for (cp = body->ext.block.case_list; cp; cp = cp->next)
7485 {
7486 if (cp->low
7487 && gfc_check_integer_range (cp->low->value.integer,
7488 case_expr->ts.kind) != ARITH_OK)
7489 gfc_warning ("Expression in CASE statement at %L is "
7490 "not in the range of %s", &cp->low->where,
7491 gfc_typename (&case_expr->ts));
7492
7493 if (cp->high
7494 && cp->low != cp->high
7495 && gfc_check_integer_range (cp->high->value.integer,
7496 case_expr->ts.kind) != ARITH_OK)
7497 gfc_warning ("Expression in CASE statement at %L is "
7498 "not in the range of %s", &cp->high->where,
7499 gfc_typename (&case_expr->ts));
7500 }
7501
7502 /* PR 19168 has a long discussion concerning a mismatch of the kinds
7503 of the SELECT CASE expression and its CASE values. Walk the lists
7504 of case values, and if we find a mismatch, promote case_expr to
7505 the appropriate kind. */
7506
7507 if (type == BT_LOGICAL || type == BT_INTEGER)
7508 {
7509 for (body = code->block; body; body = body->block)
7510 {
7511 /* Walk the case label list. */
7512 for (cp = body->ext.block.case_list; cp; cp = cp->next)
7513 {
7514 /* Intercept the DEFAULT case. It does not have a kind. */
7515 if (cp->low == NULL && cp->high == NULL)
7516 continue;
7517
7518 /* Unreachable case ranges are discarded, so ignore. */
7519 if (cp->low != NULL && cp->high != NULL
7520 && cp->low != cp->high
7521 && gfc_compare_expr (cp->low, cp->high, INTRINSIC_GT) > 0)
7522 continue;
7523
7524 if (cp->low != NULL
7525 && case_expr->ts.kind != gfc_kind_max(case_expr, cp->low))
7526 gfc_convert_type_warn (case_expr, &cp->low->ts, 2, 0);
7527
7528 if (cp->high != NULL
7529 && case_expr->ts.kind != gfc_kind_max(case_expr, cp->high))
7530 gfc_convert_type_warn (case_expr, &cp->high->ts, 2, 0);
7531 }
7532 }
7533 }
7534
7535 /* Assume there is no DEFAULT case. */
7536 default_case = NULL;
7537 head = tail = NULL;
7538 ncases = 0;
7539 seen_logical = 0;
7540
7541 for (body = code->block; body; body = body->block)
7542 {
7543 /* Assume the CASE list is OK, and all CASE labels can be matched. */
7544 t = SUCCESS;
7545 seen_unreachable = 0;
7546
7547 /* Walk the case label list, making sure that all case labels
7548 are legal. */
7549 for (cp = body->ext.block.case_list; cp; cp = cp->next)
7550 {
7551 /* Count the number of cases in the whole construct. */
7552 ncases++;
7553
7554 /* Intercept the DEFAULT case. */
7555 if (cp->low == NULL && cp->high == NULL)
7556 {
7557 if (default_case != NULL)
7558 {
7559 gfc_error ("The DEFAULT CASE at %L cannot be followed "
7560 "by a second DEFAULT CASE at %L",
7561 &default_case->where, &cp->where);
7562 t = FAILURE;
7563 break;
7564 }
7565 else
7566 {
7567 default_case = cp;
7568 continue;
7569 }
7570 }
7571
7572 /* Deal with single value cases and case ranges. Errors are
7573 issued from the validation function. */
7574 if (validate_case_label_expr (cp->low, case_expr) != SUCCESS
7575 || validate_case_label_expr (cp->high, case_expr) != SUCCESS)
7576 {
7577 t = FAILURE;
7578 break;
7579 }
7580
7581 if (type == BT_LOGICAL
7582 && ((cp->low == NULL || cp->high == NULL)
7583 || cp->low != cp->high))
7584 {
7585 gfc_error ("Logical range in CASE statement at %L is not "
7586 "allowed", &cp->low->where);
7587 t = FAILURE;
7588 break;
7589 }
7590
7591 if (type == BT_LOGICAL && cp->low->expr_type == EXPR_CONSTANT)
7592 {
7593 int value;
7594 value = cp->low->value.logical == 0 ? 2 : 1;
7595 if (value & seen_logical)
7596 {
7597 gfc_error ("Constant logical value in CASE statement "
7598 "is repeated at %L",
7599 &cp->low->where);
7600 t = FAILURE;
7601 break;
7602 }
7603 seen_logical |= value;
7604 }
7605
7606 if (cp->low != NULL && cp->high != NULL
7607 && cp->low != cp->high
7608 && gfc_compare_expr (cp->low, cp->high, INTRINSIC_GT) > 0)
7609 {
7610 if (gfc_option.warn_surprising)
7611 gfc_warning ("Range specification at %L can never "
7612 "be matched", &cp->where);
7613
7614 cp->unreachable = 1;
7615 seen_unreachable = 1;
7616 }
7617 else
7618 {
7619 /* If the case range can be matched, it can also overlap with
7620 other cases. To make sure it does not, we put it in a
7621 double linked list here. We sort that with a merge sort
7622 later on to detect any overlapping cases. */
7623 if (!head)
7624 {
7625 head = tail = cp;
7626 head->right = head->left = NULL;
7627 }
7628 else
7629 {
7630 tail->right = cp;
7631 tail->right->left = tail;
7632 tail = tail->right;
7633 tail->right = NULL;
7634 }
7635 }
7636 }
7637
7638 /* It there was a failure in the previous case label, give up
7639 for this case label list. Continue with the next block. */
7640 if (t == FAILURE)
7641 continue;
7642
7643 /* See if any case labels that are unreachable have been seen.
7644 If so, we eliminate them. This is a bit of a kludge because
7645 the case lists for a single case statement (label) is a
7646 single forward linked lists. */
7647 if (seen_unreachable)
7648 {
7649 /* Advance until the first case in the list is reachable. */
7650 while (body->ext.block.case_list != NULL
7651 && body->ext.block.case_list->unreachable)
7652 {
7653 gfc_case *n = body->ext.block.case_list;
7654 body->ext.block.case_list = body->ext.block.case_list->next;
7655 n->next = NULL;
7656 gfc_free_case_list (n);
7657 }
7658
7659 /* Strip all other unreachable cases. */
7660 if (body->ext.block.case_list)
7661 {
7662 for (cp = body->ext.block.case_list; cp->next; cp = cp->next)
7663 {
7664 if (cp->next->unreachable)
7665 {
7666 gfc_case *n = cp->next;
7667 cp->next = cp->next->next;
7668 n->next = NULL;
7669 gfc_free_case_list (n);
7670 }
7671 }
7672 }
7673 }
7674 }
7675
7676 /* See if there were overlapping cases. If the check returns NULL,
7677 there was overlap. In that case we don't do anything. If head
7678 is non-NULL, we prepend the DEFAULT case. The sorted list can
7679 then used during code generation for SELECT CASE constructs with
7680 a case expression of a CHARACTER type. */
7681 if (head)
7682 {
7683 head = check_case_overlap (head);
7684
7685 /* Prepend the default_case if it is there. */
7686 if (head != NULL && default_case)
7687 {
7688 default_case->left = NULL;
7689 default_case->right = head;
7690 head->left = default_case;
7691 }
7692 }
7693
7694 /* Eliminate dead blocks that may be the result if we've seen
7695 unreachable case labels for a block. */
7696 for (body = code; body && body->block; body = body->block)
7697 {
7698 if (body->block->ext.block.case_list == NULL)
7699 {
7700 /* Cut the unreachable block from the code chain. */
7701 gfc_code *c = body->block;
7702 body->block = c->block;
7703
7704 /* Kill the dead block, but not the blocks below it. */
7705 c->block = NULL;
7706 gfc_free_statements (c);
7707 }
7708 }
7709
7710 /* More than two cases is legal but insane for logical selects.
7711 Issue a warning for it. */
7712 if (gfc_option.warn_surprising && type == BT_LOGICAL
7713 && ncases > 2)
7714 gfc_warning ("Logical SELECT CASE block at %L has more that two cases",
7715 &code->loc);
7716 }
7717
7718
7719 /* Check if a derived type is extensible. */
7720
7721 bool
7722 gfc_type_is_extensible (gfc_symbol *sym)
7723 {
7724 return !(sym->attr.is_bind_c || sym->attr.sequence);
7725 }
7726
7727
7728 /* Resolve an associate name: Resolve target and ensure the type-spec is
7729 correct as well as possibly the array-spec. */
7730
7731 static void
7732 resolve_assoc_var (gfc_symbol* sym, bool resolve_target)
7733 {
7734 gfc_expr* target;
7735
7736 gcc_assert (sym->assoc);
7737 gcc_assert (sym->attr.flavor == FL_VARIABLE);
7738
7739 /* If this is for SELECT TYPE, the target may not yet be set. In that
7740 case, return. Resolution will be called later manually again when
7741 this is done. */
7742 target = sym->assoc->target;
7743 if (!target)
7744 return;
7745 gcc_assert (!sym->assoc->dangling);
7746
7747 if (resolve_target && gfc_resolve_expr (target) != SUCCESS)
7748 return;
7749
7750 /* For variable targets, we get some attributes from the target. */
7751 if (target->expr_type == EXPR_VARIABLE)
7752 {
7753 gfc_symbol* tsym;
7754
7755 gcc_assert (target->symtree);
7756 tsym = target->symtree->n.sym;
7757
7758 sym->attr.asynchronous = tsym->attr.asynchronous;
7759 sym->attr.volatile_ = tsym->attr.volatile_;
7760
7761 sym->attr.target = (tsym->attr.target || tsym->attr.pointer);
7762 }
7763
7764 /* Get type if this was not already set. Note that it can be
7765 some other type than the target in case this is a SELECT TYPE
7766 selector! So we must not update when the type is already there. */
7767 if (sym->ts.type == BT_UNKNOWN)
7768 sym->ts = target->ts;
7769 gcc_assert (sym->ts.type != BT_UNKNOWN);
7770
7771 /* See if this is a valid association-to-variable. */
7772 sym->assoc->variable = (target->expr_type == EXPR_VARIABLE
7773 && !gfc_has_vector_subscript (target));
7774
7775 /* Finally resolve if this is an array or not. */
7776 if (sym->attr.dimension && target->rank == 0)
7777 {
7778 gfc_error ("Associate-name '%s' at %L is used as array",
7779 sym->name, &sym->declared_at);
7780 sym->attr.dimension = 0;
7781 return;
7782 }
7783 if (target->rank > 0)
7784 sym->attr.dimension = 1;
7785
7786 if (sym->attr.dimension)
7787 {
7788 sym->as = gfc_get_array_spec ();
7789 sym->as->rank = target->rank;
7790 sym->as->type = AS_DEFERRED;
7791
7792 /* Target must not be coindexed, thus the associate-variable
7793 has no corank. */
7794 sym->as->corank = 0;
7795 }
7796 }
7797
7798
7799 /* Resolve a SELECT TYPE statement. */
7800
7801 static void
7802 resolve_select_type (gfc_code *code, gfc_namespace *old_ns)
7803 {
7804 gfc_symbol *selector_type;
7805 gfc_code *body, *new_st, *if_st, *tail;
7806 gfc_code *class_is = NULL, *default_case = NULL;
7807 gfc_case *c;
7808 gfc_symtree *st;
7809 char name[GFC_MAX_SYMBOL_LEN];
7810 gfc_namespace *ns;
7811 int error = 0;
7812
7813 ns = code->ext.block.ns;
7814 gfc_resolve (ns);
7815
7816 /* Check for F03:C813. */
7817 if (code->expr1->ts.type != BT_CLASS
7818 && !(code->expr2 && code->expr2->ts.type == BT_CLASS))
7819 {
7820 gfc_error ("Selector shall be polymorphic in SELECT TYPE statement "
7821 "at %L", &code->loc);
7822 return;
7823 }
7824
7825 if (code->expr2)
7826 {
7827 if (code->expr1->symtree->n.sym->attr.untyped)
7828 code->expr1->symtree->n.sym->ts = code->expr2->ts;
7829 selector_type = CLASS_DATA (code->expr2)->ts.u.derived;
7830 }
7831 else
7832 selector_type = CLASS_DATA (code->expr1)->ts.u.derived;
7833
7834 /* Loop over TYPE IS / CLASS IS cases. */
7835 for (body = code->block; body; body = body->block)
7836 {
7837 c = body->ext.block.case_list;
7838
7839 /* Check F03:C815. */
7840 if ((c->ts.type == BT_DERIVED || c->ts.type == BT_CLASS)
7841 && !gfc_type_is_extensible (c->ts.u.derived))
7842 {
7843 gfc_error ("Derived type '%s' at %L must be extensible",
7844 c->ts.u.derived->name, &c->where);
7845 error++;
7846 continue;
7847 }
7848
7849 /* Check F03:C816. */
7850 if ((c->ts.type == BT_DERIVED || c->ts.type == BT_CLASS)
7851 && !gfc_type_is_extension_of (selector_type, c->ts.u.derived))
7852 {
7853 gfc_error ("Derived type '%s' at %L must be an extension of '%s'",
7854 c->ts.u.derived->name, &c->where, selector_type->name);
7855 error++;
7856 continue;
7857 }
7858
7859 /* Intercept the DEFAULT case. */
7860 if (c->ts.type == BT_UNKNOWN)
7861 {
7862 /* Check F03:C818. */
7863 if (default_case)
7864 {
7865 gfc_error ("The DEFAULT CASE at %L cannot be followed "
7866 "by a second DEFAULT CASE at %L",
7867 &default_case->ext.block.case_list->where, &c->where);
7868 error++;
7869 continue;
7870 }
7871
7872 default_case = body;
7873 }
7874 }
7875
7876 if (error > 0)
7877 return;
7878
7879 /* Transform SELECT TYPE statement to BLOCK and associate selector to
7880 target if present. If there are any EXIT statements referring to the
7881 SELECT TYPE construct, this is no problem because the gfc_code
7882 reference stays the same and EXIT is equally possible from the BLOCK
7883 it is changed to. */
7884 code->op = EXEC_BLOCK;
7885 if (code->expr2)
7886 {
7887 gfc_association_list* assoc;
7888
7889 assoc = gfc_get_association_list ();
7890 assoc->st = code->expr1->symtree;
7891 assoc->target = gfc_copy_expr (code->expr2);
7892 /* assoc->variable will be set by resolve_assoc_var. */
7893
7894 code->ext.block.assoc = assoc;
7895 code->expr1->symtree->n.sym->assoc = assoc;
7896
7897 resolve_assoc_var (code->expr1->symtree->n.sym, false);
7898 }
7899 else
7900 code->ext.block.assoc = NULL;
7901
7902 /* Add EXEC_SELECT to switch on type. */
7903 new_st = gfc_get_code ();
7904 new_st->op = code->op;
7905 new_st->expr1 = code->expr1;
7906 new_st->expr2 = code->expr2;
7907 new_st->block = code->block;
7908 code->expr1 = code->expr2 = NULL;
7909 code->block = NULL;
7910 if (!ns->code)
7911 ns->code = new_st;
7912 else
7913 ns->code->next = new_st;
7914 code = new_st;
7915 code->op = EXEC_SELECT;
7916 gfc_add_vptr_component (code->expr1);
7917 gfc_add_hash_component (code->expr1);
7918
7919 /* Loop over TYPE IS / CLASS IS cases. */
7920 for (body = code->block; body; body = body->block)
7921 {
7922 c = body->ext.block.case_list;
7923
7924 if (c->ts.type == BT_DERIVED)
7925 c->low = c->high = gfc_get_int_expr (gfc_default_integer_kind, NULL,
7926 c->ts.u.derived->hash_value);
7927
7928 else if (c->ts.type == BT_UNKNOWN)
7929 continue;
7930
7931 /* Associate temporary to selector. This should only be done
7932 when this case is actually true, so build a new ASSOCIATE
7933 that does precisely this here (instead of using the
7934 'global' one). */
7935
7936 if (c->ts.type == BT_CLASS)
7937 sprintf (name, "__tmp_class_%s", c->ts.u.derived->name);
7938 else
7939 sprintf (name, "__tmp_type_%s", c->ts.u.derived->name);
7940 st = gfc_find_symtree (ns->sym_root, name);
7941 gcc_assert (st->n.sym->assoc);
7942 st->n.sym->assoc->target = gfc_get_variable_expr (code->expr1->symtree);
7943 if (c->ts.type == BT_DERIVED)
7944 gfc_add_data_component (st->n.sym->assoc->target);
7945
7946 new_st = gfc_get_code ();
7947 new_st->op = EXEC_BLOCK;
7948 new_st->ext.block.ns = gfc_build_block_ns (ns);
7949 new_st->ext.block.ns->code = body->next;
7950 body->next = new_st;
7951
7952 /* Chain in the new list only if it is marked as dangling. Otherwise
7953 there is a CASE label overlap and this is already used. Just ignore,
7954 the error is diagonsed elsewhere. */
7955 if (st->n.sym->assoc->dangling)
7956 {
7957 new_st->ext.block.assoc = st->n.sym->assoc;
7958 st->n.sym->assoc->dangling = 0;
7959 }
7960
7961 resolve_assoc_var (st->n.sym, false);
7962 }
7963
7964 /* Take out CLASS IS cases for separate treatment. */
7965 body = code;
7966 while (body && body->block)
7967 {
7968 if (body->block->ext.block.case_list->ts.type == BT_CLASS)
7969 {
7970 /* Add to class_is list. */
7971 if (class_is == NULL)
7972 {
7973 class_is = body->block;
7974 tail = class_is;
7975 }
7976 else
7977 {
7978 for (tail = class_is; tail->block; tail = tail->block) ;
7979 tail->block = body->block;
7980 tail = tail->block;
7981 }
7982 /* Remove from EXEC_SELECT list. */
7983 body->block = body->block->block;
7984 tail->block = NULL;
7985 }
7986 else
7987 body = body->block;
7988 }
7989
7990 if (class_is)
7991 {
7992 gfc_symbol *vtab;
7993
7994 if (!default_case)
7995 {
7996 /* Add a default case to hold the CLASS IS cases. */
7997 for (tail = code; tail->block; tail = tail->block) ;
7998 tail->block = gfc_get_code ();
7999 tail = tail->block;
8000 tail->op = EXEC_SELECT_TYPE;
8001 tail->ext.block.case_list = gfc_get_case ();
8002 tail->ext.block.case_list->ts.type = BT_UNKNOWN;
8003 tail->next = NULL;
8004 default_case = tail;
8005 }
8006
8007 /* More than one CLASS IS block? */
8008 if (class_is->block)
8009 {
8010 gfc_code **c1,*c2;
8011 bool swapped;
8012 /* Sort CLASS IS blocks by extension level. */
8013 do
8014 {
8015 swapped = false;
8016 for (c1 = &class_is; (*c1) && (*c1)->block; c1 = &((*c1)->block))
8017 {
8018 c2 = (*c1)->block;
8019 /* F03:C817 (check for doubles). */
8020 if ((*c1)->ext.block.case_list->ts.u.derived->hash_value
8021 == c2->ext.block.case_list->ts.u.derived->hash_value)
8022 {
8023 gfc_error ("Double CLASS IS block in SELECT TYPE "
8024 "statement at %L",
8025 &c2->ext.block.case_list->where);
8026 return;
8027 }
8028 if ((*c1)->ext.block.case_list->ts.u.derived->attr.extension
8029 < c2->ext.block.case_list->ts.u.derived->attr.extension)
8030 {
8031 /* Swap. */
8032 (*c1)->block = c2->block;
8033 c2->block = *c1;
8034 *c1 = c2;
8035 swapped = true;
8036 }
8037 }
8038 }
8039 while (swapped);
8040 }
8041
8042 /* Generate IF chain. */
8043 if_st = gfc_get_code ();
8044 if_st->op = EXEC_IF;
8045 new_st = if_st;
8046 for (body = class_is; body; body = body->block)
8047 {
8048 new_st->block = gfc_get_code ();
8049 new_st = new_st->block;
8050 new_st->op = EXEC_IF;
8051 /* Set up IF condition: Call _gfortran_is_extension_of. */
8052 new_st->expr1 = gfc_get_expr ();
8053 new_st->expr1->expr_type = EXPR_FUNCTION;
8054 new_st->expr1->ts.type = BT_LOGICAL;
8055 new_st->expr1->ts.kind = 4;
8056 new_st->expr1->value.function.name = gfc_get_string (PREFIX ("is_extension_of"));
8057 new_st->expr1->value.function.isym = XCNEW (gfc_intrinsic_sym);
8058 new_st->expr1->value.function.isym->id = GFC_ISYM_EXTENDS_TYPE_OF;
8059 /* Set up arguments. */
8060 new_st->expr1->value.function.actual = gfc_get_actual_arglist ();
8061 new_st->expr1->value.function.actual->expr = gfc_get_variable_expr (code->expr1->symtree);
8062 new_st->expr1->value.function.actual->expr->where = code->loc;
8063 gfc_add_vptr_component (new_st->expr1->value.function.actual->expr);
8064 vtab = gfc_find_derived_vtab (body->ext.block.case_list->ts.u.derived);
8065 st = gfc_find_symtree (vtab->ns->sym_root, vtab->name);
8066 new_st->expr1->value.function.actual->next = gfc_get_actual_arglist ();
8067 new_st->expr1->value.function.actual->next->expr = gfc_get_variable_expr (st);
8068 new_st->next = body->next;
8069 }
8070 if (default_case->next)
8071 {
8072 new_st->block = gfc_get_code ();
8073 new_st = new_st->block;
8074 new_st->op = EXEC_IF;
8075 new_st->next = default_case->next;
8076 }
8077
8078 /* Replace CLASS DEFAULT code by the IF chain. */
8079 default_case->next = if_st;
8080 }
8081
8082 /* Resolve the internal code. This can not be done earlier because
8083 it requires that the sym->assoc of selectors is set already. */
8084 gfc_current_ns = ns;
8085 gfc_resolve_blocks (code->block, gfc_current_ns);
8086 gfc_current_ns = old_ns;
8087
8088 resolve_select (code);
8089 }
8090
8091
8092 /* Resolve a transfer statement. This is making sure that:
8093 -- a derived type being transferred has only non-pointer components
8094 -- a derived type being transferred doesn't have private components, unless
8095 it's being transferred from the module where the type was defined
8096 -- we're not trying to transfer a whole assumed size array. */
8097
8098 static void
8099 resolve_transfer (gfc_code *code)
8100 {
8101 gfc_typespec *ts;
8102 gfc_symbol *sym;
8103 gfc_ref *ref;
8104 gfc_expr *exp;
8105
8106 exp = code->expr1;
8107
8108 while (exp != NULL && exp->expr_type == EXPR_OP
8109 && exp->value.op.op == INTRINSIC_PARENTHESES)
8110 exp = exp->value.op.op1;
8111
8112 if (exp == NULL || (exp->expr_type != EXPR_VARIABLE
8113 && exp->expr_type != EXPR_FUNCTION))
8114 return;
8115
8116 /* If we are reading, the variable will be changed. Note that
8117 code->ext.dt may be NULL if the TRANSFER is related to
8118 an INQUIRE statement -- but in this case, we are not reading, either. */
8119 if (code->ext.dt && code->ext.dt->dt_io_kind->value.iokind == M_READ
8120 && gfc_check_vardef_context (exp, false, false, _("item in READ"))
8121 == FAILURE)
8122 return;
8123
8124 sym = exp->symtree->n.sym;
8125 ts = &sym->ts;
8126
8127 /* Go to actual component transferred. */
8128 for (ref = exp->ref; ref; ref = ref->next)
8129 if (ref->type == REF_COMPONENT)
8130 ts = &ref->u.c.component->ts;
8131
8132 if (ts->type == BT_CLASS)
8133 {
8134 /* FIXME: Test for defined input/output. */
8135 gfc_error ("Data transfer element at %L cannot be polymorphic unless "
8136 "it is processed by a defined input/output procedure",
8137 &code->loc);
8138 return;
8139 }
8140
8141 if (ts->type == BT_DERIVED)
8142 {
8143 /* Check that transferred derived type doesn't contain POINTER
8144 components. */
8145 if (ts->u.derived->attr.pointer_comp)
8146 {
8147 gfc_error ("Data transfer element at %L cannot have "
8148 "POINTER components", &code->loc);
8149 return;
8150 }
8151
8152 /* F08:C935. */
8153 if (ts->u.derived->attr.proc_pointer_comp)
8154 {
8155 gfc_error ("Data transfer element at %L cannot have "
8156 "procedure pointer components", &code->loc);
8157 return;
8158 }
8159
8160 if (ts->u.derived->attr.alloc_comp)
8161 {
8162 gfc_error ("Data transfer element at %L cannot have "
8163 "ALLOCATABLE components", &code->loc);
8164 return;
8165 }
8166
8167 if (derived_inaccessible (ts->u.derived))
8168 {
8169 gfc_error ("Data transfer element at %L cannot have "
8170 "PRIVATE components",&code->loc);
8171 return;
8172 }
8173 }
8174
8175 if (sym->as != NULL && sym->as->type == AS_ASSUMED_SIZE
8176 && exp->ref->type == REF_ARRAY && exp->ref->u.ar.type == AR_FULL)
8177 {
8178 gfc_error ("Data transfer element at %L cannot be a full reference to "
8179 "an assumed-size array", &code->loc);
8180 return;
8181 }
8182 }
8183
8184
8185 /*********** Toplevel code resolution subroutines ***********/
8186
8187 /* Find the set of labels that are reachable from this block. We also
8188 record the last statement in each block. */
8189
8190 static void
8191 find_reachable_labels (gfc_code *block)
8192 {
8193 gfc_code *c;
8194
8195 if (!block)
8196 return;
8197
8198 cs_base->reachable_labels = bitmap_obstack_alloc (&labels_obstack);
8199
8200 /* Collect labels in this block. We don't keep those corresponding
8201 to END {IF|SELECT}, these are checked in resolve_branch by going
8202 up through the code_stack. */
8203 for (c = block; c; c = c->next)
8204 {
8205 if (c->here && c->op != EXEC_END_BLOCK)
8206 bitmap_set_bit (cs_base->reachable_labels, c->here->value);
8207 }
8208
8209 /* Merge with labels from parent block. */
8210 if (cs_base->prev)
8211 {
8212 gcc_assert (cs_base->prev->reachable_labels);
8213 bitmap_ior_into (cs_base->reachable_labels,
8214 cs_base->prev->reachable_labels);
8215 }
8216 }
8217
8218
8219 static void
8220 resolve_lock_unlock (gfc_code *code)
8221 {
8222 if (code->expr1->ts.type != BT_DERIVED
8223 || code->expr1->expr_type != EXPR_VARIABLE
8224 || code->expr1->ts.u.derived->from_intmod != INTMOD_ISO_FORTRAN_ENV
8225 || code->expr1->ts.u.derived->intmod_sym_id != ISOFORTRAN_LOCK_TYPE
8226 || code->expr1->rank != 0
8227 || !(gfc_expr_attr (code->expr1).codimension
8228 || gfc_is_coindexed (code->expr1)))
8229 gfc_error ("Lock variable at %L must be a scalar coarray of type "
8230 "LOCK_TYPE", &code->expr1->where);
8231
8232 /* Check STAT. */
8233 if (code->expr2
8234 && (code->expr2->ts.type != BT_INTEGER || code->expr2->rank != 0
8235 || code->expr2->expr_type != EXPR_VARIABLE))
8236 gfc_error ("STAT= argument at %L must be a scalar INTEGER variable",
8237 &code->expr2->where);
8238
8239 if (code->expr2
8240 && gfc_check_vardef_context (code->expr2, false, false,
8241 _("STAT variable")) == FAILURE)
8242 return;
8243
8244 /* Check ERRMSG. */
8245 if (code->expr3
8246 && (code->expr3->ts.type != BT_CHARACTER || code->expr3->rank != 0
8247 || code->expr3->expr_type != EXPR_VARIABLE))
8248 gfc_error ("ERRMSG= argument at %L must be a scalar CHARACTER variable",
8249 &code->expr3->where);
8250
8251 if (code->expr3
8252 && gfc_check_vardef_context (code->expr3, false, false,
8253 _("ERRMSG variable")) == FAILURE)
8254 return;
8255
8256 /* Check ACQUIRED_LOCK. */
8257 if (code->expr4
8258 && (code->expr4->ts.type != BT_LOGICAL || code->expr4->rank != 0
8259 || code->expr4->expr_type != EXPR_VARIABLE))
8260 gfc_error ("ACQUIRED_LOCK= argument at %L must be a scalar LOGICAL "
8261 "variable", &code->expr4->where);
8262
8263 if (code->expr4
8264 && gfc_check_vardef_context (code->expr4, false, false,
8265 _("ACQUIRED_LOCK variable")) == FAILURE)
8266 return;
8267 }
8268
8269
8270 static void
8271 resolve_sync (gfc_code *code)
8272 {
8273 /* Check imageset. The * case matches expr1 == NULL. */
8274 if (code->expr1)
8275 {
8276 if (code->expr1->ts.type != BT_INTEGER || code->expr1->rank > 1)
8277 gfc_error ("Imageset argument at %L must be a scalar or rank-1 "
8278 "INTEGER expression", &code->expr1->where);
8279 if (code->expr1->expr_type == EXPR_CONSTANT && code->expr1->rank == 0
8280 && mpz_cmp_si (code->expr1->value.integer, 1) < 0)
8281 gfc_error ("Imageset argument at %L must between 1 and num_images()",
8282 &code->expr1->where);
8283 else if (code->expr1->expr_type == EXPR_ARRAY
8284 && gfc_simplify_expr (code->expr1, 0) == SUCCESS)
8285 {
8286 gfc_constructor *cons;
8287 cons = gfc_constructor_first (code->expr1->value.constructor);
8288 for (; cons; cons = gfc_constructor_next (cons))
8289 if (cons->expr->expr_type == EXPR_CONSTANT
8290 && mpz_cmp_si (cons->expr->value.integer, 1) < 0)
8291 gfc_error ("Imageset argument at %L must between 1 and "
8292 "num_images()", &cons->expr->where);
8293 }
8294 }
8295
8296 /* Check STAT. */
8297 if (code->expr2
8298 && (code->expr2->ts.type != BT_INTEGER || code->expr2->rank != 0
8299 || code->expr2->expr_type != EXPR_VARIABLE))
8300 gfc_error ("STAT= argument at %L must be a scalar INTEGER variable",
8301 &code->expr2->where);
8302
8303 /* Check ERRMSG. */
8304 if (code->expr3
8305 && (code->expr3->ts.type != BT_CHARACTER || code->expr3->rank != 0
8306 || code->expr3->expr_type != EXPR_VARIABLE))
8307 gfc_error ("ERRMSG= argument at %L must be a scalar CHARACTER variable",
8308 &code->expr3->where);
8309 }
8310
8311
8312 /* Given a branch to a label, see if the branch is conforming.
8313 The code node describes where the branch is located. */
8314
8315 static void
8316 resolve_branch (gfc_st_label *label, gfc_code *code)
8317 {
8318 code_stack *stack;
8319
8320 if (label == NULL)
8321 return;
8322
8323 /* Step one: is this a valid branching target? */
8324
8325 if (label->defined == ST_LABEL_UNKNOWN)
8326 {
8327 gfc_error ("Label %d referenced at %L is never defined", label->value,
8328 &label->where);
8329 return;
8330 }
8331
8332 if (label->defined != ST_LABEL_TARGET)
8333 {
8334 gfc_error ("Statement at %L is not a valid branch target statement "
8335 "for the branch statement at %L", &label->where, &code->loc);
8336 return;
8337 }
8338
8339 /* Step two: make sure this branch is not a branch to itself ;-) */
8340
8341 if (code->here == label)
8342 {
8343 gfc_warning ("Branch at %L may result in an infinite loop", &code->loc);
8344 return;
8345 }
8346
8347 /* Step three: See if the label is in the same block as the
8348 branching statement. The hard work has been done by setting up
8349 the bitmap reachable_labels. */
8350
8351 if (bitmap_bit_p (cs_base->reachable_labels, label->value))
8352 {
8353 /* Check now whether there is a CRITICAL construct; if so, check
8354 whether the label is still visible outside of the CRITICAL block,
8355 which is invalid. */
8356 for (stack = cs_base; stack; stack = stack->prev)
8357 if (stack->current->op == EXEC_CRITICAL
8358 && bitmap_bit_p (stack->reachable_labels, label->value))
8359 gfc_error ("GOTO statement at %L leaves CRITICAL construct for label"
8360 " at %L", &code->loc, &label->where);
8361
8362 return;
8363 }
8364
8365 /* Step four: If we haven't found the label in the bitmap, it may
8366 still be the label of the END of the enclosing block, in which
8367 case we find it by going up the code_stack. */
8368
8369 for (stack = cs_base; stack; stack = stack->prev)
8370 {
8371 if (stack->current->next && stack->current->next->here == label)
8372 break;
8373 if (stack->current->op == EXEC_CRITICAL)
8374 {
8375 /* Note: A label at END CRITICAL does not leave the CRITICAL
8376 construct as END CRITICAL is still part of it. */
8377 gfc_error ("GOTO statement at %L leaves CRITICAL construct for label"
8378 " at %L", &code->loc, &label->where);
8379 return;
8380 }
8381 }
8382
8383 if (stack)
8384 {
8385 gcc_assert (stack->current->next->op == EXEC_END_BLOCK);
8386 return;
8387 }
8388
8389 /* The label is not in an enclosing block, so illegal. This was
8390 allowed in Fortran 66, so we allow it as extension. No
8391 further checks are necessary in this case. */
8392 gfc_notify_std (GFC_STD_LEGACY, "Label at %L is not in the same block "
8393 "as the GOTO statement at %L", &label->where,
8394 &code->loc);
8395 return;
8396 }
8397
8398
8399 /* Check whether EXPR1 has the same shape as EXPR2. */
8400
8401 static gfc_try
8402 resolve_where_shape (gfc_expr *expr1, gfc_expr *expr2)
8403 {
8404 mpz_t shape[GFC_MAX_DIMENSIONS];
8405 mpz_t shape2[GFC_MAX_DIMENSIONS];
8406 gfc_try result = FAILURE;
8407 int i;
8408
8409 /* Compare the rank. */
8410 if (expr1->rank != expr2->rank)
8411 return result;
8412
8413 /* Compare the size of each dimension. */
8414 for (i=0; i<expr1->rank; i++)
8415 {
8416 if (gfc_array_dimen_size (expr1, i, &shape[i]) == FAILURE)
8417 goto ignore;
8418
8419 if (gfc_array_dimen_size (expr2, i, &shape2[i]) == FAILURE)
8420 goto ignore;
8421
8422 if (mpz_cmp (shape[i], shape2[i]))
8423 goto over;
8424 }
8425
8426 /* When either of the two expression is an assumed size array, we
8427 ignore the comparison of dimension sizes. */
8428 ignore:
8429 result = SUCCESS;
8430
8431 over:
8432 for (i--; i >= 0; i--)
8433 {
8434 mpz_clear (shape[i]);
8435 mpz_clear (shape2[i]);
8436 }
8437 return result;
8438 }
8439
8440
8441 /* Check whether a WHERE assignment target or a WHERE mask expression
8442 has the same shape as the outmost WHERE mask expression. */
8443
8444 static void
8445 resolve_where (gfc_code *code, gfc_expr *mask)
8446 {
8447 gfc_code *cblock;
8448 gfc_code *cnext;
8449 gfc_expr *e = NULL;
8450
8451 cblock = code->block;
8452
8453 /* Store the first WHERE mask-expr of the WHERE statement or construct.
8454 In case of nested WHERE, only the outmost one is stored. */
8455 if (mask == NULL) /* outmost WHERE */
8456 e = cblock->expr1;
8457 else /* inner WHERE */
8458 e = mask;
8459
8460 while (cblock)
8461 {
8462 if (cblock->expr1)
8463 {
8464 /* Check if the mask-expr has a consistent shape with the
8465 outmost WHERE mask-expr. */
8466 if (resolve_where_shape (cblock->expr1, e) == FAILURE)
8467 gfc_error ("WHERE mask at %L has inconsistent shape",
8468 &cblock->expr1->where);
8469 }
8470
8471 /* the assignment statement of a WHERE statement, or the first
8472 statement in where-body-construct of a WHERE construct */
8473 cnext = cblock->next;
8474 while (cnext)
8475 {
8476 switch (cnext->op)
8477 {
8478 /* WHERE assignment statement */
8479 case EXEC_ASSIGN:
8480
8481 /* Check shape consistent for WHERE assignment target. */
8482 if (e && resolve_where_shape (cnext->expr1, e) == FAILURE)
8483 gfc_error ("WHERE assignment target at %L has "
8484 "inconsistent shape", &cnext->expr1->where);
8485 break;
8486
8487
8488 case EXEC_ASSIGN_CALL:
8489 resolve_call (cnext);
8490 if (!cnext->resolved_sym->attr.elemental)
8491 gfc_error("Non-ELEMENTAL user-defined assignment in WHERE at %L",
8492 &cnext->ext.actual->expr->where);
8493 break;
8494
8495 /* WHERE or WHERE construct is part of a where-body-construct */
8496 case EXEC_WHERE:
8497 resolve_where (cnext, e);
8498 break;
8499
8500 default:
8501 gfc_error ("Unsupported statement inside WHERE at %L",
8502 &cnext->loc);
8503 }
8504 /* the next statement within the same where-body-construct */
8505 cnext = cnext->next;
8506 }
8507 /* the next masked-elsewhere-stmt, elsewhere-stmt, or end-where-stmt */
8508 cblock = cblock->block;
8509 }
8510 }
8511
8512
8513 /* Resolve assignment in FORALL construct.
8514 NVAR is the number of FORALL index variables, and VAR_EXPR records the
8515 FORALL index variables. */
8516
8517 static void
8518 gfc_resolve_assign_in_forall (gfc_code *code, int nvar, gfc_expr **var_expr)
8519 {
8520 int n;
8521
8522 for (n = 0; n < nvar; n++)
8523 {
8524 gfc_symbol *forall_index;
8525
8526 forall_index = var_expr[n]->symtree->n.sym;
8527
8528 /* Check whether the assignment target is one of the FORALL index
8529 variable. */
8530 if ((code->expr1->expr_type == EXPR_VARIABLE)
8531 && (code->expr1->symtree->n.sym == forall_index))
8532 gfc_error ("Assignment to a FORALL index variable at %L",
8533 &code->expr1->where);
8534 else
8535 {
8536 /* If one of the FORALL index variables doesn't appear in the
8537 assignment variable, then there could be a many-to-one
8538 assignment. Emit a warning rather than an error because the
8539 mask could be resolving this problem. */
8540 if (find_forall_index (code->expr1, forall_index, 0) == FAILURE)
8541 gfc_warning ("The FORALL with index '%s' is not used on the "
8542 "left side of the assignment at %L and so might "
8543 "cause multiple assignment to this object",
8544 var_expr[n]->symtree->name, &code->expr1->where);
8545 }
8546 }
8547 }
8548
8549
8550 /* Resolve WHERE statement in FORALL construct. */
8551
8552 static void
8553 gfc_resolve_where_code_in_forall (gfc_code *code, int nvar,
8554 gfc_expr **var_expr)
8555 {
8556 gfc_code *cblock;
8557 gfc_code *cnext;
8558
8559 cblock = code->block;
8560 while (cblock)
8561 {
8562 /* the assignment statement of a WHERE statement, or the first
8563 statement in where-body-construct of a WHERE construct */
8564 cnext = cblock->next;
8565 while (cnext)
8566 {
8567 switch (cnext->op)
8568 {
8569 /* WHERE assignment statement */
8570 case EXEC_ASSIGN:
8571 gfc_resolve_assign_in_forall (cnext, nvar, var_expr);
8572 break;
8573
8574 /* WHERE operator assignment statement */
8575 case EXEC_ASSIGN_CALL:
8576 resolve_call (cnext);
8577 if (!cnext->resolved_sym->attr.elemental)
8578 gfc_error("Non-ELEMENTAL user-defined assignment in WHERE at %L",
8579 &cnext->ext.actual->expr->where);
8580 break;
8581
8582 /* WHERE or WHERE construct is part of a where-body-construct */
8583 case EXEC_WHERE:
8584 gfc_resolve_where_code_in_forall (cnext, nvar, var_expr);
8585 break;
8586
8587 default:
8588 gfc_error ("Unsupported statement inside WHERE at %L",
8589 &cnext->loc);
8590 }
8591 /* the next statement within the same where-body-construct */
8592 cnext = cnext->next;
8593 }
8594 /* the next masked-elsewhere-stmt, elsewhere-stmt, or end-where-stmt */
8595 cblock = cblock->block;
8596 }
8597 }
8598
8599
8600 /* Traverse the FORALL body to check whether the following errors exist:
8601 1. For assignment, check if a many-to-one assignment happens.
8602 2. For WHERE statement, check the WHERE body to see if there is any
8603 many-to-one assignment. */
8604
8605 static void
8606 gfc_resolve_forall_body (gfc_code *code, int nvar, gfc_expr **var_expr)
8607 {
8608 gfc_code *c;
8609
8610 c = code->block->next;
8611 while (c)
8612 {
8613 switch (c->op)
8614 {
8615 case EXEC_ASSIGN:
8616 case EXEC_POINTER_ASSIGN:
8617 gfc_resolve_assign_in_forall (c, nvar, var_expr);
8618 break;
8619
8620 case EXEC_ASSIGN_CALL:
8621 resolve_call (c);
8622 break;
8623
8624 /* Because the gfc_resolve_blocks() will handle the nested FORALL,
8625 there is no need to handle it here. */
8626 case EXEC_FORALL:
8627 break;
8628 case EXEC_WHERE:
8629 gfc_resolve_where_code_in_forall(c, nvar, var_expr);
8630 break;
8631 default:
8632 break;
8633 }
8634 /* The next statement in the FORALL body. */
8635 c = c->next;
8636 }
8637 }
8638
8639
8640 /* Counts the number of iterators needed inside a forall construct, including
8641 nested forall constructs. This is used to allocate the needed memory
8642 in gfc_resolve_forall. */
8643
8644 static int
8645 gfc_count_forall_iterators (gfc_code *code)
8646 {
8647 int max_iters, sub_iters, current_iters;
8648 gfc_forall_iterator *fa;
8649
8650 gcc_assert(code->op == EXEC_FORALL);
8651 max_iters = 0;
8652 current_iters = 0;
8653
8654 for (fa = code->ext.forall_iterator; fa; fa = fa->next)
8655 current_iters ++;
8656
8657 code = code->block->next;
8658
8659 while (code)
8660 {
8661 if (code->op == EXEC_FORALL)
8662 {
8663 sub_iters = gfc_count_forall_iterators (code);
8664 if (sub_iters > max_iters)
8665 max_iters = sub_iters;
8666 }
8667 code = code->next;
8668 }
8669
8670 return current_iters + max_iters;
8671 }
8672
8673
8674 /* Given a FORALL construct, first resolve the FORALL iterator, then call
8675 gfc_resolve_forall_body to resolve the FORALL body. */
8676
8677 static void
8678 gfc_resolve_forall (gfc_code *code, gfc_namespace *ns, int forall_save)
8679 {
8680 static gfc_expr **var_expr;
8681 static int total_var = 0;
8682 static int nvar = 0;
8683 int old_nvar, tmp;
8684 gfc_forall_iterator *fa;
8685 int i;
8686
8687 old_nvar = nvar;
8688
8689 /* Start to resolve a FORALL construct */
8690 if (forall_save == 0)
8691 {
8692 /* Count the total number of FORALL index in the nested FORALL
8693 construct in order to allocate the VAR_EXPR with proper size. */
8694 total_var = gfc_count_forall_iterators (code);
8695
8696 /* Allocate VAR_EXPR with NUMBER_OF_FORALL_INDEX elements. */
8697 var_expr = XCNEWVEC (gfc_expr *, total_var);
8698 }
8699
8700 /* The information about FORALL iterator, including FORALL index start, end
8701 and stride. The FORALL index can not appear in start, end or stride. */
8702 for (fa = code->ext.forall_iterator; fa; fa = fa->next)
8703 {
8704 /* Check if any outer FORALL index name is the same as the current
8705 one. */
8706 for (i = 0; i < nvar; i++)
8707 {
8708 if (fa->var->symtree->n.sym == var_expr[i]->symtree->n.sym)
8709 {
8710 gfc_error ("An outer FORALL construct already has an index "
8711 "with this name %L", &fa->var->where);
8712 }
8713 }
8714
8715 /* Record the current FORALL index. */
8716 var_expr[nvar] = gfc_copy_expr (fa->var);
8717
8718 nvar++;
8719
8720 /* No memory leak. */
8721 gcc_assert (nvar <= total_var);
8722 }
8723
8724 /* Resolve the FORALL body. */
8725 gfc_resolve_forall_body (code, nvar, var_expr);
8726
8727 /* May call gfc_resolve_forall to resolve the inner FORALL loop. */
8728 gfc_resolve_blocks (code->block, ns);
8729
8730 tmp = nvar;
8731 nvar = old_nvar;
8732 /* Free only the VAR_EXPRs allocated in this frame. */
8733 for (i = nvar; i < tmp; i++)
8734 gfc_free_expr (var_expr[i]);
8735
8736 if (nvar == 0)
8737 {
8738 /* We are in the outermost FORALL construct. */
8739 gcc_assert (forall_save == 0);
8740
8741 /* VAR_EXPR is not needed any more. */
8742 free (var_expr);
8743 total_var = 0;
8744 }
8745 }
8746
8747
8748 /* Resolve a BLOCK construct statement. */
8749
8750 static void
8751 resolve_block_construct (gfc_code* code)
8752 {
8753 /* Resolve the BLOCK's namespace. */
8754 gfc_resolve (code->ext.block.ns);
8755
8756 /* For an ASSOCIATE block, the associations (and their targets) are already
8757 resolved during resolve_symbol. */
8758 }
8759
8760
8761 /* Resolve lists of blocks found in IF, SELECT CASE, WHERE, FORALL, GOTO and
8762 DO code nodes. */
8763
8764 static void resolve_code (gfc_code *, gfc_namespace *);
8765
8766 void
8767 gfc_resolve_blocks (gfc_code *b, gfc_namespace *ns)
8768 {
8769 gfc_try t;
8770
8771 for (; b; b = b->block)
8772 {
8773 t = gfc_resolve_expr (b->expr1);
8774 if (gfc_resolve_expr (b->expr2) == FAILURE)
8775 t = FAILURE;
8776
8777 switch (b->op)
8778 {
8779 case EXEC_IF:
8780 if (t == SUCCESS && b->expr1 != NULL
8781 && (b->expr1->ts.type != BT_LOGICAL || b->expr1->rank != 0))
8782 gfc_error ("IF clause at %L requires a scalar LOGICAL expression",
8783 &b->expr1->where);
8784 break;
8785
8786 case EXEC_WHERE:
8787 if (t == SUCCESS
8788 && b->expr1 != NULL
8789 && (b->expr1->ts.type != BT_LOGICAL || b->expr1->rank == 0))
8790 gfc_error ("WHERE/ELSEWHERE clause at %L requires a LOGICAL array",
8791 &b->expr1->where);
8792 break;
8793
8794 case EXEC_GOTO:
8795 resolve_branch (b->label1, b);
8796 break;
8797
8798 case EXEC_BLOCK:
8799 resolve_block_construct (b);
8800 break;
8801
8802 case EXEC_SELECT:
8803 case EXEC_SELECT_TYPE:
8804 case EXEC_FORALL:
8805 case EXEC_DO:
8806 case EXEC_DO_WHILE:
8807 case EXEC_CRITICAL:
8808 case EXEC_READ:
8809 case EXEC_WRITE:
8810 case EXEC_IOLENGTH:
8811 case EXEC_WAIT:
8812 break;
8813
8814 case EXEC_OMP_ATOMIC:
8815 case EXEC_OMP_CRITICAL:
8816 case EXEC_OMP_DO:
8817 case EXEC_OMP_MASTER:
8818 case EXEC_OMP_ORDERED:
8819 case EXEC_OMP_PARALLEL:
8820 case EXEC_OMP_PARALLEL_DO:
8821 case EXEC_OMP_PARALLEL_SECTIONS:
8822 case EXEC_OMP_PARALLEL_WORKSHARE:
8823 case EXEC_OMP_SECTIONS:
8824 case EXEC_OMP_SINGLE:
8825 case EXEC_OMP_TASK:
8826 case EXEC_OMP_TASKWAIT:
8827 case EXEC_OMP_WORKSHARE:
8828 break;
8829
8830 default:
8831 gfc_internal_error ("gfc_resolve_blocks(): Bad block type");
8832 }
8833
8834 resolve_code (b->next, ns);
8835 }
8836 }
8837
8838
8839 /* Does everything to resolve an ordinary assignment. Returns true
8840 if this is an interface assignment. */
8841 static bool
8842 resolve_ordinary_assign (gfc_code *code, gfc_namespace *ns)
8843 {
8844 bool rval = false;
8845 gfc_expr *lhs;
8846 gfc_expr *rhs;
8847 int llen = 0;
8848 int rlen = 0;
8849 int n;
8850 gfc_ref *ref;
8851
8852 if (gfc_extend_assign (code, ns) == SUCCESS)
8853 {
8854 gfc_expr** rhsptr;
8855
8856 if (code->op == EXEC_ASSIGN_CALL)
8857 {
8858 lhs = code->ext.actual->expr;
8859 rhsptr = &code->ext.actual->next->expr;
8860 }
8861 else
8862 {
8863 gfc_actual_arglist* args;
8864 gfc_typebound_proc* tbp;
8865
8866 gcc_assert (code->op == EXEC_COMPCALL);
8867
8868 args = code->expr1->value.compcall.actual;
8869 lhs = args->expr;
8870 rhsptr = &args->next->expr;
8871
8872 tbp = code->expr1->value.compcall.tbp;
8873 gcc_assert (!tbp->is_generic);
8874 }
8875
8876 /* Make a temporary rhs when there is a default initializer
8877 and rhs is the same symbol as the lhs. */
8878 if ((*rhsptr)->expr_type == EXPR_VARIABLE
8879 && (*rhsptr)->symtree->n.sym->ts.type == BT_DERIVED
8880 && gfc_has_default_initializer ((*rhsptr)->symtree->n.sym->ts.u.derived)
8881 && (lhs->symtree->n.sym == (*rhsptr)->symtree->n.sym))
8882 *rhsptr = gfc_get_parentheses (*rhsptr);
8883
8884 return true;
8885 }
8886
8887 lhs = code->expr1;
8888 rhs = code->expr2;
8889
8890 if (rhs->is_boz
8891 && gfc_notify_std (GFC_STD_GNU, "Extension: BOZ literal at %L outside "
8892 "a DATA statement and outside INT/REAL/DBLE/CMPLX",
8893 &code->loc) == FAILURE)
8894 return false;
8895
8896 /* Handle the case of a BOZ literal on the RHS. */
8897 if (rhs->is_boz && lhs->ts.type != BT_INTEGER)
8898 {
8899 int rc;
8900 if (gfc_option.warn_surprising)
8901 gfc_warning ("BOZ literal at %L is bitwise transferred "
8902 "non-integer symbol '%s'", &code->loc,
8903 lhs->symtree->n.sym->name);
8904
8905 if (!gfc_convert_boz (rhs, &lhs->ts))
8906 return false;
8907 if ((rc = gfc_range_check (rhs)) != ARITH_OK)
8908 {
8909 if (rc == ARITH_UNDERFLOW)
8910 gfc_error ("Arithmetic underflow of bit-wise transferred BOZ at %L"
8911 ". This check can be disabled with the option "
8912 "-fno-range-check", &rhs->where);
8913 else if (rc == ARITH_OVERFLOW)
8914 gfc_error ("Arithmetic overflow of bit-wise transferred BOZ at %L"
8915 ". This check can be disabled with the option "
8916 "-fno-range-check", &rhs->where);
8917 else if (rc == ARITH_NAN)
8918 gfc_error ("Arithmetic NaN of bit-wise transferred BOZ at %L"
8919 ". This check can be disabled with the option "
8920 "-fno-range-check", &rhs->where);
8921 return false;
8922 }
8923 }
8924
8925 if (lhs->ts.type == BT_CHARACTER
8926 && gfc_option.warn_character_truncation)
8927 {
8928 if (lhs->ts.u.cl != NULL
8929 && lhs->ts.u.cl->length != NULL
8930 && lhs->ts.u.cl->length->expr_type == EXPR_CONSTANT)
8931 llen = mpz_get_si (lhs->ts.u.cl->length->value.integer);
8932
8933 if (rhs->expr_type == EXPR_CONSTANT)
8934 rlen = rhs->value.character.length;
8935
8936 else if (rhs->ts.u.cl != NULL
8937 && rhs->ts.u.cl->length != NULL
8938 && rhs->ts.u.cl->length->expr_type == EXPR_CONSTANT)
8939 rlen = mpz_get_si (rhs->ts.u.cl->length->value.integer);
8940
8941 if (rlen && llen && rlen > llen)
8942 gfc_warning_now ("CHARACTER expression will be truncated "
8943 "in assignment (%d/%d) at %L",
8944 llen, rlen, &code->loc);
8945 }
8946
8947 /* Ensure that a vector index expression for the lvalue is evaluated
8948 to a temporary if the lvalue symbol is referenced in it. */
8949 if (lhs->rank)
8950 {
8951 for (ref = lhs->ref; ref; ref= ref->next)
8952 if (ref->type == REF_ARRAY)
8953 {
8954 for (n = 0; n < ref->u.ar.dimen; n++)
8955 if (ref->u.ar.dimen_type[n] == DIMEN_VECTOR
8956 && gfc_find_sym_in_expr (lhs->symtree->n.sym,
8957 ref->u.ar.start[n]))
8958 ref->u.ar.start[n]
8959 = gfc_get_parentheses (ref->u.ar.start[n]);
8960 }
8961 }
8962
8963 if (gfc_pure (NULL))
8964 {
8965 if (lhs->ts.type == BT_DERIVED
8966 && lhs->expr_type == EXPR_VARIABLE
8967 && lhs->ts.u.derived->attr.pointer_comp
8968 && rhs->expr_type == EXPR_VARIABLE
8969 && (gfc_impure_variable (rhs->symtree->n.sym)
8970 || gfc_is_coindexed (rhs)))
8971 {
8972 /* F2008, C1283. */
8973 if (gfc_is_coindexed (rhs))
8974 gfc_error ("Coindexed expression at %L is assigned to "
8975 "a derived type variable with a POINTER "
8976 "component in a PURE procedure",
8977 &rhs->where);
8978 else
8979 gfc_error ("The impure variable at %L is assigned to "
8980 "a derived type variable with a POINTER "
8981 "component in a PURE procedure (12.6)",
8982 &rhs->where);
8983 return rval;
8984 }
8985
8986 /* Fortran 2008, C1283. */
8987 if (gfc_is_coindexed (lhs))
8988 {
8989 gfc_error ("Assignment to coindexed variable at %L in a PURE "
8990 "procedure", &rhs->where);
8991 return rval;
8992 }
8993 }
8994
8995 if (gfc_implicit_pure (NULL))
8996 {
8997 if (lhs->expr_type == EXPR_VARIABLE
8998 && lhs->symtree->n.sym != gfc_current_ns->proc_name
8999 && lhs->symtree->n.sym->ns != gfc_current_ns)
9000 gfc_current_ns->proc_name->attr.implicit_pure = 0;
9001
9002 if (lhs->ts.type == BT_DERIVED
9003 && lhs->expr_type == EXPR_VARIABLE
9004 && lhs->ts.u.derived->attr.pointer_comp
9005 && rhs->expr_type == EXPR_VARIABLE
9006 && (gfc_impure_variable (rhs->symtree->n.sym)
9007 || gfc_is_coindexed (rhs)))
9008 gfc_current_ns->proc_name->attr.implicit_pure = 0;
9009
9010 /* Fortran 2008, C1283. */
9011 if (gfc_is_coindexed (lhs))
9012 gfc_current_ns->proc_name->attr.implicit_pure = 0;
9013 }
9014
9015 /* F03:7.4.1.2. */
9016 /* FIXME: Valid in Fortran 2008, unless the LHS is both polymorphic
9017 and coindexed; cf. F2008, 7.2.1.2 and PR 43366. */
9018 if (lhs->ts.type == BT_CLASS)
9019 {
9020 gfc_error ("Variable must not be polymorphic in assignment at %L",
9021 &lhs->where);
9022 return false;
9023 }
9024
9025 /* F2008, Section 7.2.1.2. */
9026 if (gfc_is_coindexed (lhs) && gfc_has_ultimate_allocatable (lhs))
9027 {
9028 gfc_error ("Coindexed variable must not be have an allocatable ultimate "
9029 "component in assignment at %L", &lhs->where);
9030 return false;
9031 }
9032
9033 gfc_check_assign (lhs, rhs, 1);
9034 return false;
9035 }
9036
9037
9038 /* Given a block of code, recursively resolve everything pointed to by this
9039 code block. */
9040
9041 static void
9042 resolve_code (gfc_code *code, gfc_namespace *ns)
9043 {
9044 int omp_workshare_save;
9045 int forall_save;
9046 code_stack frame;
9047 gfc_try t;
9048
9049 frame.prev = cs_base;
9050 frame.head = code;
9051 cs_base = &frame;
9052
9053 find_reachable_labels (code);
9054
9055 for (; code; code = code->next)
9056 {
9057 frame.current = code;
9058 forall_save = forall_flag;
9059
9060 if (code->op == EXEC_FORALL)
9061 {
9062 forall_flag = 1;
9063 gfc_resolve_forall (code, ns, forall_save);
9064 forall_flag = 2;
9065 }
9066 else if (code->block)
9067 {
9068 omp_workshare_save = -1;
9069 switch (code->op)
9070 {
9071 case EXEC_OMP_PARALLEL_WORKSHARE:
9072 omp_workshare_save = omp_workshare_flag;
9073 omp_workshare_flag = 1;
9074 gfc_resolve_omp_parallel_blocks (code, ns);
9075 break;
9076 case EXEC_OMP_PARALLEL:
9077 case EXEC_OMP_PARALLEL_DO:
9078 case EXEC_OMP_PARALLEL_SECTIONS:
9079 case EXEC_OMP_TASK:
9080 omp_workshare_save = omp_workshare_flag;
9081 omp_workshare_flag = 0;
9082 gfc_resolve_omp_parallel_blocks (code, ns);
9083 break;
9084 case EXEC_OMP_DO:
9085 gfc_resolve_omp_do_blocks (code, ns);
9086 break;
9087 case EXEC_SELECT_TYPE:
9088 /* Blocks are handled in resolve_select_type because we have
9089 to transform the SELECT TYPE into ASSOCIATE first. */
9090 break;
9091 case EXEC_OMP_WORKSHARE:
9092 omp_workshare_save = omp_workshare_flag;
9093 omp_workshare_flag = 1;
9094 /* FALLTHROUGH */
9095 default:
9096 gfc_resolve_blocks (code->block, ns);
9097 break;
9098 }
9099
9100 if (omp_workshare_save != -1)
9101 omp_workshare_flag = omp_workshare_save;
9102 }
9103
9104 t = SUCCESS;
9105 if (code->op != EXEC_COMPCALL && code->op != EXEC_CALL_PPC)
9106 t = gfc_resolve_expr (code->expr1);
9107 forall_flag = forall_save;
9108
9109 if (gfc_resolve_expr (code->expr2) == FAILURE)
9110 t = FAILURE;
9111
9112 if (code->op == EXEC_ALLOCATE
9113 && gfc_resolve_expr (code->expr3) == FAILURE)
9114 t = FAILURE;
9115
9116 switch (code->op)
9117 {
9118 case EXEC_NOP:
9119 case EXEC_END_BLOCK:
9120 case EXEC_CYCLE:
9121 case EXEC_PAUSE:
9122 case EXEC_STOP:
9123 case EXEC_ERROR_STOP:
9124 case EXEC_EXIT:
9125 case EXEC_CONTINUE:
9126 case EXEC_DT_END:
9127 case EXEC_ASSIGN_CALL:
9128 case EXEC_CRITICAL:
9129 break;
9130
9131 case EXEC_SYNC_ALL:
9132 case EXEC_SYNC_IMAGES:
9133 case EXEC_SYNC_MEMORY:
9134 resolve_sync (code);
9135 break;
9136
9137 case EXEC_LOCK:
9138 case EXEC_UNLOCK:
9139 resolve_lock_unlock (code);
9140 break;
9141
9142 case EXEC_ENTRY:
9143 /* Keep track of which entry we are up to. */
9144 current_entry_id = code->ext.entry->id;
9145 break;
9146
9147 case EXEC_WHERE:
9148 resolve_where (code, NULL);
9149 break;
9150
9151 case EXEC_GOTO:
9152 if (code->expr1 != NULL)
9153 {
9154 if (code->expr1->ts.type != BT_INTEGER)
9155 gfc_error ("ASSIGNED GOTO statement at %L requires an "
9156 "INTEGER variable", &code->expr1->where);
9157 else if (code->expr1->symtree->n.sym->attr.assign != 1)
9158 gfc_error ("Variable '%s' has not been assigned a target "
9159 "label at %L", code->expr1->symtree->n.sym->name,
9160 &code->expr1->where);
9161 }
9162 else
9163 resolve_branch (code->label1, code);
9164 break;
9165
9166 case EXEC_RETURN:
9167 if (code->expr1 != NULL
9168 && (code->expr1->ts.type != BT_INTEGER || code->expr1->rank))
9169 gfc_error ("Alternate RETURN statement at %L requires a SCALAR-"
9170 "INTEGER return specifier", &code->expr1->where);
9171 break;
9172
9173 case EXEC_INIT_ASSIGN:
9174 case EXEC_END_PROCEDURE:
9175 break;
9176
9177 case EXEC_ASSIGN:
9178 if (t == FAILURE)
9179 break;
9180
9181 if (gfc_check_vardef_context (code->expr1, false, false,
9182 _("assignment")) == FAILURE)
9183 break;
9184
9185 if (resolve_ordinary_assign (code, ns))
9186 {
9187 if (code->op == EXEC_COMPCALL)
9188 goto compcall;
9189 else
9190 goto call;
9191 }
9192 break;
9193
9194 case EXEC_LABEL_ASSIGN:
9195 if (code->label1->defined == ST_LABEL_UNKNOWN)
9196 gfc_error ("Label %d referenced at %L is never defined",
9197 code->label1->value, &code->label1->where);
9198 if (t == SUCCESS
9199 && (code->expr1->expr_type != EXPR_VARIABLE
9200 || code->expr1->symtree->n.sym->ts.type != BT_INTEGER
9201 || code->expr1->symtree->n.sym->ts.kind
9202 != gfc_default_integer_kind
9203 || code->expr1->symtree->n.sym->as != NULL))
9204 gfc_error ("ASSIGN statement at %L requires a scalar "
9205 "default INTEGER variable", &code->expr1->where);
9206 break;
9207
9208 case EXEC_POINTER_ASSIGN:
9209 {
9210 gfc_expr* e;
9211
9212 if (t == FAILURE)
9213 break;
9214
9215 /* This is both a variable definition and pointer assignment
9216 context, so check both of them. For rank remapping, a final
9217 array ref may be present on the LHS and fool gfc_expr_attr
9218 used in gfc_check_vardef_context. Remove it. */
9219 e = remove_last_array_ref (code->expr1);
9220 t = gfc_check_vardef_context (e, true, false,
9221 _("pointer assignment"));
9222 if (t == SUCCESS)
9223 t = gfc_check_vardef_context (e, false, false,
9224 _("pointer assignment"));
9225 gfc_free_expr (e);
9226 if (t == FAILURE)
9227 break;
9228
9229 gfc_check_pointer_assign (code->expr1, code->expr2);
9230 break;
9231 }
9232
9233 case EXEC_ARITHMETIC_IF:
9234 if (t == SUCCESS
9235 && code->expr1->ts.type != BT_INTEGER
9236 && code->expr1->ts.type != BT_REAL)
9237 gfc_error ("Arithmetic IF statement at %L requires a numeric "
9238 "expression", &code->expr1->where);
9239
9240 resolve_branch (code->label1, code);
9241 resolve_branch (code->label2, code);
9242 resolve_branch (code->label3, code);
9243 break;
9244
9245 case EXEC_IF:
9246 if (t == SUCCESS && code->expr1 != NULL
9247 && (code->expr1->ts.type != BT_LOGICAL
9248 || code->expr1->rank != 0))
9249 gfc_error ("IF clause at %L requires a scalar LOGICAL expression",
9250 &code->expr1->where);
9251 break;
9252
9253 case EXEC_CALL:
9254 call:
9255 resolve_call (code);
9256 break;
9257
9258 case EXEC_COMPCALL:
9259 compcall:
9260 resolve_typebound_subroutine (code);
9261 break;
9262
9263 case EXEC_CALL_PPC:
9264 resolve_ppc_call (code);
9265 break;
9266
9267 case EXEC_SELECT:
9268 /* Select is complicated. Also, a SELECT construct could be
9269 a transformed computed GOTO. */
9270 resolve_select (code);
9271 break;
9272
9273 case EXEC_SELECT_TYPE:
9274 resolve_select_type (code, ns);
9275 break;
9276
9277 case EXEC_BLOCK:
9278 resolve_block_construct (code);
9279 break;
9280
9281 case EXEC_DO:
9282 if (code->ext.iterator != NULL)
9283 {
9284 gfc_iterator *iter = code->ext.iterator;
9285 if (gfc_resolve_iterator (iter, true) != FAILURE)
9286 gfc_resolve_do_iterator (code, iter->var->symtree->n.sym);
9287 }
9288 break;
9289
9290 case EXEC_DO_WHILE:
9291 if (code->expr1 == NULL)
9292 gfc_internal_error ("resolve_code(): No expression on DO WHILE");
9293 if (t == SUCCESS
9294 && (code->expr1->rank != 0
9295 || code->expr1->ts.type != BT_LOGICAL))
9296 gfc_error ("Exit condition of DO WHILE loop at %L must be "
9297 "a scalar LOGICAL expression", &code->expr1->where);
9298 break;
9299
9300 case EXEC_ALLOCATE:
9301 if (t == SUCCESS)
9302 resolve_allocate_deallocate (code, "ALLOCATE");
9303
9304 break;
9305
9306 case EXEC_DEALLOCATE:
9307 if (t == SUCCESS)
9308 resolve_allocate_deallocate (code, "DEALLOCATE");
9309
9310 break;
9311
9312 case EXEC_OPEN:
9313 if (gfc_resolve_open (code->ext.open) == FAILURE)
9314 break;
9315
9316 resolve_branch (code->ext.open->err, code);
9317 break;
9318
9319 case EXEC_CLOSE:
9320 if (gfc_resolve_close (code->ext.close) == FAILURE)
9321 break;
9322
9323 resolve_branch (code->ext.close->err, code);
9324 break;
9325
9326 case EXEC_BACKSPACE:
9327 case EXEC_ENDFILE:
9328 case EXEC_REWIND:
9329 case EXEC_FLUSH:
9330 if (gfc_resolve_filepos (code->ext.filepos) == FAILURE)
9331 break;
9332
9333 resolve_branch (code->ext.filepos->err, code);
9334 break;
9335
9336 case EXEC_INQUIRE:
9337 if (gfc_resolve_inquire (code->ext.inquire) == FAILURE)
9338 break;
9339
9340 resolve_branch (code->ext.inquire->err, code);
9341 break;
9342
9343 case EXEC_IOLENGTH:
9344 gcc_assert (code->ext.inquire != NULL);
9345 if (gfc_resolve_inquire (code->ext.inquire) == FAILURE)
9346 break;
9347
9348 resolve_branch (code->ext.inquire->err, code);
9349 break;
9350
9351 case EXEC_WAIT:
9352 if (gfc_resolve_wait (code->ext.wait) == FAILURE)
9353 break;
9354
9355 resolve_branch (code->ext.wait->err, code);
9356 resolve_branch (code->ext.wait->end, code);
9357 resolve_branch (code->ext.wait->eor, code);
9358 break;
9359
9360 case EXEC_READ:
9361 case EXEC_WRITE:
9362 if (gfc_resolve_dt (code->ext.dt, &code->loc) == FAILURE)
9363 break;
9364
9365 resolve_branch (code->ext.dt->err, code);
9366 resolve_branch (code->ext.dt->end, code);
9367 resolve_branch (code->ext.dt->eor, code);
9368 break;
9369
9370 case EXEC_TRANSFER:
9371 resolve_transfer (code);
9372 break;
9373
9374 case EXEC_FORALL:
9375 resolve_forall_iterators (code->ext.forall_iterator);
9376
9377 if (code->expr1 != NULL
9378 && (code->expr1->ts.type != BT_LOGICAL || code->expr1->rank))
9379 gfc_error ("FORALL mask clause at %L requires a scalar LOGICAL "
9380 "expression", &code->expr1->where);
9381 break;
9382
9383 case EXEC_OMP_ATOMIC:
9384 case EXEC_OMP_BARRIER:
9385 case EXEC_OMP_CRITICAL:
9386 case EXEC_OMP_FLUSH:
9387 case EXEC_OMP_DO:
9388 case EXEC_OMP_MASTER:
9389 case EXEC_OMP_ORDERED:
9390 case EXEC_OMP_SECTIONS:
9391 case EXEC_OMP_SINGLE:
9392 case EXEC_OMP_TASKWAIT:
9393 case EXEC_OMP_WORKSHARE:
9394 gfc_resolve_omp_directive (code, ns);
9395 break;
9396
9397 case EXEC_OMP_PARALLEL:
9398 case EXEC_OMP_PARALLEL_DO:
9399 case EXEC_OMP_PARALLEL_SECTIONS:
9400 case EXEC_OMP_PARALLEL_WORKSHARE:
9401 case EXEC_OMP_TASK:
9402 omp_workshare_save = omp_workshare_flag;
9403 omp_workshare_flag = 0;
9404 gfc_resolve_omp_directive (code, ns);
9405 omp_workshare_flag = omp_workshare_save;
9406 break;
9407
9408 default:
9409 gfc_internal_error ("resolve_code(): Bad statement code");
9410 }
9411 }
9412
9413 cs_base = frame.prev;
9414 }
9415
9416
9417 /* Resolve initial values and make sure they are compatible with
9418 the variable. */
9419
9420 static void
9421 resolve_values (gfc_symbol *sym)
9422 {
9423 gfc_try t;
9424
9425 if (sym->value == NULL)
9426 return;
9427
9428 if (sym->value->expr_type == EXPR_STRUCTURE)
9429 t= resolve_structure_cons (sym->value, 1);
9430 else
9431 t = gfc_resolve_expr (sym->value);
9432
9433 if (t == FAILURE)
9434 return;
9435
9436 gfc_check_assign_symbol (sym, sym->value);
9437 }
9438
9439
9440 /* Verify the binding labels for common blocks that are BIND(C). The label
9441 for a BIND(C) common block must be identical in all scoping units in which
9442 the common block is declared. Further, the binding label can not collide
9443 with any other global entity in the program. */
9444
9445 static void
9446 resolve_bind_c_comms (gfc_symtree *comm_block_tree)
9447 {
9448 if (comm_block_tree->n.common->is_bind_c == 1)
9449 {
9450 gfc_gsymbol *binding_label_gsym;
9451 gfc_gsymbol *comm_name_gsym;
9452
9453 /* See if a global symbol exists by the common block's name. It may
9454 be NULL if the common block is use-associated. */
9455 comm_name_gsym = gfc_find_gsymbol (gfc_gsym_root,
9456 comm_block_tree->n.common->name);
9457 if (comm_name_gsym != NULL && comm_name_gsym->type != GSYM_COMMON)
9458 gfc_error ("Binding label '%s' for common block '%s' at %L collides "
9459 "with the global entity '%s' at %L",
9460 comm_block_tree->n.common->binding_label,
9461 comm_block_tree->n.common->name,
9462 &(comm_block_tree->n.common->where),
9463 comm_name_gsym->name, &(comm_name_gsym->where));
9464 else if (comm_name_gsym != NULL
9465 && strcmp (comm_name_gsym->name,
9466 comm_block_tree->n.common->name) == 0)
9467 {
9468 /* TODO: Need to make sure the fields of gfc_gsymbol are initialized
9469 as expected. */
9470 if (comm_name_gsym->binding_label == NULL)
9471 /* No binding label for common block stored yet; save this one. */
9472 comm_name_gsym->binding_label =
9473 comm_block_tree->n.common->binding_label;
9474 else
9475 if (strcmp (comm_name_gsym->binding_label,
9476 comm_block_tree->n.common->binding_label) != 0)
9477 {
9478 /* Common block names match but binding labels do not. */
9479 gfc_error ("Binding label '%s' for common block '%s' at %L "
9480 "does not match the binding label '%s' for common "
9481 "block '%s' at %L",
9482 comm_block_tree->n.common->binding_label,
9483 comm_block_tree->n.common->name,
9484 &(comm_block_tree->n.common->where),
9485 comm_name_gsym->binding_label,
9486 comm_name_gsym->name,
9487 &(comm_name_gsym->where));
9488 return;
9489 }
9490 }
9491
9492 /* There is no binding label (NAME="") so we have nothing further to
9493 check and nothing to add as a global symbol for the label. */
9494 if (comm_block_tree->n.common->binding_label[0] == '\0' )
9495 return;
9496
9497 binding_label_gsym =
9498 gfc_find_gsymbol (gfc_gsym_root,
9499 comm_block_tree->n.common->binding_label);
9500 if (binding_label_gsym == NULL)
9501 {
9502 /* Need to make a global symbol for the binding label to prevent
9503 it from colliding with another. */
9504 binding_label_gsym =
9505 gfc_get_gsymbol (comm_block_tree->n.common->binding_label);
9506 binding_label_gsym->sym_name = comm_block_tree->n.common->name;
9507 binding_label_gsym->type = GSYM_COMMON;
9508 }
9509 else
9510 {
9511 /* If comm_name_gsym is NULL, the name common block is use
9512 associated and the name could be colliding. */
9513 if (binding_label_gsym->type != GSYM_COMMON)
9514 gfc_error ("Binding label '%s' for common block '%s' at %L "
9515 "collides with the global entity '%s' at %L",
9516 comm_block_tree->n.common->binding_label,
9517 comm_block_tree->n.common->name,
9518 &(comm_block_tree->n.common->where),
9519 binding_label_gsym->name,
9520 &(binding_label_gsym->where));
9521 else if (comm_name_gsym != NULL
9522 && (strcmp (binding_label_gsym->name,
9523 comm_name_gsym->binding_label) != 0)
9524 && (strcmp (binding_label_gsym->sym_name,
9525 comm_name_gsym->name) != 0))
9526 gfc_error ("Binding label '%s' for common block '%s' at %L "
9527 "collides with global entity '%s' at %L",
9528 binding_label_gsym->name, binding_label_gsym->sym_name,
9529 &(comm_block_tree->n.common->where),
9530 comm_name_gsym->name, &(comm_name_gsym->where));
9531 }
9532 }
9533
9534 return;
9535 }
9536
9537
9538 /* Verify any BIND(C) derived types in the namespace so we can report errors
9539 for them once, rather than for each variable declared of that type. */
9540
9541 static void
9542 resolve_bind_c_derived_types (gfc_symbol *derived_sym)
9543 {
9544 if (derived_sym != NULL && derived_sym->attr.flavor == FL_DERIVED
9545 && derived_sym->attr.is_bind_c == 1)
9546 verify_bind_c_derived_type (derived_sym);
9547
9548 return;
9549 }
9550
9551
9552 /* Verify that any binding labels used in a given namespace do not collide
9553 with the names or binding labels of any global symbols. */
9554
9555 static void
9556 gfc_verify_binding_labels (gfc_symbol *sym)
9557 {
9558 int has_error = 0;
9559
9560 if (sym != NULL && sym->attr.is_bind_c && sym->attr.is_iso_c == 0
9561 && sym->attr.flavor != FL_DERIVED && sym->binding_label[0] != '\0')
9562 {
9563 gfc_gsymbol *bind_c_sym;
9564
9565 bind_c_sym = gfc_find_gsymbol (gfc_gsym_root, sym->binding_label);
9566 if (bind_c_sym != NULL
9567 && strcmp (bind_c_sym->name, sym->binding_label) == 0)
9568 {
9569 if (sym->attr.if_source == IFSRC_DECL
9570 && (bind_c_sym->type != GSYM_SUBROUTINE
9571 && bind_c_sym->type != GSYM_FUNCTION)
9572 && ((sym->attr.contained == 1
9573 && strcmp (bind_c_sym->sym_name, sym->name) != 0)
9574 || (sym->attr.use_assoc == 1
9575 && (strcmp (bind_c_sym->mod_name, sym->module) != 0))))
9576 {
9577 /* Make sure global procedures don't collide with anything. */
9578 gfc_error ("Binding label '%s' at %L collides with the global "
9579 "entity '%s' at %L", sym->binding_label,
9580 &(sym->declared_at), bind_c_sym->name,
9581 &(bind_c_sym->where));
9582 has_error = 1;
9583 }
9584 else if (sym->attr.contained == 0
9585 && (sym->attr.if_source == IFSRC_IFBODY
9586 && sym->attr.flavor == FL_PROCEDURE)
9587 && (bind_c_sym->sym_name != NULL
9588 && strcmp (bind_c_sym->sym_name, sym->name) != 0))
9589 {
9590 /* Make sure procedures in interface bodies don't collide. */
9591 gfc_error ("Binding label '%s' in interface body at %L collides "
9592 "with the global entity '%s' at %L",
9593 sym->binding_label,
9594 &(sym->declared_at), bind_c_sym->name,
9595 &(bind_c_sym->where));
9596 has_error = 1;
9597 }
9598 else if (sym->attr.contained == 0
9599 && sym->attr.if_source == IFSRC_UNKNOWN)
9600 if ((sym->attr.use_assoc && bind_c_sym->mod_name
9601 && strcmp (bind_c_sym->mod_name, sym->module) != 0)
9602 || sym->attr.use_assoc == 0)
9603 {
9604 gfc_error ("Binding label '%s' at %L collides with global "
9605 "entity '%s' at %L", sym->binding_label,
9606 &(sym->declared_at), bind_c_sym->name,
9607 &(bind_c_sym->where));
9608 has_error = 1;
9609 }
9610
9611 if (has_error != 0)
9612 /* Clear the binding label to prevent checking multiple times. */
9613 sym->binding_label[0] = '\0';
9614 }
9615 else if (bind_c_sym == NULL)
9616 {
9617 bind_c_sym = gfc_get_gsymbol (sym->binding_label);
9618 bind_c_sym->where = sym->declared_at;
9619 bind_c_sym->sym_name = sym->name;
9620
9621 if (sym->attr.use_assoc == 1)
9622 bind_c_sym->mod_name = sym->module;
9623 else
9624 if (sym->ns->proc_name != NULL)
9625 bind_c_sym->mod_name = sym->ns->proc_name->name;
9626
9627 if (sym->attr.contained == 0)
9628 {
9629 if (sym->attr.subroutine)
9630 bind_c_sym->type = GSYM_SUBROUTINE;
9631 else if (sym->attr.function)
9632 bind_c_sym->type = GSYM_FUNCTION;
9633 }
9634 }
9635 }
9636 return;
9637 }
9638
9639
9640 /* Resolve an index expression. */
9641
9642 static gfc_try
9643 resolve_index_expr (gfc_expr *e)
9644 {
9645 if (gfc_resolve_expr (e) == FAILURE)
9646 return FAILURE;
9647
9648 if (gfc_simplify_expr (e, 0) == FAILURE)
9649 return FAILURE;
9650
9651 if (gfc_specification_expr (e) == FAILURE)
9652 return FAILURE;
9653
9654 return SUCCESS;
9655 }
9656
9657
9658 /* Resolve a charlen structure. */
9659
9660 static gfc_try
9661 resolve_charlen (gfc_charlen *cl)
9662 {
9663 int i, k;
9664
9665 if (cl->resolved)
9666 return SUCCESS;
9667
9668 cl->resolved = 1;
9669
9670 specification_expr = 1;
9671
9672 if (resolve_index_expr (cl->length) == FAILURE)
9673 {
9674 specification_expr = 0;
9675 return FAILURE;
9676 }
9677
9678 /* "If the character length parameter value evaluates to a negative
9679 value, the length of character entities declared is zero." */
9680 if (cl->length && !gfc_extract_int (cl->length, &i) && i < 0)
9681 {
9682 if (gfc_option.warn_surprising)
9683 gfc_warning_now ("CHARACTER variable at %L has negative length %d,"
9684 " the length has been set to zero",
9685 &cl->length->where, i);
9686 gfc_replace_expr (cl->length,
9687 gfc_get_int_expr (gfc_default_integer_kind, NULL, 0));
9688 }
9689
9690 /* Check that the character length is not too large. */
9691 k = gfc_validate_kind (BT_INTEGER, gfc_charlen_int_kind, false);
9692 if (cl->length && cl->length->expr_type == EXPR_CONSTANT
9693 && cl->length->ts.type == BT_INTEGER
9694 && mpz_cmp (cl->length->value.integer, gfc_integer_kinds[k].huge) > 0)
9695 {
9696 gfc_error ("String length at %L is too large", &cl->length->where);
9697 return FAILURE;
9698 }
9699
9700 return SUCCESS;
9701 }
9702
9703
9704 /* Test for non-constant shape arrays. */
9705
9706 static bool
9707 is_non_constant_shape_array (gfc_symbol *sym)
9708 {
9709 gfc_expr *e;
9710 int i;
9711 bool not_constant;
9712
9713 not_constant = false;
9714 if (sym->as != NULL)
9715 {
9716 /* Unfortunately, !gfc_is_compile_time_shape hits a legal case that
9717 has not been simplified; parameter array references. Do the
9718 simplification now. */
9719 for (i = 0; i < sym->as->rank + sym->as->corank; i++)
9720 {
9721 e = sym->as->lower[i];
9722 if (e && (resolve_index_expr (e) == FAILURE
9723 || !gfc_is_constant_expr (e)))
9724 not_constant = true;
9725 e = sym->as->upper[i];
9726 if (e && (resolve_index_expr (e) == FAILURE
9727 || !gfc_is_constant_expr (e)))
9728 not_constant = true;
9729 }
9730 }
9731 return not_constant;
9732 }
9733
9734 /* Given a symbol and an initialization expression, add code to initialize
9735 the symbol to the function entry. */
9736 static void
9737 build_init_assign (gfc_symbol *sym, gfc_expr *init)
9738 {
9739 gfc_expr *lval;
9740 gfc_code *init_st;
9741 gfc_namespace *ns = sym->ns;
9742
9743 /* Search for the function namespace if this is a contained
9744 function without an explicit result. */
9745 if (sym->attr.function && sym == sym->result
9746 && sym->name != sym->ns->proc_name->name)
9747 {
9748 ns = ns->contained;
9749 for (;ns; ns = ns->sibling)
9750 if (strcmp (ns->proc_name->name, sym->name) == 0)
9751 break;
9752 }
9753
9754 if (ns == NULL)
9755 {
9756 gfc_free_expr (init);
9757 return;
9758 }
9759
9760 /* Build an l-value expression for the result. */
9761 lval = gfc_lval_expr_from_sym (sym);
9762
9763 /* Add the code at scope entry. */
9764 init_st = gfc_get_code ();
9765 init_st->next = ns->code;
9766 ns->code = init_st;
9767
9768 /* Assign the default initializer to the l-value. */
9769 init_st->loc = sym->declared_at;
9770 init_st->op = EXEC_INIT_ASSIGN;
9771 init_st->expr1 = lval;
9772 init_st->expr2 = init;
9773 }
9774
9775 /* Assign the default initializer to a derived type variable or result. */
9776
9777 static void
9778 apply_default_init (gfc_symbol *sym)
9779 {
9780 gfc_expr *init = NULL;
9781
9782 if (sym->attr.flavor != FL_VARIABLE && !sym->attr.function)
9783 return;
9784
9785 if (sym->ts.type == BT_DERIVED && sym->ts.u.derived)
9786 init = gfc_default_initializer (&sym->ts);
9787
9788 if (init == NULL && sym->ts.type != BT_CLASS)
9789 return;
9790
9791 build_init_assign (sym, init);
9792 sym->attr.referenced = 1;
9793 }
9794
9795 /* Build an initializer for a local integer, real, complex, logical, or
9796 character variable, based on the command line flags finit-local-zero,
9797 finit-integer=, finit-real=, finit-logical=, and finit-runtime. Returns
9798 null if the symbol should not have a default initialization. */
9799 static gfc_expr *
9800 build_default_init_expr (gfc_symbol *sym)
9801 {
9802 int char_len;
9803 gfc_expr *init_expr;
9804 int i;
9805
9806 /* These symbols should never have a default initialization. */
9807 if ((sym->attr.dimension && !gfc_is_compile_time_shape (sym->as))
9808 || sym->attr.external
9809 || sym->attr.dummy
9810 || sym->attr.pointer
9811 || sym->attr.in_equivalence
9812 || sym->attr.in_common
9813 || sym->attr.data
9814 || sym->module
9815 || sym->attr.cray_pointee
9816 || sym->attr.cray_pointer)
9817 return NULL;
9818
9819 /* Now we'll try to build an initializer expression. */
9820 init_expr = gfc_get_constant_expr (sym->ts.type, sym->ts.kind,
9821 &sym->declared_at);
9822
9823 /* We will only initialize integers, reals, complex, logicals, and
9824 characters, and only if the corresponding command-line flags
9825 were set. Otherwise, we free init_expr and return null. */
9826 switch (sym->ts.type)
9827 {
9828 case BT_INTEGER:
9829 if (gfc_option.flag_init_integer != GFC_INIT_INTEGER_OFF)
9830 mpz_set_si (init_expr->value.integer,
9831 gfc_option.flag_init_integer_value);
9832 else
9833 {
9834 gfc_free_expr (init_expr);
9835 init_expr = NULL;
9836 }
9837 break;
9838
9839 case BT_REAL:
9840 switch (gfc_option.flag_init_real)
9841 {
9842 case GFC_INIT_REAL_SNAN:
9843 init_expr->is_snan = 1;
9844 /* Fall through. */
9845 case GFC_INIT_REAL_NAN:
9846 mpfr_set_nan (init_expr->value.real);
9847 break;
9848
9849 case GFC_INIT_REAL_INF:
9850 mpfr_set_inf (init_expr->value.real, 1);
9851 break;
9852
9853 case GFC_INIT_REAL_NEG_INF:
9854 mpfr_set_inf (init_expr->value.real, -1);
9855 break;
9856
9857 case GFC_INIT_REAL_ZERO:
9858 mpfr_set_ui (init_expr->value.real, 0.0, GFC_RND_MODE);
9859 break;
9860
9861 default:
9862 gfc_free_expr (init_expr);
9863 init_expr = NULL;
9864 break;
9865 }
9866 break;
9867
9868 case BT_COMPLEX:
9869 switch (gfc_option.flag_init_real)
9870 {
9871 case GFC_INIT_REAL_SNAN:
9872 init_expr->is_snan = 1;
9873 /* Fall through. */
9874 case GFC_INIT_REAL_NAN:
9875 mpfr_set_nan (mpc_realref (init_expr->value.complex));
9876 mpfr_set_nan (mpc_imagref (init_expr->value.complex));
9877 break;
9878
9879 case GFC_INIT_REAL_INF:
9880 mpfr_set_inf (mpc_realref (init_expr->value.complex), 1);
9881 mpfr_set_inf (mpc_imagref (init_expr->value.complex), 1);
9882 break;
9883
9884 case GFC_INIT_REAL_NEG_INF:
9885 mpfr_set_inf (mpc_realref (init_expr->value.complex), -1);
9886 mpfr_set_inf (mpc_imagref (init_expr->value.complex), -1);
9887 break;
9888
9889 case GFC_INIT_REAL_ZERO:
9890 mpc_set_ui (init_expr->value.complex, 0, GFC_MPC_RND_MODE);
9891 break;
9892
9893 default:
9894 gfc_free_expr (init_expr);
9895 init_expr = NULL;
9896 break;
9897 }
9898 break;
9899
9900 case BT_LOGICAL:
9901 if (gfc_option.flag_init_logical == GFC_INIT_LOGICAL_FALSE)
9902 init_expr->value.logical = 0;
9903 else if (gfc_option.flag_init_logical == GFC_INIT_LOGICAL_TRUE)
9904 init_expr->value.logical = 1;
9905 else
9906 {
9907 gfc_free_expr (init_expr);
9908 init_expr = NULL;
9909 }
9910 break;
9911
9912 case BT_CHARACTER:
9913 /* For characters, the length must be constant in order to
9914 create a default initializer. */
9915 if (gfc_option.flag_init_character == GFC_INIT_CHARACTER_ON
9916 && sym->ts.u.cl->length
9917 && sym->ts.u.cl->length->expr_type == EXPR_CONSTANT)
9918 {
9919 char_len = mpz_get_si (sym->ts.u.cl->length->value.integer);
9920 init_expr->value.character.length = char_len;
9921 init_expr->value.character.string = gfc_get_wide_string (char_len+1);
9922 for (i = 0; i < char_len; i++)
9923 init_expr->value.character.string[i]
9924 = (unsigned char) gfc_option.flag_init_character_value;
9925 }
9926 else
9927 {
9928 gfc_free_expr (init_expr);
9929 init_expr = NULL;
9930 }
9931 break;
9932
9933 default:
9934 gfc_free_expr (init_expr);
9935 init_expr = NULL;
9936 }
9937 return init_expr;
9938 }
9939
9940 /* Add an initialization expression to a local variable. */
9941 static void
9942 apply_default_init_local (gfc_symbol *sym)
9943 {
9944 gfc_expr *init = NULL;
9945
9946 /* The symbol should be a variable or a function return value. */
9947 if ((sym->attr.flavor != FL_VARIABLE && !sym->attr.function)
9948 || (sym->attr.function && sym->result != sym))
9949 return;
9950
9951 /* Try to build the initializer expression. If we can't initialize
9952 this symbol, then init will be NULL. */
9953 init = build_default_init_expr (sym);
9954 if (init == NULL)
9955 return;
9956
9957 /* For saved variables, we don't want to add an initializer at
9958 function entry, so we just add a static initializer. */
9959 if (sym->attr.save || sym->ns->save_all
9960 || gfc_option.flag_max_stack_var_size == 0)
9961 {
9962 /* Don't clobber an existing initializer! */
9963 gcc_assert (sym->value == NULL);
9964 sym->value = init;
9965 return;
9966 }
9967
9968 build_init_assign (sym, init);
9969 }
9970
9971
9972 /* Resolution of common features of flavors variable and procedure. */
9973
9974 static gfc_try
9975 resolve_fl_var_and_proc (gfc_symbol *sym, int mp_flag)
9976 {
9977 /* Avoid double diagnostics for function result symbols. */
9978 if ((sym->result || sym->attr.result) && !sym->attr.dummy
9979 && (sym->ns != gfc_current_ns))
9980 return SUCCESS;
9981
9982 /* Constraints on deferred shape variable. */
9983 if (sym->as == NULL || sym->as->type != AS_DEFERRED)
9984 {
9985 if (sym->attr.allocatable)
9986 {
9987 if (sym->attr.dimension)
9988 {
9989 gfc_error ("Allocatable array '%s' at %L must have "
9990 "a deferred shape", sym->name, &sym->declared_at);
9991 return FAILURE;
9992 }
9993 else if (gfc_notify_std (GFC_STD_F2003, "Scalar object '%s' at %L "
9994 "may not be ALLOCATABLE", sym->name,
9995 &sym->declared_at) == FAILURE)
9996 return FAILURE;
9997 }
9998
9999 if (sym->attr.pointer && sym->attr.dimension)
10000 {
10001 gfc_error ("Array pointer '%s' at %L must have a deferred shape",
10002 sym->name, &sym->declared_at);
10003 return FAILURE;
10004 }
10005 }
10006 else
10007 {
10008 if (!mp_flag && !sym->attr.allocatable && !sym->attr.pointer
10009 && sym->ts.type != BT_CLASS && !sym->assoc)
10010 {
10011 gfc_error ("Array '%s' at %L cannot have a deferred shape",
10012 sym->name, &sym->declared_at);
10013 return FAILURE;
10014 }
10015 }
10016
10017 /* Constraints on polymorphic variables. */
10018 if (sym->ts.type == BT_CLASS && !(sym->result && sym->result != sym))
10019 {
10020 /* F03:C502. */
10021 if (sym->attr.class_ok
10022 && !gfc_type_is_extensible (CLASS_DATA (sym)->ts.u.derived))
10023 {
10024 gfc_error ("Type '%s' of CLASS variable '%s' at %L is not extensible",
10025 CLASS_DATA (sym)->ts.u.derived->name, sym->name,
10026 &sym->declared_at);
10027 return FAILURE;
10028 }
10029
10030 /* F03:C509. */
10031 /* Assume that use associated symbols were checked in the module ns.
10032 Class-variables that are associate-names are also something special
10033 and excepted from the test. */
10034 if (!sym->attr.class_ok && !sym->attr.use_assoc && !sym->assoc)
10035 {
10036 gfc_error ("CLASS variable '%s' at %L must be dummy, allocatable "
10037 "or pointer", sym->name, &sym->declared_at);
10038 return FAILURE;
10039 }
10040 }
10041
10042 return SUCCESS;
10043 }
10044
10045
10046 /* Additional checks for symbols with flavor variable and derived
10047 type. To be called from resolve_fl_variable. */
10048
10049 static gfc_try
10050 resolve_fl_variable_derived (gfc_symbol *sym, int no_init_flag)
10051 {
10052 gcc_assert (sym->ts.type == BT_DERIVED || sym->ts.type == BT_CLASS);
10053
10054 /* Check to see if a derived type is blocked from being host
10055 associated by the presence of another class I symbol in the same
10056 namespace. 14.6.1.3 of the standard and the discussion on
10057 comp.lang.fortran. */
10058 if (sym->ns != sym->ts.u.derived->ns
10059 && sym->ns->proc_name->attr.if_source != IFSRC_IFBODY)
10060 {
10061 gfc_symbol *s;
10062 gfc_find_symbol (sym->ts.u.derived->name, sym->ns, 0, &s);
10063 if (s && s->attr.flavor != FL_DERIVED)
10064 {
10065 gfc_error ("The type '%s' cannot be host associated at %L "
10066 "because it is blocked by an incompatible object "
10067 "of the same name declared at %L",
10068 sym->ts.u.derived->name, &sym->declared_at,
10069 &s->declared_at);
10070 return FAILURE;
10071 }
10072 }
10073
10074 /* 4th constraint in section 11.3: "If an object of a type for which
10075 component-initialization is specified (R429) appears in the
10076 specification-part of a module and does not have the ALLOCATABLE
10077 or POINTER attribute, the object shall have the SAVE attribute."
10078
10079 The check for initializers is performed with
10080 gfc_has_default_initializer because gfc_default_initializer generates
10081 a hidden default for allocatable components. */
10082 if (!(sym->value || no_init_flag) && sym->ns->proc_name
10083 && sym->ns->proc_name->attr.flavor == FL_MODULE
10084 && !sym->ns->save_all && !sym->attr.save
10085 && !sym->attr.pointer && !sym->attr.allocatable
10086 && gfc_has_default_initializer (sym->ts.u.derived)
10087 && gfc_notify_std (GFC_STD_F2008, "Fortran 2008: Implied SAVE for "
10088 "module variable '%s' at %L, needed due to "
10089 "the default initialization", sym->name,
10090 &sym->declared_at) == FAILURE)
10091 return FAILURE;
10092
10093 /* Assign default initializer. */
10094 if (!(sym->value || sym->attr.pointer || sym->attr.allocatable)
10095 && (!no_init_flag || sym->attr.intent == INTENT_OUT))
10096 {
10097 sym->value = gfc_default_initializer (&sym->ts);
10098 }
10099
10100 return SUCCESS;
10101 }
10102
10103
10104 /* Resolve symbols with flavor variable. */
10105
10106 static gfc_try
10107 resolve_fl_variable (gfc_symbol *sym, int mp_flag)
10108 {
10109 int no_init_flag, automatic_flag;
10110 gfc_expr *e;
10111 const char *auto_save_msg;
10112
10113 auto_save_msg = "Automatic object '%s' at %L cannot have the "
10114 "SAVE attribute";
10115
10116 if (resolve_fl_var_and_proc (sym, mp_flag) == FAILURE)
10117 return FAILURE;
10118
10119 /* Set this flag to check that variables are parameters of all entries.
10120 This check is effected by the call to gfc_resolve_expr through
10121 is_non_constant_shape_array. */
10122 specification_expr = 1;
10123
10124 if (sym->ns->proc_name
10125 && (sym->ns->proc_name->attr.flavor == FL_MODULE
10126 || sym->ns->proc_name->attr.is_main_program)
10127 && !sym->attr.use_assoc
10128 && !sym->attr.allocatable
10129 && !sym->attr.pointer
10130 && is_non_constant_shape_array (sym))
10131 {
10132 /* The shape of a main program or module array needs to be
10133 constant. */
10134 gfc_error ("The module or main program array '%s' at %L must "
10135 "have constant shape", sym->name, &sym->declared_at);
10136 specification_expr = 0;
10137 return FAILURE;
10138 }
10139
10140 /* Constraints on deferred type parameter. */
10141 if (sym->ts.deferred && !(sym->attr.pointer || sym->attr.allocatable))
10142 {
10143 gfc_error ("Entity '%s' at %L has a deferred type parameter and "
10144 "requires either the pointer or allocatable attribute",
10145 sym->name, &sym->declared_at);
10146 return FAILURE;
10147 }
10148
10149 if (sym->ts.type == BT_CHARACTER)
10150 {
10151 /* Make sure that character string variables with assumed length are
10152 dummy arguments. */
10153 e = sym->ts.u.cl->length;
10154 if (e == NULL && !sym->attr.dummy && !sym->attr.result
10155 && !sym->ts.deferred)
10156 {
10157 gfc_error ("Entity with assumed character length at %L must be a "
10158 "dummy argument or a PARAMETER", &sym->declared_at);
10159 return FAILURE;
10160 }
10161
10162 if (e && sym->attr.save == SAVE_EXPLICIT && !gfc_is_constant_expr (e))
10163 {
10164 gfc_error (auto_save_msg, sym->name, &sym->declared_at);
10165 return FAILURE;
10166 }
10167
10168 if (!gfc_is_constant_expr (e)
10169 && !(e->expr_type == EXPR_VARIABLE
10170 && e->symtree->n.sym->attr.flavor == FL_PARAMETER)
10171 && sym->ns->proc_name
10172 && (sym->ns->proc_name->attr.flavor == FL_MODULE
10173 || sym->ns->proc_name->attr.is_main_program)
10174 && !sym->attr.use_assoc)
10175 {
10176 gfc_error ("'%s' at %L must have constant character length "
10177 "in this context", sym->name, &sym->declared_at);
10178 return FAILURE;
10179 }
10180 }
10181
10182 if (sym->value == NULL && sym->attr.referenced)
10183 apply_default_init_local (sym); /* Try to apply a default initialization. */
10184
10185 /* Determine if the symbol may not have an initializer. */
10186 no_init_flag = automatic_flag = 0;
10187 if (sym->attr.allocatable || sym->attr.external || sym->attr.dummy
10188 || sym->attr.intrinsic || sym->attr.result)
10189 no_init_flag = 1;
10190 else if ((sym->attr.dimension || sym->attr.codimension) && !sym->attr.pointer
10191 && is_non_constant_shape_array (sym))
10192 {
10193 no_init_flag = automatic_flag = 1;
10194
10195 /* Also, they must not have the SAVE attribute.
10196 SAVE_IMPLICIT is checked below. */
10197 if (sym->as && sym->attr.codimension)
10198 {
10199 int corank = sym->as->corank;
10200 sym->as->corank = 0;
10201 no_init_flag = automatic_flag = is_non_constant_shape_array (sym);
10202 sym->as->corank = corank;
10203 }
10204 if (automatic_flag && sym->attr.save == SAVE_EXPLICIT)
10205 {
10206 gfc_error (auto_save_msg, sym->name, &sym->declared_at);
10207 return FAILURE;
10208 }
10209 }
10210
10211 /* Ensure that any initializer is simplified. */
10212 if (sym->value)
10213 gfc_simplify_expr (sym->value, 1);
10214
10215 /* Reject illegal initializers. */
10216 if (!sym->mark && sym->value)
10217 {
10218 if (sym->attr.allocatable || (sym->ts.type == BT_CLASS
10219 && CLASS_DATA (sym)->attr.allocatable))
10220 gfc_error ("Allocatable '%s' at %L cannot have an initializer",
10221 sym->name, &sym->declared_at);
10222 else if (sym->attr.external)
10223 gfc_error ("External '%s' at %L cannot have an initializer",
10224 sym->name, &sym->declared_at);
10225 else if (sym->attr.dummy
10226 && !(sym->ts.type == BT_DERIVED && sym->attr.intent == INTENT_OUT))
10227 gfc_error ("Dummy '%s' at %L cannot have an initializer",
10228 sym->name, &sym->declared_at);
10229 else if (sym->attr.intrinsic)
10230 gfc_error ("Intrinsic '%s' at %L cannot have an initializer",
10231 sym->name, &sym->declared_at);
10232 else if (sym->attr.result)
10233 gfc_error ("Function result '%s' at %L cannot have an initializer",
10234 sym->name, &sym->declared_at);
10235 else if (automatic_flag)
10236 gfc_error ("Automatic array '%s' at %L cannot have an initializer",
10237 sym->name, &sym->declared_at);
10238 else
10239 goto no_init_error;
10240 return FAILURE;
10241 }
10242
10243 no_init_error:
10244 if (sym->ts.type == BT_DERIVED || sym->ts.type == BT_CLASS)
10245 return resolve_fl_variable_derived (sym, no_init_flag);
10246
10247 return SUCCESS;
10248 }
10249
10250
10251 /* Resolve a procedure. */
10252
10253 static gfc_try
10254 resolve_fl_procedure (gfc_symbol *sym, int mp_flag)
10255 {
10256 gfc_formal_arglist *arg;
10257
10258 if (sym->attr.function
10259 && resolve_fl_var_and_proc (sym, mp_flag) == FAILURE)
10260 return FAILURE;
10261
10262 if (sym->ts.type == BT_CHARACTER)
10263 {
10264 gfc_charlen *cl = sym->ts.u.cl;
10265
10266 if (cl && cl->length && gfc_is_constant_expr (cl->length)
10267 && resolve_charlen (cl) == FAILURE)
10268 return FAILURE;
10269
10270 if ((!cl || !cl->length || cl->length->expr_type != EXPR_CONSTANT)
10271 && sym->attr.proc == PROC_ST_FUNCTION)
10272 {
10273 gfc_error ("Character-valued statement function '%s' at %L must "
10274 "have constant length", sym->name, &sym->declared_at);
10275 return FAILURE;
10276 }
10277 }
10278
10279 /* Ensure that derived type for are not of a private type. Internal
10280 module procedures are excluded by 2.2.3.3 - i.e., they are not
10281 externally accessible and can access all the objects accessible in
10282 the host. */
10283 if (!(sym->ns->parent
10284 && sym->ns->parent->proc_name->attr.flavor == FL_MODULE)
10285 && gfc_check_symbol_access (sym))
10286 {
10287 gfc_interface *iface;
10288
10289 for (arg = sym->formal; arg; arg = arg->next)
10290 {
10291 if (arg->sym
10292 && arg->sym->ts.type == BT_DERIVED
10293 && !arg->sym->ts.u.derived->attr.use_assoc
10294 && !gfc_check_symbol_access (arg->sym->ts.u.derived)
10295 && gfc_notify_std (GFC_STD_F2003, "Fortran 2003: '%s' is of a "
10296 "PRIVATE type and cannot be a dummy argument"
10297 " of '%s', which is PUBLIC at %L",
10298 arg->sym->name, sym->name, &sym->declared_at)
10299 == FAILURE)
10300 {
10301 /* Stop this message from recurring. */
10302 arg->sym->ts.u.derived->attr.access = ACCESS_PUBLIC;
10303 return FAILURE;
10304 }
10305 }
10306
10307 /* PUBLIC interfaces may expose PRIVATE procedures that take types
10308 PRIVATE to the containing module. */
10309 for (iface = sym->generic; iface; iface = iface->next)
10310 {
10311 for (arg = iface->sym->formal; arg; arg = arg->next)
10312 {
10313 if (arg->sym
10314 && arg->sym->ts.type == BT_DERIVED
10315 && !arg->sym->ts.u.derived->attr.use_assoc
10316 && !gfc_check_symbol_access (arg->sym->ts.u.derived)
10317 && gfc_notify_std (GFC_STD_F2003, "Fortran 2003: Procedure "
10318 "'%s' in PUBLIC interface '%s' at %L "
10319 "takes dummy arguments of '%s' which is "
10320 "PRIVATE", iface->sym->name, sym->name,
10321 &iface->sym->declared_at,
10322 gfc_typename (&arg->sym->ts)) == FAILURE)
10323 {
10324 /* Stop this message from recurring. */
10325 arg->sym->ts.u.derived->attr.access = ACCESS_PUBLIC;
10326 return FAILURE;
10327 }
10328 }
10329 }
10330
10331 /* PUBLIC interfaces may expose PRIVATE procedures that take types
10332 PRIVATE to the containing module. */
10333 for (iface = sym->generic; iface; iface = iface->next)
10334 {
10335 for (arg = iface->sym->formal; arg; arg = arg->next)
10336 {
10337 if (arg->sym
10338 && arg->sym->ts.type == BT_DERIVED
10339 && !arg->sym->ts.u.derived->attr.use_assoc
10340 && !gfc_check_symbol_access (arg->sym->ts.u.derived)
10341 && gfc_notify_std (GFC_STD_F2003, "Fortran 2003: Procedure "
10342 "'%s' in PUBLIC interface '%s' at %L "
10343 "takes dummy arguments of '%s' which is "
10344 "PRIVATE", iface->sym->name, sym->name,
10345 &iface->sym->declared_at,
10346 gfc_typename (&arg->sym->ts)) == FAILURE)
10347 {
10348 /* Stop this message from recurring. */
10349 arg->sym->ts.u.derived->attr.access = ACCESS_PUBLIC;
10350 return FAILURE;
10351 }
10352 }
10353 }
10354 }
10355
10356 if (sym->attr.function && sym->value && sym->attr.proc != PROC_ST_FUNCTION
10357 && !sym->attr.proc_pointer)
10358 {
10359 gfc_error ("Function '%s' at %L cannot have an initializer",
10360 sym->name, &sym->declared_at);
10361 return FAILURE;
10362 }
10363
10364 /* An external symbol may not have an initializer because it is taken to be
10365 a procedure. Exception: Procedure Pointers. */
10366 if (sym->attr.external && sym->value && !sym->attr.proc_pointer)
10367 {
10368 gfc_error ("External object '%s' at %L may not have an initializer",
10369 sym->name, &sym->declared_at);
10370 return FAILURE;
10371 }
10372
10373 /* An elemental function is required to return a scalar 12.7.1 */
10374 if (sym->attr.elemental && sym->attr.function && sym->as)
10375 {
10376 gfc_error ("ELEMENTAL function '%s' at %L must have a scalar "
10377 "result", sym->name, &sym->declared_at);
10378 /* Reset so that the error only occurs once. */
10379 sym->attr.elemental = 0;
10380 return FAILURE;
10381 }
10382
10383 if (sym->attr.proc == PROC_ST_FUNCTION
10384 && (sym->attr.allocatable || sym->attr.pointer))
10385 {
10386 gfc_error ("Statement function '%s' at %L may not have pointer or "
10387 "allocatable attribute", sym->name, &sym->declared_at);
10388 return FAILURE;
10389 }
10390
10391 /* 5.1.1.5 of the Standard: A function name declared with an asterisk
10392 char-len-param shall not be array-valued, pointer-valued, recursive
10393 or pure. ....snip... A character value of * may only be used in the
10394 following ways: (i) Dummy arg of procedure - dummy associates with
10395 actual length; (ii) To declare a named constant; or (iii) External
10396 function - but length must be declared in calling scoping unit. */
10397 if (sym->attr.function
10398 && sym->ts.type == BT_CHARACTER
10399 && sym->ts.u.cl && sym->ts.u.cl->length == NULL)
10400 {
10401 if ((sym->as && sym->as->rank) || (sym->attr.pointer)
10402 || (sym->attr.recursive) || (sym->attr.pure))
10403 {
10404 if (sym->as && sym->as->rank)
10405 gfc_error ("CHARACTER(*) function '%s' at %L cannot be "
10406 "array-valued", sym->name, &sym->declared_at);
10407
10408 if (sym->attr.pointer)
10409 gfc_error ("CHARACTER(*) function '%s' at %L cannot be "
10410 "pointer-valued", sym->name, &sym->declared_at);
10411
10412 if (sym->attr.pure)
10413 gfc_error ("CHARACTER(*) function '%s' at %L cannot be "
10414 "pure", sym->name, &sym->declared_at);
10415
10416 if (sym->attr.recursive)
10417 gfc_error ("CHARACTER(*) function '%s' at %L cannot be "
10418 "recursive", sym->name, &sym->declared_at);
10419
10420 return FAILURE;
10421 }
10422
10423 /* Appendix B.2 of the standard. Contained functions give an
10424 error anyway. Fixed-form is likely to be F77/legacy. Deferred
10425 character length is an F2003 feature. */
10426 if (!sym->attr.contained
10427 && gfc_current_form != FORM_FIXED
10428 && !sym->ts.deferred)
10429 gfc_notify_std (GFC_STD_F95_OBS, "Obsolescent feature: "
10430 "CHARACTER(*) function '%s' at %L",
10431 sym->name, &sym->declared_at);
10432 }
10433
10434 if (sym->attr.is_bind_c && sym->attr.is_c_interop != 1)
10435 {
10436 gfc_formal_arglist *curr_arg;
10437 int has_non_interop_arg = 0;
10438
10439 if (verify_bind_c_sym (sym, &(sym->ts), sym->attr.in_common,
10440 sym->common_block) == FAILURE)
10441 {
10442 /* Clear these to prevent looking at them again if there was an
10443 error. */
10444 sym->attr.is_bind_c = 0;
10445 sym->attr.is_c_interop = 0;
10446 sym->ts.is_c_interop = 0;
10447 }
10448 else
10449 {
10450 /* So far, no errors have been found. */
10451 sym->attr.is_c_interop = 1;
10452 sym->ts.is_c_interop = 1;
10453 }
10454
10455 curr_arg = sym->formal;
10456 while (curr_arg != NULL)
10457 {
10458 /* Skip implicitly typed dummy args here. */
10459 if (curr_arg->sym->attr.implicit_type == 0)
10460 if (verify_c_interop_param (curr_arg->sym) == FAILURE)
10461 /* If something is found to fail, record the fact so we
10462 can mark the symbol for the procedure as not being
10463 BIND(C) to try and prevent multiple errors being
10464 reported. */
10465 has_non_interop_arg = 1;
10466
10467 curr_arg = curr_arg->next;
10468 }
10469
10470 /* See if any of the arguments were not interoperable and if so, clear
10471 the procedure symbol to prevent duplicate error messages. */
10472 if (has_non_interop_arg != 0)
10473 {
10474 sym->attr.is_c_interop = 0;
10475 sym->ts.is_c_interop = 0;
10476 sym->attr.is_bind_c = 0;
10477 }
10478 }
10479
10480 if (!sym->attr.proc_pointer)
10481 {
10482 if (sym->attr.save == SAVE_EXPLICIT)
10483 {
10484 gfc_error ("PROCEDURE attribute conflicts with SAVE attribute "
10485 "in '%s' at %L", sym->name, &sym->declared_at);
10486 return FAILURE;
10487 }
10488 if (sym->attr.intent)
10489 {
10490 gfc_error ("PROCEDURE attribute conflicts with INTENT attribute "
10491 "in '%s' at %L", sym->name, &sym->declared_at);
10492 return FAILURE;
10493 }
10494 if (sym->attr.subroutine && sym->attr.result)
10495 {
10496 gfc_error ("PROCEDURE attribute conflicts with RESULT attribute "
10497 "in '%s' at %L", sym->name, &sym->declared_at);
10498 return FAILURE;
10499 }
10500 if (sym->attr.external && sym->attr.function
10501 && ((sym->attr.if_source == IFSRC_DECL && !sym->attr.procedure)
10502 || sym->attr.contained))
10503 {
10504 gfc_error ("EXTERNAL attribute conflicts with FUNCTION attribute "
10505 "in '%s' at %L", sym->name, &sym->declared_at);
10506 return FAILURE;
10507 }
10508 if (strcmp ("ppr@", sym->name) == 0)
10509 {
10510 gfc_error ("Procedure pointer result '%s' at %L "
10511 "is missing the pointer attribute",
10512 sym->ns->proc_name->name, &sym->declared_at);
10513 return FAILURE;
10514 }
10515 }
10516
10517 return SUCCESS;
10518 }
10519
10520
10521 /* Resolve a list of finalizer procedures. That is, after they have hopefully
10522 been defined and we now know their defined arguments, check that they fulfill
10523 the requirements of the standard for procedures used as finalizers. */
10524
10525 static gfc_try
10526 gfc_resolve_finalizers (gfc_symbol* derived)
10527 {
10528 gfc_finalizer* list;
10529 gfc_finalizer** prev_link; /* For removing wrong entries from the list. */
10530 gfc_try result = SUCCESS;
10531 bool seen_scalar = false;
10532
10533 if (!derived->f2k_derived || !derived->f2k_derived->finalizers)
10534 return SUCCESS;
10535
10536 /* Walk over the list of finalizer-procedures, check them, and if any one
10537 does not fit in with the standard's definition, print an error and remove
10538 it from the list. */
10539 prev_link = &derived->f2k_derived->finalizers;
10540 for (list = derived->f2k_derived->finalizers; list; list = *prev_link)
10541 {
10542 gfc_symbol* arg;
10543 gfc_finalizer* i;
10544 int my_rank;
10545
10546 /* Skip this finalizer if we already resolved it. */
10547 if (list->proc_tree)
10548 {
10549 prev_link = &(list->next);
10550 continue;
10551 }
10552
10553 /* Check this exists and is a SUBROUTINE. */
10554 if (!list->proc_sym->attr.subroutine)
10555 {
10556 gfc_error ("FINAL procedure '%s' at %L is not a SUBROUTINE",
10557 list->proc_sym->name, &list->where);
10558 goto error;
10559 }
10560
10561 /* We should have exactly one argument. */
10562 if (!list->proc_sym->formal || list->proc_sym->formal->next)
10563 {
10564 gfc_error ("FINAL procedure at %L must have exactly one argument",
10565 &list->where);
10566 goto error;
10567 }
10568 arg = list->proc_sym->formal->sym;
10569
10570 /* This argument must be of our type. */
10571 if (arg->ts.type != BT_DERIVED || arg->ts.u.derived != derived)
10572 {
10573 gfc_error ("Argument of FINAL procedure at %L must be of type '%s'",
10574 &arg->declared_at, derived->name);
10575 goto error;
10576 }
10577
10578 /* It must neither be a pointer nor allocatable nor optional. */
10579 if (arg->attr.pointer)
10580 {
10581 gfc_error ("Argument of FINAL procedure at %L must not be a POINTER",
10582 &arg->declared_at);
10583 goto error;
10584 }
10585 if (arg->attr.allocatable)
10586 {
10587 gfc_error ("Argument of FINAL procedure at %L must not be"
10588 " ALLOCATABLE", &arg->declared_at);
10589 goto error;
10590 }
10591 if (arg->attr.optional)
10592 {
10593 gfc_error ("Argument of FINAL procedure at %L must not be OPTIONAL",
10594 &arg->declared_at);
10595 goto error;
10596 }
10597
10598 /* It must not be INTENT(OUT). */
10599 if (arg->attr.intent == INTENT_OUT)
10600 {
10601 gfc_error ("Argument of FINAL procedure at %L must not be"
10602 " INTENT(OUT)", &arg->declared_at);
10603 goto error;
10604 }
10605
10606 /* Warn if the procedure is non-scalar and not assumed shape. */
10607 if (gfc_option.warn_surprising && arg->as && arg->as->rank > 0
10608 && arg->as->type != AS_ASSUMED_SHAPE)
10609 gfc_warning ("Non-scalar FINAL procedure at %L should have assumed"
10610 " shape argument", &arg->declared_at);
10611
10612 /* Check that it does not match in kind and rank with a FINAL procedure
10613 defined earlier. To really loop over the *earlier* declarations,
10614 we need to walk the tail of the list as new ones were pushed at the
10615 front. */
10616 /* TODO: Handle kind parameters once they are implemented. */
10617 my_rank = (arg->as ? arg->as->rank : 0);
10618 for (i = list->next; i; i = i->next)
10619 {
10620 /* Argument list might be empty; that is an error signalled earlier,
10621 but we nevertheless continued resolving. */
10622 if (i->proc_sym->formal)
10623 {
10624 gfc_symbol* i_arg = i->proc_sym->formal->sym;
10625 const int i_rank = (i_arg->as ? i_arg->as->rank : 0);
10626 if (i_rank == my_rank)
10627 {
10628 gfc_error ("FINAL procedure '%s' declared at %L has the same"
10629 " rank (%d) as '%s'",
10630 list->proc_sym->name, &list->where, my_rank,
10631 i->proc_sym->name);
10632 goto error;
10633 }
10634 }
10635 }
10636
10637 /* Is this the/a scalar finalizer procedure? */
10638 if (!arg->as || arg->as->rank == 0)
10639 seen_scalar = true;
10640
10641 /* Find the symtree for this procedure. */
10642 gcc_assert (!list->proc_tree);
10643 list->proc_tree = gfc_find_sym_in_symtree (list->proc_sym);
10644
10645 prev_link = &list->next;
10646 continue;
10647
10648 /* Remove wrong nodes immediately from the list so we don't risk any
10649 troubles in the future when they might fail later expectations. */
10650 error:
10651 result = FAILURE;
10652 i = list;
10653 *prev_link = list->next;
10654 gfc_free_finalizer (i);
10655 }
10656
10657 /* Warn if we haven't seen a scalar finalizer procedure (but we know there
10658 were nodes in the list, must have been for arrays. It is surely a good
10659 idea to have a scalar version there if there's something to finalize. */
10660 if (gfc_option.warn_surprising && result == SUCCESS && !seen_scalar)
10661 gfc_warning ("Only array FINAL procedures declared for derived type '%s'"
10662 " defined at %L, suggest also scalar one",
10663 derived->name, &derived->declared_at);
10664
10665 /* TODO: Remove this error when finalization is finished. */
10666 gfc_error ("Finalization at %L is not yet implemented",
10667 &derived->declared_at);
10668
10669 return result;
10670 }
10671
10672
10673 /* Check that it is ok for the typebound procedure proc to override the
10674 procedure old. */
10675
10676 static gfc_try
10677 check_typebound_override (gfc_symtree* proc, gfc_symtree* old)
10678 {
10679 locus where;
10680 const gfc_symbol* proc_target;
10681 const gfc_symbol* old_target;
10682 unsigned proc_pass_arg, old_pass_arg, argpos;
10683 gfc_formal_arglist* proc_formal;
10684 gfc_formal_arglist* old_formal;
10685
10686 /* This procedure should only be called for non-GENERIC proc. */
10687 gcc_assert (!proc->n.tb->is_generic);
10688
10689 /* If the overwritten procedure is GENERIC, this is an error. */
10690 if (old->n.tb->is_generic)
10691 {
10692 gfc_error ("Can't overwrite GENERIC '%s' at %L",
10693 old->name, &proc->n.tb->where);
10694 return FAILURE;
10695 }
10696
10697 where = proc->n.tb->where;
10698 proc_target = proc->n.tb->u.specific->n.sym;
10699 old_target = old->n.tb->u.specific->n.sym;
10700
10701 /* Check that overridden binding is not NON_OVERRIDABLE. */
10702 if (old->n.tb->non_overridable)
10703 {
10704 gfc_error ("'%s' at %L overrides a procedure binding declared"
10705 " NON_OVERRIDABLE", proc->name, &where);
10706 return FAILURE;
10707 }
10708
10709 /* It's an error to override a non-DEFERRED procedure with a DEFERRED one. */
10710 if (!old->n.tb->deferred && proc->n.tb->deferred)
10711 {
10712 gfc_error ("'%s' at %L must not be DEFERRED as it overrides a"
10713 " non-DEFERRED binding", proc->name, &where);
10714 return FAILURE;
10715 }
10716
10717 /* If the overridden binding is PURE, the overriding must be, too. */
10718 if (old_target->attr.pure && !proc_target->attr.pure)
10719 {
10720 gfc_error ("'%s' at %L overrides a PURE procedure and must also be PURE",
10721 proc->name, &where);
10722 return FAILURE;
10723 }
10724
10725 /* If the overridden binding is ELEMENTAL, the overriding must be, too. If it
10726 is not, the overriding must not be either. */
10727 if (old_target->attr.elemental && !proc_target->attr.elemental)
10728 {
10729 gfc_error ("'%s' at %L overrides an ELEMENTAL procedure and must also be"
10730 " ELEMENTAL", proc->name, &where);
10731 return FAILURE;
10732 }
10733 if (!old_target->attr.elemental && proc_target->attr.elemental)
10734 {
10735 gfc_error ("'%s' at %L overrides a non-ELEMENTAL procedure and must not"
10736 " be ELEMENTAL, either", proc->name, &where);
10737 return FAILURE;
10738 }
10739
10740 /* If the overridden binding is a SUBROUTINE, the overriding must also be a
10741 SUBROUTINE. */
10742 if (old_target->attr.subroutine && !proc_target->attr.subroutine)
10743 {
10744 gfc_error ("'%s' at %L overrides a SUBROUTINE and must also be a"
10745 " SUBROUTINE", proc->name, &where);
10746 return FAILURE;
10747 }
10748
10749 /* If the overridden binding is a FUNCTION, the overriding must also be a
10750 FUNCTION and have the same characteristics. */
10751 if (old_target->attr.function)
10752 {
10753 if (!proc_target->attr.function)
10754 {
10755 gfc_error ("'%s' at %L overrides a FUNCTION and must also be a"
10756 " FUNCTION", proc->name, &where);
10757 return FAILURE;
10758 }
10759
10760 /* FIXME: Do more comprehensive checking (including, for instance, the
10761 rank and array-shape). */
10762 gcc_assert (proc_target->result && old_target->result);
10763 if (!gfc_compare_types (&proc_target->result->ts,
10764 &old_target->result->ts))
10765 {
10766 gfc_error ("'%s' at %L and the overridden FUNCTION should have"
10767 " matching result types", proc->name, &where);
10768 return FAILURE;
10769 }
10770 }
10771
10772 /* If the overridden binding is PUBLIC, the overriding one must not be
10773 PRIVATE. */
10774 if (old->n.tb->access == ACCESS_PUBLIC
10775 && proc->n.tb->access == ACCESS_PRIVATE)
10776 {
10777 gfc_error ("'%s' at %L overrides a PUBLIC procedure and must not be"
10778 " PRIVATE", proc->name, &where);
10779 return FAILURE;
10780 }
10781
10782 /* Compare the formal argument lists of both procedures. This is also abused
10783 to find the position of the passed-object dummy arguments of both
10784 bindings as at least the overridden one might not yet be resolved and we
10785 need those positions in the check below. */
10786 proc_pass_arg = old_pass_arg = 0;
10787 if (!proc->n.tb->nopass && !proc->n.tb->pass_arg)
10788 proc_pass_arg = 1;
10789 if (!old->n.tb->nopass && !old->n.tb->pass_arg)
10790 old_pass_arg = 1;
10791 argpos = 1;
10792 for (proc_formal = proc_target->formal, old_formal = old_target->formal;
10793 proc_formal && old_formal;
10794 proc_formal = proc_formal->next, old_formal = old_formal->next)
10795 {
10796 if (proc->n.tb->pass_arg
10797 && !strcmp (proc->n.tb->pass_arg, proc_formal->sym->name))
10798 proc_pass_arg = argpos;
10799 if (old->n.tb->pass_arg
10800 && !strcmp (old->n.tb->pass_arg, old_formal->sym->name))
10801 old_pass_arg = argpos;
10802
10803 /* Check that the names correspond. */
10804 if (strcmp (proc_formal->sym->name, old_formal->sym->name))
10805 {
10806 gfc_error ("Dummy argument '%s' of '%s' at %L should be named '%s' as"
10807 " to match the corresponding argument of the overridden"
10808 " procedure", proc_formal->sym->name, proc->name, &where,
10809 old_formal->sym->name);
10810 return FAILURE;
10811 }
10812
10813 /* Check that the types correspond if neither is the passed-object
10814 argument. */
10815 /* FIXME: Do more comprehensive testing here. */
10816 if (proc_pass_arg != argpos && old_pass_arg != argpos
10817 && !gfc_compare_types (&proc_formal->sym->ts, &old_formal->sym->ts))
10818 {
10819 gfc_error ("Types mismatch for dummy argument '%s' of '%s' %L "
10820 "in respect to the overridden procedure",
10821 proc_formal->sym->name, proc->name, &where);
10822 return FAILURE;
10823 }
10824
10825 ++argpos;
10826 }
10827 if (proc_formal || old_formal)
10828 {
10829 gfc_error ("'%s' at %L must have the same number of formal arguments as"
10830 " the overridden procedure", proc->name, &where);
10831 return FAILURE;
10832 }
10833
10834 /* If the overridden binding is NOPASS, the overriding one must also be
10835 NOPASS. */
10836 if (old->n.tb->nopass && !proc->n.tb->nopass)
10837 {
10838 gfc_error ("'%s' at %L overrides a NOPASS binding and must also be"
10839 " NOPASS", proc->name, &where);
10840 return FAILURE;
10841 }
10842
10843 /* If the overridden binding is PASS(x), the overriding one must also be
10844 PASS and the passed-object dummy arguments must correspond. */
10845 if (!old->n.tb->nopass)
10846 {
10847 if (proc->n.tb->nopass)
10848 {
10849 gfc_error ("'%s' at %L overrides a binding with PASS and must also be"
10850 " PASS", proc->name, &where);
10851 return FAILURE;
10852 }
10853
10854 if (proc_pass_arg != old_pass_arg)
10855 {
10856 gfc_error ("Passed-object dummy argument of '%s' at %L must be at"
10857 " the same position as the passed-object dummy argument of"
10858 " the overridden procedure", proc->name, &where);
10859 return FAILURE;
10860 }
10861 }
10862
10863 return SUCCESS;
10864 }
10865
10866
10867 /* Check if two GENERIC targets are ambiguous and emit an error is they are. */
10868
10869 static gfc_try
10870 check_generic_tbp_ambiguity (gfc_tbp_generic* t1, gfc_tbp_generic* t2,
10871 const char* generic_name, locus where)
10872 {
10873 gfc_symbol* sym1;
10874 gfc_symbol* sym2;
10875
10876 gcc_assert (t1->specific && t2->specific);
10877 gcc_assert (!t1->specific->is_generic);
10878 gcc_assert (!t2->specific->is_generic);
10879
10880 sym1 = t1->specific->u.specific->n.sym;
10881 sym2 = t2->specific->u.specific->n.sym;
10882
10883 if (sym1 == sym2)
10884 return SUCCESS;
10885
10886 /* Both must be SUBROUTINEs or both must be FUNCTIONs. */
10887 if (sym1->attr.subroutine != sym2->attr.subroutine
10888 || sym1->attr.function != sym2->attr.function)
10889 {
10890 gfc_error ("'%s' and '%s' can't be mixed FUNCTION/SUBROUTINE for"
10891 " GENERIC '%s' at %L",
10892 sym1->name, sym2->name, generic_name, &where);
10893 return FAILURE;
10894 }
10895
10896 /* Compare the interfaces. */
10897 if (gfc_compare_interfaces (sym1, sym2, sym2->name, 1, 0, NULL, 0))
10898 {
10899 gfc_error ("'%s' and '%s' for GENERIC '%s' at %L are ambiguous",
10900 sym1->name, sym2->name, generic_name, &where);
10901 return FAILURE;
10902 }
10903
10904 return SUCCESS;
10905 }
10906
10907
10908 /* Worker function for resolving a generic procedure binding; this is used to
10909 resolve GENERIC as well as user and intrinsic OPERATOR typebound procedures.
10910
10911 The difference between those cases is finding possible inherited bindings
10912 that are overridden, as one has to look for them in tb_sym_root,
10913 tb_uop_root or tb_op, respectively. Thus the caller must already find
10914 the super-type and set p->overridden correctly. */
10915
10916 static gfc_try
10917 resolve_tb_generic_targets (gfc_symbol* super_type,
10918 gfc_typebound_proc* p, const char* name)
10919 {
10920 gfc_tbp_generic* target;
10921 gfc_symtree* first_target;
10922 gfc_symtree* inherited;
10923
10924 gcc_assert (p && p->is_generic);
10925
10926 /* Try to find the specific bindings for the symtrees in our target-list. */
10927 gcc_assert (p->u.generic);
10928 for (target = p->u.generic; target; target = target->next)
10929 if (!target->specific)
10930 {
10931 gfc_typebound_proc* overridden_tbp;
10932 gfc_tbp_generic* g;
10933 const char* target_name;
10934
10935 target_name = target->specific_st->name;
10936
10937 /* Defined for this type directly. */
10938 if (target->specific_st->n.tb && !target->specific_st->n.tb->error)
10939 {
10940 target->specific = target->specific_st->n.tb;
10941 goto specific_found;
10942 }
10943
10944 /* Look for an inherited specific binding. */
10945 if (super_type)
10946 {
10947 inherited = gfc_find_typebound_proc (super_type, NULL, target_name,
10948 true, NULL);
10949
10950 if (inherited)
10951 {
10952 gcc_assert (inherited->n.tb);
10953 target->specific = inherited->n.tb;
10954 goto specific_found;
10955 }
10956 }
10957
10958 gfc_error ("Undefined specific binding '%s' as target of GENERIC '%s'"
10959 " at %L", target_name, name, &p->where);
10960 return FAILURE;
10961
10962 /* Once we've found the specific binding, check it is not ambiguous with
10963 other specifics already found or inherited for the same GENERIC. */
10964 specific_found:
10965 gcc_assert (target->specific);
10966
10967 /* This must really be a specific binding! */
10968 if (target->specific->is_generic)
10969 {
10970 gfc_error ("GENERIC '%s' at %L must target a specific binding,"
10971 " '%s' is GENERIC, too", name, &p->where, target_name);
10972 return FAILURE;
10973 }
10974
10975 /* Check those already resolved on this type directly. */
10976 for (g = p->u.generic; g; g = g->next)
10977 if (g != target && g->specific
10978 && check_generic_tbp_ambiguity (target, g, name, p->where)
10979 == FAILURE)
10980 return FAILURE;
10981
10982 /* Check for ambiguity with inherited specific targets. */
10983 for (overridden_tbp = p->overridden; overridden_tbp;
10984 overridden_tbp = overridden_tbp->overridden)
10985 if (overridden_tbp->is_generic)
10986 {
10987 for (g = overridden_tbp->u.generic; g; g = g->next)
10988 {
10989 gcc_assert (g->specific);
10990 if (check_generic_tbp_ambiguity (target, g,
10991 name, p->where) == FAILURE)
10992 return FAILURE;
10993 }
10994 }
10995 }
10996
10997 /* If we attempt to "overwrite" a specific binding, this is an error. */
10998 if (p->overridden && !p->overridden->is_generic)
10999 {
11000 gfc_error ("GENERIC '%s' at %L can't overwrite specific binding with"
11001 " the same name", name, &p->where);
11002 return FAILURE;
11003 }
11004
11005 /* Take the SUBROUTINE/FUNCTION attributes of the first specific target, as
11006 all must have the same attributes here. */
11007 first_target = p->u.generic->specific->u.specific;
11008 gcc_assert (first_target);
11009 p->subroutine = first_target->n.sym->attr.subroutine;
11010 p->function = first_target->n.sym->attr.function;
11011
11012 return SUCCESS;
11013 }
11014
11015
11016 /* Resolve a GENERIC procedure binding for a derived type. */
11017
11018 static gfc_try
11019 resolve_typebound_generic (gfc_symbol* derived, gfc_symtree* st)
11020 {
11021 gfc_symbol* super_type;
11022
11023 /* Find the overridden binding if any. */
11024 st->n.tb->overridden = NULL;
11025 super_type = gfc_get_derived_super_type (derived);
11026 if (super_type)
11027 {
11028 gfc_symtree* overridden;
11029 overridden = gfc_find_typebound_proc (super_type, NULL, st->name,
11030 true, NULL);
11031
11032 if (overridden && overridden->n.tb)
11033 st->n.tb->overridden = overridden->n.tb;
11034 }
11035
11036 /* Resolve using worker function. */
11037 return resolve_tb_generic_targets (super_type, st->n.tb, st->name);
11038 }
11039
11040
11041 /* Retrieve the target-procedure of an operator binding and do some checks in
11042 common for intrinsic and user-defined type-bound operators. */
11043
11044 static gfc_symbol*
11045 get_checked_tb_operator_target (gfc_tbp_generic* target, locus where)
11046 {
11047 gfc_symbol* target_proc;
11048
11049 gcc_assert (target->specific && !target->specific->is_generic);
11050 target_proc = target->specific->u.specific->n.sym;
11051 gcc_assert (target_proc);
11052
11053 /* All operator bindings must have a passed-object dummy argument. */
11054 if (target->specific->nopass)
11055 {
11056 gfc_error ("Type-bound operator at %L can't be NOPASS", &where);
11057 return NULL;
11058 }
11059
11060 return target_proc;
11061 }
11062
11063
11064 /* Resolve a type-bound intrinsic operator. */
11065
11066 static gfc_try
11067 resolve_typebound_intrinsic_op (gfc_symbol* derived, gfc_intrinsic_op op,
11068 gfc_typebound_proc* p)
11069 {
11070 gfc_symbol* super_type;
11071 gfc_tbp_generic* target;
11072
11073 /* If there's already an error here, do nothing (but don't fail again). */
11074 if (p->error)
11075 return SUCCESS;
11076
11077 /* Operators should always be GENERIC bindings. */
11078 gcc_assert (p->is_generic);
11079
11080 /* Look for an overridden binding. */
11081 super_type = gfc_get_derived_super_type (derived);
11082 if (super_type && super_type->f2k_derived)
11083 p->overridden = gfc_find_typebound_intrinsic_op (super_type, NULL,
11084 op, true, NULL);
11085 else
11086 p->overridden = NULL;
11087
11088 /* Resolve general GENERIC properties using worker function. */
11089 if (resolve_tb_generic_targets (super_type, p, gfc_op2string (op)) == FAILURE)
11090 goto error;
11091
11092 /* Check the targets to be procedures of correct interface. */
11093 for (target = p->u.generic; target; target = target->next)
11094 {
11095 gfc_symbol* target_proc;
11096
11097 target_proc = get_checked_tb_operator_target (target, p->where);
11098 if (!target_proc)
11099 goto error;
11100
11101 if (!gfc_check_operator_interface (target_proc, op, p->where))
11102 goto error;
11103 }
11104
11105 return SUCCESS;
11106
11107 error:
11108 p->error = 1;
11109 return FAILURE;
11110 }
11111
11112
11113 /* Resolve a type-bound user operator (tree-walker callback). */
11114
11115 static gfc_symbol* resolve_bindings_derived;
11116 static gfc_try resolve_bindings_result;
11117
11118 static gfc_try check_uop_procedure (gfc_symbol* sym, locus where);
11119
11120 static void
11121 resolve_typebound_user_op (gfc_symtree* stree)
11122 {
11123 gfc_symbol* super_type;
11124 gfc_tbp_generic* target;
11125
11126 gcc_assert (stree && stree->n.tb);
11127
11128 if (stree->n.tb->error)
11129 return;
11130
11131 /* Operators should always be GENERIC bindings. */
11132 gcc_assert (stree->n.tb->is_generic);
11133
11134 /* Find overridden procedure, if any. */
11135 super_type = gfc_get_derived_super_type (resolve_bindings_derived);
11136 if (super_type && super_type->f2k_derived)
11137 {
11138 gfc_symtree* overridden;
11139 overridden = gfc_find_typebound_user_op (super_type, NULL,
11140 stree->name, true, NULL);
11141
11142 if (overridden && overridden->n.tb)
11143 stree->n.tb->overridden = overridden->n.tb;
11144 }
11145 else
11146 stree->n.tb->overridden = NULL;
11147
11148 /* Resolve basically using worker function. */
11149 if (resolve_tb_generic_targets (super_type, stree->n.tb, stree->name)
11150 == FAILURE)
11151 goto error;
11152
11153 /* Check the targets to be functions of correct interface. */
11154 for (target = stree->n.tb->u.generic; target; target = target->next)
11155 {
11156 gfc_symbol* target_proc;
11157
11158 target_proc = get_checked_tb_operator_target (target, stree->n.tb->where);
11159 if (!target_proc)
11160 goto error;
11161
11162 if (check_uop_procedure (target_proc, stree->n.tb->where) == FAILURE)
11163 goto error;
11164 }
11165
11166 return;
11167
11168 error:
11169 resolve_bindings_result = FAILURE;
11170 stree->n.tb->error = 1;
11171 }
11172
11173
11174 /* Resolve the type-bound procedures for a derived type. */
11175
11176 static void
11177 resolve_typebound_procedure (gfc_symtree* stree)
11178 {
11179 gfc_symbol* proc;
11180 locus where;
11181 gfc_symbol* me_arg;
11182 gfc_symbol* super_type;
11183 gfc_component* comp;
11184
11185 gcc_assert (stree);
11186
11187 /* Undefined specific symbol from GENERIC target definition. */
11188 if (!stree->n.tb)
11189 return;
11190
11191 if (stree->n.tb->error)
11192 return;
11193
11194 /* If this is a GENERIC binding, use that routine. */
11195 if (stree->n.tb->is_generic)
11196 {
11197 if (resolve_typebound_generic (resolve_bindings_derived, stree)
11198 == FAILURE)
11199 goto error;
11200 return;
11201 }
11202
11203 /* Get the target-procedure to check it. */
11204 gcc_assert (!stree->n.tb->is_generic);
11205 gcc_assert (stree->n.tb->u.specific);
11206 proc = stree->n.tb->u.specific->n.sym;
11207 where = stree->n.tb->where;
11208
11209 /* Default access should already be resolved from the parser. */
11210 gcc_assert (stree->n.tb->access != ACCESS_UNKNOWN);
11211
11212 /* It should be a module procedure or an external procedure with explicit
11213 interface. For DEFERRED bindings, abstract interfaces are ok as well. */
11214 if ((!proc->attr.subroutine && !proc->attr.function)
11215 || (proc->attr.proc != PROC_MODULE
11216 && proc->attr.if_source != IFSRC_IFBODY)
11217 || (proc->attr.abstract && !stree->n.tb->deferred))
11218 {
11219 gfc_error ("'%s' must be a module procedure or an external procedure with"
11220 " an explicit interface at %L", proc->name, &where);
11221 goto error;
11222 }
11223 stree->n.tb->subroutine = proc->attr.subroutine;
11224 stree->n.tb->function = proc->attr.function;
11225
11226 /* Find the super-type of the current derived type. We could do this once and
11227 store in a global if speed is needed, but as long as not I believe this is
11228 more readable and clearer. */
11229 super_type = gfc_get_derived_super_type (resolve_bindings_derived);
11230
11231 /* If PASS, resolve and check arguments if not already resolved / loaded
11232 from a .mod file. */
11233 if (!stree->n.tb->nopass && stree->n.tb->pass_arg_num == 0)
11234 {
11235 if (stree->n.tb->pass_arg)
11236 {
11237 gfc_formal_arglist* i;
11238
11239 /* If an explicit passing argument name is given, walk the arg-list
11240 and look for it. */
11241
11242 me_arg = NULL;
11243 stree->n.tb->pass_arg_num = 1;
11244 for (i = proc->formal; i; i = i->next)
11245 {
11246 if (!strcmp (i->sym->name, stree->n.tb->pass_arg))
11247 {
11248 me_arg = i->sym;
11249 break;
11250 }
11251 ++stree->n.tb->pass_arg_num;
11252 }
11253
11254 if (!me_arg)
11255 {
11256 gfc_error ("Procedure '%s' with PASS(%s) at %L has no"
11257 " argument '%s'",
11258 proc->name, stree->n.tb->pass_arg, &where,
11259 stree->n.tb->pass_arg);
11260 goto error;
11261 }
11262 }
11263 else
11264 {
11265 /* Otherwise, take the first one; there should in fact be at least
11266 one. */
11267 stree->n.tb->pass_arg_num = 1;
11268 if (!proc->formal)
11269 {
11270 gfc_error ("Procedure '%s' with PASS at %L must have at"
11271 " least one argument", proc->name, &where);
11272 goto error;
11273 }
11274 me_arg = proc->formal->sym;
11275 }
11276
11277 /* Now check that the argument-type matches and the passed-object
11278 dummy argument is generally fine. */
11279
11280 gcc_assert (me_arg);
11281
11282 if (me_arg->ts.type != BT_CLASS)
11283 {
11284 gfc_error ("Non-polymorphic passed-object dummy argument of '%s'"
11285 " at %L", proc->name, &where);
11286 goto error;
11287 }
11288
11289 if (CLASS_DATA (me_arg)->ts.u.derived
11290 != resolve_bindings_derived)
11291 {
11292 gfc_error ("Argument '%s' of '%s' with PASS(%s) at %L must be of"
11293 " the derived-type '%s'", me_arg->name, proc->name,
11294 me_arg->name, &where, resolve_bindings_derived->name);
11295 goto error;
11296 }
11297
11298 gcc_assert (me_arg->ts.type == BT_CLASS);
11299 if (CLASS_DATA (me_arg)->as && CLASS_DATA (me_arg)->as->rank > 0)
11300 {
11301 gfc_error ("Passed-object dummy argument of '%s' at %L must be"
11302 " scalar", proc->name, &where);
11303 goto error;
11304 }
11305 if (CLASS_DATA (me_arg)->attr.allocatable)
11306 {
11307 gfc_error ("Passed-object dummy argument of '%s' at %L must not"
11308 " be ALLOCATABLE", proc->name, &where);
11309 goto error;
11310 }
11311 if (CLASS_DATA (me_arg)->attr.class_pointer)
11312 {
11313 gfc_error ("Passed-object dummy argument of '%s' at %L must not"
11314 " be POINTER", proc->name, &where);
11315 goto error;
11316 }
11317 }
11318
11319 /* If we are extending some type, check that we don't override a procedure
11320 flagged NON_OVERRIDABLE. */
11321 stree->n.tb->overridden = NULL;
11322 if (super_type)
11323 {
11324 gfc_symtree* overridden;
11325 overridden = gfc_find_typebound_proc (super_type, NULL,
11326 stree->name, true, NULL);
11327
11328 if (overridden && overridden->n.tb)
11329 stree->n.tb->overridden = overridden->n.tb;
11330
11331 if (overridden && check_typebound_override (stree, overridden) == FAILURE)
11332 goto error;
11333 }
11334
11335 /* See if there's a name collision with a component directly in this type. */
11336 for (comp = resolve_bindings_derived->components; comp; comp = comp->next)
11337 if (!strcmp (comp->name, stree->name))
11338 {
11339 gfc_error ("Procedure '%s' at %L has the same name as a component of"
11340 " '%s'",
11341 stree->name, &where, resolve_bindings_derived->name);
11342 goto error;
11343 }
11344
11345 /* Try to find a name collision with an inherited component. */
11346 if (super_type && gfc_find_component (super_type, stree->name, true, true))
11347 {
11348 gfc_error ("Procedure '%s' at %L has the same name as an inherited"
11349 " component of '%s'",
11350 stree->name, &where, resolve_bindings_derived->name);
11351 goto error;
11352 }
11353
11354 stree->n.tb->error = 0;
11355 return;
11356
11357 error:
11358 resolve_bindings_result = FAILURE;
11359 stree->n.tb->error = 1;
11360 }
11361
11362
11363 static gfc_try
11364 resolve_typebound_procedures (gfc_symbol* derived)
11365 {
11366 int op;
11367
11368 if (!derived->f2k_derived || !derived->f2k_derived->tb_sym_root)
11369 return SUCCESS;
11370
11371 resolve_bindings_derived = derived;
11372 resolve_bindings_result = SUCCESS;
11373
11374 /* Make sure the vtab has been generated. */
11375 gfc_find_derived_vtab (derived);
11376
11377 if (derived->f2k_derived->tb_sym_root)
11378 gfc_traverse_symtree (derived->f2k_derived->tb_sym_root,
11379 &resolve_typebound_procedure);
11380
11381 if (derived->f2k_derived->tb_uop_root)
11382 gfc_traverse_symtree (derived->f2k_derived->tb_uop_root,
11383 &resolve_typebound_user_op);
11384
11385 for (op = 0; op != GFC_INTRINSIC_OPS; ++op)
11386 {
11387 gfc_typebound_proc* p = derived->f2k_derived->tb_op[op];
11388 if (p && resolve_typebound_intrinsic_op (derived, (gfc_intrinsic_op) op,
11389 p) == FAILURE)
11390 resolve_bindings_result = FAILURE;
11391 }
11392
11393 return resolve_bindings_result;
11394 }
11395
11396
11397 /* Add a derived type to the dt_list. The dt_list is used in trans-types.c
11398 to give all identical derived types the same backend_decl. */
11399 static void
11400 add_dt_to_dt_list (gfc_symbol *derived)
11401 {
11402 gfc_dt_list *dt_list;
11403
11404 for (dt_list = gfc_derived_types; dt_list; dt_list = dt_list->next)
11405 if (derived == dt_list->derived)
11406 return;
11407
11408 dt_list = gfc_get_dt_list ();
11409 dt_list->next = gfc_derived_types;
11410 dt_list->derived = derived;
11411 gfc_derived_types = dt_list;
11412 }
11413
11414
11415 /* Ensure that a derived-type is really not abstract, meaning that every
11416 inherited DEFERRED binding is overridden by a non-DEFERRED one. */
11417
11418 static gfc_try
11419 ensure_not_abstract_walker (gfc_symbol* sub, gfc_symtree* st)
11420 {
11421 if (!st)
11422 return SUCCESS;
11423
11424 if (ensure_not_abstract_walker (sub, st->left) == FAILURE)
11425 return FAILURE;
11426 if (ensure_not_abstract_walker (sub, st->right) == FAILURE)
11427 return FAILURE;
11428
11429 if (st->n.tb && st->n.tb->deferred)
11430 {
11431 gfc_symtree* overriding;
11432 overriding = gfc_find_typebound_proc (sub, NULL, st->name, true, NULL);
11433 if (!overriding)
11434 return FAILURE;
11435 gcc_assert (overriding->n.tb);
11436 if (overriding->n.tb->deferred)
11437 {
11438 gfc_error ("Derived-type '%s' declared at %L must be ABSTRACT because"
11439 " '%s' is DEFERRED and not overridden",
11440 sub->name, &sub->declared_at, st->name);
11441 return FAILURE;
11442 }
11443 }
11444
11445 return SUCCESS;
11446 }
11447
11448 static gfc_try
11449 ensure_not_abstract (gfc_symbol* sub, gfc_symbol* ancestor)
11450 {
11451 /* The algorithm used here is to recursively travel up the ancestry of sub
11452 and for each ancestor-type, check all bindings. If any of them is
11453 DEFERRED, look it up starting from sub and see if the found (overriding)
11454 binding is not DEFERRED.
11455 This is not the most efficient way to do this, but it should be ok and is
11456 clearer than something sophisticated. */
11457
11458 gcc_assert (ancestor && !sub->attr.abstract);
11459
11460 if (!ancestor->attr.abstract)
11461 return SUCCESS;
11462
11463 /* Walk bindings of this ancestor. */
11464 if (ancestor->f2k_derived)
11465 {
11466 gfc_try t;
11467 t = ensure_not_abstract_walker (sub, ancestor->f2k_derived->tb_sym_root);
11468 if (t == FAILURE)
11469 return FAILURE;
11470 }
11471
11472 /* Find next ancestor type and recurse on it. */
11473 ancestor = gfc_get_derived_super_type (ancestor);
11474 if (ancestor)
11475 return ensure_not_abstract (sub, ancestor);
11476
11477 return SUCCESS;
11478 }
11479
11480
11481 /* Resolve the components of a derived type. */
11482
11483 static gfc_try
11484 resolve_fl_derived (gfc_symbol *sym)
11485 {
11486 gfc_symbol* super_type;
11487 gfc_component *c;
11488
11489 super_type = gfc_get_derived_super_type (sym);
11490
11491 if (sym->attr.is_class && sym->ts.u.derived == NULL)
11492 {
11493 /* Fix up incomplete CLASS symbols. */
11494 gfc_component *data = gfc_find_component (sym, "_data", true, true);
11495 gfc_component *vptr = gfc_find_component (sym, "_vptr", true, true);
11496 if (vptr->ts.u.derived == NULL)
11497 {
11498 gfc_symbol *vtab = gfc_find_derived_vtab (data->ts.u.derived);
11499 gcc_assert (vtab);
11500 vptr->ts.u.derived = vtab->ts.u.derived;
11501 }
11502 }
11503
11504 /* F2008, C432. */
11505 if (super_type && sym->attr.coarray_comp && !super_type->attr.coarray_comp)
11506 {
11507 gfc_error ("As extending type '%s' at %L has a coarray component, "
11508 "parent type '%s' shall also have one", sym->name,
11509 &sym->declared_at, super_type->name);
11510 return FAILURE;
11511 }
11512
11513 /* Ensure the extended type gets resolved before we do. */
11514 if (super_type && resolve_fl_derived (super_type) == FAILURE)
11515 return FAILURE;
11516
11517 /* An ABSTRACT type must be extensible. */
11518 if (sym->attr.abstract && !gfc_type_is_extensible (sym))
11519 {
11520 gfc_error ("Non-extensible derived-type '%s' at %L must not be ABSTRACT",
11521 sym->name, &sym->declared_at);
11522 return FAILURE;
11523 }
11524
11525 for (c = sym->components; c != NULL; c = c->next)
11526 {
11527 /* F2008, C442. */
11528 if (c->attr.codimension /* FIXME: c->as check due to PR 43412. */
11529 && (!c->attr.allocatable || (c->as && c->as->type != AS_DEFERRED)))
11530 {
11531 gfc_error ("Coarray component '%s' at %L must be allocatable with "
11532 "deferred shape", c->name, &c->loc);
11533 return FAILURE;
11534 }
11535
11536 /* F2008, C443. */
11537 if (c->attr.codimension && c->ts.type == BT_DERIVED
11538 && c->ts.u.derived->ts.is_iso_c)
11539 {
11540 gfc_error ("Component '%s' at %L of TYPE(C_PTR) or TYPE(C_FUNPTR) "
11541 "shall not be a coarray", c->name, &c->loc);
11542 return FAILURE;
11543 }
11544
11545 /* F2008, C444. */
11546 if (c->ts.type == BT_DERIVED && c->ts.u.derived->attr.coarray_comp
11547 && (c->attr.codimension || c->attr.pointer || c->attr.dimension
11548 || c->attr.allocatable))
11549 {
11550 gfc_error ("Component '%s' at %L with coarray component "
11551 "shall be a nonpointer, nonallocatable scalar",
11552 c->name, &c->loc);
11553 return FAILURE;
11554 }
11555
11556 /* F2008, C448. */
11557 if (c->attr.contiguous && (!c->attr.dimension || !c->attr.pointer))
11558 {
11559 gfc_error ("Component '%s' at %L has the CONTIGUOUS attribute but "
11560 "is not an array pointer", c->name, &c->loc);
11561 return FAILURE;
11562 }
11563
11564 if (c->attr.proc_pointer && c->ts.interface)
11565 {
11566 if (c->ts.interface->attr.procedure && !sym->attr.vtype)
11567 gfc_error ("Interface '%s', used by procedure pointer component "
11568 "'%s' at %L, is declared in a later PROCEDURE statement",
11569 c->ts.interface->name, c->name, &c->loc);
11570
11571 /* Get the attributes from the interface (now resolved). */
11572 if (c->ts.interface->attr.if_source
11573 || c->ts.interface->attr.intrinsic)
11574 {
11575 gfc_symbol *ifc = c->ts.interface;
11576
11577 if (ifc->formal && !ifc->formal_ns)
11578 resolve_symbol (ifc);
11579
11580 if (ifc->attr.intrinsic)
11581 resolve_intrinsic (ifc, &ifc->declared_at);
11582
11583 if (ifc->result)
11584 {
11585 c->ts = ifc->result->ts;
11586 c->attr.allocatable = ifc->result->attr.allocatable;
11587 c->attr.pointer = ifc->result->attr.pointer;
11588 c->attr.dimension = ifc->result->attr.dimension;
11589 c->as = gfc_copy_array_spec (ifc->result->as);
11590 }
11591 else
11592 {
11593 c->ts = ifc->ts;
11594 c->attr.allocatable = ifc->attr.allocatable;
11595 c->attr.pointer = ifc->attr.pointer;
11596 c->attr.dimension = ifc->attr.dimension;
11597 c->as = gfc_copy_array_spec (ifc->as);
11598 }
11599 c->ts.interface = ifc;
11600 c->attr.function = ifc->attr.function;
11601 c->attr.subroutine = ifc->attr.subroutine;
11602 gfc_copy_formal_args_ppc (c, ifc);
11603
11604 c->attr.pure = ifc->attr.pure;
11605 c->attr.elemental = ifc->attr.elemental;
11606 c->attr.recursive = ifc->attr.recursive;
11607 c->attr.always_explicit = ifc->attr.always_explicit;
11608 c->attr.ext_attr |= ifc->attr.ext_attr;
11609 /* Replace symbols in array spec. */
11610 if (c->as)
11611 {
11612 int i;
11613 for (i = 0; i < c->as->rank; i++)
11614 {
11615 gfc_expr_replace_comp (c->as->lower[i], c);
11616 gfc_expr_replace_comp (c->as->upper[i], c);
11617 }
11618 }
11619 /* Copy char length. */
11620 if (ifc->ts.type == BT_CHARACTER && ifc->ts.u.cl)
11621 {
11622 gfc_charlen *cl = gfc_new_charlen (sym->ns, ifc->ts.u.cl);
11623 gfc_expr_replace_comp (cl->length, c);
11624 if (cl->length && !cl->resolved
11625 && gfc_resolve_expr (cl->length) == FAILURE)
11626 return FAILURE;
11627 c->ts.u.cl = cl;
11628 }
11629 }
11630 else if (!sym->attr.vtype && c->ts.interface->name[0] != '\0')
11631 {
11632 gfc_error ("Interface '%s' of procedure pointer component "
11633 "'%s' at %L must be explicit", c->ts.interface->name,
11634 c->name, &c->loc);
11635 return FAILURE;
11636 }
11637 }
11638 else if (c->attr.proc_pointer && c->ts.type == BT_UNKNOWN)
11639 {
11640 /* Since PPCs are not implicitly typed, a PPC without an explicit
11641 interface must be a subroutine. */
11642 gfc_add_subroutine (&c->attr, c->name, &c->loc);
11643 }
11644
11645 /* Procedure pointer components: Check PASS arg. */
11646 if (c->attr.proc_pointer && !c->tb->nopass && c->tb->pass_arg_num == 0
11647 && !sym->attr.vtype)
11648 {
11649 gfc_symbol* me_arg;
11650
11651 if (c->tb->pass_arg)
11652 {
11653 gfc_formal_arglist* i;
11654
11655 /* If an explicit passing argument name is given, walk the arg-list
11656 and look for it. */
11657
11658 me_arg = NULL;
11659 c->tb->pass_arg_num = 1;
11660 for (i = c->formal; i; i = i->next)
11661 {
11662 if (!strcmp (i->sym->name, c->tb->pass_arg))
11663 {
11664 me_arg = i->sym;
11665 break;
11666 }
11667 c->tb->pass_arg_num++;
11668 }
11669
11670 if (!me_arg)
11671 {
11672 gfc_error ("Procedure pointer component '%s' with PASS(%s) "
11673 "at %L has no argument '%s'", c->name,
11674 c->tb->pass_arg, &c->loc, c->tb->pass_arg);
11675 c->tb->error = 1;
11676 return FAILURE;
11677 }
11678 }
11679 else
11680 {
11681 /* Otherwise, take the first one; there should in fact be at least
11682 one. */
11683 c->tb->pass_arg_num = 1;
11684 if (!c->formal)
11685 {
11686 gfc_error ("Procedure pointer component '%s' with PASS at %L "
11687 "must have at least one argument",
11688 c->name, &c->loc);
11689 c->tb->error = 1;
11690 return FAILURE;
11691 }
11692 me_arg = c->formal->sym;
11693 }
11694
11695 /* Now check that the argument-type matches. */
11696 gcc_assert (me_arg);
11697 if ((me_arg->ts.type != BT_DERIVED && me_arg->ts.type != BT_CLASS)
11698 || (me_arg->ts.type == BT_DERIVED && me_arg->ts.u.derived != sym)
11699 || (me_arg->ts.type == BT_CLASS
11700 && CLASS_DATA (me_arg)->ts.u.derived != sym))
11701 {
11702 gfc_error ("Argument '%s' of '%s' with PASS(%s) at %L must be of"
11703 " the derived type '%s'", me_arg->name, c->name,
11704 me_arg->name, &c->loc, sym->name);
11705 c->tb->error = 1;
11706 return FAILURE;
11707 }
11708
11709 /* Check for C453. */
11710 if (me_arg->attr.dimension)
11711 {
11712 gfc_error ("Argument '%s' of '%s' with PASS(%s) at %L "
11713 "must be scalar", me_arg->name, c->name, me_arg->name,
11714 &c->loc);
11715 c->tb->error = 1;
11716 return FAILURE;
11717 }
11718
11719 if (me_arg->attr.pointer)
11720 {
11721 gfc_error ("Argument '%s' of '%s' with PASS(%s) at %L "
11722 "may not have the POINTER attribute", me_arg->name,
11723 c->name, me_arg->name, &c->loc);
11724 c->tb->error = 1;
11725 return FAILURE;
11726 }
11727
11728 if (me_arg->attr.allocatable)
11729 {
11730 gfc_error ("Argument '%s' of '%s' with PASS(%s) at %L "
11731 "may not be ALLOCATABLE", me_arg->name, c->name,
11732 me_arg->name, &c->loc);
11733 c->tb->error = 1;
11734 return FAILURE;
11735 }
11736
11737 if (gfc_type_is_extensible (sym) && me_arg->ts.type != BT_CLASS)
11738 gfc_error ("Non-polymorphic passed-object dummy argument of '%s'"
11739 " at %L", c->name, &c->loc);
11740
11741 }
11742
11743 /* Check type-spec if this is not the parent-type component. */
11744 if ((!sym->attr.extension || c != sym->components) && !sym->attr.vtype
11745 && resolve_typespec_used (&c->ts, &c->loc, c->name) == FAILURE)
11746 return FAILURE;
11747
11748 /* If this type is an extension, set the accessibility of the parent
11749 component. */
11750 if (super_type && c == sym->components
11751 && strcmp (super_type->name, c->name) == 0)
11752 c->attr.access = super_type->attr.access;
11753
11754 /* If this type is an extension, see if this component has the same name
11755 as an inherited type-bound procedure. */
11756 if (super_type && !sym->attr.is_class
11757 && gfc_find_typebound_proc (super_type, NULL, c->name, true, NULL))
11758 {
11759 gfc_error ("Component '%s' of '%s' at %L has the same name as an"
11760 " inherited type-bound procedure",
11761 c->name, sym->name, &c->loc);
11762 return FAILURE;
11763 }
11764
11765 if (c->ts.type == BT_CHARACTER && !c->attr.proc_pointer
11766 && !c->ts.deferred)
11767 {
11768 if (c->ts.u.cl->length == NULL
11769 || (resolve_charlen (c->ts.u.cl) == FAILURE)
11770 || !gfc_is_constant_expr (c->ts.u.cl->length))
11771 {
11772 gfc_error ("Character length of component '%s' needs to "
11773 "be a constant specification expression at %L",
11774 c->name,
11775 c->ts.u.cl->length ? &c->ts.u.cl->length->where : &c->loc);
11776 return FAILURE;
11777 }
11778 }
11779
11780 if (c->ts.type == BT_CHARACTER && c->ts.deferred
11781 && !c->attr.pointer && !c->attr.allocatable)
11782 {
11783 gfc_error ("Character component '%s' of '%s' at %L with deferred "
11784 "length must be a POINTER or ALLOCATABLE",
11785 c->name, sym->name, &c->loc);
11786 return FAILURE;
11787 }
11788
11789 if (c->ts.type == BT_DERIVED
11790 && sym->component_access != ACCESS_PRIVATE
11791 && gfc_check_symbol_access (sym)
11792 && !is_sym_host_assoc (c->ts.u.derived, sym->ns)
11793 && !c->ts.u.derived->attr.use_assoc
11794 && !gfc_check_symbol_access (c->ts.u.derived)
11795 && gfc_notify_std (GFC_STD_F2003, "Fortran 2003: the component '%s' "
11796 "is a PRIVATE type and cannot be a component of "
11797 "'%s', which is PUBLIC at %L", c->name,
11798 sym->name, &sym->declared_at) == FAILURE)
11799 return FAILURE;
11800
11801 if ((sym->attr.sequence || sym->attr.is_bind_c) && c->ts.type == BT_CLASS)
11802 {
11803 gfc_error ("Polymorphic component %s at %L in SEQUENCE or BIND(C) "
11804 "type %s", c->name, &c->loc, sym->name);
11805 return FAILURE;
11806 }
11807
11808 if (sym->attr.sequence)
11809 {
11810 if (c->ts.type == BT_DERIVED && c->ts.u.derived->attr.sequence == 0)
11811 {
11812 gfc_error ("Component %s of SEQUENCE type declared at %L does "
11813 "not have the SEQUENCE attribute",
11814 c->ts.u.derived->name, &sym->declared_at);
11815 return FAILURE;
11816 }
11817 }
11818
11819 if (!sym->attr.is_class && c->ts.type == BT_DERIVED && !sym->attr.vtype
11820 && c->attr.pointer && c->ts.u.derived->components == NULL
11821 && !c->ts.u.derived->attr.zero_comp)
11822 {
11823 gfc_error ("The pointer component '%s' of '%s' at %L is a type "
11824 "that has not been declared", c->name, sym->name,
11825 &c->loc);
11826 return FAILURE;
11827 }
11828
11829 if (c->ts.type == BT_CLASS && c->attr.class_ok
11830 && CLASS_DATA (c)->attr.class_pointer
11831 && CLASS_DATA (c)->ts.u.derived->components == NULL
11832 && !CLASS_DATA (c)->ts.u.derived->attr.zero_comp)
11833 {
11834 gfc_error ("The pointer component '%s' of '%s' at %L is a type "
11835 "that has not been declared", c->name, sym->name,
11836 &c->loc);
11837 return FAILURE;
11838 }
11839
11840 /* C437. */
11841 if (c->ts.type == BT_CLASS && c->attr.flavor != FL_PROCEDURE
11842 && (!c->attr.class_ok
11843 || !(CLASS_DATA (c)->attr.class_pointer
11844 || CLASS_DATA (c)->attr.allocatable)))
11845 {
11846 gfc_error ("Component '%s' with CLASS at %L must be allocatable "
11847 "or pointer", c->name, &c->loc);
11848 return FAILURE;
11849 }
11850
11851 /* Ensure that all the derived type components are put on the
11852 derived type list; even in formal namespaces, where derived type
11853 pointer components might not have been declared. */
11854 if (c->ts.type == BT_DERIVED
11855 && c->ts.u.derived
11856 && c->ts.u.derived->components
11857 && c->attr.pointer
11858 && sym != c->ts.u.derived)
11859 add_dt_to_dt_list (c->ts.u.derived);
11860
11861 if (gfc_resolve_array_spec (c->as, !(c->attr.pointer
11862 || c->attr.proc_pointer
11863 || c->attr.allocatable)) == FAILURE)
11864 return FAILURE;
11865 }
11866
11867 /* Resolve the type-bound procedures. */
11868 if (resolve_typebound_procedures (sym) == FAILURE)
11869 return FAILURE;
11870
11871 /* Resolve the finalizer procedures. */
11872 if (gfc_resolve_finalizers (sym) == FAILURE)
11873 return FAILURE;
11874
11875 /* If this is a non-ABSTRACT type extending an ABSTRACT one, ensure that
11876 all DEFERRED bindings are overridden. */
11877 if (super_type && super_type->attr.abstract && !sym->attr.abstract
11878 && !sym->attr.is_class
11879 && ensure_not_abstract (sym, super_type) == FAILURE)
11880 return FAILURE;
11881
11882 /* Add derived type to the derived type list. */
11883 add_dt_to_dt_list (sym);
11884
11885 return SUCCESS;
11886 }
11887
11888
11889 static gfc_try
11890 resolve_fl_namelist (gfc_symbol *sym)
11891 {
11892 gfc_namelist *nl;
11893 gfc_symbol *nlsym;
11894
11895 for (nl = sym->namelist; nl; nl = nl->next)
11896 {
11897 /* Check again, the check in match only works if NAMELIST comes
11898 after the decl. */
11899 if (nl->sym->as && nl->sym->as->type == AS_ASSUMED_SIZE)
11900 {
11901 gfc_error ("Assumed size array '%s' in namelist '%s' at %L is not "
11902 "allowed", nl->sym->name, sym->name, &sym->declared_at);
11903 return FAILURE;
11904 }
11905
11906 if (nl->sym->as && nl->sym->as->type == AS_ASSUMED_SHAPE
11907 && gfc_notify_std (GFC_STD_F2003, "Fortran 2003: NAMELIST array "
11908 "object '%s' with assumed shape in namelist "
11909 "'%s' at %L", nl->sym->name, sym->name,
11910 &sym->declared_at) == FAILURE)
11911 return FAILURE;
11912
11913 if (is_non_constant_shape_array (nl->sym)
11914 && gfc_notify_std (GFC_STD_F2003, "Fortran 2003: NAMELIST array "
11915 "object '%s' with nonconstant shape in namelist "
11916 "'%s' at %L", nl->sym->name, sym->name,
11917 &sym->declared_at) == FAILURE)
11918 return FAILURE;
11919
11920 if (nl->sym->ts.type == BT_CHARACTER
11921 && (nl->sym->ts.u.cl->length == NULL
11922 || !gfc_is_constant_expr (nl->sym->ts.u.cl->length))
11923 && gfc_notify_std (GFC_STD_F2003, "Fortran 2003: NAMELIST object "
11924 "'%s' with nonconstant character length in "
11925 "namelist '%s' at %L", nl->sym->name, sym->name,
11926 &sym->declared_at) == FAILURE)
11927 return FAILURE;
11928
11929 /* FIXME: Once UDDTIO is implemented, the following can be
11930 removed. */
11931 if (nl->sym->ts.type == BT_CLASS)
11932 {
11933 gfc_error ("NAMELIST object '%s' in namelist '%s' at %L is "
11934 "polymorphic and requires a defined input/output "
11935 "procedure", nl->sym->name, sym->name, &sym->declared_at);
11936 return FAILURE;
11937 }
11938
11939 if (nl->sym->ts.type == BT_DERIVED
11940 && (nl->sym->ts.u.derived->attr.alloc_comp
11941 || nl->sym->ts.u.derived->attr.pointer_comp))
11942 {
11943 if (gfc_notify_std (GFC_STD_F2003, "Fortran 2003: NAMELIST object "
11944 "'%s' in namelist '%s' at %L with ALLOCATABLE "
11945 "or POINTER components", nl->sym->name,
11946 sym->name, &sym->declared_at) == FAILURE)
11947 return FAILURE;
11948
11949 /* FIXME: Once UDDTIO is implemented, the following can be
11950 removed. */
11951 gfc_error ("NAMELIST object '%s' in namelist '%s' at %L has "
11952 "ALLOCATABLE or POINTER components and thus requires "
11953 "a defined input/output procedure", nl->sym->name,
11954 sym->name, &sym->declared_at);
11955 return FAILURE;
11956 }
11957 }
11958
11959 /* Reject PRIVATE objects in a PUBLIC namelist. */
11960 if (gfc_check_symbol_access (sym))
11961 {
11962 for (nl = sym->namelist; nl; nl = nl->next)
11963 {
11964 if (!nl->sym->attr.use_assoc
11965 && !is_sym_host_assoc (nl->sym, sym->ns)
11966 && !gfc_check_symbol_access (nl->sym))
11967 {
11968 gfc_error ("NAMELIST object '%s' was declared PRIVATE and "
11969 "cannot be member of PUBLIC namelist '%s' at %L",
11970 nl->sym->name, sym->name, &sym->declared_at);
11971 return FAILURE;
11972 }
11973
11974 /* Types with private components that came here by USE-association. */
11975 if (nl->sym->ts.type == BT_DERIVED
11976 && derived_inaccessible (nl->sym->ts.u.derived))
11977 {
11978 gfc_error ("NAMELIST object '%s' has use-associated PRIVATE "
11979 "components and cannot be member of namelist '%s' at %L",
11980 nl->sym->name, sym->name, &sym->declared_at);
11981 return FAILURE;
11982 }
11983
11984 /* Types with private components that are defined in the same module. */
11985 if (nl->sym->ts.type == BT_DERIVED
11986 && !is_sym_host_assoc (nl->sym->ts.u.derived, sym->ns)
11987 && nl->sym->ts.u.derived->attr.private_comp)
11988 {
11989 gfc_error ("NAMELIST object '%s' has PRIVATE components and "
11990 "cannot be a member of PUBLIC namelist '%s' at %L",
11991 nl->sym->name, sym->name, &sym->declared_at);
11992 return FAILURE;
11993 }
11994 }
11995 }
11996
11997
11998 /* 14.1.2 A module or internal procedure represent local entities
11999 of the same type as a namelist member and so are not allowed. */
12000 for (nl = sym->namelist; nl; nl = nl->next)
12001 {
12002 if (nl->sym->ts.kind != 0 && nl->sym->attr.flavor == FL_VARIABLE)
12003 continue;
12004
12005 if (nl->sym->attr.function && nl->sym == nl->sym->result)
12006 if ((nl->sym == sym->ns->proc_name)
12007 ||
12008 (sym->ns->parent && nl->sym == sym->ns->parent->proc_name))
12009 continue;
12010
12011 nlsym = NULL;
12012 if (nl->sym && nl->sym->name)
12013 gfc_find_symbol (nl->sym->name, sym->ns, 1, &nlsym);
12014 if (nlsym && nlsym->attr.flavor == FL_PROCEDURE)
12015 {
12016 gfc_error ("PROCEDURE attribute conflicts with NAMELIST "
12017 "attribute in '%s' at %L", nlsym->name,
12018 &sym->declared_at);
12019 return FAILURE;
12020 }
12021 }
12022
12023 return SUCCESS;
12024 }
12025
12026
12027 static gfc_try
12028 resolve_fl_parameter (gfc_symbol *sym)
12029 {
12030 /* A parameter array's shape needs to be constant. */
12031 if (sym->as != NULL
12032 && (sym->as->type == AS_DEFERRED
12033 || is_non_constant_shape_array (sym)))
12034 {
12035 gfc_error ("Parameter array '%s' at %L cannot be automatic "
12036 "or of deferred shape", sym->name, &sym->declared_at);
12037 return FAILURE;
12038 }
12039
12040 /* Make sure a parameter that has been implicitly typed still
12041 matches the implicit type, since PARAMETER statements can precede
12042 IMPLICIT statements. */
12043 if (sym->attr.implicit_type
12044 && !gfc_compare_types (&sym->ts, gfc_get_default_type (sym->name,
12045 sym->ns)))
12046 {
12047 gfc_error ("Implicitly typed PARAMETER '%s' at %L doesn't match a "
12048 "later IMPLICIT type", sym->name, &sym->declared_at);
12049 return FAILURE;
12050 }
12051
12052 /* Make sure the types of derived parameters are consistent. This
12053 type checking is deferred until resolution because the type may
12054 refer to a derived type from the host. */
12055 if (sym->ts.type == BT_DERIVED
12056 && !gfc_compare_types (&sym->ts, &sym->value->ts))
12057 {
12058 gfc_error ("Incompatible derived type in PARAMETER at %L",
12059 &sym->value->where);
12060 return FAILURE;
12061 }
12062 return SUCCESS;
12063 }
12064
12065
12066 /* Do anything necessary to resolve a symbol. Right now, we just
12067 assume that an otherwise unknown symbol is a variable. This sort
12068 of thing commonly happens for symbols in module. */
12069
12070 static void
12071 resolve_symbol (gfc_symbol *sym)
12072 {
12073 int check_constant, mp_flag;
12074 gfc_symtree *symtree;
12075 gfc_symtree *this_symtree;
12076 gfc_namespace *ns;
12077 gfc_component *c;
12078
12079 if (sym->attr.flavor == FL_UNKNOWN)
12080 {
12081
12082 /* If we find that a flavorless symbol is an interface in one of the
12083 parent namespaces, find its symtree in this namespace, free the
12084 symbol and set the symtree to point to the interface symbol. */
12085 for (ns = gfc_current_ns->parent; ns; ns = ns->parent)
12086 {
12087 symtree = gfc_find_symtree (ns->sym_root, sym->name);
12088 if (symtree && (symtree->n.sym->generic ||
12089 (symtree->n.sym->attr.flavor == FL_PROCEDURE
12090 && sym->ns->construct_entities)))
12091 {
12092 this_symtree = gfc_find_symtree (gfc_current_ns->sym_root,
12093 sym->name);
12094 gfc_release_symbol (sym);
12095 symtree->n.sym->refs++;
12096 this_symtree->n.sym = symtree->n.sym;
12097 return;
12098 }
12099 }
12100
12101 /* Otherwise give it a flavor according to such attributes as
12102 it has. */
12103 if (sym->attr.external == 0 && sym->attr.intrinsic == 0)
12104 sym->attr.flavor = FL_VARIABLE;
12105 else
12106 {
12107 sym->attr.flavor = FL_PROCEDURE;
12108 if (sym->attr.dimension)
12109 sym->attr.function = 1;
12110 }
12111 }
12112
12113 if (sym->attr.external && sym->ts.type != BT_UNKNOWN && !sym->attr.function)
12114 gfc_add_function (&sym->attr, sym->name, &sym->declared_at);
12115
12116 if (sym->attr.procedure && sym->ts.interface
12117 && sym->attr.if_source != IFSRC_DECL
12118 && resolve_procedure_interface (sym) == FAILURE)
12119 return;
12120
12121 if (sym->attr.is_protected && !sym->attr.proc_pointer
12122 && (sym->attr.procedure || sym->attr.external))
12123 {
12124 if (sym->attr.external)
12125 gfc_error ("PROTECTED attribute conflicts with EXTERNAL attribute "
12126 "at %L", &sym->declared_at);
12127 else
12128 gfc_error ("PROCEDURE attribute conflicts with PROTECTED attribute "
12129 "at %L", &sym->declared_at);
12130
12131 return;
12132 }
12133
12134
12135 /* F2008, C530. */
12136 if (sym->attr.contiguous
12137 && (!sym->attr.dimension || (sym->as->type != AS_ASSUMED_SHAPE
12138 && !sym->attr.pointer)))
12139 {
12140 gfc_error ("'%s' at %L has the CONTIGUOUS attribute but is not an "
12141 "array pointer or an assumed-shape array", sym->name,
12142 &sym->declared_at);
12143 return;
12144 }
12145
12146 if (sym->attr.flavor == FL_DERIVED && resolve_fl_derived (sym) == FAILURE)
12147 return;
12148
12149 /* Symbols that are module procedures with results (functions) have
12150 the types and array specification copied for type checking in
12151 procedures that call them, as well as for saving to a module
12152 file. These symbols can't stand the scrutiny that their results
12153 can. */
12154 mp_flag = (sym->result != NULL && sym->result != sym);
12155
12156 /* Make sure that the intrinsic is consistent with its internal
12157 representation. This needs to be done before assigning a default
12158 type to avoid spurious warnings. */
12159 if (sym->attr.flavor != FL_MODULE && sym->attr.intrinsic
12160 && resolve_intrinsic (sym, &sym->declared_at) == FAILURE)
12161 return;
12162
12163 /* Resolve associate names. */
12164 if (sym->assoc)
12165 resolve_assoc_var (sym, true);
12166
12167 /* Assign default type to symbols that need one and don't have one. */
12168 if (sym->ts.type == BT_UNKNOWN)
12169 {
12170 if (sym->attr.flavor == FL_VARIABLE || sym->attr.flavor == FL_PARAMETER)
12171 gfc_set_default_type (sym, 1, NULL);
12172
12173 if (sym->attr.flavor == FL_PROCEDURE && sym->attr.external
12174 && !sym->attr.function && !sym->attr.subroutine
12175 && gfc_get_default_type (sym->name, sym->ns)->type == BT_UNKNOWN)
12176 gfc_add_subroutine (&sym->attr, sym->name, &sym->declared_at);
12177
12178 if (sym->attr.flavor == FL_PROCEDURE && sym->attr.function)
12179 {
12180 /* The specific case of an external procedure should emit an error
12181 in the case that there is no implicit type. */
12182 if (!mp_flag)
12183 gfc_set_default_type (sym, sym->attr.external, NULL);
12184 else
12185 {
12186 /* Result may be in another namespace. */
12187 resolve_symbol (sym->result);
12188
12189 if (!sym->result->attr.proc_pointer)
12190 {
12191 sym->ts = sym->result->ts;
12192 sym->as = gfc_copy_array_spec (sym->result->as);
12193 sym->attr.dimension = sym->result->attr.dimension;
12194 sym->attr.pointer = sym->result->attr.pointer;
12195 sym->attr.allocatable = sym->result->attr.allocatable;
12196 sym->attr.contiguous = sym->result->attr.contiguous;
12197 }
12198 }
12199 }
12200 }
12201
12202 /* Assumed size arrays and assumed shape arrays must be dummy
12203 arguments. Array-spec's of implied-shape should have been resolved to
12204 AS_EXPLICIT already. */
12205
12206 if (sym->as)
12207 {
12208 gcc_assert (sym->as->type != AS_IMPLIED_SHAPE);
12209 if (((sym->as->type == AS_ASSUMED_SIZE && !sym->as->cp_was_assumed)
12210 || sym->as->type == AS_ASSUMED_SHAPE)
12211 && sym->attr.dummy == 0)
12212 {
12213 if (sym->as->type == AS_ASSUMED_SIZE)
12214 gfc_error ("Assumed size array at %L must be a dummy argument",
12215 &sym->declared_at);
12216 else
12217 gfc_error ("Assumed shape array at %L must be a dummy argument",
12218 &sym->declared_at);
12219 return;
12220 }
12221 }
12222
12223 /* Make sure symbols with known intent or optional are really dummy
12224 variable. Because of ENTRY statement, this has to be deferred
12225 until resolution time. */
12226
12227 if (!sym->attr.dummy
12228 && (sym->attr.optional || sym->attr.intent != INTENT_UNKNOWN))
12229 {
12230 gfc_error ("Symbol at %L is not a DUMMY variable", &sym->declared_at);
12231 return;
12232 }
12233
12234 if (sym->attr.value && !sym->attr.dummy)
12235 {
12236 gfc_error ("'%s' at %L cannot have the VALUE attribute because "
12237 "it is not a dummy argument", sym->name, &sym->declared_at);
12238 return;
12239 }
12240
12241 if (sym->attr.value && sym->ts.type == BT_CHARACTER)
12242 {
12243 gfc_charlen *cl = sym->ts.u.cl;
12244 if (!cl || !cl->length || cl->length->expr_type != EXPR_CONSTANT)
12245 {
12246 gfc_error ("Character dummy variable '%s' at %L with VALUE "
12247 "attribute must have constant length",
12248 sym->name, &sym->declared_at);
12249 return;
12250 }
12251
12252 if (sym->ts.is_c_interop
12253 && mpz_cmp_si (cl->length->value.integer, 1) != 0)
12254 {
12255 gfc_error ("C interoperable character dummy variable '%s' at %L "
12256 "with VALUE attribute must have length one",
12257 sym->name, &sym->declared_at);
12258 return;
12259 }
12260 }
12261
12262 /* If the symbol is marked as bind(c), verify it's type and kind. Do not
12263 do this for something that was implicitly typed because that is handled
12264 in gfc_set_default_type. Handle dummy arguments and procedure
12265 definitions separately. Also, anything that is use associated is not
12266 handled here but instead is handled in the module it is declared in.
12267 Finally, derived type definitions are allowed to be BIND(C) since that
12268 only implies that they're interoperable, and they are checked fully for
12269 interoperability when a variable is declared of that type. */
12270 if (sym->attr.is_bind_c && sym->attr.implicit_type == 0 &&
12271 sym->attr.use_assoc == 0 && sym->attr.dummy == 0 &&
12272 sym->attr.flavor != FL_PROCEDURE && sym->attr.flavor != FL_DERIVED)
12273 {
12274 gfc_try t = SUCCESS;
12275
12276 /* First, make sure the variable is declared at the
12277 module-level scope (J3/04-007, Section 15.3). */
12278 if (sym->ns->proc_name->attr.flavor != FL_MODULE &&
12279 sym->attr.in_common == 0)
12280 {
12281 gfc_error ("Variable '%s' at %L cannot be BIND(C) because it "
12282 "is neither a COMMON block nor declared at the "
12283 "module level scope", sym->name, &(sym->declared_at));
12284 t = FAILURE;
12285 }
12286 else if (sym->common_head != NULL)
12287 {
12288 t = verify_com_block_vars_c_interop (sym->common_head);
12289 }
12290 else
12291 {
12292 /* If type() declaration, we need to verify that the components
12293 of the given type are all C interoperable, etc. */
12294 if (sym->ts.type == BT_DERIVED &&
12295 sym->ts.u.derived->attr.is_c_interop != 1)
12296 {
12297 /* Make sure the user marked the derived type as BIND(C). If
12298 not, call the verify routine. This could print an error
12299 for the derived type more than once if multiple variables
12300 of that type are declared. */
12301 if (sym->ts.u.derived->attr.is_bind_c != 1)
12302 verify_bind_c_derived_type (sym->ts.u.derived);
12303 t = FAILURE;
12304 }
12305
12306 /* Verify the variable itself as C interoperable if it
12307 is BIND(C). It is not possible for this to succeed if
12308 the verify_bind_c_derived_type failed, so don't have to handle
12309 any error returned by verify_bind_c_derived_type. */
12310 t = verify_bind_c_sym (sym, &(sym->ts), sym->attr.in_common,
12311 sym->common_block);
12312 }
12313
12314 if (t == FAILURE)
12315 {
12316 /* clear the is_bind_c flag to prevent reporting errors more than
12317 once if something failed. */
12318 sym->attr.is_bind_c = 0;
12319 return;
12320 }
12321 }
12322
12323 /* If a derived type symbol has reached this point, without its
12324 type being declared, we have an error. Notice that most
12325 conditions that produce undefined derived types have already
12326 been dealt with. However, the likes of:
12327 implicit type(t) (t) ..... call foo (t) will get us here if
12328 the type is not declared in the scope of the implicit
12329 statement. Change the type to BT_UNKNOWN, both because it is so
12330 and to prevent an ICE. */
12331 if (sym->ts.type == BT_DERIVED && sym->ts.u.derived->components == NULL
12332 && !sym->ts.u.derived->attr.zero_comp)
12333 {
12334 gfc_error ("The derived type '%s' at %L is of type '%s', "
12335 "which has not been defined", sym->name,
12336 &sym->declared_at, sym->ts.u.derived->name);
12337 sym->ts.type = BT_UNKNOWN;
12338 return;
12339 }
12340
12341 /* Make sure that the derived type has been resolved and that the
12342 derived type is visible in the symbol's namespace, if it is a
12343 module function and is not PRIVATE. */
12344 if (sym->ts.type == BT_DERIVED
12345 && sym->ts.u.derived->attr.use_assoc
12346 && sym->ns->proc_name
12347 && sym->ns->proc_name->attr.flavor == FL_MODULE)
12348 {
12349 gfc_symbol *ds;
12350
12351 if (resolve_fl_derived (sym->ts.u.derived) == FAILURE)
12352 return;
12353
12354 gfc_find_symbol (sym->ts.u.derived->name, sym->ns, 1, &ds);
12355 if (!ds && sym->attr.function && gfc_check_symbol_access (sym))
12356 {
12357 symtree = gfc_new_symtree (&sym->ns->sym_root,
12358 sym->ts.u.derived->name);
12359 symtree->n.sym = sym->ts.u.derived;
12360 sym->ts.u.derived->refs++;
12361 }
12362 }
12363
12364 /* Unless the derived-type declaration is use associated, Fortran 95
12365 does not allow public entries of private derived types.
12366 See 4.4.1 (F95) and 4.5.1.1 (F2003); and related interpretation
12367 161 in 95-006r3. */
12368 if (sym->ts.type == BT_DERIVED
12369 && sym->ns->proc_name && sym->ns->proc_name->attr.flavor == FL_MODULE
12370 && !sym->ts.u.derived->attr.use_assoc
12371 && gfc_check_symbol_access (sym)
12372 && !gfc_check_symbol_access (sym->ts.u.derived)
12373 && gfc_notify_std (GFC_STD_F2003, "Fortran 2003: PUBLIC %s '%s' at %L "
12374 "of PRIVATE derived type '%s'",
12375 (sym->attr.flavor == FL_PARAMETER) ? "parameter"
12376 : "variable", sym->name, &sym->declared_at,
12377 sym->ts.u.derived->name) == FAILURE)
12378 return;
12379
12380 /* F2008, C1302. */
12381 if (sym->ts.type == BT_DERIVED
12382 && sym->ts.u.derived->from_intmod == INTMOD_ISO_FORTRAN_ENV
12383 && sym->ts.u.derived->intmod_sym_id == ISOFORTRAN_LOCK_TYPE
12384 && !sym->attr.codimension)
12385 {
12386 gfc_error ("Variable '%s' at %L of type LOCK_TYPE must be a coarray",
12387 sym->name, &sym->declared_at);
12388 return;
12389 }
12390
12391 /* An assumed-size array with INTENT(OUT) shall not be of a type for which
12392 default initialization is defined (5.1.2.4.4). */
12393 if (sym->ts.type == BT_DERIVED
12394 && sym->attr.dummy
12395 && sym->attr.intent == INTENT_OUT
12396 && sym->as
12397 && sym->as->type == AS_ASSUMED_SIZE)
12398 {
12399 for (c = sym->ts.u.derived->components; c; c = c->next)
12400 {
12401 if (c->initializer)
12402 {
12403 gfc_error ("The INTENT(OUT) dummy argument '%s' at %L is "
12404 "ASSUMED SIZE and so cannot have a default initializer",
12405 sym->name, &sym->declared_at);
12406 return;
12407 }
12408 }
12409 }
12410
12411 /* F2008, C542. */
12412 if (sym->ts.type == BT_DERIVED && sym->attr.dummy
12413 && sym->attr.intent == INTENT_OUT && sym->attr.lock_comp)
12414 gfc_error ("Dummy argument '%s' at %L of LOCK_TYPE shall not be "
12415 "INTENT(OUT)", sym->name, &sym->declared_at);
12416
12417 /* F2008, C526. */
12418 if (((sym->ts.type == BT_DERIVED && sym->ts.u.derived->attr.coarray_comp)
12419 || sym->attr.codimension)
12420 && sym->attr.result)
12421 gfc_error ("Function result '%s' at %L shall not be a coarray or have "
12422 "a coarray component", sym->name, &sym->declared_at);
12423
12424 /* F2008, C524. */
12425 if (sym->attr.codimension && sym->ts.type == BT_DERIVED
12426 && sym->ts.u.derived->ts.is_iso_c)
12427 gfc_error ("Variable '%s' at %L of TYPE(C_PTR) or TYPE(C_FUNPTR) "
12428 "shall not be a coarray", sym->name, &sym->declared_at);
12429
12430 /* F2008, C525. */
12431 if (sym->ts.type == BT_DERIVED && sym->ts.u.derived->attr.coarray_comp
12432 && (sym->attr.codimension || sym->attr.pointer || sym->attr.dimension
12433 || sym->attr.allocatable))
12434 gfc_error ("Variable '%s' at %L with coarray component "
12435 "shall be a nonpointer, nonallocatable scalar",
12436 sym->name, &sym->declared_at);
12437
12438 /* F2008, C526. The function-result case was handled above. */
12439 if (((sym->ts.type == BT_DERIVED && sym->ts.u.derived->attr.coarray_comp)
12440 || sym->attr.codimension)
12441 && !(sym->attr.allocatable || sym->attr.dummy || sym->attr.save
12442 || sym->ns->save_all
12443 || sym->ns->proc_name->attr.flavor == FL_MODULE
12444 || sym->ns->proc_name->attr.is_main_program
12445 || sym->attr.function || sym->attr.result || sym->attr.use_assoc))
12446 gfc_error ("Variable '%s' at %L is a coarray or has a coarray "
12447 "component and is not ALLOCATABLE, SAVE nor a "
12448 "dummy argument", sym->name, &sym->declared_at);
12449 /* F2008, C528. */ /* FIXME: sym->as check due to PR 43412. */
12450 else if (sym->attr.codimension && !sym->attr.allocatable
12451 && sym->as && sym->as->cotype == AS_DEFERRED)
12452 gfc_error ("Coarray variable '%s' at %L shall not have codimensions with "
12453 "deferred shape", sym->name, &sym->declared_at);
12454 else if (sym->attr.codimension && sym->attr.allocatable
12455 && (sym->as->type != AS_DEFERRED || sym->as->cotype != AS_DEFERRED))
12456 gfc_error ("Allocatable coarray variable '%s' at %L must have "
12457 "deferred shape", sym->name, &sym->declared_at);
12458
12459
12460 /* F2008, C541. */
12461 if (((sym->ts.type == BT_DERIVED && sym->ts.u.derived->attr.coarray_comp)
12462 || (sym->attr.codimension && sym->attr.allocatable))
12463 && sym->attr.dummy && sym->attr.intent == INTENT_OUT)
12464 gfc_error ("Variable '%s' at %L is INTENT(OUT) and can thus not be an "
12465 "allocatable coarray or have coarray components",
12466 sym->name, &sym->declared_at);
12467
12468 if (sym->attr.codimension && sym->attr.dummy
12469 && sym->ns->proc_name && sym->ns->proc_name->attr.is_bind_c)
12470 gfc_error ("Coarray dummy variable '%s' at %L not allowed in BIND(C) "
12471 "procedure '%s'", sym->name, &sym->declared_at,
12472 sym->ns->proc_name->name);
12473
12474 switch (sym->attr.flavor)
12475 {
12476 case FL_VARIABLE:
12477 if (resolve_fl_variable (sym, mp_flag) == FAILURE)
12478 return;
12479 break;
12480
12481 case FL_PROCEDURE:
12482 if (resolve_fl_procedure (sym, mp_flag) == FAILURE)
12483 return;
12484 break;
12485
12486 case FL_NAMELIST:
12487 if (resolve_fl_namelist (sym) == FAILURE)
12488 return;
12489 break;
12490
12491 case FL_PARAMETER:
12492 if (resolve_fl_parameter (sym) == FAILURE)
12493 return;
12494 break;
12495
12496 default:
12497 break;
12498 }
12499
12500 /* Resolve array specifier. Check as well some constraints
12501 on COMMON blocks. */
12502
12503 check_constant = sym->attr.in_common && !sym->attr.pointer;
12504
12505 /* Set the formal_arg_flag so that check_conflict will not throw
12506 an error for host associated variables in the specification
12507 expression for an array_valued function. */
12508 if (sym->attr.function && sym->as)
12509 formal_arg_flag = 1;
12510
12511 gfc_resolve_array_spec (sym->as, check_constant);
12512
12513 formal_arg_flag = 0;
12514
12515 /* Resolve formal namespaces. */
12516 if (sym->formal_ns && sym->formal_ns != gfc_current_ns
12517 && !sym->attr.contained && !sym->attr.intrinsic)
12518 gfc_resolve (sym->formal_ns);
12519
12520 /* Make sure the formal namespace is present. */
12521 if (sym->formal && !sym->formal_ns)
12522 {
12523 gfc_formal_arglist *formal = sym->formal;
12524 while (formal && !formal->sym)
12525 formal = formal->next;
12526
12527 if (formal)
12528 {
12529 sym->formal_ns = formal->sym->ns;
12530 sym->formal_ns->refs++;
12531 }
12532 }
12533
12534 /* Check threadprivate restrictions. */
12535 if (sym->attr.threadprivate && !sym->attr.save && !sym->ns->save_all
12536 && (!sym->attr.in_common
12537 && sym->module == NULL
12538 && (sym->ns->proc_name == NULL
12539 || sym->ns->proc_name->attr.flavor != FL_MODULE)))
12540 gfc_error ("Threadprivate at %L isn't SAVEd", &sym->declared_at);
12541
12542 /* If we have come this far we can apply default-initializers, as
12543 described in 14.7.5, to those variables that have not already
12544 been assigned one. */
12545 if (sym->ts.type == BT_DERIVED
12546 && sym->ns == gfc_current_ns
12547 && !sym->value
12548 && !sym->attr.allocatable
12549 && !sym->attr.alloc_comp)
12550 {
12551 symbol_attribute *a = &sym->attr;
12552
12553 if ((!a->save && !a->dummy && !a->pointer
12554 && !a->in_common && !a->use_assoc
12555 && (a->referenced || a->result)
12556 && !(a->function && sym != sym->result))
12557 || (a->dummy && a->intent == INTENT_OUT && !a->pointer))
12558 apply_default_init (sym);
12559 }
12560
12561 if (sym->ts.type == BT_CLASS && sym->ns == gfc_current_ns
12562 && sym->attr.dummy && sym->attr.intent == INTENT_OUT
12563 && !CLASS_DATA (sym)->attr.class_pointer
12564 && !CLASS_DATA (sym)->attr.allocatable)
12565 apply_default_init (sym);
12566
12567 /* If this symbol has a type-spec, check it. */
12568 if (sym->attr.flavor == FL_VARIABLE || sym->attr.flavor == FL_PARAMETER
12569 || (sym->attr.flavor == FL_PROCEDURE && sym->attr.function))
12570 if (resolve_typespec_used (&sym->ts, &sym->declared_at, sym->name)
12571 == FAILURE)
12572 return;
12573 }
12574
12575
12576 /************* Resolve DATA statements *************/
12577
12578 static struct
12579 {
12580 gfc_data_value *vnode;
12581 mpz_t left;
12582 }
12583 values;
12584
12585
12586 /* Advance the values structure to point to the next value in the data list. */
12587
12588 static gfc_try
12589 next_data_value (void)
12590 {
12591 while (mpz_cmp_ui (values.left, 0) == 0)
12592 {
12593
12594 if (values.vnode->next == NULL)
12595 return FAILURE;
12596
12597 values.vnode = values.vnode->next;
12598 mpz_set (values.left, values.vnode->repeat);
12599 }
12600
12601 return SUCCESS;
12602 }
12603
12604
12605 static gfc_try
12606 check_data_variable (gfc_data_variable *var, locus *where)
12607 {
12608 gfc_expr *e;
12609 mpz_t size;
12610 mpz_t offset;
12611 gfc_try t;
12612 ar_type mark = AR_UNKNOWN;
12613 int i;
12614 mpz_t section_index[GFC_MAX_DIMENSIONS];
12615 gfc_ref *ref;
12616 gfc_array_ref *ar;
12617 gfc_symbol *sym;
12618 int has_pointer;
12619
12620 if (gfc_resolve_expr (var->expr) == FAILURE)
12621 return FAILURE;
12622
12623 ar = NULL;
12624 mpz_init_set_si (offset, 0);
12625 e = var->expr;
12626
12627 if (e->expr_type != EXPR_VARIABLE)
12628 gfc_internal_error ("check_data_variable(): Bad expression");
12629
12630 sym = e->symtree->n.sym;
12631
12632 if (sym->ns->is_block_data && !sym->attr.in_common)
12633 {
12634 gfc_error ("BLOCK DATA element '%s' at %L must be in COMMON",
12635 sym->name, &sym->declared_at);
12636 }
12637
12638 if (e->ref == NULL && sym->as)
12639 {
12640 gfc_error ("DATA array '%s' at %L must be specified in a previous"
12641 " declaration", sym->name, where);
12642 return FAILURE;
12643 }
12644
12645 has_pointer = sym->attr.pointer;
12646
12647 if (gfc_is_coindexed (e))
12648 {
12649 gfc_error ("DATA element '%s' at %L cannot have a coindex", sym->name,
12650 where);
12651 return FAILURE;
12652 }
12653
12654 for (ref = e->ref; ref; ref = ref->next)
12655 {
12656 if (ref->type == REF_COMPONENT && ref->u.c.component->attr.pointer)
12657 has_pointer = 1;
12658
12659 if (has_pointer
12660 && ref->type == REF_ARRAY
12661 && ref->u.ar.type != AR_FULL)
12662 {
12663 gfc_error ("DATA element '%s' at %L is a pointer and so must "
12664 "be a full array", sym->name, where);
12665 return FAILURE;
12666 }
12667 }
12668
12669 if (e->rank == 0 || has_pointer)
12670 {
12671 mpz_init_set_ui (size, 1);
12672 ref = NULL;
12673 }
12674 else
12675 {
12676 ref = e->ref;
12677
12678 /* Find the array section reference. */
12679 for (ref = e->ref; ref; ref = ref->next)
12680 {
12681 if (ref->type != REF_ARRAY)
12682 continue;
12683 if (ref->u.ar.type == AR_ELEMENT)
12684 continue;
12685 break;
12686 }
12687 gcc_assert (ref);
12688
12689 /* Set marks according to the reference pattern. */
12690 switch (ref->u.ar.type)
12691 {
12692 case AR_FULL:
12693 mark = AR_FULL;
12694 break;
12695
12696 case AR_SECTION:
12697 ar = &ref->u.ar;
12698 /* Get the start position of array section. */
12699 gfc_get_section_index (ar, section_index, &offset);
12700 mark = AR_SECTION;
12701 break;
12702
12703 default:
12704 gcc_unreachable ();
12705 }
12706
12707 if (gfc_array_size (e, &size) == FAILURE)
12708 {
12709 gfc_error ("Nonconstant array section at %L in DATA statement",
12710 &e->where);
12711 mpz_clear (offset);
12712 return FAILURE;
12713 }
12714 }
12715
12716 t = SUCCESS;
12717
12718 while (mpz_cmp_ui (size, 0) > 0)
12719 {
12720 if (next_data_value () == FAILURE)
12721 {
12722 gfc_error ("DATA statement at %L has more variables than values",
12723 where);
12724 t = FAILURE;
12725 break;
12726 }
12727
12728 t = gfc_check_assign (var->expr, values.vnode->expr, 0);
12729 if (t == FAILURE)
12730 break;
12731
12732 /* If we have more than one element left in the repeat count,
12733 and we have more than one element left in the target variable,
12734 then create a range assignment. */
12735 /* FIXME: Only done for full arrays for now, since array sections
12736 seem tricky. */
12737 if (mark == AR_FULL && ref && ref->next == NULL
12738 && mpz_cmp_ui (values.left, 1) > 0 && mpz_cmp_ui (size, 1) > 0)
12739 {
12740 mpz_t range;
12741
12742 if (mpz_cmp (size, values.left) >= 0)
12743 {
12744 mpz_init_set (range, values.left);
12745 mpz_sub (size, size, values.left);
12746 mpz_set_ui (values.left, 0);
12747 }
12748 else
12749 {
12750 mpz_init_set (range, size);
12751 mpz_sub (values.left, values.left, size);
12752 mpz_set_ui (size, 0);
12753 }
12754
12755 t = gfc_assign_data_value (var->expr, values.vnode->expr,
12756 offset, &range);
12757
12758 mpz_add (offset, offset, range);
12759 mpz_clear (range);
12760
12761 if (t == FAILURE)
12762 break;
12763 }
12764
12765 /* Assign initial value to symbol. */
12766 else
12767 {
12768 mpz_sub_ui (values.left, values.left, 1);
12769 mpz_sub_ui (size, size, 1);
12770
12771 t = gfc_assign_data_value (var->expr, values.vnode->expr,
12772 offset, NULL);
12773 if (t == FAILURE)
12774 break;
12775
12776 if (mark == AR_FULL)
12777 mpz_add_ui (offset, offset, 1);
12778
12779 /* Modify the array section indexes and recalculate the offset
12780 for next element. */
12781 else if (mark == AR_SECTION)
12782 gfc_advance_section (section_index, ar, &offset);
12783 }
12784 }
12785
12786 if (mark == AR_SECTION)
12787 {
12788 for (i = 0; i < ar->dimen; i++)
12789 mpz_clear (section_index[i]);
12790 }
12791
12792 mpz_clear (size);
12793 mpz_clear (offset);
12794
12795 return t;
12796 }
12797
12798
12799 static gfc_try traverse_data_var (gfc_data_variable *, locus *);
12800
12801 /* Iterate over a list of elements in a DATA statement. */
12802
12803 static gfc_try
12804 traverse_data_list (gfc_data_variable *var, locus *where)
12805 {
12806 mpz_t trip;
12807 iterator_stack frame;
12808 gfc_expr *e, *start, *end, *step;
12809 gfc_try retval = SUCCESS;
12810
12811 mpz_init (frame.value);
12812 mpz_init (trip);
12813
12814 start = gfc_copy_expr (var->iter.start);
12815 end = gfc_copy_expr (var->iter.end);
12816 step = gfc_copy_expr (var->iter.step);
12817
12818 if (gfc_simplify_expr (start, 1) == FAILURE
12819 || start->expr_type != EXPR_CONSTANT)
12820 {
12821 gfc_error ("start of implied-do loop at %L could not be "
12822 "simplified to a constant value", &start->where);
12823 retval = FAILURE;
12824 goto cleanup;
12825 }
12826 if (gfc_simplify_expr (end, 1) == FAILURE
12827 || end->expr_type != EXPR_CONSTANT)
12828 {
12829 gfc_error ("end of implied-do loop at %L could not be "
12830 "simplified to a constant value", &start->where);
12831 retval = FAILURE;
12832 goto cleanup;
12833 }
12834 if (gfc_simplify_expr (step, 1) == FAILURE
12835 || step->expr_type != EXPR_CONSTANT)
12836 {
12837 gfc_error ("step of implied-do loop at %L could not be "
12838 "simplified to a constant value", &start->where);
12839 retval = FAILURE;
12840 goto cleanup;
12841 }
12842
12843 mpz_set (trip, end->value.integer);
12844 mpz_sub (trip, trip, start->value.integer);
12845 mpz_add (trip, trip, step->value.integer);
12846
12847 mpz_div (trip, trip, step->value.integer);
12848
12849 mpz_set (frame.value, start->value.integer);
12850
12851 frame.prev = iter_stack;
12852 frame.variable = var->iter.var->symtree;
12853 iter_stack = &frame;
12854
12855 while (mpz_cmp_ui (trip, 0) > 0)
12856 {
12857 if (traverse_data_var (var->list, where) == FAILURE)
12858 {
12859 retval = FAILURE;
12860 goto cleanup;
12861 }
12862
12863 e = gfc_copy_expr (var->expr);
12864 if (gfc_simplify_expr (e, 1) == FAILURE)
12865 {
12866 gfc_free_expr (e);
12867 retval = FAILURE;
12868 goto cleanup;
12869 }
12870
12871 mpz_add (frame.value, frame.value, step->value.integer);
12872
12873 mpz_sub_ui (trip, trip, 1);
12874 }
12875
12876 cleanup:
12877 mpz_clear (frame.value);
12878 mpz_clear (trip);
12879
12880 gfc_free_expr (start);
12881 gfc_free_expr (end);
12882 gfc_free_expr (step);
12883
12884 iter_stack = frame.prev;
12885 return retval;
12886 }
12887
12888
12889 /* Type resolve variables in the variable list of a DATA statement. */
12890
12891 static gfc_try
12892 traverse_data_var (gfc_data_variable *var, locus *where)
12893 {
12894 gfc_try t;
12895
12896 for (; var; var = var->next)
12897 {
12898 if (var->expr == NULL)
12899 t = traverse_data_list (var, where);
12900 else
12901 t = check_data_variable (var, where);
12902
12903 if (t == FAILURE)
12904 return FAILURE;
12905 }
12906
12907 return SUCCESS;
12908 }
12909
12910
12911 /* Resolve the expressions and iterators associated with a data statement.
12912 This is separate from the assignment checking because data lists should
12913 only be resolved once. */
12914
12915 static gfc_try
12916 resolve_data_variables (gfc_data_variable *d)
12917 {
12918 for (; d; d = d->next)
12919 {
12920 if (d->list == NULL)
12921 {
12922 if (gfc_resolve_expr (d->expr) == FAILURE)
12923 return FAILURE;
12924 }
12925 else
12926 {
12927 if (gfc_resolve_iterator (&d->iter, false) == FAILURE)
12928 return FAILURE;
12929
12930 if (resolve_data_variables (d->list) == FAILURE)
12931 return FAILURE;
12932 }
12933 }
12934
12935 return SUCCESS;
12936 }
12937
12938
12939 /* Resolve a single DATA statement. We implement this by storing a pointer to
12940 the value list into static variables, and then recursively traversing the
12941 variables list, expanding iterators and such. */
12942
12943 static void
12944 resolve_data (gfc_data *d)
12945 {
12946
12947 if (resolve_data_variables (d->var) == FAILURE)
12948 return;
12949
12950 values.vnode = d->value;
12951 if (d->value == NULL)
12952 mpz_set_ui (values.left, 0);
12953 else
12954 mpz_set (values.left, d->value->repeat);
12955
12956 if (traverse_data_var (d->var, &d->where) == FAILURE)
12957 return;
12958
12959 /* At this point, we better not have any values left. */
12960
12961 if (next_data_value () == SUCCESS)
12962 gfc_error ("DATA statement at %L has more values than variables",
12963 &d->where);
12964 }
12965
12966
12967 /* 12.6 Constraint: In a pure subprogram any variable which is in common or
12968 accessed by host or use association, is a dummy argument to a pure function,
12969 is a dummy argument with INTENT (IN) to a pure subroutine, or an object that
12970 is storage associated with any such variable, shall not be used in the
12971 following contexts: (clients of this function). */
12972
12973 /* Determines if a variable is not 'pure', i.e., not assignable within a pure
12974 procedure. Returns zero if assignment is OK, nonzero if there is a
12975 problem. */
12976 int
12977 gfc_impure_variable (gfc_symbol *sym)
12978 {
12979 gfc_symbol *proc;
12980 gfc_namespace *ns;
12981
12982 if (sym->attr.use_assoc || sym->attr.in_common)
12983 return 1;
12984
12985 /* Check if the symbol's ns is inside the pure procedure. */
12986 for (ns = gfc_current_ns; ns; ns = ns->parent)
12987 {
12988 if (ns == sym->ns)
12989 break;
12990 if (ns->proc_name->attr.flavor == FL_PROCEDURE && !sym->attr.function)
12991 return 1;
12992 }
12993
12994 proc = sym->ns->proc_name;
12995 if (sym->attr.dummy && gfc_pure (proc)
12996 && ((proc->attr.subroutine && sym->attr.intent == INTENT_IN)
12997 ||
12998 proc->attr.function))
12999 return 1;
13000
13001 /* TODO: Sort out what can be storage associated, if anything, and include
13002 it here. In principle equivalences should be scanned but it does not
13003 seem to be possible to storage associate an impure variable this way. */
13004 return 0;
13005 }
13006
13007
13008 /* Test whether a symbol is pure or not. For a NULL pointer, checks if the
13009 current namespace is inside a pure procedure. */
13010
13011 int
13012 gfc_pure (gfc_symbol *sym)
13013 {
13014 symbol_attribute attr;
13015 gfc_namespace *ns;
13016
13017 if (sym == NULL)
13018 {
13019 /* Check if the current namespace or one of its parents
13020 belongs to a pure procedure. */
13021 for (ns = gfc_current_ns; ns; ns = ns->parent)
13022 {
13023 sym = ns->proc_name;
13024 if (sym == NULL)
13025 return 0;
13026 attr = sym->attr;
13027 if (attr.flavor == FL_PROCEDURE && attr.pure)
13028 return 1;
13029 }
13030 return 0;
13031 }
13032
13033 attr = sym->attr;
13034
13035 return attr.flavor == FL_PROCEDURE && attr.pure;
13036 }
13037
13038
13039 /* Test whether a symbol is implicitly pure or not. For a NULL pointer,
13040 checks if the current namespace is implicitly pure. Note that this
13041 function returns false for a PURE procedure. */
13042
13043 int
13044 gfc_implicit_pure (gfc_symbol *sym)
13045 {
13046 symbol_attribute attr;
13047
13048 if (sym == NULL)
13049 {
13050 /* Check if the current namespace is implicit_pure. */
13051 sym = gfc_current_ns->proc_name;
13052 if (sym == NULL)
13053 return 0;
13054 attr = sym->attr;
13055 if (attr.flavor == FL_PROCEDURE
13056 && attr.implicit_pure && !attr.pure)
13057 return 1;
13058 return 0;
13059 }
13060
13061 attr = sym->attr;
13062
13063 return attr.flavor == FL_PROCEDURE && attr.implicit_pure && !attr.pure;
13064 }
13065
13066
13067 /* Test whether the current procedure is elemental or not. */
13068
13069 int
13070 gfc_elemental (gfc_symbol *sym)
13071 {
13072 symbol_attribute attr;
13073
13074 if (sym == NULL)
13075 sym = gfc_current_ns->proc_name;
13076 if (sym == NULL)
13077 return 0;
13078 attr = sym->attr;
13079
13080 return attr.flavor == FL_PROCEDURE && attr.elemental;
13081 }
13082
13083
13084 /* Warn about unused labels. */
13085
13086 static void
13087 warn_unused_fortran_label (gfc_st_label *label)
13088 {
13089 if (label == NULL)
13090 return;
13091
13092 warn_unused_fortran_label (label->left);
13093
13094 if (label->defined == ST_LABEL_UNKNOWN)
13095 return;
13096
13097 switch (label->referenced)
13098 {
13099 case ST_LABEL_UNKNOWN:
13100 gfc_warning ("Label %d at %L defined but not used", label->value,
13101 &label->where);
13102 break;
13103
13104 case ST_LABEL_BAD_TARGET:
13105 gfc_warning ("Label %d at %L defined but cannot be used",
13106 label->value, &label->where);
13107 break;
13108
13109 default:
13110 break;
13111 }
13112
13113 warn_unused_fortran_label (label->right);
13114 }
13115
13116
13117 /* Returns the sequence type of a symbol or sequence. */
13118
13119 static seq_type
13120 sequence_type (gfc_typespec ts)
13121 {
13122 seq_type result;
13123 gfc_component *c;
13124
13125 switch (ts.type)
13126 {
13127 case BT_DERIVED:
13128
13129 if (ts.u.derived->components == NULL)
13130 return SEQ_NONDEFAULT;
13131
13132 result = sequence_type (ts.u.derived->components->ts);
13133 for (c = ts.u.derived->components->next; c; c = c->next)
13134 if (sequence_type (c->ts) != result)
13135 return SEQ_MIXED;
13136
13137 return result;
13138
13139 case BT_CHARACTER:
13140 if (ts.kind != gfc_default_character_kind)
13141 return SEQ_NONDEFAULT;
13142
13143 return SEQ_CHARACTER;
13144
13145 case BT_INTEGER:
13146 if (ts.kind != gfc_default_integer_kind)
13147 return SEQ_NONDEFAULT;
13148
13149 return SEQ_NUMERIC;
13150
13151 case BT_REAL:
13152 if (!(ts.kind == gfc_default_real_kind
13153 || ts.kind == gfc_default_double_kind))
13154 return SEQ_NONDEFAULT;
13155
13156 return SEQ_NUMERIC;
13157
13158 case BT_COMPLEX:
13159 if (ts.kind != gfc_default_complex_kind)
13160 return SEQ_NONDEFAULT;
13161
13162 return SEQ_NUMERIC;
13163
13164 case BT_LOGICAL:
13165 if (ts.kind != gfc_default_logical_kind)
13166 return SEQ_NONDEFAULT;
13167
13168 return SEQ_NUMERIC;
13169
13170 default:
13171 return SEQ_NONDEFAULT;
13172 }
13173 }
13174
13175
13176 /* Resolve derived type EQUIVALENCE object. */
13177
13178 static gfc_try
13179 resolve_equivalence_derived (gfc_symbol *derived, gfc_symbol *sym, gfc_expr *e)
13180 {
13181 gfc_component *c = derived->components;
13182
13183 if (!derived)
13184 return SUCCESS;
13185
13186 /* Shall not be an object of nonsequence derived type. */
13187 if (!derived->attr.sequence)
13188 {
13189 gfc_error ("Derived type variable '%s' at %L must have SEQUENCE "
13190 "attribute to be an EQUIVALENCE object", sym->name,
13191 &e->where);
13192 return FAILURE;
13193 }
13194
13195 /* Shall not have allocatable components. */
13196 if (derived->attr.alloc_comp)
13197 {
13198 gfc_error ("Derived type variable '%s' at %L cannot have ALLOCATABLE "
13199 "components to be an EQUIVALENCE object",sym->name,
13200 &e->where);
13201 return FAILURE;
13202 }
13203
13204 if (sym->attr.in_common && gfc_has_default_initializer (sym->ts.u.derived))
13205 {
13206 gfc_error ("Derived type variable '%s' at %L with default "
13207 "initialization cannot be in EQUIVALENCE with a variable "
13208 "in COMMON", sym->name, &e->where);
13209 return FAILURE;
13210 }
13211
13212 for (; c ; c = c->next)
13213 {
13214 if (c->ts.type == BT_DERIVED
13215 && (resolve_equivalence_derived (c->ts.u.derived, sym, e) == FAILURE))
13216 return FAILURE;
13217
13218 /* Shall not be an object of sequence derived type containing a pointer
13219 in the structure. */
13220 if (c->attr.pointer)
13221 {
13222 gfc_error ("Derived type variable '%s' at %L with pointer "
13223 "component(s) cannot be an EQUIVALENCE object",
13224 sym->name, &e->where);
13225 return FAILURE;
13226 }
13227 }
13228 return SUCCESS;
13229 }
13230
13231
13232 /* Resolve equivalence object.
13233 An EQUIVALENCE object shall not be a dummy argument, a pointer, a target,
13234 an allocatable array, an object of nonsequence derived type, an object of
13235 sequence derived type containing a pointer at any level of component
13236 selection, an automatic object, a function name, an entry name, a result
13237 name, a named constant, a structure component, or a subobject of any of
13238 the preceding objects. A substring shall not have length zero. A
13239 derived type shall not have components with default initialization nor
13240 shall two objects of an equivalence group be initialized.
13241 Either all or none of the objects shall have an protected attribute.
13242 The simple constraints are done in symbol.c(check_conflict) and the rest
13243 are implemented here. */
13244
13245 static void
13246 resolve_equivalence (gfc_equiv *eq)
13247 {
13248 gfc_symbol *sym;
13249 gfc_symbol *first_sym;
13250 gfc_expr *e;
13251 gfc_ref *r;
13252 locus *last_where = NULL;
13253 seq_type eq_type, last_eq_type;
13254 gfc_typespec *last_ts;
13255 int object, cnt_protected;
13256 const char *msg;
13257
13258 last_ts = &eq->expr->symtree->n.sym->ts;
13259
13260 first_sym = eq->expr->symtree->n.sym;
13261
13262 cnt_protected = 0;
13263
13264 for (object = 1; eq; eq = eq->eq, object++)
13265 {
13266 e = eq->expr;
13267
13268 e->ts = e->symtree->n.sym->ts;
13269 /* match_varspec might not know yet if it is seeing
13270 array reference or substring reference, as it doesn't
13271 know the types. */
13272 if (e->ref && e->ref->type == REF_ARRAY)
13273 {
13274 gfc_ref *ref = e->ref;
13275 sym = e->symtree->n.sym;
13276
13277 if (sym->attr.dimension)
13278 {
13279 ref->u.ar.as = sym->as;
13280 ref = ref->next;
13281 }
13282
13283 /* For substrings, convert REF_ARRAY into REF_SUBSTRING. */
13284 if (e->ts.type == BT_CHARACTER
13285 && ref
13286 && ref->type == REF_ARRAY
13287 && ref->u.ar.dimen == 1
13288 && ref->u.ar.dimen_type[0] == DIMEN_RANGE
13289 && ref->u.ar.stride[0] == NULL)
13290 {
13291 gfc_expr *start = ref->u.ar.start[0];
13292 gfc_expr *end = ref->u.ar.end[0];
13293 void *mem = NULL;
13294
13295 /* Optimize away the (:) reference. */
13296 if (start == NULL && end == NULL)
13297 {
13298 if (e->ref == ref)
13299 e->ref = ref->next;
13300 else
13301 e->ref->next = ref->next;
13302 mem = ref;
13303 }
13304 else
13305 {
13306 ref->type = REF_SUBSTRING;
13307 if (start == NULL)
13308 start = gfc_get_int_expr (gfc_default_integer_kind,
13309 NULL, 1);
13310 ref->u.ss.start = start;
13311 if (end == NULL && e->ts.u.cl)
13312 end = gfc_copy_expr (e->ts.u.cl->length);
13313 ref->u.ss.end = end;
13314 ref->u.ss.length = e->ts.u.cl;
13315 e->ts.u.cl = NULL;
13316 }
13317 ref = ref->next;
13318 free (mem);
13319 }
13320
13321 /* Any further ref is an error. */
13322 if (ref)
13323 {
13324 gcc_assert (ref->type == REF_ARRAY);
13325 gfc_error ("Syntax error in EQUIVALENCE statement at %L",
13326 &ref->u.ar.where);
13327 continue;
13328 }
13329 }
13330
13331 if (gfc_resolve_expr (e) == FAILURE)
13332 continue;
13333
13334 sym = e->symtree->n.sym;
13335
13336 if (sym->attr.is_protected)
13337 cnt_protected++;
13338 if (cnt_protected > 0 && cnt_protected != object)
13339 {
13340 gfc_error ("Either all or none of the objects in the "
13341 "EQUIVALENCE set at %L shall have the "
13342 "PROTECTED attribute",
13343 &e->where);
13344 break;
13345 }
13346
13347 /* Shall not equivalence common block variables in a PURE procedure. */
13348 if (sym->ns->proc_name
13349 && sym->ns->proc_name->attr.pure
13350 && sym->attr.in_common)
13351 {
13352 gfc_error ("Common block member '%s' at %L cannot be an EQUIVALENCE "
13353 "object in the pure procedure '%s'",
13354 sym->name, &e->where, sym->ns->proc_name->name);
13355 break;
13356 }
13357
13358 /* Shall not be a named constant. */
13359 if (e->expr_type == EXPR_CONSTANT)
13360 {
13361 gfc_error ("Named constant '%s' at %L cannot be an EQUIVALENCE "
13362 "object", sym->name, &e->where);
13363 continue;
13364 }
13365
13366 if (e->ts.type == BT_DERIVED
13367 && resolve_equivalence_derived (e->ts.u.derived, sym, e) == FAILURE)
13368 continue;
13369
13370 /* Check that the types correspond correctly:
13371 Note 5.28:
13372 A numeric sequence structure may be equivalenced to another sequence
13373 structure, an object of default integer type, default real type, double
13374 precision real type, default logical type such that components of the
13375 structure ultimately only become associated to objects of the same
13376 kind. A character sequence structure may be equivalenced to an object
13377 of default character kind or another character sequence structure.
13378 Other objects may be equivalenced only to objects of the same type and
13379 kind parameters. */
13380
13381 /* Identical types are unconditionally OK. */
13382 if (object == 1 || gfc_compare_types (last_ts, &sym->ts))
13383 goto identical_types;
13384
13385 last_eq_type = sequence_type (*last_ts);
13386 eq_type = sequence_type (sym->ts);
13387
13388 /* Since the pair of objects is not of the same type, mixed or
13389 non-default sequences can be rejected. */
13390
13391 msg = "Sequence %s with mixed components in EQUIVALENCE "
13392 "statement at %L with different type objects";
13393 if ((object ==2
13394 && last_eq_type == SEQ_MIXED
13395 && gfc_notify_std (GFC_STD_GNU, msg, first_sym->name, last_where)
13396 == FAILURE)
13397 || (eq_type == SEQ_MIXED
13398 && gfc_notify_std (GFC_STD_GNU, msg, sym->name,
13399 &e->where) == FAILURE))
13400 continue;
13401
13402 msg = "Non-default type object or sequence %s in EQUIVALENCE "
13403 "statement at %L with objects of different type";
13404 if ((object ==2
13405 && last_eq_type == SEQ_NONDEFAULT
13406 && gfc_notify_std (GFC_STD_GNU, msg, first_sym->name,
13407 last_where) == FAILURE)
13408 || (eq_type == SEQ_NONDEFAULT
13409 && gfc_notify_std (GFC_STD_GNU, msg, sym->name,
13410 &e->where) == FAILURE))
13411 continue;
13412
13413 msg ="Non-CHARACTER object '%s' in default CHARACTER "
13414 "EQUIVALENCE statement at %L";
13415 if (last_eq_type == SEQ_CHARACTER
13416 && eq_type != SEQ_CHARACTER
13417 && gfc_notify_std (GFC_STD_GNU, msg, sym->name,
13418 &e->where) == FAILURE)
13419 continue;
13420
13421 msg ="Non-NUMERIC object '%s' in default NUMERIC "
13422 "EQUIVALENCE statement at %L";
13423 if (last_eq_type == SEQ_NUMERIC
13424 && eq_type != SEQ_NUMERIC
13425 && gfc_notify_std (GFC_STD_GNU, msg, sym->name,
13426 &e->where) == FAILURE)
13427 continue;
13428
13429 identical_types:
13430 last_ts =&sym->ts;
13431 last_where = &e->where;
13432
13433 if (!e->ref)
13434 continue;
13435
13436 /* Shall not be an automatic array. */
13437 if (e->ref->type == REF_ARRAY
13438 && gfc_resolve_array_spec (e->ref->u.ar.as, 1) == FAILURE)
13439 {
13440 gfc_error ("Array '%s' at %L with non-constant bounds cannot be "
13441 "an EQUIVALENCE object", sym->name, &e->where);
13442 continue;
13443 }
13444
13445 r = e->ref;
13446 while (r)
13447 {
13448 /* Shall not be a structure component. */
13449 if (r->type == REF_COMPONENT)
13450 {
13451 gfc_error ("Structure component '%s' at %L cannot be an "
13452 "EQUIVALENCE object",
13453 r->u.c.component->name, &e->where);
13454 break;
13455 }
13456
13457 /* A substring shall not have length zero. */
13458 if (r->type == REF_SUBSTRING)
13459 {
13460 if (compare_bound (r->u.ss.start, r->u.ss.end) == CMP_GT)
13461 {
13462 gfc_error ("Substring at %L has length zero",
13463 &r->u.ss.start->where);
13464 break;
13465 }
13466 }
13467 r = r->next;
13468 }
13469 }
13470 }
13471
13472
13473 /* Resolve function and ENTRY types, issue diagnostics if needed. */
13474
13475 static void
13476 resolve_fntype (gfc_namespace *ns)
13477 {
13478 gfc_entry_list *el;
13479 gfc_symbol *sym;
13480
13481 if (ns->proc_name == NULL || !ns->proc_name->attr.function)
13482 return;
13483
13484 /* If there are any entries, ns->proc_name is the entry master
13485 synthetic symbol and ns->entries->sym actual FUNCTION symbol. */
13486 if (ns->entries)
13487 sym = ns->entries->sym;
13488 else
13489 sym = ns->proc_name;
13490 if (sym->result == sym
13491 && sym->ts.type == BT_UNKNOWN
13492 && gfc_set_default_type (sym, 0, NULL) == FAILURE
13493 && !sym->attr.untyped)
13494 {
13495 gfc_error ("Function '%s' at %L has no IMPLICIT type",
13496 sym->name, &sym->declared_at);
13497 sym->attr.untyped = 1;
13498 }
13499
13500 if (sym->ts.type == BT_DERIVED && !sym->ts.u.derived->attr.use_assoc
13501 && !sym->attr.contained
13502 && !gfc_check_symbol_access (sym->ts.u.derived)
13503 && gfc_check_symbol_access (sym))
13504 {
13505 gfc_notify_std (GFC_STD_F2003, "Fortran 2003: PUBLIC function '%s' at "
13506 "%L of PRIVATE type '%s'", sym->name,
13507 &sym->declared_at, sym->ts.u.derived->name);
13508 }
13509
13510 if (ns->entries)
13511 for (el = ns->entries->next; el; el = el->next)
13512 {
13513 if (el->sym->result == el->sym
13514 && el->sym->ts.type == BT_UNKNOWN
13515 && gfc_set_default_type (el->sym, 0, NULL) == FAILURE
13516 && !el->sym->attr.untyped)
13517 {
13518 gfc_error ("ENTRY '%s' at %L has no IMPLICIT type",
13519 el->sym->name, &el->sym->declared_at);
13520 el->sym->attr.untyped = 1;
13521 }
13522 }
13523 }
13524
13525
13526 /* 12.3.2.1.1 Defined operators. */
13527
13528 static gfc_try
13529 check_uop_procedure (gfc_symbol *sym, locus where)
13530 {
13531 gfc_formal_arglist *formal;
13532
13533 if (!sym->attr.function)
13534 {
13535 gfc_error ("User operator procedure '%s' at %L must be a FUNCTION",
13536 sym->name, &where);
13537 return FAILURE;
13538 }
13539
13540 if (sym->ts.type == BT_CHARACTER
13541 && !(sym->ts.u.cl && sym->ts.u.cl->length)
13542 && !(sym->result && sym->result->ts.u.cl
13543 && sym->result->ts.u.cl->length))
13544 {
13545 gfc_error ("User operator procedure '%s' at %L cannot be assumed "
13546 "character length", sym->name, &where);
13547 return FAILURE;
13548 }
13549
13550 formal = sym->formal;
13551 if (!formal || !formal->sym)
13552 {
13553 gfc_error ("User operator procedure '%s' at %L must have at least "
13554 "one argument", sym->name, &where);
13555 return FAILURE;
13556 }
13557
13558 if (formal->sym->attr.intent != INTENT_IN)
13559 {
13560 gfc_error ("First argument of operator interface at %L must be "
13561 "INTENT(IN)", &where);
13562 return FAILURE;
13563 }
13564
13565 if (formal->sym->attr.optional)
13566 {
13567 gfc_error ("First argument of operator interface at %L cannot be "
13568 "optional", &where);
13569 return FAILURE;
13570 }
13571
13572 formal = formal->next;
13573 if (!formal || !formal->sym)
13574 return SUCCESS;
13575
13576 if (formal->sym->attr.intent != INTENT_IN)
13577 {
13578 gfc_error ("Second argument of operator interface at %L must be "
13579 "INTENT(IN)", &where);
13580 return FAILURE;
13581 }
13582
13583 if (formal->sym->attr.optional)
13584 {
13585 gfc_error ("Second argument of operator interface at %L cannot be "
13586 "optional", &where);
13587 return FAILURE;
13588 }
13589
13590 if (formal->next)
13591 {
13592 gfc_error ("Operator interface at %L must have, at most, two "
13593 "arguments", &where);
13594 return FAILURE;
13595 }
13596
13597 return SUCCESS;
13598 }
13599
13600 static void
13601 gfc_resolve_uops (gfc_symtree *symtree)
13602 {
13603 gfc_interface *itr;
13604
13605 if (symtree == NULL)
13606 return;
13607
13608 gfc_resolve_uops (symtree->left);
13609 gfc_resolve_uops (symtree->right);
13610
13611 for (itr = symtree->n.uop->op; itr; itr = itr->next)
13612 check_uop_procedure (itr->sym, itr->sym->declared_at);
13613 }
13614
13615
13616 /* Examine all of the expressions associated with a program unit,
13617 assign types to all intermediate expressions, make sure that all
13618 assignments are to compatible types and figure out which names
13619 refer to which functions or subroutines. It doesn't check code
13620 block, which is handled by resolve_code. */
13621
13622 static void
13623 resolve_types (gfc_namespace *ns)
13624 {
13625 gfc_namespace *n;
13626 gfc_charlen *cl;
13627 gfc_data *d;
13628 gfc_equiv *eq;
13629 gfc_namespace* old_ns = gfc_current_ns;
13630
13631 /* Check that all IMPLICIT types are ok. */
13632 if (!ns->seen_implicit_none)
13633 {
13634 unsigned letter;
13635 for (letter = 0; letter != GFC_LETTERS; ++letter)
13636 if (ns->set_flag[letter]
13637 && resolve_typespec_used (&ns->default_type[letter],
13638 &ns->implicit_loc[letter],
13639 NULL) == FAILURE)
13640 return;
13641 }
13642
13643 gfc_current_ns = ns;
13644
13645 resolve_entries (ns);
13646
13647 resolve_common_vars (ns->blank_common.head, false);
13648 resolve_common_blocks (ns->common_root);
13649
13650 resolve_contained_functions (ns);
13651
13652 if (ns->proc_name && ns->proc_name->attr.flavor == FL_PROCEDURE
13653 && ns->proc_name->attr.if_source == IFSRC_IFBODY)
13654 resolve_formal_arglist (ns->proc_name);
13655
13656 gfc_traverse_ns (ns, resolve_bind_c_derived_types);
13657
13658 for (cl = ns->cl_list; cl; cl = cl->next)
13659 resolve_charlen (cl);
13660
13661 gfc_traverse_ns (ns, resolve_symbol);
13662
13663 resolve_fntype (ns);
13664
13665 for (n = ns->contained; n; n = n->sibling)
13666 {
13667 if (gfc_pure (ns->proc_name) && !gfc_pure (n->proc_name))
13668 gfc_error ("Contained procedure '%s' at %L of a PURE procedure must "
13669 "also be PURE", n->proc_name->name,
13670 &n->proc_name->declared_at);
13671
13672 resolve_types (n);
13673 }
13674
13675 forall_flag = 0;
13676 gfc_check_interfaces (ns);
13677
13678 gfc_traverse_ns (ns, resolve_values);
13679
13680 if (ns->save_all)
13681 gfc_save_all (ns);
13682
13683 iter_stack = NULL;
13684 for (d = ns->data; d; d = d->next)
13685 resolve_data (d);
13686
13687 iter_stack = NULL;
13688 gfc_traverse_ns (ns, gfc_formalize_init_value);
13689
13690 gfc_traverse_ns (ns, gfc_verify_binding_labels);
13691
13692 if (ns->common_root != NULL)
13693 gfc_traverse_symtree (ns->common_root, resolve_bind_c_comms);
13694
13695 for (eq = ns->equiv; eq; eq = eq->next)
13696 resolve_equivalence (eq);
13697
13698 /* Warn about unused labels. */
13699 if (warn_unused_label)
13700 warn_unused_fortran_label (ns->st_labels);
13701
13702 gfc_resolve_uops (ns->uop_root);
13703
13704 gfc_current_ns = old_ns;
13705 }
13706
13707
13708 /* Call resolve_code recursively. */
13709
13710 static void
13711 resolve_codes (gfc_namespace *ns)
13712 {
13713 gfc_namespace *n;
13714 bitmap_obstack old_obstack;
13715
13716 if (ns->resolved == 1)
13717 return;
13718
13719 for (n = ns->contained; n; n = n->sibling)
13720 resolve_codes (n);
13721
13722 gfc_current_ns = ns;
13723
13724 /* Don't clear 'cs_base' if this is the namespace of a BLOCK construct. */
13725 if (!(ns->proc_name && ns->proc_name->attr.flavor == FL_LABEL))
13726 cs_base = NULL;
13727
13728 /* Set to an out of range value. */
13729 current_entry_id = -1;
13730
13731 old_obstack = labels_obstack;
13732 bitmap_obstack_initialize (&labels_obstack);
13733
13734 resolve_code (ns->code, ns);
13735
13736 bitmap_obstack_release (&labels_obstack);
13737 labels_obstack = old_obstack;
13738 }
13739
13740
13741 /* This function is called after a complete program unit has been compiled.
13742 Its purpose is to examine all of the expressions associated with a program
13743 unit, assign types to all intermediate expressions, make sure that all
13744 assignments are to compatible types and figure out which names refer to
13745 which functions or subroutines. */
13746
13747 void
13748 gfc_resolve (gfc_namespace *ns)
13749 {
13750 gfc_namespace *old_ns;
13751 code_stack *old_cs_base;
13752
13753 if (ns->resolved)
13754 return;
13755
13756 ns->resolved = -1;
13757 old_ns = gfc_current_ns;
13758 old_cs_base = cs_base;
13759
13760 resolve_types (ns);
13761 resolve_codes (ns);
13762
13763 gfc_current_ns = old_ns;
13764 cs_base = old_cs_base;
13765 ns->resolved = 1;
13766
13767 gfc_run_passes (ns);
13768 }