[all-commits] [llvm/llvm-project] 3265b9: [flang] Extension: reduced scope for some implied ...

Peter Klausler via All-commits all-commits at lists.llvm.org
Tue Aug 24 09:34:36 PDT 2021


  Branch: refs/heads/main
  Home:   https://github.com/llvm/llvm-project
  Commit: 3265b93363d8540ee96357bfd708cc36b8c89280
      https://github.com/llvm/llvm-project/commit/3265b93363d8540ee96357bfd708cc36b8c89280
  Author: peter klausler <pklausler at nvidia.com>
  Date:   2021-08-24 (Tue, 24 Aug 2021)

  Changed paths:
    M flang/docs/Extensions.md
    M flang/lib/Semantics/expression.cpp
    M flang/lib/Semantics/resolve-names.cpp
    M flang/test/Semantics/array-constr-values.f90
    A flang/test/Semantics/data11.f90
    M flang/test/Semantics/modfile25.f90
    M flang/test/Semantics/modfile26.f90
    A flang/test/Semantics/resolve106.f90
    M flang/test/Semantics/resolve30.f90
    M flang/test/Semantics/symbol05.f90

  Log Message:
  -----------
  [flang] Extension: reduced scope for some implied DO loop indices

The index of an implied DO loop in a DATA statement or array
constructor is defined by Fortran 2018 to have scope over its
implied DO loop.  This definition is unfortunate, because it
requires the implied DO loop's bounds expressions to be in the
scope of the index variable.  Consequently, in code like

  integer, parameter :: j = 5
  real, save :: a(5) = [(j, j=1, j)]

the upper bound of the loop is a reference to the index variable,
not the parameter in the enclosing scope.

This patch limits the scope of the index variable to the "body"
of the implied DO loop as one would naturally expect, with a warning.
I would have preferred to make this a hard error, but most Fortran
compilers treat this case as f18 now does.  If the standard
were to be fixed, the warning could be made optional.

Differential Revision: https://reviews.llvm.org/D108595




More information about the All-commits mailing list