LCOV - code coverage report
Current view: top level - gcc/fortran - interface.cc (source / functions) Coverage Total Hit
Test: gcc.info Lines: 92.7 % 2784 2580
Test Date: 2026-05-30 15:37:04 Functions: 100.0 % 77 77
Legend: Lines:     hit not hit

            Line data    Source code
       1              : /* Deal with interfaces.
       2              :    Copyright (C) 2000-2026 Free Software Foundation, Inc.
       3              :    Contributed by Andy Vaught
       4              : 
       5              : This file is part of GCC.
       6              : 
       7              : GCC is free software; you can redistribute it and/or modify it under
       8              : the terms of the GNU General Public License as published by the Free
       9              : Software Foundation; either version 3, or (at your option) any later
      10              : version.
      11              : 
      12              : GCC is distributed in the hope that it will be useful, but WITHOUT ANY
      13              : WARRANTY; without even the implied warranty of MERCHANTABILITY or
      14              : FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
      15              : for more details.
      16              : 
      17              : You should have received a copy of the GNU General Public License
      18              : along with GCC; see the file COPYING3.  If not see
      19              : <http://www.gnu.org/licenses/>.  */
      20              : 
      21              : 
      22              : /* Deal with interfaces.  An explicit interface is represented as a
      23              :    singly linked list of formal argument structures attached to the
      24              :    relevant symbols.  For an implicit interface, the arguments don't
      25              :    point to symbols.  Explicit interfaces point to namespaces that
      26              :    contain the symbols within that interface.
      27              : 
      28              :    Implicit interfaces are linked together in a singly linked list
      29              :    along the next_if member of symbol nodes.  Since a particular
      30              :    symbol can only have a single explicit interface, the symbol cannot
      31              :    be part of multiple lists and a single next-member suffices.
      32              : 
      33              :    This is not the case for general classes, though.  An operator
      34              :    definition is independent of just about all other uses and has it's
      35              :    own head pointer.
      36              : 
      37              :    Nameless interfaces:
      38              :      Nameless interfaces create symbols with explicit interfaces within
      39              :      the current namespace.  They are otherwise unlinked.
      40              : 
      41              :    Generic interfaces:
      42              :      The generic name points to a linked list of symbols.  Each symbol
      43              :      has an explicit interface.  Each explicit interface has its own
      44              :      namespace containing the arguments.  Module procedures are symbols in
      45              :      which the interface is added later when the module procedure is parsed.
      46              : 
      47              :    User operators:
      48              :      User-defined operators are stored in a their own set of symtrees
      49              :      separate from regular symbols.  The symtrees point to gfc_user_op
      50              :      structures which in turn head up a list of relevant interfaces.
      51              : 
      52              :    Extended intrinsics and assignment:
      53              :      The head of these interface lists are stored in the containing namespace.
      54              : 
      55              :    Implicit interfaces:
      56              :      An implicit interface is represented as a singly linked list of
      57              :      formal argument list structures that don't point to any symbol
      58              :      nodes -- they just contain types.
      59              : 
      60              : 
      61              :    When a subprogram is defined, the program unit's name points to an
      62              :    interface as usual, but the link to the namespace is NULL and the
      63              :    formal argument list points to symbols within the same namespace as
      64              :    the program unit name.  */
      65              : 
      66              : #include "config.h"
      67              : #include "system.h"
      68              : #include "coretypes.h"
      69              : #include "options.h"
      70              : #include "gfortran.h"
      71              : #include "match.h"
      72              : #include "arith.h"
      73              : 
      74              : /* The current_interface structure holds information about the
      75              :    interface currently being parsed.  This structure is saved and
      76              :    restored during recursive interfaces.  */
      77              : 
      78              : gfc_interface_info current_interface;
      79              : 
      80              : 
      81              : /* Free the leading members of the gfc_interface linked list given in INTR
      82              :    up to the END element (exclusive: the END element is not freed).
      83              :    If END is not nullptr, it is assumed that END is in the linked list starting
      84              :    with INTR.  */
      85              : 
      86              : static void
      87     21622204 : free_interface_elements_until (gfc_interface *intr, gfc_interface *end)
      88              : {
      89     21622204 :   gfc_interface *next;
      90              : 
      91     21814562 :   for (; intr != end; intr = next)
      92              :     {
      93       192358 :       next = intr->next;
      94       192358 :       free (intr);
      95              :     }
      96            0 : }
      97              : 
      98              : 
      99              : /* Free a singly linked list of gfc_interface structures.  */
     100              : 
     101              : void
     102     20924806 : gfc_free_interface (gfc_interface *intr)
     103              : {
     104     20924806 :   free_interface_elements_until (intr, nullptr);
     105     20924806 : }
     106              : 
     107              : 
     108              : /* Update the interface pointer given by IFC_PTR to make it point to TAIL.
     109              :    It is expected that TAIL (if non-null) is in the list pointed to by
     110              :    IFC_PTR, hence the tail of it.  The members of the list before TAIL are
     111              :    freed before the pointer reassignment.  */
     112              : 
     113              : void
     114      9014603 : gfc_drop_interface_elements_before (gfc_interface **ifc_ptr,
     115              :                                     gfc_interface *tail)
     116              : {
     117      9014603 :   if (ifc_ptr == nullptr)
     118              :     return;
     119              : 
     120       697398 :   free_interface_elements_until (*ifc_ptr, tail);
     121       697398 :   *ifc_ptr = tail;
     122              : }
     123              : 
     124              : 
     125              : /* Change the operators unary plus and minus into binary plus and
     126              :    minus respectively, leaving the rest unchanged.  */
     127              : 
     128              : static gfc_intrinsic_op
     129         2952 : fold_unary_intrinsic (gfc_intrinsic_op op)
     130              : {
     131            0 :   switch (op)
     132              :     {
     133            0 :     case INTRINSIC_UPLUS:
     134            0 :       op = INTRINSIC_PLUS;
     135            0 :       break;
     136           56 :     case INTRINSIC_UMINUS:
     137           56 :       op = INTRINSIC_MINUS;
     138            0 :       break;
     139              :     default:
     140              :       break;
     141              :     }
     142              : 
     143         2938 :   return op;
     144              : }
     145              : 
     146              : 
     147              : /* Return the operator depending on the DTIO moded string.  Note that
     148              :    these are not operators in the normal sense and so have been placed
     149              :    beyond GFC_INTRINSIC_END in gfortran.h:enum gfc_intrinsic_op.  */
     150              : 
     151              : static gfc_intrinsic_op
     152          410 : dtio_op (char* mode)
     153              : {
     154          410 :   if (strcmp (mode, "formatted") == 0)
     155              :     return INTRINSIC_FORMATTED;
     156           84 :   if (strcmp (mode, "unformatted") == 0)
     157           84 :     return INTRINSIC_UNFORMATTED;
     158              :   return INTRINSIC_NONE;
     159              : }
     160              : 
     161              : 
     162              : /* Match a generic specification.  Depending on which type of
     163              :    interface is found, the 'name' or 'op' pointers may be set.
     164              :    This subroutine doesn't return MATCH_NO.  */
     165              : 
     166              : match
     167        28638 : gfc_match_generic_spec (interface_type *type,
     168              :                         char *name,
     169              :                         gfc_intrinsic_op *op)
     170              : {
     171        28638 :   char buffer[GFC_MAX_SYMBOL_LEN + 1];
     172        28638 :   match m;
     173        28638 :   gfc_intrinsic_op i;
     174              : 
     175        28638 :   if (gfc_match (" assignment ( = )") == MATCH_YES)
     176              :     {
     177          574 :       *type = INTERFACE_INTRINSIC_OP;
     178          574 :       *op = INTRINSIC_ASSIGN;
     179          574 :       return MATCH_YES;
     180              :     }
     181              : 
     182        28064 :   if (gfc_match (" operator ( %o )", &i) == MATCH_YES)
     183              :     {                           /* Operator i/f */
     184          764 :       *type = INTERFACE_INTRINSIC_OP;
     185          764 :       *op = fold_unary_intrinsic (i);
     186          764 :       return MATCH_YES;
     187              :     }
     188              : 
     189        27300 :   *op = INTRINSIC_NONE;
     190        27300 :   if (gfc_match (" operator ( ") == MATCH_YES)
     191              :     {
     192          346 :       m = gfc_match_defined_op_name (buffer, 1);
     193          346 :       if (m == MATCH_NO)
     194            0 :         goto syntax;
     195          346 :       if (m != MATCH_YES)
     196              :         return MATCH_ERROR;
     197              : 
     198          346 :       m = gfc_match_char (')');
     199          346 :       if (m == MATCH_NO)
     200            0 :         goto syntax;
     201          346 :       if (m != MATCH_YES)
     202              :         return MATCH_ERROR;
     203              : 
     204          346 :       strcpy (name, buffer);
     205          346 :       *type = INTERFACE_USER_OP;
     206          346 :       return MATCH_YES;
     207              :     }
     208              : 
     209        26954 :   if (gfc_match (" read ( %n )", buffer) == MATCH_YES)
     210              :     {
     211          166 :       *op = dtio_op (buffer);
     212          166 :       if (*op == INTRINSIC_FORMATTED)
     213              :         {
     214          123 :           if (flag_default_integer)
     215            0 :             goto conflict;
     216          123 :           strcpy (name, gfc_code2string (dtio_procs, DTIO_RF));
     217          123 :           *type = INTERFACE_DTIO;
     218              :         }
     219          166 :       if (*op == INTRINSIC_UNFORMATTED)
     220              :         {
     221           43 :           if (flag_default_integer)
     222            0 :             goto conflict;
     223           43 :           strcpy (name, gfc_code2string (dtio_procs, DTIO_RUF));
     224           43 :           *type = INTERFACE_DTIO;
     225              :         }
     226          166 :       if (*op != INTRINSIC_NONE)
     227              :         return MATCH_YES;
     228              :     }
     229              : 
     230        26788 :   if (gfc_match (" write ( %n )", buffer) == MATCH_YES)
     231              :     {
     232          244 :       *op = dtio_op (buffer);
     233          244 :       if (*op == INTRINSIC_FORMATTED)
     234              :         {
     235          203 :           if (flag_default_integer)
     236            1 :             goto conflict;
     237          202 :           strcpy (name, gfc_code2string (dtio_procs, DTIO_WF));
     238          202 :           *type = INTERFACE_DTIO;
     239              :         }
     240          243 :       if (*op == INTRINSIC_UNFORMATTED)
     241              :         {
     242           41 :           if (flag_default_integer)
     243            0 :             goto conflict;
     244           41 :           strcpy (name, gfc_code2string (dtio_procs, DTIO_WUF));
     245           41 :           *type = INTERFACE_DTIO;
     246              :         }
     247          243 :       if (*op != INTRINSIC_NONE)
     248              :         return MATCH_YES;
     249              :     }
     250              : 
     251        26544 :   if (gfc_match_name (buffer) == MATCH_YES)
     252              :     {
     253        21219 :       strcpy (name, buffer);
     254        21219 :       *type = INTERFACE_GENERIC;
     255        21219 :       return MATCH_YES;
     256              :     }
     257              : 
     258         5325 :   *type = INTERFACE_NAMELESS;
     259         5325 :   return MATCH_YES;
     260              : 
     261            1 : conflict:
     262            1 :   gfc_error ("Sorry: -fdefault-integer-8 option is not supported with "
     263              :              "user-defined input/output at %C");
     264            1 :   return MATCH_ERROR;
     265              : 
     266            0 : syntax:
     267            0 :   gfc_error ("Syntax error in generic specification at %C");
     268            0 :   return MATCH_ERROR;
     269              : }
     270              : 
     271              : 
     272              : /* Match one of the five F95 forms of an interface statement.  The
     273              :    matcher for the abstract interface follows.  */
     274              : 
     275              : match
     276        10202 : gfc_match_interface (void)
     277              : {
     278        10202 :   char name[GFC_MAX_SYMBOL_LEN + 1];
     279        10202 :   interface_type type;
     280        10202 :   gfc_symbol *sym;
     281        10202 :   gfc_intrinsic_op op;
     282        10202 :   match m;
     283              : 
     284        10202 :   m = gfc_match_space ();
     285              : 
     286        10202 :   if (gfc_match_generic_spec (&type, name, &op) == MATCH_ERROR)
     287              :     return MATCH_ERROR;
     288              : 
     289              :   /* If we're not looking at the end of the statement now, or if this
     290              :      is not a nameless interface but we did not see a space, punt.  */
     291        10201 :   if (gfc_match_eos () != MATCH_YES
     292        10201 :       || (type != INTERFACE_NAMELESS && m != MATCH_YES))
     293              :     {
     294            0 :       gfc_error ("Syntax error: Trailing garbage in INTERFACE statement "
     295              :                  "at %C");
     296            0 :       return MATCH_ERROR;
     297              :     }
     298              : 
     299        10201 :   current_interface.type = type;
     300              : 
     301        10201 :   switch (type)
     302              :     {
     303         4175 :     case INTERFACE_DTIO:
     304         4175 :     case INTERFACE_GENERIC:
     305         4175 :       if (gfc_get_symbol (name, NULL, &sym))
     306              :         return MATCH_ERROR;
     307              : 
     308         4175 :       if (!sym->attr.generic
     309         4175 :           && !gfc_add_generic (&sym->attr, sym->name, NULL))
     310              :         return MATCH_ERROR;
     311              : 
     312         4174 :       if (sym->attr.dummy)
     313              :         {
     314            0 :           gfc_error ("Dummy procedure %qs at %C cannot have a "
     315              :                      "generic interface", sym->name);
     316            0 :           return MATCH_ERROR;
     317              :         }
     318              : 
     319         4174 :       current_interface.sym = gfc_new_block = sym;
     320         4174 :       break;
     321              : 
     322          155 :     case INTERFACE_USER_OP:
     323          155 :       current_interface.uop = gfc_get_uop (name);
     324          155 :       break;
     325              : 
     326          550 :     case INTERFACE_INTRINSIC_OP:
     327          550 :       current_interface.op = op;
     328          550 :       break;
     329              : 
     330              :     case INTERFACE_NAMELESS:
     331              :     case INTERFACE_ABSTRACT:
     332              :       break;
     333              :     }
     334              : 
     335              :   return MATCH_YES;
     336              : }
     337              : 
     338              : 
     339              : 
     340              : /* Match a F2003 abstract interface.  */
     341              : 
     342              : match
     343          463 : gfc_match_abstract_interface (void)
     344              : {
     345          463 :   match m;
     346              : 
     347          463 :   if (!gfc_notify_std (GFC_STD_F2003, "ABSTRACT INTERFACE at %C"))
     348              :     return MATCH_ERROR;
     349              : 
     350          462 :   m = gfc_match_eos ();
     351              : 
     352          462 :   if (m != MATCH_YES)
     353              :     {
     354            1 :       gfc_error ("Syntax error in ABSTRACT INTERFACE statement at %C");
     355            1 :       return MATCH_ERROR;
     356              :     }
     357              : 
     358          461 :   current_interface.type = INTERFACE_ABSTRACT;
     359              : 
     360          461 :   return m;
     361              : }
     362              : 
     363              : 
     364              : /* Match the different sort of generic-specs that can be present after
     365              :    the END INTERFACE itself.  */
     366              : 
     367              : match
     368          693 : gfc_match_end_interface (void)
     369              : {
     370          693 :   char name[GFC_MAX_SYMBOL_LEN + 1];
     371          693 :   interface_type type;
     372          693 :   gfc_intrinsic_op op;
     373          693 :   match m;
     374              : 
     375          693 :   m = gfc_match_space ();
     376              : 
     377          693 :   if (gfc_match_generic_spec (&type, name, &op) == MATCH_ERROR)
     378              :     return MATCH_ERROR;
     379              : 
     380              :   /* If we're not looking at the end of the statement now, or if this
     381              :      is not a nameless interface but we did not see a space, punt.  */
     382          693 :   if (gfc_match_eos () != MATCH_YES
     383          693 :       || (type != INTERFACE_NAMELESS && m != MATCH_YES))
     384              :     {
     385            0 :       gfc_error ("Syntax error: Trailing garbage in END INTERFACE "
     386              :                  "statement at %C");
     387            0 :       return MATCH_ERROR;
     388              :     }
     389              : 
     390          693 :   m = MATCH_YES;
     391              : 
     392          693 :   switch (current_interface.type)
     393              :     {
     394            0 :     case INTERFACE_NAMELESS:
     395            0 :     case INTERFACE_ABSTRACT:
     396            0 :       if (type != INTERFACE_NAMELESS)
     397              :         {
     398            0 :           gfc_error ("Expected a nameless interface at %C");
     399            0 :           m = MATCH_ERROR;
     400              :         }
     401              : 
     402              :       break;
     403              : 
     404          157 :     case INTERFACE_INTRINSIC_OP:
     405          157 :       if (type != current_interface.type || op != current_interface.op)
     406              :         {
     407              : 
     408           14 :           if (current_interface.op == INTRINSIC_ASSIGN)
     409              :             {
     410            0 :               m = MATCH_ERROR;
     411            0 :               gfc_error ("Expected %<END INTERFACE ASSIGNMENT (=)%> at %C");
     412              :             }
     413              :           else
     414              :             {
     415           14 :               const char *s1, *s2;
     416           14 :               s1 = gfc_op2string (current_interface.op);
     417           14 :               s2 = gfc_op2string (op);
     418              : 
     419              :               /* The following if-statements are used to enforce C1202
     420              :                  from F2003.  */
     421           14 :               if ((strcmp(s1, "==") == 0 && strcmp (s2, ".eq.") == 0)
     422           13 :                   || (strcmp(s1, ".eq.") == 0 && strcmp (s2, "==") == 0))
     423              :                 break;
     424           12 :               if ((strcmp(s1, "/=") == 0 && strcmp (s2, ".ne.") == 0)
     425           11 :                   || (strcmp(s1, ".ne.") == 0 && strcmp (s2, "/=") == 0))
     426              :                 break;
     427           10 :               if ((strcmp(s1, "<=") == 0 && strcmp (s2, ".le.") == 0)
     428            9 :                   || (strcmp(s1, ".le.") == 0 && strcmp (s2, "<=") == 0))
     429              :                 break;
     430            8 :               if ((strcmp(s1, "<") == 0 && strcmp (s2, ".lt.") == 0)
     431            7 :                   || (strcmp(s1, ".lt.") == 0 && strcmp (s2, "<") == 0))
     432              :                 break;
     433            6 :               if ((strcmp(s1, ">=") == 0 && strcmp (s2, ".ge.") == 0)
     434            5 :                   || (strcmp(s1, ".ge.") == 0 && strcmp (s2, ">=") == 0))
     435              :                 break;
     436            4 :               if ((strcmp(s1, ">") == 0 && strcmp (s2, ".gt.") == 0)
     437            3 :                   || (strcmp(s1, ".gt.") == 0 && strcmp (s2, ">") == 0))
     438              :                 break;
     439              : 
     440            2 :               m = MATCH_ERROR;
     441            2 :               if (strcmp(s2, "none") == 0)
     442            1 :                 gfc_error ("Expecting %<END INTERFACE OPERATOR (%s)%> "
     443              :                            "at %C", s1);
     444              :               else
     445            1 :                 gfc_error ("Expecting %<END INTERFACE OPERATOR (%s)%> at %C, "
     446              :                            "but got %qs", s1, s2);
     447              :             }
     448              : 
     449              :         }
     450              : 
     451              :       break;
     452              : 
     453           14 :     case INTERFACE_USER_OP:
     454              :       /* Comparing the symbol node names is OK because only use-associated
     455              :          symbols can be renamed.  */
     456           14 :       if (type != current_interface.type
     457           14 :           || strcmp (current_interface.uop->name, name) != 0)
     458              :         {
     459            0 :           gfc_error ("Expecting %<END INTERFACE OPERATOR (.%s.)%> at %C",
     460            0 :                      current_interface.uop->name);
     461            0 :           m = MATCH_ERROR;
     462              :         }
     463              : 
     464              :       break;
     465              : 
     466          522 :     case INTERFACE_DTIO:
     467          522 :     case INTERFACE_GENERIC:
     468              :       /* If a use-associated symbol is renamed, check the local_name.   */
     469          522 :       const char *local_name = current_interface.sym->name;
     470              : 
     471          522 :       if (current_interface.sym->attr.use_assoc
     472            4 :           && current_interface.sym->attr.use_rename
     473            2 :           && current_interface.sym->ns->use_stmts->rename
     474            2 :           && (current_interface.sym->ns->use_stmts->rename->local_name[0]
     475              :               != '\0'))
     476            1 :         local_name = current_interface.sym->ns->use_stmts->rename->local_name;
     477              : 
     478          522 :       if (type != current_interface.type
     479          522 :           || strcmp (local_name, name) != 0)
     480              :         {
     481            0 :           gfc_error ("Expecting %<END INTERFACE %s%> at %C", local_name);
     482            0 :           m = MATCH_ERROR;
     483              :         }
     484              : 
     485              :       break;
     486              :     }
     487              : 
     488              :   return m;
     489              : }
     490              : 
     491              : 
     492              : /* Return whether the component was defined anonymously.  */
     493              : 
     494              : static bool
     495        10401 : is_anonymous_component (gfc_component *cmp)
     496              : {
     497              :   /* Only UNION and MAP components are anonymous.  In the case of a MAP,
     498              :      the derived type symbol is FL_STRUCT and the component name looks like mM*.
     499              :      This is the only case in which the second character of a component name is
     500              :      uppercase.  */
     501        10401 :   return cmp->ts.type == BT_UNION
     502        10401 :     || (cmp->ts.type == BT_DERIVED
     503         3752 :         && cmp->ts.u.derived->attr.flavor == FL_STRUCT
     504           72 :         && cmp->name[0] && cmp->name[1] && ISUPPER (cmp->name[1]));
     505              : }
     506              : 
     507              : 
     508              : /* Return whether the derived type was defined anonymously.  */
     509              : 
     510              : static bool
     511       605863 : is_anonymous_dt (gfc_symbol *derived)
     512              : {
     513              :   /* UNION and MAP types are always anonymous. Otherwise, only nested STRUCTURE
     514              :      types can be anonymous.  For anonymous MAP/STRUCTURE, we have FL_STRUCT
     515              :      and the type name looks like XX*.  This is the only case in which the
     516              :      second character of a type name is uppercase.  */
     517       605863 :   return derived->attr.flavor == FL_UNION
     518       605863 :     || (derived->attr.flavor == FL_STRUCT
     519         3345 :         && derived->name[0] && derived->name[1] && ISUPPER (derived->name[1]));
     520              : }
     521              : 
     522              : 
     523              : /* Compare components according to 4.4.2 of the Fortran standard.  */
     524              : 
     525              : static bool
     526         5364 : compare_components (gfc_component *cmp1, gfc_component *cmp2,
     527              :     gfc_symbol *derived1, gfc_symbol *derived2)
     528              : {
     529              :   /* Compare names, but not for anonymous components such as UNION or MAP.  */
     530         5037 :   if (!is_anonymous_component (cmp1) && !is_anonymous_component (cmp2)
     531        10116 :       && strcmp (cmp1->name, cmp2->name) != 0)
     532              :     return false;
     533              : 
     534         4501 :   if (cmp1->attr.access != cmp2->attr.access)
     535              :     return false;
     536              : 
     537         4500 :   if (cmp1->attr.pointer != cmp2->attr.pointer)
     538              :     return false;
     539              : 
     540         4500 :   if (cmp1->attr.dimension != cmp2->attr.dimension)
     541              :     return false;
     542              : 
     543         4366 :   if (cmp1->attr.codimension != cmp2->attr.codimension)
     544              :     return false;
     545              : 
     546         4366 :   if (cmp1->attr.allocatable != cmp2->attr.allocatable)
     547              :     return false;
     548              : 
     549         4366 :   if (cmp1->attr.dimension && gfc_compare_array_spec (cmp1->as, cmp2->as) == 0)
     550              :     return false;
     551              : 
     552         3962 :   if (cmp1->attr.codimension
     553         3962 :       && gfc_compare_array_spec (cmp1->as, cmp2->as) == 0)
     554              :     return false;
     555              : 
     556         3962 :   if (cmp1->ts.type == BT_CHARACTER && cmp2->ts.type == BT_CHARACTER)
     557              :     {
     558           75 :       gfc_charlen *l1 = cmp1->ts.u.cl;
     559           75 :       gfc_charlen *l2 = cmp2->ts.u.cl;
     560           75 :       if (l1 && l2 && l1->length && l2->length
     561           75 :           && l1->length->expr_type == EXPR_CONSTANT
     562           75 :           && l2->length->expr_type == EXPR_CONSTANT
     563          150 :           && gfc_dep_compare_expr (l1->length, l2->length) != 0)
     564              :         return false;
     565              :     }
     566              : 
     567              :   /* Make sure that link lists do not put this function into an
     568              :      endless recursive loop!  */
     569         1477 :   if (!(cmp1->ts.type == BT_DERIVED && derived1 == cmp1->ts.u.derived)
     570         3758 :       && !(cmp2->ts.type == BT_DERIVED && derived2 == cmp2->ts.u.derived)
     571         7715 :       && !gfc_compare_types (&cmp1->ts, &cmp2->ts))
     572              :     return false;
     573              : 
     574         3539 :   else if ( (cmp1->ts.type == BT_DERIVED && derived1 == cmp1->ts.u.derived)
     575          199 :         && !(cmp2->ts.type == BT_DERIVED && derived2 == cmp2->ts.u.derived))
     576              :     return false;
     577              : 
     578         3539 :   else if (!(cmp1->ts.type == BT_DERIVED && derived1 == cmp1->ts.u.derived)
     579         3340 :         &&  (cmp2->ts.type == BT_DERIVED && derived2 == cmp2->ts.u.derived))
     580              :     return false;
     581              : 
     582              :   return true;
     583              : }
     584              : 
     585              : 
     586              : /* Compare two union types by comparing the components of their maps.
     587              :    Because unions and maps are anonymous their types get special internal
     588              :    names; therefore the usual derived type comparison will fail on them.
     589              : 
     590              :    Returns nonzero if equal, as with gfc_compare_derived_types. Also as with
     591              :    gfc_compare_derived_types, 'equal' is closer to meaning 'duplicate
     592              :    definitions' than 'equivalent structure'. */
     593              : 
     594              : static bool
     595          793 : compare_union_types (gfc_symbol *un1, gfc_symbol *un2)
     596              : {
     597          793 :   gfc_component *map1, *map2, *cmp1, *cmp2;
     598          793 :   gfc_symbol *map1_t, *map2_t;
     599              : 
     600          793 :   if (un1->attr.flavor != FL_UNION || un2->attr.flavor != FL_UNION)
     601              :     return false;
     602              : 
     603          148 :   if (un1->attr.zero_comp != un2->attr.zero_comp)
     604              :     return false;
     605              : 
     606          148 :   if (un1->attr.zero_comp)
     607              :     return true;
     608              : 
     609          146 :   map1 = un1->components;
     610          146 :   map2 = un2->components;
     611              : 
     612              :   /* In terms of 'equality' here we are worried about types which are
     613              :      declared the same in two places, not types that represent equivalent
     614              :      structures. (This is common because of FORTRAN's weird scoping rules.)
     615              :      Though two unions with their maps in different orders could be equivalent,
     616              :      we will say they are not equal for the purposes of this test; therefore
     617              :      we compare the maps sequentially. */
     618          229 :   for (;;)
     619              :     {
     620          229 :       map1_t = map1->ts.u.derived;
     621          229 :       map2_t = map2->ts.u.derived;
     622              : 
     623          229 :       cmp1 = map1_t->components;
     624          229 :       cmp2 = map2_t->components;
     625              : 
     626              :       /* Protect against null components.  */
     627          229 :       if (map1_t->attr.zero_comp != map2_t->attr.zero_comp)
     628              :         return false;
     629              : 
     630          229 :       if (map1_t->attr.zero_comp)
     631              :         return true;
     632              : 
     633          609 :       for (;;)
     634              :         {
     635              :           /* No two fields will ever point to the same map type unless they are
     636              :              the same component, because one map field is created with its type
     637              :              declaration. Therefore don't worry about recursion here. */
     638              :           /* TODO: worry about recursion into parent types of the unions? */
     639          609 :           if (!compare_components (cmp1, cmp2, map1_t, map2_t))
     640              :             return false;
     641              : 
     642          603 :           cmp1 = cmp1->next;
     643          603 :           cmp2 = cmp2->next;
     644              : 
     645          603 :           if (cmp1 == NULL && cmp2 == NULL)
     646              :             break;
     647          384 :           if (cmp1 == NULL || cmp2 == NULL)
     648              :             return false;
     649              :         }
     650              : 
     651          219 :       map1 = map1->next;
     652          219 :       map2 = map2->next;
     653              : 
     654          219 :       if (map1 == NULL && map2 == NULL)
     655              :         break;
     656           83 :       if (map1 == NULL || map2 == NULL)
     657              :         return false;
     658              :     }
     659              : 
     660              :   return true;
     661              : }
     662              : 
     663              : 
     664              : 
     665              : /* Compare two derived types using the criteria in 4.4.2 of the standard,
     666              :    recursing through gfc_compare_types for the components.  */
     667              : 
     668              : bool
     669       628620 : gfc_compare_derived_types (gfc_symbol *derived1, gfc_symbol *derived2)
     670              : {
     671       628620 :   gfc_component *cmp1, *cmp2;
     672              : 
     673       628620 :   if (derived1 == derived2)
     674              :     return true;
     675              : 
     676       334088 :   if (!derived1 || !derived2)
     677            0 :     gfc_internal_error ("gfc_compare_derived_types: invalid derived type");
     678              : 
     679       334088 :   if (derived1->attr.unlimited_polymorphic
     680          187 :       && derived2->attr.unlimited_polymorphic)
     681              :     return true;
     682              : 
     683       333915 :   if (derived1->attr.unlimited_polymorphic
     684       333915 :       != derived2->attr.unlimited_polymorphic)
     685              :     return false;
     686              : 
     687              :   /* Compare UNION types specially.  */
     688       333826 :   if (derived1->attr.flavor == FL_UNION || derived2->attr.flavor == FL_UNION)
     689          645 :     return compare_union_types (derived1, derived2);
     690              : 
     691              :   /* Special case for comparing derived types across namespaces.  If the
     692              :      true names and module names are the same and the module name is
     693              :      nonnull, then they are equal.  */
     694       333181 :   if (strcmp (derived1->name, derived2->name) == 0
     695        32583 :       && derived1->module != NULL && derived2->module != NULL
     696        30163 :       && strcmp (derived1->module, derived2->module) == 0)
     697              :     return true;
     698              : 
     699              :   /* Compare type via the rules of the standard.  Both types must have the
     700              :      SEQUENCE or BIND(C) attribute to be equal.  We also compare types
     701              :      recursively if they are class descriptors types or virtual tables types.
     702              :      STRUCTUREs are special because they can be anonymous; therefore two
     703              :      structures with different names may be equal.  */
     704              : 
     705              :   /* Compare names, but not for anonymous types such as UNION or MAP.  */
     706       302367 :   if (!is_anonymous_dt (derived1) && !is_anonymous_dt (derived2)
     707       605508 :       && strcmp (derived1->name, derived2->name) != 0)
     708              :     return false;
     709              : 
     710         4382 :   if (derived1->component_access == ACCESS_PRIVATE
     711         4381 :       || derived2->component_access == ACCESS_PRIVATE)
     712              :     return false;
     713              : 
     714         4381 :   if (!(derived1->attr.sequence && derived2->attr.sequence)
     715         2640 :       && !(derived1->attr.is_bind_c && derived2->attr.is_bind_c)
     716         2627 :       && !(derived1->attr.is_class && derived2->attr.is_class)
     717         1719 :       && !(derived1->attr.vtype && derived2->attr.vtype)
     718         1509 :       && !(derived1->attr.pdt_type && derived2->attr.pdt_type))
     719              :     return false;
     720              : 
     721              :   /* Protect against null components.  */
     722         2872 :   if (derived1->attr.zero_comp != derived2->attr.zero_comp)
     723              :     return false;
     724              : 
     725         2863 :   if (derived1->attr.zero_comp)
     726              :     return true;
     727              : 
     728         2863 :   cmp1 = derived1->components;
     729         2863 :   cmp2 = derived2->components;
     730              : 
     731              :   /* Since subtypes of SEQUENCE types must be SEQUENCE types as well, a
     732              :      simple test can speed things up.  Otherwise, lots of things have to
     733              :      match.  */
     734         4755 :   for (;;)
     735              :     {
     736         4755 :       if (!compare_components (cmp1, cmp2, derived1, derived2))
     737              :         return false;
     738              : 
     739         2936 :       cmp1 = cmp1->next;
     740         2936 :       cmp2 = cmp2->next;
     741              : 
     742         2936 :       if (cmp1 == NULL && cmp2 == NULL)
     743              :         break;
     744         1898 :       if (cmp1 == NULL || cmp2 == NULL)
     745              :         return false;
     746              :     }
     747              : 
     748              :   return true;
     749              : }
     750              : 
     751              : 
     752              : /* Compare two typespecs, recursively if necessary.  */
     753              : 
     754              : bool
     755      7457477 : gfc_compare_types (gfc_typespec *ts1, gfc_typespec *ts2)
     756              : {
     757              :   /* See if one of the typespecs is a BT_VOID, which is what is being used
     758              :      to allow the funcs like c_f_pointer to accept any pointer type.
     759              :      TODO: Possibly should narrow this to just the one typespec coming in
     760              :      that is for the formal arg, but oh well.  */
     761      7457477 :   if (ts1->type == BT_VOID || ts2->type == BT_VOID)
     762              :     return true;
     763              : 
     764              :   /* Special case for our C interop types.  FIXME: There should be a
     765              :      better way of doing this.  When ISO C binding is cleared up,
     766              :      this can probably be removed.  See PR 57048.  */
     767              : 
     768      7457448 :   if ((ts1->type == BT_INTEGER
     769      1961200 :        && ts2->type == BT_DERIVED
     770         5614 :        && ts1->f90_type == BT_VOID
     771           86 :        && ts2->u.derived->from_intmod == INTMOD_ISO_C_BINDING
     772           86 :        && ts1->u.derived
     773           86 :        && strcmp (ts1->u.derived->name, ts2->u.derived->name) == 0)
     774      7457363 :       || (ts2->type == BT_INTEGER
     775      2084701 :           && ts1->type == BT_DERIVED
     776         5172 :           && ts2->f90_type == BT_VOID
     777           84 :           && ts1->u.derived->from_intmod == INTMOD_ISO_C_BINDING
     778           84 :           && ts2->u.derived
     779           84 :           && strcmp (ts1->u.derived->name, ts2->u.derived->name) == 0))
     780              :     return true;
     781              : 
     782              :   /* The _data component is not always present, therefore check for its
     783              :      presence before assuming, that its derived->attr is available.
     784              :      When the _data component is not present, then nevertheless the
     785              :      unlimited_polymorphic flag may be set in the derived type's attr.  */
     786      7457279 :   if (ts1->type == BT_CLASS && ts1->u.derived->components
     787        31831 :       && ((ts1->u.derived->attr.is_class
     788        31824 :            && ts1->u.derived->components->ts.u.derived->attr
     789        31824 :                                                   .unlimited_polymorphic)
     790        26403 :           || ts1->u.derived->attr.unlimited_polymorphic))
     791              :     return true;
     792              : 
     793              :   /* F2003: C717  */
     794      7451851 :   if (ts2->type == BT_CLASS && ts1->type == BT_DERIVED
     795          977 :       && ts2->u.derived->components
     796          976 :       && ((ts2->u.derived->attr.is_class
     797          974 :            && ts2->u.derived->components->ts.u.derived->attr
     798          974 :                                                   .unlimited_polymorphic)
     799          935 :           || ts2->u.derived->attr.unlimited_polymorphic)
     800           41 :       && (ts1->u.derived->attr.sequence || ts1->u.derived->attr.is_bind_c))
     801              :     return true;
     802              : 
     803      7451825 :   if (ts1->type != ts2->type
     804      1038645 :       && ((ts1->type != BT_DERIVED && ts1->type != BT_CLASS)
     805        72094 :           || (ts2->type != BT_DERIVED && ts2->type != BT_CLASS)))
     806              :     return false;
     807              : 
     808      6421996 :   if (ts1->type == BT_UNION)
     809          148 :     return compare_union_types (ts1->u.derived, ts2->u.derived);
     810              : 
     811      6421848 :   if (ts1->type != BT_DERIVED && ts1->type != BT_CLASS)
     812      6140569 :     return (ts1->kind == ts2->kind);
     813              : 
     814              :   /* Compare derived types.  */
     815       281279 :   return gfc_type_compatible (ts1, ts2);
     816              : }
     817              : 
     818              : 
     819              : static bool
     820      5233546 : compare_type (gfc_symbol *s1, gfc_symbol *s2)
     821              : {
     822      5233546 :   if (s2->attr.ext_attr & (1 << EXT_ATTR_NO_ARG_CHECK))
     823              :     return true;
     824              : 
     825      5056114 :   return gfc_compare_types (&s1->ts, &s2->ts) || s2->ts.type == BT_ASSUMED;
     826              : }
     827              : 
     828              : 
     829              : static bool
     830       285374 : compare_type_characteristics (gfc_symbol *s1, gfc_symbol *s2)
     831              : {
     832              :   /* TYPE and CLASS of the same declared type are type compatible,
     833              :      but have different characteristics.  */
     834       285374 :   if ((s1->ts.type == BT_CLASS && s2->ts.type == BT_DERIVED)
     835       285366 :       || (s1->ts.type == BT_DERIVED && s2->ts.type == BT_CLASS))
     836              :     return false;
     837              : 
     838       285365 :   return compare_type (s1, s2);
     839              : }
     840              : 
     841              : 
     842              : static bool
     843       875783 : compare_rank (gfc_symbol *s1, gfc_symbol *s2)
     844              : {
     845       875783 :   gfc_array_spec *as1, *as2;
     846       875783 :   int r1, r2;
     847              : 
     848       875783 :   if (s2->attr.ext_attr & (1 << EXT_ATTR_NO_ARG_CHECK))
     849              :     return true;
     850              : 
     851       693980 :   as1 = (s1->ts.type == BT_CLASS
     852         5071 :          && !s1->ts.u.derived->attr.unlimited_polymorphic)
     853       704118 :         ? CLASS_DATA (s1)->as : s1->as;
     854       693998 :   as2 = (s2->ts.type == BT_CLASS
     855         5053 :          && !s2->ts.u.derived->attr.unlimited_polymorphic)
     856       704100 :         ? CLASS_DATA (s2)->as : s2->as;
     857              : 
     858       699049 :   r1 = as1 ? as1->rank : 0;
     859       699049 :   r2 = as2 ? as2->rank : 0;
     860              : 
     861       699049 :   if (r1 != r2 && (!as2 || as2->type != AS_ASSUMED_RANK))
     862         3834 :     return false;  /* Ranks differ.  */
     863              : 
     864              :   return true;
     865              : }
     866              : 
     867              : 
     868              : /* Given two symbols that are formal arguments, compare their ranks
     869              :    and types.  Returns true if they have the same rank and type,
     870              :    false otherwise.  */
     871              : 
     872              : static bool
     873      4944888 : compare_type_rank (gfc_symbol *s1, gfc_symbol *s2)
     874              : {
     875      4944888 :   return compare_type (s1, s2) && compare_rank (s1, s2);
     876              : }
     877              : 
     878              : 
     879              : /* Given two symbols that are formal arguments, compare their types
     880              :    and rank and their formal interfaces if they are both dummy
     881              :    procedures.  Returns true if the same, false if different.  */
     882              : 
     883              : static bool
     884      4833841 : compare_type_rank_if (gfc_symbol *s1, gfc_symbol *s2)
     885              : {
     886      4833841 :   if (s1 == NULL || s2 == NULL)
     887          120 :     return (s1 == s2);
     888              : 
     889      4833721 :   if (s1 == s2)
     890              :     return true;
     891              : 
     892      4833721 :   if (s1->attr.flavor != FL_PROCEDURE && s2->attr.flavor != FL_PROCEDURE)
     893      4833647 :     return compare_type_rank (s1, s2);
     894              : 
     895           74 :   if (s1->attr.flavor != FL_PROCEDURE || s2->attr.flavor != FL_PROCEDURE)
     896              :     return false;
     897              : 
     898              :   /* At this point, both symbols are procedures.  It can happen that
     899              :      external procedures are compared, where one is identified by usage
     900              :      to be a function or subroutine but the other is not.  Check TKR
     901              :      nonetheless for these cases.  */
     902            6 :   if (s1->attr.function == 0 && s1->attr.subroutine == 0)
     903            2 :     return s1->attr.external ? compare_type_rank (s1, s2) : false;
     904              : 
     905            4 :   if (s2->attr.function == 0 && s2->attr.subroutine == 0)
     906            0 :     return s2->attr.external ? compare_type_rank (s1, s2) : false;
     907              : 
     908              :   /* Now the type of procedure has been identified.  */
     909            4 :   if (s1->attr.function != s2->attr.function
     910            4 :       || s1->attr.subroutine != s2->attr.subroutine)
     911              :     return false;
     912              : 
     913            4 :   if (s1->attr.function && !compare_type_rank (s1, s2))
     914              :     return false;
     915              : 
     916              :   /* Originally, gfortran recursed here to check the interfaces of passed
     917              :      procedures.  This is explicitly not required by the standard.  */
     918              :   return true;
     919              : }
     920              : 
     921              : 
     922              : /* Given a formal argument list and a keyword name, search the list
     923              :    for that keyword.  Returns the correct symbol node if found, NULL
     924              :    if not found.  */
     925              : 
     926              : static gfc_symbol *
     927        32564 : find_keyword_arg (const char *name, gfc_formal_arglist *f)
     928              : {
     929        46058 :   for (; f; f = f->next)
     930        46058 :     if (strcmp (f->sym->name, name) == 0)
     931              :       return f->sym;
     932              : 
     933              :   return NULL;
     934              : }
     935              : 
     936              : 
     937              : /******** Interface checking subroutines **********/
     938              : 
     939              : 
     940              : /* Given an operator interface and the operator, make sure that all
     941              :    interfaces for that operator are legal.  */
     942              : 
     943              : bool
     944         3587 : gfc_check_operator_interface (gfc_symbol *sym, gfc_intrinsic_op op,
     945              :                               locus opwhere)
     946              : {
     947         3587 :   gfc_formal_arglist *formal;
     948         3587 :   sym_intent i1, i2;
     949         3587 :   bt t1, t2;
     950         3587 :   int args, r1, r2, k1, k2;
     951              : 
     952         3587 :   gcc_assert (sym);
     953              : 
     954         3587 :   args = 0;
     955         3587 :   t1 = t2 = BT_UNKNOWN;
     956         3587 :   i1 = i2 = INTENT_UNKNOWN;
     957         3587 :   r1 = r2 = -1;
     958         3587 :   k1 = k2 = -1;
     959              : 
     960        10729 :   for (formal = gfc_sym_get_dummy_args (sym); formal; formal = formal->next)
     961              :     {
     962         7143 :       gfc_symbol *fsym = formal->sym;
     963         7143 :       if (fsym == NULL)
     964              :         {
     965            1 :           gfc_error ("Alternate return cannot appear in operator "
     966              :                      "interface at %L", &sym->declared_at);
     967            1 :           return false;
     968              :         }
     969         7142 :       if (args == 0)
     970              :         {
     971         3587 :           t1 = fsym->ts.type;
     972         3587 :           i1 = fsym->attr.intent;
     973         3587 :           r1 = (fsym->as != NULL) ? fsym->as->rank : 0;
     974         3587 :           k1 = fsym->ts.kind;
     975              :         }
     976         7142 :       if (args == 1)
     977              :         {
     978         3555 :           t2 = fsym->ts.type;
     979         3555 :           i2 = fsym->attr.intent;
     980         3555 :           r2 = (fsym->as != NULL) ? fsym->as->rank : 0;
     981         3555 :           k2 = fsym->ts.kind;
     982              :         }
     983         7142 :       args++;
     984              :     }
     985              : 
     986              :   /* Only +, - and .not. can be unary operators.
     987              :      .not. cannot be a binary operator.  */
     988         3586 :   if (args == 0 || args > 2 || (args == 1 && op != INTRINSIC_PLUS
     989           30 :                                 && op != INTRINSIC_MINUS
     990           30 :                                 && op != INTRINSIC_NOT)
     991         3585 :       || (args == 2 && op == INTRINSIC_NOT))
     992              :     {
     993            1 :       if (op == INTRINSIC_ASSIGN)
     994            0 :         gfc_error ("Assignment operator interface at %L must have "
     995              :                    "two arguments", &sym->declared_at);
     996              :       else
     997            1 :         gfc_error ("Operator interface at %L has the wrong number of arguments",
     998              :                    &sym->declared_at);
     999            1 :       return false;
    1000              :     }
    1001              : 
    1002              :   /* Check that intrinsics are mapped to functions, except
    1003              :      INTRINSIC_ASSIGN which should map to a subroutine.  */
    1004         3585 :   if (op == INTRINSIC_ASSIGN)
    1005              :     {
    1006         1385 :       gfc_formal_arglist *dummy_args;
    1007              : 
    1008         1385 :       if (!sym->attr.subroutine)
    1009              :         {
    1010            1 :           gfc_error ("Assignment operator interface at %L must be "
    1011              :                      "a SUBROUTINE", &sym->declared_at);
    1012            1 :           return false;
    1013              :         }
    1014              : 
    1015              :       /* Allowed are (per F2003, 12.3.2.1.2 Defined assignments):
    1016              :          - First argument an array with different rank than second,
    1017              :          - First argument is a scalar and second an array,
    1018              :          - Types and kinds do not conform, or
    1019              :          - First argument is of derived type.  */
    1020         1384 :       dummy_args = gfc_sym_get_dummy_args (sym);
    1021         1384 :       if (dummy_args->sym->ts.type != BT_DERIVED
    1022         1153 :           && dummy_args->sym->ts.type != BT_CLASS
    1023           94 :           && (r2 == 0 || r1 == r2)
    1024         1473 :           && (dummy_args->sym->ts.type == dummy_args->next->sym->ts.type
    1025           84 :               || (gfc_numeric_ts (&dummy_args->sym->ts)
    1026           50 :                   && gfc_numeric_ts (&dummy_args->next->sym->ts))))
    1027              :         {
    1028            5 :           gfc_error ("Assignment operator interface at %L must not redefine "
    1029              :                      "an INTRINSIC type assignment", &sym->declared_at);
    1030            5 :           return false;
    1031              :         }
    1032              :     }
    1033              :   else
    1034              :     {
    1035         2200 :       if (!sym->attr.function)
    1036              :         {
    1037            1 :           gfc_error ("Intrinsic operator interface at %L must be a FUNCTION",
    1038              :                      &sym->declared_at);
    1039            1 :           return false;
    1040              :         }
    1041              :     }
    1042              : 
    1043              :   /* Check intents on operator interfaces.  */
    1044         3578 :   if (op == INTRINSIC_ASSIGN)
    1045              :     {
    1046         1379 :       if (i1 != INTENT_OUT && i1 != INTENT_INOUT)
    1047              :         {
    1048            0 :           gfc_error ("First argument of defined assignment at %L must be "
    1049              :                      "INTENT(OUT) or INTENT(INOUT)", &sym->declared_at);
    1050            0 :           return false;
    1051              :         }
    1052              : 
    1053         1379 :       if (i2 != INTENT_IN)
    1054              :         {
    1055            0 :           gfc_error ("Second argument of defined assignment at %L must be "
    1056              :                      "INTENT(IN)", &sym->declared_at);
    1057            0 :           return false;
    1058              :         }
    1059              :     }
    1060              :   else
    1061              :     {
    1062         2199 :       if (i1 != INTENT_IN)
    1063              :         {
    1064            0 :           gfc_error ("First argument of operator interface at %L must be "
    1065              :                      "INTENT(IN)", &sym->declared_at);
    1066            0 :           return false;
    1067              :         }
    1068              : 
    1069         2199 :       if (args == 2 && i2 != INTENT_IN)
    1070              :         {
    1071            0 :           gfc_error ("Second argument of operator interface at %L must be "
    1072              :                      "INTENT(IN)", &sym->declared_at);
    1073            0 :           return false;
    1074              :         }
    1075              :     }
    1076              : 
    1077              :   /* From now on, all we have to do is check that the operator definition
    1078              :      doesn't conflict with an intrinsic operator. The rules for this
    1079              :      game are defined in 7.1.2 and 7.1.3 of both F95 and F2003 standards,
    1080              :      as well as 12.3.2.1.1 of Fortran 2003:
    1081              : 
    1082              :      "If the operator is an intrinsic-operator (R310), the number of
    1083              :      function arguments shall be consistent with the intrinsic uses of
    1084              :      that operator, and the types, kind type parameters, or ranks of the
    1085              :      dummy arguments shall differ from those required for the intrinsic
    1086              :      operation (7.1.2)."  */
    1087              : 
    1088              : #define IS_NUMERIC_TYPE(t) \
    1089              :   ((t) == BT_INTEGER || (t) == BT_REAL || (t) == BT_COMPLEX)
    1090              : 
    1091              :   /* Unary ops are easy, do them first.  */
    1092         3578 :   if (op == INTRINSIC_NOT)
    1093              :     {
    1094            5 :       if (t1 == BT_LOGICAL)
    1095            0 :         goto bad_repl;
    1096              :       else
    1097              :         return true;
    1098              :     }
    1099              : 
    1100         3573 :   if (args == 1 && (op == INTRINSIC_PLUS || op == INTRINSIC_MINUS))
    1101              :     {
    1102           25 :       if (IS_NUMERIC_TYPE (t1))
    1103            0 :         goto bad_repl;
    1104              :       else
    1105              :         return true;
    1106              :     }
    1107              : 
    1108              :   /* Character intrinsic operators have same character kind, thus
    1109              :      operator definitions with operands of different character kinds
    1110              :      are always safe.  */
    1111         3548 :   if (t1 == BT_CHARACTER && t2 == BT_CHARACTER && k1 != k2)
    1112              :     return true;
    1113              : 
    1114              :   /* Intrinsic operators always perform on arguments of same rank,
    1115              :      so different ranks is also always safe.  (rank == 0) is an exception
    1116              :      to that, because all intrinsic operators are elemental.  */
    1117         3548 :   if (r1 != r2 && r1 != 0 && r2 != 0)
    1118              :     return true;
    1119              : 
    1120         3482 :   switch (op)
    1121              :   {
    1122         1019 :     case INTRINSIC_EQ:
    1123         1019 :     case INTRINSIC_EQ_OS:
    1124         1019 :     case INTRINSIC_NE:
    1125         1019 :     case INTRINSIC_NE_OS:
    1126         1019 :       if (t1 == BT_CHARACTER && t2 == BT_CHARACTER)
    1127            0 :         goto bad_repl;
    1128              :       /* Fall through.  */
    1129              : 
    1130         1736 :     case INTRINSIC_PLUS:
    1131         1736 :     case INTRINSIC_MINUS:
    1132         1736 :     case INTRINSIC_TIMES:
    1133         1736 :     case INTRINSIC_DIVIDE:
    1134         1736 :     case INTRINSIC_POWER:
    1135         1736 :       if (IS_NUMERIC_TYPE (t1) && IS_NUMERIC_TYPE (t2))
    1136            2 :         goto bad_repl;
    1137              :       break;
    1138              : 
    1139          278 :     case INTRINSIC_GT:
    1140          278 :     case INTRINSIC_GT_OS:
    1141          278 :     case INTRINSIC_GE:
    1142          278 :     case INTRINSIC_GE_OS:
    1143          278 :     case INTRINSIC_LT:
    1144          278 :     case INTRINSIC_LT_OS:
    1145          278 :     case INTRINSIC_LE:
    1146          278 :     case INTRINSIC_LE_OS:
    1147          278 :       if (t1 == BT_CHARACTER && t2 == BT_CHARACTER)
    1148            1 :         goto bad_repl;
    1149          277 :       if ((t1 == BT_INTEGER || t1 == BT_REAL)
    1150            0 :           && (t2 == BT_INTEGER || t2 == BT_REAL))
    1151            0 :         goto bad_repl;
    1152              :       break;
    1153              : 
    1154           36 :     case INTRINSIC_CONCAT:
    1155           36 :       if (t1 == BT_CHARACTER && t2 == BT_CHARACTER)
    1156            0 :         goto bad_repl;
    1157              :       break;
    1158              : 
    1159           56 :     case INTRINSIC_AND:
    1160           56 :     case INTRINSIC_OR:
    1161           56 :     case INTRINSIC_EQV:
    1162           56 :     case INTRINSIC_NEQV:
    1163           56 :       if (t1 == BT_LOGICAL && t2 == BT_LOGICAL)
    1164            0 :         goto bad_repl;
    1165              :       break;
    1166              : 
    1167              :     default:
    1168              :       break;
    1169              :   }
    1170              : 
    1171              :   return true;
    1172              : 
    1173              : #undef IS_NUMERIC_TYPE
    1174              : 
    1175            3 : bad_repl:
    1176            3 :   gfc_error ("Operator interface at %L conflicts with intrinsic interface",
    1177              :              &opwhere);
    1178            3 :   return false;
    1179              : }
    1180              : 
    1181              : 
    1182              : /* Given a pair of formal argument lists, we see if the two lists can
    1183              :    be distinguished by counting the number of nonoptional arguments of
    1184              :    a given type/rank in f1 and seeing if there are less then that
    1185              :    number of those arguments in f2 (including optional arguments).
    1186              :    Since this test is asymmetric, it has to be called twice to make it
    1187              :    symmetric. Returns nonzero if the argument lists are incompatible
    1188              :    by this test. This subroutine implements rule 1 of section F03:16.2.3.
    1189              :    'p1' and 'p2' are the PASS arguments of both procedures (if applicable).  */
    1190              : 
    1191              : static bool
    1192       888608 : count_types_test (gfc_formal_arglist *f1, gfc_formal_arglist *f2,
    1193              :                   const char *p1, const char *p2)
    1194              : {
    1195       888608 :   int ac1, ac2, i, j, k, n1;
    1196       888608 :   gfc_formal_arglist *f;
    1197              : 
    1198       888608 :   typedef struct
    1199              :   {
    1200              :     int flag;
    1201              :     gfc_symbol *sym;
    1202              :   }
    1203              :   arginfo;
    1204              : 
    1205       888608 :   arginfo *arg;
    1206              : 
    1207       888608 :   n1 = 0;
    1208              : 
    1209      2511650 :   for (f = f1; f; f = f->next)
    1210      1623042 :     n1++;
    1211              : 
    1212              :   /* Build an array of integers that gives the same integer to
    1213              :      arguments of the same type/rank.  */
    1214       888608 :   arg = XCNEWVEC (arginfo, n1);
    1215              : 
    1216       888608 :   f = f1;
    1217      3400258 :   for (i = 0; i < n1; i++, f = f->next)
    1218              :     {
    1219      1623042 :       arg[i].flag = -1;
    1220      1623042 :       arg[i].sym = f->sym;
    1221              :     }
    1222              : 
    1223              :   k = 0;
    1224              : 
    1225      2511650 :   for (i = 0; i < n1; i++)
    1226              :     {
    1227      1623042 :       if (arg[i].flag != -1)
    1228       265869 :         continue;
    1229              : 
    1230      1357173 :       if (arg[i].sym && (arg[i].sym->attr.optional
    1231      1356984 :                          || (p1 && strcmp (arg[i].sym->name, p1) == 0)))
    1232          481 :         continue;               /* Skip OPTIONAL and PASS arguments.  */
    1233              : 
    1234      1356692 :       arg[i].flag = k;
    1235              : 
    1236              :       /* Find other non-optional, non-pass arguments of the same type/rank.  */
    1237      2108010 :       for (j = i + 1; j < n1; j++)
    1238       751318 :         if ((arg[j].sym == NULL
    1239       751286 :              || !(arg[j].sym->attr.optional
    1240          188 :                   || (p1 && strcmp (arg[j].sym->name, p1) == 0)))
    1241      1502246 :             && (compare_type_rank_if (arg[i].sym, arg[j].sym)
    1242       564747 :                 || compare_type_rank_if (arg[j].sym, arg[i].sym)))
    1243       265869 :           arg[j].flag = k;
    1244              : 
    1245      1356692 :       k++;
    1246              :     }
    1247              : 
    1248              :   /* Now loop over each distinct type found in f1.  */
    1249              :   k = 0;
    1250      1198570 :   bool rc = false;
    1251              : 
    1252      1198570 :   for (i = 0; i < n1; i++)
    1253              :     {
    1254      1100388 :       if (arg[i].flag != k)
    1255        42694 :         continue;
    1256              : 
    1257      1057694 :       ac1 = 1;
    1258      1808751 :       for (j = i + 1; j < n1; j++)
    1259       751057 :         if (arg[j].flag == k)
    1260       265848 :           ac1++;
    1261              : 
    1262              :       /* Count the number of non-pass arguments in f2 with that type,
    1263              :          including those that are optional.  */
    1264              :       ac2 = 0;
    1265              : 
    1266      2995866 :       for (f = f2; f; f = f->next)
    1267          609 :         if ((!p2 || strcmp (f->sym->name, p2) != 0)
    1268      1938443 :             && (compare_type_rank_if (arg[i].sym, f->sym)
    1269      1580300 :                 || compare_type_rank_if (f->sym, arg[i].sym)))
    1270       423750 :           ac2++;
    1271              : 
    1272      1057694 :       if (ac1 > ac2)
    1273              :         {
    1274              :           rc = true;
    1275              :           break;
    1276              :         }
    1277              : 
    1278       267268 :       k++;
    1279              :     }
    1280              : 
    1281       888608 :   free (arg);
    1282              : 
    1283       888608 :   return rc;
    1284              : }
    1285              : 
    1286              : 
    1287              : /* Returns true if two dummy arguments are distinguishable due to their POINTER
    1288              :    and ALLOCATABLE attributes according to F2018 section 15.4.3.4.5 (3).
    1289              :    The function is asymmetric wrt to the arguments s1 and s2 and should always
    1290              :    be called twice (with flipped arguments in the second call).  */
    1291              : 
    1292              : static bool
    1293        27801 : compare_ptr_alloc(gfc_symbol *s1, gfc_symbol *s2)
    1294              : {
    1295              :   /* Is s1 allocatable?  */
    1296        27801 :   const bool a1 = s1->ts.type == BT_CLASS ?
    1297        27801 :                   CLASS_DATA(s1)->attr.allocatable : s1->attr.allocatable;
    1298              :   /* Is s2 a pointer?  */
    1299        27801 :   const bool p2 = s2->ts.type == BT_CLASS ?
    1300        27801 :                   CLASS_DATA(s2)->attr.class_pointer : s2->attr.pointer;
    1301        27801 :   return a1 && p2 && (s2->attr.intent != INTENT_IN);
    1302              : }
    1303              : 
    1304              : 
    1305              : /* Perform the correspondence test in rule (3) of F08:C1215.
    1306              :    Returns zero if no argument is found that satisfies this rule,
    1307              :    nonzero otherwise. 'p1' and 'p2' are the PASS arguments of both procedures
    1308              :    (if applicable).
    1309              : 
    1310              :    This test is also not symmetric in f1 and f2 and must be called
    1311              :    twice.  This test finds problems caused by sorting the actual
    1312              :    argument list with keywords.  For example:
    1313              : 
    1314              :    INTERFACE FOO
    1315              :      SUBROUTINE F1(A, B)
    1316              :        INTEGER :: A ; REAL :: B
    1317              :      END SUBROUTINE F1
    1318              : 
    1319              :      SUBROUTINE F2(B, A)
    1320              :        INTEGER :: A ; REAL :: B
    1321              :      END SUBROUTINE F1
    1322              :    END INTERFACE FOO
    1323              : 
    1324              :    At this point, 'CALL FOO(A=1, B=1.0)' is ambiguous.  */
    1325              : 
    1326              : static bool
    1327        32614 : generic_correspondence (gfc_formal_arglist *f1, gfc_formal_arglist *f2,
    1328              :                         const char *p1, const char *p2)
    1329              : {
    1330        32614 :   gfc_formal_arglist *f2_save, *g;
    1331        32614 :   gfc_symbol *sym;
    1332              : 
    1333        32614 :   f2_save = f2;
    1334              : 
    1335        46176 :   while (f1)
    1336              :     {
    1337        46126 :       if (!f1->sym || f1->sym->attr.optional)
    1338            4 :         goto next;
    1339              : 
    1340        46122 :       if (p1 && strcmp (f1->sym->name, p1) == 0)
    1341            7 :         f1 = f1->next;
    1342        46122 :       if (f2 && p2 && strcmp (f2->sym->name, p2) == 0)
    1343            5 :         f2 = f2->next;
    1344              : 
    1345        46118 :       if (f2 != NULL && (compare_type_rank (f1->sym, f2->sym)
    1346        32555 :                          || compare_type_rank (f2->sym, f1->sym))
    1347        59688 :           && !((gfc_option.allow_std & GFC_STD_F2008)
    1348        13566 :                && (compare_ptr_alloc(f1->sym, f2->sym)
    1349        13559 :                    || compare_ptr_alloc(f2->sym, f1->sym))))
    1350        13554 :         goto next;
    1351              : 
    1352              :       /* Now search for a disambiguating keyword argument starting at
    1353              :          the current non-match.  */
    1354        32568 :       for (g = f1; g; g = g->next)
    1355              :         {
    1356        32564 :           if (g->sym->attr.optional || (p1 && strcmp (g->sym->name, p1) == 0))
    1357            0 :             continue;
    1358              : 
    1359        32564 :           sym = find_keyword_arg (g->sym->name, f2_save);
    1360        32564 :           if (sym == NULL || !compare_type_rank (g->sym, sym)
    1361        32578 :               || ((gfc_option.allow_std & GFC_STD_F2008)
    1362           14 :                   && (compare_ptr_alloc(sym, g->sym)
    1363            7 :                       || compare_ptr_alloc(g->sym, sym))))
    1364        32564 :             return true;
    1365              :         }
    1366              : 
    1367        13562 :     next:
    1368        13562 :       if (f1 != NULL)
    1369        13558 :         f1 = f1->next;
    1370        13562 :       if (f2 != NULL)
    1371        13558 :         f2 = f2->next;
    1372              :     }
    1373              : 
    1374              :   return false;
    1375              : }
    1376              : 
    1377              : 
    1378              : int
    1379       562555 : gfc_symbol_rank (gfc_symbol *sym)
    1380              : {
    1381       562555 :   gfc_array_spec *as = NULL;
    1382              : 
    1383       562555 :   if (sym->ts.type == BT_CLASS && CLASS_DATA (sym))
    1384        16907 :     as = CLASS_DATA (sym)->as;
    1385              :   else
    1386       545648 :     as = sym->as;
    1387              : 
    1388       562555 :   return as ? as->rank : 0;
    1389              : }
    1390              : 
    1391              : 
    1392              : /* Check if the characteristics of two dummy arguments match,
    1393              :    cf. F08:12.3.2.  */
    1394              : 
    1395              : bool
    1396       118092 : gfc_check_dummy_characteristics (gfc_symbol *s1, gfc_symbol *s2,
    1397              :                                  bool type_must_agree, char *errmsg,
    1398              :                                  int err_len)
    1399              : {
    1400       118092 :   if (s1 == NULL || s2 == NULL)
    1401           27 :     return s1 == s2 ? true : false;
    1402              : 
    1403       118065 :   if (s1->attr.proc == PROC_ST_FUNCTION || s2->attr.proc == PROC_ST_FUNCTION)
    1404              :     {
    1405            1 :       strncpy (errmsg, "Statement function", err_len);
    1406            1 :       return false;
    1407              :     }
    1408              : 
    1409              :   /* Check type and rank.  */
    1410       118064 :   if (type_must_agree)
    1411              :     {
    1412       116899 :       if (!compare_type_characteristics (s1, s2)
    1413       116899 :           || !compare_type_characteristics (s2, s1))
    1414              :         {
    1415           24 :           snprintf (errmsg, err_len, "Type mismatch in argument '%s' (%s/%s)",
    1416              :                     s1->name, gfc_dummy_typename (&s1->ts),
    1417              :                     gfc_dummy_typename (&s2->ts));
    1418           24 :           return false;
    1419              :         }
    1420       116875 :       if (!compare_rank (s1, s2))
    1421              :         {
    1422            5 :           snprintf (errmsg, err_len, "Rank mismatch in argument '%s' (%i/%i)",
    1423              :                     s1->name, gfc_symbol_rank (s1), gfc_symbol_rank (s2));
    1424            5 :           return false;
    1425              :         }
    1426              :     }
    1427              : 
    1428              :   /* A lot of information is missing for artificially generated
    1429              :      formal arguments, let's not look into that.  */
    1430              : 
    1431       118035 :   if (!s1->attr.artificial && !s2->attr.artificial)
    1432              :     {
    1433              :       /* Check INTENT.  */
    1434        92752 :       if (s1->attr.intent != s2->attr.intent)
    1435              :         {
    1436            5 :           snprintf (errmsg, err_len, "INTENT mismatch in argument '%s'",
    1437              :                     s1->name);
    1438            5 :           return false;
    1439              :         }
    1440              : 
    1441              :       /* Check OPTIONAL attribute.  */
    1442        92747 :       if (s1->attr.optional != s2->attr.optional)
    1443              :         {
    1444            1 :           snprintf (errmsg, err_len, "OPTIONAL mismatch in argument '%s'",
    1445              :                     s1->name);
    1446            1 :           return false;
    1447              :         }
    1448              : 
    1449              :       /* Check ALLOCATABLE attribute.  */
    1450        92746 :       if (s1->attr.allocatable != s2->attr.allocatable)
    1451              :         {
    1452            0 :           snprintf (errmsg, err_len, "ALLOCATABLE mismatch in argument '%s'",
    1453              :                     s1->name);
    1454            0 :           return false;
    1455              :         }
    1456              : 
    1457              :       /* Check POINTER attribute.  */
    1458        92746 :       if (s1->attr.pointer != s2->attr.pointer)
    1459              :         {
    1460            0 :           snprintf (errmsg, err_len, "POINTER mismatch in argument '%s'",
    1461              :                     s1->name);
    1462            0 :           return false;
    1463              :         }
    1464              : 
    1465              :       /* Check TARGET attribute.  */
    1466        92746 :       if (s1->attr.target != s2->attr.target)
    1467              :         {
    1468            0 :           snprintf (errmsg, err_len, "TARGET mismatch in argument '%s'",
    1469              :                     s1->name);
    1470            0 :           return false;
    1471              :         }
    1472              : 
    1473              :       /* Check ASYNCHRONOUS attribute.  */
    1474        92746 :       if (s1->attr.asynchronous != s2->attr.asynchronous)
    1475              :         {
    1476            1 :           snprintf (errmsg, err_len, "ASYNCHRONOUS mismatch in argument '%s'",
    1477              :                     s1->name);
    1478            1 :           return false;
    1479              :         }
    1480              : 
    1481              :       /* Check CONTIGUOUS attribute.  */
    1482        92745 :       if (s1->attr.contiguous != s2->attr.contiguous)
    1483              :         {
    1484            1 :           snprintf (errmsg, err_len, "CONTIGUOUS mismatch in argument '%s'",
    1485              :                     s1->name);
    1486            1 :           return false;
    1487              :         }
    1488              : 
    1489              :       /* Check VALUE attribute.  */
    1490        92744 :       if (s1->attr.value != s2->attr.value)
    1491              :         {
    1492            1 :           snprintf (errmsg, err_len, "VALUE mismatch in argument '%s'",
    1493              :                     s1->name);
    1494            1 :           return false;
    1495              :         }
    1496              : 
    1497              :       /* Check VOLATILE attribute.  */
    1498        92743 :       if (s1->attr.volatile_ != s2->attr.volatile_)
    1499              :         {
    1500            1 :           snprintf (errmsg, err_len, "VOLATILE mismatch in argument '%s'",
    1501              :                     s1->name);
    1502            1 :           return false;
    1503              :         }
    1504              :     }
    1505              : 
    1506              :   /* Check interface of dummy procedures.  */
    1507       118025 :   if (s1->attr.flavor == FL_PROCEDURE)
    1508              :     {
    1509          123 :       char err[200];
    1510          123 :       if (!gfc_compare_interfaces (s1, s2, s2->name, 0, 1, err, sizeof(err),
    1511              :                                    NULL, NULL))
    1512              :         {
    1513            1 :           snprintf (errmsg, err_len, "Interface mismatch in dummy procedure "
    1514              :                     "'%s': %s", s1->name, err);
    1515            1 :           return false;
    1516              :         }
    1517              :     }
    1518              : 
    1519              :   /* Check string length.  */
    1520       118024 :   if (s1->ts.type == BT_CHARACTER
    1521         2784 :       && s1->ts.u.cl && s1->ts.u.cl->length
    1522          883 :       && s2->ts.u.cl && s2->ts.u.cl->length)
    1523              :     {
    1524          883 :       int compval = gfc_dep_compare_expr (s1->ts.u.cl->length,
    1525              :                                           s2->ts.u.cl->length);
    1526          883 :       switch (compval)
    1527              :       {
    1528            0 :         case -1:
    1529            0 :         case  1:
    1530            0 :         case -3:
    1531            0 :           snprintf (errmsg, err_len, "Character length mismatch "
    1532              :                     "in argument '%s'", s1->name);
    1533            0 :           return false;
    1534              : 
    1535              :         case -2:
    1536              :           /* FIXME: Implement a warning for this case.
    1537              :           gfc_warning (0, "Possible character length mismatch in argument %qs",
    1538              :                        s1->name);*/
    1539              :           break;
    1540              : 
    1541              :         case 0:
    1542              :           break;
    1543              : 
    1544            0 :         default:
    1545            0 :           gfc_internal_error ("check_dummy_characteristics: Unexpected result "
    1546              :                               "%i of gfc_dep_compare_expr", compval);
    1547              :           break;
    1548              :       }
    1549              :     }
    1550              : 
    1551              :   /* Check array shape.  */
    1552       118024 :   if (s1->as && s2->as)
    1553              :     {
    1554        20063 :       int i, compval;
    1555        20063 :       gfc_expr *shape1, *shape2;
    1556              : 
    1557        20063 :       if (s1->as->rank != s2->as->rank)
    1558              :         {
    1559            2 :           snprintf (errmsg, err_len, "Rank mismatch in argument '%s' (%i/%i)",
    1560              :                     s1->name, s1->as->rank, s2->as->rank);
    1561            2 :           return false;
    1562              :         }
    1563              : 
    1564              :       /* Sometimes the ambiguity between deferred shape and assumed shape
    1565              :          does not get resolved in module procedures, where the only explicit
    1566              :          declaration of the dummy is in the interface.  */
    1567        20061 :       if (s1->ns->proc_name && s1->ns->proc_name->attr.module_procedure
    1568          114 :           && s1->as->type == AS_ASSUMED_SHAPE
    1569           67 :           && s2->as->type == AS_DEFERRED)
    1570              :         {
    1571            7 :           s2->as->type = AS_ASSUMED_SHAPE;
    1572           14 :           for (i = 0; i < s2->as->rank; i++)
    1573            7 :             if (s1->as->lower[i] != NULL)
    1574            7 :               s2->as->lower[i] = gfc_copy_expr (s1->as->lower[i]);
    1575              :         }
    1576              : 
    1577        20061 :       if (s1->as->type != s2->as->type
    1578            4 :           && !(s1->as->type == AS_DEFERRED
    1579              :                && s2->as->type == AS_ASSUMED_SHAPE))
    1580              :         {
    1581            2 :           snprintf (errmsg, err_len, "Shape mismatch in argument '%s'",
    1582              :                     s1->name);
    1583            2 :           return false;
    1584              :         }
    1585              : 
    1586        20059 :       if (s1->as->corank != s2->as->corank)
    1587              :         {
    1588            1 :           snprintf (errmsg, err_len, "Corank mismatch in argument '%s' (%i/%i)",
    1589              :                     s1->name, s1->as->corank, s2->as->corank);
    1590            1 :           return false;
    1591              :         }
    1592              : 
    1593        20058 :       if (s1->as->type == AS_EXPLICIT)
    1594         1271 :         for (i = 0; i < s1->as->rank + MAX (0, s1->as->corank-1); i++)
    1595              :           {
    1596          786 :             shape1 = gfc_subtract (gfc_copy_expr (s1->as->upper[i]),
    1597          786 :                                   gfc_copy_expr (s1->as->lower[i]));
    1598          786 :             shape2 = gfc_subtract (gfc_copy_expr (s2->as->upper[i]),
    1599          786 :                                   gfc_copy_expr (s2->as->lower[i]));
    1600          786 :             compval = gfc_dep_compare_expr (shape1, shape2);
    1601          786 :             gfc_free_expr (shape1);
    1602          786 :             gfc_free_expr (shape2);
    1603          786 :             switch (compval)
    1604              :             {
    1605            2 :               case -1:
    1606            2 :               case  1:
    1607            2 :               case -3:
    1608            2 :                 if (i < s1->as->rank)
    1609            2 :                   snprintf (errmsg, err_len, "Shape mismatch in dimension %i of"
    1610              :                             " argument '%s'", i + 1, s1->name);
    1611              :                 else
    1612            0 :                   snprintf (errmsg, err_len, "Shape mismatch in codimension %i "
    1613            0 :                             "of argument '%s'", i - s1->as->rank + 1, s1->name);
    1614            2 :                 return false;
    1615              : 
    1616              :               case -2:
    1617              :                 /* FIXME: Implement a warning for this case.
    1618              :                 gfc_warning (0, "Possible shape mismatch in argument %qs",
    1619              :                             s1->name);*/
    1620              :                 break;
    1621              : 
    1622              :               case 0:
    1623              :                 break;
    1624              : 
    1625            0 :               default:
    1626            0 :                 gfc_internal_error ("check_dummy_characteristics: Unexpected "
    1627              :                                     "result %i of gfc_dep_compare_expr",
    1628              :                                     compval);
    1629          784 :                 break;
    1630              :             }
    1631              :           }
    1632              :     }
    1633              : 
    1634              :   return true;
    1635              : }
    1636              : 
    1637              : 
    1638              : /* Check if the characteristics of two function results match,
    1639              :    cf. F08:12.3.3.  */
    1640              : 
    1641              : bool
    1642        51846 : gfc_check_result_characteristics (gfc_symbol *s1, gfc_symbol *s2,
    1643              :                                   char *errmsg, int err_len)
    1644              : {
    1645        51846 :   gfc_symbol *r1, *r2;
    1646              : 
    1647        51846 :   if (s1->ts.interface && s1->ts.interface->result)
    1648              :     r1 = s1->ts.interface->result;
    1649              :   else
    1650        51393 :     r1 = s1->result ? s1->result : s1;
    1651              : 
    1652        51846 :   if (s2->ts.interface && s2->ts.interface->result)
    1653              :     r2 = s2->ts.interface->result;
    1654              :   else
    1655        51395 :     r2 = s2->result ? s2->result : s2;
    1656              : 
    1657        51846 :   if (r1->ts.type == BT_UNKNOWN)
    1658              :     return true;
    1659              : 
    1660              :   /* Check type and rank.  */
    1661        51598 :   if (!compare_type_characteristics (r1, r2))
    1662              :     {
    1663           21 :       snprintf (errmsg, err_len, "Type mismatch in function result (%s/%s)",
    1664              :                 gfc_typename (&r1->ts), gfc_typename (&r2->ts));
    1665           21 :       return false;
    1666              :     }
    1667        51577 :   if (!compare_rank (r1, r2))
    1668              :     {
    1669            5 :       snprintf (errmsg, err_len, "Rank mismatch in function result (%i/%i)",
    1670              :                 gfc_symbol_rank (r1), gfc_symbol_rank (r2));
    1671            5 :       return false;
    1672              :     }
    1673              : 
    1674              :   /* Check ALLOCATABLE attribute.  */
    1675        51572 :   if (r1->attr.allocatable != r2->attr.allocatable)
    1676              :     {
    1677            2 :       snprintf (errmsg, err_len, "ALLOCATABLE attribute mismatch in "
    1678              :                 "function result");
    1679            2 :       return false;
    1680              :     }
    1681              : 
    1682              :   /* Check POINTER attribute.  */
    1683        51570 :   if (r1->attr.pointer != r2->attr.pointer)
    1684              :     {
    1685            2 :       snprintf (errmsg, err_len, "POINTER attribute mismatch in "
    1686              :                 "function result");
    1687            2 :       return false;
    1688              :     }
    1689              : 
    1690              :   /* Check CONTIGUOUS attribute.  */
    1691        51568 :   if (r1->attr.contiguous != r2->attr.contiguous)
    1692              :     {
    1693            1 :       snprintf (errmsg, err_len, "CONTIGUOUS attribute mismatch in "
    1694              :                 "function result");
    1695            1 :       return false;
    1696              :     }
    1697              : 
    1698              :   /* Check PROCEDURE POINTER attribute.  */
    1699        51567 :   if (r1 != s1 && r1->attr.proc_pointer != r2->attr.proc_pointer)
    1700              :     {
    1701            3 :       snprintf (errmsg, err_len, "PROCEDURE POINTER mismatch in "
    1702              :                 "function result");
    1703            3 :       return false;
    1704              :     }
    1705              : 
    1706              :   /* Check string length.  */
    1707        51564 :   if (r1->ts.type == BT_CHARACTER && r1->ts.u.cl && r2->ts.u.cl)
    1708              :     {
    1709         2211 :       if (r1->ts.deferred != r2->ts.deferred)
    1710              :         {
    1711            0 :           snprintf (errmsg, err_len, "Character length mismatch "
    1712              :                     "in function result");
    1713            0 :           return false;
    1714              :         }
    1715              : 
    1716         2211 :       if (r1->ts.u.cl->length && r2->ts.u.cl->length)
    1717              :         {
    1718         1647 :           int compval = gfc_dep_compare_expr (r1->ts.u.cl->length,
    1719              :                                               r2->ts.u.cl->length);
    1720         1647 :           switch (compval)
    1721              :           {
    1722            3 :             case -1:
    1723            3 :             case  1:
    1724            3 :             case -3:
    1725            3 :               snprintf (errmsg, err_len, "Character length mismatch "
    1726              :                         "in function result");
    1727            3 :               return false;
    1728              : 
    1729           75 :             case -2:
    1730           75 :               if (r1->ts.u.cl->length->expr_type == EXPR_CONSTANT)
    1731              :                 {
    1732            0 :                   snprintf (errmsg, err_len,
    1733              :                             "Function declared with a non-constant character "
    1734              :                             "length referenced with a constant length");
    1735            0 :                   return false;
    1736              :                 }
    1737           75 :               else if (r2->ts.u.cl->length->expr_type == EXPR_CONSTANT)
    1738              :                 {
    1739            3 :                   snprintf (errmsg, err_len,
    1740              :                             "Function declared with a constant character "
    1741              :                             "length referenced with a non-constant length");
    1742            3 :                   return false;
    1743              :                 }
    1744              :               /* Warn if length expression types are different, except for
    1745              :                   possibly false positives where complex expressions might have
    1746              :                   been used.  */
    1747           72 :               else if ((r1->ts.u.cl->length->expr_type
    1748              :                         != r2->ts.u.cl->length->expr_type)
    1749            4 :                        && (r1->ts.u.cl->length->expr_type != EXPR_OP
    1750            2 :                            || r2->ts.u.cl->length->expr_type != EXPR_OP))
    1751            4 :                 gfc_warning (0, "Possible character length mismatch in "
    1752              :                              "function result between %L and %L",
    1753              :                              &r1->declared_at, &r2->declared_at);
    1754              :               break;
    1755              : 
    1756              :             case 0:
    1757              :               break;
    1758              : 
    1759            0 :             default:
    1760            0 :               gfc_internal_error ("check_result_characteristics (1): Unexpected "
    1761              :                                   "result %i of gfc_dep_compare_expr", compval);
    1762              :               break;
    1763              :           }
    1764              :         }
    1765              :     }
    1766              : 
    1767              :   /* Check array shape.  */
    1768        51558 :   if (!r1->attr.allocatable && !r1->attr.pointer && r1->as && r2->as)
    1769              :     {
    1770          989 :       int i, compval;
    1771          989 :       gfc_expr *shape1, *shape2;
    1772              : 
    1773          989 :       if (r1->as->type != r2->as->type)
    1774              :         {
    1775            0 :           snprintf (errmsg, err_len, "Shape mismatch in function result");
    1776            0 :           return false;
    1777              :         }
    1778              : 
    1779          989 :       if (r1->as->type == AS_EXPLICIT)
    1780         2493 :         for (i = 0; i < r1->as->rank + r1->as->corank; i++)
    1781              :           {
    1782         1505 :             shape1 = gfc_subtract (gfc_copy_expr (r1->as->upper[i]),
    1783         1505 :                                    gfc_copy_expr (r1->as->lower[i]));
    1784         1505 :             shape2 = gfc_subtract (gfc_copy_expr (r2->as->upper[i]),
    1785         1505 :                                    gfc_copy_expr (r2->as->lower[i]));
    1786         1505 :             compval = gfc_dep_compare_expr (shape1, shape2);
    1787         1505 :             gfc_free_expr (shape1);
    1788         1505 :             gfc_free_expr (shape2);
    1789         1505 :             switch (compval)
    1790              :             {
    1791            1 :               case -1:
    1792            1 :               case  1:
    1793            1 :               case -3:
    1794            1 :                 snprintf (errmsg, err_len, "Shape mismatch in dimension %i of "
    1795              :                           "function result", i + 1);
    1796            1 :                 return false;
    1797              : 
    1798              :               case -2:
    1799              :                 /* FIXME: Implement a warning for this case.
    1800              :                 gfc_warning (0, "Possible shape mismatch in return value");*/
    1801              :                 break;
    1802              : 
    1803              :               case 0:
    1804              :                 break;
    1805              : 
    1806            0 :               default:
    1807            0 :                 gfc_internal_error ("check_result_characteristics (2): "
    1808              :                                     "Unexpected result %i of "
    1809              :                                     "gfc_dep_compare_expr", compval);
    1810         1504 :                 break;
    1811              :             }
    1812              :           }
    1813              :     }
    1814              : 
    1815              :   return true;
    1816              : }
    1817              : 
    1818              : 
    1819              : /* 'Compare' two formal interfaces associated with a pair of symbols.
    1820              :    We return true if there exists an actual argument list that
    1821              :    would be ambiguous between the two interfaces, zero otherwise.
    1822              :    'strict_flag' specifies whether all the characteristics are
    1823              :    required to match, which is not the case for ambiguity checks.
    1824              :    'p1' and 'p2' are the PASS arguments of both procedures (if applicable).  */
    1825              : 
    1826              : bool
    1827       884171 : gfc_compare_interfaces (gfc_symbol *s1, gfc_symbol *s2, const char *name2,
    1828              :                         int generic_flag, int strict_flag,
    1829              :                         char *errmsg, int err_len,
    1830              :                         const char *p1, const char *p2,
    1831              :                         bool *bad_result_characteristics)
    1832              : {
    1833       884171 :   gfc_formal_arglist *f1, *f2;
    1834              : 
    1835       884171 :   gcc_assert (name2 != NULL);
    1836              : 
    1837       884171 :   if (bad_result_characteristics)
    1838        14929 :     *bad_result_characteristics = false;
    1839              : 
    1840       884171 :   if (s1->attr.function && (s2->attr.subroutine
    1841       793062 :       || (!s2->attr.function && s2->ts.type == BT_UNKNOWN
    1842            5 :           && gfc_get_default_type (name2, s2->ns)->type == BT_UNKNOWN)))
    1843              :     {
    1844            3 :       if (errmsg != NULL)
    1845            3 :         snprintf (errmsg, err_len, "'%s' is not a function", name2);
    1846            3 :       return false;
    1847              :     }
    1848              : 
    1849       884168 :   if (s1->attr.subroutine && s2->attr.function)
    1850              :     {
    1851            6 :       if (errmsg != NULL)
    1852            6 :         snprintf (errmsg, err_len, "'%s' is not a subroutine", name2);
    1853            6 :       return false;
    1854              :     }
    1855              : 
    1856       884162 :   if (s2->attr.subroutine && s1->attr.flavor == FL_VARIABLE)
    1857              :     {
    1858            2 :       if (errmsg != NULL)
    1859            2 :         snprintf (errmsg, err_len, "subroutine proc pointer '%s' passed "
    1860              :                   "to dummy variable '%s'", name2, s1->name);
    1861            2 :       return false;
    1862              :     }
    1863              : 
    1864              :   /* Do strict checks on all characteristics
    1865              :      (for dummy procedures and procedure pointer assignments).  */
    1866       884160 :   if (!generic_flag && strict_flag)
    1867              :     {
    1868        58161 :       if (s1->attr.function && s2->attr.function)
    1869              :         {
    1870              :           /* If both are functions, check result characteristics.  */
    1871        25392 :           if (!gfc_check_result_characteristics (s1, s2, errmsg, err_len)
    1872        25392 :               || !gfc_check_result_characteristics (s2, s1, errmsg, err_len))
    1873              :             {
    1874           30 :               if (bad_result_characteristics)
    1875            6 :                 *bad_result_characteristics = true;
    1876           30 :               return false;
    1877              :             }
    1878              :         }
    1879              : 
    1880        58131 :       if (s1->attr.pure && !s2->attr.pure)
    1881              :         {
    1882            2 :           snprintf (errmsg, err_len, "Mismatch in PURE attribute");
    1883            2 :           return false;
    1884              :         }
    1885        58129 :       if (s1->attr.elemental && !s2->attr.elemental)
    1886              :         {
    1887            0 :           snprintf (errmsg, err_len, "Mismatch in ELEMENTAL attribute");
    1888            0 :           return false;
    1889              :         }
    1890              :     }
    1891              : 
    1892       884128 :   if (s1->attr.if_source == IFSRC_UNKNOWN
    1893       868506 :       || s2->attr.if_source == IFSRC_UNKNOWN)
    1894              :     return true;
    1895              : 
    1896       868430 :   f1 = gfc_sym_get_dummy_args (s1);
    1897       868430 :   f2 = gfc_sym_get_dummy_args (s2);
    1898              : 
    1899              :   /* Special case: No arguments.  */
    1900       868430 :   if (f1 == NULL && f2 == NULL)
    1901              :     return true;
    1902              : 
    1903       866339 :   if (generic_flag)
    1904              :     {
    1905       823018 :       if (count_types_test (f1, f2, p1, p2)
    1906       823018 :           || count_types_test (f2, f1, p2, p1))
    1907       790426 :         return false;
    1908              : 
    1909              :       /* Special case: alternate returns.  If both f1->sym and f2->sym are
    1910              :          NULL, then the leading formal arguments are alternate returns.
    1911              :          The previous conditional should catch argument lists with
    1912              :          different number of argument.  */
    1913        32592 :       if (f1 && f1->sym == NULL && f2 && f2->sym == NULL)
    1914              :         return true;
    1915              : 
    1916        32589 :       if (generic_correspondence (f1, f2, p1, p2)
    1917        32589 :           || generic_correspondence (f2, f1, p2, p1))
    1918        32564 :         return false;
    1919              :     }
    1920              :   else
    1921              :     /* Perform the abbreviated correspondence test for operators (the
    1922              :        arguments cannot be optional and are always ordered correctly).
    1923              :        This is also done when comparing interfaces for dummy procedures and in
    1924              :        procedure pointer assignments.  */
    1925              : 
    1926       159256 :     for (; f1 || f2; f1 = f1->next, f2 = f2->next)
    1927              :       {
    1928              :         /* Check existence.  */
    1929       118952 :         if (f1 == NULL || f2 == NULL)
    1930              :           {
    1931           10 :             if (errmsg != NULL)
    1932            6 :               snprintf (errmsg, err_len, "'%s' has the wrong number of "
    1933              :                         "arguments", name2);
    1934           10 :             return false;
    1935              :           }
    1936              : 
    1937       118942 :         if (strict_flag)
    1938              :           {
    1939              :             /* Check all characteristics.  */
    1940       115649 :             if (!gfc_check_dummy_characteristics (f1->sym, f2->sym, true,
    1941              :                                               errmsg, err_len))
    1942              :               return false;
    1943              :           }
    1944              :         else
    1945              :           {
    1946              :             /* Operators: Only check type and rank of arguments.  */
    1947         3293 :             if (!compare_type (f2->sym, f1->sym))
    1948              :               {
    1949         2961 :                 if (errmsg != NULL)
    1950            0 :                   snprintf (errmsg, err_len, "Type mismatch in argument '%s' "
    1951            0 :                             "(%s/%s)", f1->sym->name,
    1952            0 :                             gfc_typename (&f1->sym->ts),
    1953            0 :                             gfc_typename (&f2->sym->ts));
    1954         2961 :                 return false;
    1955              :               }
    1956          332 :             if (!compare_rank (f2->sym, f1->sym))
    1957              :               {
    1958            4 :                 if (errmsg != NULL)
    1959            0 :                   snprintf (errmsg, err_len, "Rank mismatch in argument "
    1960            0 :                             "'%s' (%i/%i)", f1->sym->name,
    1961            0 :                             gfc_symbol_rank (f1->sym), gfc_symbol_rank (f2->sym));
    1962            4 :                 return false;
    1963              :               }
    1964          328 :             if ((gfc_option.allow_std & GFC_STD_F2008)
    1965          328 :                 && (compare_ptr_alloc(f1->sym, f2->sym)
    1966          327 :                     || compare_ptr_alloc(f2->sym, f1->sym)))
    1967              :               {
    1968            2 :                 if (errmsg != NULL)
    1969            0 :                   snprintf (errmsg, err_len, "Mismatching POINTER/ALLOCATABLE "
    1970              :                             "attribute in argument '%s' ", f1->sym->name);
    1971            2 :                 return false;
    1972              :               }
    1973              :           }
    1974              :       }
    1975              : 
    1976              :   return true;
    1977              : }
    1978              : 
    1979              : 
    1980              : /* Given a pointer to an interface pointer, remove duplicate
    1981              :    interfaces and make sure that all symbols are either functions
    1982              :    or subroutines, and all of the same kind.  Returns true if
    1983              :    something goes wrong.  */
    1984              : 
    1985              : static bool
    1986      9415426 : check_interface0 (gfc_interface *p, const char *interface_name)
    1987              : {
    1988      9415426 :   gfc_interface *psave, *q, *qlast;
    1989              : 
    1990      9415426 :   psave = p;
    1991      9612913 :   for (; p; p = p->next)
    1992              :     {
    1993              :       /* Make sure all symbols in the interface have been defined as
    1994              :          functions or subroutines.  */
    1995       197503 :       if (((!p->sym->attr.function && !p->sym->attr.subroutine)
    1996       161359 :            || !p->sym->attr.if_source)
    1997        36147 :           && !gfc_fl_struct (p->sym->attr.flavor))
    1998              :         {
    1999           12 :           const char *guessed
    2000           12 :             = gfc_lookup_function_fuzzy (p->sym->name, p->sym->ns->sym_root);
    2001              : 
    2002           12 :           if (p->sym->attr.external)
    2003            5 :             if (guessed)
    2004            5 :               gfc_error ("Procedure %qs in %s at %L has no explicit interface"
    2005              :                          "; did you mean %qs?",
    2006              :                          p->sym->name, interface_name, &p->sym->declared_at,
    2007              :                          guessed);
    2008              :             else
    2009            0 :               gfc_error ("Procedure %qs in %s at %L has no explicit interface",
    2010              :                          p->sym->name, interface_name, &p->sym->declared_at);
    2011              :           else
    2012            7 :             if (guessed)
    2013            4 :               gfc_error ("Procedure %qs in %s at %L is neither function nor "
    2014              :                          "subroutine; did you mean %qs?", p->sym->name,
    2015              :                         interface_name, &p->sym->declared_at, guessed);
    2016              :             else
    2017            3 :               gfc_error ("Procedure %qs in %s at %L is neither function nor "
    2018              :                          "subroutine", p->sym->name, interface_name,
    2019              :                         &p->sym->declared_at);
    2020           12 :           return true;
    2021              :         }
    2022              : 
    2023              :       /* Verify that procedures are either all SUBROUTINEs or all FUNCTIONs.  */
    2024       197491 :       if ((psave->sym->attr.function && !p->sym->attr.function
    2025          282 :            && !gfc_fl_struct (p->sym->attr.flavor))
    2026       197489 :           || (psave->sym->attr.subroutine && !p->sym->attr.subroutine))
    2027              :         {
    2028            3 :           if (!gfc_fl_struct (p->sym->attr.flavor))
    2029            3 :             gfc_error ("In %s at %L procedures must be either all SUBROUTINEs"
    2030              :                        " or all FUNCTIONs", interface_name,
    2031              :                        &p->sym->declared_at);
    2032            0 :           else if (p->sym->attr.flavor == FL_DERIVED)
    2033            0 :             gfc_error ("In %s at %L procedures must be all FUNCTIONs as the "
    2034              :                        "generic name is also the name of a derived type",
    2035              :                        interface_name, &p->sym->declared_at);
    2036            3 :           return true;
    2037              :         }
    2038              : 
    2039              :       /* F2003, C1207. F2008, C1207.  */
    2040       197488 :       if (p->sym->attr.proc == PROC_INTERNAL
    2041       197488 :           && !gfc_notify_std (GFC_STD_F2008, "Internal procedure "
    2042              :                               "%qs in %s at %L", p->sym->name,
    2043              :                               interface_name, &p->sym->declared_at))
    2044              :         return true;
    2045              :     }
    2046              :   p = psave;
    2047              : 
    2048              :   /* Remove duplicate interfaces in this interface list.  */
    2049      9607877 :   for (; p; p = p->next)
    2050              :     {
    2051       192467 :       qlast = p;
    2052              : 
    2053       621963 :       for (q = p->next; q;)
    2054              :         {
    2055       429496 :           if (p->sym != q->sym)
    2056              :             {
    2057       424480 :               qlast = q;
    2058       424480 :               q = q->next;
    2059              :             }
    2060              :           else
    2061              :             {
    2062              :               /* Duplicate interface.  */
    2063         5016 :               qlast->next = q->next;
    2064         5016 :               free (q);
    2065         5016 :               q = qlast->next;
    2066              :             }
    2067              :         }
    2068              :     }
    2069              : 
    2070              :   return false;
    2071              : }
    2072              : 
    2073              : 
    2074              : /* Check lists of interfaces to make sure that no two interfaces are
    2075              :    ambiguous.  Duplicate interfaces (from the same symbol) are OK here.  */
    2076              : 
    2077              : static bool
    2078     17028021 : check_interface1 (gfc_interface *p, gfc_interface *q0,
    2079              :                   int generic_flag, const char *interface_name,
    2080              :                   bool referenced)
    2081              : {
    2082     17028021 :   gfc_interface *q;
    2083     17223661 :   for (; p; p = p->next)
    2084      1214078 :     for (q = q0; q; q = q->next)
    2085              :       {
    2086      1018438 :         if (p->sym == q->sym)
    2087       192429 :           continue;             /* Duplicates OK here.  */
    2088              : 
    2089       826009 :         if (p->sym->name == q->sym->name && p->sym->module == q->sym->module)
    2090          100 :           continue;
    2091              : 
    2092       825909 :         if (!gfc_fl_struct (p->sym->attr.flavor)
    2093       825587 :             && !gfc_fl_struct (q->sym->attr.flavor)
    2094       825269 :             && gfc_compare_interfaces (p->sym, q->sym, q->sym->name,
    2095              :                                        generic_flag, 0, NULL, 0, NULL, NULL))
    2096              :           {
    2097           30 :             if (referenced)
    2098           27 :               gfc_error ("Ambiguous interfaces in %s for %qs at %L "
    2099              :                          "and %qs at %L", interface_name,
    2100           27 :                          q->sym->name, &q->sym->declared_at,
    2101           27 :                          p->sym->name, &p->sym->declared_at);
    2102            3 :             else if (!p->sym->attr.use_assoc && q->sym->attr.use_assoc)
    2103            1 :               gfc_warning (0, "Ambiguous interfaces in %s for %qs at %L "
    2104              :                          "and %qs at %L", interface_name,
    2105              :                          q->sym->name, &q->sym->declared_at,
    2106              :                          p->sym->name, &p->sym->declared_at);
    2107              :             else
    2108            2 :               gfc_warning (0, "Although not referenced, %qs has ambiguous "
    2109              :                            "interfaces at %L", interface_name, &p->where);
    2110           30 :             return true;
    2111              :           }
    2112              :       }
    2113              :   return false;
    2114              : }
    2115              : 
    2116              : 
    2117              : /* Check the generic and operator interfaces of symbols to make sure
    2118              :    that none of the interfaces conflict.  The check has to be done
    2119              :    after all of the symbols are actually loaded.  */
    2120              : 
    2121              : static void
    2122      1883232 : check_sym_interfaces (gfc_symbol *sym)
    2123              : {
    2124              :   /* Provide sufficient space to hold "generic interface 'symbol.symbol'".  */
    2125      1883232 :   char interface_name[2*GFC_MAX_SYMBOL_LEN+2 + sizeof("generic interface ''")];
    2126      1883232 :   gfc_interface *p;
    2127              : 
    2128      1883232 :   if (sym->ns != gfc_current_ns)
    2129        60478 :     return;
    2130              : 
    2131      1822772 :   if (sym->generic != NULL)
    2132              :     {
    2133        78859 :       size_t len = strlen (sym->name) + sizeof("generic interface ''");
    2134        78859 :       gcc_assert (len < sizeof (interface_name));
    2135        78859 :       sprintf (interface_name, "generic interface '%s'", sym->name);
    2136        78859 :       if (check_interface0 (sym->generic, interface_name))
    2137              :         return;
    2138              : 
    2139       267345 :       for (p = sym->generic; p; p = p->next)
    2140              :         {
    2141       188504 :           if (p->sym->attr.mod_proc
    2142         1206 :               && !p->sym->attr.module_procedure
    2143         1200 :               && (p->sym->attr.if_source != IFSRC_DECL
    2144         1196 :                   || p->sym->attr.procedure))
    2145              :             {
    2146            4 :               gfc_error ("%qs at %L is not a module procedure",
    2147              :                          p->sym->name, &p->where);
    2148            4 :               return;
    2149              :             }
    2150              :         }
    2151              : 
    2152              :       /* Originally, this test was applied to host interfaces too;
    2153              :          this is incorrect since host associated symbols, from any
    2154              :          source, cannot be ambiguous with local symbols.  */
    2155        78841 :       check_interface1 (sym->generic, sym->generic, 1, interface_name,
    2156        78841 :                         sym->attr.referenced || !sym->attr.use_assoc);
    2157              :     }
    2158              : }
    2159              : 
    2160              : 
    2161              : static void
    2162          380 : check_uop_interfaces (gfc_user_op *uop)
    2163              : {
    2164          380 :   char interface_name[GFC_MAX_SYMBOL_LEN + sizeof("operator interface ''")];
    2165          380 :   gfc_user_op *uop2;
    2166          380 :   gfc_namespace *ns;
    2167              : 
    2168          380 :   sprintf (interface_name, "operator interface '%s'", uop->name);
    2169          380 :   if (check_interface0 (uop->op, interface_name))
    2170            2 :     return;
    2171              : 
    2172          779 :   for (ns = gfc_current_ns; ns; ns = ns->parent)
    2173              :     {
    2174          401 :       uop2 = gfc_find_uop (uop->name, ns);
    2175          401 :       if (uop2 == NULL)
    2176           16 :         continue;
    2177              : 
    2178          385 :       check_interface1 (uop->op, uop2->op, 0,
    2179              :                         interface_name, true);
    2180              :     }
    2181              : }
    2182              : 
    2183              : /* Given an intrinsic op, return an equivalent op if one exists,
    2184              :    or INTRINSIC_NONE otherwise.  */
    2185              : 
    2186              : gfc_intrinsic_op
    2187     11733856 : gfc_equivalent_op (gfc_intrinsic_op op)
    2188              : {
    2189     11733856 :   switch(op)
    2190              :     {
    2191              :     case INTRINSIC_EQ:
    2192              :       return INTRINSIC_EQ_OS;
    2193              : 
    2194              :     case INTRINSIC_EQ_OS:
    2195              :       return INTRINSIC_EQ;
    2196              : 
    2197              :     case INTRINSIC_NE:
    2198              :       return INTRINSIC_NE_OS;
    2199              : 
    2200              :     case INTRINSIC_NE_OS:
    2201              :       return INTRINSIC_NE;
    2202              : 
    2203              :     case INTRINSIC_GT:
    2204              :       return INTRINSIC_GT_OS;
    2205              : 
    2206              :     case INTRINSIC_GT_OS:
    2207              :       return INTRINSIC_GT;
    2208              : 
    2209              :     case INTRINSIC_GE:
    2210              :       return INTRINSIC_GE_OS;
    2211              : 
    2212              :     case INTRINSIC_GE_OS:
    2213              :       return INTRINSIC_GE;
    2214              : 
    2215              :     case INTRINSIC_LT:
    2216              :       return INTRINSIC_LT_OS;
    2217              : 
    2218              :     case INTRINSIC_LT_OS:
    2219              :       return INTRINSIC_LT;
    2220              : 
    2221              :     case INTRINSIC_LE:
    2222              :       return INTRINSIC_LE_OS;
    2223              : 
    2224              :     case INTRINSIC_LE_OS:
    2225              :       return INTRINSIC_LE;
    2226              : 
    2227              :     default:
    2228              :       return INTRINSIC_NONE;
    2229              :     }
    2230              : }
    2231              : 
    2232              : /* For the namespace, check generic, user operator and intrinsic
    2233              :    operator interfaces for consistency and to remove duplicate
    2234              :    interfaces.  We traverse the whole namespace, counting on the fact
    2235              :    that most symbols will not have generic or operator interfaces.  */
    2236              : 
    2237              : void
    2238       345787 : gfc_check_interfaces (gfc_namespace *ns)
    2239              : {
    2240       345787 :   gfc_namespace *old_ns, *ns2;
    2241       345787 :   char interface_name[GFC_MAX_SYMBOL_LEN + sizeof("intrinsic '' operator")];
    2242       345787 :   int i;
    2243              : 
    2244       345787 :   old_ns = gfc_current_ns;
    2245       345787 :   gfc_current_ns = ns;
    2246              : 
    2247       345787 :   gfc_traverse_ns (ns, check_sym_interfaces);
    2248              : 
    2249       345787 :   gfc_traverse_user_op (ns, check_uop_interfaces);
    2250              : 
    2251     10027755 :   for (i = GFC_INTRINSIC_BEGIN; i != GFC_INTRINSIC_END; i++)
    2252              :     {
    2253      9681971 :       if (i == INTRINSIC_USER)
    2254       345784 :         continue;
    2255              : 
    2256      9336187 :       if (i == INTRINSIC_ASSIGN)
    2257       345784 :         strcpy (interface_name, "intrinsic assignment operator");
    2258              :       else
    2259      8990403 :         sprintf (interface_name, "intrinsic '%s' operator",
    2260              :                  gfc_op2string ((gfc_intrinsic_op) i));
    2261              : 
    2262      9336187 :       if (check_interface0 (ns->op[i], interface_name))
    2263            0 :         continue;
    2264              : 
    2265      9336187 :       if (ns->op[i])
    2266         2460 :         gfc_check_operator_interface (ns->op[i]->sym, (gfc_intrinsic_op) i,
    2267              :                                       ns->op[i]->where);
    2268              : 
    2269     21069971 :       for (ns2 = ns; ns2; ns2 = ns2->parent)
    2270              :         {
    2271     11733787 :           gfc_intrinsic_op other_op;
    2272              : 
    2273     11733787 :           if (check_interface1 (ns->op[i], ns2->op[i], 0,
    2274              :                                 interface_name, true))
    2275            3 :             goto done;
    2276              : 
    2277              :           /* i should be gfc_intrinsic_op, but has to be int with this cast
    2278              :              here for stupid C++ compatibility rules.  */
    2279     11733784 :           other_op = gfc_equivalent_op ((gfc_intrinsic_op) i);
    2280     11733784 :           if (other_op != INTRINSIC_NONE
    2281     11733784 :             &&  check_interface1 (ns->op[i], ns2->op[other_op],
    2282              :                                   0, interface_name, true))
    2283            0 :             goto done;
    2284              :         }
    2285              :     }
    2286              : 
    2287       345784 : done:
    2288       345787 :   gfc_current_ns = old_ns;
    2289       345787 : }
    2290              : 
    2291              : 
    2292              : /* Given a symbol of a formal argument list and an expression, if the
    2293              :    formal argument is allocatable, check that the actual argument is
    2294              :    allocatable. Returns true if compatible, zero if not compatible.  */
    2295              : 
    2296              : static bool
    2297       256322 : compare_allocatable (gfc_symbol *formal, gfc_expr *actual)
    2298              : {
    2299       256322 :   if (formal->attr.allocatable
    2300       253223 :       || (formal->ts.type == BT_CLASS && CLASS_DATA (formal)->attr.allocatable))
    2301              :     {
    2302         3973 :       symbol_attribute attr = gfc_expr_attr (actual);
    2303         3973 :       if (actual->ts.type == BT_CLASS && !attr.class_ok)
    2304           23 :         return true;
    2305         3959 :       else if (!attr.allocatable)
    2306              :         return false;
    2307              :     }
    2308              : 
    2309              :   return true;
    2310              : }
    2311              : 
    2312              : 
    2313              : /* Given a symbol of a formal argument list and an expression, if the
    2314              :    formal argument is a pointer, see if the actual argument is a
    2315              :    pointer. Returns nonzero if compatible, zero if not compatible.  */
    2316              : 
    2317              : static int
    2318       256343 : compare_pointer (gfc_symbol *formal, gfc_expr *actual)
    2319              : {
    2320       256343 :   symbol_attribute attr;
    2321              : 
    2322       256343 :   if (formal->attr.pointer
    2323       251541 :       || (formal->ts.type == BT_CLASS && CLASS_DATA (formal)
    2324        14054 :           && CLASS_DATA (formal)->attr.class_pointer))
    2325              :     {
    2326         5742 :       attr = gfc_expr_attr (actual);
    2327              : 
    2328              :       /* Fortran 2008 allows non-pointer actual arguments.  */
    2329         5742 :       if (!attr.pointer && attr.target && formal->attr.intent == INTENT_IN)
    2330              :         return 2;
    2331              : 
    2332         5355 :       if (!attr.pointer)
    2333              :         return 0;
    2334              :     }
    2335              : 
    2336              :   return 1;
    2337              : }
    2338              : 
    2339              : 
    2340              : /* Emit clear error messages for rank mismatch.  */
    2341              : 
    2342              : static void
    2343          153 : argument_rank_mismatch (const char *name, locus *where,
    2344              :                         int rank1, int rank2, locus *where_formal)
    2345              : {
    2346              : 
    2347              :   /* TS 29113, C407b.  */
    2348          153 :   if (where_formal == NULL)
    2349              :     {
    2350          143 :       if (rank2 == -1)
    2351           10 :         gfc_error ("The assumed-rank array at %L requires that the dummy "
    2352              :                    "argument %qs has assumed-rank", where, name);
    2353          133 :       else if (rank1 == 0)
    2354           22 :         gfc_error_opt (0, "Rank mismatch in argument %qs "
    2355              :                        "at %L (scalar and rank-%d)", name, where, rank2);
    2356          111 :       else if (rank2 == 0)
    2357          104 :         gfc_error_opt (0, "Rank mismatch in argument %qs "
    2358              :                        "at %L (rank-%d and scalar)", name, where, rank1);
    2359              :       else
    2360            7 :         gfc_error_opt (0, "Rank mismatch in argument %qs "
    2361              :                        "at %L (rank-%d and rank-%d)", name, where, rank1,
    2362              :                        rank2);
    2363              :     }
    2364              :   else
    2365              :     {
    2366           10 :       if (rank2 == -1)
    2367              :         /* This is an assumed rank-actual passed to a function without
    2368              :            an explicit interface, which is already diagnosed in
    2369              :            gfc_procedure_use.  */
    2370              :         return;
    2371            8 :       if (rank1 == 0)
    2372            6 :         gfc_error_opt (0, "Rank mismatch between actual argument at %L "
    2373              :                        "and actual argument at %L (scalar and rank-%d)",
    2374              :                        where, where_formal, rank2);
    2375            2 :       else if (rank2 == 0)
    2376            2 :         gfc_error_opt (0, "Rank mismatch between actual argument at %L "
    2377              :                        "and actual argument at %L (rank-%d and scalar)",
    2378              :                        where, where_formal, rank1);
    2379              :       else
    2380            0 :         gfc_error_opt (0, "Rank mismatch between actual argument at %L "
    2381              :                        "and actual argument at %L (rank-%d and rank-%d)", where,
    2382              :                        where_formal, rank1, rank2);
    2383              :     }
    2384              : }
    2385              : 
    2386              : 
    2387              : /* Under certain conditions, a scalar actual argument can be passed
    2388              :    to an array dummy argument - see F2018, 15.5.2.4, paragraph 14.
    2389              :    This function returns true for these conditions so that an error
    2390              :    or warning for this can be suppressed later.  Always return false
    2391              :    for expressions with rank > 0.  */
    2392              : 
    2393              : bool
    2394         3063 : maybe_dummy_array_arg (gfc_expr *e)
    2395              : {
    2396         3063 :   gfc_symbol *s;
    2397         3063 :   gfc_ref *ref;
    2398         3063 :   bool array_pointer = false;
    2399         3063 :   bool assumed_shape = false;
    2400         3063 :   bool scalar_ref = true;
    2401              : 
    2402         3063 :   if (e->rank > 0)
    2403              :     return false;
    2404              : 
    2405         3057 :   if (e->ts.type == BT_CHARACTER && e->ts.kind == 1)
    2406              :     return true;
    2407              : 
    2408              :   /* If this comes from a constructor, it has been an array element
    2409              :      originally.  */
    2410              : 
    2411         2908 :   if (e->expr_type == EXPR_CONSTANT)
    2412          687 :     return e->from_constructor;
    2413              : 
    2414         2221 :   if (e->expr_type != EXPR_VARIABLE)
    2415              :     return false;
    2416              : 
    2417         2113 :   s = e->symtree->n.sym;
    2418              : 
    2419         2113 :   if (s->attr.dimension)
    2420              :     {
    2421          235 :       scalar_ref = false;
    2422          235 :       array_pointer = s->attr.pointer;
    2423              :     }
    2424              : 
    2425         2113 :   if (s->as && s->as->type == AS_ASSUMED_SHAPE)
    2426         2113 :     assumed_shape = true;
    2427              : 
    2428         2377 :   for (ref=e->ref; ref; ref=ref->next)
    2429              :     {
    2430          264 :       if (ref->type == REF_COMPONENT)
    2431              :         {
    2432           20 :           symbol_attribute *attr;
    2433           20 :           attr = &ref->u.c.component->attr;
    2434           20 :           if (attr->dimension)
    2435              :             {
    2436            2 :               array_pointer = attr->pointer;
    2437            2 :               assumed_shape = false;
    2438            2 :               scalar_ref = false;
    2439              :             }
    2440              :           else
    2441              :             scalar_ref = true;
    2442              :         }
    2443              :     }
    2444              : 
    2445         2113 :   return !(scalar_ref || array_pointer || assumed_shape);
    2446              : }
    2447              : 
    2448              : /* Given a symbol of a formal argument list and an expression, see if
    2449              :    the two are compatible as arguments.  Returns true if
    2450              :    compatible, false if not compatible.  */
    2451              : 
    2452              : static bool
    2453       363517 : compare_parameter (gfc_symbol *formal, gfc_expr *actual,
    2454              :                    int ranks_must_agree, int is_elemental, locus *where)
    2455              : {
    2456       363517 :   gfc_ref *ref;
    2457       363517 :   bool rank_check, is_pointer;
    2458       363517 :   char err[200];
    2459       363517 :   gfc_component *ppc;
    2460       363517 :   bool codimension = false;
    2461       363517 :   gfc_array_spec *formal_as;
    2462       363517 :   const char *actual_name;
    2463              : 
    2464              :   /* If the formal arg has type BT_VOID, it's to one of the iso_c_binding
    2465              :      procs c_f_pointer or c_f_procpointer, and we need to accept most
    2466              :      pointers the user could give us.  This should allow that.  */
    2467       363517 :   if (formal->ts.type == BT_VOID)
    2468              :     return true;
    2469              : 
    2470       363517 :   if (formal->ts.type == BT_DERIVED
    2471        29868 :       && formal->ts.u.derived && formal->ts.u.derived->ts.is_iso_c
    2472         4406 :       && actual->ts.type == BT_DERIVED
    2473         4396 :       && actual->ts.u.derived && actual->ts.u.derived->ts.is_iso_c)
    2474              :     {
    2475         4396 :       if (formal->ts.u.derived->intmod_sym_id
    2476         4396 :           != actual->ts.u.derived->intmod_sym_id)
    2477              :         return false;
    2478              : 
    2479         4295 :       if (ranks_must_agree
    2480          136 :           && gfc_symbol_rank (formal) != actual->rank
    2481         4355 :           && gfc_symbol_rank (formal) != -1)
    2482              :         {
    2483           42 :           if (where)
    2484            0 :             argument_rank_mismatch (formal->name, &actual->where,
    2485              :                                     gfc_symbol_rank (formal), actual->rank,
    2486              :                                     NULL);
    2487           42 :           return false;
    2488              :         }
    2489         4253 :       return true;
    2490              :     }
    2491              : 
    2492       359121 :   if (formal->ts.type == BT_CLASS && actual->ts.type == BT_DERIVED)
    2493              :     /* Make sure the vtab symbol is present when
    2494              :        the module variables are generated.  */
    2495         7285 :     gfc_find_derived_vtab (actual->ts.u.derived);
    2496              : 
    2497       359121 :   if (actual->ts.type == BT_PROCEDURE)
    2498              :     {
    2499         1972 :       gfc_symbol *act_sym = actual->symtree->n.sym;
    2500              : 
    2501         1972 :       if (formal->attr.flavor != FL_PROCEDURE && !act_sym->ts.interface)
    2502              :         {
    2503            4 :           if (where)
    2504            2 :             gfc_error ("Invalid procedure argument at %L", &actual->where);
    2505            4 :           return false;
    2506              :         }
    2507         1968 :       else if (act_sym->ts.interface
    2508         1968 :                && !gfc_compare_interfaces (formal, act_sym->ts.interface,
    2509              :                                            act_sym->name, 0, 1, err,
    2510              :                                            sizeof(err),NULL, NULL))
    2511              :         {
    2512            1 :           if (where)
    2513              :             {
    2514              :               /* Artificially generated symbol names would only confuse.  */
    2515            1 :               if (formal->attr.artificial)
    2516            0 :                 gfc_error_opt (0, "Interface mismatch in dummy procedure "
    2517              :                                "at %L conflicts with %L: %s", &actual->where,
    2518              :                                &formal->declared_at, err);
    2519              :               else
    2520            1 :                 gfc_error_opt (0, "Interface mismatch in dummy procedure %qs "
    2521              :                                "at %L: %s", formal->name, &actual->where, err);
    2522              :             }
    2523            1 :           return false;
    2524              :         }
    2525              : 
    2526         1967 :       if (!gfc_compare_interfaces (formal, act_sym, act_sym->name, 0, 1, err,
    2527              :                                    sizeof(err), NULL, NULL))
    2528              :         {
    2529           40 :           if (where)
    2530              :             {
    2531           40 :               if (formal->attr.artificial)
    2532            1 :                 gfc_error_opt (0, "Interface mismatch in dummy procedure "
    2533              :                                "at %L conflicts with %L: %s", &actual->where,
    2534              :                                &formal->declared_at, err);
    2535              :               else
    2536           39 :                 gfc_error_opt (0, "Interface mismatch in dummy procedure %qs at "
    2537              :                                "%L: %s", formal->name, &actual->where, err);
    2538              : 
    2539              :             }
    2540           40 :           return false;
    2541              :         }
    2542              : 
    2543              :       /* The actual symbol may disagree with a global symbol.  If so, issue an
    2544              :          error, but only if no previous error has been reported on the formal
    2545              :          argument.  */
    2546         1927 :       actual_name = act_sym->name;
    2547         1927 :       if (!formal->error && actual_name)
    2548              :         {
    2549         1927 :           gfc_gsymbol *gsym;
    2550         1927 :           gsym = gfc_find_gsymbol (gfc_gsym_root, actual_name);
    2551         1927 :           if (gsym != NULL)
    2552              :             {
    2553          180 :               if (gsym->type == GSYM_SUBROUTINE && formal->attr.function)
    2554              :                 {
    2555            1 :                   gfc_error ("Passing global subroutine %qs declared at %L "
    2556              :                              "as function at %L", actual_name, &gsym->where,
    2557              :                              &actual->where);
    2558            1 :                   return false;
    2559              :                 }
    2560          179 :               if (gsym->type == GSYM_FUNCTION && formal->attr.subroutine)
    2561              :                 {
    2562            1 :                   gfc_error ("Passing global function %qs declared at %L "
    2563              :                              "as subroutine at %L", actual_name, &gsym->where,
    2564              :                              &actual->where);
    2565            1 :                   return false;
    2566              :                 }
    2567          178 :               if (gsym->type == GSYM_FUNCTION)
    2568              :                 {
    2569           99 :                   gfc_symbol *global_asym;
    2570           99 :                   gfc_find_symbol (actual_name, gsym->ns, 0, &global_asym);
    2571           99 :                   if (global_asym != NULL)
    2572              :                     {
    2573           99 :                       if (formal->attr.subroutine)
    2574              :                         {
    2575            0 :                           gfc_error ("Mismatch between subroutine and "
    2576              :                                      "function at %L", &actual->where);
    2577            1 :                           return false;
    2578              :                         }
    2579           99 :                       else if (formal->attr.function)
    2580              :                         {
    2581           98 :                           gfc_typespec ts;
    2582              : 
    2583           98 :                           if (global_asym->result)
    2584           97 :                             ts = global_asym->result->ts;
    2585              :                           else
    2586            1 :                             ts = global_asym->ts;
    2587              : 
    2588           98 :                           if (!gfc_compare_types (&ts,
    2589              :                                                   &formal->ts))
    2590              :                             {
    2591            2 :                               gfc_error ("Type mismatch at %L passing global "
    2592              :                                          "function %qs declared at %L (%s/%s)",
    2593              :                                          &actual->where, actual_name,
    2594              :                                          &gsym->where,
    2595            1 :                                          gfc_typename (&global_asym->ts),
    2596              :                                          gfc_dummy_typename (&formal->ts));
    2597            1 :                               return false;
    2598              :                             }
    2599              :                         }
    2600              :                       else
    2601              :                         {
    2602              :                           /* The global symbol is a function.  Set the formal
    2603              :                              argument acordingly.  */
    2604            1 :                           formal->attr.function = 1;
    2605            1 :                           formal->ts = global_asym->ts;
    2606              :                         }
    2607              :                     }
    2608              :                 }
    2609              :             }
    2610              :         }
    2611              : 
    2612         1924 :       if (formal->attr.function && !act_sym->attr.function)
    2613              :         {
    2614            5 :           gfc_add_function (&act_sym->attr, act_sym->name,
    2615              :           &act_sym->declared_at);
    2616            5 :           if (act_sym->ts.type == BT_UNKNOWN
    2617            5 :               && !gfc_set_default_type (act_sym, 1, act_sym->ns))
    2618              :             return false;
    2619              :         }
    2620         1919 :       else if (formal->attr.subroutine && !act_sym->attr.subroutine)
    2621           50 :         gfc_add_subroutine (&act_sym->attr, act_sym->name,
    2622              :                             &act_sym->declared_at);
    2623              : 
    2624         1924 :       return true;
    2625              :     }
    2626       357149 :   ppc = gfc_get_proc_ptr_comp (actual);
    2627       357149 :   if (ppc && ppc->ts.interface)
    2628              :     {
    2629          495 :       if (!gfc_compare_interfaces (formal, ppc->ts.interface, ppc->name, 0, 1,
    2630              :                                    err, sizeof(err), NULL, NULL))
    2631              :         {
    2632            2 :           if (where)
    2633            2 :             gfc_error_opt (0, "Interface mismatch in dummy procedure %qs at %L:"
    2634              :                            " %s", formal->name, &actual->where, err);
    2635            2 :           return false;
    2636              :         }
    2637              :     }
    2638              : 
    2639              :   /* F2008, C1241.  */
    2640         5317 :   if (formal->attr.pointer && formal->attr.contiguous
    2641       357182 :       && !gfc_is_simply_contiguous (actual, true, false))
    2642              :     {
    2643            4 :       if (where)
    2644            4 :         gfc_error ("Actual argument to contiguous pointer dummy %qs at %L "
    2645              :                    "must be simply contiguous", formal->name, &actual->where);
    2646            4 :       return false;
    2647              :     }
    2648              : 
    2649       357143 :   symbol_attribute actual_attr = gfc_expr_attr (actual);
    2650       357143 :   if (actual->ts.type == BT_CLASS && !actual_attr.class_ok)
    2651              :     return true;
    2652              : 
    2653          807 :   if ((actual->expr_type != EXPR_NULL || actual->ts.type != BT_UNKNOWN)
    2654       356828 :       && actual->ts.type != BT_HOLLERITH
    2655       356809 :       && formal->ts.type != BT_ASSUMED
    2656       353342 :       && !(formal->attr.ext_attr & (1 << EXT_ATTR_NO_ARG_CHECK))
    2657       353342 :       && !gfc_compare_types (&formal->ts, &actual->ts)
    2658       462843 :       && !(formal->ts.type == BT_DERIVED && actual->ts.type == BT_CLASS
    2659            2 :            && gfc_compare_derived_types (formal->ts.u.derived,
    2660            2 :                                          CLASS_DATA (actual)->ts.u.derived)))
    2661              :     {
    2662       105755 :       if (where)
    2663              :         {
    2664           68 :           if (formal->attr.artificial)
    2665              :             {
    2666           19 :               if (!flag_allow_argument_mismatch || !formal->error)
    2667           14 :                 gfc_error_opt (0, "Type mismatch between actual argument at %L "
    2668              :                                "and actual argument at %L (%s/%s).",
    2669              :                                &actual->where,
    2670              :                                &formal->declared_at,
    2671              :                                gfc_typename (actual),
    2672              :                                gfc_dummy_typename (&formal->ts));
    2673              : 
    2674           19 :               formal->error = 1;
    2675              :             }
    2676              :           else
    2677           49 :             gfc_error_opt (0, "Type mismatch in argument %qs at %L; passed %s "
    2678              :                            "to %s", formal->name, where, gfc_typename (actual),
    2679              :                            gfc_dummy_typename (&formal->ts));
    2680              :         }
    2681       105755 :       return false;
    2682              :     }
    2683              : 
    2684       251331 :   if (actual->ts.type == BT_ASSUMED && formal->ts.type != BT_ASSUMED)
    2685              :     {
    2686            3 :       if (where)
    2687            1 :         gfc_error ("Assumed-type actual argument at %L requires that dummy "
    2688              :                    "argument %qs is of assumed type", &actual->where,
    2689              :                    formal->name);
    2690            3 :       return false;
    2691              :     }
    2692              : 
    2693              :   /* TS29113 C407c; F2018 C711.  */
    2694       251328 :   if (actual->ts.type == BT_ASSUMED
    2695          326 :       && gfc_symbol_rank (formal) == -1
    2696           27 :       && actual->rank != -1
    2697       251335 :       && !(actual->symtree->n.sym->as
    2698            5 :            && actual->symtree->n.sym->as->type == AS_ASSUMED_SHAPE))
    2699              :     {
    2700            4 :       if (where)
    2701            4 :         gfc_error ("Assumed-type actual argument at %L corresponding to "
    2702              :                    "assumed-rank dummy argument %qs must be "
    2703              :                    "assumed-shape or assumed-rank",
    2704              :                    &actual->where, formal->name);
    2705            4 :       return false;
    2706              :     }
    2707              : 
    2708              :   /* F2008, 12.5.2.5; IR F08/0073.  */
    2709       251324 :   if (formal->ts.type == BT_CLASS && formal->attr.class_ok
    2710        14048 :       && actual->expr_type != EXPR_NULL
    2711        14048 :       && ((CLASS_DATA (formal)->attr.class_pointer
    2712          917 :            && formal->attr.intent != INTENT_IN)
    2713        13796 :           || CLASS_DATA (formal)->attr.allocatable))
    2714              :     {
    2715         1114 :       if (actual->ts.type != BT_CLASS)
    2716              :         {
    2717            2 :           if (where)
    2718            2 :             gfc_error ("Actual argument to %qs at %L must be polymorphic",
    2719              :                         formal->name, &actual->where);
    2720            2 :           return false;
    2721              :         }
    2722              : 
    2723         1112 :       if ((!UNLIMITED_POLY (formal) || !UNLIMITED_POLY(actual))
    2724          769 :           && !gfc_compare_derived_types (CLASS_DATA (actual)->ts.u.derived,
    2725          769 :                                          CLASS_DATA (formal)->ts.u.derived))
    2726              :         {
    2727            1 :           if (where)
    2728            1 :             gfc_error ("Actual argument to %qs at %L must have the same "
    2729              :                        "declared type", formal->name, &actual->where);
    2730            1 :           return false;
    2731              :         }
    2732              :     }
    2733              : 
    2734              :   /* F08: 12.5.2.5 Allocatable and pointer dummy variables.  However, this
    2735              :      is necessary also for F03, so retain error for both.
    2736              :      NOTE: Other type/kind errors pre-empt this error.  Since they are F03
    2737              :      compatible, no attempt has been made to channel to this one.  */
    2738       251321 :   if (UNLIMITED_POLY (formal) && !UNLIMITED_POLY (actual)
    2739         1616 :       && (CLASS_DATA (formal)->attr.allocatable
    2740         1616 :           ||CLASS_DATA (formal)->attr.class_pointer))
    2741              :     {
    2742            0 :       if (where)
    2743            0 :         gfc_error ("Actual argument to %qs at %L must be unlimited "
    2744              :                    "polymorphic since the formal argument is a "
    2745              :                    "pointer or allocatable unlimited polymorphic "
    2746              :                    "entity [F2008: 12.5.2.5]", formal->name,
    2747              :                    &actual->where);
    2748            0 :       return false;
    2749              :     }
    2750              : 
    2751       251321 :   if (formal->ts.type == BT_CLASS && formal->attr.class_ok)
    2752        14045 :     codimension = CLASS_DATA (formal)->attr.codimension;
    2753              :   else
    2754       237276 :     codimension = formal->attr.codimension;
    2755              : 
    2756       251321 :   if (codimension && !gfc_is_coarray (actual))
    2757              :     {
    2758            4 :       if (where)
    2759            4 :         gfc_error ("Actual argument to %qs at %L must be a coarray",
    2760              :                        formal->name, &actual->where);
    2761            4 :       return false;
    2762              :     }
    2763              : 
    2764       237273 :   formal_as = (formal->ts.type == BT_CLASS
    2765       251317 :                ? CLASS_DATA (formal)->as : formal->as);
    2766              : 
    2767       251317 :   if (codimension && formal->attr.allocatable)
    2768              :     {
    2769           27 :       gfc_ref *last = NULL;
    2770              : 
    2771           54 :       for (ref = actual->ref; ref; ref = ref->next)
    2772           27 :         if (ref->type == REF_COMPONENT)
    2773            0 :           last = ref;
    2774              : 
    2775              :       /* F2008, 12.5.2.6.  */
    2776           27 :       if ((last && last->u.c.component->as->corank != formal->as->corank)
    2777              :           || (!last
    2778           27 :               && actual->symtree->n.sym->as->corank != formal->as->corank))
    2779              :         {
    2780            1 :           if (where)
    2781            1 :             gfc_error ("Corank mismatch in argument %qs at %L (%d and %d)",
    2782            1 :                    formal->name, &actual->where, formal->as->corank,
    2783            0 :                    last ? last->u.c.component->as->corank
    2784            1 :                         : actual->symtree->n.sym->as->corank);
    2785            1 :           return false;
    2786              :         }
    2787              :     }
    2788              : 
    2789          417 :   if (codimension)
    2790              :     {
    2791              :       /* F2008, 12.5.2.8 + Corrig 2 (IR F08/0048).  */
    2792              :       /* F2018, 12.5.2.8.  */
    2793          417 :       if (formal->attr.dimension
    2794          162 :           && (formal->attr.contiguous || formal->as->type != AS_ASSUMED_SHAPE)
    2795          103 :           && actual_attr.dimension
    2796          519 :           && !gfc_is_simply_contiguous (actual, true, true))
    2797              :         {
    2798            2 :           if (where)
    2799            2 :             gfc_error ("Actual argument to %qs at %L must be simply "
    2800              :                        "contiguous or an element of such an array",
    2801              :                        formal->name, &actual->where);
    2802            2 :           return false;
    2803              :         }
    2804              : 
    2805              :       /* F2008, C1303 and C1304.  */
    2806          415 :       if (formal->attr.intent != INTENT_INOUT
    2807          406 :           && (((formal->ts.type == BT_DERIVED || formal->ts.type == BT_CLASS)
    2808          203 :                && formal->ts.u.derived->from_intmod == INTMOD_ISO_FORTRAN_ENV
    2809            1 :                && formal->ts.u.derived->intmod_sym_id == ISOFORTRAN_LOCK_TYPE)
    2810          405 :               || formal->attr.lock_comp))
    2811              : 
    2812              :         {
    2813            1 :           if (where)
    2814            1 :             gfc_error ("Actual argument to non-INTENT(INOUT) dummy %qs at %L, "
    2815              :                        "which is LOCK_TYPE or has a LOCK_TYPE component",
    2816              :                        formal->name, &actual->where);
    2817            1 :           return false;
    2818              :         }
    2819              : 
    2820              :       /* TS18508, C702/C703.  */
    2821          414 :       if (formal->attr.intent != INTENT_INOUT
    2822          405 :           && (((formal->ts.type == BT_DERIVED || formal->ts.type == BT_CLASS)
    2823          202 :                && formal->ts.u.derived->from_intmod == INTMOD_ISO_FORTRAN_ENV
    2824            0 :                && formal->ts.u.derived->intmod_sym_id == ISOFORTRAN_EVENT_TYPE)
    2825          405 :               || formal->attr.event_comp))
    2826              : 
    2827              :         {
    2828            0 :           if (where)
    2829            0 :             gfc_error ("Actual argument to non-INTENT(INOUT) dummy %qs at %L, "
    2830              :                        "which is EVENT_TYPE or has a EVENT_TYPE component",
    2831              :                        formal->name, &actual->where);
    2832            0 :           return false;
    2833              :         }
    2834              :     }
    2835              : 
    2836              :   /* F2008, C1239/C1240.  */
    2837       251313 :   if (actual->expr_type == EXPR_VARIABLE
    2838       103529 :       && (actual->symtree->n.sym->attr.asynchronous
    2839       103492 :          || actual->symtree->n.sym->attr.volatile_)
    2840         3284 :       &&  (formal->attr.asynchronous || formal->attr.volatile_)
    2841           75 :       && actual->rank && formal->as
    2842           70 :       && !gfc_is_simply_contiguous (actual, true, false)
    2843       251361 :       && ((formal->as->type != AS_ASSUMED_SHAPE
    2844           19 :            && formal->as->type != AS_ASSUMED_RANK && !formal->attr.pointer)
    2845           37 :           || formal->attr.contiguous))
    2846              :     {
    2847           22 :       if (where)
    2848           22 :         gfc_error ("Dummy argument %qs has to be a pointer, assumed-shape or "
    2849              :                    "assumed-rank array without CONTIGUOUS attribute - as actual"
    2850              :                    " argument at %L is not simply contiguous and both are "
    2851              :                    "ASYNCHRONOUS or VOLATILE", formal->name, &actual->where);
    2852           22 :       return false;
    2853              :     }
    2854              : 
    2855       251291 :   if (formal->attr.allocatable && !codimension
    2856         3183 :       && actual_attr.codimension)
    2857              :     {
    2858            5 :       if (formal->attr.intent == INTENT_OUT)
    2859              :         {
    2860            1 :           if (where)
    2861            1 :             gfc_error ("Passing coarray at %L to allocatable, noncoarray, "
    2862              :                        "INTENT(OUT) dummy argument %qs", &actual->where,
    2863              :                        formal->name);
    2864            1 :           return false;
    2865              :         }
    2866            4 :       else if (warn_surprising && where && formal->attr.intent != INTENT_IN)
    2867            1 :         gfc_warning (OPT_Wsurprising,
    2868              :                      "Passing coarray at %L to allocatable, noncoarray dummy "
    2869              :                      "argument %qs, which is invalid if the allocation status"
    2870              :                      " is modified",  &actual->where, formal->name);
    2871              :     }
    2872              : 
    2873              :   /* If the rank is the same or the formal argument has assumed-rank.  */
    2874       251290 :   if (gfc_symbol_rank (formal) == actual->rank || gfc_symbol_rank (formal) == -1)
    2875       243189 :     return true;
    2876              : 
    2877         1818 :   rank_check = where != NULL && !is_elemental && formal_as
    2878         1785 :     && (formal_as->type == AS_ASSUMED_SHAPE
    2879         1785 :         || formal_as->type == AS_DEFERRED)
    2880         8252 :     && !(actual->expr_type == EXPR_NULL
    2881           86 :          && actual->ts.type == BT_UNKNOWN);
    2882              : 
    2883              :   /* Skip rank checks for NO_ARG_CHECK.  */
    2884         8101 :   if (formal->attr.ext_attr & (1 << EXT_ATTR_NO_ARG_CHECK))
    2885              :     return true;
    2886              : 
    2887              :   /* Scalar & coindexed, see: F2008, Section 12.5.2.4.  */
    2888         7763 :   if (rank_check || ranks_must_agree
    2889         7605 :       || (formal->attr.pointer && actual->expr_type != EXPR_NULL)
    2890         7605 :       || (actual->rank != 0
    2891         6814 :           && !(is_elemental || formal->attr.dimension
    2892          118 :                || (formal->ts.type == BT_CLASS
    2893           85 :                    && CLASS_DATA (formal)->attr.dimension)))
    2894         7572 :       || (actual->rank == 0
    2895          791 :           && ((formal->ts.type == BT_CLASS
    2896            1 :                && CLASS_DATA (formal)->as->type == AS_ASSUMED_SHAPE)
    2897          791 :               || (formal->ts.type != BT_CLASS
    2898          790 :                    && formal->as->type == AS_ASSUMED_SHAPE))
    2899           13 :           && actual->expr_type != EXPR_NULL)
    2900         7572 :       || (actual->rank == 0
    2901          791 :           && (formal->attr.dimension
    2902            1 :               || (formal->ts.type == BT_CLASS
    2903            1 :                   && CLASS_DATA (formal)->attr.dimension))
    2904          791 :           && gfc_is_coindexed (actual))
    2905              :       /* Assumed-rank actual argument; F2018 C838.  */
    2906        15332 :       || actual->rank == -1)
    2907              :     {
    2908          199 :       if (where
    2909          199 :           && (!formal->attr.artificial || (!formal->maybe_array
    2910            8 :                                            && !maybe_dummy_array_arg (actual))))
    2911              :         {
    2912          104 :           locus *where_formal;
    2913          104 :           if (formal->attr.artificial)
    2914            8 :             where_formal = &formal->declared_at;
    2915              :           else
    2916              :             where_formal = NULL;
    2917              : 
    2918          104 :           argument_rank_mismatch (formal->name, &actual->where,
    2919              :                                   gfc_symbol_rank (formal), actual->rank,
    2920              :                                   where_formal);
    2921              :         }
    2922          199 :       return false;
    2923              :     }
    2924         7564 :   else if (actual->rank != 0
    2925         6776 :            && (is_elemental || formal->attr.dimension
    2926           85 :                || (formal->ts.type == BT_CLASS
    2927           85 :                    && CLASS_DATA (formal)->attr.dimension)))
    2928              :     return true;
    2929              : 
    2930              :   /* At this point, we are considering a scalar passed to an array.   This
    2931              :      is valid (cf. F95 12.4.1.1, F2003 12.4.1.2, and F2008 12.5.2.4),
    2932              :      - if the actual argument is (a substring of) an element of a
    2933              :        non-assumed-shape/non-pointer/non-polymorphic array; or
    2934              :      - (F2003) if the actual argument is of type character of default/c_char
    2935              :        kind.
    2936              :      - (F2018) if the dummy argument is type(*).  */
    2937              : 
    2938         1576 :   is_pointer = actual->expr_type == EXPR_VARIABLE
    2939          788 :                ? actual->symtree->n.sym->attr.pointer : false;
    2940              : 
    2941          811 :   for (ref = actual->ref; ref; ref = ref->next)
    2942              :     {
    2943          439 :       if (ref->type == REF_COMPONENT)
    2944           12 :         is_pointer = ref->u.c.component->attr.pointer;
    2945          427 :       else if (ref->type == REF_ARRAY && ref->u.ar.type == AR_ELEMENT
    2946          420 :                && ref->u.ar.dimen > 0
    2947          417 :                && (!ref->next
    2948            9 :                    || (ref->next->type == REF_SUBSTRING && !ref->next->next)))
    2949              :         break;
    2950              :     }
    2951              : 
    2952          788 :   if (actual->ts.type == BT_CLASS && actual->expr_type != EXPR_NULL)
    2953              :     {
    2954            0 :       if (where)
    2955            0 :         gfc_error ("Polymorphic scalar passed to array dummy argument %qs "
    2956              :                    "at %L", formal->name, &actual->where);
    2957            0 :       return false;
    2958              :     }
    2959              : 
    2960          788 :   if (actual->expr_type != EXPR_NULL && ref && actual->ts.type != BT_CHARACTER
    2961          367 :       && (is_pointer || ref->u.ar.as->type == AS_ASSUMED_SHAPE))
    2962              :     {
    2963           10 :       if (where)
    2964              :         {
    2965           10 :           if (formal->attr.artificial)
    2966            3 :             gfc_error ("Element of assumed-shape or pointer array "
    2967              :                        "as actual argument at %L cannot correspond to "
    2968              :                        "actual argument at %L",
    2969              :                        &actual->where, &formal->declared_at);
    2970              :           else
    2971            7 :             gfc_error ("Element of assumed-shape or pointer "
    2972              :                        "array passed to array dummy argument %qs at %L",
    2973              :                        formal->name, &actual->where);
    2974              :         }
    2975           10 :       return false;
    2976              :     }
    2977              : 
    2978          778 :   if (actual->ts.type == BT_CHARACTER && actual->expr_type != EXPR_NULL
    2979          280 :       && (!ref || is_pointer || ref->u.ar.as->type == AS_ASSUMED_SHAPE))
    2980              :     {
    2981          263 :       if (formal->ts.kind != 1 && (gfc_option.allow_std & GFC_STD_GNU) == 0)
    2982              :         {
    2983            0 :           if (where)
    2984            0 :             gfc_error ("Extension: Scalar non-default-kind, non-C_CHAR-kind "
    2985              :                        "CHARACTER actual argument with array dummy argument "
    2986              :                        "%qs at %L", formal->name, &actual->where);
    2987            0 :           return false;
    2988              :         }
    2989              : 
    2990          263 :       if (where && (gfc_option.allow_std & GFC_STD_F2003) == 0)
    2991              :         {
    2992           50 :           gfc_error ("Fortran 2003: Scalar CHARACTER actual argument with "
    2993              :                      "array dummy argument %qs at %L",
    2994              :                      formal->name, &actual->where);
    2995           50 :           return false;
    2996              :         }
    2997              :       else
    2998          213 :         return ((gfc_option.allow_std & GFC_STD_F2003) != 0);
    2999              :     }
    3000              : 
    3001          498 :   if (ref == NULL && actual->expr_type != EXPR_NULL)
    3002              :     {
    3003           53 :       if (actual->rank == 0
    3004           53 :           && formal->ts.type == BT_ASSUMED
    3005            3 :           && formal->as
    3006            3 :           && formal->as->type == AS_ASSUMED_SIZE)
    3007              :         /* This is new in F2018, type(*) is new in TS29113, but gfortran does
    3008              :            not differentiate.  Thus, if type(*) exists, it is valid;
    3009              :            otherwise, type(*) is already rejected.  */
    3010              :         return true;
    3011           50 :       if (where
    3012           50 :           && (!formal->attr.artificial || (!formal->maybe_array
    3013            3 :                                            && !maybe_dummy_array_arg (actual))))
    3014              :         {
    3015           49 :           locus *where_formal;
    3016           49 :           if (formal->attr.artificial)
    3017            2 :             where_formal = &formal->declared_at;
    3018              :           else
    3019              :             where_formal = NULL;
    3020              : 
    3021           49 :           argument_rank_mismatch (formal->name, &actual->where,
    3022              :                                   gfc_symbol_rank (formal), actual->rank,
    3023              :                                   where_formal);
    3024              :         }
    3025           50 :       return false;
    3026              :     }
    3027              : 
    3028              :   return true;
    3029              : }
    3030              : 
    3031              : 
    3032              : /* Returns the storage size of a symbol (formal argument) or sets argument
    3033              :    size_known to false if it cannot be determined.  */
    3034              : 
    3035              : static unsigned long
    3036       242870 : get_sym_storage_size (gfc_symbol *sym, bool *size_known)
    3037              : {
    3038       242870 :   int i;
    3039       242870 :   unsigned long strlen, elements;
    3040              : 
    3041       242870 :   *size_known = false;
    3042              : 
    3043       242870 :   if (sym->ts.type == BT_CHARACTER)
    3044              :     {
    3045        33591 :       if (sym->ts.u.cl && sym->ts.u.cl->length
    3046         7146 :           && sym->ts.u.cl->length->expr_type == EXPR_CONSTANT
    3047         6159 :           && sym->ts.u.cl->length->ts.type == BT_INTEGER)
    3048         6157 :         strlen = mpz_get_ui (sym->ts.u.cl->length->value.integer);
    3049              :       else
    3050              :         return 0;
    3051              :     }
    3052              :   else
    3053              :     strlen = 1;
    3054              : 
    3055       215436 :   if (gfc_symbol_rank (sym) == 0)
    3056              :     {
    3057       182378 :       *size_known = true;
    3058       182378 :       return strlen;
    3059              :     }
    3060              : 
    3061        33058 :   elements = 1;
    3062        33058 :   if (sym->as->type != AS_EXPLICIT)
    3063              :     return 0;
    3064        14698 :   for (i = 0; i < sym->as->rank; i++)
    3065              :     {
    3066         9682 :       if (sym->as->upper[i]->expr_type != EXPR_CONSTANT
    3067         6518 :           || sym->as->lower[i]->expr_type != EXPR_CONSTANT
    3068         6518 :           || sym->as->upper[i]->ts.type != BT_INTEGER
    3069         6517 :           || sym->as->lower[i]->ts.type != BT_INTEGER)
    3070              :         return 0;
    3071              : 
    3072         6515 :       elements *= mpz_get_si (sym->as->upper[i]->value.integer)
    3073         6515 :                   - mpz_get_si (sym->as->lower[i]->value.integer) + 1L;
    3074              :     }
    3075              : 
    3076         5016 :   *size_known = true;
    3077              : 
    3078         5016 :   return strlen*elements;
    3079              : }
    3080              : 
    3081              : 
    3082              : /* Returns the storage size of an expression (actual argument) or sets argument
    3083              :    size_known to false if it cannot be determined.  For an array element, it
    3084              :    returns the remaining size as the element sequence consists of all storage
    3085              :    units of the actual argument up to the end of the array.  */
    3086              : 
    3087              : static unsigned long
    3088       242870 : get_expr_storage_size (gfc_expr *e, bool *size_known, long int *charlen)
    3089              : {
    3090       242870 :   int i;
    3091       242870 :   long int strlen, elements;
    3092       242870 :   long int substrlen = 0;
    3093       242870 :   bool is_str_storage = false;
    3094       242870 :   gfc_ref *ref;
    3095              : 
    3096       242870 :   *size_known = false;
    3097       242870 :   *charlen = -1;
    3098              : 
    3099       242870 :   if (e == NULL)
    3100              :     return 0;
    3101              : 
    3102       242870 :   if (e->ts.type == BT_CHARACTER)
    3103              :     {
    3104        33984 :       if (e->ts.u.cl && e->ts.u.cl->length
    3105        11550 :           && e->ts.u.cl->length->expr_type == EXPR_CONSTANT
    3106        10741 :           && e->ts.u.cl->length->ts.type == BT_INTEGER)
    3107        10740 :         strlen = mpz_get_si (e->ts.u.cl->length->value.integer);
    3108        23244 :       else if (e->expr_type == EXPR_CONSTANT
    3109        19545 :                && (e->ts.u.cl == NULL || e->ts.u.cl->length == NULL))
    3110        19545 :         strlen = e->value.character.length;
    3111              :       else
    3112              :         return 0;
    3113        30285 :       *charlen = strlen;
    3114              :     }
    3115              :   else
    3116              :     strlen = 1; /* Length per element.  */
    3117              : 
    3118       239171 :   if (e->rank == 0 && !e->ref)
    3119              :     {
    3120       194429 :       *size_known = true;
    3121       194429 :       return strlen;
    3122              :     }
    3123              : 
    3124        44742 :   elements = 1;
    3125        44742 :   if (!e->ref)
    3126              :     {
    3127         6512 :       if (!e->shape)
    3128              :         return 0;
    3129        11841 :       for (i = 0; i < e->rank; i++)
    3130         6411 :         elements *= mpz_get_si (e->shape[i]);
    3131         5430 :       {
    3132         5430 :         *size_known = true;
    3133         5430 :         return elements*strlen;
    3134              :       }
    3135              :     }
    3136              : 
    3137        62779 :   for (ref = e->ref; ref; ref = ref->next)
    3138              :     {
    3139        39724 :       if (ref->type == REF_SUBSTRING && ref->u.ss.start
    3140           64 :           && ref->u.ss.start->expr_type == EXPR_CONSTANT)
    3141              :         {
    3142           58 :           if (is_str_storage)
    3143              :             {
    3144              :               /* The string length is the substring length.
    3145              :                  Set now to full string length.  */
    3146            5 :               if (!ref->u.ss.length || !ref->u.ss.length->length
    3147            4 :                   || ref->u.ss.length->length->expr_type != EXPR_CONSTANT)
    3148              :                 return 0;
    3149              : 
    3150            4 :               strlen = mpz_get_ui (ref->u.ss.length->length->value.integer);
    3151              :             }
    3152           57 :           substrlen = strlen - mpz_get_ui (ref->u.ss.start->value.integer) + 1;
    3153           57 :           continue;
    3154              :         }
    3155              : 
    3156        39666 :       if (ref->type == REF_ARRAY && ref->u.ar.type == AR_SECTION)
    3157        11434 :         for (i = 0; i < ref->u.ar.dimen; i++)
    3158              :           {
    3159         7020 :             long int start, end, stride;
    3160         7020 :             stride = 1;
    3161              : 
    3162         7020 :             if (ref->u.ar.stride[i])
    3163              :               {
    3164         2736 :                 if (ref->u.ar.stride[i]->expr_type == EXPR_CONSTANT
    3165         2573 :                     && ref->u.ar.stride[i]->ts.type == BT_INTEGER)
    3166         2573 :                   stride = mpz_get_si (ref->u.ar.stride[i]->value.integer);
    3167              :                 else
    3168              :                   return 0;
    3169              :               }
    3170              : 
    3171         6857 :             if (ref->u.ar.start[i])
    3172              :               {
    3173         3977 :                 if (ref->u.ar.start[i]->expr_type == EXPR_CONSTANT
    3174         3600 :                     && ref->u.ar.start[i]->ts.type == BT_INTEGER)
    3175         3600 :                   start = mpz_get_si (ref->u.ar.start[i]->value.integer);
    3176              :                 else
    3177              :                   return 0;
    3178              :               }
    3179         2880 :             else if (ref->u.ar.as->lower[i]
    3180         2584 :                      && ref->u.ar.as->lower[i]->expr_type == EXPR_CONSTANT
    3181         2584 :                      && ref->u.ar.as->lower[i]->ts.type == BT_INTEGER)
    3182         2584 :               start = mpz_get_si (ref->u.ar.as->lower[i]->value.integer);
    3183              :             else
    3184              :               return 0;
    3185              : 
    3186         6184 :             if (ref->u.ar.end[i])
    3187              :               {
    3188         4831 :                 if (ref->u.ar.end[i]->expr_type == EXPR_CONSTANT
    3189         4712 :                     && ref->u.ar.end[i]->ts.type == BT_INTEGER)
    3190         4712 :                   end = mpz_get_si (ref->u.ar.end[i]->value.integer);
    3191              :                 else
    3192              :                   return 0;
    3193              :               }
    3194         1353 :             else if (ref->u.ar.as->upper[i]
    3195         1099 :                      && ref->u.ar.as->upper[i]->expr_type == EXPR_CONSTANT
    3196         1065 :                      && ref->u.ar.as->upper[i]->ts.type == BT_INTEGER)
    3197         1064 :               end = mpz_get_si (ref->u.ar.as->upper[i]->value.integer);
    3198              :             else
    3199              :               return 0;
    3200              : 
    3201         5776 :             elements *= (end - start)/stride + 1L;
    3202              :           }
    3203        34008 :       else if (ref->type == REF_ARRAY && ref->u.ar.type == AR_FULL)
    3204        49175 :         for (i = 0; i < ref->u.ar.as->rank; i++)
    3205              :           {
    3206        33112 :             if (ref->u.ar.as->lower[i] && ref->u.ar.as->upper[i]
    3207        23260 :                 && ref->u.ar.as->lower[i]->expr_type == EXPR_CONSTANT
    3208        23211 :                 && ref->u.ar.as->lower[i]->ts.type == BT_INTEGER
    3209        23211 :                 && ref->u.ar.as->upper[i]->expr_type == EXPR_CONSTANT
    3210        21585 :                 && ref->u.ar.as->upper[i]->ts.type == BT_INTEGER)
    3211        21585 :               elements *= mpz_get_si (ref->u.ar.as->upper[i]->value.integer)
    3212        21585 :                           - mpz_get_si (ref->u.ar.as->lower[i]->value.integer)
    3213        21585 :                           + 1L;
    3214              :             else
    3215              :               return 0;
    3216              :           }
    3217         6418 :       else if (ref->type == REF_ARRAY && ref->u.ar.type == AR_ELEMENT
    3218         4035 :                && e->expr_type == EXPR_VARIABLE)
    3219              :         {
    3220         4035 :           if (ref->u.ar.as->type == AS_ASSUMED_SHAPE
    3221         3860 :               || e->symtree->n.sym->attr.pointer)
    3222              :             {
    3223          216 :               elements = 1;
    3224          216 :               continue;
    3225              :             }
    3226              : 
    3227              :           /* Determine the number of remaining elements in the element
    3228              :              sequence for array element designators.  */
    3229         3819 :           is_str_storage = true;
    3230         5334 :           for (i = ref->u.ar.dimen - 1; i >= 0; i--)
    3231              :             {
    3232         3917 :               if (ref->u.ar.start[i] == NULL
    3233         3917 :                   || ref->u.ar.start[i]->expr_type != EXPR_CONSTANT
    3234         2113 :                   || ref->u.ar.as->upper[i] == NULL
    3235         1542 :                   || ref->u.ar.as->lower[i] == NULL
    3236         1542 :                   || ref->u.ar.as->upper[i]->expr_type != EXPR_CONSTANT
    3237         1515 :                   || ref->u.ar.as->lower[i]->expr_type != EXPR_CONSTANT
    3238         1515 :                   || ref->u.ar.as->upper[i]->ts.type != BT_INTEGER
    3239         1515 :                   || ref->u.ar.as->lower[i]->ts.type != BT_INTEGER)
    3240              :                 return 0;
    3241              : 
    3242         1515 :               elements
    3243         1515 :                    = elements
    3244         1515 :                      * (mpz_get_si (ref->u.ar.as->upper[i]->value.integer)
    3245         1515 :                         - mpz_get_si (ref->u.ar.as->lower[i]->value.integer)
    3246         1515 :                         + 1L)
    3247         1515 :                      - (mpz_get_si (ref->u.ar.start[i]->value.integer)
    3248         1515 :                         - mpz_get_si (ref->u.ar.as->lower[i]->value.integer));
    3249              :             }
    3250              :         }
    3251         2383 :       else if (ref->type == REF_COMPONENT && ref->u.c.component->attr.function
    3252           90 :                && ref->u.c.component->attr.proc_pointer
    3253           90 :                && ref->u.c.component->attr.dimension)
    3254              :         {
    3255              :           /* Array-valued procedure-pointer components.  */
    3256            8 :           gfc_array_spec *as = ref->u.c.component->as;
    3257           15 :           for (i = 0; i < as->rank; i++)
    3258              :             {
    3259            8 :               if (!as->upper[i] || !as->lower[i]
    3260            8 :                   || as->upper[i]->expr_type != EXPR_CONSTANT
    3261            7 :                   || as->lower[i]->expr_type != EXPR_CONSTANT
    3262            7 :                   || as->upper[i]->ts.type != BT_INTEGER
    3263            7 :                   || as->lower[i]->ts.type != BT_INTEGER)
    3264              :                 return 0;
    3265              : 
    3266            7 :               elements = elements
    3267            7 :                          * (mpz_get_si (as->upper[i]->value.integer)
    3268            7 :                             - mpz_get_si (as->lower[i]->value.integer) + 1L);
    3269              :             }
    3270              :         }
    3271              :     }
    3272              : 
    3273        23055 :   *size_known = true;
    3274              : 
    3275        23055 :   if (substrlen)
    3276           51 :     return (is_str_storage) ? substrlen + (elements-1)*strlen
    3277           51 :                             : elements*strlen;
    3278              :   else
    3279        23004 :     return elements*strlen;
    3280              : }
    3281              : 
    3282              : 
    3283              : /* Given an expression, check whether it is an array section
    3284              :    which has a vector subscript.  */
    3285              : 
    3286              : bool
    3287        14015 : gfc_has_vector_subscript (gfc_expr *e)
    3288              : {
    3289        14015 :   int i;
    3290        14015 :   gfc_ref *ref;
    3291              : 
    3292        14015 :   if (e == NULL || e->rank == 0 || e->expr_type != EXPR_VARIABLE)
    3293              :     return false;
    3294              : 
    3295        13336 :   for (ref = e->ref; ref; ref = ref->next)
    3296         7713 :     if (ref->type == REF_ARRAY && ref->u.ar.type == AR_SECTION)
    3297         1067 :       for (i = 0; i < ref->u.ar.dimen; i++)
    3298          635 :         if (ref->u.ar.dimen_type[i] == DIMEN_VECTOR)
    3299              :           return true;
    3300              : 
    3301              :   return false;
    3302              : }
    3303              : 
    3304              : 
    3305              : static bool
    3306           27 : is_procptr_result (gfc_expr *expr)
    3307              : {
    3308           27 :   gfc_component *c = gfc_get_proc_ptr_comp (expr);
    3309           27 :   if (c)
    3310            2 :     return (c->ts.interface && (c->ts.interface->attr.proc_pointer == 1));
    3311              :   else
    3312           26 :     return ((expr->symtree->n.sym->result != expr->symtree->n.sym)
    3313           28 :             && (expr->symtree->n.sym->result->attr.proc_pointer == 1));
    3314              : }
    3315              : 
    3316              : 
    3317              : /* Recursively append candidate argument ARG to CANDIDATES.  Store the
    3318              :    number of total candidates in CANDIDATES_LEN.  */
    3319              : 
    3320              : static void
    3321            1 : lookup_arg_fuzzy_find_candidates (gfc_formal_arglist *arg,
    3322              :                                   char **&candidates,
    3323              :                                   size_t &candidates_len)
    3324              : {
    3325            2 :   for (gfc_formal_arglist *p = arg; p && p->sym; p = p->next)
    3326            1 :     vec_push (candidates, candidates_len, p->sym->name);
    3327            1 : }
    3328              : 
    3329              : 
    3330              : /* Lookup argument ARG fuzzily, taking names in ARGUMENTS into account.  */
    3331              : 
    3332              : static const char*
    3333            1 : lookup_arg_fuzzy (const char *arg, gfc_formal_arglist *arguments)
    3334              : {
    3335            1 :   char **candidates = NULL;
    3336            1 :   size_t candidates_len = 0;
    3337            1 :   lookup_arg_fuzzy_find_candidates (arguments, candidates, candidates_len);
    3338            1 :   return gfc_closest_fuzzy_match (arg, candidates);
    3339              : }
    3340              : 
    3341              : 
    3342              : static gfc_dummy_arg *
    3343       369112 : get_nonintrinsic_dummy_arg (gfc_formal_arglist *formal)
    3344              : {
    3345            0 :   gfc_dummy_arg * const dummy_arg = gfc_get_dummy_arg ();
    3346              : 
    3347       369112 :   dummy_arg->intrinsicness = GFC_NON_INTRINSIC_DUMMY_ARG;
    3348       369112 :   dummy_arg->u.non_intrinsic = formal;
    3349              : 
    3350       369112 :   return dummy_arg;
    3351              : }
    3352              : 
    3353              : 
    3354              : /* Given formal and actual argument lists, see if they are compatible.
    3355              :    If they are compatible, the actual argument list is sorted to
    3356              :    correspond with the formal list, and elements for missing optional
    3357              :    arguments are inserted. If WHERE pointer is nonnull, then we issue
    3358              :    errors when things don't match instead of just returning the status
    3359              :    code.  */
    3360              : 
    3361              : bool
    3362       195401 : gfc_compare_actual_formal (gfc_actual_arglist **ap, gfc_formal_arglist *formal,
    3363              :                            int ranks_must_agree, int is_elemental,
    3364              :                            bool in_statement_function, locus *where)
    3365              : {
    3366       195401 :   gfc_actual_arglist **new_arg, *a, *actual;
    3367       195401 :   gfc_formal_arglist *f;
    3368       195401 :   int i, n, na;
    3369       195401 :   unsigned long actual_size, formal_size;
    3370       195401 :   long int charlen;
    3371       195401 :   bool full_array = false;
    3372       195401 :   gfc_array_ref *actual_arr_ref;
    3373       195401 :   gfc_array_spec *fas, *aas;
    3374       195401 :   bool pointer_dummy, pointer_arg, allocatable_arg;
    3375       195401 :   bool procptr_dummy, optional_dummy, allocatable_dummy;
    3376       195401 :   bool actual_size_known = false;
    3377       195401 :   bool formal_size_known = false;
    3378       195401 :   bool ok = true;
    3379              : 
    3380       195401 :   actual = *ap;
    3381              : 
    3382       195401 :   if (actual == NULL && formal == NULL)
    3383              :     return true;
    3384              : 
    3385              :   n = 0;
    3386       547267 :   for (f = formal; f; f = f->next)
    3387       369525 :     n++;
    3388              : 
    3389       177742 :   new_arg = XALLOCAVEC (gfc_actual_arglist *, n);
    3390              : 
    3391       547267 :   for (i = 0; i < n; i++)
    3392       369525 :     new_arg[i] = NULL;
    3393              : 
    3394              :   na = 0;
    3395              :   f = formal;
    3396              :   i = 0;
    3397              : 
    3398       541482 :   for (a = actual; a; a = a->next, f = f->next)
    3399              :     {
    3400       364931 :       if (a->name != NULL && in_statement_function)
    3401              :         {
    3402            1 :           gfc_error ("Keyword argument %qs at %L is invalid in "
    3403            1 :                      "a statement function", a->name, &a->expr->where);
    3404            1 :           return false;
    3405              :         }
    3406              : 
    3407              :       /* Look for keywords but ignore g77 extensions like %VAL.  */
    3408       364930 :       if (a->name != NULL && a->name[0] != '%')
    3409              :         {
    3410              :           i = 0;
    3411        12197 :           for (f = formal; f; f = f->next, i++)
    3412              :             {
    3413        12167 :               if (f->sym == NULL)
    3414            0 :                 continue;
    3415        12167 :               if (strcmp (f->sym->name, a->name) == 0)
    3416              :                 break;
    3417              :             }
    3418              : 
    3419         3518 :           if (f == NULL)
    3420              :             {
    3421           30 :               if (where)
    3422              :                 {
    3423            1 :                   const char *guessed = lookup_arg_fuzzy (a->name, formal);
    3424            1 :                   if (guessed)
    3425            1 :                     gfc_error ("Keyword argument %qs at %L is not in "
    3426              :                                "the procedure; did you mean %qs?",
    3427            1 :                                a->name, &a->expr->where, guessed);
    3428              :                   else
    3429            0 :                     gfc_error ("Keyword argument %qs at %L is not in "
    3430            0 :                                "the procedure", a->name, &a->expr->where);
    3431              :                 }
    3432           30 :               return false;
    3433              :             }
    3434              : 
    3435         3518 :           if (new_arg[i] != NULL)
    3436              :             {
    3437            0 :               if (where)
    3438            0 :                 gfc_error ("Keyword argument %qs at %L is already associated "
    3439              :                            "with another actual argument", a->name,
    3440            0 :                            &a->expr->where);
    3441            0 :               return false;
    3442              :             }
    3443              :         }
    3444              : 
    3445       364900 :       if (f == NULL)
    3446              :         {
    3447         1152 :           if (where)
    3448            8 :             gfc_error ("More actual than formal arguments in procedure "
    3449              :                        "call at %L", where);
    3450         1152 :           return false;
    3451              :         }
    3452              : 
    3453       363748 :       if (f->sym == NULL && a->expr == NULL)
    3454          210 :         goto match;
    3455              : 
    3456       363538 :       if (f->sym == NULL)
    3457              :         {
    3458              :           /* These errors have to be issued, otherwise an ICE can occur.
    3459              :              See PR 78865.  */
    3460            6 :           if (where)
    3461            6 :             gfc_error_now ("Missing alternate return specifier in subroutine "
    3462              :                            "call at %L", where);
    3463            6 :           return false;
    3464              :         }
    3465              :       else
    3466              :         {
    3467       363532 :           if (a->associated_dummy)
    3468       124344 :             free (a->associated_dummy);
    3469       363532 :           a->associated_dummy = get_nonintrinsic_dummy_arg (f);
    3470              :         }
    3471              : 
    3472       363532 :       if (a->expr == NULL)
    3473              :         {
    3474            8 :           if (f->sym->attr.optional)
    3475            6 :             continue;
    3476              :           else
    3477              :             {
    3478            2 :               if (where)
    3479            1 :                 gfc_error_now ("Unexpected alternate return specifier in "
    3480              :                                "subroutine call at %L", where);
    3481            2 :               return false;
    3482              :             }
    3483              :         }
    3484              : 
    3485              :       /* Make sure that intrinsic vtables exist for calls to unlimited
    3486              :          polymorphic formal arguments.  */
    3487       363524 :       if (UNLIMITED_POLY (f->sym)
    3488         2849 :           && a->expr->ts.type != BT_DERIVED
    3489              :           && a->expr->ts.type != BT_CLASS
    3490              :           && a->expr->ts.type != BT_ASSUMED)
    3491          929 :         gfc_find_vtab (&a->expr->ts);
    3492              : 
    3493              :       /* Interp J3/22-146:
    3494              :          "If the context of the reference to NULL is an <actual argument>
    3495              :          corresponding to an <assumed-rank> dummy argument, MOLD shall be
    3496              :          present."  */
    3497       363524 :       if (a->expr->expr_type == EXPR_NULL
    3498          826 :           && a->expr->ts.type == BT_UNKNOWN
    3499          264 :           && f->sym->as
    3500           97 :           && f->sym->as->type == AS_ASSUMED_RANK)
    3501              :         {
    3502            1 :           gfc_error ("Intrinsic %<NULL()%> without %<MOLD%> argument at %L "
    3503              :                      "passed to assumed-rank dummy %qs",
    3504              :                      &a->expr->where, f->sym->name);
    3505            1 :           ok = false;
    3506            1 :           goto match;
    3507              :         }
    3508              : 
    3509       363523 :       if (warn_surprising
    3510         1279 :           && a->expr->expr_type == EXPR_VARIABLE
    3511          618 :           && a->expr->symtree->n.sym->as
    3512          263 :           && a->expr->symtree->n.sym->as->type == AS_ASSUMED_SIZE
    3513          153 :           && f->sym->as
    3514          153 :           && f->sym->as->type == AS_ASSUMED_RANK)
    3515            1 :         gfc_warning (0, "The assumed-size dummy %qs is being passed at %L to "
    3516              :                      "an assumed-rank dummy %qs", a->expr->symtree->name,
    3517              :                      &a->expr->where, f->sym->name);
    3518              : 
    3519       363523 :       if (a->expr->expr_type == EXPR_NULL
    3520          825 :           && a->expr->ts.type == BT_UNKNOWN
    3521          263 :           && f->sym->ts.type == BT_CHARACTER
    3522           83 :           && !f->sym->ts.deferred
    3523           46 :           && f->sym->ts.u.cl
    3524           46 :           && f->sym->ts.u.cl->length == NULL)
    3525              :         {
    3526            1 :           gfc_error ("Intrinsic %<NULL()%> without %<MOLD%> argument at %L "
    3527              :                      "passed to assumed-length dummy %qs",
    3528              :                      &a->expr->where, f->sym->name);
    3529            1 :           ok = false;
    3530            1 :           goto match;
    3531              :         }
    3532              : 
    3533              :       /* Allow passing of NULL() as disassociated pointer, procedure
    3534              :          pointer, or unallocated allocatable (F2008+) to a respective dummy
    3535              :          argument.  */
    3536       727044 :       pointer_dummy = ((f->sym->ts.type != BT_CLASS
    3537       348671 :                         && f->sym->attr.pointer)
    3538       706832 :                        || (f->sym->ts.type == BT_CLASS
    3539        14851 :                            && CLASS_DATA (f->sym)->attr.class_pointer));
    3540              : 
    3541       727044 :       procptr_dummy = ((f->sym->ts.type != BT_CLASS
    3542       348671 :                         && f->sym->attr.proc_pointer)
    3543       711988 :                        || (f->sym->ts.type == BT_CLASS
    3544        14851 :                            && CLASS_DATA (f->sym)->attr.proc_pointer));
    3545              : 
    3546       363522 :       optional_dummy = f->sym->attr.optional;
    3547              : 
    3548       727044 :       allocatable_dummy = ((f->sym->ts.type != BT_CLASS
    3549       348671 :                             && f->sym->attr.allocatable)
    3550       708956 :                            || (f->sym->ts.type == BT_CLASS
    3551        14851 :                                && CLASS_DATA (f->sym)->attr.allocatable));
    3552              : 
    3553       363522 :       if (a->expr->expr_type == EXPR_NULL
    3554              :           && !pointer_dummy
    3555          824 :           && !procptr_dummy
    3556          338 :           && !(optional_dummy
    3557          287 :                && (gfc_option.allow_std & GFC_STD_F2008) != 0)
    3558           54 :           && !(allocatable_dummy
    3559           50 :                && (gfc_option.allow_std & GFC_STD_F2008) != 0))
    3560              :         {
    3561            5 :           if (where
    3562            4 :               && (!f->sym->attr.optional
    3563            2 :                   || (f->sym->ts.type != BT_CLASS && f->sym->attr.allocatable)
    3564            1 :                   || (f->sym->ts.type == BT_CLASS
    3565            0 :                          && CLASS_DATA (f->sym)->attr.allocatable)))
    3566            3 :             gfc_error ("Unexpected NULL() intrinsic at %L to dummy %qs",
    3567              :                        where, f->sym->name);
    3568            1 :           else if (where)
    3569            1 :             gfc_error ("Fortran 2008: Null pointer at %L to non-pointer "
    3570              :                        "dummy %qs", where, f->sym->name);
    3571            5 :           ok = false;
    3572            5 :           goto match;
    3573              :         }
    3574              : 
    3575       363517 :       if (!compare_parameter (f->sym, a->expr, ranks_must_agree,
    3576              :                               is_elemental, where))
    3577              :         {
    3578       106302 :           ok = false;
    3579       106302 :           goto match;
    3580              :         }
    3581              : 
    3582              :       /* TS 29113, 6.3p2; F2018 15.5.2.4.  */
    3583       257215 :       if (f->sym->ts.type == BT_ASSUMED
    3584         3473 :           && (a->expr->ts.type == BT_DERIVED
    3585         3029 :               || (a->expr->ts.type == BT_CLASS && CLASS_DATA (a->expr))))
    3586              :         {
    3587          651 :           gfc_symbol *derived = (a->expr->ts.type == BT_DERIVED
    3588              :                                  ? a->expr->ts.u.derived
    3589          207 :                                  : CLASS_DATA (a->expr)->ts.u.derived);
    3590          651 :           gfc_namespace *f2k_derived = derived->f2k_derived;
    3591          651 :           if (derived->attr.pdt_type
    3592          650 :               || (f2k_derived
    3593          585 :                   && (f2k_derived->finalizers || f2k_derived->tb_sym_root)))
    3594              :             {
    3595            5 :               gfc_error ("Actual argument at %L to assumed-type dummy "
    3596              :                          "has type parameters or is of "
    3597              :                          "derived type with type-bound or FINAL procedures",
    3598              :                          &a->expr->where);
    3599            5 :               ok = false;
    3600            5 :               goto match;
    3601              :             }
    3602              :         }
    3603              : 
    3604       257210 :       if (UNLIMITED_POLY (a->expr)
    3605         1207 :           && !(f->sym->ts.type == BT_ASSUMED || UNLIMITED_POLY (f->sym)))
    3606              :         {
    3607            1 :           gfc_error ("Unlimited polymorphic actual argument at %L is not "
    3608              :                      "matched with either an unlimited polymorphic or "
    3609              :                      "assumed type dummy argument", &a->expr->where);
    3610            1 :           ok = false;
    3611            1 :           goto match;
    3612              :         }
    3613              : 
    3614              :       /* Special case for character arguments.  For allocatable, pointer
    3615              :          and assumed-shape dummies, the string length needs to match
    3616              :          exactly.  */
    3617       257209 :       if (a->expr->ts.type == BT_CHARACTER
    3618        34177 :           && a->expr->ts.u.cl && a->expr->ts.u.cl->length
    3619        11690 :           && a->expr->ts.u.cl->length->expr_type == EXPR_CONSTANT
    3620        10881 :           && a->expr->ts.u.cl->length->ts.type == BT_INTEGER
    3621        10880 :           && f->sym->ts.type == BT_CHARACTER && f->sym->ts.u.cl
    3622        10549 :           && f->sym->ts.u.cl->length
    3623         5548 :           && f->sym->ts.u.cl->length->expr_type == EXPR_CONSTANT
    3624         4695 :           && f->sym->ts.u.cl->length->ts.type == BT_INTEGER
    3625         4693 :           && (f->sym->attr.pointer || f->sym->attr.allocatable
    3626         4283 :               || (f->sym->as && f->sym->as->type == AS_ASSUMED_SHAPE))
    3627         1020 :           && (mpz_cmp (a->expr->ts.u.cl->length->value.integer,
    3628         1020 :                        f->sym->ts.u.cl->length->value.integer) != 0))
    3629              :         {
    3630           14 :           long actual_len, formal_len;
    3631           14 :           actual_len = mpz_get_si (a->expr->ts.u.cl->length->value.integer);
    3632           14 :           formal_len = mpz_get_si (f->sym->ts.u.cl->length->value.integer);
    3633              : 
    3634           14 :           if (where && (f->sym->attr.pointer || f->sym->attr.allocatable))
    3635              :             {
    3636              :               /* Emit a warning for -std=legacy and an error otherwise. */
    3637            5 :               if (gfc_option.warn_std == 0)
    3638            4 :                 gfc_warning (0, "Character length mismatch (%ld/%ld) between "
    3639              :                              "actual argument and pointer or allocatable "
    3640              :                              "dummy argument %qs at %L", actual_len, formal_len,
    3641              :                              f->sym->name, &a->expr->where);
    3642              :               else
    3643            1 :                 gfc_error ("Character length mismatch (%ld/%ld) between "
    3644              :                            "actual argument and pointer or allocatable "
    3645              :                            "dummy argument %qs at %L", actual_len, formal_len,
    3646              :                            f->sym->name, &a->expr->where);
    3647              :             }
    3648            9 :           else if (where)
    3649              :             {
    3650              :               /* Emit a warning for -std=legacy and an error otherwise. */
    3651            9 :               if (gfc_option.warn_std == 0)
    3652            0 :                 gfc_warning (0, "Character length mismatch (%ld/%ld) between "
    3653              :                              "actual argument and assumed-shape dummy argument "
    3654              :                              "%qs at %L", actual_len, formal_len,
    3655              :                              f->sym->name, &a->expr->where);
    3656              :               else
    3657            9 :                 gfc_error ("Character length mismatch (%ld/%ld) between "
    3658              :                            "actual argument and assumed-shape dummy argument "
    3659              :                            "%qs at %L", actual_len, formal_len,
    3660              :                            f->sym->name, &a->expr->where);
    3661              : 
    3662              :             }
    3663           14 :           ok = false;
    3664           14 :           goto match;
    3665              :         }
    3666              : 
    3667       257195 :       if ((f->sym->attr.pointer || f->sym->attr.allocatable)
    3668         8429 :           && f->sym->ts.deferred != a->expr->ts.deferred
    3669           38 :           && a->expr->ts.type == BT_CHARACTER)
    3670              :         {
    3671            1 :           if (where)
    3672            1 :             gfc_error ("Actual argument at %L to allocatable or "
    3673              :                        "pointer dummy argument %qs must have a deferred "
    3674              :                        "length type parameter if and only if the dummy has one",
    3675              :                        &a->expr->where, f->sym->name);
    3676            1 :           ok = false;
    3677            1 :           goto match;
    3678              :         }
    3679              : 
    3680       257194 :       if (f->sym->ts.type == BT_CLASS)
    3681        14067 :         goto skip_size_check;
    3682              : 
    3683              :       /* Skip size check for NULL() actual without MOLD argument.  */
    3684       243127 :       if (a->expr->expr_type == EXPR_NULL && a->expr->ts.type == BT_UNKNOWN)
    3685          257 :         goto skip_size_check;
    3686              : 
    3687       242870 :       actual_size = get_expr_storage_size (a->expr, &actual_size_known, &charlen);
    3688       242870 :       formal_size = get_sym_storage_size (f->sym, &formal_size_known);
    3689              : 
    3690              :       /* If the formal is a scalar character variable, use the charlen of the
    3691              :          actual.  */
    3692       242870 :       if (actual_size_known && formal_size_known && charlen >= 0
    3693         4240 :           && a->expr->ts.type == BT_CHARACTER
    3694         4240 :           && f->sym->attr.flavor != FL_PROCEDURE
    3695         4240 :           && !f->sym->attr.dimension)
    3696         3693 :         actual_size = charlen;
    3697              : 
    3698       242870 :       if (actual_size_known && formal_size_known
    3699       182747 :           && actual_size != formal_size
    3700         3898 :           && a->expr->ts.type == BT_CHARACTER
    3701          256 :           && f->sym->attr.flavor != FL_PROCEDURE)
    3702              :         {
    3703              :           /* F2018:15.5.2.4:
    3704              :              (3) "The length type parameter values of a present actual argument
    3705              :              shall agree with the corresponding ones of the dummy argument that
    3706              :              are not assumed, except for the case of the character length
    3707              :              parameter of an actual argument of type character with default
    3708              :              kind or C character kind associated with a dummy argument that is
    3709              :              not assumed-shape or assumed-rank."
    3710              : 
    3711              :              (4) "If a present scalar dummy argument is of type character with
    3712              :              default kind or C character kind, the length len of the dummy
    3713              :              argument shall be less than or equal to the length of the actual
    3714              :              argument.  The dummy argument becomes associated with the leftmost
    3715              :              len characters of the actual argument.  If a present array dummy
    3716              :              argument is of type character with default kind or C character
    3717              :              kind and is not assumed-shape or assumed-rank, it becomes
    3718              :              associated with the leftmost characters of the actual argument
    3719              :              element sequence."
    3720              : 
    3721              :              As an extension we treat kind=4 character similarly to kind=1.  */
    3722              : 
    3723          256 :           if (actual_size > formal_size)
    3724              :             {
    3725          175 :               if (a->expr->ts.type == BT_CHARACTER && where
    3726          175 :                   && (!f->sym->as || f->sym->as->type == AS_EXPLICIT))
    3727          175 :                 gfc_warning (OPT_Wcharacter_truncation,
    3728              :                              "Character length of actual argument longer "
    3729              :                              "than of dummy argument %qs (%lu/%lu) at %L",
    3730              :                              f->sym->name, actual_size, formal_size,
    3731              :                              &a->expr->where);
    3732          175 :               goto skip_size_check;
    3733              :             }
    3734              : 
    3735           81 :           if (a->expr->ts.type == BT_CHARACTER && where && !f->sym->as)
    3736              :             {
    3737              :               /* Emit warning for -std=legacy/gnu and an error otherwise. */
    3738           57 :               if (gfc_notification_std (GFC_STD_LEGACY) == ERROR)
    3739              :                 {
    3740           11 :                   gfc_error ("Character length of actual argument shorter "
    3741              :                              "than of dummy argument %qs (%lu/%lu) at %L",
    3742           11 :                              f->sym->name, actual_size, formal_size,
    3743           11 :                              &a->expr->where);
    3744           11 :                   ok = false;
    3745           11 :                   goto match;
    3746              :                 }
    3747              :               else
    3748           46 :                 gfc_warning (0, "Character length of actual argument shorter "
    3749              :                              "than of dummy argument %qs (%lu/%lu) at %L",
    3750           46 :                              f->sym->name, actual_size, formal_size,
    3751           46 :                              &a->expr->where);
    3752           46 :               goto skip_size_check;
    3753              :             }
    3754              :         }
    3755              : 
    3756       242638 :       if (actual_size_known && formal_size_known
    3757       182515 :           && actual_size < formal_size
    3758           54 :           && f->sym->as
    3759           48 :           && a->expr->ts.type != BT_PROCEDURE
    3760           48 :           && f->sym->attr.flavor != FL_PROCEDURE)
    3761              :         {
    3762           48 :           if (where)
    3763              :             {
    3764              :               /* Emit a warning for -std=legacy and an error otherwise. */
    3765           48 :               if (gfc_option.warn_std == 0)
    3766            0 :                 gfc_warning (0, "Actual argument contains too few "
    3767              :                              "elements for dummy argument %qs (%lu/%lu) "
    3768              :                              "at %L", f->sym->name, actual_size,
    3769              :                              formal_size, &a->expr->where);
    3770              :               else
    3771           48 :                 gfc_error_now ("Actual argument contains too few "
    3772              :                                "elements for dummy argument %qs (%lu/%lu) "
    3773              :                                "at %L", f->sym->name, actual_size,
    3774              :                                formal_size, &a->expr->where);
    3775              :             }
    3776           48 :           ok = false;
    3777           48 :           goto match;
    3778              :         }
    3779              : 
    3780       242590 :      skip_size_check:
    3781              : 
    3782              :       /* Satisfy either: F03:12.4.1.3 by ensuring that a procedure pointer
    3783              :          actual argument is provided for a procedure pointer formal argument;
    3784              :          or: F08:12.5.2.9 (F18:15.5.2.10) by ensuring that the effective
    3785              :          argument shall be an external, internal, module, or dummy procedure.
    3786              :          The interfaces are checked elsewhere.  */
    3787       257135 :       if (f->sym->attr.proc_pointer
    3788       257135 :           && !((a->expr->expr_type == EXPR_VARIABLE
    3789          194 :                 && (a->expr->symtree->n.sym->attr.proc_pointer
    3790           31 :                     || gfc_is_proc_ptr_comp (a->expr)))
    3791           16 :                || (a->expr->ts.type == BT_PROCEDURE
    3792           10 :                    && f->sym->ts.interface)
    3793            6 :                || (a->expr->expr_type == EXPR_FUNCTION
    3794            6 :                    && is_procptr_result (a->expr))))
    3795              :         {
    3796            0 :           if (where)
    3797            0 :             gfc_error ("Expected a procedure pointer for argument %qs at %L",
    3798            0 :                        f->sym->name, &a->expr->where);
    3799            0 :           ok = false;
    3800            0 :           goto match;
    3801              :         }
    3802              : 
    3803              :       /* Satisfy F03:12.4.1.3 by ensuring that a procedure actual argument is
    3804              :          provided for a procedure formal argument.  */
    3805       257135 :       if (f->sym->attr.flavor == FL_PROCEDURE
    3806       257135 :           && !((a->expr->expr_type == EXPR_VARIABLE
    3807         1956 :                 && (a->expr->symtree->n.sym->attr.flavor == FL_PROCEDURE
    3808           32 :                     || a->expr->symtree->n.sym->attr.proc_pointer
    3809           32 :                     || gfc_is_proc_ptr_comp (a->expr)))
    3810           30 :                || (a->expr->expr_type == EXPR_FUNCTION
    3811           21 :                    && is_procptr_result (a->expr))))
    3812              :         {
    3813           12 :           if (where)
    3814            6 :             gfc_error ("Expected a procedure for argument %qs at %L",
    3815            6 :                        f->sym->name, &a->expr->where);
    3816           12 :           ok = false;
    3817           12 :           goto match;
    3818              :         }
    3819              : 
    3820              :       /* Class array variables and expressions store array info in a
    3821              :          different place from non-class objects; consolidate the logic
    3822              :          to access it here instead of repeating it below.  Note that
    3823              :          pointer_arg and allocatable_arg are not fully general and are
    3824              :          only used in a specific situation below with an assumed-rank
    3825              :          argument.  */
    3826       257123 :       if (f->sym->ts.type == BT_CLASS && CLASS_DATA (f->sym))
    3827              :         {
    3828        14067 :           gfc_component *classdata = CLASS_DATA (f->sym);
    3829        14067 :           fas = classdata->as;
    3830        14067 :           pointer_dummy = classdata->attr.class_pointer;
    3831        14067 :         }
    3832              :       else
    3833              :         {
    3834       243056 :           fas = f->sym->as;
    3835       243056 :           pointer_dummy = f->sym->attr.pointer;
    3836              :         }
    3837              : 
    3838       257123 :       if (a->expr->expr_type != EXPR_VARIABLE
    3839       149350 :           && !(a->expr->expr_type == EXPR_NULL
    3840          758 :                && a->expr->ts.type != BT_UNKNOWN))
    3841              :         {
    3842              :           aas = NULL;
    3843              :           pointer_arg = false;
    3844              :           allocatable_arg = false;
    3845              :         }
    3846       108274 :       else if (a->expr->ts.type == BT_CLASS
    3847         6649 :                && a->expr->symtree->n.sym
    3848         6649 :                && CLASS_DATA (a->expr->symtree->n.sym))
    3849              :         {
    3850         6646 :           gfc_component *classdata = CLASS_DATA (a->expr->symtree->n.sym);
    3851         6646 :           aas = classdata->as;
    3852         6646 :           pointer_arg = classdata->attr.class_pointer;
    3853         6646 :           allocatable_arg = classdata->attr.allocatable;
    3854         6646 :         }
    3855              :       else
    3856              :         {
    3857       101628 :           aas = a->expr->symtree->n.sym->as;
    3858       101628 :           pointer_arg = a->expr->symtree->n.sym->attr.pointer;
    3859       101628 :           allocatable_arg = a->expr->symtree->n.sym->attr.allocatable;
    3860              :         }
    3861              : 
    3862              :       /* F2018:9.5.2(2) permits assumed-size whole array expressions as
    3863              :          actual arguments only if the shape is not required; thus it
    3864              :          cannot be passed to an assumed-shape array dummy.
    3865              :          F2018:15.5.2.(2) permits passing a nonpointer actual to an
    3866              :          intent(in) pointer dummy argument and this is accepted by
    3867              :          the compare_pointer check below, but this also requires shape
    3868              :          information.
    3869              :          There's more discussion of this in PR94110.  */
    3870       257123 :       if (fas
    3871        43137 :           && (fas->type == AS_ASSUMED_SHAPE
    3872        43137 :               || fas->type == AS_DEFERRED
    3873        21852 :               || (fas->type == AS_ASSUMED_RANK && pointer_dummy))
    3874        22347 :           && aas
    3875        17736 :           && aas->type == AS_ASSUMED_SIZE
    3876           14 :           && (a->expr->ref == NULL
    3877           14 :               || (a->expr->ref->type == REF_ARRAY
    3878           14 :                   && a->expr->ref->u.ar.type == AR_FULL)))
    3879              :         {
    3880           10 :           if (where)
    3881           10 :             gfc_error ("Actual argument for %qs cannot be an assumed-size"
    3882              :                        " array at %L", f->sym->name, where);
    3883           10 :           ok = false;
    3884           10 :           goto match;
    3885              :         }
    3886              : 
    3887              :       /* Diagnose F2018 C839 (TS29113 C535c).  Here the problem is
    3888              :          passing an assumed-size array to an INTENT(OUT) assumed-rank
    3889              :          dummy when it doesn't have the size information needed to run
    3890              :          initializers and finalizers.  */
    3891       257113 :       if (f->sym->attr.intent == INTENT_OUT
    3892         6650 :           && fas
    3893         1231 :           && fas->type == AS_ASSUMED_RANK
    3894          276 :           && aas
    3895          223 :           && ((aas->type == AS_ASSUMED_SIZE
    3896           61 :                && (a->expr->ref == NULL
    3897           61 :                    || (a->expr->ref->type == REF_ARRAY
    3898           61 :                        && a->expr->ref->u.ar.type == AR_FULL)))
    3899          173 :               || (aas->type == AS_ASSUMED_RANK
    3900              :                   && !pointer_arg
    3901           34 :                   && !allocatable_arg))
    3902       257181 :           && (a->expr->ts.type == BT_CLASS
    3903           62 :               || (a->expr->ts.type == BT_DERIVED
    3904           16 :                   && (gfc_is_finalizable (a->expr->ts.u.derived, NULL)
    3905           14 :                       || gfc_has_ultimate_allocatable (a->expr)
    3906           12 :                       || gfc_has_default_initializer
    3907           12 :                            (a->expr->ts.u.derived)))))
    3908              :         {
    3909           12 :           if (where)
    3910           12 :             gfc_error ("Actual argument to assumed-rank INTENT(OUT) "
    3911              :                        "dummy %qs at %L cannot be of unknown size",
    3912           12 :                        f->sym->name, where);
    3913           12 :           ok = false;
    3914           12 :           goto match;
    3915              :         }
    3916              : 
    3917       257101 :       if (a->expr->expr_type != EXPR_NULL)
    3918              :         {
    3919       256343 :           int cmp = compare_pointer (f->sym, a->expr);
    3920       256343 :           bool pre2008 = ((gfc_option.allow_std & GFC_STD_F2008) == 0);
    3921              : 
    3922       256343 :           if (pre2008 && cmp == 0)
    3923              :             {
    3924            1 :               if (where)
    3925            1 :                 gfc_error ("Actual argument for %qs at %L must be a pointer",
    3926            1 :                            f->sym->name, &a->expr->where);
    3927            1 :               ok = false;
    3928            1 :               goto match;
    3929              :             }
    3930              : 
    3931       256342 :           if (pre2008 && cmp == 2)
    3932              :             {
    3933            3 :               if (where)
    3934            3 :                 gfc_error ("Fortran 2008: Non-pointer actual argument at %L to "
    3935            3 :                            "pointer dummy %qs", &a->expr->where, f->sym->name);
    3936            3 :               ok = false;
    3937            3 :               goto match;
    3938              :             }
    3939              : 
    3940       256339 :           if (!pre2008 && cmp == 0)
    3941              :             {
    3942           11 :               if (where)
    3943            5 :                 gfc_error ("Actual argument for %qs at %L must be a pointer "
    3944              :                            "or a valid target for the dummy pointer in a "
    3945              :                            "pointer assignment statement",
    3946            5 :                            f->sym->name, &a->expr->where);
    3947           11 :               ok = false;
    3948           11 :               goto match;
    3949              :             }
    3950              :         }
    3951              : 
    3952              : 
    3953              :       /* Fortran 2008, C1242.  */
    3954       257086 :       if (f->sym->attr.pointer && gfc_is_coindexed (a->expr))
    3955              :         {
    3956            2 :           if (where)
    3957            2 :             gfc_error ("Coindexed actual argument at %L to pointer "
    3958              :                        "dummy %qs",
    3959            2 :                        &a->expr->where, f->sym->name);
    3960            2 :           ok = false;
    3961            2 :           goto match;
    3962              :         }
    3963              : 
    3964              :       /* Fortran 2008, 12.5.2.5 (no constraint).  */
    3965       257084 :       if (a->expr->expr_type == EXPR_VARIABLE
    3966       107735 :           && f->sym->attr.intent != INTENT_IN
    3967        61762 :           && f->sym->attr.allocatable
    3968       260000 :           && gfc_is_coindexed (a->expr))
    3969              :         {
    3970            1 :           if (where)
    3971            1 :             gfc_error ("Coindexed actual argument at %L to allocatable "
    3972              :                        "dummy %qs requires INTENT(IN)",
    3973            1 :                        &a->expr->where, f->sym->name);
    3974            1 :           ok = false;
    3975            1 :           goto match;
    3976              :         }
    3977              : 
    3978              :       /* Fortran 2008, C1237.  */
    3979       257083 :       if (a->expr->expr_type == EXPR_VARIABLE
    3980       107734 :           && (f->sym->attr.asynchronous || f->sym->attr.volatile_)
    3981           65 :           && gfc_is_coindexed (a->expr)
    3982       257085 :           && (a->expr->symtree->n.sym->attr.volatile_
    3983            1 :               || a->expr->symtree->n.sym->attr.asynchronous))
    3984              :         {
    3985            2 :           if (where)
    3986            2 :             gfc_error ("Coindexed ASYNCHRONOUS or VOLATILE actual argument at "
    3987              :                        "%L requires that dummy %qs has neither "
    3988              :                        "ASYNCHRONOUS nor VOLATILE", &a->expr->where,
    3989            2 :                        f->sym->name);
    3990            2 :           ok = false;
    3991            2 :           goto match;
    3992              :         }
    3993              : 
    3994              :       /* Fortran 2008, 12.5.2.4 (no constraint).  */
    3995       257081 :       if (a->expr->expr_type == EXPR_VARIABLE
    3996       107732 :           && f->sym->attr.intent != INTENT_IN && !f->sym->attr.value
    3997        57327 :           && gfc_is_coindexed (a->expr)
    3998       257092 :           && gfc_has_ultimate_allocatable (a->expr))
    3999              :         {
    4000            1 :           if (where)
    4001            1 :             gfc_error ("Coindexed actual argument at %L with allocatable "
    4002              :                        "ultimate component to dummy %qs requires either VALUE "
    4003            1 :                        "or INTENT(IN)", &a->expr->where, f->sym->name);
    4004            1 :           ok = false;
    4005            1 :           goto match;
    4006              :         }
    4007              : 
    4008       257080 :      if (f->sym->ts.type == BT_CLASS
    4009        14059 :            && CLASS_DATA (f->sym)->attr.allocatable
    4010          874 :            && gfc_is_class_array_ref (a->expr, &full_array)
    4011       257525 :            && !full_array)
    4012              :         {
    4013            0 :           if (where)
    4014            0 :             gfc_error ("Actual CLASS array argument for %qs must be a full "
    4015            0 :                        "array at %L", f->sym->name, &a->expr->where);
    4016            0 :           ok = false;
    4017            0 :           goto match;
    4018              :         }
    4019              : 
    4020              : 
    4021       257080 :       if (a->expr->expr_type != EXPR_NULL
    4022       257080 :           && !compare_allocatable (f->sym, a->expr))
    4023              :         {
    4024            9 :           if (where)
    4025            9 :             gfc_error ("Actual argument for %qs must be ALLOCATABLE at %L",
    4026            9 :                        f->sym->name, &a->expr->where);
    4027            9 :           ok = false;
    4028            9 :           goto match;
    4029              :         }
    4030              : 
    4031       257071 :       if (a->expr->expr_type == EXPR_FUNCTION
    4032        15124 :           && a->expr->value.function.esym
    4033         5027 :           && f->sym->attr.allocatable)
    4034              :         {
    4035            4 :           if (where)
    4036            4 :             gfc_error ("Actual argument for %qs at %L is a function result "
    4037              :                        "and the dummy argument is ALLOCATABLE",
    4038              :                        f->sym->name, &a->expr->where);
    4039            4 :           ok = false;
    4040            4 :           goto match;
    4041              :         }
    4042              : 
    4043              :       /* Check intent = OUT/INOUT for definable actual argument.  */
    4044       257067 :       if (!in_statement_function
    4045       256592 :           && (f->sym->attr.intent == INTENT_OUT
    4046       249956 :               || f->sym->attr.intent == INTENT_INOUT))
    4047              :         {
    4048        10884 :           const char* context = (where
    4049        10884 :                                  ? _("actual argument to INTENT = OUT/INOUT")
    4050              :                                  : NULL);
    4051              : 
    4052         2866 :           if (((f->sym->ts.type == BT_CLASS && f->sym->attr.class_ok
    4053         2866 :                 && CLASS_DATA (f->sym)->attr.class_pointer)
    4054        10864 :                || (f->sym->ts.type != BT_CLASS && f->sym->attr.pointer))
    4055        11074 :               && !gfc_check_vardef_context (a->expr, true, false, false, context))
    4056              :             {
    4057            6 :               ok = false;
    4058            6 :               goto match;
    4059              :             }
    4060        10878 :           if (!gfc_check_vardef_context (a->expr, false, false, false, context))
    4061              :             {
    4062           21 :               ok = false;
    4063           21 :               goto match;
    4064              :             }
    4065              :         }
    4066              : 
    4067              :       /* F2023: 15.5.2.5 Ordinary dummy variables:
    4068              :          "(21) If the procedure is nonelemental, the dummy argument does not
    4069              :          have the VALUE attribute, and the actual argument is an array section
    4070              :          having a vector subscript, the dummy argument is not definable and
    4071              :          shall not have the ASYNCHRONOUS, INTENT (OUT), INTENT (INOUT), or
    4072              :          VOLATILE attributes."
    4073              :        */
    4074       257040 :       if ((f->sym->attr.intent == INTENT_OUT
    4075       250412 :            || f->sym->attr.intent == INTENT_INOUT
    4076       246181 :            || f->sym->attr.volatile_
    4077       246145 :            || f->sym->attr.asynchronous)
    4078        10923 :           && !f->sym->attr.value
    4079        10923 :           && !is_elemental
    4080       264244 :           && gfc_has_vector_subscript (a->expr))
    4081              :         {
    4082            3 :           if (where)
    4083            3 :             gfc_error ("Array-section actual argument with vector "
    4084              :                        "subscripts at %L is incompatible with INTENT(OUT), "
    4085              :                        "INTENT(INOUT), VOLATILE or ASYNCHRONOUS attribute "
    4086              :                        "of the dummy argument %qs",
    4087            3 :                        &a->expr->where, f->sym->name);
    4088            3 :           ok = false;
    4089            3 :           goto match;
    4090              :         }
    4091              : 
    4092              :       /* C1232 (R1221) For an actual argument which is an array section or
    4093              :          an assumed-shape array, the dummy argument shall be an assumed-
    4094              :          shape array, if the dummy argument has the VOLATILE attribute.  */
    4095              : 
    4096       257037 :       if (f->sym->attr.volatile_
    4097           37 :           && a->expr->expr_type == EXPR_VARIABLE
    4098           34 :           && a->expr->symtree->n.sym->as
    4099           29 :           && a->expr->symtree->n.sym->as->type == AS_ASSUMED_SHAPE
    4100            2 :           && !(fas && fas->type == AS_ASSUMED_SHAPE))
    4101              :         {
    4102            1 :           if (where)
    4103            1 :             gfc_error ("Assumed-shape actual argument at %L is "
    4104              :                        "incompatible with the non-assumed-shape "
    4105              :                        "dummy argument %qs due to VOLATILE attribute",
    4106              :                        &a->expr->where,f->sym->name);
    4107            1 :           ok = false;
    4108            1 :           goto match;
    4109              :         }
    4110              : 
    4111              :       /* Find the last array_ref.  */
    4112       257036 :       actual_arr_ref = NULL;
    4113       257036 :       if (a->expr->ref)
    4114        46157 :         actual_arr_ref = gfc_find_array_ref (a->expr, true);
    4115              : 
    4116       257036 :       if (f->sym->attr.volatile_
    4117           36 :           && actual_arr_ref && actual_arr_ref->type == AR_SECTION
    4118            5 :           && !(fas && fas->type == AS_ASSUMED_SHAPE))
    4119              :         {
    4120            1 :           if (where)
    4121            1 :             gfc_error ("Array-section actual argument at %L is "
    4122              :                        "incompatible with the non-assumed-shape "
    4123              :                        "dummy argument %qs due to VOLATILE attribute",
    4124            1 :                        &a->expr->where, f->sym->name);
    4125            1 :           ok = false;
    4126            1 :           goto match;
    4127              :         }
    4128              : 
    4129              :       /* C1233 (R1221) For an actual argument which is a pointer array, the
    4130              :          dummy argument shall be an assumed-shape or pointer array, if the
    4131              :          dummy argument has the VOLATILE attribute.  */
    4132              : 
    4133       257035 :       if (f->sym->attr.volatile_
    4134           35 :           && a->expr->expr_type == EXPR_VARIABLE
    4135           32 :           && a->expr->symtree->n.sym->attr.pointer
    4136           17 :           && a->expr->symtree->n.sym->as
    4137           17 :           && !(fas
    4138           17 :                && (fas->type == AS_ASSUMED_SHAPE
    4139            6 :                    || f->sym->attr.pointer)))
    4140              :         {
    4141            3 :           if (where)
    4142            2 :             gfc_error ("Pointer-array actual argument at %L requires "
    4143              :                        "an assumed-shape or pointer-array dummy "
    4144              :                        "argument %qs due to VOLATILE attribute",
    4145              :                        &a->expr->where,f->sym->name);
    4146            3 :           ok = false;
    4147            3 :           goto match;
    4148              :         }
    4149              : 
    4150              :       /* C_LOC/C_FUNLOC from ISO_C_BINDING as actual argument can only be
    4151              :          passed to a dummy argument of matching type C_PTR/C_FUNPTR.  */
    4152       257032 :       if (a->expr->expr_type == EXPR_FUNCTION
    4153        15117 :           && a->expr->ts.type == BT_VOID
    4154            5 :           && a->expr->symtree->n.sym
    4155            5 :           && a->expr->symtree->n.sym->from_intmod == INTMOD_ISO_C_BINDING
    4156            5 :           && (f->sym->ts.type != BT_DERIVED
    4157            3 :               || f->sym->ts.u.derived->from_intmod != INTMOD_ISO_C_BINDING
    4158            3 :               || !((a->expr->symtree->n.sym->intmod_sym_id == ISOCBINDING_FUNLOC
    4159            1 :                     && f->sym->ts.u.derived->intmod_sym_id == ISOCBINDING_FUNPTR)
    4160              :                    || (a->expr->symtree->n.sym->intmod_sym_id == ISOCBINDING_LOC
    4161            2 :                        && f->sym->ts.u.derived->intmod_sym_id == ISOCBINDING_PTR))))
    4162              :         {
    4163            3 :           if (where)
    4164            0 :             gfc_error ("ISO_C_BINDING function actual argument at %L "
    4165              :                        "requires dummy argument %qs to have a matching "
    4166              :                        "type from ISO_C_BINDING",
    4167              :                        &a->expr->where,f->sym->name);
    4168            3 :           ok = false;
    4169            3 :           goto match;
    4170              :         }
    4171              : 
    4172       257029 :     match:
    4173       363734 :       if (a == actual)
    4174       176386 :         na = i;
    4175              : 
    4176       363734 :       new_arg[i++] = a;
    4177              :     }
    4178              : 
    4179              :   /* Give up now if we saw any bad argument.  */
    4180       176551 :   if (!ok)
    4181              :     return false;
    4182              : 
    4183              :   /* Make sure missing actual arguments are optional.  */
    4184              :   i = 0;
    4185       356741 :   for (f = formal; f; f = f->next, i++)
    4186              :     {
    4187       246276 :       if (new_arg[i] != NULL)
    4188       240608 :         continue;
    4189         5668 :       if (f->sym == NULL)
    4190              :         {
    4191            1 :           if (where)
    4192            1 :             gfc_error ("Missing alternate return spec in subroutine call "
    4193              :                        "at %L", where);
    4194            1 :           return false;
    4195              :         }
    4196              :       /* For CLASS, the optional attribute might be set at either location. */
    4197         5667 :       if (((f->sym->ts.type != BT_CLASS || !CLASS_DATA (f->sym)->attr.optional)
    4198         5667 :            && !f->sym->attr.optional)
    4199         5581 :           || (in_statement_function
    4200            1 :               && (f->sym->attr.optional
    4201            0 :                   || (f->sym->ts.type == BT_CLASS
    4202            0 :                       && CLASS_DATA (f->sym)->attr.optional))))
    4203              :         {
    4204           87 :           if (where)
    4205            4 :             gfc_error ("Missing actual argument for argument %qs at %L",
    4206              :                        f->sym->name, where);
    4207           87 :           return false;
    4208              :         }
    4209              :     }
    4210              : 
    4211              :   /* We should have handled the cases where the formal arglist is null
    4212              :      already.  */
    4213       110465 :   gcc_assert (n > 0);
    4214              : 
    4215              :   /* The argument lists are compatible.  We now relink a new actual
    4216              :      argument list with null arguments in the right places.  The head
    4217              :      of the list remains the head.  */
    4218       356574 :   for (f = formal, i = 0; f; f = f->next, i++)
    4219       246109 :     if (new_arg[i] == NULL)
    4220              :       {
    4221         5580 :         new_arg[i] = gfc_get_actual_arglist ();
    4222         5580 :         new_arg[i]->associated_dummy = get_nonintrinsic_dummy_arg (f);
    4223              :       }
    4224              : 
    4225       110465 :   if (na != 0)
    4226              :     {
    4227          385 :       std::swap (*new_arg[0], *actual);
    4228          385 :       std::swap (new_arg[0], new_arg[na]);
    4229              :     }
    4230              : 
    4231       246109 :   for (i = 0; i < n - 1; i++)
    4232       135644 :     new_arg[i]->next = new_arg[i + 1];
    4233              : 
    4234       110465 :   new_arg[i]->next = NULL;
    4235              : 
    4236       110465 :   if (*ap == NULL && n > 0)
    4237          796 :     *ap = new_arg[0];
    4238              : 
    4239              :   return true;
    4240              : }
    4241              : 
    4242              : 
    4243              : typedef struct
    4244              : {
    4245              :   gfc_formal_arglist *f;
    4246              :   gfc_actual_arglist *a;
    4247              : }
    4248              : argpair;
    4249              : 
    4250              : /* qsort comparison function for argument pairs, with the following
    4251              :    order:
    4252              :     - p->a->expr == NULL
    4253              :     - p->a->expr->expr_type != EXPR_VARIABLE
    4254              :     - by gfc_symbol pointer value (larger first).  */
    4255              : 
    4256              : static int
    4257         2345 : pair_cmp (const void *p1, const void *p2)
    4258              : {
    4259         2345 :   const gfc_actual_arglist *a1, *a2;
    4260              : 
    4261              :   /* *p1 and *p2 are elements of the to-be-sorted array.  */
    4262         2345 :   a1 = ((const argpair *) p1)->a;
    4263         2345 :   a2 = ((const argpair *) p2)->a;
    4264         2345 :   if (!a1->expr)
    4265              :     {
    4266           23 :       if (!a2->expr)
    4267              :         return 0;
    4268           23 :       return -1;
    4269              :     }
    4270         2322 :   if (!a2->expr)
    4271              :     return 1;
    4272         2313 :   if (a1->expr->expr_type != EXPR_VARIABLE)
    4273              :     {
    4274         1658 :       if (a2->expr->expr_type != EXPR_VARIABLE)
    4275              :         return 0;
    4276         1110 :       return -1;
    4277              :     }
    4278          655 :   if (a2->expr->expr_type != EXPR_VARIABLE)
    4279              :     return 1;
    4280          195 :   if (a1->expr->symtree->n.sym > a2->expr->symtree->n.sym)
    4281              :     return -1;
    4282           79 :   return a1->expr->symtree->n.sym < a2->expr->symtree->n.sym;
    4283              : }
    4284              : 
    4285              : 
    4286              : /* Given two expressions from some actual arguments, test whether they
    4287              :    refer to the same expression. The analysis is conservative.
    4288              :    Returning false will produce no warning.  */
    4289              : 
    4290              : static bool
    4291           43 : compare_actual_expr (gfc_expr *e1, gfc_expr *e2)
    4292              : {
    4293           43 :   const gfc_ref *r1, *r2;
    4294              : 
    4295           43 :   if (!e1 || !e2
    4296           43 :       || e1->expr_type != EXPR_VARIABLE
    4297           43 :       || e2->expr_type != EXPR_VARIABLE
    4298           43 :       || e1->symtree->n.sym != e2->symtree->n.sym)
    4299              :     return false;
    4300              : 
    4301              :   /* TODO: improve comparison, see expr.cc:show_ref().  */
    4302            4 :   for (r1 = e1->ref, r2 = e2->ref; r1 && r2; r1 = r1->next, r2 = r2->next)
    4303              :     {
    4304            1 :       if (r1->type != r2->type)
    4305              :         return false;
    4306            1 :       switch (r1->type)
    4307              :         {
    4308            0 :         case REF_ARRAY:
    4309            0 :           if (r1->u.ar.type != r2->u.ar.type)
    4310              :             return false;
    4311              :           /* TODO: At the moment, consider only full arrays;
    4312              :              we could do better.  */
    4313            0 :           if (r1->u.ar.type != AR_FULL || r2->u.ar.type != AR_FULL)
    4314              :             return false;
    4315              :           break;
    4316              : 
    4317            0 :         case REF_COMPONENT:
    4318            0 :           if (r1->u.c.component != r2->u.c.component)
    4319              :             return false;
    4320              :           break;
    4321              : 
    4322              :         case REF_SUBSTRING:
    4323              :           return false;
    4324              : 
    4325            1 :         case REF_INQUIRY:
    4326            1 :           if (e1->symtree->n.sym->ts.type == BT_COMPLEX
    4327            1 :               && e1->ts.type == BT_REAL && e2->ts.type == BT_REAL
    4328            1 :               && r1->u.i != r2->u.i)
    4329              :             return false;
    4330              :           break;
    4331              : 
    4332            0 :         default:
    4333            0 :           gfc_internal_error ("compare_actual_expr(): Bad component code");
    4334              :         }
    4335              :     }
    4336            3 :   if (!r1 && !r2)
    4337              :     return true;
    4338              :   return false;
    4339              : }
    4340              : 
    4341              : 
    4342              : /* Given formal and actual argument lists that correspond to one
    4343              :    another, check that identical actual arguments aren't not
    4344              :    associated with some incompatible INTENTs.  */
    4345              : 
    4346              : static bool
    4347          737 : check_some_aliasing (gfc_formal_arglist *f, gfc_actual_arglist *a)
    4348              : {
    4349          737 :   sym_intent f1_intent, f2_intent;
    4350          737 :   gfc_formal_arglist *f1;
    4351          737 :   gfc_actual_arglist *a1;
    4352          737 :   size_t n, i, j;
    4353          737 :   argpair *p;
    4354          737 :   bool t = true;
    4355              : 
    4356          737 :   n = 0;
    4357          737 :   for (f1 = f, a1 = a;; f1 = f1->next, a1 = a1->next)
    4358              :     {
    4359         1934 :       if (f1 == NULL && a1 == NULL)
    4360              :         break;
    4361         1197 :       if (f1 == NULL || a1 == NULL)
    4362            0 :         gfc_internal_error ("check_some_aliasing(): List mismatch");
    4363         1197 :       n++;
    4364              :     }
    4365          737 :   if (n == 0)
    4366              :     return t;
    4367          655 :   p = XALLOCAVEC (argpair, n);
    4368              : 
    4369         1852 :   for (i = 0, f1 = f, a1 = a; i < n; i++, f1 = f1->next, a1 = a1->next)
    4370              :     {
    4371         1197 :       p[i].f = f1;
    4372         1197 :       p[i].a = a1;
    4373              :     }
    4374              : 
    4375          655 :   qsort (p, n, sizeof (argpair), pair_cmp);
    4376              : 
    4377         2507 :   for (i = 0; i < n; i++)
    4378              :     {
    4379         1197 :       if (!p[i].a->expr
    4380         1192 :           || p[i].a->expr->expr_type != EXPR_VARIABLE
    4381          570 :           || p[i].a->expr->ts.type == BT_PROCEDURE)
    4382          628 :         continue;
    4383          569 :       f1_intent = p[i].f->sym->attr.intent;
    4384          572 :       for (j = i + 1; j < n; j++)
    4385              :         {
    4386              :           /* Expected order after the sort.  */
    4387           43 :           if (!p[j].a->expr || p[j].a->expr->expr_type != EXPR_VARIABLE)
    4388            0 :             gfc_internal_error ("check_some_aliasing(): corrupted data");
    4389              : 
    4390              :           /* Are the expression the same?  */
    4391           43 :           if (!compare_actual_expr (p[i].a->expr, p[j].a->expr))
    4392              :             break;
    4393            3 :           f2_intent = p[j].f->sym->attr.intent;
    4394            3 :           if ((f1_intent == INTENT_IN && f2_intent == INTENT_OUT)
    4395            2 :               || (f1_intent == INTENT_OUT && f2_intent == INTENT_IN)
    4396            1 :               || (f1_intent == INTENT_OUT && f2_intent == INTENT_OUT))
    4397              :             {
    4398            3 :               gfc_warning (0, "Same actual argument associated with INTENT(%s) "
    4399              :                            "argument %qs and INTENT(%s) argument %qs at %L",
    4400            3 :                            gfc_intent_string (f1_intent), p[i].f->sym->name,
    4401              :                            gfc_intent_string (f2_intent), p[j].f->sym->name,
    4402              :                            &p[i].a->expr->where);
    4403            3 :               t = false;
    4404              :             }
    4405              :         }
    4406              :     }
    4407              : 
    4408              :   return t;
    4409              : }
    4410              : 
    4411              : 
    4412              : /* Given formal and actual argument lists that correspond to one
    4413              :    another, check that they are compatible in the sense that intents
    4414              :    are not mismatched.  */
    4415              : 
    4416              : static bool
    4417       113709 : check_intents (gfc_formal_arglist *f, gfc_actual_arglist *a)
    4418              : {
    4419       332183 :   sym_intent f_intent;
    4420              : 
    4421       550657 :   for (;; f = f->next, a = a->next)
    4422              :     {
    4423       332183 :       gfc_expr *expr;
    4424              : 
    4425       332183 :       if (f == NULL && a == NULL)
    4426              :         break;
    4427       218478 :       if (f == NULL || a == NULL)
    4428            0 :         gfc_internal_error ("check_intents(): List mismatch");
    4429              : 
    4430       218478 :       if (a->expr && a->expr->expr_type == EXPR_FUNCTION
    4431        12659 :           && a->expr->value.function.isym
    4432         7606 :           && a->expr->value.function.isym->id == GFC_ISYM_CAF_GET)
    4433            0 :         expr = a->expr->value.function.actual->expr;
    4434              :       else
    4435              :         expr = a->expr;
    4436              : 
    4437       218478 :       if (expr == NULL || expr->expr_type != EXPR_VARIABLE)
    4438       126790 :         continue;
    4439              : 
    4440        91688 :       f_intent = f->sym->attr.intent;
    4441              : 
    4442        91688 :       if (gfc_pure (NULL) && gfc_impure_variable (expr->symtree->n.sym))
    4443              :         {
    4444          412 :           if ((f->sym->ts.type == BT_CLASS && f->sym->attr.class_ok
    4445           16 :                && CLASS_DATA (f->sym)->attr.class_pointer)
    4446          411 :               || (f->sym->ts.type != BT_CLASS && f->sym->attr.pointer))
    4447              :             {
    4448            2 :               gfc_error ("Procedure argument at %L is local to a PURE "
    4449              :                          "procedure and has the POINTER attribute",
    4450              :                          &expr->where);
    4451            2 :               return false;
    4452              :             }
    4453              :         }
    4454              : 
    4455              :        /* Fortran 2008, C1283.  */
    4456        91686 :        if (gfc_pure (NULL) && gfc_is_coindexed (expr))
    4457              :         {
    4458            1 :           if (f_intent == INTENT_INOUT || f_intent == INTENT_OUT)
    4459              :             {
    4460            1 :               gfc_error ("Coindexed actual argument at %L in PURE procedure "
    4461              :                          "is passed to an INTENT(%s) argument",
    4462              :                          &expr->where, gfc_intent_string (f_intent));
    4463            1 :               return false;
    4464              :             }
    4465              : 
    4466            0 :           if ((f->sym->ts.type == BT_CLASS && f->sym->attr.class_ok
    4467            0 :                && CLASS_DATA (f->sym)->attr.class_pointer)
    4468            0 :               || (f->sym->ts.type != BT_CLASS && f->sym->attr.pointer))
    4469              :             {
    4470            0 :               gfc_error ("Coindexed actual argument at %L in PURE procedure "
    4471              :                          "is passed to a POINTER dummy argument",
    4472              :                          &expr->where);
    4473            0 :               return false;
    4474              :             }
    4475              :         }
    4476              : 
    4477              :        /* F2008, Section 12.5.2.4.  */
    4478         6514 :        if (expr->ts.type == BT_CLASS && f->sym->ts.type == BT_CLASS
    4479        97499 :            && gfc_is_coindexed (expr))
    4480              :          {
    4481            1 :            gfc_error ("Coindexed polymorphic actual argument at %L is passed "
    4482              :                       "polymorphic dummy argument %qs",
    4483            1 :                          &expr->where, f->sym->name);
    4484            1 :            return false;
    4485              :          }
    4486       218474 :     }
    4487              : 
    4488              :   return true;
    4489              : }
    4490              : 
    4491              : 
    4492              : /* Check how a procedure is used against its interface.  If all goes
    4493              :    well, the actual argument list will also end up being properly
    4494              :    sorted.  */
    4495              : 
    4496              : bool
    4497       104215 : gfc_procedure_use (gfc_symbol *sym, gfc_actual_arglist **ap, locus *where)
    4498              : {
    4499       104215 :   gfc_actual_arglist *a;
    4500       104215 :   gfc_formal_arglist *dummy_args;
    4501       104215 :   bool implicit = false;
    4502              : 
    4503              :   /* Warn about calls with an implicit interface.  Special case
    4504              :      for calling a ISO_C_BINDING because c_loc and c_funloc
    4505              :      are pseudo-unknown.  Additionally, warn about procedures not
    4506              :      explicitly declared at all if requested.  */
    4507       104215 :   if (sym->attr.if_source == IFSRC_UNKNOWN && !sym->attr.is_iso_c)
    4508              :     {
    4509        16424 :       bool has_implicit_none_export = false;
    4510        16424 :       implicit = true;
    4511        16424 :       if (sym->attr.proc == PROC_UNKNOWN)
    4512        23254 :         for (gfc_namespace *ns = sym->ns; ns; ns = ns->parent)
    4513        11718 :           if (ns->has_implicit_none_export)
    4514              :             {
    4515              :               has_implicit_none_export = true;
    4516              :               break;
    4517              :             }
    4518        11540 :       if (has_implicit_none_export)
    4519              :         {
    4520            4 :           const char *guessed
    4521            4 :             = gfc_lookup_function_fuzzy (sym->name, sym->ns->sym_root);
    4522            4 :           if (guessed)
    4523            1 :             gfc_error ("Procedure %qs called at %L is not explicitly declared"
    4524              :                        "; did you mean %qs?",
    4525              :                        sym->name, where, guessed);
    4526              :           else
    4527            3 :             gfc_error ("Procedure %qs called at %L is not explicitly declared",
    4528              :                        sym->name, where);
    4529            4 :           return false;
    4530              :         }
    4531        16420 :       if (warn_implicit_interface)
    4532            0 :         gfc_warning (OPT_Wimplicit_interface,
    4533              :                      "Procedure %qs called with an implicit interface at %L",
    4534              :                      sym->name, where);
    4535        16420 :       else if (warn_implicit_procedure && sym->attr.proc == PROC_UNKNOWN)
    4536            1 :         gfc_warning (OPT_Wimplicit_procedure,
    4537              :                      "Procedure %qs called at %L is not explicitly declared",
    4538              :                      sym->name, where);
    4539        16420 :       gfc_find_proc_namespace (sym->ns)->implicit_interface_calls = 1;
    4540              :     }
    4541              : 
    4542       104211 :   if (sym->attr.if_source == IFSRC_UNKNOWN)
    4543              :     {
    4544        16420 :       if (sym->attr.pointer)
    4545              :         {
    4546            1 :           gfc_error ("The pointer object %qs at %L must have an explicit "
    4547              :                      "function interface or be declared as array",
    4548              :                      sym->name, where);
    4549            1 :           return false;
    4550              :         }
    4551              : 
    4552        16419 :       if (sym->attr.allocatable && !sym->attr.external)
    4553              :         {
    4554            1 :           gfc_error ("The allocatable object %qs at %L must have an explicit "
    4555              :                      "function interface or be declared as array",
    4556              :                      sym->name, where);
    4557            1 :           return false;
    4558              :         }
    4559              : 
    4560        16418 :       if (sym->attr.allocatable)
    4561              :         {
    4562            1 :           gfc_error ("Allocatable function %qs at %L must have an explicit "
    4563              :                      "function interface", sym->name, where);
    4564            1 :           return false;
    4565              :         }
    4566              : 
    4567        46859 :       for (a = *ap; a; a = a->next)
    4568              :         {
    4569        30457 :           if (a->expr && a->expr->error)
    4570              :             return false;
    4571              : 
    4572              :           /* F2018, 15.4.2.2 Explicit interface is required for a
    4573              :              polymorphic dummy argument, so there is no way to
    4574              :              legally have a class appear in an argument with an
    4575              :              implicit interface.  */
    4576              : 
    4577        30457 :           if (implicit && a->expr && a->expr->ts.type == BT_CLASS)
    4578              :             {
    4579            3 :               gfc_error ("Explicit interface required for polymorphic "
    4580              :                          "argument at %L",&a->expr->where);
    4581            3 :               a->expr->error = 1;
    4582            3 :               break;
    4583              :             }
    4584              : 
    4585              :           /* Skip g77 keyword extensions like %VAL, %REF, %LOC.  */
    4586        30454 :           if (a->name != NULL && a->name[0] != '%')
    4587              :             {
    4588            2 :               gfc_error ("Keyword argument requires explicit interface "
    4589              :                          "for procedure %qs at %L", sym->name, &a->expr->where);
    4590            2 :               break;
    4591              :             }
    4592              : 
    4593              :           /* TS 29113, 6.2.  */
    4594        30452 :           if (a->expr && a->expr->ts.type == BT_ASSUMED
    4595            3 :               && sym->intmod_sym_id != ISOCBINDING_LOC)
    4596              :             {
    4597            3 :               gfc_error ("Assumed-type argument %s at %L requires an explicit "
    4598            3 :                          "interface", a->expr->symtree->n.sym->name,
    4599              :                          &a->expr->where);
    4600            3 :               a->expr->error = 1;
    4601            3 :               break;
    4602              :             }
    4603              : 
    4604              :           /* F2008, C1303 and C1304.  */
    4605        30449 :           if (a->expr
    4606        30274 :               && (a->expr->ts.type == BT_DERIVED || a->expr->ts.type == BT_CLASS)
    4607           73 :               && a->expr->ts.u.derived
    4608        30520 :               && ((a->expr->ts.u.derived->from_intmod == INTMOD_ISO_FORTRAN_ENV
    4609            1 :                    && a->expr->ts.u.derived->intmod_sym_id == ISOFORTRAN_LOCK_TYPE)
    4610           70 :                   || gfc_expr_attr (a->expr).lock_comp))
    4611              :             {
    4612            1 :               gfc_error ("Actual argument of LOCK_TYPE or with LOCK_TYPE "
    4613              :                          "component at %L requires an explicit interface for "
    4614            1 :                          "procedure %qs", &a->expr->where, sym->name);
    4615            1 :               a->expr->error = 1;
    4616            1 :               break;
    4617              :             }
    4618              : 
    4619        30448 :           if (a->expr
    4620        30273 :               && (a->expr->ts.type == BT_DERIVED || a->expr->ts.type == BT_CLASS)
    4621           72 :               && a->expr->ts.u.derived
    4622        30518 :               && ((a->expr->ts.u.derived->from_intmod == INTMOD_ISO_FORTRAN_ENV
    4623            0 :                    && a->expr->ts.u.derived->intmod_sym_id
    4624              :                       == ISOFORTRAN_EVENT_TYPE)
    4625           70 :                   || gfc_expr_attr (a->expr).event_comp))
    4626              :             {
    4627            0 :               gfc_error ("Actual argument of EVENT_TYPE or with EVENT_TYPE "
    4628              :                          "component at %L requires an explicit interface for "
    4629            0 :                          "procedure %qs", &a->expr->where, sym->name);
    4630            0 :               a->expr->error = 1;
    4631            0 :               break;
    4632              :             }
    4633              : 
    4634        30448 :           if (a->expr && a->expr->expr_type == EXPR_NULL
    4635            2 :               && a->expr->ts.type == BT_UNKNOWN)
    4636              :             {
    4637            1 :               gfc_error ("MOLD argument to NULL required at %L",
    4638              :                          &a->expr->where);
    4639            1 :               a->expr->error = 1;
    4640            1 :               return false;
    4641              :             }
    4642              : 
    4643        30447 :           if (a->expr && a->expr->expr_type == EXPR_NULL)
    4644              :             {
    4645            1 :               gfc_error ("Passing intrinsic NULL as actual argument at %L "
    4646              :                          "requires an explicit interface", &a->expr->where);
    4647            1 :               a->expr->error = 1;
    4648            1 :               return false;
    4649              :             }
    4650              : 
    4651              :           /* TS 29113, C407b.  */
    4652        30271 :           if (a->expr && a->expr->expr_type == EXPR_VARIABLE
    4653        43727 :               && gfc_symbol_rank (a->expr->symtree->n.sym) == -1)
    4654              :             {
    4655            4 :               gfc_error ("Assumed-rank argument requires an explicit interface "
    4656            4 :                          "at %L", &a->expr->where);
    4657            4 :               a->expr->error = 1;
    4658            4 :               return false;
    4659              :             }
    4660              :         }
    4661              : 
    4662        16411 :       return true;
    4663              :     }
    4664              : 
    4665        87791 :   dummy_args = gfc_sym_get_dummy_args (sym);
    4666              : 
    4667              :   /* For a statement function, check that types and type parameters of actual
    4668              :      arguments and dummy arguments match.  */
    4669        87791 :   if (!gfc_compare_actual_formal (ap, dummy_args, 0, sym->attr.elemental,
    4670        87791 :                                   sym->attr.proc == PROC_ST_FUNCTION, where))
    4671              :     return false;
    4672              : 
    4673        87354 :   if (!check_intents (dummy_args, *ap))
    4674              :     return false;
    4675              : 
    4676        87350 :   if (warn_aliasing)
    4677          725 :     check_some_aliasing (dummy_args, *ap);
    4678              : 
    4679              :   return true;
    4680              : }
    4681              : 
    4682              : 
    4683              : /* Check how a procedure pointer component is used against its interface.
    4684              :    If all goes well, the actual argument list will also end up being properly
    4685              :    sorted. Completely analogous to gfc_procedure_use.  */
    4686              : 
    4687              : void
    4688          569 : gfc_ppc_use (gfc_component *comp, gfc_actual_arglist **ap, locus *where)
    4689              : {
    4690              :   /* Warn about calls with an implicit interface.  Special case
    4691              :      for calling a ISO_C_BINDING because c_loc and c_funloc
    4692              :      are pseudo-unknown.  */
    4693          569 :   if (warn_implicit_interface
    4694            0 :       && comp->attr.if_source == IFSRC_UNKNOWN
    4695            0 :       && !comp->attr.is_iso_c)
    4696            0 :     gfc_warning (OPT_Wimplicit_interface,
    4697              :                  "Procedure pointer component %qs called with an implicit "
    4698              :                  "interface at %L", comp->name, where);
    4699              : 
    4700          569 :   if (comp->attr.if_source == IFSRC_UNKNOWN)
    4701              :     {
    4702           60 :       gfc_actual_arglist *a;
    4703          105 :       for (a = *ap; a; a = a->next)
    4704              :         {
    4705              :           /* Skip g77 keyword extensions like %VAL, %REF, %LOC.  */
    4706           45 :           if (a->name != NULL && a->name[0] != '%')
    4707              :             {
    4708            0 :               gfc_error ("Keyword argument requires explicit interface "
    4709              :                          "for procedure pointer component %qs at %L",
    4710            0 :                          comp->name, &a->expr->where);
    4711            0 :               break;
    4712              :             }
    4713              :         }
    4714              : 
    4715           60 :       return;
    4716              :     }
    4717              : 
    4718          509 :   if (!gfc_compare_actual_formal (ap, comp->ts.interface->formal, 0,
    4719          509 :                               comp->attr.elemental, false, where))
    4720              :     return;
    4721              : 
    4722          509 :   check_intents (comp->ts.interface->formal, *ap);
    4723          509 :   if (warn_aliasing)
    4724            0 :     check_some_aliasing (comp->ts.interface->formal, *ap);
    4725              : }
    4726              : 
    4727              : 
    4728              : /* Try if an actual argument list matches the formal list of a symbol,
    4729              :    respecting the symbol's attributes like ELEMENTAL.  This is used for
    4730              :    GENERIC resolution.  */
    4731              : 
    4732              : bool
    4733        92614 : gfc_arglist_matches_symbol (gfc_actual_arglist** args, gfc_symbol* sym)
    4734              : {
    4735        92614 :   gfc_formal_arglist *dummy_args;
    4736        92614 :   bool r;
    4737              : 
    4738        92614 :   if (sym->attr.flavor != FL_PROCEDURE)
    4739              :     return false;
    4740              : 
    4741        92610 :   dummy_args = gfc_sym_get_dummy_args (sym);
    4742              : 
    4743        92610 :   r = !sym->attr.elemental;
    4744        92610 :   if (gfc_compare_actual_formal (args, dummy_args, r, !r, false, NULL))
    4745              :     {
    4746        25846 :       check_intents (dummy_args, *args);
    4747        25846 :       if (warn_aliasing)
    4748           12 :         check_some_aliasing (dummy_args, *args);
    4749        25846 :       return true;
    4750              :     }
    4751              : 
    4752              :   return false;
    4753              : }
    4754              : 
    4755              : 
    4756              : /* Given an interface pointer and an actual argument list, search for
    4757              :    a formal argument list that matches the actual.  If found, returns
    4758              :    a pointer to the symbol of the correct interface.  Returns NULL if
    4759              :    not found.  */
    4760              : 
    4761              : gfc_symbol *
    4762        45582 : gfc_search_interface (gfc_interface *intr, int sub_flag,
    4763              :                       gfc_actual_arglist **ap)
    4764              : {
    4765        45582 :   gfc_symbol *elem_sym = NULL;
    4766        45582 :   gfc_symbol *null_sym = NULL;
    4767        45582 :   locus null_expr_loc;
    4768        45582 :   gfc_actual_arglist *a;
    4769        45582 :   bool has_null_arg = false;
    4770              : 
    4771       126960 :   for (a = *ap; a; a = a->next)
    4772        81507 :     if (a->expr && a->expr->expr_type == EXPR_NULL
    4773          175 :         && a->expr->ts.type == BT_UNKNOWN)
    4774              :       {
    4775          129 :         has_null_arg = true;
    4776          129 :         null_expr_loc = a->expr->where;
    4777          129 :         break;
    4778              :       }
    4779              : 
    4780       131868 :   for (; intr; intr = intr->next)
    4781              :     {
    4782        97209 :       if (gfc_fl_struct (intr->sym->attr.flavor))
    4783         6595 :         continue;
    4784        90614 :       if (sub_flag && intr->sym->attr.function)
    4785            0 :         continue;
    4786        83664 :       if (!sub_flag && intr->sym->attr.subroutine)
    4787            0 :         continue;
    4788              : 
    4789        90614 :       if (gfc_arglist_matches_symbol (ap, intr->sym))
    4790              :         {
    4791        24646 :           if (has_null_arg && null_sym)
    4792              :             {
    4793            2 :               gfc_error ("MOLD= required in NULL() argument at %L: Ambiguity "
    4794              :                          "between specific functions %s and %s",
    4795            2 :                          &null_expr_loc, null_sym->name, intr->sym->name);
    4796            2 :               return NULL;
    4797              :             }
    4798        24644 :           else if (has_null_arg)
    4799              :             {
    4800            4 :               null_sym = intr->sym;
    4801            4 :               continue;
    4802              :             }
    4803              : 
    4804              :           /* Satisfy 12.4.4.1 such that an elemental match has lower
    4805              :              weight than a non-elemental match.  */
    4806        24640 :           if (intr->sym->attr.elemental)
    4807              :             {
    4808        13719 :               elem_sym = intr->sym;
    4809        13719 :               continue;
    4810              :             }
    4811              :           return intr->sym;
    4812              :         }
    4813              :     }
    4814              : 
    4815        34659 :   if (null_sym)
    4816            2 :     return null_sym;
    4817              : 
    4818              :   return elem_sym ? elem_sym : NULL;
    4819              : }
    4820              : 
    4821              : 
    4822              : /* Do a brute force recursive search for a symbol.  */
    4823              : 
    4824              : static gfc_symtree *
    4825        58804 : find_symtree0 (gfc_symtree *root, gfc_symbol *sym)
    4826              : {
    4827       113740 :   gfc_symtree * st;
    4828              : 
    4829       113740 :   if (root->n.sym == sym)
    4830              :     return root;
    4831              : 
    4832       112717 :   st = NULL;
    4833       112717 :   if (root->left)
    4834        57724 :     st = find_symtree0 (root->left, sym);
    4835       112717 :   if (root->right && ! st)
    4836              :     st = find_symtree0 (root->right, sym);
    4837              :   return st;
    4838              : }
    4839              : 
    4840              : 
    4841              : /* Find a symtree for a symbol.  */
    4842              : 
    4843              : gfc_symtree *
    4844         4642 : gfc_find_sym_in_symtree (gfc_symbol *sym)
    4845              : {
    4846         4642 :   gfc_symtree *st;
    4847         4642 :   gfc_namespace *ns;
    4848              : 
    4849              :   /* First try to find it by name.  */
    4850         4642 :   gfc_find_sym_tree (sym->name, gfc_current_ns, 1, &st);
    4851         4642 :   if (st && st->n.sym == sym)
    4852              :     return st;
    4853              : 
    4854              :   /* If it's been renamed, resort to a brute-force search.  */
    4855              :   /* TODO: avoid having to do this search.  If the symbol doesn't exist
    4856              :      in the symtree for the current namespace, it should probably be added.  */
    4857         1080 :   for (ns = gfc_current_ns; ns; ns = ns->parent)
    4858              :     {
    4859         1080 :       st = find_symtree0 (ns->sym_root, sym);
    4860         1080 :       if (st)
    4861              :         return st;
    4862              :     }
    4863            0 :   gfc_internal_error ("Unable to find symbol %qs", sym->name);
    4864              :   /* Not reached.  */
    4865              : }
    4866              : 
    4867              : 
    4868              : /* See if the arglist to an operator-call contains a derived-type argument
    4869              :    with a matching type-bound operator.  If so, return the matching specific
    4870              :    procedure defined as operator-target as well as the base-object to use
    4871              :    (which is the found derived-type argument with operator).  The generic
    4872              :    name, if any, is transmitted to the final expression via 'gname'.  */
    4873              : 
    4874              : static gfc_typebound_proc*
    4875        13591 : matching_typebound_op (gfc_expr** tb_base,
    4876              :                        gfc_actual_arglist* args,
    4877              :                        gfc_intrinsic_op op, const char* uop,
    4878              :                        const char ** gname)
    4879              : {
    4880        13591 :   gfc_actual_arglist* base;
    4881              : 
    4882        39084 :   for (base = args; base; base = base->next)
    4883        26285 :     if (base->expr->ts.type == BT_DERIVED || base->expr->ts.type == BT_CLASS)
    4884              :       {
    4885              :         gfc_typebound_proc* tb;
    4886              :         gfc_symbol* derived;
    4887              :         bool result;
    4888              : 
    4889        22256 :         while (base->expr->expr_type == EXPR_OP
    4890        22256 :                && base->expr->value.op.op == INTRINSIC_PARENTHESES)
    4891          117 :           base->expr = base->expr->value.op.op1;
    4892              : 
    4893        22139 :         if (base->expr->ts.type == BT_CLASS)
    4894              :           {
    4895         1936 :             if (!base->expr->ts.u.derived || CLASS_DATA (base->expr) == NULL
    4896         3869 :                 || !gfc_expr_attr (base->expr).class_ok)
    4897           87 :               continue;
    4898         1850 :             derived = CLASS_DATA (base->expr)->ts.u.derived;
    4899              :           }
    4900              :         else
    4901        20202 :           derived = base->expr->ts.u.derived;
    4902              : 
    4903              :         /* A use associated derived type is resolvable during parsing.  */
    4904        22052 :         if (derived && derived->attr.use_assoc && !gfc_current_ns->resolved)
    4905         3979 :           gfc_resolve_symbol (derived);
    4906              : 
    4907        22052 :         if (op == INTRINSIC_USER)
    4908              :           {
    4909          186 :             gfc_symtree* tb_uop;
    4910              : 
    4911          186 :             gcc_assert (uop);
    4912          186 :             tb_uop = gfc_find_typebound_user_op (derived, &result, uop,
    4913              :                                                  false, NULL);
    4914              : 
    4915          186 :             if (tb_uop)
    4916           48 :               tb = tb_uop->n.tb;
    4917              :             else
    4918              :               tb = NULL;
    4919              :           }
    4920              :         else
    4921        21866 :           tb = gfc_find_typebound_intrinsic_op (derived, &result, op,
    4922              :                                                 false, NULL);
    4923              : 
    4924              :         /* This means we hit a PRIVATE operator which is use-associated and
    4925              :            should thus not be seen.  */
    4926        22052 :         if (!result)
    4927        21110 :           tb = NULL;
    4928              : 
    4929              :         /* Look through the super-type hierarchy for a matching specific
    4930              :            binding.  */
    4931        22202 :         for (; tb; tb = tb->overridden)
    4932              :           {
    4933          942 :             gfc_tbp_generic* g;
    4934              : 
    4935          942 :             gcc_assert (tb->is_generic);
    4936         1514 :             for (g = tb->u.generic; g; g = g->next)
    4937              :               {
    4938         1364 :                 gfc_symbol* target;
    4939         1364 :                 gfc_actual_arglist* argcopy;
    4940         1364 :                 bool matches;
    4941              : 
    4942              :                 /* If expression matching comes here during parsing, eg. when
    4943              :                    parsing ASSOCIATE, generic TBPs have not yet been resolved
    4944              :                    and g->specific will not have been set. Wait for expression
    4945              :                    resolution by returning NULL.  */
    4946         1364 :                 if (!g->specific && !gfc_current_ns->resolved)
    4947          792 :                   return NULL;
    4948              : 
    4949         1364 :                 gcc_assert (g->specific);
    4950         1364 :                 if (g->specific->error)
    4951            0 :                   continue;
    4952              : 
    4953         1364 :                 target = g->specific->u.specific->n.sym;
    4954              : 
    4955              :                 /* Check if this arglist matches the formal.  */
    4956         1364 :                 argcopy = gfc_copy_actual_arglist (args);
    4957         1364 :                 matches = gfc_arglist_matches_symbol (&argcopy, target);
    4958         1364 :                 gfc_free_actual_arglist (argcopy);
    4959              : 
    4960              :                 /* Return if we found a match.  */
    4961         1364 :                 if (matches)
    4962              :                   {
    4963          792 :                     *tb_base = base->expr;
    4964          792 :                     *gname = g->specific_st->name;
    4965          792 :                     return g->specific;
    4966              :                   }
    4967              :               }
    4968              :           }
    4969              :       }
    4970              : 
    4971              :   return NULL;
    4972              : }
    4973              : 
    4974              : 
    4975              : /* For the 'actual arglist' of an operator call and a specific typebound
    4976              :    procedure that has been found the target of a type-bound operator, build the
    4977              :    appropriate EXPR_COMPCALL and resolve it.  We take this indirection over
    4978              :    type-bound procedures rather than resolving type-bound operators 'directly'
    4979              :    so that we can reuse the existing logic.  */
    4980              : 
    4981              : static void
    4982          792 : build_compcall_for_operator (gfc_expr* e, gfc_actual_arglist* actual,
    4983              :                              gfc_expr* base, gfc_typebound_proc* target,
    4984              :                              const char *gname)
    4985              : {
    4986          792 :   e->expr_type = EXPR_COMPCALL;
    4987          792 :   e->value.compcall.tbp = target;
    4988          792 :   e->value.compcall.name = gname ? gname : "$op";
    4989          792 :   e->value.compcall.actual = actual;
    4990          792 :   e->value.compcall.base_object = base;
    4991          792 :   e->value.compcall.ignore_pass = 1;
    4992          792 :   e->value.compcall.assign = 0;
    4993          792 :   if (e->ts.type == BT_UNKNOWN
    4994          792 :         && target->function)
    4995              :     {
    4996          343 :       if (target->is_generic)
    4997            0 :         e->ts = target->u.generic->specific->u.specific->n.sym->ts;
    4998              :       else
    4999          343 :         e->ts = target->u.specific->n.sym->ts;
    5000              :     }
    5001          792 : }
    5002              : 
    5003              : 
    5004              : /* This subroutine is called when an expression is being resolved.
    5005              :    The expression node in question is either a user defined operator
    5006              :    or an intrinsic operator with arguments that aren't compatible
    5007              :    with the operator.  This subroutine builds an actual argument list
    5008              :    corresponding to the operands, then searches for a compatible
    5009              :    interface.  If one is found, the expression node is replaced with
    5010              :    the appropriate function call. We use the 'match' enum to specify
    5011              :    whether a replacement has been made or not, or if an error occurred.  */
    5012              : 
    5013              : match
    5014         2188 : gfc_extend_expr (gfc_expr *e)
    5015              : {
    5016         2188 :   gfc_actual_arglist *actual;
    5017         2188 :   gfc_symbol *sym;
    5018         2188 :   gfc_namespace *ns;
    5019         2188 :   gfc_user_op *uop;
    5020         2188 :   gfc_intrinsic_op i;
    5021         2188 :   const char *gname;
    5022         2188 :   gfc_typebound_proc* tbo;
    5023         2188 :   gfc_expr* tb_base;
    5024              : 
    5025         2188 :   sym = NULL;
    5026              : 
    5027         2188 :   actual = gfc_get_actual_arglist ();
    5028         2188 :   actual->expr = e->value.op.op1;
    5029              : 
    5030         2188 :   gname = NULL;
    5031              : 
    5032         2188 :   if (e->value.op.op2 != NULL)
    5033              :     {
    5034         1997 :       actual->next = gfc_get_actual_arglist ();
    5035         1997 :       actual->next->expr = e->value.op.op2;
    5036              :     }
    5037              : 
    5038         2188 :   i = fold_unary_intrinsic (e->value.op.op);
    5039              : 
    5040              :   /* See if we find a matching type-bound operator.  */
    5041         2174 :   if (i == INTRINSIC_USER)
    5042          290 :     tbo = matching_typebound_op (&tb_base, actual,
    5043          290 :                                   i, e->value.op.uop->name, &gname);
    5044              :   else
    5045         1898 :     switch (i)
    5046              :       {
    5047              : #define CHECK_OS_COMPARISON(comp) \
    5048              :   case INTRINSIC_##comp: \
    5049              :   case INTRINSIC_##comp##_OS: \
    5050              :     tbo = matching_typebound_op (&tb_base, actual, \
    5051              :                                  INTRINSIC_##comp, NULL, &gname); \
    5052              :     if (!tbo) \
    5053              :       tbo = matching_typebound_op (&tb_base, actual, \
    5054              :                                    INTRINSIC_##comp##_OS, NULL, &gname); \
    5055              :     break;
    5056          193 :         CHECK_OS_COMPARISON(EQ)
    5057          828 :         CHECK_OS_COMPARISON(NE)
    5058           41 :         CHECK_OS_COMPARISON(GT)
    5059           40 :         CHECK_OS_COMPARISON(GE)
    5060           78 :         CHECK_OS_COMPARISON(LT)
    5061           40 :         CHECK_OS_COMPARISON(LE)
    5062              : #undef CHECK_OS_COMPARISON
    5063              : 
    5064          678 :         default:
    5065          678 :           tbo = matching_typebound_op (&tb_base, actual, i, NULL, &gname);
    5066          678 :           break;
    5067              :       }
    5068              : 
    5069              :   /* If there is a matching typebound-operator, replace the expression with
    5070              :       a call to it and succeed.  */
    5071         2184 :   if (tbo)
    5072              :     {
    5073          343 :       gcc_assert (tb_base);
    5074          343 :       build_compcall_for_operator (e, actual, tb_base, tbo, gname);
    5075              : 
    5076          343 :       if (!gfc_resolve_expr (e))
    5077              :         return MATCH_ERROR;
    5078              :       else
    5079              :         return MATCH_YES;
    5080              :     }
    5081              : 
    5082         1845 :   if (i == INTRINSIC_USER)
    5083              :     {
    5084          267 :       for (ns = gfc_current_ns; ns; ns = ns->parent)
    5085              :         {
    5086          257 :           uop = gfc_find_uop (e->value.op.uop->name, ns);
    5087          257 :           if (uop == NULL)
    5088            0 :             continue;
    5089              : 
    5090          257 :           sym = gfc_search_interface (uop->op, 0, &actual);
    5091          257 :           if (sym != NULL)
    5092              :             break;
    5093              :         }
    5094              :     }
    5095              :   else
    5096              :     {
    5097         1917 :       for (ns = gfc_current_ns; ns; ns = ns->parent)
    5098              :         {
    5099              :           /* Due to the distinction between '==' and '.eq.' and friends, one has
    5100              :              to check if either is defined.  */
    5101         1677 :           switch (i)
    5102              :             {
    5103              : #define CHECK_OS_COMPARISON(comp) \
    5104              :   case INTRINSIC_##comp: \
    5105              :   case INTRINSIC_##comp##_OS: \
    5106              :     sym = gfc_search_interface (ns->op[INTRINSIC_##comp], 0, &actual); \
    5107              :     if (!sym) \
    5108              :       sym = gfc_search_interface (ns->op[INTRINSIC_##comp##_OS], 0, &actual); \
    5109              :     break;
    5110          196 :               CHECK_OS_COMPARISON(EQ)
    5111          872 :               CHECK_OS_COMPARISON(NE)
    5112           41 :               CHECK_OS_COMPARISON(GT)
    5113           40 :               CHECK_OS_COMPARISON(GE)
    5114           65 :               CHECK_OS_COMPARISON(LT)
    5115           40 :               CHECK_OS_COMPARISON(LE)
    5116              : #undef CHECK_OS_COMPARISON
    5117              : 
    5118          423 :               default:
    5119          423 :                 sym = gfc_search_interface (ns->op[i], 0, &actual);
    5120              :             }
    5121              : 
    5122         1443 :           if (sym != NULL)
    5123              :             break;
    5124              :         }
    5125              : 
    5126              :       /* F2018(15.4.3.4.2) requires that the use of unlimited polymorphic
    5127              :          formal arguments does not override the intrinsic uses.  */
    5128         1602 :       gfc_push_suppress_errors ();
    5129         1602 :       if (sym
    5130         1362 :           && (UNLIMITED_POLY (sym->formal->sym)
    5131         1352 :               || (sym->formal->next
    5132         1326 :                   && UNLIMITED_POLY (sym->formal->next->sym)))
    5133         1612 :           && !gfc_check_operator_interface (sym, e->value.op.op, e->where))
    5134            0 :         sym = NULL;
    5135         1602 :       gfc_pop_suppress_errors ();
    5136              :     }
    5137              : 
    5138              :   /* TODO: Do an ambiguity-check and error if multiple matching interfaces are
    5139              :      found rather than just taking the first one and not checking further.  */
    5140              : 
    5141         1845 :   if (sym == NULL)
    5142              :     {
    5143              :       /* Don't use gfc_free_actual_arglist().  */
    5144          250 :       free (actual->next);
    5145          250 :       free (actual);
    5146          250 :       return MATCH_NO;
    5147              :     }
    5148              : 
    5149              :   /* Change the expression node to a function call.  */
    5150         1595 :   e->expr_type = EXPR_FUNCTION;
    5151         1595 :   e->symtree = gfc_find_sym_in_symtree (sym);
    5152         1595 :   e->value.function.actual = actual;
    5153         1595 :   e->value.function.esym = NULL;
    5154         1595 :   e->value.function.isym = NULL;
    5155         1595 :   e->value.function.name = NULL;
    5156         1595 :   e->user_operator = 1;
    5157              : 
    5158         1595 :   if (!gfc_resolve_expr (e))
    5159              :     return MATCH_ERROR;
    5160              : 
    5161              :   return MATCH_YES;
    5162              : }
    5163              : 
    5164              : 
    5165              : /* Tries to replace an assignment code node with a subroutine call to the
    5166              :    subroutine associated with the assignment operator. Return true if the node
    5167              :    was replaced. On false, no error is generated.  */
    5168              : 
    5169              : bool
    5170       286108 : gfc_extend_assign (gfc_code *c, gfc_namespace *ns)
    5171              : {
    5172       286108 :   gfc_actual_arglist *actual;
    5173       286108 :   gfc_expr *lhs, *rhs, *tb_base;
    5174       286108 :   gfc_symbol *sym = NULL;
    5175       286108 :   const char *gname = NULL;
    5176       286108 :   gfc_typebound_proc* tbo;
    5177              : 
    5178       286108 :   lhs = c->expr1;
    5179       286108 :   rhs = c->expr2;
    5180              : 
    5181              :   /* Don't allow an intrinsic assignment with a BOZ rhs to be replaced.  */
    5182       286108 :   if (c->op == EXEC_ASSIGN
    5183       286108 :       && c->expr1->expr_type == EXPR_VARIABLE
    5184       286108 :       && c->expr2->expr_type == EXPR_CONSTANT && c->expr2->ts.type == BT_BOZ)
    5185              :     return false;
    5186              : 
    5187              :   /* Don't allow an intrinsic assignment to be replaced.  */
    5188       278155 :   if (lhs->ts.type != BT_DERIVED && lhs->ts.type != BT_CLASS
    5189       277041 :       && (rhs->rank == 0 || rhs->rank == lhs->rank)
    5190       563122 :       && (lhs->ts.type == rhs->ts.type
    5191         6832 :           || (gfc_numeric_ts (&lhs->ts) && gfc_numeric_ts (&rhs->ts))))
    5192       275918 :     return false;
    5193              : 
    5194        10187 :   actual = gfc_get_actual_arglist ();
    5195        10187 :   actual->expr = lhs;
    5196              : 
    5197        10187 :   actual->next = gfc_get_actual_arglist ();
    5198        10187 :   actual->next->expr = rhs;
    5199              : 
    5200              :   /* TODO: Ambiguity-check, see above for gfc_extend_expr.  */
    5201              : 
    5202              :   /* See if we find a matching type-bound assignment.  */
    5203        10187 :   tbo = matching_typebound_op (&tb_base, actual, INTRINSIC_ASSIGN,
    5204              :                                NULL, &gname);
    5205              : 
    5206        10187 :   if (tbo)
    5207              :     {
    5208              :       /* Success: Replace the expression with a type-bound call.  */
    5209          449 :       gcc_assert (tb_base);
    5210          449 :       c->expr1 = gfc_get_expr ();
    5211          449 :       build_compcall_for_operator (c->expr1, actual, tb_base, tbo, gname);
    5212          449 :       c->expr1->value.compcall.assign = 1;
    5213          449 :       c->expr1->where = c->loc;
    5214          449 :       c->expr2 = NULL;
    5215          449 :       c->op = EXEC_COMPCALL;
    5216          449 :       return true;
    5217              :     }
    5218              : 
    5219              :   /* See if we find an 'ordinary' (non-typebound) assignment procedure.  */
    5220        22689 :   for (; ns; ns = ns->parent)
    5221              :     {
    5222        13420 :       sym = gfc_search_interface (ns->op[INTRINSIC_ASSIGN], 1, &actual);
    5223        13420 :       if (sym != NULL)
    5224              :         break;
    5225              :     }
    5226              : 
    5227         9738 :   if (sym)
    5228              :     {
    5229              :       /* Success: Replace the assignment with the call.  */
    5230          469 :       c->op = EXEC_ASSIGN_CALL;
    5231          469 :       c->symtree = gfc_find_sym_in_symtree (sym);
    5232          469 :       c->expr1 = NULL;
    5233          469 :       c->expr2 = NULL;
    5234          469 :       c->ext.actual = actual;
    5235          469 :       return true;
    5236              :     }
    5237              : 
    5238              :   /* Failure: No assignment procedure found.  */
    5239         9269 :   free (actual->next);
    5240         9269 :   free (actual);
    5241         9269 :   return false;
    5242              : }
    5243              : 
    5244              : 
    5245              : /* Make sure that the interface just parsed is not already present in
    5246              :    the given interface list.  Ambiguity isn't checked yet since module
    5247              :    procedures can be present without interfaces.  */
    5248              : 
    5249              : bool
    5250        10129 : gfc_check_new_interface (gfc_interface *base, gfc_symbol *new_sym, locus loc)
    5251              : {
    5252        10129 :   gfc_interface *ip;
    5253              : 
    5254        19960 :   for (ip = base; ip; ip = ip->next)
    5255              :     {
    5256         9838 :       if (ip->sym == new_sym)
    5257              :         {
    5258            7 :           gfc_error ("Entity %qs at %L is already present in the interface",
    5259              :                      new_sym->name, &loc);
    5260            7 :           return false;
    5261              :         }
    5262              :     }
    5263              : 
    5264              :   return true;
    5265              : }
    5266              : 
    5267              : 
    5268              : /* Add a symbol to the current interface.  */
    5269              : 
    5270              : bool
    5271        18351 : gfc_add_interface (gfc_symbol *new_sym)
    5272              : {
    5273        18351 :   gfc_interface **head, *intr;
    5274        18351 :   gfc_namespace *ns;
    5275        18351 :   gfc_symbol *sym;
    5276              : 
    5277        18351 :   switch (current_interface.type)
    5278              :     {
    5279              :     case INTERFACE_NAMELESS:
    5280              :     case INTERFACE_ABSTRACT:
    5281              :       return true;
    5282              : 
    5283          666 :     case INTERFACE_INTRINSIC_OP:
    5284         1335 :       for (ns = current_interface.ns; ns; ns = ns->parent)
    5285          672 :         switch (current_interface.op)
    5286              :           {
    5287           75 :             case INTRINSIC_EQ:
    5288           75 :             case INTRINSIC_EQ_OS:
    5289           75 :               if (!gfc_check_new_interface (ns->op[INTRINSIC_EQ], new_sym,
    5290              :                                             gfc_current_locus)
    5291           75 :                   || !gfc_check_new_interface (ns->op[INTRINSIC_EQ_OS],
    5292              :                                                new_sym, gfc_current_locus))
    5293            2 :                 return false;
    5294              :               break;
    5295              : 
    5296           44 :             case INTRINSIC_NE:
    5297           44 :             case INTRINSIC_NE_OS:
    5298           44 :               if (!gfc_check_new_interface (ns->op[INTRINSIC_NE], new_sym,
    5299              :                                             gfc_current_locus)
    5300           44 :                   || !gfc_check_new_interface (ns->op[INTRINSIC_NE_OS],
    5301              :                                                new_sym, gfc_current_locus))
    5302            0 :                 return false;
    5303              :               break;
    5304              : 
    5305           19 :             case INTRINSIC_GT:
    5306           19 :             case INTRINSIC_GT_OS:
    5307           19 :               if (!gfc_check_new_interface (ns->op[INTRINSIC_GT],
    5308              :                                             new_sym, gfc_current_locus)
    5309           19 :                   || !gfc_check_new_interface (ns->op[INTRINSIC_GT_OS],
    5310              :                                                new_sym, gfc_current_locus))
    5311            0 :                 return false;
    5312              :               break;
    5313              : 
    5314           17 :             case INTRINSIC_GE:
    5315           17 :             case INTRINSIC_GE_OS:
    5316           17 :               if (!gfc_check_new_interface (ns->op[INTRINSIC_GE],
    5317              :                                             new_sym, gfc_current_locus)
    5318           17 :                   || !gfc_check_new_interface (ns->op[INTRINSIC_GE_OS],
    5319              :                                                new_sym, gfc_current_locus))
    5320            0 :                 return false;
    5321              :               break;
    5322              : 
    5323           29 :             case INTRINSIC_LT:
    5324           29 :             case INTRINSIC_LT_OS:
    5325           29 :               if (!gfc_check_new_interface (ns->op[INTRINSIC_LT],
    5326              :                                             new_sym, gfc_current_locus)
    5327           29 :                   || !gfc_check_new_interface (ns->op[INTRINSIC_LT_OS],
    5328              :                                                new_sym, gfc_current_locus))
    5329            0 :                 return false;
    5330              :               break;
    5331              : 
    5332           17 :             case INTRINSIC_LE:
    5333           17 :             case INTRINSIC_LE_OS:
    5334           17 :               if (!gfc_check_new_interface (ns->op[INTRINSIC_LE],
    5335              :                                             new_sym, gfc_current_locus)
    5336           17 :                   || !gfc_check_new_interface (ns->op[INTRINSIC_LE_OS],
    5337              :                                                new_sym, gfc_current_locus))
    5338            0 :                 return false;
    5339              :               break;
    5340              : 
    5341          471 :             default:
    5342          471 :               if (!gfc_check_new_interface (ns->op[current_interface.op],
    5343              :                                             new_sym, gfc_current_locus))
    5344              :                 return false;
    5345              :           }
    5346              : 
    5347          663 :       head = &current_interface.ns->op[current_interface.op];
    5348          663 :       break;
    5349              : 
    5350         8721 :     case INTERFACE_GENERIC:
    5351         8721 :     case INTERFACE_DTIO:
    5352        17451 :       for (ns = current_interface.ns; ns; ns = ns->parent)
    5353              :         {
    5354         8731 :           gfc_find_symbol (current_interface.sym->name, ns, 0, &sym);
    5355         8731 :           if (sym == NULL)
    5356           11 :             continue;
    5357              : 
    5358         8720 :           if (!gfc_check_new_interface (sym->generic,
    5359              :                                         new_sym, gfc_current_locus))
    5360              :             return false;
    5361              :         }
    5362              : 
    5363         8720 :       head = &current_interface.sym->generic;
    5364         8720 :       break;
    5365              : 
    5366          168 :     case INTERFACE_USER_OP:
    5367          168 :       if (!gfc_check_new_interface (current_interface.uop->op,
    5368              :                                     new_sym, gfc_current_locus))
    5369              :         return false;
    5370              : 
    5371          167 :       head = &current_interface.uop->op;
    5372          167 :       break;
    5373              : 
    5374            0 :     default:
    5375            0 :       gfc_internal_error ("gfc_add_interface(): Bad interface type");
    5376              :     }
    5377              : 
    5378         9550 :   intr = gfc_get_interface ();
    5379         9550 :   intr->sym = new_sym;
    5380         9550 :   intr->where = gfc_current_locus;
    5381              : 
    5382         9550 :   intr->next = *head;
    5383         9550 :   *head = intr;
    5384              : 
    5385         9550 :   return true;
    5386              : }
    5387              : 
    5388              : 
    5389              : gfc_interface *&
    5390        92739 : gfc_current_interface_head (void)
    5391              : {
    5392        92739 :   switch (current_interface.type)
    5393              :     {
    5394        12051 :       case INTERFACE_INTRINSIC_OP:
    5395        12051 :         return current_interface.ns->op[current_interface.op];
    5396              : 
    5397        77837 :       case INTERFACE_GENERIC:
    5398        77837 :       case INTERFACE_DTIO:
    5399        77837 :         return current_interface.sym->generic;
    5400              : 
    5401         2851 :       case INTERFACE_USER_OP:
    5402         2851 :         return current_interface.uop->op;
    5403              : 
    5404            0 :       default:
    5405            0 :         gcc_unreachable ();
    5406              :     }
    5407              : }
    5408              : 
    5409              : 
    5410              : void
    5411            3 : gfc_set_current_interface_head (gfc_interface *i)
    5412              : {
    5413            3 :   switch (current_interface.type)
    5414              :     {
    5415            0 :       case INTERFACE_INTRINSIC_OP:
    5416            0 :         current_interface.ns->op[current_interface.op] = i;
    5417            0 :         break;
    5418              : 
    5419            3 :       case INTERFACE_GENERIC:
    5420            3 :       case INTERFACE_DTIO:
    5421            3 :         current_interface.sym->generic = i;
    5422            3 :         break;
    5423              : 
    5424            0 :       case INTERFACE_USER_OP:
    5425            0 :         current_interface.uop->op = i;
    5426            0 :         break;
    5427              : 
    5428            0 :       default:
    5429            0 :         gcc_unreachable ();
    5430              :     }
    5431            3 : }
    5432              : 
    5433              : 
    5434              : /* Gets rid of a formal argument list.  We do not free symbols.
    5435              :    Symbols are freed when a namespace is freed.  */
    5436              : 
    5437              : void
    5438      6293971 : gfc_free_formal_arglist (gfc_formal_arglist *p)
    5439              : {
    5440      6293971 :   gfc_formal_arglist *q;
    5441              : 
    5442      7035504 :   for (; p; p = q)
    5443              :     {
    5444       741533 :       q = p->next;
    5445       741533 :       free (p);
    5446              :     }
    5447      6293971 : }
    5448              : 
    5449              : 
    5450              : /* Check that it is ok for the type-bound procedure 'proc' to override the
    5451              :    procedure 'old', cf. F08:4.5.7.3.  */
    5452              : 
    5453              : bool
    5454         1214 : gfc_check_typebound_override (gfc_symtree* proc, gfc_symtree* old)
    5455              : {
    5456         1214 :   locus where;
    5457         1214 :   gfc_symbol *proc_target, *old_target;
    5458         1214 :   unsigned proc_pass_arg, old_pass_arg, argpos;
    5459         1214 :   gfc_formal_arglist *proc_formal, *old_formal;
    5460         1214 :   bool check_type;
    5461         1214 :   char err[200];
    5462              : 
    5463              :   /* This procedure should only be called for non-GENERIC proc.  */
    5464         1214 :   gcc_assert (!proc->n.tb->is_generic);
    5465              : 
    5466              :   /* If the overwritten procedure is GENERIC, this is an error.  */
    5467         1214 :   if (old->n.tb->is_generic)
    5468              :     {
    5469            1 :       gfc_error ("Cannot overwrite GENERIC %qs at %L",
    5470              :                  old->name, &proc->n.tb->where);
    5471            1 :       return false;
    5472              :     }
    5473              : 
    5474         1213 :   where = proc->n.tb->where;
    5475         1213 :   proc_target = proc->n.tb->u.specific->n.sym;
    5476         1213 :   old_target = old->n.tb->u.specific->n.sym;
    5477              : 
    5478              :   /* Check that overridden binding is not NON_OVERRIDABLE.  */
    5479         1213 :   if (old->n.tb->non_overridable)
    5480              :     {
    5481            1 :       gfc_error ("%qs at %L overrides a procedure binding declared"
    5482              :                  " NON_OVERRIDABLE", proc->name, &where);
    5483            1 :       return false;
    5484              :     }
    5485              : 
    5486              :   /* It's an error to override a non-DEFERRED procedure with a DEFERRED one.  */
    5487         1212 :   if (!old->n.tb->deferred && proc->n.tb->deferred)
    5488              :     {
    5489            1 :       gfc_error ("%qs at %L must not be DEFERRED as it overrides a"
    5490              :                  " non-DEFERRED binding", proc->name, &where);
    5491            1 :       return false;
    5492              :     }
    5493              : 
    5494              :   /* If the overridden binding is PURE, the overriding must be, too.  */
    5495         1211 :   if (old_target->attr.pure && !proc_target->attr.pure)
    5496              :     {
    5497            2 :       gfc_error ("%qs at %L overrides a PURE procedure and must also be PURE",
    5498              :                  proc->name, &where);
    5499            2 :       return false;
    5500              :     }
    5501              : 
    5502              :   /* If the overridden binding is ELEMENTAL, the overriding must be, too.  If it
    5503              :      is not, the overriding must not be either.  */
    5504         1209 :   if (old_target->attr.elemental && !proc_target->attr.elemental)
    5505              :     {
    5506            0 :       gfc_error ("%qs at %L overrides an ELEMENTAL procedure and must also be"
    5507              :                  " ELEMENTAL", proc->name, &where);
    5508            0 :       return false;
    5509              :     }
    5510         1209 :   if (!old_target->attr.elemental && proc_target->attr.elemental)
    5511              :     {
    5512            1 :       gfc_error ("%qs at %L overrides a non-ELEMENTAL procedure and must not"
    5513              :                  " be ELEMENTAL, either", proc->name, &where);
    5514            1 :       return false;
    5515              :     }
    5516              : 
    5517              :   /* If the overridden binding is a SUBROUTINE, the overriding must also be a
    5518              :      SUBROUTINE.  */
    5519         1208 :   if (old_target->attr.subroutine && !proc_target->attr.subroutine)
    5520              :     {
    5521            1 :       gfc_error ("%qs at %L overrides a SUBROUTINE and must also be a"
    5522              :                  " SUBROUTINE", proc->name, &where);
    5523            1 :       return false;
    5524              :     }
    5525              : 
    5526              :   /* If the overridden binding is a FUNCTION, the overriding must also be a
    5527              :      FUNCTION and have the same characteristics.  */
    5528         1207 :   if (old_target->attr.function)
    5529              :     {
    5530          657 :       if (!proc_target->attr.function)
    5531              :         {
    5532            1 :           gfc_error ("%qs at %L overrides a FUNCTION and must also be a"
    5533              :                      " FUNCTION", proc->name, &where);
    5534            1 :           return false;
    5535              :         }
    5536              : 
    5537          656 :       if (!gfc_check_result_characteristics (proc_target, old_target,
    5538              :                                              err, sizeof(err)))
    5539              :         {
    5540            6 :           gfc_error ("Result mismatch for the overriding procedure "
    5541              :                      "%qs at %L: %s", proc->name, &where, err);
    5542            6 :           return false;
    5543              :         }
    5544              :     }
    5545              : 
    5546              :   /* If the overridden binding is PUBLIC, the overriding one must not be
    5547              :      PRIVATE.  */
    5548         1200 :   if (old->n.tb->access == ACCESS_PUBLIC
    5549         1175 :       && proc->n.tb->access == ACCESS_PRIVATE)
    5550              :     {
    5551            1 :       gfc_error ("%qs at %L overrides a PUBLIC procedure and must not be"
    5552              :                  " PRIVATE", proc->name, &where);
    5553            1 :       return false;
    5554              :     }
    5555              : 
    5556              :   /* Compare the formal argument lists of both procedures.  This is also abused
    5557              :      to find the position of the passed-object dummy arguments of both
    5558              :      bindings as at least the overridden one might not yet be resolved and we
    5559              :      need those positions in the check below.  */
    5560         1199 :   proc_pass_arg = old_pass_arg = 0;
    5561         1199 :   if (!proc->n.tb->nopass && !proc->n.tb->pass_arg)
    5562         1199 :     proc_pass_arg = 1;
    5563         1199 :   if (!old->n.tb->nopass && !old->n.tb->pass_arg)
    5564         1199 :     old_pass_arg = 1;
    5565         1199 :   argpos = 1;
    5566         1199 :   proc_formal = gfc_sym_get_dummy_args (proc_target);
    5567         1199 :   old_formal = gfc_sym_get_dummy_args (old_target);
    5568         4330 :   for ( ; proc_formal && old_formal;
    5569         1932 :        proc_formal = proc_formal->next, old_formal = old_formal->next)
    5570              :     {
    5571         1939 :       if (proc->n.tb->pass_arg
    5572          493 :           && !strcmp (proc->n.tb->pass_arg, proc_formal->sym->name))
    5573         1939 :         proc_pass_arg = argpos;
    5574         1939 :       if (old->n.tb->pass_arg
    5575          495 :           && !strcmp (old->n.tb->pass_arg, old_formal->sym->name))
    5576         1939 :         old_pass_arg = argpos;
    5577              : 
    5578              :       /* Check that the names correspond.  */
    5579         1939 :       if (strcmp (proc_formal->sym->name, old_formal->sym->name))
    5580              :         {
    5581            1 :           gfc_error ("Dummy argument %qs of %qs at %L should be named %qs as"
    5582              :                      " to match the corresponding argument of the overridden"
    5583              :                      " procedure", proc_formal->sym->name, proc->name, &where,
    5584              :                      old_formal->sym->name);
    5585            1 :           return false;
    5586              :         }
    5587              : 
    5588         1938 :       check_type = proc_pass_arg != argpos && old_pass_arg != argpos;
    5589         1938 :       if (!gfc_check_dummy_characteristics (proc_formal->sym, old_formal->sym,
    5590              :                                         check_type, err, sizeof(err)))
    5591              :         {
    5592            6 :           gfc_error_opt (0, "Argument mismatch for the overriding procedure "
    5593              :                          "%qs at %L: %s", proc->name, &where, err);
    5594            6 :           return false;
    5595              :         }
    5596              : 
    5597         1932 :       ++argpos;
    5598              :     }
    5599         1192 :   if (proc_formal || old_formal)
    5600              :     {
    5601            1 :       gfc_error ("%qs at %L must have the same number of formal arguments as"
    5602              :                  " the overridden procedure", proc->name, &where);
    5603            1 :       return false;
    5604              :     }
    5605              : 
    5606              :   /* If the overridden binding is NOPASS, the overriding one must also be
    5607              :      NOPASS.  */
    5608         1191 :   if (old->n.tb->nopass && !proc->n.tb->nopass)
    5609              :     {
    5610            1 :       gfc_error ("%qs at %L overrides a NOPASS binding and must also be"
    5611              :                  " NOPASS", proc->name, &where);
    5612            1 :       return false;
    5613              :     }
    5614              : 
    5615              :   /* If the overridden binding is PASS(x), the overriding one must also be
    5616              :      PASS and the passed-object dummy arguments must correspond.  */
    5617         1190 :   if (!old->n.tb->nopass)
    5618              :     {
    5619         1156 :       if (proc->n.tb->nopass)
    5620              :         {
    5621            1 :           gfc_error ("%qs at %L overrides a binding with PASS and must also be"
    5622              :                      " PASS", proc->name, &where);
    5623            1 :           return false;
    5624              :         }
    5625              : 
    5626         1155 :       if (proc_pass_arg != old_pass_arg)
    5627              :         {
    5628            1 :           gfc_error ("Passed-object dummy argument of %qs at %L must be at"
    5629              :                      " the same position as the passed-object dummy argument of"
    5630              :                      " the overridden procedure", proc->name, &where);
    5631            1 :           return false;
    5632              :         }
    5633              :     }
    5634              : 
    5635              :   return true;
    5636              : }
    5637              : 
    5638              : 
    5639              : /* The following three functions check that the formal arguments
    5640              :    of user defined derived type IO procedures are compliant with
    5641              :    the requirements of the standard, see F03:9.5.3.7.2 (F08:9.6.4.8.3).  */
    5642              : 
    5643              : static void
    5644         4572 : check_dtio_arg_TKR_intent (gfc_symbol *fsym, bool typebound, bt type,
    5645              :                            int kind, int rank, sym_intent intent)
    5646              : {
    5647         4572 :   if (fsym->ts.type != type)
    5648              :     {
    5649            3 :       gfc_error ("DTIO dummy argument at %L must be of type %s",
    5650              :                  &fsym->declared_at, gfc_basic_typename (type));
    5651            3 :       return;
    5652              :     }
    5653              : 
    5654         4569 :   if (fsym->ts.type != BT_CLASS && fsym->ts.type != BT_DERIVED
    5655         3767 :       && fsym->ts.kind != kind)
    5656            1 :     gfc_error ("DTIO dummy argument at %L must be of KIND = %d",
    5657              :                &fsym->declared_at, kind);
    5658              : 
    5659         4569 :   if (!typebound
    5660         4569 :       && rank == 0
    5661         1148 :       && (((type == BT_CLASS) && CLASS_DATA (fsym)->attr.dimension)
    5662          950 :           || ((type != BT_CLASS) && fsym->attr.dimension)))
    5663            0 :     gfc_error ("DTIO dummy argument at %L must be a scalar",
    5664              :                &fsym->declared_at);
    5665         4569 :   else if (rank == 1
    5666          677 :            && (fsym->as == NULL || fsym->as->type != AS_ASSUMED_SHAPE))
    5667            1 :     gfc_error ("DTIO dummy argument at %L must be an "
    5668              :                "ASSUMED SHAPE ARRAY", &fsym->declared_at);
    5669              : 
    5670         4569 :   if (type == BT_CHARACTER && fsym->ts.u.cl->length != NULL)
    5671            1 :     gfc_error ("DTIO character argument at %L must have assumed length",
    5672              :                &fsym->declared_at);
    5673              : 
    5674         4569 :   if (fsym->attr.intent != intent)
    5675            1 :     gfc_error ("DTIO dummy argument at %L must have INTENT %s",
    5676              :                &fsym->declared_at, gfc_code2string (intents, (int)intent));
    5677              :   return;
    5678              : }
    5679              : 
    5680              : 
    5681              : static void
    5682          889 : check_dtio_interface1 (gfc_symbol *derived, gfc_symtree *tb_io_st,
    5683              :                        bool typebound, bool formatted, int code)
    5684              : {
    5685          889 :   gfc_symbol *dtio_sub, *generic_proc, *fsym;
    5686          889 :   gfc_typebound_proc *tb_io_proc, *specific_proc;
    5687          889 :   gfc_interface *intr;
    5688          889 :   gfc_formal_arglist *formal;
    5689          889 :   int arg_num;
    5690              : 
    5691          889 :   bool read = ((dtio_codes)code == DTIO_RF)
    5692          889 :                || ((dtio_codes)code == DTIO_RUF);
    5693          889 :   bt type;
    5694          889 :   sym_intent intent;
    5695          889 :   int kind;
    5696              : 
    5697          889 :   dtio_sub = NULL;
    5698          889 :   if (typebound)
    5699              :     {
    5700              :       /* Typebound DTIO binding.  */
    5701          559 :       tb_io_proc = tb_io_st->n.tb;
    5702          559 :       if (tb_io_proc == NULL)
    5703              :         return;
    5704              : 
    5705          559 :       gcc_assert (tb_io_proc->is_generic);
    5706              : 
    5707          559 :       specific_proc = tb_io_proc->u.generic->specific;
    5708          559 :       if (specific_proc == NULL || specific_proc->is_generic)
    5709              :         return;
    5710              : 
    5711          559 :       dtio_sub = specific_proc->u.specific->n.sym;
    5712              :     }
    5713              :   else
    5714              :     {
    5715          330 :       generic_proc = tb_io_st->n.sym;
    5716          330 :       if (generic_proc == NULL || generic_proc->generic == NULL)
    5717              :         return;
    5718              : 
    5719          407 :       for (intr = tb_io_st->n.sym->generic; intr; intr = intr->next)
    5720              :         {
    5721          334 :           if (intr->sym && intr->sym->formal && intr->sym->formal->sym
    5722          330 :               && ((intr->sym->formal->sym->ts.type == BT_CLASS
    5723          231 :                    && CLASS_DATA (intr->sym->formal->sym)->ts.u.derived
    5724              :                                                              == derived)
    5725          127 :                   || (intr->sym->formal->sym->ts.type == BT_DERIVED
    5726           99 :                       && intr->sym->formal->sym->ts.u.derived == derived)))
    5727              :             {
    5728              :               dtio_sub = intr->sym;
    5729              :               break;
    5730              :             }
    5731           80 :           else if (intr->sym && intr->sym->formal && !intr->sym->formal->sym)
    5732              :             {
    5733            1 :               gfc_error ("Alternate return at %L is not permitted in a DTIO "
    5734              :                          "procedure", &intr->sym->declared_at);
    5735            1 :               return;
    5736              :             }
    5737              :         }
    5738              : 
    5739          327 :       if (dtio_sub == NULL)
    5740              :         return;
    5741              :     }
    5742              : 
    5743          559 :   gcc_assert (dtio_sub);
    5744          813 :   if (!dtio_sub->attr.subroutine)
    5745            0 :     gfc_error ("DTIO procedure %qs at %L must be a subroutine",
    5746              :                dtio_sub->name, &dtio_sub->declared_at);
    5747              : 
    5748          813 :   if (!dtio_sub->resolve_symbol_called)
    5749            1 :     gfc_resolve_formal_arglist (dtio_sub);
    5750              : 
    5751          813 :   arg_num = 0;
    5752         5416 :   for (formal = dtio_sub->formal; formal; formal = formal->next)
    5753         4603 :     arg_num++;
    5754              : 
    5755          944 :   if (arg_num < (formatted ? 6 : 4))
    5756              :     {
    5757            5 :       gfc_error ("Too few dummy arguments in DTIO procedure %qs at %L",
    5758              :                  dtio_sub->name, &dtio_sub->declared_at);
    5759            5 :       return;
    5760              :     }
    5761              : 
    5762          808 :   if (arg_num > (formatted ? 6 : 4))
    5763              :     {
    5764            3 :       gfc_error ("Too many dummy arguments in DTIO procedure %qs at %L",
    5765              :                  dtio_sub->name, &dtio_sub->declared_at);
    5766            3 :       return;
    5767              :     }
    5768              : 
    5769              :   /* Now go through the formal arglist.  */
    5770              :   arg_num = 1;
    5771         5377 :   for (formal = dtio_sub->formal; formal; formal = formal->next, arg_num++)
    5772              :     {
    5773         4573 :       if (!formatted && arg_num == 3)
    5774          128 :         arg_num = 5;
    5775         4573 :       fsym = formal->sym;
    5776              : 
    5777         4573 :       if (fsym == NULL)
    5778              :         {
    5779            1 :           gfc_error ("Alternate return at %L is not permitted in a DTIO "
    5780              :                      "procedure", &dtio_sub->declared_at);
    5781            1 :           return;
    5782              :         }
    5783              : 
    5784         4572 :       switch (arg_num)
    5785              :         {
    5786          805 :         case(1):                        /* DTV  */
    5787          805 :           type = derived->attr.sequence || derived->attr.is_bind_c ?
    5788              :                  BT_DERIVED : BT_CLASS;
    5789          805 :           kind = 0;
    5790          805 :           intent = read ? INTENT_INOUT : INTENT_IN;
    5791          805 :           check_dtio_arg_TKR_intent (fsym, typebound, type, kind,
    5792              :                                      0, intent);
    5793          805 :           break;
    5794              : 
    5795          805 :         case(2):                        /* UNIT  */
    5796          805 :           type = BT_INTEGER;
    5797          805 :           kind = gfc_default_integer_kind;
    5798          805 :           intent = INTENT_IN;
    5799          805 :           check_dtio_arg_TKR_intent (fsym, typebound, type, kind,
    5800              :                                      0, intent);
    5801          805 :           break;
    5802          677 :         case(3):                        /* IOTYPE  */
    5803          677 :           type = BT_CHARACTER;
    5804          677 :           kind = gfc_default_character_kind;
    5805          677 :           intent = INTENT_IN;
    5806          677 :           check_dtio_arg_TKR_intent (fsym, typebound, type, kind,
    5807              :                                      0, intent);
    5808          677 :           break;
    5809          677 :         case(4):                        /* VLIST  */
    5810          677 :           type = BT_INTEGER;
    5811          677 :           kind = gfc_default_integer_kind;
    5812          677 :           intent = INTENT_IN;
    5813          677 :           check_dtio_arg_TKR_intent (fsym, typebound, type, kind,
    5814              :                                      1, intent);
    5815          677 :           break;
    5816          804 :         case(5):                        /* IOSTAT  */
    5817          804 :           type = BT_INTEGER;
    5818          804 :           kind = gfc_default_integer_kind;
    5819          804 :           intent = INTENT_OUT;
    5820          804 :           check_dtio_arg_TKR_intent (fsym, typebound, type, kind,
    5821              :                                      0, intent);
    5822          804 :           break;
    5823          804 :         case(6):                        /* IOMSG  */
    5824          804 :           type = BT_CHARACTER;
    5825          804 :           kind = gfc_default_character_kind;
    5826          804 :           intent = INTENT_INOUT;
    5827          804 :           check_dtio_arg_TKR_intent (fsym, typebound, type, kind,
    5828              :                                      0, intent);
    5829          804 :           break;
    5830            0 :         default:
    5831            0 :           gcc_unreachable ();
    5832              :         }
    5833              :     }
    5834          804 :   derived->attr.has_dtio_procs = 1;
    5835          804 :   return;
    5836              : }
    5837              : 
    5838              : void
    5839        92929 : gfc_check_dtio_interfaces (gfc_symbol *derived)
    5840              : {
    5841        92929 :   gfc_symtree *tb_io_st;
    5842        92929 :   bool t = false;
    5843        92929 :   int code;
    5844        92929 :   bool formatted;
    5845              : 
    5846        92929 :   if (derived->attr.is_class == 1 || derived->attr.vtype == 1)
    5847        36587 :     return;
    5848              : 
    5849              :   /* Check typebound DTIO bindings.  */
    5850       281710 :   for (code = 0; code < 4; code++)
    5851              :     {
    5852       225368 :       formatted = ((dtio_codes)code == DTIO_RF)
    5853              :                    || ((dtio_codes)code == DTIO_WF);
    5854              : 
    5855       225368 :       tb_io_st = gfc_find_typebound_proc (derived, &t,
    5856              :                                           gfc_code2string (dtio_procs, code),
    5857              :                                           true, &derived->declared_at);
    5858       225368 :       if (tb_io_st != NULL)
    5859          559 :         check_dtio_interface1 (derived, tb_io_st, true, formatted, code);
    5860              :     }
    5861              : 
    5862              :   /* Check generic DTIO interfaces.  */
    5863       281710 :   for (code = 0; code < 4; code++)
    5864              :     {
    5865       225368 :       formatted = ((dtio_codes)code == DTIO_RF)
    5866              :                    || ((dtio_codes)code == DTIO_WF);
    5867              : 
    5868       225368 :       tb_io_st = gfc_find_symtree (derived->ns->sym_root,
    5869              :                                    gfc_code2string (dtio_procs, code));
    5870       225368 :       if (tb_io_st != NULL)
    5871          330 :         check_dtio_interface1 (derived, tb_io_st, false, formatted, code);
    5872              :     }
    5873              : }
    5874              : 
    5875              : 
    5876              : gfc_symtree*
    5877         4349 : gfc_find_typebound_dtio_proc (gfc_symbol *derived, bool write, bool formatted)
    5878              : {
    5879         4349 :   gfc_symtree *tb_io_st = NULL;
    5880         4349 :   bool t = false;
    5881              : 
    5882         4349 :   if (!derived || !derived->resolve_symbol_called
    5883         4349 :       || derived->attr.flavor != FL_DERIVED)
    5884              :     return NULL;
    5885              : 
    5886              :   /* Try to find a typebound DTIO binding.  */
    5887         4343 :   if (formatted == true)
    5888              :     {
    5889         4098 :       if (write == true)
    5890         1929 :         tb_io_st = gfc_find_typebound_proc (derived, &t,
    5891              :                                             gfc_code2string (dtio_procs,
    5892              :                                                              DTIO_WF),
    5893              :                                             true,
    5894              :                                             &derived->declared_at);
    5895              :       else
    5896         2169 :         tb_io_st = gfc_find_typebound_proc (derived, &t,
    5897              :                                             gfc_code2string (dtio_procs,
    5898              :                                                              DTIO_RF),
    5899              :                                             true,
    5900              :                                             &derived->declared_at);
    5901              :     }
    5902              :   else
    5903              :     {
    5904          245 :       if (write == true)
    5905          109 :         tb_io_st = gfc_find_typebound_proc (derived, &t,
    5906              :                                             gfc_code2string (dtio_procs,
    5907              :                                                              DTIO_WUF),
    5908              :                                             true,
    5909              :                                             &derived->declared_at);
    5910              :       else
    5911          136 :         tb_io_st = gfc_find_typebound_proc (derived, &t,
    5912              :                                             gfc_code2string (dtio_procs,
    5913              :                                                              DTIO_RUF),
    5914              :                                             true,
    5915              :                                             &derived->declared_at);
    5916              :     }
    5917              :   return tb_io_st;
    5918              : }
    5919              : 
    5920              : 
    5921              : gfc_symbol *
    5922         2907 : gfc_find_specific_dtio_proc (gfc_symbol *derived, bool write, bool formatted)
    5923              : {
    5924         2907 :   gfc_symtree *tb_io_st = NULL;
    5925         2907 :   gfc_symbol *dtio_sub = NULL;
    5926         2907 :   gfc_symbol *extended;
    5927         2907 :   gfc_typebound_proc *tb_io_proc, *specific_proc;
    5928              : 
    5929         2907 :   tb_io_st = gfc_find_typebound_dtio_proc (derived, write, formatted);
    5930              : 
    5931         2907 :   if (tb_io_st != NULL)
    5932              :     {
    5933          860 :       const char *genname;
    5934          860 :       gfc_symtree *st;
    5935              : 
    5936          860 :       tb_io_proc = tb_io_st->n.tb;
    5937          860 :       gcc_assert (tb_io_proc != NULL);
    5938          860 :       gcc_assert (tb_io_proc->is_generic);
    5939          860 :       gcc_assert (tb_io_proc->u.generic->next == NULL);
    5940              : 
    5941          860 :       specific_proc = tb_io_proc->u.generic->specific;
    5942          860 :       gcc_assert (!specific_proc->is_generic);
    5943              : 
    5944              :       /* Go back and make sure that we have the right specific procedure.
    5945              :          Here we most likely have a procedure from the parent type, which
    5946              :          can be overridden in extensions.  */
    5947          860 :       genname = tb_io_proc->u.generic->specific_st->name;
    5948          860 :       st = gfc_find_typebound_proc (derived, NULL, genname,
    5949              :                                     true, &tb_io_proc->where);
    5950          860 :       if (st)
    5951          860 :         dtio_sub = st->n.tb->u.specific->n.sym;
    5952              :       else
    5953            0 :         dtio_sub = specific_proc->u.specific->n.sym;
    5954              : 
    5955          860 :       goto finish;
    5956              :     }
    5957              : 
    5958              :   /* If there is not a typebound binding, look for a generic
    5959              :      DTIO interface.  */
    5960         4173 :   for (extended = derived; extended;
    5961         2126 :        extended = gfc_get_derived_super_type (extended))
    5962              :     {
    5963         2126 :       if (extended == NULL || extended->ns == NULL
    5964         2126 :           || extended->attr.flavor == FL_UNKNOWN)
    5965              :         return NULL;
    5966              : 
    5967         2126 :       if (formatted == true)
    5968              :         {
    5969         2039 :           if (write == true)
    5970          928 :             tb_io_st = gfc_find_symtree (extended->ns->sym_root,
    5971              :                                          gfc_code2string (dtio_procs,
    5972              :                                                           DTIO_WF));
    5973              :           else
    5974         1111 :             tb_io_st = gfc_find_symtree (extended->ns->sym_root,
    5975              :                                          gfc_code2string (dtio_procs,
    5976              :                                                           DTIO_RF));
    5977              :         }
    5978              :       else
    5979              :         {
    5980           87 :           if (write == true)
    5981           37 :             tb_io_st = gfc_find_symtree (extended->ns->sym_root,
    5982              :                                          gfc_code2string (dtio_procs,
    5983              :                                                           DTIO_WUF));
    5984              :           else
    5985           50 :             tb_io_st = gfc_find_symtree (extended->ns->sym_root,
    5986              :                                          gfc_code2string (dtio_procs,
    5987              :                                                           DTIO_RUF));
    5988              :         }
    5989              : 
    5990         2126 :       if (tb_io_st != NULL
    5991          269 :           && tb_io_st->n.sym
    5992          269 :           && tb_io_st->n.sym->generic)
    5993              :         {
    5994           26 :           for (gfc_interface *intr = tb_io_st->n.sym->generic;
    5995          295 :                intr && intr->sym; intr = intr->next)
    5996              :             {
    5997          273 :               if (intr->sym->formal)
    5998              :                 {
    5999          268 :                   gfc_symbol *fsym = intr->sym->formal->sym;
    6000          268 :                   if ((fsym->ts.type == BT_CLASS
    6001          218 :                       && CLASS_DATA (fsym)->ts.u.derived == extended)
    6002           71 :                       || (fsym->ts.type == BT_DERIVED
    6003           50 :                           && fsym->ts.u.derived == extended))
    6004              :                     {
    6005              :                       dtio_sub = intr->sym;
    6006              :                       break;
    6007              :                     }
    6008              :                 }
    6009              :             }
    6010              :         }
    6011              :     }
    6012              : 
    6013         2047 : finish:
    6014         2907 :   if (dtio_sub
    6015         1107 :       && dtio_sub->formal->sym->ts.type == BT_CLASS
    6016         1057 :       && derived != CLASS_DATA (dtio_sub->formal->sym)->ts.u.derived)
    6017           97 :     gfc_find_derived_vtab (derived);
    6018              : 
    6019              :   return dtio_sub;
    6020              : }
    6021              : 
    6022              : /* Helper function - if we do not find an interface for a procedure,
    6023              :    construct it from the actual arglist.  Luckily, this can only
    6024              :    happen for call by reference, so the information we actually need
    6025              :    to provide (and which would be impossible to guess from the call
    6026              :    itself) is not actually needed.  */
    6027              : 
    6028              : void
    6029         1985 : gfc_get_formal_from_actual_arglist (gfc_symbol *sym,
    6030              :                                     gfc_actual_arglist *actual_args)
    6031              : {
    6032         1985 :   gfc_actual_arglist *a;
    6033         1985 :   gfc_formal_arglist **f;
    6034         1985 :   gfc_symbol *s;
    6035         1985 :   char name[GFC_MAX_SYMBOL_LEN + 1];
    6036         1985 :   static int var_num;
    6037              : 
    6038              :   /* Do not infer the formal from actual arguments if we are dealing with
    6039              :      classes.  */
    6040              : 
    6041         1985 :   if (sym->ts.type == BT_CLASS)
    6042            1 :     return;
    6043              : 
    6044         1984 :   f = &sym->formal;
    6045         5960 :   for (a = actual_args; a != NULL; a = a->next)
    6046              :     {
    6047         3976 :       (*f) = gfc_get_formal_arglist ();
    6048         3976 :       if (a->expr)
    6049              :         {
    6050         3968 :           snprintf (name, GFC_MAX_SYMBOL_LEN, "_formal_%d", var_num ++);
    6051         3968 :           gfc_get_symbol (name, gfc_current_ns, &s);
    6052         3968 :           if (a->expr->ts.type == BT_PROCEDURE)
    6053              :             {
    6054           44 :               gfc_symbol *asym = a->expr->symtree->n.sym;
    6055           44 :               s->attr.flavor = FL_PROCEDURE;
    6056           44 :               if (asym->attr.function)
    6057              :                 {
    6058           24 :                   s->attr.function = 1;
    6059           24 :                   s->ts = asym->ts;
    6060              :                 }
    6061           44 :               s->attr.subroutine = asym->attr.subroutine;
    6062              :             }
    6063              :           else
    6064              :             {
    6065         3924 :               s->ts = a->expr->ts;
    6066              : 
    6067         3924 :               if (s->ts.type == BT_CHARACTER)
    6068          180 :                 s->ts.u.cl = gfc_get_charlen ();
    6069              : 
    6070         3924 :               s->ts.deferred = 0;
    6071         3924 :               s->ts.is_iso_c = 0;
    6072         3924 :               s->ts.is_c_interop = 0;
    6073         3924 :               s->attr.flavor = FL_VARIABLE;
    6074         3924 :               if (a->expr->rank > 0)
    6075              :                 {
    6076          872 :                   s->attr.dimension = 1;
    6077          872 :                   s->as = gfc_get_array_spec ();
    6078          872 :                   s->as->rank = 1;
    6079         1744 :                   s->as->lower[0] = gfc_get_int_expr (gfc_index_integer_kind,
    6080          872 :                                                       &a->expr->where, 1);
    6081          872 :                   s->as->upper[0] = NULL;
    6082          872 :                   s->as->type = AS_ASSUMED_SIZE;
    6083              :                 }
    6084              :               else
    6085         3052 :                 s->maybe_array = maybe_dummy_array_arg (a->expr);
    6086              :             }
    6087         3968 :           s->attr.dummy = 1;
    6088         3968 :           s->attr.artificial = 1;
    6089         3968 :           s->declared_at = a->expr->where;
    6090         3968 :           s->attr.intent = INTENT_UNKNOWN;
    6091         3968 :           (*f)->sym = s;
    6092         3968 :           gfc_commit_symbol (s);
    6093              :         }
    6094              :       else  /* If a->expr is NULL, this is an alternate rerturn.  */
    6095            8 :         (*f)->sym = NULL;
    6096              : 
    6097         3976 :       f = &((*f)->next);
    6098              :     }
    6099              : 
    6100              : }
    6101              : 
    6102              : 
    6103              : const char *
    6104          241 : gfc_dummy_arg_get_name (gfc_dummy_arg & dummy_arg)
    6105              : {
    6106          241 :   switch (dummy_arg.intrinsicness)
    6107              :     {
    6108          241 :     case GFC_INTRINSIC_DUMMY_ARG:
    6109          241 :       return dummy_arg.u.intrinsic->name;
    6110              : 
    6111            0 :     case GFC_NON_INTRINSIC_DUMMY_ARG:
    6112            0 :       return dummy_arg.u.non_intrinsic->sym->name;
    6113              : 
    6114            0 :     default:
    6115            0 :       gcc_unreachable ();
    6116              :     }
    6117              : }
    6118              : 
    6119              : 
    6120              : const gfc_typespec &
    6121         2460 : gfc_dummy_arg_get_typespec (gfc_dummy_arg & dummy_arg)
    6122              : {
    6123         2460 :   switch (dummy_arg.intrinsicness)
    6124              :     {
    6125         1352 :     case GFC_INTRINSIC_DUMMY_ARG:
    6126         1352 :       return dummy_arg.u.intrinsic->ts;
    6127              : 
    6128         1108 :     case GFC_NON_INTRINSIC_DUMMY_ARG:
    6129         1108 :       return dummy_arg.u.non_intrinsic->sym->ts;
    6130              : 
    6131            0 :     default:
    6132            0 :       gcc_unreachable ();
    6133              :     }
    6134              : }
    6135              : 
    6136              : 
    6137              : bool
    6138        26408 : gfc_dummy_arg_is_optional (gfc_dummy_arg & dummy_arg)
    6139              : {
    6140        26408 :   switch (dummy_arg.intrinsicness)
    6141              :     {
    6142        12422 :     case GFC_INTRINSIC_DUMMY_ARG:
    6143        12422 :       return dummy_arg.u.intrinsic->optional;
    6144              : 
    6145        13986 :     case GFC_NON_INTRINSIC_DUMMY_ARG:
    6146        13986 :       return dummy_arg.u.non_intrinsic->sym->attr.optional;
    6147              : 
    6148            0 :     default:
    6149            0 :       gcc_unreachable ();
    6150              :     }
    6151              : }
        

Generated by: LCOV version 2.4-beta

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