
This patch tries to remove all the direct use of DeclID except the real low level reading and writing. All the use of DeclID is converted to the use of LocalDeclID or GlobalDeclID. This is helpful to increase the readability and type safety.
193 lines
8.0 KiB
C++
193 lines
8.0 KiB
C++
//===--- 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<Expr *> VL) {
|
|
auto *D = OMPDeclarativeDirective::createDirective<OMPThreadPrivateDecl>(
|
|
C, DC, std::nullopt, VL.size(), L);
|
|
D->setVars(VL);
|
|
return D;
|
|
}
|
|
|
|
OMPThreadPrivateDecl *OMPThreadPrivateDecl::CreateDeserialized(ASTContext &C,
|
|
GlobalDeclID ID,
|
|
unsigned N) {
|
|
return OMPDeclarativeDirective::createEmptyDirective<OMPThreadPrivateDecl>(
|
|
C, ID, 0, N);
|
|
}
|
|
|
|
void OMPThreadPrivateDecl::setVars(ArrayRef<Expr *> VL) {
|
|
assert(VL.size() == Data->getNumChildren() &&
|
|
"Number of variables is not the same as the preallocated buffer");
|
|
llvm::copy(VL, getVars().begin());
|
|
}
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
// OMPAllocateDecl Implementation.
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
void OMPAllocateDecl::anchor() { }
|
|
|
|
OMPAllocateDecl *OMPAllocateDecl::Create(ASTContext &C, DeclContext *DC,
|
|
SourceLocation L, ArrayRef<Expr *> VL,
|
|
ArrayRef<OMPClause *> CL) {
|
|
auto *D = OMPDeclarativeDirective::createDirective<OMPAllocateDecl>(
|
|
C, DC, CL, VL.size(), L);
|
|
D->setVars(VL);
|
|
return D;
|
|
}
|
|
|
|
OMPAllocateDecl *OMPAllocateDecl::CreateDeserialized(ASTContext &C,
|
|
GlobalDeclID ID,
|
|
unsigned NVars,
|
|
unsigned NClauses) {
|
|
return OMPDeclarativeDirective::createEmptyDirective<OMPAllocateDecl>(
|
|
C, ID, NClauses, NVars, SourceLocation());
|
|
}
|
|
|
|
void OMPAllocateDecl::setVars(ArrayRef<Expr *> VL) {
|
|
assert(VL.size() == Data->getNumChildren() &&
|
|
"Number of variables is not the same as the preallocated buffer");
|
|
llvm::copy(VL, getVars().begin());
|
|
}
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
// OMPRequiresDecl Implementation.
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
void OMPRequiresDecl::anchor() {}
|
|
|
|
OMPRequiresDecl *OMPRequiresDecl::Create(ASTContext &C, DeclContext *DC,
|
|
SourceLocation L,
|
|
ArrayRef<OMPClause *> CL) {
|
|
return OMPDeclarativeDirective::createDirective<OMPRequiresDecl>(C, DC, CL, 0,
|
|
L);
|
|
}
|
|
|
|
OMPRequiresDecl *OMPRequiresDecl::CreateDeserialized(ASTContext &C,
|
|
GlobalDeclID ID,
|
|
unsigned N) {
|
|
return OMPDeclarativeDirective::createEmptyDirective<OMPRequiresDecl>(
|
|
C, ID, N, 0, SourceLocation());
|
|
}
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
// 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, OMPDeclareReductionInitKind::Call);
|
|
}
|
|
|
|
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, GlobalDeclID ID) {
|
|
return new (C, ID) OMPDeclareReductionDecl(
|
|
OMPDeclareReduction, /*DC=*/nullptr, SourceLocation(), DeclarationName(),
|
|
QualType(), /*PrevDeclInScope=*/nullptr);
|
|
}
|
|
|
|
OMPDeclareReductionDecl *OMPDeclareReductionDecl::getPrevDeclInScope() {
|
|
return cast_or_null<OMPDeclareReductionDecl>(
|
|
PrevDeclInScope.get(getASTContext().getExternalSource()));
|
|
}
|
|
const OMPDeclareReductionDecl *
|
|
OMPDeclareReductionDecl::getPrevDeclInScope() const {
|
|
return cast_or_null<OMPDeclareReductionDecl>(
|
|
PrevDeclInScope.get(getASTContext().getExternalSource()));
|
|
}
|
|
|
|
//===----------------------------------------------------------------------===//
|
|
// OMPDeclareMapperDecl Implementation.
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
void OMPDeclareMapperDecl::anchor() {}
|
|
|
|
OMPDeclareMapperDecl *OMPDeclareMapperDecl::Create(
|
|
ASTContext &C, DeclContext *DC, SourceLocation L, DeclarationName Name,
|
|
QualType T, DeclarationName VarName, ArrayRef<OMPClause *> Clauses,
|
|
OMPDeclareMapperDecl *PrevDeclInScope) {
|
|
return OMPDeclarativeDirective::createDirective<OMPDeclareMapperDecl>(
|
|
C, DC, Clauses, 1, L, Name, T, VarName, PrevDeclInScope);
|
|
}
|
|
|
|
OMPDeclareMapperDecl *OMPDeclareMapperDecl::CreateDeserialized(ASTContext &C,
|
|
GlobalDeclID ID,
|
|
unsigned N) {
|
|
return OMPDeclarativeDirective::createEmptyDirective<OMPDeclareMapperDecl>(
|
|
C, ID, N, 1, SourceLocation(), DeclarationName(), QualType(),
|
|
DeclarationName(), /*PrevDeclInScope=*/nullptr);
|
|
}
|
|
|
|
OMPDeclareMapperDecl *OMPDeclareMapperDecl::getPrevDeclInScope() {
|
|
return cast_or_null<OMPDeclareMapperDecl>(
|
|
PrevDeclInScope.get(getASTContext().getExternalSource()));
|
|
}
|
|
|
|
const OMPDeclareMapperDecl *OMPDeclareMapperDecl::getPrevDeclInScope() const {
|
|
return cast_or_null<OMPDeclareMapperDecl>(
|
|
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,
|
|
GlobalDeclID 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());
|
|
}
|