From 8dba66412b0a7dba4a07de30fb74eabd37a69e79 Mon Sep 17 00:00:00 2001 From: Alexander Musman Date: Tue, 22 Apr 2014 13:09:42 +0000 Subject: [OPENMP] parsing 'linear' clause (for directive 'omp simd') Differential Revision: http://reviews.llvm.org/D3272 llvm-svn: 206891 --- clang/lib/Sema/TreeTransform.h | 32 ++++++++++++++++++++++++++++++++ 1 file changed, 32 insertions(+) (limited to 'clang/lib/Sema/TreeTransform.h') diff --git a/clang/lib/Sema/TreeTransform.h b/clang/lib/Sema/TreeTransform.h index 22913104d74..f1138918825 100644 --- a/clang/lib/Sema/TreeTransform.h +++ b/clang/lib/Sema/TreeTransform.h @@ -1382,6 +1382,19 @@ public: EndLoc); } + /// \brief Build a new OpenMP 'linear' clause. + /// + /// By default, performs semantic analysis to build the new statement. + /// Subclasses may override this routine to provide different behavior. + OMPClause *RebuildOMPLinearClause(ArrayRef VarList, Expr *Step, + SourceLocation StartLoc, + SourceLocation LParenLoc, + SourceLocation ColonLoc, + SourceLocation EndLoc) { + return getSema().ActOnOpenMPLinearClause(VarList, Step, StartLoc, LParenLoc, + ColonLoc, EndLoc); + } + /// \brief Build a new OpenMP 'copyin' clause. /// /// By default, performs semantic analysis to build the new statement. @@ -6434,6 +6447,25 @@ TreeTransform::TransformOMPSharedClause(OMPSharedClause *C) { C->getLocEnd()); } +template +OMPClause * +TreeTransform::TransformOMPLinearClause(OMPLinearClause *C) { + llvm::SmallVector Vars; + Vars.reserve(C->varlist_size()); + for (auto *VE : C->varlists()) { + ExprResult EVar = getDerived().TransformExpr(cast(VE)); + if (EVar.isInvalid()) + return 0; + Vars.push_back(EVar.take()); + } + ExprResult Step = getDerived().TransformExpr(C->getStep()); + if (Step.isInvalid()) + return 0; + return getDerived().RebuildOMPLinearClause( + Vars, Step.take(), C->getLocStart(), C->getLParenLoc(), C->getColonLoc(), + C->getLocEnd()); +} + template OMPClause * TreeTransform::TransformOMPCopyinClause(OMPCopyinClause *C) { -- cgit v1.2.3