re PR fortran/78300 ([OOP] Failure to compile a F03 code with an optional dummy proce...
[gcc.git] / gcc / fortran / resolve.c
index c85525aabb9e557cc03367c3566257514819a797..825bb12a517bdb2639d3660e4d7afe1b55882bb7 100644 (file)
@@ -214,27 +214,33 @@ resolve_procedure_interface (gfc_symbol *sym)
       if (ifc->result)
        {
          sym->ts = ifc->result->ts;
+         sym->attr.allocatable = ifc->result->attr.allocatable;
+         sym->attr.pointer = ifc->result->attr.pointer;
+         sym->attr.dimension = ifc->result->attr.dimension;
+         sym->attr.class_ok = ifc->result->attr.class_ok;
+         sym->as = gfc_copy_array_spec (ifc->result->as);
          sym->result = sym;
        }
       else
-       sym->ts = ifc->ts;
+       {
+         sym->ts = ifc->ts;
+         sym->attr.allocatable = ifc->attr.allocatable;
+         sym->attr.pointer = ifc->attr.pointer;
+         sym->attr.dimension = ifc->attr.dimension;
+         sym->attr.class_ok = ifc->attr.class_ok;
+         sym->as = gfc_copy_array_spec (ifc->as);
+       }
       sym->ts.interface = ifc;
       sym->attr.function = ifc->attr.function;
       sym->attr.subroutine = ifc->attr.subroutine;
 
-      sym->attr.allocatable = ifc->attr.allocatable;
-      sym->attr.pointer = ifc->attr.pointer;
       sym->attr.pure = ifc->attr.pure;
       sym->attr.elemental = ifc->attr.elemental;
-      sym->attr.dimension = ifc->attr.dimension;
       sym->attr.contiguous = ifc->attr.contiguous;
       sym->attr.recursive = ifc->attr.recursive;
       sym->attr.always_explicit = ifc->attr.always_explicit;
       sym->attr.ext_attr |= ifc->attr.ext_attr;
       sym->attr.is_bind_c = ifc->attr.is_bind_c;
-      sym->attr.class_ok = ifc->attr.class_ok;
-      /* Copy array spec.  */
-      sym->as = gfc_copy_array_spec (ifc->as);
       /* Copy char length.  */
       if (ifc->ts.type == BT_CHARACTER && ifc->ts.u.cl)
        {