[clang] [OpenACC][CIR] Implement 'init' lowering for private clause vars (PR #151781)
Erich Keane via cfe-commits
cfe-commits at lists.llvm.org
Mon Aug 4 10:34:05 PDT 2025
================
@@ -837,23 +837,43 @@ class OpenACCClauseWithVarList : public OpenACCClauseWithExprs {
class OpenACCPrivateClause final
: public OpenACCClauseWithVarList,
- private llvm::TrailingObjects<OpenACCPrivateClause, Expr *> {
+ private llvm::TrailingObjects<OpenACCPrivateClause, Expr *, VarDecl *> {
friend TrailingObjects;
OpenACCPrivateClause(SourceLocation BeginLoc, SourceLocation LParenLoc,
- ArrayRef<Expr *> VarList, SourceLocation EndLoc)
+ ArrayRef<Expr *> VarList,
+ ArrayRef<VarDecl *> InitRecipes, SourceLocation EndLoc)
: OpenACCClauseWithVarList(OpenACCClauseKind::Private, BeginLoc,
LParenLoc, EndLoc) {
- setExprs(getTrailingObjects(VarList.size()), VarList);
+ assert(VarList.size() == InitRecipes.size());
+ setExprs(getTrailingObjects<Expr *>(VarList.size()), VarList);
+ llvm::uninitialized_copy(InitRecipes, getTrailingObjects<VarDecl *>());
----------------
erichkeane wrote:
`std::initialized_copy` doesn't take the range, so I'd have to write out `InitRecipes.begin(), InitRecipes.end()`. The LLVM versions are 'whole range' versions that simplify the code.
https://github.com/llvm/llvm-project/pull/151781
More information about the cfe-commits
mailing list