[clang] [OpenACC] Add 'collapse' clause AST/basic Sema implementation (PR #109461)
via cfe-commits
cfe-commits at lists.llvm.org
Fri Sep 20 12:38:07 PDT 2024
================
@@ -1583,6 +1618,33 @@ ExprResult SemaOpenACC::ActOnArraySectionExpr(Expr *Base, SourceLocation LBLoc,
OK_Ordinary, ColonLoc, RBLoc);
}
+ExprResult SemaOpenACC::CheckCollapseLoopCount(Expr *LoopCount) {
+ if (!LoopCount)
+ return ExprError();
+
+ assert((LoopCount->isInstantiationDependent() ||
+ LoopCount->getType()->isIntegerType()) &&
+ "Loop argument non integer?");
+
+ // If this is dependent, there really isn't anything we can check.
+ if (LoopCount->isInstantiationDependent())
+ return ExprResult{LoopCount};
+
+ std::optional<llvm::APSInt> ICE =
+ LoopCount->getIntegerConstantExpr(getASTContext());
----------------
cor3ntin wrote:
I would wrap LoopCount in a ConstantExpr if it's not dependent, so that you don't have to evaluate every time.
(We don't seem to do that for other openacc nodes though)
https://github.com/llvm/llvm-project/pull/109461
More information about the cfe-commits
mailing list