|  | //===--- StmtOpenMP.cpp - Classes for OpenMP directives -------------------===// | 
|  | // | 
|  | //                     The LLVM Compiler Infrastructure | 
|  | // | 
|  | // This file is distributed under the University of Illinois Open Source | 
|  | // License. See LICENSE.TXT for details. | 
|  | // | 
|  | //===----------------------------------------------------------------------===// | 
|  | // | 
|  | // This file implements the subclesses of Stmt class declared in StmtOpenMP.h | 
|  | // | 
|  | //===----------------------------------------------------------------------===// | 
|  |  | 
|  | #include "clang/AST/StmtOpenMP.h" | 
|  |  | 
|  | #include "clang/AST/ASTContext.h" | 
|  |  | 
|  | using namespace clang; | 
|  |  | 
|  | void OMPExecutableDirective::setClauses(ArrayRef<OMPClause *> Clauses) { | 
|  | assert(Clauses.size() == getNumClauses() && | 
|  | "Number of clauses is not the same as the preallocated buffer"); | 
|  | std::copy(Clauses.begin(), Clauses.end(), getClauses().begin()); | 
|  | } | 
|  |  | 
|  | void OMPLoopDirective::setCounters(ArrayRef<Expr *> A) { | 
|  | assert(A.size() == getCollapsedNumber() && | 
|  | "Number of loop counters is not the same as the collapsed number"); | 
|  | std::copy(A.begin(), A.end(), getCounters().begin()); | 
|  | } | 
|  |  | 
|  | void OMPLoopDirective::setPrivateCounters(ArrayRef<Expr *> A) { | 
|  | assert(A.size() == getCollapsedNumber() && "Number of loop private counters " | 
|  | "is not the same as the collapsed " | 
|  | "number"); | 
|  | std::copy(A.begin(), A.end(), getPrivateCounters().begin()); | 
|  | } | 
|  |  | 
|  | void OMPLoopDirective::setInits(ArrayRef<Expr *> A) { | 
|  | assert(A.size() == getCollapsedNumber() && | 
|  | "Number of counter inits is not the same as the collapsed number"); | 
|  | std::copy(A.begin(), A.end(), getInits().begin()); | 
|  | } | 
|  |  | 
|  | void OMPLoopDirective::setUpdates(ArrayRef<Expr *> A) { | 
|  | assert(A.size() == getCollapsedNumber() && | 
|  | "Number of counter updates is not the same as the collapsed number"); | 
|  | std::copy(A.begin(), A.end(), getUpdates().begin()); | 
|  | } | 
|  |  | 
|  | void OMPLoopDirective::setFinals(ArrayRef<Expr *> A) { | 
|  | assert(A.size() == getCollapsedNumber() && | 
|  | "Number of counter finals is not the same as the collapsed number"); | 
|  | std::copy(A.begin(), A.end(), getFinals().begin()); | 
|  | } | 
|  |  | 
|  | OMPParallelDirective *OMPParallelDirective::Create( | 
|  | const ASTContext &C, SourceLocation StartLoc, SourceLocation EndLoc, | 
|  | ArrayRef<OMPClause *> Clauses, Stmt *AssociatedStmt, bool HasCancel) { | 
|  | unsigned Size = | 
|  | llvm::alignTo(sizeof(OMPParallelDirective), alignof(OMPClause *)); | 
|  | void *Mem = | 
|  | C.Allocate(Size + sizeof(OMPClause *) * Clauses.size() + sizeof(Stmt *)); | 
|  | OMPParallelDirective *Dir = | 
|  | new (Mem) OMPParallelDirective(StartLoc, EndLoc, Clauses.size()); | 
|  | Dir->setClauses(Clauses); | 
|  | Dir->setAssociatedStmt(AssociatedStmt); | 
|  | Dir->setHasCancel(HasCancel); | 
|  | return Dir; | 
|  | } | 
|  |  | 
|  | OMPParallelDirective *OMPParallelDirective::CreateEmpty(const ASTContext &C, | 
|  | unsigned NumClauses, | 
|  | EmptyShell) { | 
|  | unsigned Size = | 
|  | llvm::alignTo(sizeof(OMPParallelDirective), alignof(OMPClause *)); | 
|  | void *Mem = | 
|  | C.Allocate(Size + sizeof(OMPClause *) * NumClauses + sizeof(Stmt *)); | 
|  | return new (Mem) OMPParallelDirective(NumClauses); | 
|  | } | 
|  |  | 
|  | OMPSimdDirective * | 
|  | OMPSimdDirective::Create(const ASTContext &C, SourceLocation StartLoc, | 
|  | SourceLocation EndLoc, unsigned CollapsedNum, | 
|  | ArrayRef<OMPClause *> Clauses, Stmt *AssociatedStmt, | 
|  | const HelperExprs &Exprs) { | 
|  | unsigned Size = llvm::alignTo(sizeof(OMPSimdDirective), alignof(OMPClause *)); | 
|  | void *Mem = | 
|  | C.Allocate(Size + sizeof(OMPClause *) * Clauses.size() + | 
|  | sizeof(Stmt *) * numLoopChildren(CollapsedNum, OMPD_simd)); | 
|  | OMPSimdDirective *Dir = new (Mem) | 
|  | OMPSimdDirective(StartLoc, EndLoc, CollapsedNum, Clauses.size()); | 
|  | Dir->setClauses(Clauses); | 
|  | Dir->setAssociatedStmt(AssociatedStmt); | 
|  | Dir->setIterationVariable(Exprs.IterationVarRef); | 
|  | Dir->setLastIteration(Exprs.LastIteration); | 
|  | Dir->setCalcLastIteration(Exprs.CalcLastIteration); | 
|  | Dir->setPreCond(Exprs.PreCond); | 
|  | Dir->setCond(Exprs.Cond); | 
|  | Dir->setInit(Exprs.Init); | 
|  | Dir->setInc(Exprs.Inc); | 
|  | Dir->setCounters(Exprs.Counters); | 
|  | Dir->setPrivateCounters(Exprs.PrivateCounters); | 
|  | Dir->setInits(Exprs.Inits); | 
|  | Dir->setUpdates(Exprs.Updates); | 
|  | Dir->setFinals(Exprs.Finals); | 
|  | Dir->setPreInits(Exprs.PreInits); | 
|  | return Dir; | 
|  | } | 
|  |  | 
|  | OMPSimdDirective *OMPSimdDirective::CreateEmpty(const ASTContext &C, | 
|  | unsigned NumClauses, | 
|  | unsigned CollapsedNum, | 
|  | EmptyShell) { | 
|  | unsigned Size = llvm::alignTo(sizeof(OMPSimdDirective), alignof(OMPClause *)); | 
|  | void *Mem = | 
|  | C.Allocate(Size + sizeof(OMPClause *) * NumClauses + | 
|  | sizeof(Stmt *) * numLoopChildren(CollapsedNum, OMPD_simd)); | 
|  | return new (Mem) OMPSimdDirective(CollapsedNum, NumClauses); | 
|  | } | 
|  |  | 
|  | OMPForDirective * | 
|  | OMPForDirective::Create(const ASTContext &C, SourceLocation StartLoc, | 
|  | SourceLocation EndLoc, unsigned CollapsedNum, | 
|  | ArrayRef<OMPClause *> Clauses, Stmt *AssociatedStmt, | 
|  | const HelperExprs &Exprs, bool HasCancel) { | 
|  | unsigned Size = llvm::alignTo(sizeof(OMPForDirective), alignof(OMPClause *)); | 
|  | void *Mem = | 
|  | C.Allocate(Size + sizeof(OMPClause *) * Clauses.size() + | 
|  | sizeof(Stmt *) * numLoopChildren(CollapsedNum, OMPD_for)); | 
|  | OMPForDirective *Dir = | 
|  | new (Mem) OMPForDirective(StartLoc, EndLoc, CollapsedNum, Clauses.size()); | 
|  | Dir->setClauses(Clauses); | 
|  | Dir->setAssociatedStmt(AssociatedStmt); | 
|  | Dir->setIterationVariable(Exprs.IterationVarRef); | 
|  | Dir->setLastIteration(Exprs.LastIteration); | 
|  | Dir->setCalcLastIteration(Exprs.CalcLastIteration); | 
|  | Dir->setPreCond(Exprs.PreCond); | 
|  | Dir->setCond(Exprs.Cond); | 
|  | Dir->setInit(Exprs.Init); | 
|  | Dir->setInc(Exprs.Inc); | 
|  | Dir->setIsLastIterVariable(Exprs.IL); | 
|  | Dir->setLowerBoundVariable(Exprs.LB); | 
|  | Dir->setUpperBoundVariable(Exprs.UB); | 
|  | Dir->setStrideVariable(Exprs.ST); | 
|  | Dir->setEnsureUpperBound(Exprs.EUB); | 
|  | Dir->setNextLowerBound(Exprs.NLB); | 
|  | Dir->setNextUpperBound(Exprs.NUB); | 
|  | Dir->setNumIterations(Exprs.NumIterations); | 
|  | Dir->setCounters(Exprs.Counters); | 
|  | Dir->setPrivateCounters(Exprs.PrivateCounters); | 
|  | Dir->setInits(Exprs.Inits); | 
|  | Dir->setUpdates(Exprs.Updates); | 
|  | Dir->setFinals(Exprs.Finals); | 
|  | Dir->setPreInits(Exprs.PreInits); | 
|  | Dir->setHasCancel(HasCancel); | 
|  | return Dir; | 
|  | } | 
|  |  | 
|  | OMPForDirective *OMPForDirective::CreateEmpty(const ASTContext &C, | 
|  | unsigned NumClauses, | 
|  | unsigned CollapsedNum, | 
|  | EmptyShell) { | 
|  | unsigned Size = llvm::alignTo(sizeof(OMPForDirective), alignof(OMPClause *)); | 
|  | void *Mem = | 
|  | C.Allocate(Size + sizeof(OMPClause *) * NumClauses + | 
|  | sizeof(Stmt *) * numLoopChildren(CollapsedNum, OMPD_for)); | 
|  | return new (Mem) OMPForDirective(CollapsedNum, NumClauses); | 
|  | } | 
|  |  | 
|  | OMPForSimdDirective * | 
|  | OMPForSimdDirective::Create(const ASTContext &C, SourceLocation StartLoc, | 
|  | SourceLocation EndLoc, unsigned CollapsedNum, | 
|  | ArrayRef<OMPClause *> Clauses, Stmt *AssociatedStmt, | 
|  | const HelperExprs &Exprs) { | 
|  | unsigned Size = | 
|  | llvm::alignTo(sizeof(OMPForSimdDirective), alignof(OMPClause *)); | 
|  | void *Mem = | 
|  | C.Allocate(Size + sizeof(OMPClause *) * Clauses.size() + | 
|  | sizeof(Stmt *) * numLoopChildren(CollapsedNum, OMPD_for_simd)); | 
|  | OMPForSimdDirective *Dir = new (Mem) | 
|  | OMPForSimdDirective(StartLoc, EndLoc, CollapsedNum, Clauses.size()); | 
|  | Dir->setClauses(Clauses); | 
|  | Dir->setAssociatedStmt(AssociatedStmt); | 
|  | Dir->setIterationVariable(Exprs.IterationVarRef); | 
|  | Dir->setLastIteration(Exprs.LastIteration); | 
|  | Dir->setCalcLastIteration(Exprs.CalcLastIteration); | 
|  | Dir->setPreCond(Exprs.PreCond); | 
|  | Dir->setCond(Exprs.Cond); | 
|  | Dir->setInit(Exprs.Init); | 
|  | Dir->setInc(Exprs.Inc); | 
|  | Dir->setIsLastIterVariable(Exprs.IL); | 
|  | Dir->setLowerBoundVariable(Exprs.LB); | 
|  | Dir->setUpperBoundVariable(Exprs.UB); | 
|  | Dir->setStrideVariable(Exprs.ST); | 
|  | Dir->setEnsureUpperBound(Exprs.EUB); | 
|  | Dir->setNextLowerBound(Exprs.NLB); | 
|  | Dir->setNextUpperBound(Exprs.NUB); | 
|  | Dir->setNumIterations(Exprs.NumIterations); | 
|  | Dir->setCounters(Exprs.Counters); | 
|  | Dir->setPrivateCounters(Exprs.PrivateCounters); | 
|  | Dir->setInits(Exprs.Inits); | 
|  | Dir->setUpdates(Exprs.Updates); | 
|  | Dir->setFinals(Exprs.Finals); | 
|  | Dir->setPreInits(Exprs.PreInits); | 
|  | return Dir; | 
|  | } | 
|  |  | 
|  | OMPForSimdDirective *OMPForSimdDirective::CreateEmpty(const ASTContext &C, | 
|  | unsigned NumClauses, | 
|  | unsigned CollapsedNum, | 
|  | EmptyShell) { | 
|  | unsigned Size = | 
|  | llvm::alignTo(sizeof(OMPForSimdDirective), alignof(OMPClause *)); | 
|  | void *Mem = | 
|  | C.Allocate(Size + sizeof(OMPClause *) * NumClauses + | 
|  | sizeof(Stmt *) * numLoopChildren(CollapsedNum, OMPD_for_simd)); | 
|  | return new (Mem) OMPForSimdDirective(CollapsedNum, NumClauses); | 
|  | } | 
|  |  | 
|  | OMPSectionsDirective *OMPSectionsDirective::Create( | 
|  | const ASTContext &C, SourceLocation StartLoc, SourceLocation EndLoc, | 
|  | ArrayRef<OMPClause *> Clauses, Stmt *AssociatedStmt, bool HasCancel) { | 
|  | unsigned Size = | 
|  | llvm::alignTo(sizeof(OMPSectionsDirective), alignof(OMPClause *)); | 
|  | void *Mem = | 
|  | C.Allocate(Size + sizeof(OMPClause *) * Clauses.size() + sizeof(Stmt *)); | 
|  | OMPSectionsDirective *Dir = | 
|  | new (Mem) OMPSectionsDirective(StartLoc, EndLoc, Clauses.size()); | 
|  | Dir->setClauses(Clauses); | 
|  | Dir->setAssociatedStmt(AssociatedStmt); | 
|  | Dir->setHasCancel(HasCancel); | 
|  | return Dir; | 
|  | } | 
|  |  | 
|  | OMPSectionsDirective *OMPSectionsDirective::CreateEmpty(const ASTContext &C, | 
|  | unsigned NumClauses, | 
|  | EmptyShell) { | 
|  | unsigned Size = | 
|  | llvm::alignTo(sizeof(OMPSectionsDirective), alignof(OMPClause *)); | 
|  | void *Mem = | 
|  | C.Allocate(Size + sizeof(OMPClause *) * NumClauses + sizeof(Stmt *)); | 
|  | return new (Mem) OMPSectionsDirective(NumClauses); | 
|  | } | 
|  |  | 
|  | OMPSectionDirective *OMPSectionDirective::Create(const ASTContext &C, | 
|  | SourceLocation StartLoc, | 
|  | SourceLocation EndLoc, | 
|  | Stmt *AssociatedStmt, | 
|  | bool HasCancel) { | 
|  | unsigned Size = llvm::alignTo(sizeof(OMPSectionDirective), alignof(Stmt *)); | 
|  | void *Mem = C.Allocate(Size + sizeof(Stmt *)); | 
|  | OMPSectionDirective *Dir = new (Mem) OMPSectionDirective(StartLoc, EndLoc); | 
|  | Dir->setAssociatedStmt(AssociatedStmt); | 
|  | Dir->setHasCancel(HasCancel); | 
|  | return Dir; | 
|  | } | 
|  |  | 
|  | OMPSectionDirective *OMPSectionDirective::CreateEmpty(const ASTContext &C, | 
|  | EmptyShell) { | 
|  | unsigned Size = llvm::alignTo(sizeof(OMPSectionDirective), alignof(Stmt *)); | 
|  | void *Mem = C.Allocate(Size + sizeof(Stmt *)); | 
|  | return new (Mem) OMPSectionDirective(); | 
|  | } | 
|  |  | 
|  | OMPSingleDirective *OMPSingleDirective::Create(const ASTContext &C, | 
|  | SourceLocation StartLoc, | 
|  | SourceLocation EndLoc, | 
|  | ArrayRef<OMPClause *> Clauses, | 
|  | Stmt *AssociatedStmt) { | 
|  | unsigned Size = | 
|  | llvm::alignTo(sizeof(OMPSingleDirective), alignof(OMPClause *)); | 
|  | void *Mem = | 
|  | C.Allocate(Size + sizeof(OMPClause *) * Clauses.size() + sizeof(Stmt *)); | 
|  | OMPSingleDirective *Dir = | 
|  | new (Mem) OMPSingleDirective(StartLoc, EndLoc, Clauses.size()); | 
|  | Dir->setClauses(Clauses); | 
|  | Dir->setAssociatedStmt(AssociatedStmt); | 
|  | return Dir; | 
|  | } | 
|  |  | 
|  | OMPSingleDirective *OMPSingleDirective::CreateEmpty(const ASTContext &C, | 
|  | unsigned NumClauses, | 
|  | EmptyShell) { | 
|  | unsigned Size = | 
|  | llvm::alignTo(sizeof(OMPSingleDirective), alignof(OMPClause *)); | 
|  | void *Mem = | 
|  | C.Allocate(Size + sizeof(OMPClause *) * NumClauses + sizeof(Stmt *)); | 
|  | return new (Mem) OMPSingleDirective(NumClauses); | 
|  | } | 
|  |  | 
|  | OMPMasterDirective *OMPMasterDirective::Create(const ASTContext &C, | 
|  | SourceLocation StartLoc, | 
|  | SourceLocation EndLoc, | 
|  | Stmt *AssociatedStmt) { | 
|  | unsigned Size = llvm::alignTo(sizeof(OMPMasterDirective), alignof(Stmt *)); | 
|  | void *Mem = C.Allocate(Size + sizeof(Stmt *)); | 
|  | OMPMasterDirective *Dir = new (Mem) OMPMasterDirective(StartLoc, EndLoc); | 
|  | Dir->setAssociatedStmt(AssociatedStmt); | 
|  | return Dir; | 
|  | } | 
|  |  | 
|  | OMPMasterDirective *OMPMasterDirective::CreateEmpty(const ASTContext &C, | 
|  | EmptyShell) { | 
|  | unsigned Size = llvm::alignTo(sizeof(OMPMasterDirective), alignof(Stmt *)); | 
|  | void *Mem = C.Allocate(Size + sizeof(Stmt *)); | 
|  | return new (Mem) OMPMasterDirective(); | 
|  | } | 
|  |  | 
|  | OMPCriticalDirective *OMPCriticalDirective::Create( | 
|  | const ASTContext &C, const DeclarationNameInfo &Name, | 
|  | SourceLocation StartLoc, SourceLocation EndLoc, | 
|  | ArrayRef<OMPClause *> Clauses, Stmt *AssociatedStmt) { | 
|  | unsigned Size = | 
|  | llvm::alignTo(sizeof(OMPCriticalDirective), alignof(OMPClause *)); | 
|  | void *Mem = | 
|  | C.Allocate(Size + sizeof(OMPClause *) * Clauses.size() + sizeof(Stmt *)); | 
|  | OMPCriticalDirective *Dir = | 
|  | new (Mem) OMPCriticalDirective(Name, StartLoc, EndLoc, Clauses.size()); | 
|  | Dir->setClauses(Clauses); | 
|  | Dir->setAssociatedStmt(AssociatedStmt); | 
|  | return Dir; | 
|  | } | 
|  |  | 
|  | OMPCriticalDirective *OMPCriticalDirective::CreateEmpty(const ASTContext &C, | 
|  | unsigned NumClauses, | 
|  | EmptyShell) { | 
|  | unsigned Size = | 
|  | llvm::alignTo(sizeof(OMPCriticalDirective), alignof(OMPClause *)); | 
|  | void *Mem = | 
|  | C.Allocate(Size + sizeof(OMPClause *) * NumClauses + sizeof(Stmt *)); | 
|  | return new (Mem) OMPCriticalDirective(NumClauses); | 
|  | } | 
|  |  | 
|  | OMPParallelForDirective *OMPParallelForDirective::Create( | 
|  | const ASTContext &C, SourceLocation StartLoc, SourceLocation EndLoc, | 
|  | unsigned CollapsedNum, ArrayRef<OMPClause *> Clauses, Stmt *AssociatedStmt, | 
|  | const HelperExprs &Exprs, bool HasCancel) { | 
|  | unsigned Size = | 
|  | llvm::alignTo(sizeof(OMPParallelForDirective), alignof(OMPClause *)); | 
|  | void *Mem = C.Allocate(Size + sizeof(OMPClause *) * Clauses.size() + | 
|  | sizeof(Stmt *) * | 
|  | numLoopChildren(CollapsedNum, OMPD_parallel_for)); | 
|  | OMPParallelForDirective *Dir = new (Mem) | 
|  | OMPParallelForDirective(StartLoc, EndLoc, CollapsedNum, Clauses.size()); | 
|  | Dir->setClauses(Clauses); | 
|  | Dir->setAssociatedStmt(AssociatedStmt); | 
|  | Dir->setIterationVariable(Exprs.IterationVarRef); | 
|  | Dir->setLastIteration(Exprs.LastIteration); | 
|  | Dir->setCalcLastIteration(Exprs.CalcLastIteration); | 
|  | Dir->setPreCond(Exprs.PreCond); | 
|  | Dir->setCond(Exprs.Cond); | 
|  | Dir->setInit(Exprs.Init); | 
|  | Dir->setInc(Exprs.Inc); | 
|  | Dir->setIsLastIterVariable(Exprs.IL); | 
|  | Dir->setLowerBoundVariable(Exprs.LB); | 
|  | Dir->setUpperBoundVariable(Exprs.UB); | 
|  | Dir->setStrideVariable(Exprs.ST); | 
|  | Dir->setEnsureUpperBound(Exprs.EUB); | 
|  | Dir->setNextLowerBound(Exprs.NLB); | 
|  | Dir->setNextUpperBound(Exprs.NUB); | 
|  | Dir->setNumIterations(Exprs.NumIterations); | 
|  | Dir->setCounters(Exprs.Counters); | 
|  | Dir->setPrivateCounters(Exprs.PrivateCounters); | 
|  | Dir->setInits(Exprs.Inits); | 
|  | Dir->setUpdates(Exprs.Updates); | 
|  | Dir->setFinals(Exprs.Finals); | 
|  | Dir->setPreInits(Exprs.PreInits); | 
|  | Dir->setHasCancel(HasCancel); | 
|  | return Dir; | 
|  | } | 
|  |  | 
|  | OMPParallelForDirective * | 
|  | OMPParallelForDirective::CreateEmpty(const ASTContext &C, unsigned NumClauses, | 
|  | unsigned CollapsedNum, EmptyShell) { | 
|  | unsigned Size = | 
|  | llvm::alignTo(sizeof(OMPParallelForDirective), alignof(OMPClause *)); | 
|  | void *Mem = C.Allocate(Size + sizeof(OMPClause *) * NumClauses + | 
|  | sizeof(Stmt *) * | 
|  | numLoopChildren(CollapsedNum, OMPD_parallel_for)); | 
|  | return new (Mem) OMPParallelForDirective(CollapsedNum, NumClauses); | 
|  | } | 
|  |  | 
|  | OMPParallelForSimdDirective *OMPParallelForSimdDirective::Create( | 
|  | const ASTContext &C, SourceLocation StartLoc, SourceLocation EndLoc, | 
|  | unsigned CollapsedNum, ArrayRef<OMPClause *> Clauses, Stmt *AssociatedStmt, | 
|  | const HelperExprs &Exprs) { | 
|  | unsigned Size = | 
|  | llvm::alignTo(sizeof(OMPParallelForSimdDirective), alignof(OMPClause *)); | 
|  | void *Mem = C.Allocate( | 
|  | Size + sizeof(OMPClause *) * Clauses.size() + | 
|  | sizeof(Stmt *) * numLoopChildren(CollapsedNum, OMPD_parallel_for_simd)); | 
|  | OMPParallelForSimdDirective *Dir = new (Mem) OMPParallelForSimdDirective( | 
|  | StartLoc, EndLoc, CollapsedNum, Clauses.size()); | 
|  | Dir->setClauses(Clauses); | 
|  | Dir->setAssociatedStmt(AssociatedStmt); | 
|  | Dir->setIterationVariable(Exprs.IterationVarRef); | 
|  | Dir->setLastIteration(Exprs.LastIteration); | 
|  | Dir->setCalcLastIteration(Exprs.CalcLastIteration); | 
|  | Dir->setPreCond(Exprs.PreCond); | 
|  | Dir->setCond(Exprs.Cond); | 
|  | Dir->setInit(Exprs.Init); | 
|  | Dir->setInc(Exprs.Inc); | 
|  | Dir->setIsLastIterVariable(Exprs.IL); | 
|  | Dir->setLowerBoundVariable(Exprs.LB); | 
|  | Dir->setUpperBoundVariable(Exprs.UB); | 
|  | Dir->setStrideVariable(Exprs.ST); | 
|  | Dir->setEnsureUpperBound(Exprs.EUB); | 
|  | Dir->setNextLowerBound(Exprs.NLB); | 
|  | Dir->setNextUpperBound(Exprs.NUB); | 
|  | Dir->setNumIterations(Exprs.NumIterations); | 
|  | Dir->setCounters(Exprs.Counters); | 
|  | Dir->setPrivateCounters(Exprs.PrivateCounters); | 
|  | Dir->setInits(Exprs.Inits); | 
|  | Dir->setUpdates(Exprs.Updates); | 
|  | Dir->setFinals(Exprs.Finals); | 
|  | Dir->setPreInits(Exprs.PreInits); | 
|  | return Dir; | 
|  | } | 
|  |  | 
|  | OMPParallelForSimdDirective * | 
|  | OMPParallelForSimdDirective::CreateEmpty(const ASTContext &C, | 
|  | unsigned NumClauses, | 
|  | unsigned CollapsedNum, EmptyShell) { | 
|  | unsigned Size = | 
|  | llvm::alignTo(sizeof(OMPParallelForSimdDirective), alignof(OMPClause *)); | 
|  | void *Mem = C.Allocate( | 
|  | Size + sizeof(OMPClause *) * NumClauses + | 
|  | sizeof(Stmt *) * numLoopChildren(CollapsedNum, OMPD_parallel_for_simd)); | 
|  | return new (Mem) OMPParallelForSimdDirective(CollapsedNum, NumClauses); | 
|  | } | 
|  |  | 
|  | OMPParallelSectionsDirective *OMPParallelSectionsDirective::Create( | 
|  | const ASTContext &C, SourceLocation StartLoc, SourceLocation EndLoc, | 
|  | ArrayRef<OMPClause *> Clauses, Stmt *AssociatedStmt, bool HasCancel) { | 
|  | unsigned Size = | 
|  | llvm::alignTo(sizeof(OMPParallelSectionsDirective), alignof(OMPClause *)); | 
|  | void *Mem = | 
|  | C.Allocate(Size + sizeof(OMPClause *) * Clauses.size() + sizeof(Stmt *)); | 
|  | OMPParallelSectionsDirective *Dir = | 
|  | new (Mem) OMPParallelSectionsDirective(StartLoc, EndLoc, Clauses.size()); | 
|  | Dir->setClauses(Clauses); | 
|  | Dir->setAssociatedStmt(AssociatedStmt); | 
|  | Dir->setHasCancel(HasCancel); | 
|  | return Dir; | 
|  | } | 
|  |  | 
|  | OMPParallelSectionsDirective * | 
|  | OMPParallelSectionsDirective::CreateEmpty(const ASTContext &C, | 
|  | unsigned NumClauses, EmptyShell) { | 
|  | unsigned Size = | 
|  | llvm::alignTo(sizeof(OMPParallelSectionsDirective), alignof(OMPClause *)); | 
|  | void *Mem = | 
|  | C.Allocate(Size + sizeof(OMPClause *) * NumClauses + sizeof(Stmt *)); | 
|  | return new (Mem) OMPParallelSectionsDirective(NumClauses); | 
|  | } | 
|  |  | 
|  | OMPTaskDirective * | 
|  | OMPTaskDirective::Create(const ASTContext &C, SourceLocation StartLoc, | 
|  | SourceLocation EndLoc, ArrayRef<OMPClause *> Clauses, | 
|  | Stmt *AssociatedStmt, bool HasCancel) { | 
|  | unsigned Size = llvm::alignTo(sizeof(OMPTaskDirective), alignof(OMPClause *)); | 
|  | void *Mem = | 
|  | C.Allocate(Size + sizeof(OMPClause *) * Clauses.size() + sizeof(Stmt *)); | 
|  | OMPTaskDirective *Dir = | 
|  | new (Mem) OMPTaskDirective(StartLoc, EndLoc, Clauses.size()); | 
|  | Dir->setClauses(Clauses); | 
|  | Dir->setAssociatedStmt(AssociatedStmt); | 
|  | Dir->setHasCancel(HasCancel); | 
|  | return Dir; | 
|  | } | 
|  |  | 
|  | OMPTaskDirective *OMPTaskDirective::CreateEmpty(const ASTContext &C, | 
|  | unsigned NumClauses, | 
|  | EmptyShell) { | 
|  | unsigned Size = llvm::alignTo(sizeof(OMPTaskDirective), alignof(OMPClause *)); | 
|  | void *Mem = | 
|  | C.Allocate(Size + sizeof(OMPClause *) * NumClauses + sizeof(Stmt *)); | 
|  | return new (Mem) OMPTaskDirective(NumClauses); | 
|  | } | 
|  |  | 
|  | OMPTaskyieldDirective *OMPTaskyieldDirective::Create(const ASTContext &C, | 
|  | SourceLocation StartLoc, | 
|  | SourceLocation EndLoc) { | 
|  | void *Mem = C.Allocate(sizeof(OMPTaskyieldDirective)); | 
|  | OMPTaskyieldDirective *Dir = | 
|  | new (Mem) OMPTaskyieldDirective(StartLoc, EndLoc); | 
|  | return Dir; | 
|  | } | 
|  |  | 
|  | OMPTaskyieldDirective *OMPTaskyieldDirective::CreateEmpty(const ASTContext &C, | 
|  | EmptyShell) { | 
|  | void *Mem = C.Allocate(sizeof(OMPTaskyieldDirective)); | 
|  | return new (Mem) OMPTaskyieldDirective(); | 
|  | } | 
|  |  | 
|  | OMPBarrierDirective *OMPBarrierDirective::Create(const ASTContext &C, | 
|  | SourceLocation StartLoc, | 
|  | SourceLocation EndLoc) { | 
|  | void *Mem = C.Allocate(sizeof(OMPBarrierDirective)); | 
|  | OMPBarrierDirective *Dir = new (Mem) OMPBarrierDirective(StartLoc, EndLoc); | 
|  | return Dir; | 
|  | } | 
|  |  | 
|  | OMPBarrierDirective *OMPBarrierDirective::CreateEmpty(const ASTContext &C, | 
|  | EmptyShell) { | 
|  | void *Mem = C.Allocate(sizeof(OMPBarrierDirective)); | 
|  | return new (Mem) OMPBarrierDirective(); | 
|  | } | 
|  |  | 
|  | OMPTaskwaitDirective *OMPTaskwaitDirective::Create(const ASTContext &C, | 
|  | SourceLocation StartLoc, | 
|  | SourceLocation EndLoc) { | 
|  | void *Mem = C.Allocate(sizeof(OMPTaskwaitDirective)); | 
|  | OMPTaskwaitDirective *Dir = new (Mem) OMPTaskwaitDirective(StartLoc, EndLoc); | 
|  | return Dir; | 
|  | } | 
|  |  | 
|  | OMPTaskwaitDirective *OMPTaskwaitDirective::CreateEmpty(const ASTContext &C, | 
|  | EmptyShell) { | 
|  | void *Mem = C.Allocate(sizeof(OMPTaskwaitDirective)); | 
|  | return new (Mem) OMPTaskwaitDirective(); | 
|  | } | 
|  |  | 
|  | OMPTaskgroupDirective *OMPTaskgroupDirective::Create( | 
|  | const ASTContext &C, SourceLocation StartLoc, SourceLocation EndLoc, | 
|  | ArrayRef<OMPClause *> Clauses, Stmt *AssociatedStmt, Expr *ReductionRef) { | 
|  | unsigned Size = llvm::alignTo(sizeof(OMPTaskgroupDirective) + | 
|  | sizeof(OMPClause *) * Clauses.size(), | 
|  | alignof(Stmt *)); | 
|  | void *Mem = C.Allocate(Size + sizeof(Stmt *) + sizeof(Expr *)); | 
|  | OMPTaskgroupDirective *Dir = | 
|  | new (Mem) OMPTaskgroupDirective(StartLoc, EndLoc, Clauses.size()); | 
|  | Dir->setAssociatedStmt(AssociatedStmt); | 
|  | Dir->setReductionRef(ReductionRef); | 
|  | Dir->setClauses(Clauses); | 
|  | return Dir; | 
|  | } | 
|  |  | 
|  | OMPTaskgroupDirective *OMPTaskgroupDirective::CreateEmpty(const ASTContext &C, | 
|  | unsigned NumClauses, | 
|  | EmptyShell) { | 
|  | unsigned Size = llvm::alignTo(sizeof(OMPTaskgroupDirective) + | 
|  | sizeof(OMPClause *) * NumClauses, | 
|  | alignof(Stmt *)); | 
|  | void *Mem = C.Allocate(Size + sizeof(Stmt *) + sizeof(Expr *)); | 
|  | return new (Mem) OMPTaskgroupDirective(NumClauses); | 
|  | } | 
|  |  | 
|  | OMPCancellationPointDirective *OMPCancellationPointDirective::Create( | 
|  | const ASTContext &C, SourceLocation StartLoc, SourceLocation EndLoc, | 
|  | OpenMPDirectiveKind CancelRegion) { | 
|  | unsigned Size = | 
|  | llvm::alignTo(sizeof(OMPCancellationPointDirective), alignof(Stmt *)); | 
|  | void *Mem = C.Allocate(Size); | 
|  | OMPCancellationPointDirective *Dir = | 
|  | new (Mem) OMPCancellationPointDirective(StartLoc, EndLoc); | 
|  | Dir->setCancelRegion(CancelRegion); | 
|  | return Dir; | 
|  | } | 
|  |  | 
|  | OMPCancellationPointDirective * | 
|  | OMPCancellationPointDirective::CreateEmpty(const ASTContext &C, EmptyShell) { | 
|  | unsigned Size = | 
|  | llvm::alignTo(sizeof(OMPCancellationPointDirective), alignof(Stmt *)); | 
|  | void *Mem = C.Allocate(Size); | 
|  | return new (Mem) OMPCancellationPointDirective(); | 
|  | } | 
|  |  | 
|  | OMPCancelDirective * | 
|  | OMPCancelDirective::Create(const ASTContext &C, SourceLocation StartLoc, | 
|  | SourceLocation EndLoc, ArrayRef<OMPClause *> Clauses, | 
|  | OpenMPDirectiveKind CancelRegion) { | 
|  | unsigned Size = llvm::alignTo(sizeof(OMPCancelDirective) + | 
|  | sizeof(OMPClause *) * Clauses.size(), | 
|  | alignof(Stmt *)); | 
|  | void *Mem = C.Allocate(Size); | 
|  | OMPCancelDirective *Dir = | 
|  | new (Mem) OMPCancelDirective(StartLoc, EndLoc, Clauses.size()); | 
|  | Dir->setClauses(Clauses); | 
|  | Dir->setCancelRegion(CancelRegion); | 
|  | return Dir; | 
|  | } | 
|  |  | 
|  | OMPCancelDirective *OMPCancelDirective::CreateEmpty(const ASTContext &C, | 
|  | unsigned NumClauses, | 
|  | EmptyShell) { | 
|  | unsigned Size = llvm::alignTo(sizeof(OMPCancelDirective) + | 
|  | sizeof(OMPClause *) * NumClauses, | 
|  | alignof(Stmt *)); | 
|  | void *Mem = C.Allocate(Size); | 
|  | return new (Mem) OMPCancelDirective(NumClauses); | 
|  | } | 
|  |  | 
|  | OMPFlushDirective *OMPFlushDirective::Create(const ASTContext &C, | 
|  | SourceLocation StartLoc, | 
|  | SourceLocation EndLoc, | 
|  | ArrayRef<OMPClause *> Clauses) { | 
|  | unsigned Size = | 
|  | llvm::alignTo(sizeof(OMPFlushDirective), alignof(OMPClause *)); | 
|  | void *Mem = C.Allocate(Size + sizeof(OMPClause *) * Clauses.size()); | 
|  | OMPFlushDirective *Dir = | 
|  | new (Mem) OMPFlushDirective(StartLoc, EndLoc, Clauses.size()); | 
|  | Dir->setClauses(Clauses); | 
|  | return Dir; | 
|  | } | 
|  |  | 
|  | OMPFlushDirective *OMPFlushDirective::CreateEmpty(const ASTContext &C, | 
|  | unsigned NumClauses, | 
|  | EmptyShell) { | 
|  | unsigned Size = | 
|  | llvm::alignTo(sizeof(OMPFlushDirective), alignof(OMPClause *)); | 
|  | void *Mem = C.Allocate(Size + sizeof(OMPClause *) * NumClauses); | 
|  | return new (Mem) OMPFlushDirective(NumClauses); | 
|  | } | 
|  |  | 
|  | OMPOrderedDirective *OMPOrderedDirective::Create(const ASTContext &C, | 
|  | SourceLocation StartLoc, | 
|  | SourceLocation EndLoc, | 
|  | ArrayRef<OMPClause *> Clauses, | 
|  | Stmt *AssociatedStmt) { | 
|  | unsigned Size = | 
|  | llvm::alignTo(sizeof(OMPOrderedDirective), alignof(OMPClause *)); | 
|  | void *Mem = | 
|  | C.Allocate(Size + sizeof(Stmt *) + sizeof(OMPClause *) * Clauses.size()); | 
|  | OMPOrderedDirective *Dir = | 
|  | new (Mem) OMPOrderedDirective(StartLoc, EndLoc, Clauses.size()); | 
|  | Dir->setClauses(Clauses); | 
|  | Dir->setAssociatedStmt(AssociatedStmt); | 
|  | return Dir; | 
|  | } | 
|  |  | 
|  | OMPOrderedDirective *OMPOrderedDirective::CreateEmpty(const ASTContext &C, | 
|  | unsigned NumClauses, | 
|  | EmptyShell) { | 
|  | unsigned Size = | 
|  | llvm::alignTo(sizeof(OMPOrderedDirective), alignof(OMPClause *)); | 
|  | void *Mem = | 
|  | C.Allocate(Size + sizeof(Stmt *) + sizeof(OMPClause *) * NumClauses); | 
|  | return new (Mem) OMPOrderedDirective(NumClauses); | 
|  | } | 
|  |  | 
|  | OMPAtomicDirective *OMPAtomicDirective::Create( | 
|  | const ASTContext &C, SourceLocation StartLoc, SourceLocation EndLoc, | 
|  | ArrayRef<OMPClause *> Clauses, Stmt *AssociatedStmt, Expr *X, Expr *V, | 
|  | Expr *E, Expr *UE, bool IsXLHSInRHSPart, bool IsPostfixUpdate) { | 
|  | unsigned Size = | 
|  | llvm::alignTo(sizeof(OMPAtomicDirective), alignof(OMPClause *)); | 
|  | void *Mem = C.Allocate(Size + sizeof(OMPClause *) * Clauses.size() + | 
|  | 5 * sizeof(Stmt *)); | 
|  | OMPAtomicDirective *Dir = | 
|  | new (Mem) OMPAtomicDirective(StartLoc, EndLoc, Clauses.size()); | 
|  | Dir->setClauses(Clauses); | 
|  | Dir->setAssociatedStmt(AssociatedStmt); | 
|  | Dir->setX(X); | 
|  | Dir->setV(V); | 
|  | Dir->setExpr(E); | 
|  | Dir->setUpdateExpr(UE); | 
|  | Dir->IsXLHSInRHSPart = IsXLHSInRHSPart; | 
|  | Dir->IsPostfixUpdate = IsPostfixUpdate; | 
|  | return Dir; | 
|  | } | 
|  |  | 
|  | OMPAtomicDirective *OMPAtomicDirective::CreateEmpty(const ASTContext &C, | 
|  | unsigned NumClauses, | 
|  | EmptyShell) { | 
|  | unsigned Size = | 
|  | llvm::alignTo(sizeof(OMPAtomicDirective), alignof(OMPClause *)); | 
|  | void *Mem = | 
|  | C.Allocate(Size + sizeof(OMPClause *) * NumClauses + 5 * sizeof(Stmt *)); | 
|  | return new (Mem) OMPAtomicDirective(NumClauses); | 
|  | } | 
|  |  | 
|  | OMPTargetDirective *OMPTargetDirective::Create(const ASTContext &C, | 
|  | SourceLocation StartLoc, | 
|  | SourceLocation EndLoc, | 
|  | ArrayRef<OMPClause *> Clauses, | 
|  | Stmt *AssociatedStmt) { | 
|  | unsigned Size = | 
|  | llvm::alignTo(sizeof(OMPTargetDirective), alignof(OMPClause *)); | 
|  | void *Mem = | 
|  | C.Allocate(Size + sizeof(OMPClause *) * Clauses.size() + sizeof(Stmt *)); | 
|  | OMPTargetDirective *Dir = | 
|  | new (Mem) OMPTargetDirective(StartLoc, EndLoc, Clauses.size()); | 
|  | Dir->setClauses(Clauses); | 
|  | Dir->setAssociatedStmt(AssociatedStmt); | 
|  | return Dir; | 
|  | } | 
|  |  | 
|  | OMPTargetDirective *OMPTargetDirective::CreateEmpty(const ASTContext &C, | 
|  | unsigned NumClauses, | 
|  | EmptyShell) { | 
|  | unsigned Size = | 
|  | llvm::alignTo(sizeof(OMPTargetDirective), alignof(OMPClause *)); | 
|  | void *Mem = | 
|  | C.Allocate(Size + sizeof(OMPClause *) * NumClauses + sizeof(Stmt *)); | 
|  | return new (Mem) OMPTargetDirective(NumClauses); | 
|  | } | 
|  |  | 
|  | OMPTargetParallelDirective *OMPTargetParallelDirective::Create( | 
|  | const ASTContext &C, SourceLocation StartLoc, SourceLocation EndLoc, | 
|  | ArrayRef<OMPClause *> Clauses, Stmt *AssociatedStmt) { | 
|  | unsigned Size = | 
|  | llvm::alignTo(sizeof(OMPTargetParallelDirective), alignof(OMPClause *)); | 
|  | void *Mem = | 
|  | C.Allocate(Size + sizeof(OMPClause *) * Clauses.size() + sizeof(Stmt *)); | 
|  | OMPTargetParallelDirective *Dir = | 
|  | new (Mem) OMPTargetParallelDirective(StartLoc, EndLoc, Clauses.size()); | 
|  | Dir->setClauses(Clauses); | 
|  | Dir->setAssociatedStmt(AssociatedStmt); | 
|  | return Dir; | 
|  | } | 
|  |  | 
|  | OMPTargetParallelDirective * | 
|  | OMPTargetParallelDirective::CreateEmpty(const ASTContext &C, | 
|  | unsigned NumClauses, EmptyShell) { | 
|  | unsigned Size = | 
|  | llvm::alignTo(sizeof(OMPTargetParallelDirective), alignof(OMPClause *)); | 
|  | void *Mem = | 
|  | C.Allocate(Size + sizeof(OMPClause *) * NumClauses + sizeof(Stmt *)); | 
|  | return new (Mem) OMPTargetParallelDirective(NumClauses); | 
|  | } | 
|  |  | 
|  | OMPTargetParallelForDirective *OMPTargetParallelForDirective::Create( | 
|  | const ASTContext &C, SourceLocation StartLoc, SourceLocation EndLoc, | 
|  | unsigned CollapsedNum, ArrayRef<OMPClause *> Clauses, Stmt *AssociatedStmt, | 
|  | const HelperExprs &Exprs, bool HasCancel) { | 
|  | unsigned Size = llvm::alignTo(sizeof(OMPTargetParallelForDirective), | 
|  | alignof(OMPClause *)); | 
|  | void *Mem = C.Allocate( | 
|  | Size + sizeof(OMPClause *) * Clauses.size() + | 
|  | sizeof(Stmt *) * numLoopChildren(CollapsedNum, OMPD_target_parallel_for)); | 
|  | OMPTargetParallelForDirective *Dir = new (Mem) OMPTargetParallelForDirective( | 
|  | StartLoc, EndLoc, CollapsedNum, Clauses.size()); | 
|  | Dir->setClauses(Clauses); | 
|  | Dir->setAssociatedStmt(AssociatedStmt); | 
|  | Dir->setIterationVariable(Exprs.IterationVarRef); | 
|  | Dir->setLastIteration(Exprs.LastIteration); | 
|  | Dir->setCalcLastIteration(Exprs.CalcLastIteration); | 
|  | Dir->setPreCond(Exprs.PreCond); | 
|  | Dir->setCond(Exprs.Cond); | 
|  | Dir->setInit(Exprs.Init); | 
|  | Dir->setInc(Exprs.Inc); | 
|  | Dir->setIsLastIterVariable(Exprs.IL); | 
|  | Dir->setLowerBoundVariable(Exprs.LB); | 
|  | Dir->setUpperBoundVariable(Exprs.UB); | 
|  | Dir->setStrideVariable(Exprs.ST); | 
|  | Dir->setEnsureUpperBound(Exprs.EUB); | 
|  | Dir->setNextLowerBound(Exprs.NLB); | 
|  | Dir->setNextUpperBound(Exprs.NUB); | 
|  | Dir->setNumIterations(Exprs.NumIterations); | 
|  | Dir->setCounters(Exprs.Counters); | 
|  | Dir->setPrivateCounters(Exprs.PrivateCounters); | 
|  | Dir->setInits(Exprs.Inits); | 
|  | Dir->setUpdates(Exprs.Updates); | 
|  | Dir->setFinals(Exprs.Finals); | 
|  | Dir->setPreInits(Exprs.PreInits); | 
|  | Dir->setHasCancel(HasCancel); | 
|  | return Dir; | 
|  | } | 
|  |  | 
|  | OMPTargetParallelForDirective * | 
|  | OMPTargetParallelForDirective::CreateEmpty(const ASTContext &C, | 
|  | unsigned NumClauses, | 
|  | unsigned CollapsedNum, EmptyShell) { | 
|  | unsigned Size = llvm::alignTo(sizeof(OMPTargetParallelForDirective), | 
|  | alignof(OMPClause *)); | 
|  | void *Mem = C.Allocate( | 
|  | Size + sizeof(OMPClause *) * NumClauses + | 
|  | sizeof(Stmt *) * numLoopChildren(CollapsedNum, OMPD_target_parallel_for)); | 
|  | return new (Mem) OMPTargetParallelForDirective(CollapsedNum, NumClauses); | 
|  | } | 
|  |  | 
|  | OMPTargetDataDirective *OMPTargetDataDirective::Create( | 
|  | const ASTContext &C, SourceLocation StartLoc, SourceLocation EndLoc, | 
|  | ArrayRef<OMPClause *> Clauses, Stmt *AssociatedStmt) { | 
|  | void *Mem = C.Allocate( | 
|  | llvm::alignTo(sizeof(OMPTargetDataDirective), alignof(OMPClause *)) + | 
|  | sizeof(OMPClause *) * Clauses.size() + sizeof(Stmt *)); | 
|  | OMPTargetDataDirective *Dir = | 
|  | new (Mem) OMPTargetDataDirective(StartLoc, EndLoc, Clauses.size()); | 
|  | Dir->setClauses(Clauses); | 
|  | Dir->setAssociatedStmt(AssociatedStmt); | 
|  | return Dir; | 
|  | } | 
|  |  | 
|  | OMPTargetDataDirective *OMPTargetDataDirective::CreateEmpty(const ASTContext &C, | 
|  | unsigned N, | 
|  | EmptyShell) { | 
|  | void *Mem = C.Allocate( | 
|  | llvm::alignTo(sizeof(OMPTargetDataDirective), alignof(OMPClause *)) + | 
|  | sizeof(OMPClause *) * N + sizeof(Stmt *)); | 
|  | return new (Mem) OMPTargetDataDirective(N); | 
|  | } | 
|  |  | 
|  | OMPTargetEnterDataDirective *OMPTargetEnterDataDirective::Create( | 
|  | const ASTContext &C, SourceLocation StartLoc, SourceLocation EndLoc, | 
|  | ArrayRef<OMPClause *> Clauses, Stmt *AssociatedStmt) { | 
|  | void *Mem = C.Allocate( | 
|  | llvm::alignTo(sizeof(OMPTargetEnterDataDirective), alignof(OMPClause *)) + | 
|  | sizeof(OMPClause *) * Clauses.size() + sizeof(Stmt *)); | 
|  | OMPTargetEnterDataDirective *Dir = | 
|  | new (Mem) OMPTargetEnterDataDirective(StartLoc, EndLoc, Clauses.size()); | 
|  | Dir->setClauses(Clauses); | 
|  | Dir->setAssociatedStmt(AssociatedStmt); | 
|  | return Dir; | 
|  | } | 
|  |  | 
|  | OMPTargetEnterDataDirective * | 
|  | OMPTargetEnterDataDirective::CreateEmpty(const ASTContext &C, unsigned N, | 
|  | EmptyShell) { | 
|  | void *Mem = C.Allocate( | 
|  | llvm::alignTo(sizeof(OMPTargetEnterDataDirective), alignof(OMPClause *)) + | 
|  | sizeof(OMPClause *) * N + sizeof(Stmt *)); | 
|  | return new (Mem) OMPTargetEnterDataDirective(N); | 
|  | } | 
|  |  | 
|  | OMPTargetExitDataDirective *OMPTargetExitDataDirective::Create( | 
|  | const ASTContext &C, SourceLocation StartLoc, SourceLocation EndLoc, | 
|  | ArrayRef<OMPClause *> Clauses, Stmt *AssociatedStmt) { | 
|  | void *Mem = C.Allocate( | 
|  | llvm::alignTo(sizeof(OMPTargetExitDataDirective), alignof(OMPClause *)) + | 
|  | sizeof(OMPClause *) * Clauses.size() + sizeof(Stmt *)); | 
|  | OMPTargetExitDataDirective *Dir = | 
|  | new (Mem) OMPTargetExitDataDirective(StartLoc, EndLoc, Clauses.size()); | 
|  | Dir->setClauses(Clauses); | 
|  | Dir->setAssociatedStmt(AssociatedStmt); | 
|  | return Dir; | 
|  | } | 
|  |  | 
|  | OMPTargetExitDataDirective * | 
|  | OMPTargetExitDataDirective::CreateEmpty(const ASTContext &C, unsigned N, | 
|  | EmptyShell) { | 
|  | void *Mem = C.Allocate( | 
|  | llvm::alignTo(sizeof(OMPTargetExitDataDirective), alignof(OMPClause *)) + | 
|  | sizeof(OMPClause *) * N + sizeof(Stmt *)); | 
|  | return new (Mem) OMPTargetExitDataDirective(N); | 
|  | } | 
|  |  | 
|  | OMPTeamsDirective *OMPTeamsDirective::Create(const ASTContext &C, | 
|  | SourceLocation StartLoc, | 
|  | SourceLocation EndLoc, | 
|  | ArrayRef<OMPClause *> Clauses, | 
|  | Stmt *AssociatedStmt) { | 
|  | unsigned Size = | 
|  | llvm::alignTo(sizeof(OMPTeamsDirective), alignof(OMPClause *)); | 
|  | void *Mem = | 
|  | C.Allocate(Size + sizeof(OMPClause *) * Clauses.size() + sizeof(Stmt *)); | 
|  | OMPTeamsDirective *Dir = | 
|  | new (Mem) OMPTeamsDirective(StartLoc, EndLoc, Clauses.size()); | 
|  | Dir->setClauses(Clauses); | 
|  | Dir->setAssociatedStmt(AssociatedStmt); | 
|  | return Dir; | 
|  | } | 
|  |  | 
|  | OMPTeamsDirective *OMPTeamsDirective::CreateEmpty(const ASTContext &C, | 
|  | unsigned NumClauses, | 
|  | EmptyShell) { | 
|  | unsigned Size = | 
|  | llvm::alignTo(sizeof(OMPTeamsDirective), alignof(OMPClause *)); | 
|  | void *Mem = | 
|  | C.Allocate(Size + sizeof(OMPClause *) * NumClauses + sizeof(Stmt *)); | 
|  | return new (Mem) OMPTeamsDirective(NumClauses); | 
|  | } | 
|  |  | 
|  | OMPTaskLoopDirective *OMPTaskLoopDirective::Create( | 
|  | const ASTContext &C, SourceLocation StartLoc, SourceLocation EndLoc, | 
|  | unsigned CollapsedNum, ArrayRef<OMPClause *> Clauses, Stmt *AssociatedStmt, | 
|  | const HelperExprs &Exprs) { | 
|  | unsigned Size = | 
|  | llvm::alignTo(sizeof(OMPTaskLoopDirective), alignof(OMPClause *)); | 
|  | void *Mem = | 
|  | C.Allocate(Size + sizeof(OMPClause *) * Clauses.size() + | 
|  | sizeof(Stmt *) * numLoopChildren(CollapsedNum, OMPD_taskloop)); | 
|  | OMPTaskLoopDirective *Dir = new (Mem) | 
|  | OMPTaskLoopDirective(StartLoc, EndLoc, CollapsedNum, Clauses.size()); | 
|  | Dir->setClauses(Clauses); | 
|  | Dir->setAssociatedStmt(AssociatedStmt); | 
|  | Dir->setIterationVariable(Exprs.IterationVarRef); | 
|  | Dir->setLastIteration(Exprs.LastIteration); | 
|  | Dir->setCalcLastIteration(Exprs.CalcLastIteration); | 
|  | Dir->setPreCond(Exprs.PreCond); | 
|  | Dir->setCond(Exprs.Cond); | 
|  | Dir->setInit(Exprs.Init); | 
|  | Dir->setInc(Exprs.Inc); | 
|  | Dir->setIsLastIterVariable(Exprs.IL); | 
|  | Dir->setLowerBoundVariable(Exprs.LB); | 
|  | Dir->setUpperBoundVariable(Exprs.UB); | 
|  | Dir->setStrideVariable(Exprs.ST); | 
|  | Dir->setEnsureUpperBound(Exprs.EUB); | 
|  | Dir->setNextLowerBound(Exprs.NLB); | 
|  | Dir->setNextUpperBound(Exprs.NUB); | 
|  | Dir->setNumIterations(Exprs.NumIterations); | 
|  | Dir->setCounters(Exprs.Counters); | 
|  | Dir->setPrivateCounters(Exprs.PrivateCounters); | 
|  | Dir->setInits(Exprs.Inits); | 
|  | Dir->setUpdates(Exprs.Updates); | 
|  | Dir->setFinals(Exprs.Finals); | 
|  | Dir->setPreInits(Exprs.PreInits); | 
|  | return Dir; | 
|  | } | 
|  |  | 
|  | OMPTaskLoopDirective *OMPTaskLoopDirective::CreateEmpty(const ASTContext &C, | 
|  | unsigned NumClauses, | 
|  | unsigned CollapsedNum, | 
|  | EmptyShell) { | 
|  | unsigned Size = | 
|  | llvm::alignTo(sizeof(OMPTaskLoopDirective), alignof(OMPClause *)); | 
|  | void *Mem = | 
|  | C.Allocate(Size + sizeof(OMPClause *) * NumClauses + | 
|  | sizeof(Stmt *) * numLoopChildren(CollapsedNum, OMPD_taskloop)); | 
|  | return new (Mem) OMPTaskLoopDirective(CollapsedNum, NumClauses); | 
|  | } | 
|  |  | 
|  | OMPTaskLoopSimdDirective *OMPTaskLoopSimdDirective::Create( | 
|  | const ASTContext &C, SourceLocation StartLoc, SourceLocation EndLoc, | 
|  | unsigned CollapsedNum, ArrayRef<OMPClause *> Clauses, Stmt *AssociatedStmt, | 
|  | const HelperExprs &Exprs) { | 
|  | unsigned Size = | 
|  | llvm::alignTo(sizeof(OMPTaskLoopSimdDirective), alignof(OMPClause *)); | 
|  | void *Mem = C.Allocate(Size + sizeof(OMPClause *) * Clauses.size() + | 
|  | sizeof(Stmt *) * | 
|  | numLoopChildren(CollapsedNum, OMPD_taskloop_simd)); | 
|  | OMPTaskLoopSimdDirective *Dir = new (Mem) | 
|  | OMPTaskLoopSimdDirective(StartLoc, EndLoc, CollapsedNum, Clauses.size()); | 
|  | Dir->setClauses(Clauses); | 
|  | Dir->setAssociatedStmt(AssociatedStmt); | 
|  | Dir->setIterationVariable(Exprs.IterationVarRef); | 
|  | Dir->setLastIteration(Exprs.LastIteration); | 
|  | Dir->setCalcLastIteration(Exprs.CalcLastIteration); | 
|  | Dir->setPreCond(Exprs.PreCond); | 
|  | Dir->setCond(Exprs.Cond); | 
|  | Dir->setInit(Exprs.Init); | 
|  | Dir->setInc(Exprs.Inc); | 
|  | Dir->setIsLastIterVariable(Exprs.IL); | 
|  | Dir->setLowerBoundVariable(Exprs.LB); | 
|  | Dir->setUpperBoundVariable(Exprs.UB); | 
|  | Dir->setStrideVariable(Exprs.ST); | 
|  | Dir->setEnsureUpperBound(Exprs.EUB); | 
|  | Dir->setNextLowerBound(Exprs.NLB); | 
|  | Dir->setNextUpperBound(Exprs.NUB); | 
|  | Dir->setNumIterations(Exprs.NumIterations); | 
|  | Dir->setCounters(Exprs.Counters); | 
|  | Dir->setPrivateCounters(Exprs.PrivateCounters); | 
|  | Dir->setInits(Exprs.Inits); | 
|  | Dir->setUpdates(Exprs.Updates); | 
|  | Dir->setFinals(Exprs.Finals); | 
|  | Dir->setPreInits(Exprs.PreInits); | 
|  | return Dir; | 
|  | } | 
|  |  | 
|  | OMPTaskLoopSimdDirective * | 
|  | OMPTaskLoopSimdDirective::CreateEmpty(const ASTContext &C, unsigned NumClauses, | 
|  | unsigned CollapsedNum, EmptyShell) { | 
|  | unsigned Size = | 
|  | llvm::alignTo(sizeof(OMPTaskLoopSimdDirective), alignof(OMPClause *)); | 
|  | void *Mem = C.Allocate(Size + sizeof(OMPClause *) * NumClauses + | 
|  | sizeof(Stmt *) * | 
|  | numLoopChildren(CollapsedNum, OMPD_taskloop_simd)); | 
|  | return new (Mem) OMPTaskLoopSimdDirective(CollapsedNum, NumClauses); | 
|  | } | 
|  |  | 
|  | OMPDistributeDirective *OMPDistributeDirective::Create( | 
|  | const ASTContext &C, SourceLocation StartLoc, SourceLocation EndLoc, | 
|  | unsigned CollapsedNum, ArrayRef<OMPClause *> Clauses, Stmt *AssociatedStmt, | 
|  | const HelperExprs &Exprs) { | 
|  | unsigned Size = | 
|  | llvm::alignTo(sizeof(OMPDistributeDirective), alignof(OMPClause *)); | 
|  | void *Mem = C.Allocate(Size + sizeof(OMPClause *) * Clauses.size() + | 
|  | sizeof(Stmt *) * | 
|  | numLoopChildren(CollapsedNum, OMPD_distribute)); | 
|  | OMPDistributeDirective *Dir = new (Mem) | 
|  | OMPDistributeDirective(StartLoc, EndLoc, CollapsedNum, Clauses.size()); | 
|  | Dir->setClauses(Clauses); | 
|  | Dir->setAssociatedStmt(AssociatedStmt); | 
|  | Dir->setIterationVariable(Exprs.IterationVarRef); | 
|  | Dir->setLastIteration(Exprs.LastIteration); | 
|  | Dir->setCalcLastIteration(Exprs.CalcLastIteration); | 
|  | Dir->setPreCond(Exprs.PreCond); | 
|  | Dir->setCond(Exprs.Cond); | 
|  | Dir->setInit(Exprs.Init); | 
|  | Dir->setInc(Exprs.Inc); | 
|  | Dir->setIsLastIterVariable(Exprs.IL); | 
|  | Dir->setLowerBoundVariable(Exprs.LB); | 
|  | Dir->setUpperBoundVariable(Exprs.UB); | 
|  | Dir->setStrideVariable(Exprs.ST); | 
|  | Dir->setEnsureUpperBound(Exprs.EUB); | 
|  | Dir->setNextLowerBound(Exprs.NLB); | 
|  | Dir->setNextUpperBound(Exprs.NUB); | 
|  | Dir->setNumIterations(Exprs.NumIterations); | 
|  | Dir->setCounters(Exprs.Counters); | 
|  | Dir->setPrivateCounters(Exprs.PrivateCounters); | 
|  | Dir->setInits(Exprs.Inits); | 
|  | Dir->setUpdates(Exprs.Updates); | 
|  | Dir->setFinals(Exprs.Finals); | 
|  | Dir->setPreInits(Exprs.PreInits); | 
|  | return Dir; | 
|  | } | 
|  |  | 
|  | OMPDistributeDirective * | 
|  | OMPDistributeDirective::CreateEmpty(const ASTContext &C, unsigned NumClauses, | 
|  | unsigned CollapsedNum, EmptyShell) { | 
|  | unsigned Size = | 
|  | llvm::alignTo(sizeof(OMPDistributeDirective), alignof(OMPClause *)); | 
|  | void *Mem = C.Allocate(Size + sizeof(OMPClause *) * NumClauses + | 
|  | sizeof(Stmt *) * | 
|  | numLoopChildren(CollapsedNum, OMPD_distribute)); | 
|  | return new (Mem) OMPDistributeDirective(CollapsedNum, NumClauses); | 
|  | } | 
|  |  | 
|  | OMPTargetUpdateDirective *OMPTargetUpdateDirective::Create( | 
|  | const ASTContext &C, SourceLocation StartLoc, SourceLocation EndLoc, | 
|  | ArrayRef<OMPClause *> Clauses, Stmt *AssociatedStmt) { | 
|  | unsigned Size = | 
|  | llvm::alignTo(sizeof(OMPTargetUpdateDirective), alignof(OMPClause *)); | 
|  | void *Mem = | 
|  | C.Allocate(Size + sizeof(OMPClause *) * Clauses.size() + sizeof(Stmt *)); | 
|  | OMPTargetUpdateDirective *Dir = | 
|  | new (Mem) OMPTargetUpdateDirective(StartLoc, EndLoc, Clauses.size()); | 
|  | Dir->setClauses(Clauses); | 
|  | Dir->setAssociatedStmt(AssociatedStmt); | 
|  | return Dir; | 
|  | } | 
|  |  | 
|  | OMPTargetUpdateDirective * | 
|  | OMPTargetUpdateDirective::CreateEmpty(const ASTContext &C, unsigned NumClauses, | 
|  | EmptyShell) { | 
|  | unsigned Size = | 
|  | llvm::alignTo(sizeof(OMPTargetUpdateDirective), alignof(OMPClause *)); | 
|  | void *Mem = | 
|  | C.Allocate(Size + sizeof(OMPClause *) * NumClauses + sizeof(Stmt *)); | 
|  | return new (Mem) OMPTargetUpdateDirective(NumClauses); | 
|  | } | 
|  |  | 
|  | OMPDistributeParallelForDirective *OMPDistributeParallelForDirective::Create( | 
|  | const ASTContext &C, SourceLocation StartLoc, SourceLocation EndLoc, | 
|  | unsigned CollapsedNum, ArrayRef<OMPClause *> Clauses, Stmt *AssociatedStmt, | 
|  | const HelperExprs &Exprs, bool HasCancel) { | 
|  | unsigned Size = llvm::alignTo(sizeof(OMPDistributeParallelForDirective), | 
|  | alignof(OMPClause *)); | 
|  | void *Mem = C.Allocate( | 
|  | Size + sizeof(OMPClause *) * Clauses.size() + | 
|  | sizeof(Stmt *) * | 
|  | numLoopChildren(CollapsedNum, OMPD_distribute_parallel_for)); | 
|  | OMPDistributeParallelForDirective *Dir = | 
|  | new (Mem) OMPDistributeParallelForDirective(StartLoc, EndLoc, | 
|  | CollapsedNum, Clauses.size()); | 
|  | Dir->setClauses(Clauses); | 
|  | Dir->setAssociatedStmt(AssociatedStmt); | 
|  | Dir->setIterationVariable(Exprs.IterationVarRef); | 
|  | Dir->setLastIteration(Exprs.LastIteration); | 
|  | Dir->setCalcLastIteration(Exprs.CalcLastIteration); | 
|  | Dir->setPreCond(Exprs.PreCond); | 
|  | Dir->setCond(Exprs.Cond); | 
|  | Dir->setInit(Exprs.Init); | 
|  | Dir->setInc(Exprs.Inc); | 
|  | Dir->setIsLastIterVariable(Exprs.IL); | 
|  | Dir->setLowerBoundVariable(Exprs.LB); | 
|  | Dir->setUpperBoundVariable(Exprs.UB); | 
|  | Dir->setStrideVariable(Exprs.ST); | 
|  | Dir->setEnsureUpperBound(Exprs.EUB); | 
|  | Dir->setNextLowerBound(Exprs.NLB); | 
|  | Dir->setNextUpperBound(Exprs.NUB); | 
|  | Dir->setNumIterations(Exprs.NumIterations); | 
|  | Dir->setPrevLowerBoundVariable(Exprs.PrevLB); | 
|  | Dir->setPrevUpperBoundVariable(Exprs.PrevUB); | 
|  | Dir->setDistInc(Exprs.DistInc); | 
|  | Dir->setPrevEnsureUpperBound(Exprs.PrevEUB); | 
|  | Dir->setCounters(Exprs.Counters); | 
|  | Dir->setPrivateCounters(Exprs.PrivateCounters); | 
|  | Dir->setInits(Exprs.Inits); | 
|  | Dir->setUpdates(Exprs.Updates); | 
|  | Dir->setFinals(Exprs.Finals); | 
|  | Dir->setPreInits(Exprs.PreInits); | 
|  | Dir->setCombinedLowerBoundVariable(Exprs.DistCombinedFields.LB); | 
|  | Dir->setCombinedUpperBoundVariable(Exprs.DistCombinedFields.UB); | 
|  | Dir->setCombinedEnsureUpperBound(Exprs.DistCombinedFields.EUB); | 
|  | Dir->setCombinedInit(Exprs.DistCombinedFields.Init); | 
|  | Dir->setCombinedCond(Exprs.DistCombinedFields.Cond); | 
|  | Dir->setCombinedNextLowerBound(Exprs.DistCombinedFields.NLB); | 
|  | Dir->setCombinedNextUpperBound(Exprs.DistCombinedFields.NUB); | 
|  | Dir->HasCancel = HasCancel; | 
|  | return Dir; | 
|  | } | 
|  |  | 
|  | OMPDistributeParallelForDirective * | 
|  | OMPDistributeParallelForDirective::CreateEmpty(const ASTContext &C, | 
|  | unsigned NumClauses, | 
|  | unsigned CollapsedNum, | 
|  | EmptyShell) { | 
|  | unsigned Size = llvm::alignTo(sizeof(OMPDistributeParallelForDirective), | 
|  | alignof(OMPClause *)); | 
|  | void *Mem = C.Allocate( | 
|  | Size + sizeof(OMPClause *) * NumClauses + | 
|  | sizeof(Stmt *) * | 
|  | numLoopChildren(CollapsedNum, OMPD_distribute_parallel_for)); | 
|  | return new (Mem) OMPDistributeParallelForDirective(CollapsedNum, NumClauses); | 
|  | } | 
|  |  | 
|  | OMPDistributeParallelForSimdDirective * | 
|  | OMPDistributeParallelForSimdDirective::Create( | 
|  | const ASTContext &C, SourceLocation StartLoc, SourceLocation EndLoc, | 
|  | unsigned CollapsedNum, ArrayRef<OMPClause *> Clauses, Stmt *AssociatedStmt, | 
|  | const HelperExprs &Exprs) { | 
|  | unsigned Size = llvm::alignTo(sizeof(OMPDistributeParallelForSimdDirective), | 
|  | alignof(OMPClause *)); | 
|  | void *Mem = C.Allocate( | 
|  | Size + sizeof(OMPClause *) * Clauses.size() + | 
|  | sizeof(Stmt *) * | 
|  | numLoopChildren(CollapsedNum, OMPD_distribute_parallel_for_simd)); | 
|  | OMPDistributeParallelForSimdDirective *Dir = new (Mem) | 
|  | OMPDistributeParallelForSimdDirective(StartLoc, EndLoc, CollapsedNum, | 
|  | Clauses.size()); | 
|  | Dir->setClauses(Clauses); | 
|  | Dir->setAssociatedStmt(AssociatedStmt); | 
|  | Dir->setIterationVariable(Exprs.IterationVarRef); | 
|  | Dir->setLastIteration(Exprs.LastIteration); | 
|  | Dir->setCalcLastIteration(Exprs.CalcLastIteration); | 
|  | Dir->setPreCond(Exprs.PreCond); | 
|  | Dir->setCond(Exprs.Cond); | 
|  | Dir->setInit(Exprs.Init); | 
|  | Dir->setInc(Exprs.Inc); | 
|  | Dir->setIsLastIterVariable(Exprs.IL); | 
|  | Dir->setLowerBoundVariable(Exprs.LB); | 
|  | Dir->setUpperBoundVariable(Exprs.UB); | 
|  | Dir->setStrideVariable(Exprs.ST); | 
|  | Dir->setEnsureUpperBound(Exprs.EUB); | 
|  | Dir->setNextLowerBound(Exprs.NLB); | 
|  | Dir->setNextUpperBound(Exprs.NUB); | 
|  | Dir->setNumIterations(Exprs.NumIterations); | 
|  | Dir->setPrevLowerBoundVariable(Exprs.PrevLB); | 
|  | Dir->setPrevUpperBoundVariable(Exprs.PrevUB); | 
|  | Dir->setDistInc(Exprs.DistInc); | 
|  | Dir->setPrevEnsureUpperBound(Exprs.PrevEUB); | 
|  | Dir->setCounters(Exprs.Counters); | 
|  | Dir->setPrivateCounters(Exprs.PrivateCounters); | 
|  | Dir->setInits(Exprs.Inits); | 
|  | Dir->setUpdates(Exprs.Updates); | 
|  | Dir->setFinals(Exprs.Finals); | 
|  | Dir->setPreInits(Exprs.PreInits); | 
|  | Dir->setCombinedLowerBoundVariable(Exprs.DistCombinedFields.LB); | 
|  | Dir->setCombinedUpperBoundVariable(Exprs.DistCombinedFields.UB); | 
|  | Dir->setCombinedEnsureUpperBound(Exprs.DistCombinedFields.EUB); | 
|  | Dir->setCombinedInit(Exprs.DistCombinedFields.Init); | 
|  | Dir->setCombinedCond(Exprs.DistCombinedFields.Cond); | 
|  | Dir->setCombinedNextLowerBound(Exprs.DistCombinedFields.NLB); | 
|  | Dir->setCombinedNextUpperBound(Exprs.DistCombinedFields.NUB); | 
|  | return Dir; | 
|  | } | 
|  |  | 
|  | OMPDistributeParallelForSimdDirective * | 
|  | OMPDistributeParallelForSimdDirective::CreateEmpty(const ASTContext &C, | 
|  | unsigned NumClauses, | 
|  | unsigned CollapsedNum, | 
|  | EmptyShell) { | 
|  | unsigned Size = llvm::alignTo(sizeof(OMPDistributeParallelForSimdDirective), | 
|  | alignof(OMPClause *)); | 
|  | void *Mem = C.Allocate( | 
|  | Size + sizeof(OMPClause *) * NumClauses + | 
|  | sizeof(Stmt *) * | 
|  | numLoopChildren(CollapsedNum, OMPD_distribute_parallel_for_simd)); | 
|  | return new (Mem) | 
|  | OMPDistributeParallelForSimdDirective(CollapsedNum, NumClauses); | 
|  | } | 
|  |  | 
|  | OMPDistributeSimdDirective *OMPDistributeSimdDirective::Create( | 
|  | const ASTContext &C, SourceLocation StartLoc, SourceLocation EndLoc, | 
|  | unsigned CollapsedNum, ArrayRef<OMPClause *> Clauses, Stmt *AssociatedStmt, | 
|  | const HelperExprs &Exprs) { | 
|  | unsigned Size = | 
|  | llvm::alignTo(sizeof(OMPDistributeSimdDirective), alignof(OMPClause *)); | 
|  | void *Mem = C.Allocate( | 
|  | Size + sizeof(OMPClause *) * Clauses.size() + | 
|  | sizeof(Stmt *) * | 
|  | numLoopChildren(CollapsedNum, OMPD_distribute_simd)); | 
|  | OMPDistributeSimdDirective *Dir = new (Mem) OMPDistributeSimdDirective( | 
|  | StartLoc, EndLoc, CollapsedNum, Clauses.size()); | 
|  | Dir->setClauses(Clauses); | 
|  | Dir->setAssociatedStmt(AssociatedStmt); | 
|  | Dir->setIterationVariable(Exprs.IterationVarRef); | 
|  | Dir->setLastIteration(Exprs.LastIteration); | 
|  | Dir->setCalcLastIteration(Exprs.CalcLastIteration); | 
|  | Dir->setPreCond(Exprs.PreCond); | 
|  | Dir->setCond(Exprs.Cond); | 
|  | Dir->setInit(Exprs.Init); | 
|  | Dir->setInc(Exprs.Inc); | 
|  | Dir->setIsLastIterVariable(Exprs.IL); | 
|  | Dir->setLowerBoundVariable(Exprs.LB); | 
|  | Dir->setUpperBoundVariable(Exprs.UB); | 
|  | Dir->setStrideVariable(Exprs.ST); | 
|  | Dir->setEnsureUpperBound(Exprs.EUB); | 
|  | Dir->setNextLowerBound(Exprs.NLB); | 
|  | Dir->setNextUpperBound(Exprs.NUB); | 
|  | Dir->setNumIterations(Exprs.NumIterations); | 
|  | Dir->setCounters(Exprs.Counters); | 
|  | Dir->setPrivateCounters(Exprs.PrivateCounters); | 
|  | Dir->setInits(Exprs.Inits); | 
|  | Dir->setUpdates(Exprs.Updates); | 
|  | Dir->setFinals(Exprs.Finals); | 
|  | Dir->setPreInits(Exprs.PreInits); | 
|  | return Dir; | 
|  | } | 
|  |  | 
|  | OMPDistributeSimdDirective * | 
|  | OMPDistributeSimdDirective::CreateEmpty(const ASTContext &C, | 
|  | unsigned NumClauses, | 
|  | unsigned CollapsedNum, EmptyShell) { | 
|  | unsigned Size = | 
|  | llvm::alignTo(sizeof(OMPDistributeSimdDirective), alignof(OMPClause *)); | 
|  | void *Mem = C.Allocate( | 
|  | Size + sizeof(OMPClause *) * NumClauses + | 
|  | sizeof(Stmt *) * | 
|  | numLoopChildren(CollapsedNum, OMPD_distribute_simd)); | 
|  | return new (Mem) OMPDistributeSimdDirective(CollapsedNum, NumClauses); | 
|  | } | 
|  |  | 
|  | OMPTargetParallelForSimdDirective *OMPTargetParallelForSimdDirective::Create( | 
|  | const ASTContext &C, SourceLocation StartLoc, SourceLocation EndLoc, | 
|  | unsigned CollapsedNum, ArrayRef<OMPClause *> Clauses, Stmt *AssociatedStmt, | 
|  | const HelperExprs &Exprs) { | 
|  | unsigned Size = llvm::alignTo(sizeof(OMPTargetParallelForSimdDirective), | 
|  | alignof(OMPClause *)); | 
|  | void *Mem = C.Allocate( | 
|  | Size + sizeof(OMPClause *) * Clauses.size() + | 
|  | sizeof(Stmt *) * | 
|  | numLoopChildren(CollapsedNum, OMPD_target_parallel_for_simd)); | 
|  | OMPTargetParallelForSimdDirective *Dir = | 
|  | new (Mem) OMPTargetParallelForSimdDirective(StartLoc, EndLoc, | 
|  | CollapsedNum, Clauses.size()); | 
|  | Dir->setClauses(Clauses); | 
|  | Dir->setAssociatedStmt(AssociatedStmt); | 
|  | Dir->setIterationVariable(Exprs.IterationVarRef); | 
|  | Dir->setLastIteration(Exprs.LastIteration); | 
|  | Dir->setCalcLastIteration(Exprs.CalcLastIteration); | 
|  | Dir->setPreCond(Exprs.PreCond); | 
|  | Dir->setCond(Exprs.Cond); | 
|  | Dir->setInit(Exprs.Init); | 
|  | Dir->setInc(Exprs.Inc); | 
|  | Dir->setIsLastIterVariable(Exprs.IL); | 
|  | Dir->setLowerBoundVariable(Exprs.LB); | 
|  | Dir->setUpperBoundVariable(Exprs.UB); | 
|  | Dir->setStrideVariable(Exprs.ST); | 
|  | Dir->setEnsureUpperBound(Exprs.EUB); | 
|  | Dir->setNextLowerBound(Exprs.NLB); | 
|  | Dir->setNextUpperBound(Exprs.NUB); | 
|  | Dir->setNumIterations(Exprs.NumIterations); | 
|  | Dir->setCounters(Exprs.Counters); | 
|  | Dir->setPrivateCounters(Exprs.PrivateCounters); | 
|  | Dir->setInits(Exprs.Inits); | 
|  | Dir->setUpdates(Exprs.Updates); | 
|  | Dir->setFinals(Exprs.Finals); | 
|  | Dir->setPreInits(Exprs.PreInits); | 
|  | return Dir; | 
|  | } | 
|  |  | 
|  | OMPTargetParallelForSimdDirective * | 
|  | OMPTargetParallelForSimdDirective::CreateEmpty(const ASTContext &C, | 
|  | unsigned NumClauses, | 
|  | unsigned CollapsedNum, | 
|  | EmptyShell) { | 
|  | unsigned Size = llvm::alignTo(sizeof(OMPTargetParallelForSimdDirective), | 
|  | alignof(OMPClause *)); | 
|  | void *Mem = C.Allocate( | 
|  | Size + sizeof(OMPClause *) * NumClauses + | 
|  | sizeof(Stmt *) * | 
|  | numLoopChildren(CollapsedNum, OMPD_target_parallel_for_simd)); | 
|  | return new (Mem) OMPTargetParallelForSimdDirective(CollapsedNum, NumClauses); | 
|  | } | 
|  |  | 
|  | OMPTargetSimdDirective * | 
|  | OMPTargetSimdDirective::Create(const ASTContext &C, SourceLocation StartLoc, | 
|  | SourceLocation EndLoc, unsigned CollapsedNum, | 
|  | ArrayRef<OMPClause *> Clauses, | 
|  | Stmt *AssociatedStmt, const HelperExprs &Exprs) { | 
|  | unsigned Size = | 
|  | llvm::alignTo(sizeof(OMPTargetSimdDirective), alignof(OMPClause *)); | 
|  | void *Mem = C.Allocate(Size + sizeof(OMPClause *) * Clauses.size() + | 
|  | sizeof(Stmt *) * | 
|  | numLoopChildren(CollapsedNum, OMPD_target_simd)); | 
|  | OMPTargetSimdDirective *Dir = new (Mem) | 
|  | OMPTargetSimdDirective(StartLoc, EndLoc, CollapsedNum, Clauses.size()); | 
|  | Dir->setClauses(Clauses); | 
|  | Dir->setAssociatedStmt(AssociatedStmt); | 
|  | Dir->setIterationVariable(Exprs.IterationVarRef); | 
|  | Dir->setLastIteration(Exprs.LastIteration); | 
|  | Dir->setCalcLastIteration(Exprs.CalcLastIteration); | 
|  | Dir->setPreCond(Exprs.PreCond); | 
|  | Dir->setCond(Exprs.Cond); | 
|  | Dir->setInit(Exprs.Init); | 
|  | Dir->setInc(Exprs.Inc); | 
|  | Dir->setCounters(Exprs.Counters); | 
|  | Dir->setPrivateCounters(Exprs.PrivateCounters); | 
|  | Dir->setInits(Exprs.Inits); | 
|  | Dir->setUpdates(Exprs.Updates); | 
|  | Dir->setFinals(Exprs.Finals); | 
|  | Dir->setPreInits(Exprs.PreInits); | 
|  | return Dir; | 
|  | } | 
|  |  | 
|  | OMPTargetSimdDirective * | 
|  | OMPTargetSimdDirective::CreateEmpty(const ASTContext &C, unsigned NumClauses, | 
|  | unsigned CollapsedNum, EmptyShell) { | 
|  | unsigned Size = | 
|  | llvm::alignTo(sizeof(OMPTargetSimdDirective), alignof(OMPClause *)); | 
|  | void *Mem = C.Allocate(Size + sizeof(OMPClause *) * NumClauses + | 
|  | sizeof(Stmt *) * | 
|  | numLoopChildren(CollapsedNum, OMPD_target_simd)); | 
|  | return new (Mem) OMPTargetSimdDirective(CollapsedNum, NumClauses); | 
|  | } | 
|  |  | 
|  | OMPTeamsDistributeDirective *OMPTeamsDistributeDirective::Create( | 
|  | const ASTContext &C, SourceLocation StartLoc, SourceLocation EndLoc, | 
|  | unsigned CollapsedNum, ArrayRef<OMPClause *> Clauses, Stmt *AssociatedStmt, | 
|  | const HelperExprs &Exprs) { | 
|  | unsigned Size = | 
|  | llvm::alignTo(sizeof(OMPTeamsDistributeDirective), alignof(OMPClause *)); | 
|  | void *Mem = C.Allocate( | 
|  | Size + sizeof(OMPClause *) * Clauses.size() + | 
|  | sizeof(Stmt *) * numLoopChildren(CollapsedNum, OMPD_teams_distribute)); | 
|  | OMPTeamsDistributeDirective *Dir = new (Mem) OMPTeamsDistributeDirective( | 
|  | StartLoc, EndLoc, CollapsedNum, Clauses.size()); | 
|  | Dir->setClauses(Clauses); | 
|  | Dir->setAssociatedStmt(AssociatedStmt); | 
|  | Dir->setIterationVariable(Exprs.IterationVarRef); | 
|  | Dir->setLastIteration(Exprs.LastIteration); | 
|  | Dir->setCalcLastIteration(Exprs.CalcLastIteration); | 
|  | Dir->setPreCond(Exprs.PreCond); | 
|  | Dir->setCond(Exprs.Cond); | 
|  | Dir->setInit(Exprs.Init); | 
|  | Dir->setInc(Exprs.Inc); | 
|  | Dir->setIsLastIterVariable(Exprs.IL); | 
|  | Dir->setLowerBoundVariable(Exprs.LB); | 
|  | Dir->setUpperBoundVariable(Exprs.UB); | 
|  | Dir->setStrideVariable(Exprs.ST); | 
|  | Dir->setEnsureUpperBound(Exprs.EUB); | 
|  | Dir->setNextLowerBound(Exprs.NLB); | 
|  | Dir->setNextUpperBound(Exprs.NUB); | 
|  | Dir->setNumIterations(Exprs.NumIterations); | 
|  | Dir->setCounters(Exprs.Counters); | 
|  | Dir->setPrivateCounters(Exprs.PrivateCounters); | 
|  | Dir->setInits(Exprs.Inits); | 
|  | Dir->setUpdates(Exprs.Updates); | 
|  | Dir->setFinals(Exprs.Finals); | 
|  | Dir->setPreInits(Exprs.PreInits); | 
|  | return Dir; | 
|  | } | 
|  |  | 
|  | OMPTeamsDistributeDirective * | 
|  | OMPTeamsDistributeDirective::CreateEmpty(const ASTContext &C, | 
|  | unsigned NumClauses, | 
|  | unsigned CollapsedNum, EmptyShell) { | 
|  | unsigned Size = | 
|  | llvm::alignTo(sizeof(OMPTeamsDistributeDirective), alignof(OMPClause *)); | 
|  | void *Mem = C.Allocate( | 
|  | Size + sizeof(OMPClause *) * NumClauses + | 
|  | sizeof(Stmt *) * numLoopChildren(CollapsedNum, OMPD_teams_distribute)); | 
|  | return new (Mem) OMPTeamsDistributeDirective(CollapsedNum, NumClauses); | 
|  | } | 
|  |  | 
|  | OMPTeamsDistributeSimdDirective *OMPTeamsDistributeSimdDirective::Create( | 
|  | const ASTContext &C, SourceLocation StartLoc, SourceLocation EndLoc, | 
|  | unsigned CollapsedNum, ArrayRef<OMPClause *> Clauses, Stmt *AssociatedStmt, | 
|  | const HelperExprs &Exprs) { | 
|  | unsigned Size = llvm::alignTo(sizeof(OMPTeamsDistributeSimdDirective), | 
|  | alignof(OMPClause *)); | 
|  | void *Mem = | 
|  | C.Allocate(Size + sizeof(OMPClause *) * Clauses.size() + | 
|  | sizeof(Stmt *) * | 
|  | numLoopChildren(CollapsedNum, OMPD_teams_distribute_simd)); | 
|  | OMPTeamsDistributeSimdDirective *Dir = | 
|  | new (Mem) OMPTeamsDistributeSimdDirective(StartLoc, EndLoc, CollapsedNum, | 
|  | Clauses.size()); | 
|  | Dir->setClauses(Clauses); | 
|  | Dir->setAssociatedStmt(AssociatedStmt); | 
|  | Dir->setIterationVariable(Exprs.IterationVarRef); | 
|  | Dir->setLastIteration(Exprs.LastIteration); | 
|  | Dir->setCalcLastIteration(Exprs.CalcLastIteration); | 
|  | Dir->setPreCond(Exprs.PreCond); | 
|  | Dir->setCond(Exprs.Cond); | 
|  | Dir->setInit(Exprs.Init); | 
|  | Dir->setInc(Exprs.Inc); | 
|  | Dir->setIsLastIterVariable(Exprs.IL); | 
|  | Dir->setLowerBoundVariable(Exprs.LB); | 
|  | Dir->setUpperBoundVariable(Exprs.UB); | 
|  | Dir->setStrideVariable(Exprs.ST); | 
|  | Dir->setEnsureUpperBound(Exprs.EUB); | 
|  | Dir->setNextLowerBound(Exprs.NLB); | 
|  | Dir->setNextUpperBound(Exprs.NUB); | 
|  | Dir->setNumIterations(Exprs.NumIterations); | 
|  | Dir->setCounters(Exprs.Counters); | 
|  | Dir->setPrivateCounters(Exprs.PrivateCounters); | 
|  | Dir->setInits(Exprs.Inits); | 
|  | Dir->setUpdates(Exprs.Updates); | 
|  | Dir->setFinals(Exprs.Finals); | 
|  | Dir->setPreInits(Exprs.PreInits); | 
|  | return Dir; | 
|  | } | 
|  |  | 
|  | OMPTeamsDistributeSimdDirective *OMPTeamsDistributeSimdDirective::CreateEmpty( | 
|  | const ASTContext &C, unsigned NumClauses, unsigned CollapsedNum, | 
|  | EmptyShell) { | 
|  | unsigned Size = llvm::alignTo(sizeof(OMPTeamsDistributeSimdDirective), | 
|  | alignof(OMPClause *)); | 
|  | void *Mem = | 
|  | C.Allocate(Size + sizeof(OMPClause *) * NumClauses + | 
|  | sizeof(Stmt *) * | 
|  | numLoopChildren(CollapsedNum, OMPD_teams_distribute_simd)); | 
|  | return new (Mem) OMPTeamsDistributeSimdDirective(CollapsedNum, NumClauses); | 
|  | } | 
|  |  | 
|  | OMPTeamsDistributeParallelForSimdDirective * | 
|  | OMPTeamsDistributeParallelForSimdDirective::Create( | 
|  | const ASTContext &C, SourceLocation StartLoc, SourceLocation EndLoc, | 
|  | unsigned CollapsedNum, ArrayRef<OMPClause *> Clauses, Stmt *AssociatedStmt, | 
|  | const HelperExprs &Exprs) { | 
|  | auto Size = llvm::alignTo(sizeof(OMPTeamsDistributeParallelForSimdDirective), | 
|  | alignof(OMPClause *)); | 
|  | void *Mem = | 
|  | C.Allocate(Size + sizeof(OMPClause *) * Clauses.size() + | 
|  | sizeof(Stmt *) * | 
|  | numLoopChildren(CollapsedNum, | 
|  | OMPD_teams_distribute_parallel_for_simd)); | 
|  | OMPTeamsDistributeParallelForSimdDirective *Dir = new (Mem) | 
|  | OMPTeamsDistributeParallelForSimdDirective(StartLoc, EndLoc, CollapsedNum, | 
|  | Clauses.size()); | 
|  | Dir->setClauses(Clauses); | 
|  | Dir->setAssociatedStmt(AssociatedStmt); | 
|  | Dir->setIterationVariable(Exprs.IterationVarRef); | 
|  | Dir->setLastIteration(Exprs.LastIteration); | 
|  | Dir->setCalcLastIteration(Exprs.CalcLastIteration); | 
|  | Dir->setPreCond(Exprs.PreCond); | 
|  | Dir->setCond(Exprs.Cond); | 
|  | Dir->setInit(Exprs.Init); | 
|  | Dir->setInc(Exprs.Inc); | 
|  | Dir->setIsLastIterVariable(Exprs.IL); | 
|  | Dir->setLowerBoundVariable(Exprs.LB); | 
|  | Dir->setUpperBoundVariable(Exprs.UB); | 
|  | Dir->setStrideVariable(Exprs.ST); | 
|  | Dir->setEnsureUpperBound(Exprs.EUB); | 
|  | Dir->setNextLowerBound(Exprs.NLB); | 
|  | Dir->setNextUpperBound(Exprs.NUB); | 
|  | Dir->setNumIterations(Exprs.NumIterations); | 
|  | Dir->setPrevLowerBoundVariable(Exprs.PrevLB); | 
|  | Dir->setPrevUpperBoundVariable(Exprs.PrevUB); | 
|  | Dir->setDistInc(Exprs.DistInc); | 
|  | Dir->setPrevEnsureUpperBound(Exprs.PrevEUB); | 
|  | Dir->setCounters(Exprs.Counters); | 
|  | Dir->setPrivateCounters(Exprs.PrivateCounters); | 
|  | Dir->setInits(Exprs.Inits); | 
|  | Dir->setUpdates(Exprs.Updates); | 
|  | Dir->setFinals(Exprs.Finals); | 
|  | Dir->setPreInits(Exprs.PreInits); | 
|  | Dir->setCombinedLowerBoundVariable(Exprs.DistCombinedFields.LB); | 
|  | Dir->setCombinedUpperBoundVariable(Exprs.DistCombinedFields.UB); | 
|  | Dir->setCombinedEnsureUpperBound(Exprs.DistCombinedFields.EUB); | 
|  | Dir->setCombinedInit(Exprs.DistCombinedFields.Init); | 
|  | Dir->setCombinedCond(Exprs.DistCombinedFields.Cond); | 
|  | Dir->setCombinedNextLowerBound(Exprs.DistCombinedFields.NLB); | 
|  | Dir->setCombinedNextUpperBound(Exprs.DistCombinedFields.NUB); | 
|  | return Dir; | 
|  | } | 
|  |  | 
|  | OMPTeamsDistributeParallelForSimdDirective * | 
|  | OMPTeamsDistributeParallelForSimdDirective::CreateEmpty(const ASTContext &C, | 
|  | unsigned NumClauses, | 
|  | unsigned CollapsedNum, | 
|  | EmptyShell) { | 
|  | auto Size = llvm::alignTo(sizeof(OMPTeamsDistributeParallelForSimdDirective), | 
|  | alignof(OMPClause *)); | 
|  | void *Mem = | 
|  | C.Allocate(Size + sizeof(OMPClause *) * NumClauses + | 
|  | sizeof(Stmt *) * | 
|  | numLoopChildren(CollapsedNum, | 
|  | OMPD_teams_distribute_parallel_for_simd)); | 
|  | return new (Mem) | 
|  | OMPTeamsDistributeParallelForSimdDirective(CollapsedNum, NumClauses); | 
|  | } | 
|  |  | 
|  | OMPTeamsDistributeParallelForDirective * | 
|  | OMPTeamsDistributeParallelForDirective::Create( | 
|  | const ASTContext &C, SourceLocation StartLoc, SourceLocation EndLoc, | 
|  | unsigned CollapsedNum, ArrayRef<OMPClause *> Clauses, Stmt *AssociatedStmt, | 
|  | const HelperExprs &Exprs, bool HasCancel) { | 
|  | auto Size = llvm::alignTo(sizeof(OMPTeamsDistributeParallelForDirective), | 
|  | alignof(OMPClause *)); | 
|  | void *Mem = C.Allocate( | 
|  | Size + sizeof(OMPClause *) * Clauses.size() + | 
|  | sizeof(Stmt *) * | 
|  | numLoopChildren(CollapsedNum, OMPD_teams_distribute_parallel_for)); | 
|  | OMPTeamsDistributeParallelForDirective *Dir = new (Mem) | 
|  | OMPTeamsDistributeParallelForDirective(StartLoc, EndLoc, CollapsedNum, | 
|  | Clauses.size()); | 
|  | Dir->setClauses(Clauses); | 
|  | Dir->setAssociatedStmt(AssociatedStmt); | 
|  | Dir->setIterationVariable(Exprs.IterationVarRef); | 
|  | Dir->setLastIteration(Exprs.LastIteration); | 
|  | Dir->setCalcLastIteration(Exprs.CalcLastIteration); | 
|  | Dir->setPreCond(Exprs.PreCond); | 
|  | Dir->setCond(Exprs.Cond); | 
|  | Dir->setInit(Exprs.Init); | 
|  | Dir->setInc(Exprs.Inc); | 
|  | Dir->setIsLastIterVariable(Exprs.IL); | 
|  | Dir->setLowerBoundVariable(Exprs.LB); | 
|  | Dir->setUpperBoundVariable(Exprs.UB); | 
|  | Dir->setStrideVariable(Exprs.ST); | 
|  | Dir->setEnsureUpperBound(Exprs.EUB); | 
|  | Dir->setNextLowerBound(Exprs.NLB); | 
|  | Dir->setNextUpperBound(Exprs.NUB); | 
|  | Dir->setNumIterations(Exprs.NumIterations); | 
|  | Dir->setPrevLowerBoundVariable(Exprs.PrevLB); | 
|  | Dir->setPrevUpperBoundVariable(Exprs.PrevUB); | 
|  | Dir->setDistInc(Exprs.DistInc); | 
|  | Dir->setPrevEnsureUpperBound(Exprs.PrevEUB); | 
|  | Dir->setCounters(Exprs.Counters); | 
|  | Dir->setPrivateCounters(Exprs.PrivateCounters); | 
|  | Dir->setInits(Exprs.Inits); | 
|  | Dir->setUpdates(Exprs.Updates); | 
|  | Dir->setFinals(Exprs.Finals); | 
|  | Dir->setPreInits(Exprs.PreInits); | 
|  | Dir->setCombinedLowerBoundVariable(Exprs.DistCombinedFields.LB); | 
|  | Dir->setCombinedUpperBoundVariable(Exprs.DistCombinedFields.UB); | 
|  | Dir->setCombinedEnsureUpperBound(Exprs.DistCombinedFields.EUB); | 
|  | Dir->setCombinedInit(Exprs.DistCombinedFields.Init); | 
|  | Dir->setCombinedCond(Exprs.DistCombinedFields.Cond); | 
|  | Dir->setCombinedNextLowerBound(Exprs.DistCombinedFields.NLB); | 
|  | Dir->setCombinedNextUpperBound(Exprs.DistCombinedFields.NUB); | 
|  | Dir->HasCancel = HasCancel; | 
|  | return Dir; | 
|  | } | 
|  |  | 
|  | OMPTeamsDistributeParallelForDirective * | 
|  | OMPTeamsDistributeParallelForDirective::CreateEmpty(const ASTContext &C, | 
|  | unsigned NumClauses, | 
|  | unsigned CollapsedNum, | 
|  | EmptyShell) { | 
|  | auto Size = llvm::alignTo(sizeof(OMPTeamsDistributeParallelForDirective), | 
|  | alignof(OMPClause *)); | 
|  | void *Mem = C.Allocate( | 
|  | Size + sizeof(OMPClause *) * NumClauses + | 
|  | sizeof(Stmt *) * | 
|  | numLoopChildren(CollapsedNum, OMPD_teams_distribute_parallel_for)); | 
|  | return new (Mem) | 
|  | OMPTeamsDistributeParallelForDirective(CollapsedNum, NumClauses); | 
|  | } | 
|  |  | 
|  | OMPTargetTeamsDirective *OMPTargetTeamsDirective::Create( | 
|  | const ASTContext &C, SourceLocation StartLoc, SourceLocation EndLoc, | 
|  | ArrayRef<OMPClause *> Clauses, Stmt *AssociatedStmt) { | 
|  | auto Size = | 
|  | llvm::alignTo(sizeof(OMPTargetTeamsDirective), alignof(OMPClause *)); | 
|  | void *Mem = | 
|  | C.Allocate(Size + sizeof(OMPClause *) * Clauses.size() + sizeof(Stmt *)); | 
|  | OMPTargetTeamsDirective *Dir = | 
|  | new (Mem) OMPTargetTeamsDirective(StartLoc, EndLoc, Clauses.size()); | 
|  | Dir->setClauses(Clauses); | 
|  | Dir->setAssociatedStmt(AssociatedStmt); | 
|  | return Dir; | 
|  | } | 
|  |  | 
|  | OMPTargetTeamsDirective * | 
|  | OMPTargetTeamsDirective::CreateEmpty(const ASTContext &C, unsigned NumClauses, | 
|  | EmptyShell) { | 
|  | auto Size = | 
|  | llvm::alignTo(sizeof(OMPTargetTeamsDirective), alignof(OMPClause *)); | 
|  | void *Mem = | 
|  | C.Allocate(Size + sizeof(OMPClause *) * NumClauses + sizeof(Stmt *)); | 
|  | return new (Mem) OMPTargetTeamsDirective(NumClauses); | 
|  | } | 
|  |  | 
|  | OMPTargetTeamsDistributeDirective *OMPTargetTeamsDistributeDirective::Create( | 
|  | const ASTContext &C, SourceLocation StartLoc, SourceLocation EndLoc, | 
|  | unsigned CollapsedNum, ArrayRef<OMPClause *> Clauses, Stmt *AssociatedStmt, | 
|  | const HelperExprs &Exprs) { | 
|  | auto Size = llvm::alignTo(sizeof(OMPTargetTeamsDistributeDirective), | 
|  | alignof(OMPClause *)); | 
|  | void *Mem = C.Allocate( | 
|  | Size + sizeof(OMPClause *) * Clauses.size() + | 
|  | sizeof(Stmt *) * | 
|  | numLoopChildren(CollapsedNum, OMPD_target_teams_distribute)); | 
|  | OMPTargetTeamsDistributeDirective *Dir = | 
|  | new (Mem) OMPTargetTeamsDistributeDirective(StartLoc, EndLoc, CollapsedNum, | 
|  | Clauses.size()); | 
|  | Dir->setClauses(Clauses); | 
|  | Dir->setAssociatedStmt(AssociatedStmt); | 
|  | Dir->setIterationVariable(Exprs.IterationVarRef); | 
|  | Dir->setLastIteration(Exprs.LastIteration); | 
|  | Dir->setCalcLastIteration(Exprs.CalcLastIteration); | 
|  | Dir->setPreCond(Exprs.PreCond); | 
|  | Dir->setCond(Exprs.Cond); | 
|  | Dir->setInit(Exprs.Init); | 
|  | Dir->setInc(Exprs.Inc); | 
|  | Dir->setIsLastIterVariable(Exprs.IL); | 
|  | Dir->setLowerBoundVariable(Exprs.LB); | 
|  | Dir->setUpperBoundVariable(Exprs.UB); | 
|  | Dir->setStrideVariable(Exprs.ST); | 
|  | Dir->setEnsureUpperBound(Exprs.EUB); | 
|  | Dir->setNextLowerBound(Exprs.NLB); | 
|  | Dir->setNextUpperBound(Exprs.NUB); | 
|  | Dir->setNumIterations(Exprs.NumIterations); | 
|  | Dir->setCounters(Exprs.Counters); | 
|  | Dir->setPrivateCounters(Exprs.PrivateCounters); | 
|  | Dir->setInits(Exprs.Inits); | 
|  | Dir->setUpdates(Exprs.Updates); | 
|  | Dir->setFinals(Exprs.Finals); | 
|  | Dir->setPreInits(Exprs.PreInits); | 
|  | return Dir; | 
|  | } | 
|  |  | 
|  | OMPTargetTeamsDistributeDirective * | 
|  | OMPTargetTeamsDistributeDirective::CreateEmpty(const ASTContext &C, | 
|  | unsigned NumClauses, | 
|  | unsigned CollapsedNum, | 
|  | EmptyShell) { | 
|  | auto Size = llvm::alignTo(sizeof(OMPTargetTeamsDistributeDirective), | 
|  | alignof(OMPClause *)); | 
|  | void *Mem = C.Allocate( | 
|  | Size + sizeof(OMPClause *) * NumClauses + | 
|  | sizeof(Stmt *) * | 
|  | numLoopChildren(CollapsedNum, OMPD_target_teams_distribute)); | 
|  | return new (Mem) OMPTargetTeamsDistributeDirective(CollapsedNum, NumClauses); | 
|  | } | 
|  |  | 
|  | OMPTargetTeamsDistributeParallelForDirective * | 
|  | OMPTargetTeamsDistributeParallelForDirective::Create( | 
|  | const ASTContext &C, SourceLocation StartLoc, SourceLocation EndLoc, | 
|  | unsigned CollapsedNum, ArrayRef<OMPClause *> Clauses, Stmt *AssociatedStmt, | 
|  | const HelperExprs &Exprs, bool HasCancel) { | 
|  | auto Size = | 
|  | llvm::alignTo(sizeof(OMPTargetTeamsDistributeParallelForDirective), | 
|  | alignof(OMPClause *)); | 
|  | void *Mem = C.Allocate( | 
|  | Size + sizeof(OMPClause *) * Clauses.size() + | 
|  | sizeof(Stmt *) * | 
|  | numLoopChildren(CollapsedNum, | 
|  | OMPD_target_teams_distribute_parallel_for)); | 
|  | OMPTargetTeamsDistributeParallelForDirective *Dir = | 
|  | new (Mem) OMPTargetTeamsDistributeParallelForDirective( | 
|  | StartLoc, EndLoc, CollapsedNum, Clauses.size()); | 
|  | Dir->setClauses(Clauses); | 
|  | Dir->setAssociatedStmt(AssociatedStmt); | 
|  | Dir->setIterationVariable(Exprs.IterationVarRef); | 
|  | Dir->setLastIteration(Exprs.LastIteration); | 
|  | Dir->setCalcLastIteration(Exprs.CalcLastIteration); | 
|  | Dir->setPreCond(Exprs.PreCond); | 
|  | Dir->setCond(Exprs.Cond); | 
|  | Dir->setInit(Exprs.Init); | 
|  | Dir->setInc(Exprs.Inc); | 
|  | Dir->setIsLastIterVariable(Exprs.IL); | 
|  | Dir->setLowerBoundVariable(Exprs.LB); | 
|  | Dir->setUpperBoundVariable(Exprs.UB); | 
|  | Dir->setStrideVariable(Exprs.ST); | 
|  | Dir->setEnsureUpperBound(Exprs.EUB); | 
|  | Dir->setNextLowerBound(Exprs.NLB); | 
|  | Dir->setNextUpperBound(Exprs.NUB); | 
|  | Dir->setNumIterations(Exprs.NumIterations); | 
|  | Dir->setPrevLowerBoundVariable(Exprs.PrevLB); | 
|  | Dir->setPrevUpperBoundVariable(Exprs.PrevUB); | 
|  | Dir->setDistInc(Exprs.DistInc); | 
|  | Dir->setPrevEnsureUpperBound(Exprs.PrevEUB); | 
|  | Dir->setCounters(Exprs.Counters); | 
|  | Dir->setPrivateCounters(Exprs.PrivateCounters); | 
|  | Dir->setInits(Exprs.Inits); | 
|  | Dir->setUpdates(Exprs.Updates); | 
|  | Dir->setFinals(Exprs.Finals); | 
|  | Dir->setPreInits(Exprs.PreInits); | 
|  | Dir->setCombinedLowerBoundVariable(Exprs.DistCombinedFields.LB); | 
|  | Dir->setCombinedUpperBoundVariable(Exprs.DistCombinedFields.UB); | 
|  | Dir->setCombinedEnsureUpperBound(Exprs.DistCombinedFields.EUB); | 
|  | Dir->setCombinedInit(Exprs.DistCombinedFields.Init); | 
|  | Dir->setCombinedCond(Exprs.DistCombinedFields.Cond); | 
|  | Dir->setCombinedNextLowerBound(Exprs.DistCombinedFields.NLB); | 
|  | Dir->setCombinedNextUpperBound(Exprs.DistCombinedFields.NUB); | 
|  | Dir->HasCancel = HasCancel; | 
|  | return Dir; | 
|  | } | 
|  |  | 
|  | OMPTargetTeamsDistributeParallelForDirective * | 
|  | OMPTargetTeamsDistributeParallelForDirective::CreateEmpty(const ASTContext &C, | 
|  | unsigned NumClauses, | 
|  | unsigned CollapsedNum, | 
|  | EmptyShell) { | 
|  | auto Size = | 
|  | llvm::alignTo(sizeof(OMPTargetTeamsDistributeParallelForDirective), | 
|  | alignof(OMPClause *)); | 
|  | void *Mem = C.Allocate( | 
|  | Size + sizeof(OMPClause *) * NumClauses + | 
|  | sizeof(Stmt *) * | 
|  | numLoopChildren(CollapsedNum, | 
|  | OMPD_target_teams_distribute_parallel_for)); | 
|  | return new (Mem) | 
|  | OMPTargetTeamsDistributeParallelForDirective(CollapsedNum, NumClauses); | 
|  | } | 
|  |  | 
|  | OMPTargetTeamsDistributeParallelForSimdDirective * | 
|  | OMPTargetTeamsDistributeParallelForSimdDirective::Create( | 
|  | const ASTContext &C, SourceLocation StartLoc, SourceLocation EndLoc, | 
|  | unsigned CollapsedNum, ArrayRef<OMPClause *> Clauses, Stmt *AssociatedStmt, | 
|  | const HelperExprs &Exprs) { | 
|  | auto Size = | 
|  | llvm::alignTo(sizeof(OMPTargetTeamsDistributeParallelForSimdDirective), | 
|  | alignof(OMPClause *)); | 
|  | void *Mem = C.Allocate( | 
|  | Size + sizeof(OMPClause *) * Clauses.size() + | 
|  | sizeof(Stmt *) * | 
|  | numLoopChildren(CollapsedNum, | 
|  | OMPD_target_teams_distribute_parallel_for_simd)); | 
|  | OMPTargetTeamsDistributeParallelForSimdDirective *Dir = | 
|  | new (Mem) OMPTargetTeamsDistributeParallelForSimdDirective( | 
|  | StartLoc, EndLoc, CollapsedNum, Clauses.size()); | 
|  | Dir->setClauses(Clauses); | 
|  | Dir->setAssociatedStmt(AssociatedStmt); | 
|  | Dir->setIterationVariable(Exprs.IterationVarRef); | 
|  | Dir->setLastIteration(Exprs.LastIteration); | 
|  | Dir->setCalcLastIteration(Exprs.CalcLastIteration); | 
|  | Dir->setPreCond(Exprs.PreCond); | 
|  | Dir->setCond(Exprs.Cond); | 
|  | Dir->setInit(Exprs.Init); | 
|  | Dir->setInc(Exprs.Inc); | 
|  | Dir->setIsLastIterVariable(Exprs.IL); | 
|  | Dir->setLowerBoundVariable(Exprs.LB); | 
|  | Dir->setUpperBoundVariable(Exprs.UB); | 
|  | Dir->setStrideVariable(Exprs.ST); | 
|  | Dir->setEnsureUpperBound(Exprs.EUB); | 
|  | Dir->setNextLowerBound(Exprs.NLB); | 
|  | Dir->setNextUpperBound(Exprs.NUB); | 
|  | Dir->setNumIterations(Exprs.NumIterations); | 
|  | Dir->setPrevLowerBoundVariable(Exprs.PrevLB); | 
|  | Dir->setPrevUpperBoundVariable(Exprs.PrevUB); | 
|  | Dir->setDistInc(Exprs.DistInc); | 
|  | Dir->setPrevEnsureUpperBound(Exprs.PrevEUB); | 
|  | Dir->setCounters(Exprs.Counters); | 
|  | Dir->setPrivateCounters(Exprs.PrivateCounters); | 
|  | Dir->setInits(Exprs.Inits); | 
|  | Dir->setUpdates(Exprs.Updates); | 
|  | Dir->setFinals(Exprs.Finals); | 
|  | Dir->setPreInits(Exprs.PreInits); | 
|  | Dir->setCombinedLowerBoundVariable(Exprs.DistCombinedFields.LB); | 
|  | Dir->setCombinedUpperBoundVariable(Exprs.DistCombinedFields.UB); | 
|  | Dir->setCombinedEnsureUpperBound(Exprs.DistCombinedFields.EUB); | 
|  | Dir->setCombinedInit(Exprs.DistCombinedFields.Init); | 
|  | Dir->setCombinedCond(Exprs.DistCombinedFields.Cond); | 
|  | Dir->setCombinedNextLowerBound(Exprs.DistCombinedFields.NLB); | 
|  | Dir->setCombinedNextUpperBound(Exprs.DistCombinedFields.NUB); | 
|  | return Dir; | 
|  | } | 
|  |  | 
|  | OMPTargetTeamsDistributeParallelForSimdDirective * | 
|  | OMPTargetTeamsDistributeParallelForSimdDirective::CreateEmpty( | 
|  | const ASTContext &C, unsigned NumClauses, unsigned CollapsedNum, | 
|  | EmptyShell) { | 
|  | auto Size = | 
|  | llvm::alignTo(sizeof(OMPTargetTeamsDistributeParallelForSimdDirective), | 
|  | alignof(OMPClause *)); | 
|  | void *Mem = C.Allocate( | 
|  | Size + sizeof(OMPClause *) * NumClauses + | 
|  | sizeof(Stmt *) * | 
|  | numLoopChildren(CollapsedNum, | 
|  | OMPD_target_teams_distribute_parallel_for_simd)); | 
|  | return new (Mem) OMPTargetTeamsDistributeParallelForSimdDirective( | 
|  | CollapsedNum, NumClauses); | 
|  | } | 
|  |  | 
|  | OMPTargetTeamsDistributeSimdDirective * | 
|  | OMPTargetTeamsDistributeSimdDirective::Create( | 
|  | const ASTContext &C, SourceLocation StartLoc, SourceLocation EndLoc, | 
|  | unsigned CollapsedNum, ArrayRef<OMPClause *> Clauses, Stmt *AssociatedStmt, | 
|  | const HelperExprs &Exprs) { | 
|  | auto Size = llvm::alignTo(sizeof(OMPTargetTeamsDistributeSimdDirective), | 
|  | alignof(OMPClause *)); | 
|  | void *Mem = C.Allocate( | 
|  | Size + sizeof(OMPClause *) * Clauses.size() + | 
|  | sizeof(Stmt *) * | 
|  | numLoopChildren(CollapsedNum, OMPD_target_teams_distribute_simd)); | 
|  | OMPTargetTeamsDistributeSimdDirective *Dir = new (Mem) | 
|  | OMPTargetTeamsDistributeSimdDirective(StartLoc, EndLoc, CollapsedNum, | 
|  | Clauses.size()); | 
|  | Dir->setClauses(Clauses); | 
|  | Dir->setAssociatedStmt(AssociatedStmt); | 
|  | Dir->setIterationVariable(Exprs.IterationVarRef); | 
|  | Dir->setLastIteration(Exprs.LastIteration); | 
|  | Dir->setCalcLastIteration(Exprs.CalcLastIteration); | 
|  | Dir->setPreCond(Exprs.PreCond); | 
|  | Dir->setCond(Exprs.Cond); | 
|  | Dir->setInit(Exprs.Init); | 
|  | Dir->setInc(Exprs.Inc); | 
|  | Dir->setIsLastIterVariable(Exprs.IL); | 
|  | Dir->setLowerBoundVariable(Exprs.LB); | 
|  | Dir->setUpperBoundVariable(Exprs.UB); | 
|  | Dir->setStrideVariable(Exprs.ST); | 
|  | Dir->setEnsureUpperBound(Exprs.EUB); | 
|  | Dir->setNextLowerBound(Exprs.NLB); | 
|  | Dir->setNextUpperBound(Exprs.NUB); | 
|  | Dir->setNumIterations(Exprs.NumIterations); | 
|  | Dir->setCounters(Exprs.Counters); | 
|  | Dir->setPrivateCounters(Exprs.PrivateCounters); | 
|  | Dir->setInits(Exprs.Inits); | 
|  | Dir->setUpdates(Exprs.Updates); | 
|  | Dir->setFinals(Exprs.Finals); | 
|  | Dir->setPreInits(Exprs.PreInits); | 
|  | return Dir; | 
|  | } | 
|  |  | 
|  | OMPTargetTeamsDistributeSimdDirective * | 
|  | OMPTargetTeamsDistributeSimdDirective::CreateEmpty(const ASTContext &C, | 
|  | unsigned NumClauses, | 
|  | unsigned CollapsedNum, | 
|  | EmptyShell) { | 
|  | auto Size = llvm::alignTo(sizeof(OMPTargetTeamsDistributeSimdDirective), | 
|  | alignof(OMPClause *)); | 
|  | void *Mem = C.Allocate( | 
|  | Size + sizeof(OMPClause *) * NumClauses + | 
|  | sizeof(Stmt *) * | 
|  | numLoopChildren(CollapsedNum, OMPD_target_teams_distribute_simd)); | 
|  | return new (Mem) | 
|  | OMPTargetTeamsDistributeSimdDirective(CollapsedNum, NumClauses); | 
|  | } |