diff --git a/flang/lib/Semantics/expression.cpp b/flang/lib/Semantics/expression.cpp --- a/flang/lib/Semantics/expression.cpp +++ b/flang/lib/Semantics/expression.cpp @@ -2851,6 +2851,14 @@ const parser::Expr::ComplexConstructor &x) { auto re{Analyze(std::get<0>(x.t).value())}; auto im{Analyze(std::get<1>(x.t).value())}; + if (re && re->Rank() > 0) { + context().Say(std::get<0>(x.t).value().source, + "Real part of complex constructor must be scalar"_err_en_US); + } + if (im && im->Rank() > 0) { + context().Say(std::get<1>(x.t).value().source, + "Imaginary part of complex constructor must be scalar"_err_en_US); + } if (re && im) { ConformabilityCheck(GetContextualMessages(), *re, *im); } diff --git a/flang/test/Semantics/expr-errors05.f90 b/flang/test/Semantics/expr-errors05.f90 new file mode 100644 --- /dev/null +++ b/flang/test/Semantics/expr-errors05.f90 @@ -0,0 +1,7 @@ +! RUN: %python %S/test_errors.py %s %flang_fc1 +! The components of a complex constructor (extension) must be scalar +!ERROR: Real part of complex constructor must be scalar +complex, parameter :: z1(*) = ([1.,2.], 3.) +!ERROR: Imaginary part of complex constructor must be scalar +complex, parameter :: z2(*) = (4., [5.,6.]) +end