diff options
Diffstat (limited to 'flang/lib/Evaluate/expression.cpp')
-rw-r--r-- | flang/lib/Evaluate/expression.cpp | 12 |
1 files changed, 12 insertions, 0 deletions
diff --git a/flang/lib/Evaluate/expression.cpp b/flang/lib/Evaluate/expression.cpp index 9514ac8..759fe5b 100644 --- a/flang/lib/Evaluate/expression.cpp +++ b/flang/lib/Evaluate/expression.cpp @@ -113,6 +113,18 @@ template <typename A> int ExpressionBase<A>::Rank() const { derived().u); } +template <typename A> int ExpressionBase<A>::Corank() const { + return common::visit( + [](const auto &x) { + if constexpr (common::HasMember<decltype(x), TypelessExpression>) { + return 0; + } else { + return x.Corank(); + } + }, + derived().u); +} + DynamicType Parentheses<SomeDerived>::GetType() const { return left().GetType().value(); } |