//===--- DeclOpenMP.cpp - Declaration OpenMP AST Node Implementation ------===// // // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. // See https://llvm.org/LICENSE.txt for license information. // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception // //===----------------------------------------------------------------------===// /// \file /// This file implements OMPThreadPrivateDecl, OMPCapturedExprDecl /// classes. /// //===----------------------------------------------------------------------===// #include "clang/AST/ASTContext.h" #include "clang/AST/Decl.h" #include "clang/AST/DeclBase.h" #include "clang/AST/DeclOpenMP.h" #include "clang/AST/Expr.h" using namespace clang; //===----------------------------------------------------------------------===// // OMPThreadPrivateDecl Implementation. //===----------------------------------------------------------------------===// void OMPThreadPrivateDecl::anchor() { } OMPThreadPrivateDecl *OMPThreadPrivateDecl::Create(ASTContext &C, DeclContext *DC, SourceLocation L, ArrayRef VL) { OMPThreadPrivateDecl *D = new (C, DC, additionalSizeToAlloc(VL.size())) OMPThreadPrivateDecl(OMPThreadPrivate, DC, L); D->NumVars = VL.size(); D->setVars(VL); return D; } OMPThreadPrivateDecl *OMPThreadPrivateDecl::CreateDeserialized(ASTContext &C, unsigned ID, unsigned N) { OMPThreadPrivateDecl *D = new (C, ID, additionalSizeToAlloc(N)) OMPThreadPrivateDecl(OMPThreadPrivate, nullptr, SourceLocation()); D->NumVars = N; return D; } void OMPThreadPrivateDecl::setVars(ArrayRef VL) { assert(VL.size() == NumVars && "Number of variables is not the same as the preallocated buffer"); std::uninitialized_copy(VL.begin(), VL.end(), getTrailingObjects()); } //===----------------------------------------------------------------------===// // OMPAllocateDecl Implementation. //===----------------------------------------------------------------------===// void OMPAllocateDecl::anchor() { } OMPAllocateDecl *OMPAllocateDecl::Create(ASTContext &C, DeclContext *DC, SourceLocation L, ArrayRef VL, ArrayRef CL) { OMPAllocateDecl *D = new ( C, DC, additionalSizeToAlloc(VL.size(), CL.size())) OMPAllocateDecl(OMPAllocate, DC, L); D->NumVars = VL.size(); D->setVars(VL); D->NumClauses = CL.size(); D->setClauses(CL); return D; } OMPAllocateDecl *OMPAllocateDecl::CreateDeserialized(ASTContext &C, unsigned ID, unsigned NVars, unsigned NClauses) { OMPAllocateDecl *D = new (C, ID, additionalSizeToAlloc(NVars, NClauses)) OMPAllocateDecl(OMPAllocate, nullptr, SourceLocation()); D->NumVars = NVars; D->NumClauses = NClauses; return D; } void OMPAllocateDecl::setVars(ArrayRef VL) { assert(VL.size() == NumVars && "Number of variables is not the same as the preallocated buffer"); std::uninitialized_copy(VL.begin(), VL.end(), getTrailingObjects()); } void OMPAllocateDecl::setClauses(ArrayRef CL) { assert(CL.size() == NumClauses && "Number of variables is not the same as the preallocated buffer"); std::uninitialized_copy(CL.begin(), CL.end(), getTrailingObjects()); } //===----------------------------------------------------------------------===// // OMPRequiresDecl Implementation. //===----------------------------------------------------------------------===// void OMPRequiresDecl::anchor() {} OMPRequiresDecl *OMPRequiresDecl::Create(ASTContext &C, DeclContext *DC, SourceLocation L, ArrayRef CL) { OMPRequiresDecl *D = new (C, DC, additionalSizeToAlloc(CL.size())) OMPRequiresDecl(OMPRequires, DC, L); D->NumClauses = CL.size(); D->setClauses(CL); return D; } OMPRequiresDecl *OMPRequiresDecl::CreateDeserialized(ASTContext &C, unsigned ID, unsigned N) { OMPRequiresDecl *D = new (C, ID, additionalSizeToAlloc(N)) OMPRequiresDecl(OMPRequires, nullptr, SourceLocation()); D->NumClauses = N; return D; } void OMPRequiresDecl::setClauses(ArrayRef CL) { assert(CL.size() == NumClauses && "Number of clauses is not the same as the preallocated buffer"); std::uninitialized_copy(CL.begin(), CL.end(), getTrailingObjects()); } //===----------------------------------------------------------------------===// // OMPDeclareReductionDecl Implementation. //===----------------------------------------------------------------------===// OMPDeclareReductionDecl::OMPDeclareReductionDecl( Kind DK, DeclContext *DC, SourceLocation L, DeclarationName Name, QualType Ty, OMPDeclareReductionDecl *PrevDeclInScope) : ValueDecl(DK, DC, L, Name, Ty), DeclContext(DK), Combiner(nullptr), PrevDeclInScope(PrevDeclInScope) { setInitializer(nullptr, CallInit); } void OMPDeclareReductionDecl::anchor() {} OMPDeclareReductionDecl *OMPDeclareReductionDecl::Create( ASTContext &C, DeclContext *DC, SourceLocation L, DeclarationName Name, QualType T, OMPDeclareReductionDecl *PrevDeclInScope) { return new (C, DC) OMPDeclareReductionDecl(OMPDeclareReduction, DC, L, Name, T, PrevDeclInScope); } OMPDeclareReductionDecl * OMPDeclareReductionDecl::CreateDeserialized(ASTContext &C, unsigned ID) { return new (C, ID) OMPDeclareReductionDecl( OMPDeclareReduction, /*DC=*/nullptr, SourceLocation(), DeclarationName(), QualType(), /*PrevDeclInScope=*/nullptr); } OMPDeclareReductionDecl *OMPDeclareReductionDecl::getPrevDeclInScope() { return cast_or_null( PrevDeclInScope.get(getASTContext().getExternalSource())); } const OMPDeclareReductionDecl * OMPDeclareReductionDecl::getPrevDeclInScope() const { return cast_or_null( PrevDeclInScope.get(getASTContext().getExternalSource())); } //===----------------------------------------------------------------------===// // OMPDeclareMapperDecl Implementation. //===----------------------------------------------------------------------===// void OMPDeclareMapperDecl::anchor() {} OMPDeclareMapperDecl * OMPDeclareMapperDecl::Create(ASTContext &C, DeclContext *DC, SourceLocation L, DeclarationName Name, QualType T, DeclarationName VarName, OMPDeclareMapperDecl *PrevDeclInScope) { return new (C, DC) OMPDeclareMapperDecl(OMPDeclareMapper, DC, L, Name, T, VarName, PrevDeclInScope); } OMPDeclareMapperDecl *OMPDeclareMapperDecl::CreateDeserialized(ASTContext &C, unsigned ID, unsigned N) { auto *D = new (C, ID) OMPDeclareMapperDecl(OMPDeclareMapper, /*DC=*/nullptr, SourceLocation(), DeclarationName(), QualType(), DeclarationName(), /*PrevDeclInScope=*/nullptr); if (N) { auto **ClauseStorage = C.Allocate(N); D->Clauses = llvm::makeMutableArrayRef(ClauseStorage, N); } return D; } /// Creates an array of clauses to this mapper declaration and intializes /// them. The space used to store clause pointers is dynamically allocated, /// because we do not know the number of clauses when creating /// OMPDeclareMapperDecl void OMPDeclareMapperDecl::CreateClauses(ASTContext &C, ArrayRef CL) { assert(Clauses.empty() && "Number of clauses should be 0 on initialization"); size_t NumClauses = CL.size(); if (NumClauses) { auto **ClauseStorage = C.Allocate(NumClauses); Clauses = llvm::makeMutableArrayRef(ClauseStorage, NumClauses); setClauses(CL); } } void OMPDeclareMapperDecl::setClauses(ArrayRef CL) { assert(CL.size() == Clauses.size() && "Number of clauses is not the same as the preallocated buffer"); std::uninitialized_copy(CL.begin(), CL.end(), Clauses.data()); } OMPDeclareMapperDecl *OMPDeclareMapperDecl::getPrevDeclInScope() { return cast_or_null( PrevDeclInScope.get(getASTContext().getExternalSource())); } const OMPDeclareMapperDecl *OMPDeclareMapperDecl::getPrevDeclInScope() const { return cast_or_null( PrevDeclInScope.get(getASTContext().getExternalSource())); } //===----------------------------------------------------------------------===// // OMPCapturedExprDecl Implementation. //===----------------------------------------------------------------------===// void OMPCapturedExprDecl::anchor() {} OMPCapturedExprDecl *OMPCapturedExprDecl::Create(ASTContext &C, DeclContext *DC, IdentifierInfo *Id, QualType T, SourceLocation StartLoc) { return new (C, DC) OMPCapturedExprDecl( C, DC, Id, T, C.getTrivialTypeSourceInfo(T), StartLoc); } OMPCapturedExprDecl *OMPCapturedExprDecl::CreateDeserialized(ASTContext &C, unsigned ID) { return new (C, ID) OMPCapturedExprDecl(C, nullptr, nullptr, QualType(), /*TInfo=*/nullptr, SourceLocation()); } SourceRange OMPCapturedExprDecl::getSourceRange() const { assert(hasInit()); return SourceRange(getInit()->getBeginLoc(), getInit()->getEndLoc()); }