sym->backend_decl = DECL_CHAIN (sym->backend_decl);
}
+ /* Automatic array indices in module procedures need the backend_decl
+ to be extracted from the procedure formal arglist. */
+ if (sym->attr.dummy && !sym->backend_decl)
+ {
+ gfc_formal_arglist *f;
+ for (f = sym->ns->proc_name->formal; f; f = f->next)
+ {
+ gfc_symbol *fsym = f->sym;
+ if (strcmp (sym->name, fsym->name))
+ continue;
+ sym->backend_decl = fsym->backend_decl;
+ break;
+ }
+ }
+
/* Dummy variables should already have been created. */
gcc_assert (sym->backend_decl);
/* TODO Find out why the condition on expr->symtree had to be moved into
the loop rather than being outside it, as originally. */
for (sym = mapping->syms; sym; sym = sym->next)
- if (expr->symtree && sym->old == expr->symtree->n.sym)
+ if (expr->symtree && !strcmp (sym->old->name, expr->symtree->n.sym->name))
{
if (sym->new_sym->n.sym->backend_decl)
expr->symtree = sym->new_sym;
--- /dev/null
+! { dg-do run }
+
+module m
+ interface
+ module function f(a, n, b) result(z)
+ integer, intent(in) :: n
+ real :: z(n + 1)
+ real :: a, b
+ end
+ end interface
+contains
+ module procedure f
+ integer :: i
+ do i = 1, size(z)
+ z(i) = real(i)
+ end do
+ end procedure
+end
+
+! Comment 1
+module n
+ interface
+ module subroutine g(n, z)
+ integer, intent(in) :: n
+ real :: z(n)
+ end
+ end interface
+contains
+ module procedure g
+ z = 1
+ if (int (sum (z)) /= n) stop 1
+ end procedure
+end
+
+ use m
+ use n
+ real, allocatable :: r(:)
+ integer :: i = 2
+ r = f (1.0, i+1, 2.0)
+ if (any (r .ne. [(real(i), i = 1,4)])) stop 2
+ if (any (f (3.0, 1, 4.0) .ne. [(real(i), i = 1,2)])) stop 3
+
+ r = [(real (i), i = 10,20)]
+ call g (5, r)
+ if (int (sum (r)) /= (sum ([(i, i = 15,20)]) + 5)) stop 4
+end