[flang] [llvm] [flang][OpenMP] Apply modifier representation to semantic checks (PR #116658)
Krzysztof Parzyszek via llvm-commits
llvm-commits at lists.llvm.org
Thu Nov 21 11:11:13 PST 2024
================
@@ -518,8 +519,14 @@ class OmpAttributeVisitor : DirectiveAttributeVisitor<llvm::omp::Directive> {
}
bool Pre(const parser::OmpClause::Reduction &x) {
- const parser::OmpReductionIdentifier &opr{
- std::get<parser::OmpReductionIdentifier>(x.v.t)};
+ const auto &objList{std::get<parser::OmpObjectList>(x.v.t)};
+ ResolveOmpObjectList(objList, Symbol::Flag::OmpReduction);
+
+ auto &modifiers{OmpGetModifiers(x.v)};
----------------
kparzysz wrote:
In explicit terms, yes. Before 5.2 it was a de facto modifier by the virtue of being on the left side of a `:`, e.g. `reduction(+: x, y, z)`. In 5.2 all such things are modifiers (there are also a couple of post-modifiers, i.e. following a `:`).
https://github.com/llvm/llvm-project/pull/116658
More information about the llvm-commits
mailing list