Coverage Report

Created: 2020-09-19 12:23

/Users/buildslave/jenkins/workspace/coverage/llvm-project/clang/lib/Sema/TreeTransform.h
Line
Count
Source (jump to first uncovered line)
1
//===------- TreeTransform.h - Semantic Tree Transformation -----*- C++ -*-===//
2
//
3
// Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
4
// See https://llvm.org/LICENSE.txt for license information.
5
// SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
6
//===----------------------------------------------------------------------===//
7
//
8
//  This file implements a semantic tree transformation that takes a given
9
//  AST and rebuilds it, possibly transforming some nodes in the process.
10
//
11
//===----------------------------------------------------------------------===//
12
13
#ifndef LLVM_CLANG_LIB_SEMA_TREETRANSFORM_H
14
#define LLVM_CLANG_LIB_SEMA_TREETRANSFORM_H
15
16
#include "CoroutineStmtBuilder.h"
17
#include "TypeLocBuilder.h"
18
#include "clang/AST/Decl.h"
19
#include "clang/AST/DeclObjC.h"
20
#include "clang/AST/DeclTemplate.h"
21
#include "clang/AST/Expr.h"
22
#include "clang/AST/ExprConcepts.h"
23
#include "clang/AST/ExprCXX.h"
24
#include "clang/AST/ExprObjC.h"
25
#include "clang/AST/ExprOpenMP.h"
26
#include "clang/AST/OpenMPClause.h"
27
#include "clang/AST/Stmt.h"
28
#include "clang/AST/StmtCXX.h"
29
#include "clang/AST/StmtObjC.h"
30
#include "clang/AST/StmtOpenMP.h"
31
#include "clang/Basic/DiagnosticParse.h"
32
#include "clang/Basic/OpenMPKinds.h"
33
#include "clang/Sema/Designator.h"
34
#include "clang/Sema/Lookup.h"
35
#include "clang/Sema/Ownership.h"
36
#include "clang/Sema/ParsedTemplate.h"
37
#include "clang/Sema/ScopeInfo.h"
38
#include "clang/Sema/SemaDiagnostic.h"
39
#include "clang/Sema/SemaInternal.h"
40
#include "llvm/ADT/ArrayRef.h"
41
#include "llvm/Support/ErrorHandling.h"
42
#include <algorithm>
43
44
using namespace llvm::omp;
45
46
namespace clang {
47
using namespace sema;
48
49
/// A semantic tree transformation that allows one to transform one
50
/// abstract syntax tree into another.
51
///
52
/// A new tree transformation is defined by creating a new subclass \c X of
53
/// \c TreeTransform<X> and then overriding certain operations to provide
54
/// behavior specific to that transformation. For example, template
55
/// instantiation is implemented as a tree transformation where the
56
/// transformation of TemplateTypeParmType nodes involves substituting the
57
/// template arguments for their corresponding template parameters; a similar
58
/// transformation is performed for non-type template parameters and
59
/// template template parameters.
60
///
61
/// This tree-transformation template uses static polymorphism to allow
62
/// subclasses to customize any of its operations. Thus, a subclass can
63
/// override any of the transformation or rebuild operators by providing an
64
/// operation with the same signature as the default implementation. The
65
/// overriding function should not be virtual.
66
///
67
/// Semantic tree transformations are split into two stages, either of which
68
/// can be replaced by a subclass. The "transform" step transforms an AST node
69
/// or the parts of an AST node using the various transformation functions,
70
/// then passes the pieces on to the "rebuild" step, which constructs a new AST
71
/// node of the appropriate kind from the pieces. The default transformation
72
/// routines recursively transform the operands to composite AST nodes (e.g.,
73
/// the pointee type of a PointerType node) and, if any of those operand nodes
74
/// were changed by the transformation, invokes the rebuild operation to create
75
/// a new AST node.
76
///
77
/// Subclasses can customize the transformation at various levels. The
78
/// most coarse-grained transformations involve replacing TransformType(),
79
/// TransformExpr(), TransformDecl(), TransformNestedNameSpecifierLoc(),
80
/// TransformTemplateName(), or TransformTemplateArgument() with entirely
81
/// new implementations.
82
///
83
/// For more fine-grained transformations, subclasses can replace any of the
84
/// \c TransformXXX functions (where XXX is the name of an AST node, e.g.,
85
/// PointerType, StmtExpr) to alter the transformation. As mentioned previously,
86
/// replacing TransformTemplateTypeParmType() allows template instantiation
87
/// to substitute template arguments for their corresponding template
88
/// parameters. Additionally, subclasses can override the \c RebuildXXX
89
/// functions to control how AST nodes are rebuilt when their operands change.
90
/// By default, \c TreeTransform will invoke semantic analysis to rebuild
91
/// AST nodes. However, certain other tree transformations (e.g, cloning) may
92
/// be able to use more efficient rebuild steps.
93
///
94
/// There are a handful of other functions that can be overridden, allowing one
95
/// to avoid traversing nodes that don't need any transformation
96
/// (\c AlreadyTransformed()), force rebuilding AST nodes even when their
97
/// operands have not changed (\c AlwaysRebuild()), and customize the
98
/// default locations and entity names used for type-checking
99
/// (\c getBaseLocation(), \c getBaseEntity()).
100
template<typename Derived>
101
class TreeTransform {
102
  /// Private RAII object that helps us forget and then re-remember
103
  /// the template argument corresponding to a partially-substituted parameter
104
  /// pack.
105
  class ForgetPartiallySubstitutedPackRAII {
106
    Derived &Self;
107
    TemplateArgument Old;
108
109
  public:
110
491
    ForgetPartiallySubstitutedPackRAII(Derived &Self) : Self(Self) {
111
491
      Old = Self.ForgetPartiallySubstitutedPack();
112
491
    }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::ForgetPartiallySubstitutedPackRAII::ForgetPartiallySubstitutedPackRAII(RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove&)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::ForgetPartiallySubstitutedPackRAII::ForgetPartiallySubstitutedPackRAII((anonymous namespace)::TransformToPE&)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::ForgetPartiallySubstitutedPackRAII::ForgetPartiallySubstitutedPackRAII((anonymous namespace)::TransformTypos&)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::ForgetPartiallySubstitutedPackRAII::ForgetPartiallySubstitutedPackRAII(clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace&)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::ForgetPartiallySubstitutedPackRAII::ForgetPartiallySubstitutedPackRAII((anonymous namespace)::TransformExprToCaptures&)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::ForgetPartiallySubstitutedPackRAII::ForgetPartiallySubstitutedPackRAII((anonymous namespace)::ExtractTypeForDeductionGuide&)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::ForgetPartiallySubstitutedPackRAII::ForgetPartiallySubstitutedPackRAII((anonymous namespace)::CurrentInstantiationRebuilder&)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::ForgetPartiallySubstitutedPackRAII::ForgetPartiallySubstitutedPackRAII((anonymous namespace)::SubstituteDeducedTypeTransform&)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::ForgetPartiallySubstitutedPackRAII::ForgetPartiallySubstitutedPackRAII((anonymous namespace)::TemplateInstantiator&)
Line
Count
Source
110
491
    ForgetPartiallySubstitutedPackRAII(Derived &Self) : Self(Self) {
111
491
      Old = Self.ForgetPartiallySubstitutedPack();
112
491
    }
113
114
491
    ~ForgetPartiallySubstitutedPackRAII() {
115
491
      Self.RememberPartiallySubstitutedPack(Old);
116
491
    }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::ForgetPartiallySubstitutedPackRAII::~ForgetPartiallySubstitutedPackRAII()
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::ForgetPartiallySubstitutedPackRAII::~ForgetPartiallySubstitutedPackRAII()
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::ForgetPartiallySubstitutedPackRAII::~ForgetPartiallySubstitutedPackRAII()
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::ForgetPartiallySubstitutedPackRAII::~ForgetPartiallySubstitutedPackRAII()
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::ForgetPartiallySubstitutedPackRAII::~ForgetPartiallySubstitutedPackRAII()
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::ForgetPartiallySubstitutedPackRAII::~ForgetPartiallySubstitutedPackRAII()
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::ForgetPartiallySubstitutedPackRAII::~ForgetPartiallySubstitutedPackRAII()
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::ForgetPartiallySubstitutedPackRAII::~ForgetPartiallySubstitutedPackRAII()
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::ForgetPartiallySubstitutedPackRAII::~ForgetPartiallySubstitutedPackRAII()
Line
Count
Source
114
491
    ~ForgetPartiallySubstitutedPackRAII() {
115
491
      Self.RememberPartiallySubstitutedPack(Old);
116
491
    }
117
  };
118
119
protected:
120
  Sema &SemaRef;
121
122
  /// The set of local declarations that have been transformed, for
123
  /// cases where we are forced to build new declarations within the transformer
124
  /// rather than in the subclass (e.g., lambda closure types).
125
  llvm::DenseMap<Decl *, Decl *> TransformedLocalDecls;
126
127
public:
128
  /// Initializes a new tree transformer.
129
9.26M
  TreeTransform(Sema &SemaRef) : SemaRef(SemaRef) { }
SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::TreeTransform(clang::Sema&)
Line
Count
Source
129
517
  TreeTransform(Sema &SemaRef) : SemaRef(SemaRef) { }
SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::TreeTransform(clang::Sema&)
Line
Count
Source
129
123
  TreeTransform(Sema &SemaRef) : SemaRef(SemaRef) { }
SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::TreeTransform(clang::Sema&)
Line
Count
Source
129
2.92k
  TreeTransform(Sema &SemaRef) : SemaRef(SemaRef) { }
SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::TreeTransform(clang::Sema&)
Line
Count
Source
129
351
  TreeTransform(Sema &SemaRef) : SemaRef(SemaRef) { }
SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::TreeTransform(clang::Sema&)
Line
Count
Source
129
36
  TreeTransform(Sema &SemaRef) : SemaRef(SemaRef) { }
SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::TreeTransform(clang::Sema&)
Line
Count
Source
129
2.20k
  TreeTransform(Sema &SemaRef) : SemaRef(SemaRef) { }
SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::TreeTransform(clang::Sema&)
Line
Count
Source
129
285k
  TreeTransform(Sema &SemaRef) : SemaRef(SemaRef) { }
SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::TreeTransform(clang::Sema&)
Line
Count
Source
129
44.1k
  TreeTransform(Sema &SemaRef) : SemaRef(SemaRef) { }
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::TreeTransform(clang::Sema&)
Line
Count
Source
129
8.92M
  TreeTransform(Sema &SemaRef) : SemaRef(SemaRef) { }
130
131
  /// Retrieves a reference to the derived class.
132
177M
  Derived &getDerived() { return static_cast<Derived&>(*this); }
SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::getDerived()
Line
Count
Source
132
3.91k
  Derived &getDerived() { return static_cast<Derived&>(*this); }
SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::getDerived()
Line
Count
Source
132
6.58k
  Derived &getDerived() { return static_cast<Derived&>(*this); }
SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::getDerived()
Line
Count
Source
132
9.05k
  Derived &getDerived() { return static_cast<Derived&>(*this); }
SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::getDerived()
Line
Count
Source
132
2.17k
  Derived &getDerived() { return static_cast<Derived&>(*this); }
SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::getDerived()
Line
Count
Source
132
960
  Derived &getDerived() { return static_cast<Derived&>(*this); }
SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::getDerived()
Line
Count
Source
132
379k
  Derived &getDerived() { return static_cast<Derived&>(*this); }
SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::getDerived()
Line
Count
Source
132
9.92M
  Derived &getDerived() { return static_cast<Derived&>(*this); }
SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::getDerived()
Line
Count
Source
132
155k
  Derived &getDerived() { return static_cast<Derived&>(*this); }
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::getDerived()
Line
Count
Source
132
166M
  Derived &getDerived() { return static_cast<Derived&>(*this); }
133
134
  /// Retrieves a reference to the derived class.
135
  const Derived &getDerived() const {
136
    return static_cast<const Derived&>(*this);
137
  }
138
139
4
  static inline ExprResult Owned(Expr *E) { return E; }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::Owned(clang::Expr*)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::Owned(clang::Expr*)
SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::Owned(clang::Expr*)
Line
Count
Source
139
2
  static inline ExprResult Owned(Expr *E) { return E; }
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::Owned(clang::Expr*)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::Owned(clang::Expr*)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::Owned(clang::Expr*)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::Owned(clang::Expr*)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::Owned(clang::Expr*)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::Owned(clang::Expr*)
Line
Count
Source
139
2
  static inline ExprResult Owned(Expr *E) { return E; }
140
141
  static inline StmtResult Owned(Stmt *S) { return S; }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::Owned(clang::Stmt*)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::Owned(clang::Stmt*)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::Owned(clang::Stmt*)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::Owned(clang::Stmt*)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::Owned(clang::Stmt*)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::Owned(clang::Stmt*)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::Owned(clang::Stmt*)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::Owned(clang::Stmt*)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::Owned(clang::Stmt*)
Line
Count
Source
140
141
  static inline StmtResult Owned(Stmt *S) { return S; }
141
142
  /// Retrieves a reference to the semantic analysis object used for
143
  /// this tree transform.
144
23.7M
  Sema &getSema() const { return SemaRef; }
SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::getSema() const
Line
Count
Source
144
574
  Sema &getSema() const { return SemaRef; }
SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::getSema() const
Line
Count
Source
144
1.45k
  Sema &getSema() const { return SemaRef; }
SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::getSema() const
Line
Count
Source
144
927
  Sema &getSema() const { return SemaRef; }
SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::getSema() const
Line
Count
Source
144
473
  Sema &getSema() const { return SemaRef; }
SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::getSema() const
Line
Count
Source
144
228
  Sema &getSema() const { return SemaRef; }
SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::getSema() const
Line
Count
Source
144
942
  Sema &getSema() const { return SemaRef; }
SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::getSema() const
Line
Count
Source
144
224k
  Sema &getSema() const { return SemaRef; }
SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::getSema() const
Line
Count
Source
144
6.31k
  Sema &getSema() const { return SemaRef; }
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::getSema() const
Line
Count
Source
144
23.5M
  Sema &getSema() const { return SemaRef; }
145
146
  /// Whether the transformation should always rebuild AST nodes, even
147
  /// if none of the children have changed.
148
  ///
149
  /// Subclasses may override this function to specify when the transformation
150
  /// should rebuild all AST nodes.
151
  ///
152
  /// We must always rebuild all AST nodes when performing variadic template
153
  /// pack expansion, in order to avoid violating the AST invariant that each
154
  /// statement node appears at most once in its containing declaration.
155
12.4M
  bool AlwaysRebuild() { return SemaRef.ArgumentPackSubstitutionIndex != -1; }
SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::AlwaysRebuild()
Line
Count
Source
155
621
  bool AlwaysRebuild() { return SemaRef.ArgumentPackSubstitutionIndex != -1; }
SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::AlwaysRebuild()
Line
Count
Source
155
251
  bool AlwaysRebuild() { return SemaRef.ArgumentPackSubstitutionIndex != -1; }
SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::AlwaysRebuild()
Line
Count
Source
155
132
  bool AlwaysRebuild() { return SemaRef.ArgumentPackSubstitutionIndex != -1; }
SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::AlwaysRebuild()
Line
Count
Source
155
11.9k
  bool AlwaysRebuild() { return SemaRef.ArgumentPackSubstitutionIndex != -1; }
SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::AlwaysRebuild()
Line
Count
Source
155
443k
  bool AlwaysRebuild() { return SemaRef.ArgumentPackSubstitutionIndex != -1; }
SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::AlwaysRebuild()
Line
Count
Source
155
7.01k
  bool AlwaysRebuild() { return SemaRef.ArgumentPackSubstitutionIndex != -1; }
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::AlwaysRebuild()
Line
Count
Source
155
11.9M
  bool AlwaysRebuild() { return SemaRef.ArgumentPackSubstitutionIndex != -1; }
156
157
  /// Whether the transformation is forming an expression or statement that
158
  /// replaces the original. In this case, we'll reuse mangling numbers from
159
  /// existing lambdas.
160
1.54k
  bool ReplacingOriginal() { return false; }
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::ReplacingOriginal()
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::ReplacingOriginal()
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::ReplacingOriginal()
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::ReplacingOriginal()
Line
Count
Source
160
1.54k
  bool ReplacingOriginal() { return false; }
161
162
  /// Wether CXXConstructExpr can be skipped when they are implicit.
163
  /// They will be reconstructed when used if needed.
164
  /// This is usefull when the user that cause rebuilding of the
165
  /// CXXConstructExpr is outside of the expression at which the TreeTransform
166
  /// started.
167
3.23k
  bool AllowSkippingCXXConstructExpr() { return true; }
SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::AllowSkippingCXXConstructExpr()
Line
Count
Source
167
1
  bool AllowSkippingCXXConstructExpr() { return true; }
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::AllowSkippingCXXConstructExpr()
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::AllowSkippingCXXConstructExpr()
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::AllowSkippingCXXConstructExpr()
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::AllowSkippingCXXConstructExpr()
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::AllowSkippingCXXConstructExpr()
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::AllowSkippingCXXConstructExpr()
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::AllowSkippingCXXConstructExpr()
Line
Count
Source
167
3.23k
  bool AllowSkippingCXXConstructExpr() { return true; }
168
169
  /// Returns the location of the entity being transformed, if that
170
  /// information was not available elsewhere in the AST.
171
  ///
172
  /// By default, returns no source-location information. Subclasses can
173
  /// provide an alternative implementation that provides better location
174
  /// information.
175
43.8k
  SourceLocation getBaseLocation() { return SourceLocation(); }
SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::getBaseLocation()
Line
Count
Source
175
205
  SourceLocation getBaseLocation() { return SourceLocation(); }
SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::getBaseLocation()
Line
Count
Source
175
45
  SourceLocation getBaseLocation() { return SourceLocation(); }
SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::getBaseLocation()
Line
Count
Source
175
71
  SourceLocation getBaseLocation() { return SourceLocation(); }
SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::getBaseLocation()
Line
Count
Source
175
24
  SourceLocation getBaseLocation() { return SourceLocation(); }
SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::getBaseLocation()
Line
Count
Source
175
12
  SourceLocation getBaseLocation() { return SourceLocation(); }
SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::getBaseLocation()
Line
Count
Source
175
30.4k
  SourceLocation getBaseLocation() { return SourceLocation(); }
SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::getBaseLocation()
Line
Count
Source
175
13.0k
  SourceLocation getBaseLocation() { return SourceLocation(); }
176
177
  /// Returns the name of the entity being transformed, if that
178
  /// information was not available elsewhere in the AST.
179
  ///
180
  /// By default, returns an empty name. Subclasses can provide an alternative
181
  /// implementation with a more precise name.
182
81.7k
  DeclarationName getBaseEntity() { return DeclarationName(); }
SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::getBaseEntity()
Line
Count
Source
182
263
  DeclarationName getBaseEntity() { return DeclarationName(); }
SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::getBaseEntity()
Line
Count
Source
182
129
  DeclarationName getBaseEntity() { return DeclarationName(); }
SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::getBaseEntity()
Line
Count
Source
182
142
  DeclarationName getBaseEntity() { return DeclarationName(); }
SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::getBaseEntity()
Line
Count
Source
182
45
  DeclarationName getBaseEntity() { return DeclarationName(); }
SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::getBaseEntity()
Line
Count
Source
182
24
  DeclarationName getBaseEntity() { return DeclarationName(); }
SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::getBaseEntity()
Line
Count
Source
182
61.5k
  DeclarationName getBaseEntity() { return DeclarationName(); }
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::getBaseEntity()
SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::getBaseEntity()
Line
Count
Source
182
19.5k
  DeclarationName getBaseEntity() { return DeclarationName(); }
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::getBaseEntity()
Line
Count
Source
182
79
  DeclarationName getBaseEntity() { return DeclarationName(); }
183
184
  /// Sets the "base" location and entity when that
185
  /// information is known based on another transformation.
186
  ///
187
  /// By default, the source location and entity are ignored. Subclasses can
188
  /// override this function to provide a customized implementation.
189
68.2k
  void setBase(SourceLocation Loc, DeclarationName Entity) { }
SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::setBase(clang::SourceLocation, clang::DeclarationName)
Line
Count
Source
189
263
  void setBase(SourceLocation Loc, DeclarationName Entity) { }
SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::setBase(clang::SourceLocation, clang::DeclarationName)
Line
Count
Source
189
73
  void setBase(SourceLocation Loc, DeclarationName Entity) { }
SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::setBase(clang::SourceLocation, clang::DeclarationName)
Line
Count
Source
189
142
  void setBase(SourceLocation Loc, DeclarationName Entity) { }
SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::setBase(clang::SourceLocation, clang::DeclarationName)
Line
Count
Source
189
43
  void setBase(SourceLocation Loc, DeclarationName Entity) { }
SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::setBase(clang::SourceLocation, clang::DeclarationName)
Line
Count
Source
189
24
  void setBase(SourceLocation Loc, DeclarationName Entity) { }
SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::setBase(clang::SourceLocation, clang::DeclarationName)
Line
Count
Source
189
60.8k
  void setBase(SourceLocation Loc, DeclarationName Entity) { }
SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::setBase(clang::SourceLocation, clang::DeclarationName)
Line
Count
Source
189
6.84k
  void setBase(SourceLocation Loc, DeclarationName Entity) { }
190
191
  /// RAII object that temporarily sets the base location and entity
192
  /// used for reporting diagnostics in types.
193
  class TemporaryBase {
194
    TreeTransform &Self;
195
    SourceLocation OldLocation;
196
    DeclarationName OldEntity;
197
198
  public:
199
    TemporaryBase(TreeTransform &Self, SourceLocation Location,
200
9.29M
                  DeclarationName Entity) : Self(Self) {
201
9.29M
      OldLocation = Self.getDerived().getBaseLocation();
202
9.29M
      OldEntity = Self.getDerived().getBaseEntity();
203
9.29M
204
9.29M
      if (Location.isValid())
205
9.25M
        Self.getDerived().setBase(Location, Entity);
206
9.29M
    }
SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::TemporaryBase::TemporaryBase(clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>&, clang::SourceLocation, clang::DeclarationName)
Line
Count
Source
200
156
                  DeclarationName Entity) : Self(Self) {
201
156
      OldLocation = Self.getDerived().getBaseLocation();
202
156
      OldEntity = Self.getDerived().getBaseEntity();
203
156
204
156
      if (Location.isValid())
205
107
        Self.getDerived().setBase(Location, Entity);
206
156
    }
SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::TemporaryBase::TemporaryBase(clang::TreeTransform<(anonymous namespace)::TransformToPE>&, clang::SourceLocation, clang::DeclarationName)
Line
Count
Source
200
37
                  DeclarationName Entity) : Self(Self) {
201
37
      OldLocation = Self.getDerived().getBaseLocation();
202
37
      OldEntity = Self.getDerived().getBaseEntity();
203
37
204
37
      if (Location.isValid())
205
36
        Self.getDerived().setBase(Location, Entity);
206
37
    }
SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::TemporaryBase::TemporaryBase(clang::TreeTransform<(anonymous namespace)::TransformTypos>&, clang::SourceLocation, clang::DeclarationName)
Line
Count
Source
200
71
                  DeclarationName Entity) : Self(Self) {
201
71
      OldLocation = Self.getDerived().getBaseLocation();
202
71
      OldEntity = Self.getDerived().getBaseEntity();
203
71
204
71
      if (Location.isValid())
205
71
        Self.getDerived().setBase(Location, Entity);
206
71
    }
SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::TemporaryBase::TemporaryBase(clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>&, clang::SourceLocation, clang::DeclarationName)
Line
Count
Source
200
22
                  DeclarationName Entity) : Self(Self) {
201
22
      OldLocation = Self.getDerived().getBaseLocation();
202
22
      OldEntity = Self.getDerived().getBaseEntity();
203
22
204
22
      if (Location.isValid())
205
21
        Self.getDerived().setBase(Location, Entity);
206
22
    }
SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::TemporaryBase::TemporaryBase(clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>&, clang::SourceLocation, clang::DeclarationName)
Line
Count
Source
200
12
                  DeclarationName Entity) : Self(Self) {
201
12
      OldLocation = Self.getDerived().getBaseLocation();
202
12
      OldEntity = Self.getDerived().getBaseEntity();
203
12
204
12
      if (Location.isValid())
205
12
        Self.getDerived().setBase(Location, Entity);
206
12
    }
SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::TemporaryBase::TemporaryBase(clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>&, clang::SourceLocation, clang::DeclarationName)
Line
Count
Source
200
30.4k
                  DeclarationName Entity) : Self(Self) {
201
30.4k
      OldLocation = Self.getDerived().getBaseLocation();
202
30.4k
      OldEntity = Self.getDerived().getBaseEntity();
203
30.4k
204
30.4k
      if (Location.isValid())
205
30.4k
        Self.getDerived().setBase(Location, Entity);
206
30.4k
    }
SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::TemporaryBase::TemporaryBase(clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>&, clang::SourceLocation, clang::DeclarationName)
Line
Count
Source
200
667k
                  DeclarationName Entity) : Self(Self) {
201
667k
      OldLocation = Self.getDerived().getBaseLocation();
202
667k
      OldEntity = Self.getDerived().getBaseEntity();
203
667k
204
667k
      if (Location.isValid())
205
667k
        Self.getDerived().setBase(Location, Entity);
206
667k
    }
SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::TemporaryBase::TemporaryBase(clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>&, clang::SourceLocation, clang::DeclarationName)
Line
Count
Source
200
6.59k
                  DeclarationName Entity) : Self(Self) {
201
6.59k
      OldLocation = Self.getDerived().getBaseLocation();
202
6.59k
      OldEntity = Self.getDerived().getBaseEntity();
203
6.59k
204
6.59k
      if (Location.isValid())
205
254
        Self.getDerived().setBase(Location, Entity);
206
6.59k
    }
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::TemporaryBase::TemporaryBase(clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>&, clang::SourceLocation, clang::DeclarationName)
Line
Count
Source
200
8.59M
                  DeclarationName Entity) : Self(Self) {
201
8.59M
      OldLocation = Self.getDerived().getBaseLocation();
202
8.59M
      OldEntity = Self.getDerived().getBaseEntity();
203
8.59M
204
8.59M
      if (Location.isValid())
205
8.56M
        Self.getDerived().setBase(Location, Entity);
206
8.59M
    }
207
208
9.29M
    ~TemporaryBase() {
209
9.29M
      Self.getDerived().setBase(OldLocation, OldEntity);
210
9.29M
    }
SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::TemporaryBase::~TemporaryBase()
Line
Count
Source
208
156
    ~TemporaryBase() {
209
156
      Self.getDerived().setBase(OldLocation, OldEntity);
210
156
    }
SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::TemporaryBase::~TemporaryBase()
Line
Count
Source
208
37
    ~TemporaryBase() {
209
37
      Self.getDerived().setBase(OldLocation, OldEntity);
210
37
    }
SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::TemporaryBase::~TemporaryBase()
Line
Count
Source
208
71
    ~TemporaryBase() {
209
71
      Self.getDerived().setBase(OldLocation, OldEntity);
210
71
    }
SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::TemporaryBase::~TemporaryBase()
Line
Count
Source
208
22
    ~TemporaryBase() {
209
22
      Self.getDerived().setBase(OldLocation, OldEntity);
210
22
    }
SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::TemporaryBase::~TemporaryBase()
Line
Count
Source
208
12
    ~TemporaryBase() {
209
12
      Self.getDerived().setBase(OldLocation, OldEntity);
210
12
    }
SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::TemporaryBase::~TemporaryBase()
Line
Count
Source
208
30.4k
    ~TemporaryBase() {
209
30.4k
      Self.getDerived().setBase(OldLocation, OldEntity);
210
30.4k
    }
SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::TemporaryBase::~TemporaryBase()
Line
Count
Source
208
667k
    ~TemporaryBase() {
209
667k
      Self.getDerived().setBase(OldLocation, OldEntity);
210
667k
    }
SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::TemporaryBase::~TemporaryBase()
Line
Count
Source
208
6.59k
    ~TemporaryBase() {
209
6.59k
      Self.getDerived().setBase(OldLocation, OldEntity);
210
6.59k
    }
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::TemporaryBase::~TemporaryBase()
Line
Count
Source
208
8.59M
    ~TemporaryBase() {
209
8.59M
      Self.getDerived().setBase(OldLocation, OldEntity);
210
8.59M
    }
211
  };
212
213
  /// Determine whether the given type \p T has already been
214
  /// transformed.
215
  ///
216
  /// Subclasses can provide an alternative implementation of this routine
217
  /// to short-circuit evaluation when it is known that a given type will
218
  /// not change. For example, template instantiation need not traverse
219
  /// non-dependent types.
220
53.9k
  bool AlreadyTransformed(QualType T) {
221
53.9k
    return T.isNull();
222
53.9k
  }
SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::AlreadyTransformed(clang::QualType)
Line
Count
Source
220
156
  bool AlreadyTransformed(QualType T) {
221
156
    return T.isNull();
222
156
  }
SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::AlreadyTransformed(clang::QualType)
Line
Count
Source
220
51
  bool AlreadyTransformed(QualType T) {
221
51
    return T.isNull();
222
51
  }
SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::AlreadyTransformed(clang::QualType)
Line
Count
Source
220
75
  bool AlreadyTransformed(QualType T) {
221
75
    return T.isNull();
222
75
  }
SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::AlreadyTransformed(clang::QualType)
Line
Count
Source
220
27
  bool AlreadyTransformed(QualType T) {
221
27
    return T.isNull();
222
27
  }
SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::AlreadyTransformed(clang::QualType)
Line
Count
Source
220
36
  bool AlreadyTransformed(QualType T) {
221
36
    return T.isNull();
222
36
  }
SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::AlreadyTransformed(clang::QualType)
Line
Count
Source
220
40.8k
  bool AlreadyTransformed(QualType T) {
221
40.8k
    return T.isNull();
222
40.8k
  }
SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::AlreadyTransformed(clang::QualType)
Line
Count
Source
220
12.7k
  bool AlreadyTransformed(QualType T) {
221
12.7k
    return T.isNull();
222
12.7k
  }
223
224
  /// Transform a template parameter depth level.
225
  ///
226
  /// During a transformation that transforms template parameters, this maps
227
  /// an old template parameter depth to a new depth.
228
1
  unsigned TransformTemplateDepth(unsigned Depth) {
229
1
    return Depth;
230
1
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::TransformTemplateDepth(unsigned int)
SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::TransformTemplateDepth(unsigned int)
Line
Count
Source
228
1
  unsigned TransformTemplateDepth(unsigned Depth) {
229
1
    return Depth;
230
1
  }
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::TransformTemplateDepth(unsigned int)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::TransformTemplateDepth(unsigned int)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::TransformTemplateDepth(unsigned int)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::TransformTemplateDepth(unsigned int)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::TransformTemplateDepth(unsigned int)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::TransformTemplateDepth(unsigned int)
231
232
  /// Determine whether the given call argument should be dropped, e.g.,
233
  /// because it is a default argument.
234
  ///
235
  /// Subclasses can provide an alternative implementation of this routine to
236
  /// determine which kinds of call arguments get dropped. By default,
237
  /// CXXDefaultArgument nodes are dropped (prior to transformation).
238
359k
  bool DropCallArgument(Expr *E) {
239
359k
    return E->isDefaultArgument();
240
359k
  }
SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::DropCallArgument(clang::Expr*)
Line
Count
Source
238
167
  bool DropCallArgument(Expr *E) {
239
167
    return E->isDefaultArgument();
240
167
  }
SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::DropCallArgument(clang::Expr*)
Line
Count
Source
238
36
  bool DropCallArgument(Expr *E) {
239
36
    return E->isDefaultArgument();
240
36
  }
SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::DropCallArgument(clang::Expr*)
Line
Count
Source
238
312
  bool DropCallArgument(Expr *E) {
239
312
    return E->isDefaultArgument();
240
312
  }
SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::DropCallArgument(clang::Expr*)
Line
Count
Source
238
87
  bool DropCallArgument(Expr *E) {
239
87
    return E->isDefaultArgument();
240
87
  }
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::DropCallArgument(clang::Expr*)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::DropCallArgument(clang::Expr*)
SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::DropCallArgument(clang::Expr*)
Line
Count
Source
238
5
  bool DropCallArgument(Expr *E) {
239
5
    return E->isDefaultArgument();
240
5
  }
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::DropCallArgument(clang::Expr*)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::DropCallArgument(clang::Expr*)
Line
Count
Source
238
358k
  bool DropCallArgument(Expr *E) {
239
358k
    return E->isDefaultArgument();
240
358k
  }
241
242
  /// Determine whether we should expand a pack expansion with the
243
  /// given set of parameter packs into separate arguments by repeatedly
244
  /// transforming the pattern.
245
  ///
246
  /// By default, the transformer never tries to expand pack expansions.
247
  /// Subclasses can override this routine to provide different behavior.
248
  ///
249
  /// \param EllipsisLoc The location of the ellipsis that identifies the
250
  /// pack expansion.
251
  ///
252
  /// \param PatternRange The source range that covers the entire pattern of
253
  /// the pack expansion.
254
  ///
255
  /// \param Unexpanded The set of unexpanded parameter packs within the
256
  /// pattern.
257
  ///
258
  /// \param ShouldExpand Will be set to \c true if the transformer should
259
  /// expand the corresponding pack expansions into separate arguments. When
260
  /// set, \c NumExpansions must also be set.
261
  ///
262
  /// \param RetainExpansion Whether the caller should add an unexpanded
263
  /// pack expansion after all of the expanded arguments. This is used
264
  /// when extending explicitly-specified template argument packs per
265
  /// C++0x [temp.arg.explicit]p9.
266
  ///
267
  /// \param NumExpansions The number of separate arguments that will be in
268
  /// the expanded form of the corresponding pack expansion. This is both an
269
  /// input and an output parameter, which can be set by the caller if the
270
  /// number of expansions is known a priori (e.g., due to a prior substitution)
271
  /// and will be set by the callee when the number of expansions is known.
272
  /// The callee must set this value when \c ShouldExpand is \c true; it may
273
  /// set this value in other cases.
274
  ///
275
  /// \returns true if an error occurred (e.g., because the parameter packs
276
  /// are to be instantiated with arguments of different lengths), false
277
  /// otherwise. If false, \c ShouldExpand (and possibly \c NumExpansions)
278
  /// must be set.
279
  bool TryExpandParameterPacks(SourceLocation EllipsisLoc,
280
                               SourceRange PatternRange,
281
                               ArrayRef<UnexpandedParameterPack> Unexpanded,
282
                               bool &ShouldExpand,
283
                               bool &RetainExpansion,
284
23.8k
                               Optional<unsigned> &NumExpansions) {
285
23.8k
    ShouldExpand = false;
286
23.8k
    return false;
287
23.8k
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::TryExpandParameterPacks(clang::SourceLocation, clang::SourceRange, llvm::ArrayRef<std::__1::pair<llvm::PointerUnion<clang::TemplateTypeParmType const*, clang::NamedDecl*>, clang::SourceLocation> >, bool&, bool&, llvm::Optional<unsigned int>&)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::TryExpandParameterPacks(clang::SourceLocation, clang::SourceRange, llvm::ArrayRef<std::__1::pair<llvm::PointerUnion<clang::TemplateTypeParmType const*, clang::NamedDecl*>, clang::SourceLocation> >, bool&, bool&, llvm::Optional<unsigned int>&)
SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::TryExpandParameterPacks(clang::SourceLocation, clang::SourceRange, llvm::ArrayRef<std::__1::pair<llvm::PointerUnion<clang::TemplateTypeParmType const*, clang::NamedDecl*>, clang::SourceLocation> >, bool&, bool&, llvm::Optional<unsigned int>&)
Line
Count
Source
284
7
                               Optional<unsigned> &NumExpansions) {
285
7
    ShouldExpand = false;
286
7
    return false;
287
7
  }
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::TryExpandParameterPacks(clang::SourceLocation, clang::SourceRange, llvm::ArrayRef<std::__1::pair<llvm::PointerUnion<clang::TemplateTypeParmType const*, clang::NamedDecl*>, clang::SourceLocation> >, bool&, bool&, llvm::Optional<unsigned int>&)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::TryExpandParameterPacks(clang::SourceLocation, clang::SourceRange, llvm::ArrayRef<std::__1::pair<llvm::PointerUnion<clang::TemplateTypeParmType const*, clang::NamedDecl*>, clang::SourceLocation> >, bool&, bool&, llvm::Optional<unsigned int>&)
SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::TryExpandParameterPacks(clang::SourceLocation, clang::SourceRange, llvm::ArrayRef<std::__1::pair<llvm::PointerUnion<clang::TemplateTypeParmType const*, clang::NamedDecl*>, clang::SourceLocation> >, bool&, bool&, llvm::Optional<unsigned int>&)
Line
Count
Source
284
40
                               Optional<unsigned> &NumExpansions) {
285
40
    ShouldExpand = false;
286
40
    return false;
287
40
  }
SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::TryExpandParameterPacks(clang::SourceLocation, clang::SourceRange, llvm::ArrayRef<std::__1::pair<llvm::PointerUnion<clang::TemplateTypeParmType const*, clang::NamedDecl*>, clang::SourceLocation> >, bool&, bool&, llvm::Optional<unsigned int>&)
Line
Count
Source
284
23.7k
                               Optional<unsigned> &NumExpansions) {
285
23.7k
    ShouldExpand = false;
286
23.7k
    return false;
287
23.7k
  }
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::TryExpandParameterPacks(clang::SourceLocation, clang::SourceRange, llvm::ArrayRef<std::__1::pair<llvm::PointerUnion<clang::TemplateTypeParmType const*, clang::NamedDecl*>, clang::SourceLocation> >, bool&, bool&, llvm::Optional<unsigned int>&)
288
289
  /// "Forget" about the partially-substituted pack template argument,
290
  /// when performing an instantiation that must preserve the parameter pack
291
  /// use.
292
  ///
293
  /// This routine is meant to be overridden by the template instantiator.
294
0
  TemplateArgument ForgetPartiallySubstitutedPack() {
295
0
    return TemplateArgument();
296
0
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::ForgetPartiallySubstitutedPack()
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::ForgetPartiallySubstitutedPack()
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::ForgetPartiallySubstitutedPack()
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::ForgetPartiallySubstitutedPack()
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::ForgetPartiallySubstitutedPack()
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::ForgetPartiallySubstitutedPack()
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::ForgetPartiallySubstitutedPack()
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::ForgetPartiallySubstitutedPack()
297
298
  /// "Remember" the partially-substituted pack template argument
299
  /// after performing an instantiation that must preserve the parameter pack
300
  /// use.
301
  ///
302
  /// This routine is meant to be overridden by the template instantiator.
303
0
  void RememberPartiallySubstitutedPack(TemplateArgument Arg) { }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RememberPartiallySubstitutedPack(clang::TemplateArgument)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RememberPartiallySubstitutedPack(clang::TemplateArgument)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RememberPartiallySubstitutedPack(clang::TemplateArgument)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RememberPartiallySubstitutedPack(clang::TemplateArgument)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RememberPartiallySubstitutedPack(clang::TemplateArgument)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RememberPartiallySubstitutedPack(clang::TemplateArgument)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RememberPartiallySubstitutedPack(clang::TemplateArgument)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RememberPartiallySubstitutedPack(clang::TemplateArgument)
304
305
  /// Note to the derived class when a function parameter pack is
306
  /// being expanded.
307
0
  void ExpandingFunctionParameterPack(ParmVarDecl *Pack) { }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::ExpandingFunctionParameterPack(clang::ParmVarDecl*)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::ExpandingFunctionParameterPack(clang::ParmVarDecl*)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::ExpandingFunctionParameterPack(clang::ParmVarDecl*)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::ExpandingFunctionParameterPack(clang::ParmVarDecl*)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::ExpandingFunctionParameterPack(clang::ParmVarDecl*)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::ExpandingFunctionParameterPack(clang::ParmVarDecl*)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::ExpandingFunctionParameterPack(clang::ParmVarDecl*)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::ExpandingFunctionParameterPack(clang::ParmVarDecl*)
308
309
  /// Transforms the given type into another type.
310
  ///
311
  /// By default, this routine transforms a type by creating a
312
  /// TypeSourceInfo for it and delegating to the appropriate
313
  /// function.  This is expensive, but we don't mind, because
314
  /// this method is deprecated anyway;  all users should be
315
  /// switched to storing TypeSourceInfos.
316
  ///
317
  /// \returns the transformed type.
318
  QualType TransformType(QualType T);
319
320
  /// Transforms the given type-with-location into a new
321
  /// type-with-location.
322
  ///
323
  /// By default, this routine transforms a type by delegating to the
324
  /// appropriate TransformXXXType to build a new type.  Subclasses
325
  /// may override this function (to take over all type
326
  /// transformations) or some set of the TransformXXXType functions
327
  /// to alter the transformation.
328
  TypeSourceInfo *TransformType(TypeSourceInfo *DI);
329
330
  /// Transform the given type-with-location into a new
331
  /// type, collecting location information in the given builder
332
  /// as necessary.
333
  ///
334
  QualType TransformType(TypeLocBuilder &TLB, TypeLoc TL);
335
336
  /// Transform a type that is permitted to produce a
337
  /// DeducedTemplateSpecializationType.
338
  ///
339
  /// This is used in the (relatively rare) contexts where it is acceptable
340
  /// for transformation to produce a class template type with deduced
341
  /// template arguments.
342
  /// @{
343
  QualType TransformTypeWithDeducedTST(QualType T);
344
  TypeSourceInfo *TransformTypeWithDeducedTST(TypeSourceInfo *DI);
345
  /// @}
346
347
  /// The reason why the value of a statement is not discarded, if any.
348
  enum StmtDiscardKind {
349
    SDK_Discarded,
350
    SDK_NotDiscarded,
351
    SDK_StmtExprResult,
352
  };
353
354
  /// Transform the given statement.
355
  ///
356
  /// By default, this routine transforms a statement by delegating to the
357
  /// appropriate TransformXXXStmt function to transform a specific kind of
358
  /// statement or the TransformExpr() function to transform an expression.
359
  /// Subclasses may override this function to transform statements using some
360
  /// other mechanism.
361
  ///
362
  /// \returns the transformed statement.
363
  StmtResult TransformStmt(Stmt *S, StmtDiscardKind SDK = SDK_Discarded);
364
365
  /// Transform the given statement.
366
  ///
367
  /// By default, this routine transforms a statement by delegating to the
368
  /// appropriate TransformOMPXXXClause function to transform a specific kind
369
  /// of clause. Subclasses may override this function to transform statements
370
  /// using some other mechanism.
371
  ///
372
  /// \returns the transformed OpenMP clause.
373
  OMPClause *TransformOMPClause(OMPClause *S);
374
375
  /// Transform the given attribute.
376
  ///
377
  /// By default, this routine transforms a statement by delegating to the
378
  /// appropriate TransformXXXAttr function to transform a specific kind
379
  /// of attribute. Subclasses may override this function to transform
380
  /// attributed statements using some other mechanism.
381
  ///
382
  /// \returns the transformed attribute
383
  const Attr *TransformAttr(const Attr *S);
384
385
/// Transform the specified attribute.
386
///
387
/// Subclasses should override the transformation of attributes with a pragma
388
/// spelling to transform expressions stored within the attribute.
389
///
390
/// \returns the transformed attribute.
391
#define ATTR(X)
392
#define PRAGMA_SPELLING_ATTR(X)                                                \
393
0
  const X##Attr *Transform##X##Attr(const X##Attr *R) { return R; }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::TransformInitSegAttr(clang::InitSegAttr const*)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::TransformLoopHintAttr(clang::LoopHintAttr const*)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::TransformOMPDeclareSimdDeclAttr(clang::OMPDeclareSimdDeclAttr const*)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::TransformOMPDeclareTargetDeclAttr(clang::OMPDeclareTargetDeclAttr const*)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::TransformOMPDeclareVariantAttr(clang::OMPDeclareVariantAttr const*)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::TransformInitSegAttr(clang::InitSegAttr const*)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::TransformLoopHintAttr(clang::LoopHintAttr const*)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::TransformOMPDeclareSimdDeclAttr(clang::OMPDeclareSimdDeclAttr const*)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::TransformOMPDeclareTargetDeclAttr(clang::OMPDeclareTargetDeclAttr const*)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::TransformOMPDeclareVariantAttr(clang::OMPDeclareVariantAttr const*)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::TransformInitSegAttr(clang::InitSegAttr const*)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::TransformLoopHintAttr(clang::LoopHintAttr const*)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::TransformOMPDeclareSimdDeclAttr(clang::OMPDeclareSimdDeclAttr const*)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::TransformOMPDeclareTargetDeclAttr(clang::OMPDeclareTargetDeclAttr const*)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::TransformOMPDeclareVariantAttr(clang::OMPDeclareVariantAttr const*)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::TransformInitSegAttr(clang::InitSegAttr const*)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::TransformLoopHintAttr(clang::LoopHintAttr const*)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::TransformOMPDeclareSimdDeclAttr(clang::OMPDeclareSimdDeclAttr const*)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::TransformOMPDeclareTargetDeclAttr(clang::OMPDeclareTargetDeclAttr const*)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::TransformOMPDeclareVariantAttr(clang::OMPDeclareVariantAttr const*)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::TransformInitSegAttr(clang::InitSegAttr const*)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::TransformLoopHintAttr(clang::LoopHintAttr const*)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::TransformOMPDeclareSimdDeclAttr(clang::OMPDeclareSimdDeclAttr const*)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::TransformOMPDeclareTargetDeclAttr(clang::OMPDeclareTargetDeclAttr const*)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::TransformOMPDeclareVariantAttr(clang::OMPDeclareVariantAttr const*)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::TransformInitSegAttr(clang::InitSegAttr const*)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::TransformLoopHintAttr(clang::LoopHintAttr const*)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::TransformOMPDeclareSimdDeclAttr(clang::OMPDeclareSimdDeclAttr const*)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::TransformOMPDeclareTargetDeclAttr(clang::OMPDeclareTargetDeclAttr const*)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::TransformOMPDeclareVariantAttr(clang::OMPDeclareVariantAttr const*)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::TransformInitSegAttr(clang::InitSegAttr const*)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::TransformLoopHintAttr(clang::LoopHintAttr const*)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::TransformOMPDeclareSimdDeclAttr(clang::OMPDeclareSimdDeclAttr const*)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::TransformOMPDeclareTargetDeclAttr(clang::OMPDeclareTargetDeclAttr const*)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::TransformOMPDeclareVariantAttr(clang::OMPDeclareVariantAttr const*)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::TransformInitSegAttr(clang::InitSegAttr const*)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::TransformLoopHintAttr(clang::LoopHintAttr const*)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::TransformOMPDeclareSimdDeclAttr(clang::OMPDeclareSimdDeclAttr const*)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::TransformOMPDeclareTargetDeclAttr(clang::OMPDeclareTargetDeclAttr const*)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::TransformOMPDeclareVariantAttr(clang::OMPDeclareVariantAttr const*)
Unexecuted instantiation: SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::TransformInitSegAttr(clang::InitSegAttr const*)
Unexecuted instantiation: SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::TransformOMPDeclareSimdDeclAttr(clang::OMPDeclareSimdDeclAttr const*)
Unexecuted instantiation: SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::TransformOMPDeclareTargetDeclAttr(clang::OMPDeclareTargetDeclAttr const*)
Unexecuted instantiation: SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::TransformOMPDeclareVariantAttr(clang::OMPDeclareVariantAttr const*)
394
#include "clang/Basic/AttrList.inc"
395
396
  /// Transform the given expression.
397
  ///
398
  /// By default, this routine transforms an expression by delegating to the
399
  /// appropriate TransformXXXExpr function to build a new expression.
400
  /// Subclasses may override this function to transform expressions using some
401
  /// other mechanism.
402
  ///
403
  /// \returns the transformed expression.
404
  ExprResult TransformExpr(Expr *E);
405
406
  /// Transform the given initializer.
407
  ///
408
  /// By default, this routine transforms an initializer by stripping off the
409
  /// semantic nodes added by initialization, then passing the result to
410
  /// TransformExpr or TransformExprs.
411
  ///
412
  /// \returns the transformed initializer.
413
  ExprResult TransformInitializer(Expr *Init, bool NotCopyInit);
414
415
  /// Transform the given list of expressions.
416
  ///
417
  /// This routine transforms a list of expressions by invoking
418
  /// \c TransformExpr() for each subexpression. However, it also provides
419
  /// support for variadic templates by expanding any pack expansions (if the
420
  /// derived class permits such expansion) along the way. When pack expansions
421
  /// are present, the number of outputs may not equal the number of inputs.
422
  ///
423
  /// \param Inputs The set of expressions to be transformed.
424
  ///
425
  /// \param NumInputs The number of expressions in \c Inputs.
426
  ///
427
  /// \param IsCall If \c true, then this transform is being performed on
428
  /// function-call arguments, and any arguments that should be dropped, will
429
  /// be.
430
  ///
431
  /// \param Outputs The transformed input expressions will be added to this
432
  /// vector.
433
  ///
434
  /// \param ArgChanged If non-NULL, will be set \c true if any argument changed
435
  /// due to transformation.
436
  ///
437
  /// \returns true if an error occurred, false otherwise.
438
  bool TransformExprs(Expr *const *Inputs, unsigned NumInputs, bool IsCall,
439
                      SmallVectorImpl<Expr *> &Outputs,
440
                      bool *ArgChanged = nullptr);
441
442
  /// Transform the given declaration, which is referenced from a type
443
  /// or expression.
444
  ///
445
  /// By default, acts as the identity function on declarations, unless the
446
  /// transformer has had to transform the declaration itself. Subclasses
447
  /// may override this function to provide alternate behavior.
448
367k
  Decl *TransformDecl(SourceLocation Loc, Decl *D) {
449
367k
    llvm::DenseMap<Decl *, Decl *>::iterator Known
450
367k
      = TransformedLocalDecls.find(D);
451
367k
    if (Known != TransformedLocalDecls.end())
452
0
      return Known->second;
453
367k
454
367k
    return D;
455
367k
  }
SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::TransformDecl(clang::SourceLocation, clang::Decl*)
Line
Count
Source
448
224
  Decl *TransformDecl(SourceLocation Loc, Decl *D) {
449
224
    llvm::DenseMap<Decl *, Decl *>::iterator Known
450
224
      = TransformedLocalDecls.find(D);
451
224
    if (Known != TransformedLocalDecls.end())
452
0
      return Known->second;
453
224
454
224
    return D;
455
224
  }
SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::TransformDecl(clang::SourceLocation, clang::Decl*)
Line
Count
Source
448
603
  Decl *TransformDecl(SourceLocation Loc, Decl *D) {
449
603
    llvm::DenseMap<Decl *, Decl *>::iterator Known
450
603
      = TransformedLocalDecls.find(D);
451
603
    if (Known != TransformedLocalDecls.end())
452
0
      return Known->second;
453
603
454
603
    return D;
455
603
  }
SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::TransformDecl(clang::SourceLocation, clang::Decl*)
Line
Count
Source
448
385
  Decl *TransformDecl(SourceLocation Loc, Decl *D) {
449
385
    llvm::DenseMap<Decl *, Decl *>::iterator Known
450
385
      = TransformedLocalDecls.find(D);
451
385
    if (Known != TransformedLocalDecls.end())
452
0
      return Known->second;
453
385
454
385
    return D;
455
385
  }
SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::TransformDecl(clang::SourceLocation, clang::Decl*)
Line
Count
Source
448
112
  Decl *TransformDecl(SourceLocation Loc, Decl *D) {
449
112
    llvm::DenseMap<Decl *, Decl *>::iterator Known
450
112
      = TransformedLocalDecls.find(D);
451
112
    if (Known != TransformedLocalDecls.end())
452
0
      return Known->second;
453
112
454
112
    return D;
455
112
  }
SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::TransformDecl(clang::SourceLocation, clang::Decl*)
Line
Count
Source
448
72
  Decl *TransformDecl(SourceLocation Loc, Decl *D) {
449
72
    llvm::DenseMap<Decl *, Decl *>::iterator Known
450
72
      = TransformedLocalDecls.find(D);
451
72
    if (Known != TransformedLocalDecls.end())
452
0
      return Known->second;
453
72
454
72
    return D;
455
72
  }
SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::TransformDecl(clang::SourceLocation, clang::Decl*)
Line
Count
Source
448
10.3k
  Decl *TransformDecl(SourceLocation Loc, Decl *D) {
449
10.3k
    llvm::DenseMap<Decl *, Decl *>::iterator Known
450
10.3k
      = TransformedLocalDecls.find(D);
451
10.3k
    if (Known != TransformedLocalDecls.end())
452
0
      return Known->second;
453
10.3k
454
10.3k
    return D;
455
10.3k
  }
SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::TransformDecl(clang::SourceLocation, clang::Decl*)
Line
Count
Source
448
355k
  Decl *TransformDecl(SourceLocation Loc, Decl *D) {
449
355k
    llvm::DenseMap<Decl *, Decl *>::iterator Known
450
355k
      = TransformedLocalDecls.find(D);
451
355k
    if (Known != TransformedLocalDecls.end())
452
0
      return Known->second;
453
355k
454
355k
    return D;
455
355k
  }
SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::TransformDecl(clang::SourceLocation, clang::Decl*)
Line
Count
Source
448
228
  Decl *TransformDecl(SourceLocation Loc, Decl *D) {
449
228
    llvm::DenseMap<Decl *, Decl *>::iterator Known
450
228
      = TransformedLocalDecls.find(D);
451
228
    if (Known != TransformedLocalDecls.end())
452
0
      return Known->second;
453
228
454
228
    return D;
455
228
  }
456
457
  /// Transform the specified condition.
458
  ///
459
  /// By default, this transforms the variable and expression and rebuilds
460
  /// the condition.
461
  Sema::ConditionResult TransformCondition(SourceLocation Loc, VarDecl *Var,
462
                                           Expr *Expr,
463
                                           Sema::ConditionKind Kind);
464
465
  /// Transform the attributes associated with the given declaration and
466
  /// place them on the new declaration.
467
  ///
468
  /// By default, this operation does nothing. Subclasses may override this
469
  /// behavior to transform attributes.
470
7
  void transformAttrs(Decl *Old, Decl *New) { }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::transformAttrs(clang::Decl*, clang::Decl*)
SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::transformAttrs(clang::Decl*, clang::Decl*)
Line
Count
Source
470
7
  void transformAttrs(Decl *Old, Decl *New) { }
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::transformAttrs(clang::Decl*, clang::Decl*)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::transformAttrs(clang::Decl*, clang::Decl*)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::transformAttrs(clang::Decl*, clang::Decl*)
471
472
  /// Note that a local declaration has been transformed by this
473
  /// transformer.
474
  ///
475
  /// Local declarations are typically transformed via a call to
476
  /// TransformDefinition. However, in some cases (e.g., lambda expressions),
477
  /// the transformer itself has to transform the declarations. This routine
478
  /// can be overridden by a subclass that keeps track of such mappings.
479
14
  void transformedLocalDecl(Decl *Old, ArrayRef<Decl *> New) {
480
14
    assert(New.size() == 1 &&
481
14
           "must override transformedLocalDecl if performing pack expansion");
482
14
    TransformedLocalDecls[Old] = New.front();
483
14
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::transformedLocalDecl(clang::Decl*, llvm::ArrayRef<clang::Decl*>)
SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::transformedLocalDecl(clang::Decl*, llvm::ArrayRef<clang::Decl*>)
Line
Count
Source
479
14
  void transformedLocalDecl(Decl *Old, ArrayRef<Decl *> New) {
480
14
    assert(New.size() == 1 &&
481
14
           "must override transformedLocalDecl if performing pack expansion");
482
14
    TransformedLocalDecls[Old] = New.front();
483
14
  }
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::transformedLocalDecl(clang::Decl*, llvm::ArrayRef<clang::Decl*>)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::transformedLocalDecl(clang::Decl*, llvm::ArrayRef<clang::Decl*>)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::transformedLocalDecl(clang::Decl*, llvm::ArrayRef<clang::Decl*>)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::transformedLocalDecl(clang::Decl*, llvm::ArrayRef<clang::Decl*>)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::transformedLocalDecl(clang::Decl*, llvm::ArrayRef<clang::Decl*>)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::transformedLocalDecl(clang::Decl*, llvm::ArrayRef<clang::Decl*>)
484
485
  /// Transform the definition of the given declaration.
486
  ///
487
  /// By default, invokes TransformDecl() to transform the declaration.
488
  /// Subclasses may override this function to provide alternate behavior.
489
0
  Decl *TransformDefinition(SourceLocation Loc, Decl *D) {
490
0
    return getDerived().TransformDecl(Loc, D);
491
0
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::TransformDefinition(clang::SourceLocation, clang::Decl*)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::TransformDefinition(clang::SourceLocation, clang::Decl*)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::TransformDefinition(clang::SourceLocation, clang::Decl*)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::TransformDefinition(clang::SourceLocation, clang::Decl*)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::TransformDefinition(clang::SourceLocation, clang::Decl*)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::TransformDefinition(clang::SourceLocation, clang::Decl*)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::TransformDefinition(clang::SourceLocation, clang::Decl*)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::TransformDefinition(clang::SourceLocation, clang::Decl*)
492
493
  /// Transform the given declaration, which was the first part of a
494
  /// nested-name-specifier in a member access expression.
495
  ///
496
  /// This specific declaration transformation only applies to the first
497
  /// identifier in a nested-name-specifier of a member access expression, e.g.,
498
  /// the \c T in \c x->T::member
499
  ///
500
  /// By default, invokes TransformDecl() to transform the declaration.
501
  /// Subclasses may override this function to provide alternate behavior.
502
83
  NamedDecl *TransformFirstQualifierInScope(NamedDecl *D, SourceLocation Loc) {
503
83
    return cast_or_null<NamedDecl>(getDerived().TransformDecl(Loc, D));
504
83
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::TransformFirstQualifierInScope(clang::NamedDecl*, clang::SourceLocation)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::TransformFirstQualifierInScope(clang::NamedDecl*, clang::SourceLocation)
SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::TransformFirstQualifierInScope(clang::NamedDecl*, clang::SourceLocation)
Line
Count
Source
502
68
  NamedDecl *TransformFirstQualifierInScope(NamedDecl *D, SourceLocation Loc) {
503
68
    return cast_or_null<NamedDecl>(getDerived().TransformDecl(Loc, D));
504
68
  }
SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::TransformFirstQualifierInScope(clang::NamedDecl*, clang::SourceLocation)
Line
Count
Source
502
15
  NamedDecl *TransformFirstQualifierInScope(NamedDecl *D, SourceLocation Loc) {
503
15
    return cast_or_null<NamedDecl>(getDerived().TransformDecl(Loc, D));
504
15
  }
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::TransformFirstQualifierInScope(clang::NamedDecl*, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::TransformFirstQualifierInScope(clang::NamedDecl*, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::TransformFirstQualifierInScope(clang::NamedDecl*, clang::SourceLocation)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::TransformFirstQualifierInScope(clang::NamedDecl*, clang::SourceLocation)
505
506
  /// Transform the set of declarations in an OverloadExpr.
507
  bool TransformOverloadExprDecls(OverloadExpr *Old, bool RequiresADL,
508
                                  LookupResult &R);
509
510
  /// Transform the given nested-name-specifier with source-location
511
  /// information.
512
  ///
513
  /// By default, transforms all of the types and declarations within the
514
  /// nested-name-specifier. Subclasses may override this function to provide
515
  /// alternate behavior.
516
  NestedNameSpecifierLoc
517
  TransformNestedNameSpecifierLoc(NestedNameSpecifierLoc NNS,
518
                                  QualType ObjectType = QualType(),
519
                                  NamedDecl *FirstQualifierInScope = nullptr);
520
521
  /// Transform the given declaration name.
522
  ///
523
  /// By default, transforms the types of conversion function, constructor,
524
  /// and destructor names and then (if needed) rebuilds the declaration name.
525
  /// Identifiers and selectors are returned unmodified. Sublcasses may
526
  /// override this function to provide alternate behavior.
527
  DeclarationNameInfo
528
  TransformDeclarationNameInfo(const DeclarationNameInfo &NameInfo);
529
530
  bool TransformRequiresExprRequirements(ArrayRef<concepts::Requirement *> Reqs,
531
      llvm::SmallVectorImpl<concepts::Requirement *> &Transformed);
532
  concepts::TypeRequirement *
533
  TransformTypeRequirement(concepts::TypeRequirement *Req);
534
  concepts::ExprRequirement *
535
  TransformExprRequirement(concepts::ExprRequirement *Req);
536
  concepts::NestedRequirement *
537
  TransformNestedRequirement(concepts::NestedRequirement *Req);
538
539
  /// Transform the given template name.
540
  ///
541
  /// \param SS The nested-name-specifier that qualifies the template
542
  /// name. This nested-name-specifier must already have been transformed.
543
  ///
544
  /// \param Name The template name to transform.
545
  ///
546
  /// \param NameLoc The source location of the template name.
547
  ///
548
  /// \param ObjectType If we're translating a template name within a member
549
  /// access expression, this is the type of the object whose member template
550
  /// is being referenced.
551
  ///
552
  /// \param FirstQualifierInScope If the first part of a nested-name-specifier
553
  /// also refers to a name within the current (lexical) scope, this is the
554
  /// declaration it refers to.
555
  ///
556
  /// By default, transforms the template name by transforming the declarations
557
  /// and nested-name-specifiers that occur within the template name.
558
  /// Subclasses may override this function to provide alternate behavior.
559
  TemplateName
560
  TransformTemplateName(CXXScopeSpec &SS, TemplateName Name,
561
                        SourceLocation NameLoc,
562
                        QualType ObjectType = QualType(),
563
                        NamedDecl *FirstQualifierInScope = nullptr,
564
                        bool AllowInjectedClassName = false);
565
566
  /// Transform the given template argument.
567
  ///
568
  /// By default, this operation transforms the type, expression, or
569
  /// declaration stored within the template argument and constructs a
570
  /// new template argument from the transformed result. Subclasses may
571
  /// override this function to provide alternate behavior.
572
  ///
573
  /// Returns true if there was an error.
574
  bool TransformTemplateArgument(const TemplateArgumentLoc &Input,
575
                                 TemplateArgumentLoc &Output,
576
                                 bool Uneval = false);
577
578
  /// Transform the given set of template arguments.
579
  ///
580
  /// By default, this operation transforms all of the template arguments
581
  /// in the input set using \c TransformTemplateArgument(), and appends
582
  /// the transformed arguments to the output list.
583
  ///
584
  /// Note that this overload of \c TransformTemplateArguments() is merely
585
  /// a convenience function. Subclasses that wish to override this behavior
586
  /// should override the iterator-based member template version.
587
  ///
588
  /// \param Inputs The set of template arguments to be transformed.
589
  ///
590
  /// \param NumInputs The number of template arguments in \p Inputs.
591
  ///
592
  /// \param Outputs The set of transformed template arguments output by this
593
  /// routine.
594
  ///
595
  /// Returns true if an error occurred.
596
  bool TransformTemplateArguments(const TemplateArgumentLoc *Inputs,
597
                                  unsigned NumInputs,
598
                                  TemplateArgumentListInfo &Outputs,
599
382k
                                  bool Uneval = false) {
600
382k
    return TransformTemplateArguments(Inputs, Inputs + NumInputs, Outputs,
601
382k
                                      Uneval);
602
382k
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::TransformTemplateArguments(clang::TemplateArgumentLoc const*, unsigned int, clang::TemplateArgumentListInfo&, bool)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::TransformTemplateArguments(clang::TemplateArgumentLoc const*, unsigned int, clang::TemplateArgumentListInfo&, bool)
SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::TransformTemplateArguments(clang::TemplateArgumentLoc const*, unsigned int, clang::TemplateArgumentListInfo&, bool)
Line
Count
Source
599
8
                                  bool Uneval = false) {
600
8
    return TransformTemplateArguments(Inputs, Inputs + NumInputs, Outputs,
601
8
                                      Uneval);
602
8
  }
SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::TransformTemplateArguments(clang::TemplateArgumentLoc const*, unsigned int, clang::TemplateArgumentListInfo&, bool)
Line
Count
Source
599
2
                                  bool Uneval = false) {
600
2
    return TransformTemplateArguments(Inputs, Inputs + NumInputs, Outputs,
601
2
                                      Uneval);
602
2
  }
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::TransformTemplateArguments(clang::TemplateArgumentLoc const*, unsigned int, clang::TemplateArgumentListInfo&, bool)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::TransformTemplateArguments(clang::TemplateArgumentLoc const*, unsigned int, clang::TemplateArgumentListInfo&, bool)
SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::TransformTemplateArguments(clang::TemplateArgumentLoc const*, unsigned int, clang::TemplateArgumentListInfo&, bool)
Line
Count
Source
599
9.12k
                                  bool Uneval = false) {
600
9.12k
    return TransformTemplateArguments(Inputs, Inputs + NumInputs, Outputs,
601
9.12k
                                      Uneval);
602
9.12k
  }
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::TransformTemplateArguments(clang::TemplateArgumentLoc const*, unsigned int, clang::TemplateArgumentListInfo&, bool)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::TransformTemplateArguments(clang::TemplateArgumentLoc const*, unsigned int, clang::TemplateArgumentListInfo&, bool)
Line
Count
Source
599
373k
                                  bool Uneval = false) {
600
373k
    return TransformTemplateArguments(Inputs, Inputs + NumInputs, Outputs,
601
373k
                                      Uneval);
602
373k
  }
603
604
  /// Transform the given set of template arguments.
605
  ///
606
  /// By default, this operation transforms all of the template arguments
607
  /// in the input set using \c TransformTemplateArgument(), and appends
608
  /// the transformed arguments to the output list.
609
  ///
610
  /// \param First An iterator to the first template argument.
611
  ///
612
  /// \param Last An iterator one step past the last template argument.
613
  ///
614
  /// \param Outputs The set of transformed template arguments output by this
615
  /// routine.
616
  ///
617
  /// Returns true if an error occurred.
618
  template<typename InputIterator>
619
  bool TransformTemplateArguments(InputIterator First,
620
                                  InputIterator Last,
621
                                  TemplateArgumentListInfo &Outputs,
622
                                  bool Uneval = false);
623
624
  /// Fakes up a TemplateArgumentLoc for a given TemplateArgument.
625
  void InventTemplateArgumentLoc(const TemplateArgument &Arg,
626
                                 TemplateArgumentLoc &ArgLoc);
627
628
  /// Fakes up a TypeSourceInfo for a type.
629
0
  TypeSourceInfo *InventTypeSourceInfo(QualType T) {
630
0
    return SemaRef.Context.getTrivialTypeSourceInfo(T,
631
0
                       getDerived().getBaseLocation());
632
0
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::InventTypeSourceInfo(clang::QualType)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::InventTypeSourceInfo(clang::QualType)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::InventTypeSourceInfo(clang::QualType)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::InventTypeSourceInfo(clang::QualType)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::InventTypeSourceInfo(clang::QualType)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::InventTypeSourceInfo(clang::QualType)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::InventTypeSourceInfo(clang::QualType)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::InventTypeSourceInfo(clang::QualType)
Unexecuted instantiation: SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::InventTypeSourceInfo(clang::QualType)
633
634
#define ABSTRACT_TYPELOC(CLASS, PARENT)
635
#define TYPELOC(CLASS, PARENT)                                   \
636
  QualType Transform##CLASS##Type(TypeLocBuilder &TLB, CLASS##TypeLoc T);
637
#include "clang/AST/TypeLocNodes.def"
638
639
  template<typename Fn>
640
  QualType TransformFunctionProtoType(TypeLocBuilder &TLB,
641
                                      FunctionProtoTypeLoc TL,
642
                                      CXXRecordDecl *ThisContext,
643
                                      Qualifiers ThisTypeQuals,
644
                                      Fn TransformExceptionSpec);
645
646
  bool TransformExceptionSpec(SourceLocation Loc,
647
                              FunctionProtoType::ExceptionSpecInfo &ESI,
648
                              SmallVectorImpl<QualType> &Exceptions,
649
                              bool &Changed);
650
651
  StmtResult TransformSEHHandler(Stmt *Handler);
652
653
  QualType
654
  TransformTemplateSpecializationType(TypeLocBuilder &TLB,
655
                                      TemplateSpecializationTypeLoc TL,
656
                                      TemplateName Template);
657
658
  QualType
659
  TransformDependentTemplateSpecializationType(TypeLocBuilder &TLB,
660
                                      DependentTemplateSpecializationTypeLoc TL,
661
                                               TemplateName Template,
662
                                               CXXScopeSpec &SS);
663
664
  QualType TransformDependentTemplateSpecializationType(
665
      TypeLocBuilder &TLB, DependentTemplateSpecializationTypeLoc TL,
666
      NestedNameSpecifierLoc QualifierLoc);
667
668
  /// Transforms the parameters of a function type into the
669
  /// given vectors.
670
  ///
671
  /// The result vectors should be kept in sync; null entries in the
672
  /// variables vector are acceptable.
673
  ///
674
  /// Return true on error.
675
  bool TransformFunctionTypeParams(
676
      SourceLocation Loc, ArrayRef<ParmVarDecl *> Params,
677
      const QualType *ParamTypes,
678
      const FunctionProtoType::ExtParameterInfo *ParamInfos,
679
      SmallVectorImpl<QualType> &PTypes, SmallVectorImpl<ParmVarDecl *> *PVars,
680
      Sema::ExtParameterInfoBuilder &PInfos);
681
682
  /// Transforms a single function-type parameter.  Return null
683
  /// on error.
684
  ///
685
  /// \param indexAdjustment - A number to add to the parameter's
686
  ///   scope index;  can be negative
687
  ParmVarDecl *TransformFunctionTypeParam(ParmVarDecl *OldParm,
688
                                          int indexAdjustment,
689
                                          Optional<unsigned> NumExpansions,
690
                                          bool ExpectParameterPack);
691
692
  /// Transform the body of a lambda-expression.
693
  StmtResult TransformLambdaBody(LambdaExpr *E, Stmt *Body);
694
  /// Alternative implementation of TransformLambdaBody that skips transforming
695
  /// the body.
696
  StmtResult SkipLambdaBody(LambdaExpr *E, Stmt *Body);
697
698
  QualType TransformReferenceType(TypeLocBuilder &TLB, ReferenceTypeLoc TL);
699
700
  StmtResult TransformCompoundStmt(CompoundStmt *S, bool IsStmtExpr);
701
  ExprResult TransformCXXNamedCastExpr(CXXNamedCastExpr *E);
702
703
  TemplateParameterList *TransformTemplateParameterList(
704
7
        TemplateParameterList *TPL) {
705
7
    return TPL;
706
7
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::TransformTemplateParameterList(clang::TemplateParameterList*)
SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::TransformTemplateParameterList(clang::TemplateParameterList*)
Line
Count
Source
704
7
        TemplateParameterList *TPL) {
705
7
    return TPL;
706
7
  }
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::TransformTemplateParameterList(clang::TemplateParameterList*)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::TransformTemplateParameterList(clang::TemplateParameterList*)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::TransformTemplateParameterList(clang::TemplateParameterList*)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::TransformTemplateParameterList(clang::TemplateParameterList*)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::TransformTemplateParameterList(clang::TemplateParameterList*)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::TransformTemplateParameterList(clang::TemplateParameterList*)
707
708
  ExprResult TransformAddressOfOperand(Expr *E);
709
710
  ExprResult TransformDependentScopeDeclRefExpr(DependentScopeDeclRefExpr *E,
711
                                                bool IsAddressOfOperand,
712
                                                TypeSourceInfo **RecoveryTSI);
713
714
  ExprResult TransformParenDependentScopeDeclRefExpr(
715
      ParenExpr *PE, DependentScopeDeclRefExpr *DRE, bool IsAddressOfOperand,
716
      TypeSourceInfo **RecoveryTSI);
717
718
  StmtResult TransformOMPExecutableDirective(OMPExecutableDirective *S);
719
720
// FIXME: We use LLVM_ATTRIBUTE_NOINLINE because inlining causes a ridiculous
721
// amount of stack usage with clang.
722
#define STMT(Node, Parent)                        \
723
  LLVM_ATTRIBUTE_NOINLINE \
724
  StmtResult Transform##Node(Node *S);
725
#define VALUESTMT(Node, Parent)                   \
726
  LLVM_ATTRIBUTE_NOINLINE \
727
  StmtResult Transform##Node(Node *S, StmtDiscardKind SDK);
728
#define EXPR(Node, Parent)                        \
729
  LLVM_ATTRIBUTE_NOINLINE \
730
  ExprResult Transform##Node(Node *E);
731
#define ABSTRACT_STMT(Stmt)
732
#include "clang/AST/StmtNodes.inc"
733
734
#define OMP_CLAUSE_CLASS(Enum, Str, Class)                                           \
735
  LLVM_ATTRIBUTE_NOINLINE \
736
  OMPClause *Transform ## Class(Class *S);
737
#include "llvm/Frontend/OpenMP/OMPKinds.def"
738
739
  /// Build a new qualified type given its unqualified type and type location.
740
  ///
741
  /// By default, this routine adds type qualifiers only to types that can
742
  /// have qualifiers, and silently suppresses those qualifiers that are not
743
  /// permitted. Subclasses may override this routine to provide different
744
  /// behavior.
745
  QualType RebuildQualifiedType(QualType T, QualifiedTypeLoc TL);
746
747
  /// Build a new pointer type given its pointee type.
748
  ///
749
  /// By default, performs semantic analysis when building the pointer type.
750
  /// Subclasses may override this routine to provide different behavior.
751
  QualType RebuildPointerType(QualType PointeeType, SourceLocation Sigil);
752
753
  /// Build a new block pointer type given its pointee type.
754
  ///
755
  /// By default, performs semantic analysis when building the block pointer
756
  /// type. Subclasses may override this routine to provide different behavior.
757
  QualType RebuildBlockPointerType(QualType PointeeType, SourceLocation Sigil);
758
759
  /// Build a new reference type given the type it references.
760
  ///
761
  /// By default, performs semantic analysis when building the
762
  /// reference type. Subclasses may override this routine to provide
763
  /// different behavior.
764
  ///
765
  /// \param LValue whether the type was written with an lvalue sigil
766
  /// or an rvalue sigil.
767
  QualType RebuildReferenceType(QualType ReferentType,
768
                                bool LValue,
769
                                SourceLocation Sigil);
770
771
  /// Build a new member pointer type given the pointee type and the
772
  /// class type it refers into.
773
  ///
774
  /// By default, performs semantic analysis when building the member pointer
775
  /// type. Subclasses may override this routine to provide different behavior.
776
  QualType RebuildMemberPointerType(QualType PointeeType, QualType ClassType,
777
                                    SourceLocation Sigil);
778
779
  QualType RebuildObjCTypeParamType(const ObjCTypeParamDecl *Decl,
780
                                    SourceLocation ProtocolLAngleLoc,
781
                                    ArrayRef<ObjCProtocolDecl *> Protocols,
782
                                    ArrayRef<SourceLocation> ProtocolLocs,
783
                                    SourceLocation ProtocolRAngleLoc);
784
785
  /// Build an Objective-C object type.
786
  ///
787
  /// By default, performs semantic analysis when building the object type.
788
  /// Subclasses may override this routine to provide different behavior.
789
  QualType RebuildObjCObjectType(QualType BaseType,
790
                                 SourceLocation Loc,
791
                                 SourceLocation TypeArgsLAngleLoc,
792
                                 ArrayRef<TypeSourceInfo *> TypeArgs,
793
                                 SourceLocation TypeArgsRAngleLoc,
794
                                 SourceLocation ProtocolLAngleLoc,
795
                                 ArrayRef<ObjCProtocolDecl *> Protocols,
796
                                 ArrayRef<SourceLocation> ProtocolLocs,
797
                                 SourceLocation ProtocolRAngleLoc);
798
799
  /// Build a new Objective-C object pointer type given the pointee type.
800
  ///
801
  /// By default, directly builds the pointer type, with no additional semantic
802
  /// analysis.
803
  QualType RebuildObjCObjectPointerType(QualType PointeeType,
804
                                        SourceLocation Star);
805
806
  /// Build a new array type given the element type, size
807
  /// modifier, size of the array (if known), size expression, and index type
808
  /// qualifiers.
809
  ///
810
  /// By default, performs semantic analysis when building the array type.
811
  /// Subclasses may override this routine to provide different behavior.
812
  /// Also by default, all of the other Rebuild*Array
813
  QualType RebuildArrayType(QualType ElementType,
814
                            ArrayType::ArraySizeModifier SizeMod,
815
                            const llvm::APInt *Size,
816
                            Expr *SizeExpr,
817
                            unsigned IndexTypeQuals,
818
                            SourceRange BracketsRange);
819
820
  /// Build a new constant array type given the element type, size
821
  /// modifier, (known) size of the array, and index type qualifiers.
822
  ///
823
  /// By default, performs semantic analysis when building the array type.
824
  /// Subclasses may override this routine to provide different behavior.
825
  QualType RebuildConstantArrayType(QualType ElementType,
826
                                    ArrayType::ArraySizeModifier SizeMod,
827
                                    const llvm::APInt &Size,
828
                                    Expr *SizeExpr,
829
                                    unsigned IndexTypeQuals,
830
                                    SourceRange BracketsRange);
831
832
  /// Build a new incomplete array type given the element type, size
833
  /// modifier, and index type qualifiers.
834
  ///
835
  /// By default, performs semantic analysis when building the array type.
836
  /// Subclasses may override this routine to provide different behavior.
837
  QualType RebuildIncompleteArrayType(QualType ElementType,
838
                                      ArrayType::ArraySizeModifier SizeMod,
839
                                      unsigned IndexTypeQuals,
840
                                      SourceRange BracketsRange);
841
842
  /// Build a new variable-length array type given the element type,
843
  /// size modifier, size expression, and index type qualifiers.
844
  ///
845
  /// By default, performs semantic analysis when building the array type.
846
  /// Subclasses may override this routine to provide different behavior.
847
  QualType RebuildVariableArrayType(QualType ElementType,
848
                                    ArrayType::ArraySizeModifier SizeMod,
849
                                    Expr *SizeExpr,
850
                                    unsigned IndexTypeQuals,
851
                                    SourceRange BracketsRange);
852
853
  /// Build a new dependent-sized array type given the element type,
854
  /// size modifier, size expression, and index type qualifiers.
855
  ///
856
  /// By default, performs semantic analysis when building the array type.
857
  /// Subclasses may override this routine to provide different behavior.
858
  QualType RebuildDependentSizedArrayType(QualType ElementType,
859
                                          ArrayType::ArraySizeModifier SizeMod,
860
                                          Expr *SizeExpr,
861
                                          unsigned IndexTypeQuals,
862
                                          SourceRange BracketsRange);
863
864
  /// Build a new vector type given the element type and
865
  /// number of elements.
866
  ///
867
  /// By default, performs semantic analysis when building the vector type.
868
  /// Subclasses may override this routine to provide different behavior.
869
  QualType RebuildVectorType(QualType ElementType, unsigned NumElements,
870
                             VectorType::VectorKind VecKind);
871
872
  /// Build a new potentially dependently-sized extended vector type
873
  /// given the element type and number of elements.
874
  ///
875
  /// By default, performs semantic analysis when building the vector type.
876
  /// Subclasses may override this routine to provide different behavior.
877
  QualType RebuildDependentVectorType(QualType ElementType, Expr *SizeExpr,
878
                                           SourceLocation AttributeLoc,
879
                                           VectorType::VectorKind);
880
881
  /// Build a new extended vector type given the element type and
882
  /// number of elements.
883
  ///
884
  /// By default, performs semantic analysis when building the vector type.
885
  /// Subclasses may override this routine to provide different behavior.
886
  QualType RebuildExtVectorType(QualType ElementType, unsigned NumElements,
887
                                SourceLocation AttributeLoc);
888
889
  /// Build a new potentially dependently-sized extended vector type
890
  /// given the element type and number of elements.
891
  ///
892
  /// By default, performs semantic analysis when building the vector type.
893
  /// Subclasses may override this routine to provide different behavior.
894
  QualType RebuildDependentSizedExtVectorType(QualType ElementType,
895
                                              Expr *SizeExpr,
896
                                              SourceLocation AttributeLoc);
897
898
  /// Build a new matrix type given the element type and dimensions.
899
  QualType RebuildConstantMatrixType(QualType ElementType, unsigned NumRows,
900
                                     unsigned NumColumns);
901
902
  /// Build a new matrix type given the type and dependently-defined
903
  /// dimensions.
904
  QualType RebuildDependentSizedMatrixType(QualType ElementType, Expr *RowExpr,
905
                                           Expr *ColumnExpr,
906
                                           SourceLocation AttributeLoc);
907
908
  /// Build a new DependentAddressSpaceType or return the pointee
909
  /// type variable with the correct address space (retrieved from
910
  /// AddrSpaceExpr) applied to it. The former will be returned in cases
911
  /// where the address space remains dependent.
912
  ///
913
  /// By default, performs semantic analysis when building the type with address
914
  /// space applied. Subclasses may override this routine to provide different
915
  /// behavior.
916
  QualType RebuildDependentAddressSpaceType(QualType PointeeType,
917
                                            Expr *AddrSpaceExpr,
918
                                            SourceLocation AttributeLoc);
919
920
  /// Build a new function type.
921
  ///
922
  /// By default, performs semantic analysis when building the function type.
923
  /// Subclasses may override this routine to provide different behavior.
924
  QualType RebuildFunctionProtoType(QualType T,
925
                                    MutableArrayRef<QualType> ParamTypes,
926
                                    const FunctionProtoType::ExtProtoInfo &EPI);
927
928
  /// Build a new unprototyped function type.
929
  QualType RebuildFunctionNoProtoType(QualType ResultType);
930
931
  /// Rebuild an unresolved typename type, given the decl that
932
  /// the UnresolvedUsingTypenameDecl was transformed to.
933
  QualType RebuildUnresolvedUsingType(SourceLocation NameLoc, Decl *D);
934
935
  /// Build a new typedef type.
936
1.04M
  QualType RebuildTypedefType(TypedefNameDecl *Typedef) {
937
1.04M
    return SemaRef.Context.getTypeDeclType(Typedef);
938
1.04M
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildTypedefType(clang::TypedefNameDecl*)
SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildTypedefType(clang::TypedefNameDecl*)
Line
Count
Source
936
1
  QualType RebuildTypedefType(TypedefNameDecl *Typedef) {
937
1
    return SemaRef.Context.getTypeDeclType(Typedef);
938
1
  }
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildTypedefType(clang::TypedefNameDecl*)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildTypedefType(clang::TypedefNameDecl*)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildTypedefType(clang::TypedefNameDecl*)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildTypedefType(clang::TypedefNameDecl*)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildTypedefType(clang::TypedefNameDecl*)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildTypedefType(clang::TypedefNameDecl*)
Line
Count
Source
936
1.04M
  QualType RebuildTypedefType(TypedefNameDecl *Typedef) {
937
1.04M
    return SemaRef.Context.getTypeDeclType(Typedef);
938
1.04M
  }
939
940
  /// Build a new MacroDefined type.
941
  QualType RebuildMacroQualifiedType(QualType T,
942
23
                                     const IdentifierInfo *MacroII) {
943
23
    return SemaRef.Context.getMacroQualifiedType(T, MacroII);
944
23
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildMacroQualifiedType(clang::QualType, clang::IdentifierInfo const*)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildMacroQualifiedType(clang::QualType, clang::IdentifierInfo const*)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildMacroQualifiedType(clang::QualType, clang::IdentifierInfo const*)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildMacroQualifiedType(clang::QualType, clang::IdentifierInfo const*)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildMacroQualifiedType(clang::QualType, clang::IdentifierInfo const*)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildMacroQualifiedType(clang::QualType, clang::IdentifierInfo const*)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildMacroQualifiedType(clang::QualType, clang::IdentifierInfo const*)
SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildMacroQualifiedType(clang::QualType, clang::IdentifierInfo const*)
Line
Count
Source
942
8
                                     const IdentifierInfo *MacroII) {
943
8
    return SemaRef.Context.getMacroQualifiedType(T, MacroII);
944
8
  }
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildMacroQualifiedType(clang::QualType, clang::IdentifierInfo const*)
Line
Count
Source
942
15
                                     const IdentifierInfo *MacroII) {
943
15
    return SemaRef.Context.getMacroQualifiedType(T, MacroII);
944
15
  }
945
946
  /// Build a new class/struct/union type.
947
36.3k
  QualType RebuildRecordType(RecordDecl *Record) {
948
36.3k
    return SemaRef.Context.getTypeDeclType(Record);
949
36.3k
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildRecordType(clang::RecordDecl*)
SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildRecordType(clang::RecordDecl*)
Line
Count
Source
947
32
  QualType RebuildRecordType(RecordDecl *Record) {
948
32
    return SemaRef.Context.getTypeDeclType(Record);
949
32
  }
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildRecordType(clang::RecordDecl*)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildRecordType(clang::RecordDecl*)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildRecordType(clang::RecordDecl*)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildRecordType(clang::RecordDecl*)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildRecordType(clang::RecordDecl*)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildRecordType(clang::RecordDecl*)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildRecordType(clang::RecordDecl*)
Line
Count
Source
947
36.3k
  QualType RebuildRecordType(RecordDecl *Record) {
948
36.3k
    return SemaRef.Context.getTypeDeclType(Record);
949
36.3k
  }
950
951
  /// Build a new Enum type.
952
102
  QualType RebuildEnumType(EnumDecl *Enum) {
953
102
    return SemaRef.Context.getTypeDeclType(Enum);
954
102
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildEnumType(clang::EnumDecl*)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildEnumType(clang::EnumDecl*)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildEnumType(clang::EnumDecl*)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildEnumType(clang::EnumDecl*)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildEnumType(clang::EnumDecl*)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildEnumType(clang::EnumDecl*)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildEnumType(clang::EnumDecl*)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildEnumType(clang::EnumDecl*)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildEnumType(clang::EnumDecl*)
Line
Count
Source
952
102
  QualType RebuildEnumType(EnumDecl *Enum) {
953
102
    return SemaRef.Context.getTypeDeclType(Enum);
954
102
  }
955
956
  /// Build a new typeof(expr) type.
957
  ///
958
  /// By default, performs semantic analysis when building the typeof type.
959
  /// Subclasses may override this routine to provide different behavior.
960
  QualType RebuildTypeOfExprType(Expr *Underlying, SourceLocation Loc);
961
962
  /// Build a new typeof(type) type.
963
  ///
964
  /// By default, builds a new TypeOfType with the given underlying type.
965
  QualType RebuildTypeOfType(QualType Underlying);
966
967
  /// Build a new unary transform type.
968
  QualType RebuildUnaryTransformType(QualType BaseType,
969
                                     UnaryTransformType::UTTKind UKind,
970
                                     SourceLocation Loc);
971
972
  /// Build a new C++11 decltype type.
973
  ///
974
  /// By default, performs semantic analysis when building the decltype type.
975
  /// Subclasses may override this routine to provide different behavior.
976
  QualType RebuildDecltypeType(Expr *Underlying, SourceLocation Loc);
977
978
  /// Build a new C++11 auto type.
979
  ///
980
  /// By default, builds a new AutoType with the given deduced type.
981
  QualType RebuildAutoType(QualType Deduced, AutoTypeKeyword Keyword,
982
                           ConceptDecl *TypeConstraintConcept,
983
1.72k
                           ArrayRef<TemplateArgument> TypeConstraintArgs) {
984
    // Note, IsDependent is always false here: we implicitly convert an 'auto'
985
    // which has been deduced to a dependent type into an undeduced 'auto', so
986
    // that we'll retry deduction after the transformation.
987
1.72k
    return SemaRef.Context.getAutoType(Deduced, Keyword,
988
1.72k
                                       /*IsDependent*/ false, /*IsPack=*/false,
989
1.72k
                                       TypeConstraintConcept,
990
1.72k
                                       TypeConstraintArgs);
991
1.72k
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildAutoType(clang::QualType, clang::AutoTypeKeyword, clang::ConceptDecl*, llvm::ArrayRef<clang::TemplateArgument>)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildAutoType(clang::QualType, clang::AutoTypeKeyword, clang::ConceptDecl*, llvm::ArrayRef<clang::TemplateArgument>)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildAutoType(clang::QualType, clang::AutoTypeKeyword, clang::ConceptDecl*, llvm::ArrayRef<clang::TemplateArgument>)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildAutoType(clang::QualType, clang::AutoTypeKeyword, clang::ConceptDecl*, llvm::ArrayRef<clang::TemplateArgument>)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildAutoType(clang::QualType, clang::AutoTypeKeyword, clang::ConceptDecl*, llvm::ArrayRef<clang::TemplateArgument>)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildAutoType(clang::QualType, clang::AutoTypeKeyword, clang::ConceptDecl*, llvm::ArrayRef<clang::TemplateArgument>)
SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildAutoType(clang::QualType, clang::AutoTypeKeyword, clang::ConceptDecl*, llvm::ArrayRef<clang::TemplateArgument>)
Line
Count
Source
983
9
                           ArrayRef<TemplateArgument> TypeConstraintArgs) {
984
    // Note, IsDependent is always false here: we implicitly convert an 'auto'
985
    // which has been deduced to a dependent type into an undeduced 'auto', so
986
    // that we'll retry deduction after the transformation.
987
9
    return SemaRef.Context.getAutoType(Deduced, Keyword,
988
9
                                       /*IsDependent*/ false, /*IsPack=*/false,
989
9
                                       TypeConstraintConcept,
990
9
                                       TypeConstraintArgs);
991
9
  }
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildAutoType(clang::QualType, clang::AutoTypeKeyword, clang::ConceptDecl*, llvm::ArrayRef<clang::TemplateArgument>)
Line
Count
Source
983
1.71k
                           ArrayRef<TemplateArgument> TypeConstraintArgs) {
984
    // Note, IsDependent is always false here: we implicitly convert an 'auto'
985
    // which has been deduced to a dependent type into an undeduced 'auto', so
986
    // that we'll retry deduction after the transformation.
987
1.71k
    return SemaRef.Context.getAutoType(Deduced, Keyword,
988
1.71k
                                       /*IsDependent*/ false, /*IsPack=*/false,
989
1.71k
                                       TypeConstraintConcept,
990
1.71k
                                       TypeConstraintArgs);
991
1.71k
  }
992
993
  /// By default, builds a new DeducedTemplateSpecializationType with the given
994
  /// deduced type.
995
  QualType RebuildDeducedTemplateSpecializationType(TemplateName Template,
996
5
      QualType Deduced) {
997
5
    return SemaRef.Context.getDeducedTemplateSpecializationType(
998
5
        Template, Deduced, /*IsDependent*/ false);
999
5
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildDeducedTemplateSpecializationType(clang::TemplateName, clang::QualType)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildDeducedTemplateSpecializationType(clang::TemplateName, clang::QualType)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildDeducedTemplateSpecializationType(clang::TemplateName, clang::QualType)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildDeducedTemplateSpecializationType(clang::TemplateName, clang::QualType)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildDeducedTemplateSpecializationType(clang::TemplateName, clang::QualType)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildDeducedTemplateSpecializationType(clang::TemplateName, clang::QualType)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildDeducedTemplateSpecializationType(clang::TemplateName, clang::QualType)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildDeducedTemplateSpecializationType(clang::TemplateName, clang::QualType)
Line
Count
Source
996
5
      QualType Deduced) {
997
5
    return SemaRef.Context.getDeducedTemplateSpecializationType(
998
5
        Template, Deduced, /*IsDependent*/ false);
999
5
  }
1000
1001
  /// Build a new template specialization type.
1002
  ///
1003
  /// By default, performs semantic analysis when building the template
1004
  /// specialization type. Subclasses may override this routine to provide
1005
  /// different behavior.
1006
  QualType RebuildTemplateSpecializationType(TemplateName Template,
1007
                                             SourceLocation TemplateLoc,
1008
                                             TemplateArgumentListInfo &Args);
1009
1010
  /// Build a new parenthesized type.
1011
  ///
1012
  /// By default, builds a new ParenType type from the inner type.
1013
  /// Subclasses may override this routine to provide different behavior.
1014
3.85k
  QualType RebuildParenType(QualType InnerType) {
1015
3.85k
    return SemaRef.BuildParenType(InnerType);
1016
3.85k
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildParenType(clang::QualType)
SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildParenType(clang::QualType)
Line
Count
Source
1014
14
  QualType RebuildParenType(QualType InnerType) {
1015
14
    return SemaRef.BuildParenType(InnerType);
1016
14
  }
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildParenType(clang::QualType)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildParenType(clang::QualType)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildParenType(clang::QualType)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildParenType(clang::QualType)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildParenType(clang::QualType)
SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildParenType(clang::QualType)
Line
Count
Source
1014
120
  QualType RebuildParenType(QualType InnerType) {
1015
120
    return SemaRef.BuildParenType(InnerType);
1016
120
  }
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildParenType(clang::QualType)
Line
Count
Source
1014
3.71k
  QualType RebuildParenType(QualType InnerType) {
1015
3.71k
    return SemaRef.BuildParenType(InnerType);
1016
3.71k
  }
1017
1018
  /// Build a new qualified name type.
1019
  ///
1020
  /// By default, builds a new ElaboratedType type from the keyword,
1021
  /// the nested-name-specifier and the named type.
1022
  /// Subclasses may override this routine to provide different behavior.
1023
  QualType RebuildElaboratedType(SourceLocation KeywordLoc,
1024
                                 ElaboratedTypeKeyword Keyword,
1025
                                 NestedNameSpecifierLoc QualifierLoc,
1026
27.0k
                                 QualType Named) {
1027
27.0k
    return SemaRef.Context.getElaboratedType(Keyword,
1028
27.0k
                                         QualifierLoc.getNestedNameSpecifier(),
1029
27.0k
                                             Named);
1030
27.0k
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildElaboratedType(clang::SourceLocation, clang::ElaboratedTypeKeyword, clang::NestedNameSpecifierLoc, clang::QualType)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildElaboratedType(clang::SourceLocation, clang::ElaboratedTypeKeyword, clang::NestedNameSpecifierLoc, clang::QualType)
SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildElaboratedType(clang::SourceLocation, clang::ElaboratedTypeKeyword, clang::NestedNameSpecifierLoc, clang::QualType)
Line
Count
Source
1026
2
                                 QualType Named) {
1027
2
    return SemaRef.Context.getElaboratedType(Keyword,
1028
2
                                         QualifierLoc.getNestedNameSpecifier(),
1029
2
                                             Named);
1030
2
  }
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildElaboratedType(clang::SourceLocation, clang::ElaboratedTypeKeyword, clang::NestedNameSpecifierLoc, clang::QualType)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildElaboratedType(clang::SourceLocation, clang::ElaboratedTypeKeyword, clang::NestedNameSpecifierLoc, clang::QualType)
SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildElaboratedType(clang::SourceLocation, clang::ElaboratedTypeKeyword, clang::NestedNameSpecifierLoc, clang::QualType)
Line
Count
Source
1026
11
                                 QualType Named) {
1027
11
    return SemaRef.Context.getElaboratedType(Keyword,
1028
11
                                         QualifierLoc.getNestedNameSpecifier(),
1029
11
                                             Named);
1030
11
  }
SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildElaboratedType(clang::SourceLocation, clang::ElaboratedTypeKeyword, clang::NestedNameSpecifierLoc, clang::QualType)
Line
Count
Source
1026
6
                                 QualType Named) {
1027
6
    return SemaRef.Context.getElaboratedType(Keyword,
1028
6
                                         QualifierLoc.getNestedNameSpecifier(),
1029
6
                                             Named);
1030
6
  }
SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildElaboratedType(clang::SourceLocation, clang::ElaboratedTypeKeyword, clang::NestedNameSpecifierLoc, clang::QualType)
Line
Count
Source
1026
31
                                 QualType Named) {
1027
31
    return SemaRef.Context.getElaboratedType(Keyword,
1028
31
                                         QualifierLoc.getNestedNameSpecifier(),
1029
31
                                             Named);
1030
31
  }
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildElaboratedType(clang::SourceLocation, clang::ElaboratedTypeKeyword, clang::NestedNameSpecifierLoc, clang::QualType)
Line
Count
Source
1026
27.0k
                                 QualType Named) {
1027
27.0k
    return SemaRef.Context.getElaboratedType(Keyword,
1028
27.0k
                                         QualifierLoc.getNestedNameSpecifier(),
1029
27.0k
                                             Named);
1030
27.0k
  }
1031
1032
  /// Build a new typename type that refers to a template-id.
1033
  ///
1034
  /// By default, builds a new DependentNameType type from the
1035
  /// nested-name-specifier and the given type. Subclasses may override
1036
  /// this routine to provide different behavior.
1037
  QualType RebuildDependentTemplateSpecializationType(
1038
                                          ElaboratedTypeKeyword Keyword,
1039
                                          NestedNameSpecifierLoc QualifierLoc,
1040
                                          SourceLocation TemplateKWLoc,
1041
                                          const IdentifierInfo *Name,
1042
                                          SourceLocation NameLoc,
1043
                                          TemplateArgumentListInfo &Args,
1044
110k
                                          bool AllowInjectedClassName) {
1045
    // Rebuild the template name.
1046
    // TODO: avoid TemplateName abstraction
1047
110k
    CXXScopeSpec SS;
1048
110k
    SS.Adopt(QualifierLoc);
1049
110k
    TemplateName InstName = getDerived().RebuildTemplateName(
1050
110k
        SS, TemplateKWLoc, *Name, NameLoc, QualType(), nullptr,
1051
110k
        AllowInjectedClassName);
1052
110k
1053
110k
    if (InstName.isNull())
1054
13.3k
      return QualType();
1055
96.8k
1056
    // If it's still dependent, make a dependent specialization.
1057
96.8k
    if (InstName.getAsDependentTemplateName())
1058
69.6k
      return SemaRef.Context.getDependentTemplateSpecializationType(Keyword,
1059
69.6k
                                          QualifierLoc.getNestedNameSpecifier(),
1060
69.6k
                                                                    Name,
1061
69.6k
                                                                    Args);
1062
27.1k
1063
    // Otherwise, make an elaborated type wrapping a non-dependent
1064
    // specialization.
1065
27.1k
    QualType T =
1066
27.1k
    getDerived().RebuildTemplateSpecializationType(InstName, NameLoc, Args);
1067
27.1k
    if (T.isNull()) 
return QualType()13
;
1068
27.1k
1069
27.1k
    if (Keyword == ETK_None && 
QualifierLoc.getNestedNameSpecifier() == nullptr10
)
1070
0
      return T;
1071
27.1k
1072
27.1k
    return SemaRef.Context.getElaboratedType(Keyword,
1073
27.1k
                                       QualifierLoc.getNestedNameSpecifier(),
1074
27.1k
                                             T);
1075
27.1k
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildDependentTemplateSpecializationType(clang::ElaboratedTypeKeyword, clang::NestedNameSpecifierLoc, clang::SourceLocation, clang::IdentifierInfo const*, clang::SourceLocation, clang::TemplateArgumentListInfo&, bool)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildDependentTemplateSpecializationType(clang::ElaboratedTypeKeyword, clang::NestedNameSpecifierLoc, clang::SourceLocation, clang::IdentifierInfo const*, clang::SourceLocation, clang::TemplateArgumentListInfo&, bool)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildDependentTemplateSpecializationType(clang::ElaboratedTypeKeyword, clang::NestedNameSpecifierLoc, clang::SourceLocation, clang::IdentifierInfo const*, clang::SourceLocation, clang::TemplateArgumentListInfo&, bool)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildDependentTemplateSpecializationType(clang::ElaboratedTypeKeyword, clang::NestedNameSpecifierLoc, clang::SourceLocation, clang::IdentifierInfo const*, clang::SourceLocation, clang::TemplateArgumentListInfo&, bool)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildDependentTemplateSpecializationType(clang::ElaboratedTypeKeyword, clang::NestedNameSpecifierLoc, clang::SourceLocation, clang::IdentifierInfo const*, clang::SourceLocation, clang::TemplateArgumentListInfo&, bool)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildDependentTemplateSpecializationType(clang::ElaboratedTypeKeyword, clang::NestedNameSpecifierLoc, clang::SourceLocation, clang::IdentifierInfo const*, clang::SourceLocation, clang::TemplateArgumentListInfo&, bool)
SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildDependentTemplateSpecializationType(clang::ElaboratedTypeKeyword, clang::NestedNameSpecifierLoc, clang::SourceLocation, clang::IdentifierInfo const*, clang::SourceLocation, clang::TemplateArgumentListInfo&, bool)
Line
Count
Source
1044
12
                                          bool AllowInjectedClassName) {
1045
    // Rebuild the template name.
1046
    // TODO: avoid TemplateName abstraction
1047
12
    CXXScopeSpec SS;
1048
12
    SS.Adopt(QualifierLoc);
1049
12
    TemplateName InstName = getDerived().RebuildTemplateName(
1050
12
        SS, TemplateKWLoc, *Name, NameLoc, QualType(), nullptr,
1051
12
        AllowInjectedClassName);
1052
12
1053
12
    if (InstName.isNull())
1054
0
      return QualType();
1055
12
1056
    // If it's still dependent, make a dependent specialization.
1057
12
    if (InstName.getAsDependentTemplateName())
1058
4
      return SemaRef.Context.getDependentTemplateSpecializationType(Keyword,
1059
4
                                          QualifierLoc.getNestedNameSpecifier(),
1060
4
                                                                    Name,
1061
4
                                                                    Args);
1062
8
1063
    // Otherwise, make an elaborated type wrapping a non-dependent
1064
    // specialization.
1065
8
    QualType T =
1066
8
    getDerived().RebuildTemplateSpecializationType(InstName, NameLoc, Args);
1067
8
    if (T.isNull()) 
return QualType()0
;
1068
8
1069
8
    if (Keyword == ETK_None && 
QualifierLoc.getNestedNameSpecifier() == nullptr0
)
1070
0
      return T;
1071
8
1072
8
    return SemaRef.Context.getElaboratedType(Keyword,
1073
8
                                       QualifierLoc.getNestedNameSpecifier(),
1074
8
                                             T);
1075
8
  }
SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildDependentTemplateSpecializationType(clang::ElaboratedTypeKeyword, clang::NestedNameSpecifierLoc, clang::SourceLocation, clang::IdentifierInfo const*, clang::SourceLocation, clang::TemplateArgumentListInfo&, bool)
Line
Count
Source
1044
1
                                          bool AllowInjectedClassName) {
1045
    // Rebuild the template name.
1046
    // TODO: avoid TemplateName abstraction
1047
1
    CXXScopeSpec SS;
1048
1
    SS.Adopt(QualifierLoc);
1049
1
    TemplateName InstName = getDerived().RebuildTemplateName(
1050
1
        SS, TemplateKWLoc, *Name, NameLoc, QualType(), nullptr,
1051
1
        AllowInjectedClassName);
1052
1
1053
1
    if (InstName.isNull())
1054
0
      return QualType();
1055
1
1056
    // If it's still dependent, make a dependent specialization.
1057
1
    if (InstName.getAsDependentTemplateName())
1058
1
      return SemaRef.Context.getDependentTemplateSpecializationType(Keyword,
1059
1
                                          QualifierLoc.getNestedNameSpecifier(),
1060
1
                                                                    Name,
1061
1
                                                                    Args);
1062
0
1063
    // Otherwise, make an elaborated type wrapping a non-dependent
1064
    // specialization.
1065
0
    QualType T =
1066
0
    getDerived().RebuildTemplateSpecializationType(InstName, NameLoc, Args);
1067
0
    if (T.isNull()) return QualType();
1068
0
1069
0
    if (Keyword == ETK_None && QualifierLoc.getNestedNameSpecifier() == nullptr)
1070
0
      return T;
1071
0
1072
0
    return SemaRef.Context.getElaboratedType(Keyword,
1073
0
                                       QualifierLoc.getNestedNameSpecifier(),
1074
0
                                             T);
1075
0
  }
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildDependentTemplateSpecializationType(clang::ElaboratedTypeKeyword, clang::NestedNameSpecifierLoc, clang::SourceLocation, clang::IdentifierInfo const*, clang::SourceLocation, clang::TemplateArgumentListInfo&, bool)
Line
Count
Source
1044
110k
                                          bool AllowInjectedClassName) {
1045
    // Rebuild the template name.
1046
    // TODO: avoid TemplateName abstraction
1047
110k
    CXXScopeSpec SS;
1048
110k
    SS.Adopt(QualifierLoc);
1049
110k
    TemplateName InstName = getDerived().RebuildTemplateName(
1050
110k
        SS, TemplateKWLoc, *Name, NameLoc, QualType(), nullptr,
1051
110k
        AllowInjectedClassName);
1052
110k
1053
110k
    if (InstName.isNull())
1054
13.3k
      return QualType();
1055
96.8k
1056
    // If it's still dependent, make a dependent specialization.
1057
96.8k
    if (InstName.getAsDependentTemplateName())
1058
69.6k
      return SemaRef.Context.getDependentTemplateSpecializationType(Keyword,
1059
69.6k
                                          QualifierLoc.getNestedNameSpecifier(),
1060
69.6k
                                                                    Name,
1061
69.6k
                                                                    Args);
1062
27.1k
1063
    // Otherwise, make an elaborated type wrapping a non-dependent
1064
    // specialization.
1065
27.1k
    QualType T =
1066
27.1k
    getDerived().RebuildTemplateSpecializationType(InstName, NameLoc, Args);
1067
27.1k
    if (T.isNull()) 
return QualType()13
;
1068
27.1k
1069
27.1k
    if (Keyword == ETK_None && 
QualifierLoc.getNestedNameSpecifier() == nullptr10
)
1070
0
      return T;
1071
27.1k
1072
27.1k
    return SemaRef.Context.getElaboratedType(Keyword,
1073
27.1k
                                       QualifierLoc.getNestedNameSpecifier(),
1074
27.1k
                                             T);
1075
27.1k
  }
1076
1077
  /// Build a new typename type that refers to an identifier.
1078
  ///
1079
  /// By default, performs semantic analysis when building the typename type
1080
  /// (or elaborated type). Subclasses may override this routine to provide
1081
  /// different behavior.
1082
  QualType RebuildDependentNameType(ElaboratedTypeKeyword Keyword,
1083
                                    SourceLocation KeywordLoc,
1084
                                    NestedNameSpecifierLoc QualifierLoc,
1085
                                    const IdentifierInfo *Id,
1086
                                    SourceLocation IdLoc,
1087
1.18M
                                    bool DeducedTSTContext) {
1088
1.18M
    CXXScopeSpec SS;
1089
1.18M
    SS.Adopt(QualifierLoc);
1090
1.18M
1091
1.18M
    if (QualifierLoc.getNestedNameSpecifier()->isDependent()) {
1092
      // If the name is still dependent, just build a new dependent name type.
1093
420k
      if (!SemaRef.computeDeclContext(SS))
1094
390k
        return SemaRef.Context.getDependentNameType(Keyword,
1095
390k
                                          QualifierLoc.getNestedNameSpecifier(),
1096
390k
                                                    Id);
1097
795k
    }
1098
795k
1099
795k
    if (Keyword == ETK_None || 
Keyword == ETK_Typename792k
) {
1100
795k
      return SemaRef.CheckTypenameType(Keyword, KeywordLoc, QualifierLoc,
1101
795k
                                       *Id, IdLoc, DeducedTSTContext);
1102
795k
    }
1103
47
1104
47
    TagTypeKind Kind = TypeWithKeyword::getTagTypeKindForKeyword(Keyword);
1105
47
1106
    // We had a dependent elaborated-type-specifier that has been transformed
1107
    // into a non-dependent elaborated-type-specifier. Find the tag we're
1108
    // referring to.
1109
47
    LookupResult Result(SemaRef, Id, IdLoc, Sema::LookupTagName);
1110
47
    DeclContext *DC = SemaRef.computeDeclContext(SS, false);
1111
47
    if (!DC)
1112
0
      return QualType();
1113
47
1114
47
    if (SemaRef.RequireCompleteDeclContext(SS, DC))
1115
2
      return QualType();
1116
45
1117
45
    TagDecl *Tag = nullptr;
1118
45
    SemaRef.LookupQualifiedName(Result, DC);
1119
45
    switch (Result.getResultKind()) {
1120
4
      case LookupResult::NotFound:
1121
4
      case LookupResult::NotFoundInCurrentInstantiation:
1122
4
        break;
1123
4
1124
41
      case LookupResult::Found:
1125
41
        Tag = Result.getAsSingle<TagDecl>();
1126
41
        break;
1127
4
1128
0
      case LookupResult::FoundOverloaded:
1129
0
      case LookupResult::FoundUnresolvedValue:
1130
0
        llvm_unreachable("Tag lookup cannot find non-tags");
1131
0
1132
0
      case LookupResult::Ambiguous:
1133
        // Let the LookupResult structure handle ambiguities.
1134
0
        return QualType();
1135
45
    }
1136
45
1137
45
    if (!Tag) {
1138
      // Check where the name exists but isn't a tag type and use that to emit
1139
      // better diagnostics.
1140
10
      LookupResult Result(SemaRef, Id, IdLoc, Sema::LookupTagName);
1141
10
      SemaRef.LookupQualifiedName(Result, DC);
1142
10
      switch (Result.getResultKind()) {
1143
6
        case LookupResult::Found:
1144
6
        case LookupResult::FoundOverloaded:
1145
6
        case LookupResult::FoundUnresolvedValue: {
1146
6
          NamedDecl *SomeDecl = Result.getRepresentativeDecl();
1147
6
          Sema::NonTagKind NTK = SemaRef.getNonTagTypeDeclKind(SomeDecl, Kind);
1148
6
          SemaRef.Diag(IdLoc, diag::err_tag_reference_non_tag) << SomeDecl
1149
6
                                                               << NTK << Kind;
1150
6
          SemaRef.Diag(SomeDecl->getLocation(), diag::note_declared_at);
1151
6
          break;
1152
6
        }
1153
4
        default:
1154
4
          SemaRef.Diag(IdLoc, diag::err_not_tag_in_scope)
1155
4
              << Kind << Id << DC << QualifierLoc.getSourceRange();
1156
4
          break;
1157
10
      }
1158
10
      return QualType();
1159
10
    }
1160
35
1161
35
    if (!SemaRef.isAcceptableTagRedeclaration(Tag, Kind, /*isDefinition*/false,
1162
4
                                              IdLoc, Id)) {
1163
4
      SemaRef.Diag(KeywordLoc, diag::err_use_with_wrong_tag) << Id;
1164
4
      SemaRef.Diag(Tag->getLocation(), diag::note_previous_use);
1165
4
      return QualType();
1166
4
    }
1167
31
1168
    // Build the elaborated-type-specifier type.
1169
31
    QualType T = SemaRef.Context.getTypeDeclType(Tag);
1170
31
    return SemaRef.Context.getElaboratedType(Keyword,
1171
31
                                         QualifierLoc.getNestedNameSpecifier(),
1172
31
                                             T);
1173
31
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildDependentNameType(clang::ElaboratedTypeKeyword, clang::SourceLocation, clang::NestedNameSpecifierLoc, clang::IdentifierInfo const*, clang::SourceLocation, bool)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildDependentNameType(clang::ElaboratedTypeKeyword, clang::SourceLocation, clang::NestedNameSpecifierLoc, clang::IdentifierInfo const*, clang::SourceLocation, bool)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildDependentNameType(clang::ElaboratedTypeKeyword, clang::SourceLocation, clang::NestedNameSpecifierLoc, clang::IdentifierInfo const*, clang::SourceLocation, bool)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildDependentNameType(clang::ElaboratedTypeKeyword, clang::SourceLocation, clang::NestedNameSpecifierLoc, clang::IdentifierInfo const*, clang::SourceLocation, bool)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildDependentNameType(clang::ElaboratedTypeKeyword, clang::SourceLocation, clang::NestedNameSpecifierLoc, clang::IdentifierInfo const*, clang::SourceLocation, bool)
SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildDependentNameType(clang::ElaboratedTypeKeyword, clang::SourceLocation, clang::NestedNameSpecifierLoc, clang::IdentifierInfo const*, clang::SourceLocation, bool)
Line
Count
Source
1087
5.02k
                                    bool DeducedTSTContext) {
1088
5.02k
    CXXScopeSpec SS;
1089
5.02k
    SS.Adopt(QualifierLoc);
1090
5.02k
1091
5.02k
    if (QualifierLoc.getNestedNameSpecifier()->isDependent()) {
1092
      // If the name is still dependent, just build a new dependent name type.
1093
5.02k
      if (!SemaRef.computeDeclContext(SS))
1094
5.02k
        return SemaRef.Context.getDependentNameType(Keyword,
1095
5.02k
                                          QualifierLoc.getNestedNameSpecifier(),
1096
5.02k
                                                    Id);
1097
0
    }
1098
0
1099
0
    if (Keyword == ETK_None || Keyword == ETK_Typename) {
1100
0
      return SemaRef.CheckTypenameType(Keyword, KeywordLoc, QualifierLoc,
1101
0
                                       *Id, IdLoc, DeducedTSTContext);
1102
0
    }
1103
0
1104
0
    TagTypeKind Kind = TypeWithKeyword::getTagTypeKindForKeyword(Keyword);
1105
0
1106
    // We had a dependent elaborated-type-specifier that has been transformed
1107
    // into a non-dependent elaborated-type-specifier. Find the tag we're
1108
    // referring to.
1109
0
    LookupResult Result(SemaRef, Id, IdLoc, Sema::LookupTagName);
1110
0
    DeclContext *DC = SemaRef.computeDeclContext(SS, false);
1111
0
    if (!DC)
1112
0
      return QualType();
1113
0
1114
0
    if (SemaRef.RequireCompleteDeclContext(SS, DC))
1115
0
      return QualType();
1116
0
1117
0
    TagDecl *Tag = nullptr;
1118
0
    SemaRef.LookupQualifiedName(Result, DC);
1119
0
    switch (Result.getResultKind()) {
1120
0
      case LookupResult::NotFound:
1121
0
      case LookupResult::NotFoundInCurrentInstantiation:
1122
0
        break;
1123
0
1124
0
      case LookupResult::Found:
1125
0
        Tag = Result.getAsSingle<TagDecl>();
1126
0
        break;
1127
0
1128
0
      case LookupResult::FoundOverloaded:
1129
0
      case LookupResult::FoundUnresolvedValue:
1130
0
        llvm_unreachable("Tag lookup cannot find non-tags");
1131
0
1132
0
      case LookupResult::Ambiguous:
1133
        // Let the LookupResult structure handle ambiguities.
1134
0
        return QualType();
1135
0
    }
1136
0
1137
0
    if (!Tag) {
1138
      // Check where the name exists but isn't a tag type and use that to emit
1139
      // better diagnostics.
1140
0
      LookupResult Result(SemaRef, Id, IdLoc, Sema::LookupTagName);
1141
0
      SemaRef.LookupQualifiedName(Result, DC);
1142
0
      switch (Result.getResultKind()) {
1143
0
        case LookupResult::Found:
1144
0
        case LookupResult::FoundOverloaded:
1145
0
        case LookupResult::FoundUnresolvedValue: {
1146
0
          NamedDecl *SomeDecl = Result.getRepresentativeDecl();
1147
0
          Sema::NonTagKind NTK = SemaRef.getNonTagTypeDeclKind(SomeDecl, Kind);
1148
0
          SemaRef.Diag(IdLoc, diag::err_tag_reference_non_tag) << SomeDecl
1149
0
                                                               << NTK << Kind;
1150
0
          SemaRef.Diag(SomeDecl->getLocation(), diag::note_declared_at);
1151
0
          break;
1152
0
        }
1153
0
        default:
1154
0
          SemaRef.Diag(IdLoc, diag::err_not_tag_in_scope)
1155
0
              << Kind << Id << DC << QualifierLoc.getSourceRange();
1156
0
          break;
1157
0
      }
1158
0
      return QualType();
1159
0
    }
1160
0
1161
0
    if (!SemaRef.isAcceptableTagRedeclaration(Tag, Kind, /*isDefinition*/false,
1162
0
                                              IdLoc, Id)) {
1163
0
      SemaRef.Diag(KeywordLoc, diag::err_use_with_wrong_tag) << Id;
1164
0
      SemaRef.Diag(Tag->getLocation(), diag::note_previous_use);
1165
0
      return QualType();
1166
0
    }
1167
0
1168
    // Build the elaborated-type-specifier type.
1169
0
    QualType T = SemaRef.Context.getTypeDeclType(Tag);
1170
0
    return SemaRef.Context.getElaboratedType(Keyword,
1171
0
                                         QualifierLoc.getNestedNameSpecifier(),
1172
0
                                             T);
1173
0
  }
SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildDependentNameType(clang::ElaboratedTypeKeyword, clang::SourceLocation, clang::NestedNameSpecifierLoc, clang::IdentifierInfo const*, clang::SourceLocation, bool)
Line
Count
Source
1087
39.6k
                                    bool DeducedTSTContext) {
1088
39.6k
    CXXScopeSpec SS;
1089
39.6k
    SS.Adopt(QualifierLoc);
1090
39.6k
1091
39.6k
    if (QualifierLoc.getNestedNameSpecifier()->isDependent()) {
1092
      // If the name is still dependent, just build a new dependent name type.
1093
39.6k
      if (!SemaRef.computeDeclContext(SS))
1094
11.7k
        return SemaRef.Context.getDependentNameType(Keyword,
1095
11.7k
                                          QualifierLoc.getNestedNameSpecifier(),
1096
11.7k
                                                    Id);
1097
27.8k
    }
1098
27.8k
1099
27.8k
    if (Keyword == ETK_None || 
Keyword == ETK_Typename27.8k
) {
1100
27.8k
      return SemaRef.CheckTypenameType(Keyword, KeywordLoc, QualifierLoc,
1101
27.8k
                                       *Id, IdLoc, DeducedTSTContext);
1102
27.8k
    }
1103
2
1104
2
    TagTypeKind Kind = TypeWithKeyword::getTagTypeKindForKeyword(Keyword);
1105
2
1106
    // We had a dependent elaborated-type-specifier that has been transformed
1107
    // into a non-dependent elaborated-type-specifier. Find the tag we're
1108
    // referring to.
1109
2
    LookupResult Result(SemaRef, Id, IdLoc, Sema::LookupTagName);
1110
2
    DeclContext *DC = SemaRef.computeDeclContext(SS, false);
1111
2
    if (!DC)
1112
0
      return QualType();
1113
2
1114
2
    if (SemaRef.RequireCompleteDeclContext(SS, DC))
1115
0
      return QualType();
1116
2
1117
2
    TagDecl *Tag = nullptr;
1118
2
    SemaRef.LookupQualifiedName(Result, DC);
1119
2
    switch (Result.getResultKind()) {
1120
0
      case LookupResult::NotFound:
1121
0
      case LookupResult::NotFoundInCurrentInstantiation:
1122
0
        break;
1123
0
1124
2
      case LookupResult::Found:
1125
2
        Tag = Result.getAsSingle<TagDecl>();
1126
2
        break;
1127
0
1128
0
      case LookupResult::FoundOverloaded:
1129
0
      case LookupResult::FoundUnresolvedValue:
1130
0
        llvm_unreachable("Tag lookup cannot find non-tags");
1131
0
1132
0
      case LookupResult::Ambiguous:
1133
        // Let the LookupResult structure handle ambiguities.
1134
0
        return QualType();
1135
2
    }
1136
2
1137
2
    if (!Tag) {
1138
      // Check where the name exists but isn't a tag type and use that to emit
1139
      // better diagnostics.
1140
0
      LookupResult Result(SemaRef, Id, IdLoc, Sema::LookupTagName);
1141
0
      SemaRef.LookupQualifiedName(Result, DC);
1142
0
      switch (Result.getResultKind()) {
1143
0
        case LookupResult::Found:
1144
0
        case LookupResult::FoundOverloaded:
1145
0
        case LookupResult::FoundUnresolvedValue: {
1146
0
          NamedDecl *SomeDecl = Result.getRepresentativeDecl();
1147
0
          Sema::NonTagKind NTK = SemaRef.getNonTagTypeDeclKind(SomeDecl, Kind);
1148
0
          SemaRef.Diag(IdLoc, diag::err_tag_reference_non_tag) << SomeDecl
1149
0
                                                               << NTK << Kind;
1150
0
          SemaRef.Diag(SomeDecl->getLocation(), diag::note_declared_at);
1151
0
          break;
1152
0
        }
1153
0
        default:
1154
0
          SemaRef.Diag(IdLoc, diag::err_not_tag_in_scope)
1155
0
              << Kind << Id << DC << QualifierLoc.getSourceRange();
1156
0
          break;
1157
0
      }
1158
0
      return QualType();
1159
0
    }
1160
2
1161
2
    if (!SemaRef.isAcceptableTagRedeclaration(Tag, Kind, /*isDefinition*/false,
1162
0
                                              IdLoc, Id)) {
1163
0
      SemaRef.Diag(KeywordLoc, diag::err_use_with_wrong_tag) << Id;
1164
0
      SemaRef.Diag(Tag->getLocation(), diag::note_previous_use);
1165
0
      return QualType();
1166
0
    }
1167
2
1168
    // Build the elaborated-type-specifier type.
1169
2
    QualType T = SemaRef.Context.getTypeDeclType(Tag);
1170
2
    return SemaRef.Context.getElaboratedType(Keyword,
1171
2
                                         QualifierLoc.getNestedNameSpecifier(),
1172
2
                                             T);
1173
2
  }
SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildDependentNameType(clang::ElaboratedTypeKeyword, clang::SourceLocation, clang::NestedNameSpecifierLoc, clang::IdentifierInfo const*, clang::SourceLocation, bool)
Line
Count
Source
1087
8
                                    bool DeducedTSTContext) {
1088
8
    CXXScopeSpec SS;
1089
8
    SS.Adopt(QualifierLoc);
1090
8
1091
8
    if (QualifierLoc.getNestedNameSpecifier()->isDependent()) {
1092
      // If the name is still dependent, just build a new dependent name type.
1093
8
      if (!SemaRef.computeDeclContext(SS))
1094
8
        return SemaRef.Context.getDependentNameType(Keyword,
1095
8
                                          QualifierLoc.getNestedNameSpecifier(),
1096
8
                                                    Id);
1097
0
    }
1098
0
1099
0
    if (Keyword == ETK_None || Keyword == ETK_Typename) {
1100
0
      return SemaRef.CheckTypenameType(Keyword, KeywordLoc, QualifierLoc,
1101
0
                                       *Id, IdLoc, DeducedTSTContext);
1102
0
    }
1103
0
1104
0
    TagTypeKind Kind = TypeWithKeyword::getTagTypeKindForKeyword(Keyword);
1105
0
1106
    // We had a dependent elaborated-type-specifier that has been transformed
1107
    // into a non-dependent elaborated-type-specifier. Find the tag we're
1108
    // referring to.
1109
0
    LookupResult Result(SemaRef, Id, IdLoc, Sema::LookupTagName);
1110
0
    DeclContext *DC = SemaRef.computeDeclContext(SS, false);
1111
0
    if (!DC)
1112
0
      return QualType();
1113
0
1114
0
    if (SemaRef.RequireCompleteDeclContext(SS, DC))
1115
0
      return QualType();
1116
0
1117
0
    TagDecl *Tag = nullptr;
1118
0
    SemaRef.LookupQualifiedName(Result, DC);
1119
0
    switch (Result.getResultKind()) {
1120
0
      case LookupResult::NotFound:
1121
0
      case LookupResult::NotFoundInCurrentInstantiation:
1122
0
        break;
1123
0
1124
0
      case LookupResult::Found:
1125
0
        Tag = Result.getAsSingle<TagDecl>();
1126
0
        break;
1127
0
1128
0
      case LookupResult::FoundOverloaded:
1129
0
      case LookupResult::FoundUnresolvedValue:
1130
0
        llvm_unreachable("Tag lookup cannot find non-tags");
1131
0
1132
0
      case LookupResult::Ambiguous:
1133
        // Let the LookupResult structure handle ambiguities.
1134
0
        return QualType();
1135
0
    }
1136
0
1137
0
    if (!Tag) {
1138
      // Check where the name exists but isn't a tag type and use that to emit
1139
      // better diagnostics.
1140
0
      LookupResult Result(SemaRef, Id, IdLoc, Sema::LookupTagName);
1141
0
      SemaRef.LookupQualifiedName(Result, DC);
1142
0
      switch (Result.getResultKind()) {
1143
0
        case LookupResult::Found:
1144
0
        case LookupResult::FoundOverloaded:
1145
0
        case LookupResult::FoundUnresolvedValue: {
1146
0
          NamedDecl *SomeDecl = Result.getRepresentativeDecl();
1147
0
          Sema::NonTagKind NTK = SemaRef.getNonTagTypeDeclKind(SomeDecl, Kind);
1148
0
          SemaRef.Diag(IdLoc, diag::err_tag_reference_non_tag) << SomeDecl
1149
0
                                                               << NTK << Kind;
1150
0
          SemaRef.Diag(SomeDecl->getLocation(), diag::note_declared_at);
1151
0
          break;
1152
0
        }
1153
0
        default:
1154
0
          SemaRef.Diag(IdLoc, diag::err_not_tag_in_scope)
1155
0
              << Kind << Id << DC << QualifierLoc.getSourceRange();
1156
0
          break;
1157
0
      }
1158
0
      return QualType();
1159
0
    }
1160
0
1161
0
    if (!SemaRef.isAcceptableTagRedeclaration(Tag, Kind, /*isDefinition*/false,
1162
0
                                              IdLoc, Id)) {
1163
0
      SemaRef.Diag(KeywordLoc, diag::err_use_with_wrong_tag) << Id;
1164
0
      SemaRef.Diag(Tag->getLocation(), diag::note_previous_use);
1165
0
      return QualType();
1166
0
    }
1167
0
1168
    // Build the elaborated-type-specifier type.
1169
0
    QualType T = SemaRef.Context.getTypeDeclType(Tag);
1170
0
    return SemaRef.Context.getElaboratedType(Keyword,
1171
0
                                         QualifierLoc.getNestedNameSpecifier(),
1172
0
                                             T);
1173
0
  }
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildDependentNameType(clang::ElaboratedTypeKeyword, clang::SourceLocation, clang::NestedNameSpecifierLoc, clang::IdentifierInfo const*, clang::SourceLocation, bool)
Line
Count
Source
1087
1.14M
                                    bool DeducedTSTContext) {
1088
1.14M
    CXXScopeSpec SS;
1089
1.14M
    SS.Adopt(QualifierLoc);
1090
1.14M
1091
1.14M
    if (QualifierLoc.getNestedNameSpecifier()->isDependent()) {
1092
      // If the name is still dependent, just build a new dependent name type.
1093
375k
      if (!SemaRef.computeDeclContext(SS))
1094
374k
        return SemaRef.Context.getDependentNameType(Keyword,
1095
374k
                                          QualifierLoc.getNestedNameSpecifier(),
1096
374k
                                                    Id);
1097
767k
    }
1098
767k
1099
767k
    if (Keyword == ETK_None || 
Keyword == ETK_Typename764k
) {
1100
767k
      return SemaRef.CheckTypenameType(Keyword, KeywordLoc, QualifierLoc,
1101
767k
                                       *Id, IdLoc, DeducedTSTContext);
1102
767k
    }
1103
45
1104
45
    TagTypeKind Kind = TypeWithKeyword::getTagTypeKindForKeyword(Keyword);
1105
45
1106
    // We had a dependent elaborated-type-specifier that has been transformed
1107
    // into a non-dependent elaborated-type-specifier. Find the tag we're
1108
    // referring to.
1109
45
    LookupResult Result(SemaRef, Id, IdLoc, Sema::LookupTagName);
1110
45
    DeclContext *DC = SemaRef.computeDeclContext(SS, false);
1111
45
    if (!DC)
1112
0
      return QualType();
1113
45
1114
45
    if (SemaRef.RequireCompleteDeclContext(SS, DC))
1115
2
      return QualType();
1116
43
1117
43
    TagDecl *Tag = nullptr;
1118
43
    SemaRef.LookupQualifiedName(Result, DC);
1119
43
    switch (Result.getResultKind()) {
1120
4
      case LookupResult::NotFound:
1121
4
      case LookupResult::NotFoundInCurrentInstantiation:
1122
4
        break;
1123
4
1124
39
      case LookupResult::Found:
1125
39
        Tag = Result.getAsSingle<TagDecl>();
1126
39
        break;
1127
4
1128
0
      case LookupResult::FoundOverloaded:
1129
0
      case LookupResult::FoundUnresolvedValue:
1130
0
        llvm_unreachable("Tag lookup cannot find non-tags");
1131
0
1132
0
      case LookupResult::Ambiguous:
1133
        // Let the LookupResult structure handle ambiguities.
1134
0
        return QualType();
1135
43
    }
1136
43
1137
43
    if (!Tag) {
1138
      // Check where the name exists but isn't a tag type and use that to emit
1139
      // better diagnostics.
1140
10
      LookupResult Result(SemaRef, Id, IdLoc, Sema::LookupTagName);
1141
10
      SemaRef.LookupQualifiedName(Result, DC);
1142
10
      switch (Result.getResultKind()) {
1143
6
        case LookupResult::Found:
1144
6
        case LookupResult::FoundOverloaded:
1145
6
        case LookupResult::FoundUnresolvedValue: {
1146
6
          NamedDecl *SomeDecl = Result.getRepresentativeDecl();
1147
6
          Sema::NonTagKind NTK = SemaRef.getNonTagTypeDeclKind(SomeDecl, Kind);
1148
6
          SemaRef.Diag(IdLoc, diag::err_tag_reference_non_tag) << SomeDecl
1149
6
                                                               << NTK << Kind;
1150
6
          SemaRef.Diag(SomeDecl->getLocation(), diag::note_declared_at);
1151
6
          break;
1152
6
        }
1153
4
        default:
1154
4
          SemaRef.Diag(IdLoc, diag::err_not_tag_in_scope)
1155
4
              << Kind << Id << DC << QualifierLoc.getSourceRange();
1156
4
          break;
1157
10
      }
1158
10
      return QualType();
1159
10
    }
1160
33
1161
33
    if (!SemaRef.isAcceptableTagRedeclaration(Tag, Kind, /*isDefinition*/false,
1162
4
                                              IdLoc, Id)) {
1163
4
      SemaRef.Diag(KeywordLoc, diag::err_use_with_wrong_tag) << Id;
1164
4
      SemaRef.Diag(Tag->getLocation(), diag::note_previous_use);
1165
4
      return QualType();
1166
4
    }
1167
29
1168
    // Build the elaborated-type-specifier type.
1169
29
    QualType T = SemaRef.Context.getTypeDeclType(Tag);
1170
29
    return SemaRef.Context.getElaboratedType(Keyword,
1171
29
                                         QualifierLoc.getNestedNameSpecifier(),
1172
29
                                             T);
1173
29
  }
1174
1175
  /// Build a new pack expansion type.
1176
  ///
1177
  /// By default, builds a new PackExpansionType type from the given pattern.
1178
  /// Subclasses may override this routine to provide different behavior.
1179
  QualType RebuildPackExpansionType(QualType Pattern,
1180
                                    SourceRange PatternRange,
1181
                                    SourceLocation EllipsisLoc,
1182
149
                                    Optional<unsigned> NumExpansions) {
1183
149
    return getSema().CheckPackExpansion(Pattern, PatternRange, EllipsisLoc,
1184
149
                                        NumExpansions);
1185
149
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildPackExpansionType(clang::QualType, clang::SourceRange, clang::SourceLocation, llvm::Optional<unsigned int>)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildPackExpansionType(clang::QualType, clang::SourceRange, clang::SourceLocation, llvm::Optional<unsigned int>)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildPackExpansionType(clang::QualType, clang::SourceRange, clang::SourceLocation, llvm::Optional<unsigned int>)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildPackExpansionType(clang::QualType, clang::SourceRange, clang::SourceLocation, llvm::Optional<unsigned int>)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildPackExpansionType(clang::QualType, clang::SourceRange, clang::SourceLocation, llvm::Optional<unsigned int>)
SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildPackExpansionType(clang::QualType, clang::SourceRange, clang::SourceLocation, llvm::Optional<unsigned int>)
Line
Count
Source
1182
2
                                    Optional<unsigned> NumExpansions) {
1183
2
    return getSema().CheckPackExpansion(Pattern, PatternRange, EllipsisLoc,
1184
2
                                        NumExpansions);
1185
2
  }
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildPackExpansionType(clang::QualType, clang::SourceRange, clang::SourceLocation, llvm::Optional<unsigned int>)
SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildPackExpansionType(clang::QualType, clang::SourceRange, clang::SourceLocation, llvm::Optional<unsigned int>)
Line
Count
Source
1182
59
                                    Optional<unsigned> NumExpansions) {
1183
59
    return getSema().CheckPackExpansion(Pattern, PatternRange, EllipsisLoc,
1184
59
                                        NumExpansions);
1185
59
  }
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildPackExpansionType(clang::QualType, clang::SourceRange, clang::SourceLocation, llvm::Optional<unsigned int>)
Line
Count
Source
1182
88
                                    Optional<unsigned> NumExpansions) {
1183
88
    return getSema().CheckPackExpansion(Pattern, PatternRange, EllipsisLoc,
1184
88
                                        NumExpansions);
1185
88
  }
1186
1187
  /// Build a new atomic type given its value type.
1188
  ///
1189
  /// By default, performs semantic analysis when building the atomic type.
1190
  /// Subclasses may override this routine to provide different behavior.
1191
  QualType RebuildAtomicType(QualType ValueType, SourceLocation KWLoc);
1192
1193
  /// Build a new pipe type given its value type.
1194
  QualType RebuildPipeType(QualType ValueType, SourceLocation KWLoc,
1195
                           bool isReadPipe);
1196
1197
   /// Build an extended int given its value type.
1198
  QualType RebuildExtIntType(bool IsUnsigned, unsigned NumBits,
1199
                             SourceLocation Loc);
1200
1201
  /// Build a dependent extended int given its value type.
1202
  QualType RebuildDependentExtIntType(bool IsUnsigned, Expr *NumBitsExpr,
1203
                                      SourceLocation Loc);
1204
1205
  /// Build a new template name given a nested name specifier, a flag
1206
  /// indicating whether the "template" keyword was provided, and the template
1207
  /// that the template name refers to.
1208
  ///
1209
  /// By default, builds the new template name directly. Subclasses may override
1210
  /// this routine to provide different behavior.
1211
  TemplateName RebuildTemplateName(CXXScopeSpec &SS,
1212
                                   bool TemplateKW,
1213
                                   TemplateDecl *Template);
1214
1215
  /// Build a new template name given a nested name specifier and the
1216
  /// name that is referred to as a template.
1217
  ///
1218
  /// By default, performs semantic analysis to determine whether the name can
1219
  /// be resolved to a specific template, then builds the appropriate kind of
1220
  /// template name. Subclasses may override this routine to provide different
1221
  /// behavior.
1222
  TemplateName RebuildTemplateName(CXXScopeSpec &SS,
1223
                                   SourceLocation TemplateKWLoc,
1224
                                   const IdentifierInfo &Name,
1225
                                   SourceLocation NameLoc, QualType ObjectType,
1226
                                   NamedDecl *FirstQualifierInScope,
1227
                                   bool AllowInjectedClassName);
1228
1229
  /// Build a new template name given a nested name specifier and the
1230
  /// overloaded operator name that is referred to as a template.
1231
  ///
1232
  /// By default, performs semantic analysis to determine whether the name can
1233
  /// be resolved to a specific template, then builds the appropriate kind of
1234
  /// template name. Subclasses may override this routine to provide different
1235
  /// behavior.
1236
  TemplateName RebuildTemplateName(CXXScopeSpec &SS,
1237
                                   SourceLocation TemplateKWLoc,
1238
                                   OverloadedOperatorKind Operator,
1239
                                   SourceLocation NameLoc, QualType ObjectType,
1240
                                   bool AllowInjectedClassName);
1241
1242
  /// Build a new template name given a template template parameter pack
1243
  /// and the
1244
  ///
1245
  /// By default, performs semantic analysis to determine whether the name can
1246
  /// be resolved to a specific template, then builds the appropriate kind of
1247
  /// template name. Subclasses may override this routine to provide different
1248
  /// behavior.
1249
  TemplateName RebuildTemplateName(TemplateTemplateParmDecl *Param,
1250
0
                                   const TemplateArgument &ArgPack) {
1251
0
    return getSema().Context.getSubstTemplateTemplateParmPack(Param, ArgPack);
1252
0
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildTemplateName(clang::TemplateTemplateParmDecl*, clang::TemplateArgument const&)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildTemplateName(clang::TemplateTemplateParmDecl*, clang::TemplateArgument const&)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildTemplateName(clang::TemplateTemplateParmDecl*, clang::TemplateArgument const&)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildTemplateName(clang::TemplateTemplateParmDecl*, clang::TemplateArgument const&)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildTemplateName(clang::TemplateTemplateParmDecl*, clang::TemplateArgument const&)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildTemplateName(clang::TemplateTemplateParmDecl*, clang::TemplateArgument const&)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildTemplateName(clang::TemplateTemplateParmDecl*, clang::TemplateArgument const&)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildTemplateName(clang::TemplateTemplateParmDecl*, clang::TemplateArgument const&)
Unexecuted instantiation: SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildTemplateName(clang::TemplateTemplateParmDecl*, clang::TemplateArgument const&)
1253
1254
  /// Build a new compound statement.
1255
  ///
1256
  /// By default, performs semantic analysis to build the new statement.
1257
  /// Subclasses may override this routine to provide different behavior.
1258
  StmtResult RebuildCompoundStmt(SourceLocation LBraceLoc,
1259
                                       MultiStmtArg Statements,
1260
                                       SourceLocation RBraceLoc,
1261
168k
                                       bool IsStmtExpr) {
1262
168k
    return getSema().ActOnCompoundStmt(LBraceLoc, RBraceLoc, Statements,
1263
168k
                                       IsStmtExpr);
1264
168k
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildCompoundStmt(clang::SourceLocation, llvm::MutableArrayRef<clang::Stmt*>, clang::SourceLocation, bool)
SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildCompoundStmt(clang::SourceLocation, llvm::MutableArrayRef<clang::Stmt*>, clang::SourceLocation, bool)
Line
Count
Source
1261
1
                                       bool IsStmtExpr) {
1262
1
    return getSema().ActOnCompoundStmt(LBraceLoc, RBraceLoc, Statements,
1263
1
                                       IsStmtExpr);
1264
1
  }
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildCompoundStmt(clang::SourceLocation, llvm::MutableArrayRef<clang::Stmt*>, clang::SourceLocation, bool)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildCompoundStmt(clang::SourceLocation, llvm::MutableArrayRef<clang::Stmt*>, clang::SourceLocation, bool)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildCompoundStmt(clang::SourceLocation, llvm::MutableArrayRef<clang::Stmt*>, clang::SourceLocation, bool)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildCompoundStmt(clang::SourceLocation, llvm::MutableArrayRef<clang::Stmt*>, clang::SourceLocation, bool)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildCompoundStmt(clang::SourceLocation, llvm::MutableArrayRef<clang::Stmt*>, clang::SourceLocation, bool)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildCompoundStmt(clang::SourceLocation, llvm::MutableArrayRef<clang::Stmt*>, clang::SourceLocation, bool)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildCompoundStmt(clang::SourceLocation, llvm::MutableArrayRef<clang::Stmt*>, clang::SourceLocation, bool)
Line
Count
Source
1261
168k
                                       bool IsStmtExpr) {
1262
168k
    return getSema().ActOnCompoundStmt(LBraceLoc, RBraceLoc, Statements,
1263
168k
                                       IsStmtExpr);
1264
168k
  }
1265
1266
  /// Build a new case statement.
1267
  ///
1268
  /// By default, performs semantic analysis to build the new statement.
1269
  /// Subclasses may override this routine to provide different behavior.
1270
  StmtResult RebuildCaseStmt(SourceLocation CaseLoc,
1271
                                   Expr *LHS,
1272
                                   SourceLocation EllipsisLoc,
1273
                                   Expr *RHS,
1274
466
                                   SourceLocation ColonLoc) {
1275
466
    return getSema().ActOnCaseStmt(CaseLoc, LHS, EllipsisLoc, RHS,
1276
466
                                   ColonLoc);
1277
466
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildCaseStmt(clang::SourceLocation, clang::Expr*, clang::SourceLocation, clang::Expr*, clang::SourceLocation)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildCaseStmt(clang::SourceLocation, clang::Expr*, clang::SourceLocation, clang::Expr*, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildCaseStmt(clang::SourceLocation, clang::Expr*, clang::SourceLocation, clang::Expr*, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildCaseStmt(clang::SourceLocation, clang::Expr*, clang::SourceLocation, clang::Expr*, clang::SourceLocation)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildCaseStmt(clang::SourceLocation, clang::Expr*, clang::SourceLocation, clang::Expr*, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildCaseStmt(clang::SourceLocation, clang::Expr*, clang::SourceLocation, clang::Expr*, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildCaseStmt(clang::SourceLocation, clang::Expr*, clang::SourceLocation, clang::Expr*, clang::SourceLocation)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildCaseStmt(clang::SourceLocation, clang::Expr*, clang::SourceLocation, clang::Expr*, clang::SourceLocation)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildCaseStmt(clang::SourceLocation, clang::Expr*, clang::SourceLocation, clang::Expr*, clang::SourceLocation)
Line
Count
Source
1274
466
                                   SourceLocation ColonLoc) {
1275
466
    return getSema().ActOnCaseStmt(CaseLoc, LHS, EllipsisLoc, RHS,
1276
466
                                   ColonLoc);
1277
466
  }
1278
1279
  /// Attach the body to a new case statement.
1280
  ///
1281
  /// By default, performs semantic analysis to build the new statement.
1282
  /// Subclasses may override this routine to provide different behavior.
1283
466
  StmtResult RebuildCaseStmtBody(Stmt *S, Stmt *Body) {
1284
466
    getSema().ActOnCaseStmtBody(S, Body);
1285
466
    return S;
1286
466
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildCaseStmtBody(clang::Stmt*, clang::Stmt*)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildCaseStmtBody(clang::Stmt*, clang::Stmt*)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildCaseStmtBody(clang::Stmt*, clang::Stmt*)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildCaseStmtBody(clang::Stmt*, clang::Stmt*)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildCaseStmtBody(clang::Stmt*, clang::Stmt*)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildCaseStmtBody(clang::Stmt*, clang::Stmt*)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildCaseStmtBody(clang::Stmt*, clang::Stmt*)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildCaseStmtBody(clang::Stmt*, clang::Stmt*)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildCaseStmtBody(clang::Stmt*, clang::Stmt*)
Line
Count
Source
1283
466
  StmtResult RebuildCaseStmtBody(Stmt *S, Stmt *Body) {
1284
466
    getSema().ActOnCaseStmtBody(S, Body);
1285
466
    return S;
1286
466
  }
1287
1288
  /// Build a new default statement.
1289
  ///
1290
  /// By default, performs semantic analysis to build the new statement.
1291
  /// Subclasses may override this routine to provide different behavior.
1292
  StmtResult RebuildDefaultStmt(SourceLocation DefaultLoc,
1293
                                      SourceLocation ColonLoc,
1294
50
                                      Stmt *SubStmt) {
1295
50
    return getSema().ActOnDefaultStmt(DefaultLoc, ColonLoc, SubStmt,
1296
50
                                      /*CurScope=*/nullptr);
1297
50
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildDefaultStmt(clang::SourceLocation, clang::SourceLocation, clang::Stmt*)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildDefaultStmt(clang::SourceLocation, clang::SourceLocation, clang::Stmt*)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildDefaultStmt(clang::SourceLocation, clang::SourceLocation, clang::Stmt*)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildDefaultStmt(clang::SourceLocation, clang::SourceLocation, clang::Stmt*)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildDefaultStmt(clang::SourceLocation, clang::SourceLocation, clang::Stmt*)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildDefaultStmt(clang::SourceLocation, clang::SourceLocation, clang::Stmt*)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildDefaultStmt(clang::SourceLocation, clang::SourceLocation, clang::Stmt*)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildDefaultStmt(clang::SourceLocation, clang::SourceLocation, clang::Stmt*)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildDefaultStmt(clang::SourceLocation, clang::SourceLocation, clang::Stmt*)
Line
Count
Source
1294
50
                                      Stmt *SubStmt) {
1295
50
    return getSema().ActOnDefaultStmt(DefaultLoc, ColonLoc, SubStmt,
1296
50
                                      /*CurScope=*/nullptr);
1297
50
  }
1298
1299
  /// Build a new label statement.
1300
  ///
1301
  /// By default, performs semantic analysis to build the new statement.
1302
  /// Subclasses may override this routine to provide different behavior.
1303
  StmtResult RebuildLabelStmt(SourceLocation IdentLoc, LabelDecl *L,
1304
70
                              SourceLocation ColonLoc, Stmt *SubStmt) {
1305
70
    return SemaRef.ActOnLabelStmt(IdentLoc, L, ColonLoc, SubStmt);
1306
70
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildLabelStmt(clang::SourceLocation, clang::LabelDecl*, clang::SourceLocation, clang::Stmt*)
SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildLabelStmt(clang::SourceLocation, clang::LabelDecl*, clang::SourceLocation, clang::Stmt*)
Line
Count
Source
1304
1
                              SourceLocation ColonLoc, Stmt *SubStmt) {
1305
1
    return SemaRef.ActOnLabelStmt(IdentLoc, L, ColonLoc, SubStmt);
1306
1
  }
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildLabelStmt(clang::SourceLocation, clang::LabelDecl*, clang::SourceLocation, clang::Stmt*)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildLabelStmt(clang::SourceLocation, clang::LabelDecl*, clang::SourceLocation, clang::Stmt*)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildLabelStmt(clang::SourceLocation, clang::LabelDecl*, clang::SourceLocation, clang::Stmt*)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildLabelStmt(clang::SourceLocation, clang::LabelDecl*, clang::SourceLocation, clang::Stmt*)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildLabelStmt(clang::SourceLocation, clang::LabelDecl*, clang::SourceLocation, clang::Stmt*)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildLabelStmt(clang::SourceLocation, clang::LabelDecl*, clang::SourceLocation, clang::Stmt*)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildLabelStmt(clang::SourceLocation, clang::LabelDecl*, clang::SourceLocation, clang::Stmt*)
Line
Count
Source
1304
69
                              SourceLocation ColonLoc, Stmt *SubStmt) {
1305
69
    return SemaRef.ActOnLabelStmt(IdentLoc, L, ColonLoc, SubStmt);
1306
69
  }
1307
1308
  /// Build a new label statement.
1309
  ///
1310
  /// By default, performs semantic analysis to build the new statement.
1311
  /// Subclasses may override this routine to provide different behavior.
1312
  StmtResult RebuildAttributedStmt(SourceLocation AttrLoc,
1313
                                   ArrayRef<const Attr*> Attrs,
1314
27
                                   Stmt *SubStmt) {
1315
27
    return SemaRef.ActOnAttributedStmt(AttrLoc, Attrs, SubStmt);
1316
27
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildAttributedStmt(clang::SourceLocation, llvm::ArrayRef<clang::Attr const*>, clang::Stmt*)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildAttributedStmt(clang::SourceLocation, llvm::ArrayRef<clang::Attr const*>, clang::Stmt*)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildAttributedStmt(clang::SourceLocation, llvm::ArrayRef<clang::Attr const*>, clang::Stmt*)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildAttributedStmt(clang::SourceLocation, llvm::ArrayRef<clang::Attr const*>, clang::Stmt*)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildAttributedStmt(clang::SourceLocation, llvm::ArrayRef<clang::Attr const*>, clang::Stmt*)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildAttributedStmt(clang::SourceLocation, llvm::ArrayRef<clang::Attr const*>, clang::Stmt*)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildAttributedStmt(clang::SourceLocation, llvm::ArrayRef<clang::Attr const*>, clang::Stmt*)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildAttributedStmt(clang::SourceLocation, llvm::ArrayRef<clang::Attr const*>, clang::Stmt*)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildAttributedStmt(clang::SourceLocation, llvm::ArrayRef<clang::Attr const*>, clang::Stmt*)
Line
Count
Source
1314
27
                                   Stmt *SubStmt) {
1315
27
    return SemaRef.ActOnAttributedStmt(AttrLoc, Attrs, SubStmt);
1316
27
  }
1317
1318
  /// Build a new "if" statement.
1319
  ///
1320
  /// By default, performs semantic analysis to build the new statement.
1321
  /// Subclasses may override this routine to provide different behavior.
1322
  StmtResult RebuildIfStmt(SourceLocation IfLoc, bool IsConstexpr,
1323
                           SourceLocation LParenLoc, Sema::ConditionResult Cond,
1324
                           SourceLocation RParenLoc, Stmt *Init, Stmt *Then,
1325
22.9k
                           SourceLocation ElseLoc, Stmt *Else) {
1326
22.9k
    return getSema().ActOnIfStmt(IfLoc, IsConstexpr, LParenLoc, Init, Cond,
1327
22.9k
                                 RParenLoc, Then, ElseLoc, Else);
1328
22.9k
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildIfStmt(clang::SourceLocation, bool, clang::SourceLocation, clang::Sema::ConditionResult, clang::SourceLocation, clang::Stmt*, clang::Stmt*, clang::SourceLocation, clang::Stmt*)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildIfStmt(clang::SourceLocation, bool, clang::SourceLocation, clang::Sema::ConditionResult, clang::SourceLocation, clang::Stmt*, clang::Stmt*, clang::SourceLocation, clang::Stmt*)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildIfStmt(clang::SourceLocation, bool, clang::SourceLocation, clang::Sema::ConditionResult, clang::SourceLocation, clang::Stmt*, clang::Stmt*, clang::SourceLocation, clang::Stmt*)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildIfStmt(clang::SourceLocation, bool, clang::SourceLocation, clang::Sema::ConditionResult, clang::SourceLocation, clang::Stmt*, clang::Stmt*, clang::SourceLocation, clang::Stmt*)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildIfStmt(clang::SourceLocation, bool, clang::SourceLocation, clang::Sema::ConditionResult, clang::SourceLocation, clang::Stmt*, clang::Stmt*, clang::SourceLocation, clang::Stmt*)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildIfStmt(clang::SourceLocation, bool, clang::SourceLocation, clang::Sema::ConditionResult, clang::SourceLocation, clang::Stmt*, clang::Stmt*, clang::SourceLocation, clang::Stmt*)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildIfStmt(clang::SourceLocation, bool, clang::SourceLocation, clang::Sema::ConditionResult, clang::SourceLocation, clang::Stmt*, clang::Stmt*, clang::SourceLocation, clang::Stmt*)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildIfStmt(clang::SourceLocation, bool, clang::SourceLocation, clang::Sema::ConditionResult, clang::SourceLocation, clang::Stmt*, clang::Stmt*, clang::SourceLocation, clang::Stmt*)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildIfStmt(clang::SourceLocation, bool, clang::SourceLocation, clang::Sema::ConditionResult, clang::SourceLocation, clang::Stmt*, clang::Stmt*, clang::SourceLocation, clang::Stmt*)
Line
Count
Source
1325
22.9k
                           SourceLocation ElseLoc, Stmt *Else) {
1326
22.9k
    return getSema().ActOnIfStmt(IfLoc, IsConstexpr, LParenLoc, Init, Cond,
1327
22.9k
                                 RParenLoc, Then, ElseLoc, Else);
1328
22.9k
  }
1329
1330
  /// Start building a new switch statement.
1331
  ///
1332
  /// By default, performs semantic analysis to build the new statement.
1333
  /// Subclasses may override this routine to provide different behavior.
1334
  StmtResult RebuildSwitchStmtStart(SourceLocation SwitchLoc,
1335
                                    SourceLocation LParenLoc, Stmt *Init,
1336
                                    Sema::ConditionResult Cond,
1337
152
                                    SourceLocation RParenLoc) {
1338
152
    return getSema().ActOnStartOfSwitchStmt(SwitchLoc, LParenLoc, Init, Cond,
1339
152
                                            RParenLoc);
1340
152
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildSwitchStmtStart(clang::SourceLocation, clang::SourceLocation, clang::Stmt*, clang::Sema::ConditionResult, clang::SourceLocation)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildSwitchStmtStart(clang::SourceLocation, clang::SourceLocation, clang::Stmt*, clang::Sema::ConditionResult, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildSwitchStmtStart(clang::SourceLocation, clang::SourceLocation, clang::Stmt*, clang::Sema::ConditionResult, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildSwitchStmtStart(clang::SourceLocation, clang::SourceLocation, clang::Stmt*, clang::Sema::ConditionResult, clang::SourceLocation)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildSwitchStmtStart(clang::SourceLocation, clang::SourceLocation, clang::Stmt*, clang::Sema::ConditionResult, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildSwitchStmtStart(clang::SourceLocation, clang::SourceLocation, clang::Stmt*, clang::Sema::ConditionResult, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildSwitchStmtStart(clang::SourceLocation, clang::SourceLocation, clang::Stmt*, clang::Sema::ConditionResult, clang::SourceLocation)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildSwitchStmtStart(clang::SourceLocation, clang::SourceLocation, clang::Stmt*, clang::Sema::ConditionResult, clang::SourceLocation)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildSwitchStmtStart(clang::SourceLocation, clang::SourceLocation, clang::Stmt*, clang::Sema::ConditionResult, clang::SourceLocation)
Line
Count
Source
1337
152
                                    SourceLocation RParenLoc) {
1338
152
    return getSema().ActOnStartOfSwitchStmt(SwitchLoc, LParenLoc, Init, Cond,
1339
152
                                            RParenLoc);
1340
152
  }
1341
1342
  /// Attach the body to the switch statement.
1343
  ///
1344
  /// By default, performs semantic analysis to build the new statement.
1345
  /// Subclasses may override this routine to provide different behavior.
1346
  StmtResult RebuildSwitchStmtBody(SourceLocation SwitchLoc,
1347
152
                                   Stmt *Switch, Stmt *Body) {
1348
152
    return getSema().ActOnFinishSwitchStmt(SwitchLoc, Switch, Body);
1349
152
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildSwitchStmtBody(clang::SourceLocation, clang::Stmt*, clang::Stmt*)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildSwitchStmtBody(clang::SourceLocation, clang::Stmt*, clang::Stmt*)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildSwitchStmtBody(clang::SourceLocation, clang::Stmt*, clang::Stmt*)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildSwitchStmtBody(clang::SourceLocation, clang::Stmt*, clang::Stmt*)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildSwitchStmtBody(clang::SourceLocation, clang::Stmt*, clang::Stmt*)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildSwitchStmtBody(clang::SourceLocation, clang::Stmt*, clang::Stmt*)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildSwitchStmtBody(clang::SourceLocation, clang::Stmt*, clang::Stmt*)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildSwitchStmtBody(clang::SourceLocation, clang::Stmt*, clang::Stmt*)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildSwitchStmtBody(clang::SourceLocation, clang::Stmt*, clang::Stmt*)
Line
Count
Source
1347
152
                                   Stmt *Switch, Stmt *Body) {
1348
152
    return getSema().ActOnFinishSwitchStmt(SwitchLoc, Switch, Body);
1349
152
  }
1350
1351
  /// Build a new while statement.
1352
  ///
1353
  /// By default, performs semantic analysis to build the new statement.
1354
  /// Subclasses may override this routine to provide different behavior.
1355
  StmtResult RebuildWhileStmt(SourceLocation WhileLoc, SourceLocation LParenLoc,
1356
                              Sema::ConditionResult Cond,
1357
1.61k
                              SourceLocation RParenLoc, Stmt *Body) {
1358
1.61k
    return getSema().ActOnWhileStmt(WhileLoc, LParenLoc, Cond, RParenLoc, Body);
1359
1.61k
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildWhileStmt(clang::SourceLocation, clang::SourceLocation, clang::Sema::ConditionResult, clang::SourceLocation, clang::Stmt*)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildWhileStmt(clang::SourceLocation, clang::SourceLocation, clang::Sema::ConditionResult, clang::SourceLocation, clang::Stmt*)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildWhileStmt(clang::SourceLocation, clang::SourceLocation, clang::Sema::ConditionResult, clang::SourceLocation, clang::Stmt*)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildWhileStmt(clang::SourceLocation, clang::SourceLocation, clang::Sema::ConditionResult, clang::SourceLocation, clang::Stmt*)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildWhileStmt(clang::SourceLocation, clang::SourceLocation, clang::Sema::ConditionResult, clang::SourceLocation, clang::Stmt*)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildWhileStmt(clang::SourceLocation, clang::SourceLocation, clang::Sema::ConditionResult, clang::SourceLocation, clang::Stmt*)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildWhileStmt(clang::SourceLocation, clang::SourceLocation, clang::Sema::ConditionResult, clang::SourceLocation, clang::Stmt*)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildWhileStmt(clang::SourceLocation, clang::SourceLocation, clang::Sema::ConditionResult, clang::SourceLocation, clang::Stmt*)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildWhileStmt(clang::SourceLocation, clang::SourceLocation, clang::Sema::ConditionResult, clang::SourceLocation, clang::Stmt*)
Line
Count
Source
1357
1.61k
                              SourceLocation RParenLoc, Stmt *Body) {
1358
1.61k
    return getSema().ActOnWhileStmt(WhileLoc, LParenLoc, Cond, RParenLoc, Body);
1359
1.61k
  }
1360
1361
  /// Build a new do-while statement.
1362
  ///
1363
  /// By default, performs semantic analysis to build the new statement.
1364
  /// Subclasses may override this routine to provide different behavior.
1365
  StmtResult RebuildDoStmt(SourceLocation DoLoc, Stmt *Body,
1366
                           SourceLocation WhileLoc, SourceLocation LParenLoc,
1367
511
                           Expr *Cond, SourceLocation RParenLoc) {
1368
511
    return getSema().ActOnDoStmt(DoLoc, Body, WhileLoc, LParenLoc,
1369
511
                                 Cond, RParenLoc);
1370
511
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildDoStmt(clang::SourceLocation, clang::Stmt*, clang::SourceLocation, clang::SourceLocation, clang::Expr*, clang::SourceLocation)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildDoStmt(clang::SourceLocation, clang::Stmt*, clang::SourceLocation, clang::SourceLocation, clang::Expr*, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildDoStmt(clang::SourceLocation, clang::Stmt*, clang::SourceLocation, clang::SourceLocation, clang::Expr*, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildDoStmt(clang::SourceLocation, clang::Stmt*, clang::SourceLocation, clang::SourceLocation, clang::Expr*, clang::SourceLocation)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildDoStmt(clang::SourceLocation, clang::Stmt*, clang::SourceLocation, clang::SourceLocation, clang::Expr*, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildDoStmt(clang::SourceLocation, clang::Stmt*, clang::SourceLocation, clang::SourceLocation, clang::Expr*, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildDoStmt(clang::SourceLocation, clang::Stmt*, clang::SourceLocation, clang::SourceLocation, clang::Expr*, clang::SourceLocation)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildDoStmt(clang::SourceLocation, clang::Stmt*, clang::SourceLocation, clang::SourceLocation, clang::Expr*, clang::SourceLocation)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildDoStmt(clang::SourceLocation, clang::Stmt*, clang::SourceLocation, clang::SourceLocation, clang::Expr*, clang::SourceLocation)
Line
Count
Source
1367
511
                           Expr *Cond, SourceLocation RParenLoc) {
1368
511
    return getSema().ActOnDoStmt(DoLoc, Body, WhileLoc, LParenLoc,
1369
511
                                 Cond, RParenLoc);
1370
511
  }
1371
1372
  /// Build a new for statement.
1373
  ///
1374
  /// By default, performs semantic analysis to build the new statement.
1375
  /// Subclasses may override this routine to provide different behavior.
1376
  StmtResult RebuildForStmt(SourceLocation ForLoc, SourceLocation LParenLoc,
1377
                            Stmt *Init, Sema::ConditionResult Cond,
1378
                            Sema::FullExprArg Inc, SourceLocation RParenLoc,
1379
59.3k
                            Stmt *Body) {
1380
59.3k
    return getSema().ActOnForStmt(ForLoc, LParenLoc, Init, Cond,
1381
59.3k
                                  Inc, RParenLoc, Body);
1382
59.3k
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildForStmt(clang::SourceLocation, clang::SourceLocation, clang::Stmt*, clang::Sema::ConditionResult, clang::Sema::FullExprArg, clang::SourceLocation, clang::Stmt*)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildForStmt(clang::SourceLocation, clang::SourceLocation, clang::Stmt*, clang::Sema::ConditionResult, clang::Sema::FullExprArg, clang::SourceLocation, clang::Stmt*)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildForStmt(clang::SourceLocation, clang::SourceLocation, clang::Stmt*, clang::Sema::ConditionResult, clang::Sema::FullExprArg, clang::SourceLocation, clang::Stmt*)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildForStmt(clang::SourceLocation, clang::SourceLocation, clang::Stmt*, clang::Sema::ConditionResult, clang::Sema::FullExprArg, clang::SourceLocation, clang::Stmt*)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildForStmt(clang::SourceLocation, clang::SourceLocation, clang::Stmt*, clang::Sema::ConditionResult, clang::Sema::FullExprArg, clang::SourceLocation, clang::Stmt*)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildForStmt(clang::SourceLocation, clang::SourceLocation, clang::Stmt*, clang::Sema::ConditionResult, clang::Sema::FullExprArg, clang::SourceLocation, clang::Stmt*)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildForStmt(clang::SourceLocation, clang::SourceLocation, clang::Stmt*, clang::Sema::ConditionResult, clang::Sema::FullExprArg, clang::SourceLocation, clang::Stmt*)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildForStmt(clang::SourceLocation, clang::SourceLocation, clang::Stmt*, clang::Sema::ConditionResult, clang::Sema::FullExprArg, clang::SourceLocation, clang::Stmt*)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildForStmt(clang::SourceLocation, clang::SourceLocation, clang::Stmt*, clang::Sema::ConditionResult, clang::Sema::FullExprArg, clang::SourceLocation, clang::Stmt*)
Line
Count
Source
1379
59.3k
                            Stmt *Body) {
1380
59.3k
    return getSema().ActOnForStmt(ForLoc, LParenLoc, Init, Cond,
1381
59.3k
                                  Inc, RParenLoc, Body);
1382
59.3k
  }
1383
1384
  /// Build a new goto statement.
1385
  ///
1386
  /// By default, performs semantic analysis to build the new statement.
1387
  /// Subclasses may override this routine to provide different behavior.
1388
  StmtResult RebuildGotoStmt(SourceLocation GotoLoc, SourceLocation LabelLoc,
1389
34
                             LabelDecl *Label) {
1390
34
    return getSema().ActOnGotoStmt(GotoLoc, LabelLoc, Label);
1391
34
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildGotoStmt(clang::SourceLocation, clang::SourceLocation, clang::LabelDecl*)
SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildGotoStmt(clang::SourceLocation, clang::SourceLocation, clang::LabelDecl*)
Line
Count
Source
1389
1
                             LabelDecl *Label) {
1390
1
    return getSema().ActOnGotoStmt(GotoLoc, LabelLoc, Label);
1391
1
  }
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildGotoStmt(clang::SourceLocation, clang::SourceLocation, clang::LabelDecl*)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildGotoStmt(clang::SourceLocation, clang::SourceLocation, clang::LabelDecl*)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildGotoStmt(clang::SourceLocation, clang::SourceLocation, clang::LabelDecl*)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildGotoStmt(clang::SourceLocation, clang::SourceLocation, clang::LabelDecl*)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildGotoStmt(clang::SourceLocation, clang::SourceLocation, clang::LabelDecl*)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildGotoStmt(clang::SourceLocation, clang::SourceLocation, clang::LabelDecl*)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildGotoStmt(clang::SourceLocation, clang::SourceLocation, clang::LabelDecl*)
Line
Count
Source
1389
33
                             LabelDecl *Label) {
1390
33
    return getSema().ActOnGotoStmt(GotoLoc, LabelLoc, Label);
1391
33
  }
1392
1393
  /// Build a new indirect goto statement.
1394
  ///
1395
  /// By default, performs semantic analysis to build the new statement.
1396
  /// Subclasses may override this routine to provide different behavior.
1397
  StmtResult RebuildIndirectGotoStmt(SourceLocation GotoLoc,
1398
                                     SourceLocation StarLoc,
1399
2
                                     Expr *Target) {
1400
2
    return getSema().ActOnIndirectGotoStmt(GotoLoc, StarLoc, Target);
1401
2
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildIndirectGotoStmt(clang::SourceLocation, clang::SourceLocation, clang::Expr*)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildIndirectGotoStmt(clang::SourceLocation, clang::SourceLocation, clang::Expr*)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildIndirectGotoStmt(clang::SourceLocation, clang::SourceLocation, clang::Expr*)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildIndirectGotoStmt(clang::SourceLocation, clang::SourceLocation, clang::Expr*)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildIndirectGotoStmt(clang::SourceLocation, clang::SourceLocation, clang::Expr*)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildIndirectGotoStmt(clang::SourceLocation, clang::SourceLocation, clang::Expr*)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildIndirectGotoStmt(clang::SourceLocation, clang::SourceLocation, clang::Expr*)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildIndirectGotoStmt(clang::SourceLocation, clang::SourceLocation, clang::Expr*)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildIndirectGotoStmt(clang::SourceLocation, clang::SourceLocation, clang::Expr*)
Line
Count
Source
1399
2
                                     Expr *Target) {
1400
2
    return getSema().ActOnIndirectGotoStmt(GotoLoc, StarLoc, Target);
1401
2
  }
1402
1403
  /// Build a new return statement.
1404
  ///
1405
  /// By default, performs semantic analysis to build the new statement.
1406
  /// Subclasses may override this routine to provide different behavior.
1407
120k
  StmtResult RebuildReturnStmt(SourceLocation ReturnLoc, Expr *Result) {
1408
120k
    return getSema().BuildReturnStmt(ReturnLoc, Result);
1409
120k
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildReturnStmt(clang::SourceLocation, clang::Expr*)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildReturnStmt(clang::SourceLocation, clang::Expr*)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildReturnStmt(clang::SourceLocation, clang::Expr*)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildReturnStmt(clang::SourceLocation, clang::Expr*)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildReturnStmt(clang::SourceLocation, clang::Expr*)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildReturnStmt(clang::SourceLocation, clang::Expr*)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildReturnStmt(clang::SourceLocation, clang::Expr*)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildReturnStmt(clang::SourceLocation, clang::Expr*)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildReturnStmt(clang::SourceLocation, clang::Expr*)
Line
Count
Source
1407
120k
  StmtResult RebuildReturnStmt(SourceLocation ReturnLoc, Expr *Result) {
1408
120k
    return getSema().BuildReturnStmt(ReturnLoc, Result);
1409
120k
  }
1410
1411
  /// Build a new declaration statement.
1412
  ///
1413
  /// By default, performs semantic analysis to build the new statement.
1414
  /// Subclasses may override this routine to provide different behavior.
1415
  StmtResult RebuildDeclStmt(MutableArrayRef<Decl *> Decls,
1416
130k
                             SourceLocation StartLoc, SourceLocation EndLoc) {
1417
130k
    Sema::DeclGroupPtrTy DG = getSema().BuildDeclaratorGroup(Decls);
1418
130k
    return getSema().ActOnDeclStmt(DG, StartLoc, EndLoc);
1419
130k
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildDeclStmt(llvm::MutableArrayRef<clang::Decl*>, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildDeclStmt(llvm::MutableArrayRef<clang::Decl*>, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildDeclStmt(llvm::MutableArrayRef<clang::Decl*>, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildDeclStmt(llvm::MutableArrayRef<clang::Decl*>, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildDeclStmt(llvm::MutableArrayRef<clang::Decl*>, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildDeclStmt(llvm::MutableArrayRef<clang::Decl*>, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildDeclStmt(llvm::MutableArrayRef<clang::Decl*>, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildDeclStmt(llvm::MutableArrayRef<clang::Decl*>, clang::SourceLocation, clang::SourceLocation)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildDeclStmt(llvm::MutableArrayRef<clang::Decl*>, clang::SourceLocation, clang::SourceLocation)
Line
Count
Source
1416
130k
                             SourceLocation StartLoc, SourceLocation EndLoc) {
1417
130k
    Sema::DeclGroupPtrTy DG = getSema().BuildDeclaratorGroup(Decls);
1418
130k
    return getSema().ActOnDeclStmt(DG, StartLoc, EndLoc);
1419
130k
  }
1420
1421
  /// Build a new inline asm statement.
1422
  ///
1423
  /// By default, performs semantic analysis to build the new statement.
1424
  /// Subclasses may override this routine to provide different behavior.
1425
  StmtResult RebuildGCCAsmStmt(SourceLocation AsmLoc, bool IsSimple,
1426
                               bool IsVolatile, unsigned NumOutputs,
1427
                               unsigned NumInputs, IdentifierInfo **Names,
1428
                               MultiExprArg Constraints, MultiExprArg Exprs,
1429
                               Expr *AsmString, MultiExprArg Clobbers,
1430
                               unsigned NumLabels,
1431
9
                               SourceLocation RParenLoc) {
1432
9
    return getSema().ActOnGCCAsmStmt(AsmLoc, IsSimple, IsVolatile, NumOutputs,
1433
9
                                     NumInputs, Names, Constraints, Exprs,
1434
9
                                     AsmString, Clobbers, NumLabels, RParenLoc);
1435
9
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildGCCAsmStmt(clang::SourceLocation, bool, bool, unsigned int, unsigned int, clang::IdentifierInfo**, llvm::MutableArrayRef<clang::Expr*>, llvm::MutableArrayRef<clang::Expr*>, clang::Expr*, llvm::MutableArrayRef<clang::Expr*>, unsigned int, clang::SourceLocation)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildGCCAsmStmt(clang::SourceLocation, bool, bool, unsigned int, unsigned int, clang::IdentifierInfo**, llvm::MutableArrayRef<clang::Expr*>, llvm::MutableArrayRef<clang::Expr*>, clang::Expr*, llvm::MutableArrayRef<clang::Expr*>, unsigned int, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildGCCAsmStmt(clang::SourceLocation, bool, bool, unsigned int, unsigned int, clang::IdentifierInfo**, llvm::MutableArrayRef<clang::Expr*>, llvm::MutableArrayRef<clang::Expr*>, clang::Expr*, llvm::MutableArrayRef<clang::Expr*>, unsigned int, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildGCCAsmStmt(clang::SourceLocation, bool, bool, unsigned int, unsigned int, clang::IdentifierInfo**, llvm::MutableArrayRef<clang::Expr*>, llvm::MutableArrayRef<clang::Expr*>, clang::Expr*, llvm::MutableArrayRef<clang::Expr*>, unsigned int, clang::SourceLocation)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildGCCAsmStmt(clang::SourceLocation, bool, bool, unsigned int, unsigned int, clang::IdentifierInfo**, llvm::MutableArrayRef<clang::Expr*>, llvm::MutableArrayRef<clang::Expr*>, clang::Expr*, llvm::MutableArrayRef<clang::Expr*>, unsigned int, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildGCCAsmStmt(clang::SourceLocation, bool, bool, unsigned int, unsigned int, clang::IdentifierInfo**, llvm::MutableArrayRef<clang::Expr*>, llvm::MutableArrayRef<clang::Expr*>, clang::Expr*, llvm::MutableArrayRef<clang::Expr*>, unsigned int, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildGCCAsmStmt(clang::SourceLocation, bool, bool, unsigned int, unsigned int, clang::IdentifierInfo**, llvm::MutableArrayRef<clang::Expr*>, llvm::MutableArrayRef<clang::Expr*>, clang::Expr*, llvm::MutableArrayRef<clang::Expr*>, unsigned int, clang::SourceLocation)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildGCCAsmStmt(clang::SourceLocation, bool, bool, unsigned int, unsigned int, clang::IdentifierInfo**, llvm::MutableArrayRef<clang::Expr*>, llvm::MutableArrayRef<clang::Expr*>, clang::Expr*, llvm::MutableArrayRef<clang::Expr*>, unsigned int, clang::SourceLocation)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildGCCAsmStmt(clang::SourceLocation, bool, bool, unsigned int, unsigned int, clang::IdentifierInfo**, llvm::MutableArrayRef<clang::Expr*>, llvm::MutableArrayRef<clang::Expr*>, clang::Expr*, llvm::MutableArrayRef<clang::Expr*>, unsigned int, clang::SourceLocation)
Line
Count
Source
1431
9
                               SourceLocation RParenLoc) {
1432
9
    return getSema().ActOnGCCAsmStmt(AsmLoc, IsSimple, IsVolatile, NumOutputs,
1433
9
                                     NumInputs, Names, Constraints, Exprs,
1434
9
                                     AsmString, Clobbers, NumLabels, RParenLoc);
1435
9
  }
1436
1437
  /// Build a new MS style inline asm statement.
1438
  ///
1439
  /// By default, performs semantic analysis to build the new statement.
1440
  /// Subclasses may override this routine to provide different behavior.
1441
  StmtResult RebuildMSAsmStmt(SourceLocation AsmLoc, SourceLocation LBraceLoc,
1442
                              ArrayRef<Token> AsmToks,
1443
                              StringRef AsmString,
1444
                              unsigned NumOutputs, unsigned NumInputs,
1445
                              ArrayRef<StringRef> Constraints,
1446
                              ArrayRef<StringRef> Clobbers,
1447
                              ArrayRef<Expr*> Exprs,
1448
1
                              SourceLocation EndLoc) {
1449
1
    return getSema().ActOnMSAsmStmt(AsmLoc, LBraceLoc, AsmToks, AsmString,
1450
1
                                    NumOutputs, NumInputs,
1451
1
                                    Constraints, Clobbers, Exprs, EndLoc);
1452
1
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildMSAsmStmt(clang::SourceLocation, clang::SourceLocation, llvm::ArrayRef<clang::Token>, llvm::StringRef, unsigned int, unsigned int, llvm::ArrayRef<llvm::StringRef>, llvm::ArrayRef<llvm::StringRef>, llvm::ArrayRef<clang::Expr*>, clang::SourceLocation)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildMSAsmStmt(clang::SourceLocation, clang::SourceLocation, llvm::ArrayRef<clang::Token>, llvm::StringRef, unsigned int, unsigned int, llvm::ArrayRef<llvm::StringRef>, llvm::ArrayRef<llvm::StringRef>, llvm::ArrayRef<clang::Expr*>, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildMSAsmStmt(clang::SourceLocation, clang::SourceLocation, llvm::ArrayRef<clang::Token>, llvm::StringRef, unsigned int, unsigned int, llvm::ArrayRef<llvm::StringRef>, llvm::ArrayRef<llvm::StringRef>, llvm::ArrayRef<clang::Expr*>, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildMSAsmStmt(clang::SourceLocation, clang::SourceLocation, llvm::ArrayRef<clang::Token>, llvm::StringRef, unsigned int, unsigned int, llvm::ArrayRef<llvm::StringRef>, llvm::ArrayRef<llvm::StringRef>, llvm::ArrayRef<clang::Expr*>, clang::SourceLocation)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildMSAsmStmt(clang::SourceLocation, clang::SourceLocation, llvm::ArrayRef<clang::Token>, llvm::StringRef, unsigned int, unsigned int, llvm::ArrayRef<llvm::StringRef>, llvm::ArrayRef<llvm::StringRef>, llvm::ArrayRef<clang::Expr*>, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildMSAsmStmt(clang::SourceLocation, clang::SourceLocation, llvm::ArrayRef<clang::Token>, llvm::StringRef, unsigned int, unsigned int, llvm::ArrayRef<llvm::StringRef>, llvm::ArrayRef<llvm::StringRef>, llvm::ArrayRef<clang::Expr*>, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildMSAsmStmt(clang::SourceLocation, clang::SourceLocation, llvm::ArrayRef<clang::Token>, llvm::StringRef, unsigned int, unsigned int, llvm::ArrayRef<llvm::StringRef>, llvm::ArrayRef<llvm::StringRef>, llvm::ArrayRef<clang::Expr*>, clang::SourceLocation)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildMSAsmStmt(clang::SourceLocation, clang::SourceLocation, llvm::ArrayRef<clang::Token>, llvm::StringRef, unsigned int, unsigned int, llvm::ArrayRef<llvm::StringRef>, llvm::ArrayRef<llvm::StringRef>, llvm::ArrayRef<clang::Expr*>, clang::SourceLocation)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildMSAsmStmt(clang::SourceLocation, clang::SourceLocation, llvm::ArrayRef<clang::Token>, llvm::StringRef, unsigned int, unsigned int, llvm::ArrayRef<llvm::StringRef>, llvm::ArrayRef<llvm::StringRef>, llvm::ArrayRef<clang::Expr*>, clang::SourceLocation)
Line
Count
Source
1448
1
                              SourceLocation EndLoc) {
1449
1
    return getSema().ActOnMSAsmStmt(AsmLoc, LBraceLoc, AsmToks, AsmString,
1450
1
                                    NumOutputs, NumInputs,
1451
1
                                    Constraints, Clobbers, Exprs, EndLoc);
1452
1
  }
1453
1454
  /// Build a new co_return statement.
1455
  ///
1456
  /// By default, performs semantic analysis to build the new statement.
1457
  /// Subclasses may override this routine to provide different behavior.
1458
  StmtResult RebuildCoreturnStmt(SourceLocation CoreturnLoc, Expr *Result,
1459
17
                                 bool IsImplicit) {
1460
17
    return getSema().BuildCoreturnStmt(CoreturnLoc, Result, IsImplicit);
1461
17
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildCoreturnStmt(clang::SourceLocation, clang::Expr*, bool)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildCoreturnStmt(clang::SourceLocation, clang::Expr*, bool)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildCoreturnStmt(clang::SourceLocation, clang::Expr*, bool)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildCoreturnStmt(clang::SourceLocation, clang::Expr*, bool)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildCoreturnStmt(clang::SourceLocation, clang::Expr*, bool)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildCoreturnStmt(clang::SourceLocation, clang::Expr*, bool)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildCoreturnStmt(clang::SourceLocation, clang::Expr*, bool)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildCoreturnStmt(clang::SourceLocation, clang::Expr*, bool)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildCoreturnStmt(clang::SourceLocation, clang::Expr*, bool)
Line
Count
Source
1459
17
                                 bool IsImplicit) {
1460
17
    return getSema().BuildCoreturnStmt(CoreturnLoc, Result, IsImplicit);
1461
17
  }
1462
1463
  /// Build a new co_await expression.
1464
  ///
1465
  /// By default, performs semantic analysis to build the new expression.
1466
  /// Subclasses may override this routine to provide different behavior.
1467
  ExprResult RebuildCoawaitExpr(SourceLocation CoawaitLoc, Expr *Result,
1468
118
                                bool IsImplicit) {
1469
118
    return getSema().BuildResolvedCoawaitExpr(CoawaitLoc, Result, IsImplicit);
1470
118
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildCoawaitExpr(clang::SourceLocation, clang::Expr*, bool)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildCoawaitExpr(clang::SourceLocation, clang::Expr*, bool)
SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildCoawaitExpr(clang::SourceLocation, clang::Expr*, bool)
Line
Count
Source
1468
4
                                bool IsImplicit) {
1469
4
    return getSema().BuildResolvedCoawaitExpr(CoawaitLoc, Result, IsImplicit);
1470
4
  }
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildCoawaitExpr(clang::SourceLocation, clang::Expr*, bool)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildCoawaitExpr(clang::SourceLocation, clang::Expr*, bool)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildCoawaitExpr(clang::SourceLocation, clang::Expr*, bool)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildCoawaitExpr(clang::SourceLocation, clang::Expr*, bool)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildCoawaitExpr(clang::SourceLocation, clang::Expr*, bool)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildCoawaitExpr(clang::SourceLocation, clang::Expr*, bool)
Line
Count
Source
1468
114
                                bool IsImplicit) {
1469
114
    return getSema().BuildResolvedCoawaitExpr(CoawaitLoc, Result, IsImplicit);
1470
114
  }
1471
1472
  /// Build a new co_await expression.
1473
  ///
1474
  /// By default, performs semantic analysis to build the new expression.
1475
  /// Subclasses may override this routine to provide different behavior.
1476
  ExprResult RebuildDependentCoawaitExpr(SourceLocation CoawaitLoc,
1477
                                         Expr *Result,
1478
25
                                         UnresolvedLookupExpr *Lookup) {
1479
25
    return getSema().BuildUnresolvedCoawaitExpr(CoawaitLoc, Result, Lookup);
1480
25
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildDependentCoawaitExpr(clang::SourceLocation, clang::Expr*, clang::UnresolvedLookupExpr*)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildDependentCoawaitExpr(clang::SourceLocation, clang::Expr*, clang::UnresolvedLookupExpr*)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildDependentCoawaitExpr(clang::SourceLocation, clang::Expr*, clang::UnresolvedLookupExpr*)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildDependentCoawaitExpr(clang::SourceLocation, clang::Expr*, clang::UnresolvedLookupExpr*)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildDependentCoawaitExpr(clang::SourceLocation, clang::Expr*, clang::UnresolvedLookupExpr*)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildDependentCoawaitExpr(clang::SourceLocation, clang::Expr*, clang::UnresolvedLookupExpr*)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildDependentCoawaitExpr(clang::SourceLocation, clang::Expr*, clang::UnresolvedLookupExpr*)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildDependentCoawaitExpr(clang::SourceLocation, clang::Expr*, clang::UnresolvedLookupExpr*)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildDependentCoawaitExpr(clang::SourceLocation, clang::Expr*, clang::UnresolvedLookupExpr*)
Line
Count
Source
1478
25
                                         UnresolvedLookupExpr *Lookup) {
1479
25
    return getSema().BuildUnresolvedCoawaitExpr(CoawaitLoc, Result, Lookup);
1480
25
  }
1481
1482
  /// Build a new co_yield expression.
1483
  ///
1484
  /// By default, performs semantic analysis to build the new expression.
1485
  /// Subclasses may override this routine to provide different behavior.
1486
21
  ExprResult RebuildCoyieldExpr(SourceLocation CoyieldLoc, Expr *Result) {
1487
21
    return getSema().BuildCoyieldExpr(CoyieldLoc, Result);
1488
21
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildCoyieldExpr(clang::SourceLocation, clang::Expr*)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildCoyieldExpr(clang::SourceLocation, clang::Expr*)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildCoyieldExpr(clang::SourceLocation, clang::Expr*)
SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildCoyieldExpr(clang::SourceLocation, clang::Expr*)
Line
Count
Source
1486
2
  ExprResult RebuildCoyieldExpr(SourceLocation CoyieldLoc, Expr *Result) {
1487
2
    return getSema().BuildCoyieldExpr(CoyieldLoc, Result);
1488
2
  }
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildCoyieldExpr(clang::SourceLocation, clang::Expr*)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildCoyieldExpr(clang::SourceLocation, clang::Expr*)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildCoyieldExpr(clang::SourceLocation, clang::Expr*)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildCoyieldExpr(clang::SourceLocation, clang::Expr*)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildCoyieldExpr(clang::SourceLocation, clang::Expr*)
Line
Count
Source
1486
19
  ExprResult RebuildCoyieldExpr(SourceLocation CoyieldLoc, Expr *Result) {
1487
19
    return getSema().BuildCoyieldExpr(CoyieldLoc, Result);
1488
19
  }
1489
1490
44
  StmtResult RebuildCoroutineBodyStmt(CoroutineBodyStmt::CtorArgs Args) {
1491
44
    return getSema().BuildCoroutineBodyStmt(Args);
1492
44
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildCoroutineBodyStmt(clang::CoroutineBodyStmt::CtorArgs)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildCoroutineBodyStmt(clang::CoroutineBodyStmt::CtorArgs)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildCoroutineBodyStmt(clang::CoroutineBodyStmt::CtorArgs)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildCoroutineBodyStmt(clang::CoroutineBodyStmt::CtorArgs)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildCoroutineBodyStmt(clang::CoroutineBodyStmt::CtorArgs)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildCoroutineBodyStmt(clang::CoroutineBodyStmt::CtorArgs)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildCoroutineBodyStmt(clang::CoroutineBodyStmt::CtorArgs)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildCoroutineBodyStmt(clang::CoroutineBodyStmt::CtorArgs)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildCoroutineBodyStmt(clang::CoroutineBodyStmt::CtorArgs)
Line
Count
Source
1490
44
  StmtResult RebuildCoroutineBodyStmt(CoroutineBodyStmt::CtorArgs Args) {
1491
44
    return getSema().BuildCoroutineBodyStmt(Args);
1492
44
  }
1493
1494
  /// Build a new Objective-C \@try statement.
1495
  ///
1496
  /// By default, performs semantic analysis to build the new statement.
1497
  /// Subclasses may override this routine to provide different behavior.
1498
  StmtResult RebuildObjCAtTryStmt(SourceLocation AtLoc,
1499
                                        Stmt *TryBody,
1500
                                        MultiStmtArg CatchStmts,
1501
1
                                        Stmt *Finally) {
1502
1
    return getSema().ActOnObjCAtTryStmt(AtLoc, TryBody, CatchStmts,
1503
1
                                        Finally);
1504
1
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildObjCAtTryStmt(clang::SourceLocation, clang::Stmt*, llvm::MutableArrayRef<clang::Stmt*>, clang::Stmt*)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildObjCAtTryStmt(clang::SourceLocation, clang::Stmt*, llvm::MutableArrayRef<clang::Stmt*>, clang::Stmt*)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildObjCAtTryStmt(clang::SourceLocation, clang::Stmt*, llvm::MutableArrayRef<clang::Stmt*>, clang::Stmt*)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildObjCAtTryStmt(clang::SourceLocation, clang::Stmt*, llvm::MutableArrayRef<clang::Stmt*>, clang::Stmt*)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildObjCAtTryStmt(clang::SourceLocation, clang::Stmt*, llvm::MutableArrayRef<clang::Stmt*>, clang::Stmt*)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildObjCAtTryStmt(clang::SourceLocation, clang::Stmt*, llvm::MutableArrayRef<clang::Stmt*>, clang::Stmt*)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildObjCAtTryStmt(clang::SourceLocation, clang::Stmt*, llvm::MutableArrayRef<clang::Stmt*>, clang::Stmt*)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildObjCAtTryStmt(clang::SourceLocation, clang::Stmt*, llvm::MutableArrayRef<clang::Stmt*>, clang::Stmt*)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildObjCAtTryStmt(clang::SourceLocation, clang::Stmt*, llvm::MutableArrayRef<clang::Stmt*>, clang::Stmt*)
Line
Count
Source
1501
1
                                        Stmt *Finally) {
1502
1
    return getSema().ActOnObjCAtTryStmt(AtLoc, TryBody, CatchStmts,
1503
1
                                        Finally);
1504
1
  }
1505
1506
  /// Rebuild an Objective-C exception declaration.
1507
  ///
1508
  /// By default, performs semantic analysis to build the new declaration.
1509
  /// Subclasses may override this routine to provide different behavior.
1510
  VarDecl *RebuildObjCExceptionDecl(VarDecl *ExceptionDecl,
1511
2
                                    TypeSourceInfo *TInfo, QualType T) {
1512
2
    return getSema().BuildObjCExceptionDecl(TInfo, T,
1513
2
                                            ExceptionDecl->getInnerLocStart(),
1514
2
                                            ExceptionDecl->getLocation(),
1515
2
                                            ExceptionDecl->getIdentifier());
1516
2
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildObjCExceptionDecl(clang::VarDecl*, clang::TypeSourceInfo*, clang::QualType)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildObjCExceptionDecl(clang::VarDecl*, clang::TypeSourceInfo*, clang::QualType)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildObjCExceptionDecl(clang::VarDecl*, clang::TypeSourceInfo*, clang::QualType)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildObjCExceptionDecl(clang::VarDecl*, clang::TypeSourceInfo*, clang::QualType)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildObjCExceptionDecl(clang::VarDecl*, clang::TypeSourceInfo*, clang::QualType)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildObjCExceptionDecl(clang::VarDecl*, clang::TypeSourceInfo*, clang::QualType)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildObjCExceptionDecl(clang::VarDecl*, clang::TypeSourceInfo*, clang::QualType)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildObjCExceptionDecl(clang::VarDecl*, clang::TypeSourceInfo*, clang::QualType)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildObjCExceptionDecl(clang::VarDecl*, clang::TypeSourceInfo*, clang::QualType)
Line
Count
Source
1511
2
                                    TypeSourceInfo *TInfo, QualType T) {
1512
2
    return getSema().BuildObjCExceptionDecl(TInfo, T,
1513
2
                                            ExceptionDecl->getInnerLocStart(),
1514
2
                                            ExceptionDecl->getLocation(),
1515
2
                                            ExceptionDecl->getIdentifier());
1516
2
  }
1517
1518
  /// Build a new Objective-C \@catch statement.
1519
  ///
1520
  /// By default, performs semantic analysis to build the new statement.
1521
  /// Subclasses may override this routine to provide different behavior.
1522
  StmtResult RebuildObjCAtCatchStmt(SourceLocation AtLoc,
1523
                                          SourceLocation RParenLoc,
1524
                                          VarDecl *Var,
1525
2
                                          Stmt *Body) {
1526
2
    return getSema().ActOnObjCAtCatchStmt(AtLoc, RParenLoc,
1527
2
                                          Var, Body);
1528
2
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildObjCAtCatchStmt(clang::SourceLocation, clang::SourceLocation, clang::VarDecl*, clang::Stmt*)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildObjCAtCatchStmt(clang::SourceLocation, clang::SourceLocation, clang::VarDecl*, clang::Stmt*)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildObjCAtCatchStmt(clang::SourceLocation, clang::SourceLocation, clang::VarDecl*, clang::Stmt*)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildObjCAtCatchStmt(clang::SourceLocation, clang::SourceLocation, clang::VarDecl*, clang::Stmt*)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildObjCAtCatchStmt(clang::SourceLocation, clang::SourceLocation, clang::VarDecl*, clang::Stmt*)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildObjCAtCatchStmt(clang::SourceLocation, clang::SourceLocation, clang::VarDecl*, clang::Stmt*)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildObjCAtCatchStmt(clang::SourceLocation, clang::SourceLocation, clang::VarDecl*, clang::Stmt*)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildObjCAtCatchStmt(clang::SourceLocation, clang::SourceLocation, clang::VarDecl*, clang::Stmt*)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildObjCAtCatchStmt(clang::SourceLocation, clang::SourceLocation, clang::VarDecl*, clang::Stmt*)
Line
Count
Source
1525
2
                                          Stmt *Body) {
1526
2
    return getSema().ActOnObjCAtCatchStmt(AtLoc, RParenLoc,
1527
2
                                          Var, Body);
1528
2
  }
1529
1530
  /// Build a new Objective-C \@finally statement.
1531
  ///
1532
  /// By default, performs semantic analysis to build the new statement.
1533
  /// Subclasses may override this routine to provide different behavior.
1534
  StmtResult RebuildObjCAtFinallyStmt(SourceLocation AtLoc,
1535
1
                                            Stmt *Body) {
1536
1
    return getSema().ActOnObjCAtFinallyStmt(AtLoc, Body);
1537
1
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildObjCAtFinallyStmt(clang::SourceLocation, clang::Stmt*)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildObjCAtFinallyStmt(clang::SourceLocation, clang::Stmt*)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildObjCAtFinallyStmt(clang::SourceLocation, clang::Stmt*)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildObjCAtFinallyStmt(clang::SourceLocation, clang::Stmt*)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildObjCAtFinallyStmt(clang::SourceLocation, clang::Stmt*)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildObjCAtFinallyStmt(clang::SourceLocation, clang::Stmt*)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildObjCAtFinallyStmt(clang::SourceLocation, clang::Stmt*)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildObjCAtFinallyStmt(clang::SourceLocation, clang::Stmt*)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildObjCAtFinallyStmt(clang::SourceLocation, clang::Stmt*)
Line
Count
Source
1535
1
                                            Stmt *Body) {
1536
1
    return getSema().ActOnObjCAtFinallyStmt(AtLoc, Body);
1537
1
  }
1538
1539
  /// Build a new Objective-C \@throw statement.
1540
  ///
1541
  /// By default, performs semantic analysis to build the new statement.
1542
  /// Subclasses may override this routine to provide different behavior.
1543
  StmtResult RebuildObjCAtThrowStmt(SourceLocation AtLoc,
1544
2
                                          Expr *Operand) {
1545
2
    return getSema().BuildObjCAtThrowStmt(AtLoc, Operand);
1546
2
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildObjCAtThrowStmt(clang::SourceLocation, clang::Expr*)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildObjCAtThrowStmt(clang::SourceLocation, clang::Expr*)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildObjCAtThrowStmt(clang::SourceLocation, clang::Expr*)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildObjCAtThrowStmt(clang::SourceLocation, clang::Expr*)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildObjCAtThrowStmt(clang::SourceLocation, clang::Expr*)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildObjCAtThrowStmt(clang::SourceLocation, clang::Expr*)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildObjCAtThrowStmt(clang::SourceLocation, clang::Expr*)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildObjCAtThrowStmt(clang::SourceLocation, clang::Expr*)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildObjCAtThrowStmt(clang::SourceLocation, clang::Expr*)
Line
Count
Source
1544
2
                                          Expr *Operand) {
1545
2
    return getSema().BuildObjCAtThrowStmt(AtLoc, Operand);
1546
2
  }
1547
1548
  /// Build a new OpenMP executable directive.
1549
  ///
1550
  /// By default, performs semantic analysis to build the new statement.
1551
  /// Subclasses may override this routine to provide different behavior.
1552
  StmtResult RebuildOMPExecutableDirective(OpenMPDirectiveKind Kind,
1553
                                           DeclarationNameInfo DirName,
1554
                                           OpenMPDirectiveKind CancelRegion,
1555
                                           ArrayRef<OMPClause *> Clauses,
1556
                                           Stmt *AStmt, SourceLocation StartLoc,
1557
88.1k
                                           SourceLocation EndLoc) {
1558
88.1k
    return getSema().ActOnOpenMPExecutableDirective(
1559
88.1k
        Kind, DirName, CancelRegion, Clauses, AStmt, StartLoc, EndLoc);
1560
88.1k
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildOMPExecutableDirective(llvm::omp::Directive, clang::DeclarationNameInfo, llvm::omp::Directive, llvm::ArrayRef<clang::OMPClause*>, clang::Stmt*, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildOMPExecutableDirective(llvm::omp::Directive, clang::DeclarationNameInfo, llvm::omp::Directive, llvm::ArrayRef<clang::OMPClause*>, clang::Stmt*, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildOMPExecutableDirective(llvm::omp::Directive, clang::DeclarationNameInfo, llvm::omp::Directive, llvm::ArrayRef<clang::OMPClause*>, clang::Stmt*, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildOMPExecutableDirective(llvm::omp::Directive, clang::DeclarationNameInfo, llvm::omp::Directive, llvm::ArrayRef<clang::OMPClause*>, clang::Stmt*, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildOMPExecutableDirective(llvm::omp::Directive, clang::DeclarationNameInfo, llvm::omp::Directive, llvm::ArrayRef<clang::OMPClause*>, clang::Stmt*, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildOMPExecutableDirective(llvm::omp::Directive, clang::DeclarationNameInfo, llvm::omp::Directive, llvm::ArrayRef<clang::OMPClause*>, clang::Stmt*, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildOMPExecutableDirective(llvm::omp::Directive, clang::DeclarationNameInfo, llvm::omp::Directive, llvm::ArrayRef<clang::OMPClause*>, clang::Stmt*, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildOMPExecutableDirective(llvm::omp::Directive, clang::DeclarationNameInfo, llvm::omp::Directive, llvm::ArrayRef<clang::OMPClause*>, clang::Stmt*, clang::SourceLocation, clang::SourceLocation)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildOMPExecutableDirective(llvm::omp::Directive, clang::DeclarationNameInfo, llvm::omp::Directive, llvm::ArrayRef<clang::OMPClause*>, clang::Stmt*, clang::SourceLocation, clang::SourceLocation)
Line
Count
Source
1557
88.1k
                                           SourceLocation EndLoc) {
1558
88.1k
    return getSema().ActOnOpenMPExecutableDirective(
1559
88.1k
        Kind, DirName, CancelRegion, Clauses, AStmt, StartLoc, EndLoc);
1560
88.1k
  }
1561
1562
  /// Build a new OpenMP 'if' clause.
1563
  ///
1564
  /// By default, performs semantic analysis to build the new OpenMP clause.
1565
  /// Subclasses may override this routine to provide different behavior.
1566
  OMPClause *RebuildOMPIfClause(OpenMPDirectiveKind NameModifier,
1567
                                Expr *Condition, SourceLocation StartLoc,
1568
                                SourceLocation LParenLoc,
1569
                                SourceLocation NameModifierLoc,
1570
                                SourceLocation ColonLoc,
1571
2.48k
                                SourceLocation EndLoc) {
1572
2.48k
    return getSema().ActOnOpenMPIfClause(NameModifier, Condition, StartLoc,
1573
2.48k
                                         LParenLoc, NameModifierLoc, ColonLoc,
1574
2.48k
                                         EndLoc);
1575
2.48k
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildOMPIfClause(llvm::omp::Directive, clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildOMPIfClause(llvm::omp::Directive, clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildOMPIfClause(llvm::omp::Directive, clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildOMPIfClause(llvm::omp::Directive, clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildOMPIfClause(llvm::omp::Directive, clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildOMPIfClause(llvm::omp::Directive, clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildOMPIfClause(llvm::omp::Directive, clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildOMPIfClause(llvm::omp::Directive, clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildOMPIfClause(llvm::omp::Directive, clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Line
Count
Source
1571
2.48k
                                SourceLocation EndLoc) {
1572
2.48k
    return getSema().ActOnOpenMPIfClause(NameModifier, Condition, StartLoc,
1573
2.48k
                                         LParenLoc, NameModifierLoc, ColonLoc,
1574
2.48k
                                         EndLoc);
1575
2.48k
  }
1576
1577
  /// Build a new OpenMP 'final' clause.
1578
  ///
1579
  /// By default, performs semantic analysis to build the new OpenMP clause.
1580
  /// Subclasses may override this routine to provide different behavior.
1581
  OMPClause *RebuildOMPFinalClause(Expr *Condition, SourceLocation StartLoc,
1582
                                   SourceLocation LParenLoc,
1583
178
                                   SourceLocation EndLoc) {
1584
178
    return getSema().ActOnOpenMPFinalClause(Condition, StartLoc, LParenLoc,
1585
178
                                            EndLoc);
1586
178
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildOMPFinalClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildOMPFinalClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildOMPFinalClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildOMPFinalClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildOMPFinalClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildOMPFinalClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildOMPFinalClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildOMPFinalClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildOMPFinalClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Line
Count
Source
1583
178
                                   SourceLocation EndLoc) {
1584
178
    return getSema().ActOnOpenMPFinalClause(Condition, StartLoc, LParenLoc,
1585
178
                                            EndLoc);
1586
178
  }
1587
1588
  /// Build a new OpenMP 'num_threads' clause.
1589
  ///
1590
  /// By default, performs semantic analysis to build the new OpenMP clause.
1591
  /// Subclasses may override this routine to provide different behavior.
1592
  OMPClause *RebuildOMPNumThreadsClause(Expr *NumThreads,
1593
                                        SourceLocation StartLoc,
1594
                                        SourceLocation LParenLoc,
1595
768
                                        SourceLocation EndLoc) {
1596
768
    return getSema().ActOnOpenMPNumThreadsClause(NumThreads, StartLoc,
1597
768
                                                 LParenLoc, EndLoc);
1598
768
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildOMPNumThreadsClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildOMPNumThreadsClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildOMPNumThreadsClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildOMPNumThreadsClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildOMPNumThreadsClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildOMPNumThreadsClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildOMPNumThreadsClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildOMPNumThreadsClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildOMPNumThreadsClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Line
Count
Source
1595
768
                                        SourceLocation EndLoc) {
1596
768
    return getSema().ActOnOpenMPNumThreadsClause(NumThreads, StartLoc,
1597
768
                                                 LParenLoc, EndLoc);
1598
768
  }
1599
1600
  /// Build a new OpenMP 'safelen' clause.
1601
  ///
1602
  /// By default, performs semantic analysis to build the new OpenMP clause.
1603
  /// Subclasses may override this routine to provide different behavior.
1604
  OMPClause *RebuildOMPSafelenClause(Expr *Len, SourceLocation StartLoc,
1605
                                     SourceLocation LParenLoc,
1606
1.96k
                                     SourceLocation EndLoc) {
1607
1.96k
    return getSema().ActOnOpenMPSafelenClause(Len, StartLoc, LParenLoc, EndLoc);
1608
1.96k
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildOMPSafelenClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildOMPSafelenClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildOMPSafelenClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildOMPSafelenClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildOMPSafelenClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildOMPSafelenClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildOMPSafelenClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildOMPSafelenClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildOMPSafelenClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Line
Count
Source
1606
1.96k
                                     SourceLocation EndLoc) {
1607
1.96k
    return getSema().ActOnOpenMPSafelenClause(Len, StartLoc, LParenLoc, EndLoc);
1608
1.96k
  }
1609
1610
  /// Build a new OpenMP 'simdlen' clause.
1611
  ///
1612
  /// By default, performs semantic analysis to build the new OpenMP clause.
1613
  /// Subclasses may override this routine to provide different behavior.
1614
  OMPClause *RebuildOMPSimdlenClause(Expr *Len, SourceLocation StartLoc,
1615
                                     SourceLocation LParenLoc,
1616
992
                                     SourceLocation EndLoc) {
1617
992
    return getSema().ActOnOpenMPSimdlenClause(Len, StartLoc, LParenLoc, EndLoc);
1618
992
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildOMPSimdlenClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildOMPSimdlenClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildOMPSimdlenClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildOMPSimdlenClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildOMPSimdlenClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildOMPSimdlenClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildOMPSimdlenClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildOMPSimdlenClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildOMPSimdlenClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Line
Count
Source
1616
992
                                     SourceLocation EndLoc) {
1617
992
    return getSema().ActOnOpenMPSimdlenClause(Len, StartLoc, LParenLoc, EndLoc);
1618
992
  }
1619
1620
  /// Build a new OpenMP 'allocator' clause.
1621
  ///
1622
  /// By default, performs semantic analysis to build the new OpenMP clause.
1623
  /// Subclasses may override this routine to provide different behavior.
1624
  OMPClause *RebuildOMPAllocatorClause(Expr *A, SourceLocation StartLoc,
1625
                                       SourceLocation LParenLoc,
1626
0
                                       SourceLocation EndLoc) {
1627
0
    return getSema().ActOnOpenMPAllocatorClause(A, StartLoc, LParenLoc, EndLoc);
1628
0
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildOMPAllocatorClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildOMPAllocatorClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildOMPAllocatorClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildOMPAllocatorClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildOMPAllocatorClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildOMPAllocatorClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildOMPAllocatorClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildOMPAllocatorClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildOMPAllocatorClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
1629
1630
  /// Build a new OpenMP 'collapse' clause.
1631
  ///
1632
  /// By default, performs semantic analysis to build the new OpenMP clause.
1633
  /// Subclasses may override this routine to provide different behavior.
1634
  OMPClause *RebuildOMPCollapseClause(Expr *Num, SourceLocation StartLoc,
1635
                                      SourceLocation LParenLoc,
1636
2.95k
                                      SourceLocation EndLoc) {
1637
2.95k
    return getSema().ActOnOpenMPCollapseClause(Num, StartLoc, LParenLoc,
1638
2.95k
                                               EndLoc);
1639
2.95k
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildOMPCollapseClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildOMPCollapseClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildOMPCollapseClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildOMPCollapseClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildOMPCollapseClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildOMPCollapseClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildOMPCollapseClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildOMPCollapseClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildOMPCollapseClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Line
Count
Source
1636
2.95k
                                      SourceLocation EndLoc) {
1637
2.95k
    return getSema().ActOnOpenMPCollapseClause(Num, StartLoc, LParenLoc,
1638
2.95k
                                               EndLoc);
1639
2.95k
  }
1640
1641
  /// Build a new OpenMP 'default' clause.
1642
  ///
1643
  /// By default, performs semantic analysis to build the new OpenMP clause.
1644
  /// Subclasses may override this routine to provide different behavior.
1645
  OMPClause *RebuildOMPDefaultClause(DefaultKind Kind, SourceLocation KindKwLoc,
1646
                                     SourceLocation StartLoc,
1647
                                     SourceLocation LParenLoc,
1648
436
                                     SourceLocation EndLoc) {
1649
436
    return getSema().ActOnOpenMPDefaultClause(Kind, KindKwLoc,
1650
436
                                              StartLoc, LParenLoc, EndLoc);
1651
436
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildOMPDefaultClause(llvm::omp::DefaultKind, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildOMPDefaultClause(llvm::omp::DefaultKind, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildOMPDefaultClause(llvm::omp::DefaultKind, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildOMPDefaultClause(llvm::omp::DefaultKind, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildOMPDefaultClause(llvm::omp::DefaultKind, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildOMPDefaultClause(llvm::omp::DefaultKind, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildOMPDefaultClause(llvm::omp::DefaultKind, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildOMPDefaultClause(llvm::omp::DefaultKind, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildOMPDefaultClause(llvm::omp::DefaultKind, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Line
Count
Source
1648
436
                                     SourceLocation EndLoc) {
1649
436
    return getSema().ActOnOpenMPDefaultClause(Kind, KindKwLoc,
1650
436
                                              StartLoc, LParenLoc, EndLoc);
1651
436
  }
1652
1653
  /// Build a new OpenMP 'proc_bind' clause.
1654
  ///
1655
  /// By default, performs semantic analysis to build the new OpenMP clause.
1656
  /// Subclasses may override this routine to provide different behavior.
1657
  OMPClause *RebuildOMPProcBindClause(ProcBindKind Kind,
1658
                                      SourceLocation KindKwLoc,
1659
                                      SourceLocation StartLoc,
1660
                                      SourceLocation LParenLoc,
1661
254
                                      SourceLocation EndLoc) {
1662
254
    return getSema().ActOnOpenMPProcBindClause(Kind, KindKwLoc,
1663
254
                                               StartLoc, LParenLoc, EndLoc);
1664
254
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildOMPProcBindClause(llvm::omp::ProcBindKind, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildOMPProcBindClause(llvm::omp::ProcBindKind, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildOMPProcBindClause(llvm::omp::ProcBindKind, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildOMPProcBindClause(llvm::omp::ProcBindKind, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildOMPProcBindClause(llvm::omp::ProcBindKind, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildOMPProcBindClause(llvm::omp::ProcBindKind, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildOMPProcBindClause(llvm::omp::ProcBindKind, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildOMPProcBindClause(llvm::omp::ProcBindKind, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildOMPProcBindClause(llvm::omp::ProcBindKind, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Line
Count
Source
1661
254
                                      SourceLocation EndLoc) {
1662
254
    return getSema().ActOnOpenMPProcBindClause(Kind, KindKwLoc,
1663
254
                                               StartLoc, LParenLoc, EndLoc);
1664
254
  }
1665
1666
  /// Build a new OpenMP 'schedule' clause.
1667
  ///
1668
  /// By default, performs semantic analysis to build the new OpenMP clause.
1669
  /// Subclasses may override this routine to provide different behavior.
1670
  OMPClause *RebuildOMPScheduleClause(
1671
      OpenMPScheduleClauseModifier M1, OpenMPScheduleClauseModifier M2,
1672
      OpenMPScheduleClauseKind Kind, Expr *ChunkSize, SourceLocation StartLoc,
1673
      SourceLocation LParenLoc, SourceLocation M1Loc, SourceLocation M2Loc,
1674
1.26k
      SourceLocation KindLoc, SourceLocation CommaLoc, SourceLocation EndLoc) {
1675
1.26k
    return getSema().ActOnOpenMPScheduleClause(
1676
1.26k
        M1, M2, Kind, ChunkSize, StartLoc, LParenLoc, M1Loc, M2Loc, KindLoc,
1677
1.26k
        CommaLoc, EndLoc);
1678
1.26k
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildOMPScheduleClause(clang::OpenMPScheduleClauseModifier, clang::OpenMPScheduleClauseModifier, clang::OpenMPScheduleClauseKind, clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildOMPScheduleClause(clang::OpenMPScheduleClauseModifier, clang::OpenMPScheduleClauseModifier, clang::OpenMPScheduleClauseKind, clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildOMPScheduleClause(clang::OpenMPScheduleClauseModifier, clang::OpenMPScheduleClauseModifier, clang::OpenMPScheduleClauseKind, clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildOMPScheduleClause(clang::OpenMPScheduleClauseModifier, clang::OpenMPScheduleClauseModifier, clang::OpenMPScheduleClauseKind, clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildOMPScheduleClause(clang::OpenMPScheduleClauseModifier, clang::OpenMPScheduleClauseModifier, clang::OpenMPScheduleClauseKind, clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildOMPScheduleClause(clang::OpenMPScheduleClauseModifier, clang::OpenMPScheduleClauseModifier, clang::OpenMPScheduleClauseKind, clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildOMPScheduleClause(clang::OpenMPScheduleClauseModifier, clang::OpenMPScheduleClauseModifier, clang::OpenMPScheduleClauseKind, clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildOMPScheduleClause(clang::OpenMPScheduleClauseModifier, clang::OpenMPScheduleClauseModifier, clang::OpenMPScheduleClauseKind, clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildOMPScheduleClause(clang::OpenMPScheduleClauseModifier, clang::OpenMPScheduleClauseModifier, clang::OpenMPScheduleClauseKind, clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Line
Count
Source
1674
1.26k
      SourceLocation KindLoc, SourceLocation CommaLoc, SourceLocation EndLoc) {
1675
1.26k
    return getSema().ActOnOpenMPScheduleClause(
1676
1.26k
        M1, M2, Kind, ChunkSize, StartLoc, LParenLoc, M1Loc, M2Loc, KindLoc,
1677
1.26k
        CommaLoc, EndLoc);
1678
1.26k
  }
1679
1680
  /// Build a new OpenMP 'ordered' clause.
1681
  ///
1682
  /// By default, performs semantic analysis to build the new OpenMP clause.
1683
  /// Subclasses may override this routine to provide different behavior.
1684
  OMPClause *RebuildOMPOrderedClause(SourceLocation StartLoc,
1685
                                     SourceLocation EndLoc,
1686
498
                                     SourceLocation LParenLoc, Expr *Num) {
1687
498
    return getSema().ActOnOpenMPOrderedClause(StartLoc, EndLoc, LParenLoc, Num);
1688
498
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildOMPOrderedClause(clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::Expr*)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildOMPOrderedClause(clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::Expr*)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildOMPOrderedClause(clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::Expr*)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildOMPOrderedClause(clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::Expr*)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildOMPOrderedClause(clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::Expr*)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildOMPOrderedClause(clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::Expr*)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildOMPOrderedClause(clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::Expr*)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildOMPOrderedClause(clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::Expr*)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildOMPOrderedClause(clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::Expr*)
Line
Count
Source
1686
498
                                     SourceLocation LParenLoc, Expr *Num) {
1687
498
    return getSema().ActOnOpenMPOrderedClause(StartLoc, EndLoc, LParenLoc, Num);
1688
498
  }
1689
1690
  /// Build a new OpenMP 'private' clause.
1691
  ///
1692
  /// By default, performs semantic analysis to build the new OpenMP clause.
1693
  /// Subclasses may override this routine to provide different behavior.
1694
  OMPClause *RebuildOMPPrivateClause(ArrayRef<Expr *> VarList,
1695
                                     SourceLocation StartLoc,
1696
                                     SourceLocation LParenLoc,
1697
4.48k
                                     SourceLocation EndLoc) {
1698
4.48k
    return getSema().ActOnOpenMPPrivateClause(VarList, StartLoc, LParenLoc,
1699
4.48k
                                              EndLoc);
1700
4.48k
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildOMPPrivateClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildOMPPrivateClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildOMPPrivateClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildOMPPrivateClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildOMPPrivateClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildOMPPrivateClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildOMPPrivateClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildOMPPrivateClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildOMPPrivateClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Line
Count
Source
1697
4.48k
                                     SourceLocation EndLoc) {
1698
4.48k
    return getSema().ActOnOpenMPPrivateClause(VarList, StartLoc, LParenLoc,
1699
4.48k
                                              EndLoc);
1700
4.48k
  }
1701
1702
  /// Build a new OpenMP 'firstprivate' clause.
1703
  ///
1704
  /// By default, performs semantic analysis to build the new OpenMP clause.
1705
  /// Subclasses may override this routine to provide different behavior.
1706
  OMPClause *RebuildOMPFirstprivateClause(ArrayRef<Expr *> VarList,
1707
                                          SourceLocation StartLoc,
1708
                                          SourceLocation LParenLoc,
1709
1.21k
                                          SourceLocation EndLoc) {
1710
1.21k
    return getSema().ActOnOpenMPFirstprivateClause(VarList, StartLoc, LParenLoc,
1711
1.21k
                                                   EndLoc);
1712
1.21k
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildOMPFirstprivateClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildOMPFirstprivateClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildOMPFirstprivateClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildOMPFirstprivateClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildOMPFirstprivateClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildOMPFirstprivateClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildOMPFirstprivateClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildOMPFirstprivateClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildOMPFirstprivateClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Line
Count
Source
1709
1.21k
                                          SourceLocation EndLoc) {
1710
1.21k
    return getSema().ActOnOpenMPFirstprivateClause(VarList, StartLoc, LParenLoc,
1711
1.21k
                                                   EndLoc);
1712
1.21k
  }
1713
1714
  /// Build a new OpenMP 'lastprivate' clause.
1715
  ///
1716
  /// By default, performs semantic analysis to build the new OpenMP clause.
1717
  /// Subclasses may override this routine to provide different behavior.
1718
  OMPClause *RebuildOMPLastprivateClause(ArrayRef<Expr *> VarList,
1719
                                         OpenMPLastprivateModifier LPKind,
1720
                                         SourceLocation LPKindLoc,
1721
                                         SourceLocation ColonLoc,
1722
                                         SourceLocation StartLoc,
1723
                                         SourceLocation LParenLoc,
1724
1.37k
                                         SourceLocation EndLoc) {
1725
1.37k
    return getSema().ActOnOpenMPLastprivateClause(
1726
1.37k
        VarList, LPKind, LPKindLoc, ColonLoc, StartLoc, LParenLoc, EndLoc);
1727
1.37k
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildOMPLastprivateClause(llvm::ArrayRef<clang::Expr*>, clang::OpenMPLastprivateModifier, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildOMPLastprivateClause(llvm::ArrayRef<clang::Expr*>, clang::OpenMPLastprivateModifier, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildOMPLastprivateClause(llvm::ArrayRef<clang::Expr*>, clang::OpenMPLastprivateModifier, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildOMPLastprivateClause(llvm::ArrayRef<clang::Expr*>, clang::OpenMPLastprivateModifier, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildOMPLastprivateClause(llvm::ArrayRef<clang::Expr*>, clang::OpenMPLastprivateModifier, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildOMPLastprivateClause(llvm::ArrayRef<clang::Expr*>, clang::OpenMPLastprivateModifier, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildOMPLastprivateClause(llvm::ArrayRef<clang::Expr*>, clang::OpenMPLastprivateModifier, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildOMPLastprivateClause(llvm::ArrayRef<clang::Expr*>, clang::OpenMPLastprivateModifier, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildOMPLastprivateClause(llvm::ArrayRef<clang::Expr*>, clang::OpenMPLastprivateModifier, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Line
Count
Source
1724
1.37k
                                         SourceLocation EndLoc) {
1725
1.37k
    return getSema().ActOnOpenMPLastprivateClause(
1726
1.37k
        VarList, LPKind, LPKindLoc, ColonLoc, StartLoc, LParenLoc, EndLoc);
1727
1.37k
  }
1728
1729
  /// Build a new OpenMP 'shared' clause.
1730
  ///
1731
  /// By default, performs semantic analysis to build the new OpenMP clause.
1732
  /// Subclasses may override this routine to provide different behavior.
1733
  OMPClause *RebuildOMPSharedClause(ArrayRef<Expr *> VarList,
1734
                                    SourceLocation StartLoc,
1735
                                    SourceLocation LParenLoc,
1736
1.37k
                                    SourceLocation EndLoc) {
1737
1.37k
    return getSema().ActOnOpenMPSharedClause(VarList, StartLoc, LParenLoc,
1738
1.37k
                                             EndLoc);
1739
1.37k
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildOMPSharedClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildOMPSharedClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildOMPSharedClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildOMPSharedClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildOMPSharedClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildOMPSharedClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildOMPSharedClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildOMPSharedClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildOMPSharedClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Line
Count
Source
1736
1.37k
                                    SourceLocation EndLoc) {
1737
1.37k
    return getSema().ActOnOpenMPSharedClause(VarList, StartLoc, LParenLoc,
1738
1.37k
                                             EndLoc);
1739
1.37k
  }
1740
1741
  /// Build a new OpenMP 'reduction' clause.
1742
  ///
1743
  /// By default, performs semantic analysis to build the new statement.
1744
  /// Subclasses may override this routine to provide different behavior.
1745
  OMPClause *RebuildOMPReductionClause(
1746
      ArrayRef<Expr *> VarList, OpenMPReductionClauseModifier Modifier,
1747
      SourceLocation StartLoc, SourceLocation LParenLoc,
1748
      SourceLocation ModifierLoc, SourceLocation ColonLoc,
1749
      SourceLocation EndLoc, CXXScopeSpec &ReductionIdScopeSpec,
1750
      const DeclarationNameInfo &ReductionId,
1751
17.3k
      ArrayRef<Expr *> UnresolvedReductions) {
1752
17.3k
    return getSema().ActOnOpenMPReductionClause(
1753
17.3k
        VarList, Modifier, StartLoc, LParenLoc, ModifierLoc, ColonLoc, EndLoc,
1754
17.3k
        ReductionIdScopeSpec, ReductionId, UnresolvedReductions);
1755
17.3k
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildOMPReductionClause(llvm::ArrayRef<clang::Expr*>, clang::OpenMPReductionClauseModifier, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::CXXScopeSpec&, clang::DeclarationNameInfo const&, llvm::ArrayRef<clang::Expr*>)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildOMPReductionClause(llvm::ArrayRef<clang::Expr*>, clang::OpenMPReductionClauseModifier, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::CXXScopeSpec&, clang::DeclarationNameInfo const&, llvm::ArrayRef<clang::Expr*>)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildOMPReductionClause(llvm::ArrayRef<clang::Expr*>, clang::OpenMPReductionClauseModifier, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::CXXScopeSpec&, clang::DeclarationNameInfo const&, llvm::ArrayRef<clang::Expr*>)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildOMPReductionClause(llvm::ArrayRef<clang::Expr*>, clang::OpenMPReductionClauseModifier, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::CXXScopeSpec&, clang::DeclarationNameInfo const&, llvm::ArrayRef<clang::Expr*>)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildOMPReductionClause(llvm::ArrayRef<clang::Expr*>, clang::OpenMPReductionClauseModifier, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::CXXScopeSpec&, clang::DeclarationNameInfo const&, llvm::ArrayRef<clang::Expr*>)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildOMPReductionClause(llvm::ArrayRef<clang::Expr*>, clang::OpenMPReductionClauseModifier, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::CXXScopeSpec&, clang::DeclarationNameInfo const&, llvm::ArrayRef<clang::Expr*>)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildOMPReductionClause(llvm::ArrayRef<clang::Expr*>, clang::OpenMPReductionClauseModifier, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::CXXScopeSpec&, clang::DeclarationNameInfo const&, llvm::ArrayRef<clang::Expr*>)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildOMPReductionClause(llvm::ArrayRef<clang::Expr*>, clang::OpenMPReductionClauseModifier, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::CXXScopeSpec&, clang::DeclarationNameInfo const&, llvm::ArrayRef<clang::Expr*>)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildOMPReductionClause(llvm::ArrayRef<clang::Expr*>, clang::OpenMPReductionClauseModifier, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::CXXScopeSpec&, clang::DeclarationNameInfo const&, llvm::ArrayRef<clang::Expr*>)
Line
Count
Source
1751
17.3k
      ArrayRef<Expr *> UnresolvedReductions) {
1752
17.3k
    return getSema().ActOnOpenMPReductionClause(
1753
17.3k
        VarList, Modifier, StartLoc, LParenLoc, ModifierLoc, ColonLoc, EndLoc,
1754
17.3k
        ReductionIdScopeSpec, ReductionId, UnresolvedReductions);
1755
17.3k
  }
1756
1757
  /// Build a new OpenMP 'task_reduction' clause.
1758
  ///
1759
  /// By default, performs semantic analysis to build the new statement.
1760
  /// Subclasses may override this routine to provide different behavior.
1761
  OMPClause *RebuildOMPTaskReductionClause(
1762
      ArrayRef<Expr *> VarList, SourceLocation StartLoc,
1763
      SourceLocation LParenLoc, SourceLocation ColonLoc, SourceLocation EndLoc,
1764
      CXXScopeSpec &ReductionIdScopeSpec,
1765
      const DeclarationNameInfo &ReductionId,
1766
1.24k
      ArrayRef<Expr *> UnresolvedReductions) {
1767
1.24k
    return getSema().ActOnOpenMPTaskReductionClause(
1768
1.24k
        VarList, StartLoc, LParenLoc, ColonLoc, EndLoc, ReductionIdScopeSpec,
1769
1.24k
        ReductionId, UnresolvedReductions);
1770
1.24k
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildOMPTaskReductionClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::CXXScopeSpec&, clang::DeclarationNameInfo const&, llvm::ArrayRef<clang::Expr*>)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildOMPTaskReductionClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::CXXScopeSpec&, clang::DeclarationNameInfo const&, llvm::ArrayRef<clang::Expr*>)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildOMPTaskReductionClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::CXXScopeSpec&, clang::DeclarationNameInfo const&, llvm::ArrayRef<clang::Expr*>)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildOMPTaskReductionClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::CXXScopeSpec&, clang::DeclarationNameInfo const&, llvm::ArrayRef<clang::Expr*>)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildOMPTaskReductionClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::CXXScopeSpec&, clang::DeclarationNameInfo const&, llvm::ArrayRef<clang::Expr*>)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildOMPTaskReductionClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::CXXScopeSpec&, clang::DeclarationNameInfo const&, llvm::ArrayRef<clang::Expr*>)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildOMPTaskReductionClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::CXXScopeSpec&, clang::DeclarationNameInfo const&, llvm::ArrayRef<clang::Expr*>)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildOMPTaskReductionClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::CXXScopeSpec&, clang::DeclarationNameInfo const&, llvm::ArrayRef<clang::Expr*>)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildOMPTaskReductionClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::CXXScopeSpec&, clang::DeclarationNameInfo const&, llvm::ArrayRef<clang::Expr*>)
Line
Count
Source
1766
1.24k
      ArrayRef<Expr *> UnresolvedReductions) {
1767
1.24k
    return getSema().ActOnOpenMPTaskReductionClause(
1768
1.24k
        VarList, StartLoc, LParenLoc, ColonLoc, EndLoc, ReductionIdScopeSpec,
1769
1.24k
        ReductionId, UnresolvedReductions);
1770
1.24k
  }
1771
1772
  /// Build a new OpenMP 'in_reduction' clause.
1773
  ///
1774
  /// By default, performs semantic analysis to build the new statement.
1775
  /// Subclasses may override this routine to provide different behavior.
1776
  OMPClause *
1777
  RebuildOMPInReductionClause(ArrayRef<Expr *> VarList, SourceLocation StartLoc,
1778
                              SourceLocation LParenLoc, SourceLocation ColonLoc,
1779
                              SourceLocation EndLoc,
1780
                              CXXScopeSpec &ReductionIdScopeSpec,
1781
                              const DeclarationNameInfo &ReductionId,
1782
1.12k
                              ArrayRef<Expr *> UnresolvedReductions) {
1783
1.12k
    return getSema().ActOnOpenMPInReductionClause(
1784
1.12k
        VarList, StartLoc, LParenLoc, ColonLoc, EndLoc, ReductionIdScopeSpec,
1785
1.12k
        ReductionId, UnresolvedReductions);
1786
1.12k
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildOMPInReductionClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::CXXScopeSpec&, clang::DeclarationNameInfo const&, llvm::ArrayRef<clang::Expr*>)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildOMPInReductionClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::CXXScopeSpec&, clang::DeclarationNameInfo const&, llvm::ArrayRef<clang::Expr*>)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildOMPInReductionClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::CXXScopeSpec&, clang::DeclarationNameInfo const&, llvm::ArrayRef<clang::Expr*>)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildOMPInReductionClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::CXXScopeSpec&, clang::DeclarationNameInfo const&, llvm::ArrayRef<clang::Expr*>)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildOMPInReductionClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::CXXScopeSpec&, clang::DeclarationNameInfo const&, llvm::ArrayRef<clang::Expr*>)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildOMPInReductionClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::CXXScopeSpec&, clang::DeclarationNameInfo const&, llvm::ArrayRef<clang::Expr*>)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildOMPInReductionClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::CXXScopeSpec&, clang::DeclarationNameInfo const&, llvm::ArrayRef<clang::Expr*>)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildOMPInReductionClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::CXXScopeSpec&, clang::DeclarationNameInfo const&, llvm::ArrayRef<clang::Expr*>)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildOMPInReductionClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::CXXScopeSpec&, clang::DeclarationNameInfo const&, llvm::ArrayRef<clang::Expr*>)
Line
Count
Source
1782
1.12k
                              ArrayRef<Expr *> UnresolvedReductions) {
1783
1.12k
    return getSema().ActOnOpenMPInReductionClause(
1784
1.12k
        VarList, StartLoc, LParenLoc, ColonLoc, EndLoc, ReductionIdScopeSpec,
1785
1.12k
        ReductionId, UnresolvedReductions);
1786
1.12k
  }
1787
1788
  /// Build a new OpenMP 'linear' clause.
1789
  ///
1790
  /// By default, performs semantic analysis to build the new OpenMP clause.
1791
  /// Subclasses may override this routine to provide different behavior.
1792
  OMPClause *RebuildOMPLinearClause(ArrayRef<Expr *> VarList, Expr *Step,
1793
                                    SourceLocation StartLoc,
1794
                                    SourceLocation LParenLoc,
1795
                                    OpenMPLinearClauseKind Modifier,
1796
                                    SourceLocation ModifierLoc,
1797
                                    SourceLocation ColonLoc,
1798
534
                                    SourceLocation EndLoc) {
1799
534
    return getSema().ActOnOpenMPLinearClause(VarList, Step, StartLoc, LParenLoc,
1800
534
                                             Modifier, ModifierLoc, ColonLoc,
1801
534
                                             EndLoc);
1802
534
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildOMPLinearClause(llvm::ArrayRef<clang::Expr*>, clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::OpenMPLinearClauseKind, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildOMPLinearClause(llvm::ArrayRef<clang::Expr*>, clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::OpenMPLinearClauseKind, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildOMPLinearClause(llvm::ArrayRef<clang::Expr*>, clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::OpenMPLinearClauseKind, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildOMPLinearClause(llvm::ArrayRef<clang::Expr*>, clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::OpenMPLinearClauseKind, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildOMPLinearClause(llvm::ArrayRef<clang::Expr*>, clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::OpenMPLinearClauseKind, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildOMPLinearClause(llvm::ArrayRef<clang::Expr*>, clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::OpenMPLinearClauseKind, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildOMPLinearClause(llvm::ArrayRef<clang::Expr*>, clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::OpenMPLinearClauseKind, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildOMPLinearClause(llvm::ArrayRef<clang::Expr*>, clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::OpenMPLinearClauseKind, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildOMPLinearClause(llvm::ArrayRef<clang::Expr*>, clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::OpenMPLinearClauseKind, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Line
Count
Source
1798
534
                                    SourceLocation EndLoc) {
1799
534
    return getSema().ActOnOpenMPLinearClause(VarList, Step, StartLoc, LParenLoc,
1800
534
                                             Modifier, ModifierLoc, ColonLoc,
1801
534
                                             EndLoc);
1802
534
  }
1803
1804
  /// Build a new OpenMP 'aligned' clause.
1805
  ///
1806
  /// By default, performs semantic analysis to build the new OpenMP clause.
1807
  /// Subclasses may override this routine to provide different behavior.
1808
  OMPClause *RebuildOMPAlignedClause(ArrayRef<Expr *> VarList, Expr *Alignment,
1809
                                     SourceLocation StartLoc,
1810
                                     SourceLocation LParenLoc,
1811
                                     SourceLocation ColonLoc,
1812
468
                                     SourceLocation EndLoc) {
1813
468
    return getSema().ActOnOpenMPAlignedClause(VarList, Alignment, StartLoc,
1814
468
                                              LParenLoc, ColonLoc, EndLoc);
1815
468
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildOMPAlignedClause(llvm::ArrayRef<clang::Expr*>, clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildOMPAlignedClause(llvm::ArrayRef<clang::Expr*>, clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildOMPAlignedClause(llvm::ArrayRef<clang::Expr*>, clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildOMPAlignedClause(llvm::ArrayRef<clang::Expr*>, clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildOMPAlignedClause(llvm::ArrayRef<clang::Expr*>, clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildOMPAlignedClause(llvm::ArrayRef<clang::Expr*>, clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildOMPAlignedClause(llvm::ArrayRef<clang::Expr*>, clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildOMPAlignedClause(llvm::ArrayRef<clang::Expr*>, clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildOMPAlignedClause(llvm::ArrayRef<clang::Expr*>, clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Line
Count
Source
1812
468
                                     SourceLocation EndLoc) {
1813
468
    return getSema().ActOnOpenMPAlignedClause(VarList, Alignment, StartLoc,
1814
468
                                              LParenLoc, ColonLoc, EndLoc);
1815
468
  }
1816
1817
  /// Build a new OpenMP 'copyin' clause.
1818
  ///
1819
  /// By default, performs semantic analysis to build the new OpenMP clause.
1820
  /// Subclasses may override this routine to provide different behavior.
1821
  OMPClause *RebuildOMPCopyinClause(ArrayRef<Expr *> VarList,
1822
                                    SourceLocation StartLoc,
1823
                                    SourceLocation LParenLoc,
1824
112
                                    SourceLocation EndLoc) {
1825
112
    return getSema().ActOnOpenMPCopyinClause(VarList, StartLoc, LParenLoc,
1826
112
                                             EndLoc);
1827
112
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildOMPCopyinClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildOMPCopyinClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildOMPCopyinClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildOMPCopyinClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildOMPCopyinClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildOMPCopyinClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildOMPCopyinClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildOMPCopyinClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildOMPCopyinClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Line
Count
Source
1824
112
                                    SourceLocation EndLoc) {
1825
112
    return getSema().ActOnOpenMPCopyinClause(VarList, StartLoc, LParenLoc,
1826
112
                                             EndLoc);
1827
112
  }
1828
1829
  /// Build a new OpenMP 'copyprivate' clause.
1830
  ///
1831
  /// By default, performs semantic analysis to build the new OpenMP clause.
1832
  /// Subclasses may override this routine to provide different behavior.
1833
  OMPClause *RebuildOMPCopyprivateClause(ArrayRef<Expr *> VarList,
1834
                                         SourceLocation StartLoc,
1835
                                         SourceLocation LParenLoc,
1836
62
                                         SourceLocation EndLoc) {
1837
62
    return getSema().ActOnOpenMPCopyprivateClause(VarList, StartLoc, LParenLoc,
1838
62
                                                  EndLoc);
1839
62
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildOMPCopyprivateClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildOMPCopyprivateClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildOMPCopyprivateClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildOMPCopyprivateClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildOMPCopyprivateClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildOMPCopyprivateClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildOMPCopyprivateClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildOMPCopyprivateClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildOMPCopyprivateClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Line
Count
Source
1836
62
                                         SourceLocation EndLoc) {
1837
62
    return getSema().ActOnOpenMPCopyprivateClause(VarList, StartLoc, LParenLoc,
1838
62
                                                  EndLoc);
1839
62
  }
1840
1841
  /// Build a new OpenMP 'flush' pseudo clause.
1842
  ///
1843
  /// By default, performs semantic analysis to build the new OpenMP clause.
1844
  /// Subclasses may override this routine to provide different behavior.
1845
  OMPClause *RebuildOMPFlushClause(ArrayRef<Expr *> VarList,
1846
                                   SourceLocation StartLoc,
1847
                                   SourceLocation LParenLoc,
1848
30
                                   SourceLocation EndLoc) {
1849
30
    return getSema().ActOnOpenMPFlushClause(VarList, StartLoc, LParenLoc,
1850
30
                                            EndLoc);
1851
30
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildOMPFlushClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildOMPFlushClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildOMPFlushClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildOMPFlushClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildOMPFlushClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildOMPFlushClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildOMPFlushClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildOMPFlushClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildOMPFlushClause(llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Line
Count
Source
1848
30
                                   SourceLocation EndLoc) {
1849
30
    return getSema().ActOnOpenMPFlushClause(VarList, StartLoc, LParenLoc,
1850
30
                                            EndLoc);
1851
30
  }
1852
1853
  /// Build a new OpenMP 'depobj' pseudo clause.
1854
  ///
1855
  /// By default, performs semantic analysis to build the new OpenMP clause.
1856
  /// Subclasses may override this routine to provide different behavior.
1857
  OMPClause *RebuildOMPDepobjClause(Expr *Depobj, SourceLocation StartLoc,
1858
                                    SourceLocation LParenLoc,
1859
72
                                    SourceLocation EndLoc) {
1860
72
    return getSema().ActOnOpenMPDepobjClause(Depobj, StartLoc, LParenLoc,
1861
72
                                             EndLoc);
1862
72
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildOMPDepobjClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildOMPDepobjClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildOMPDepobjClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildOMPDepobjClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildOMPDepobjClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildOMPDepobjClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildOMPDepobjClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildOMPDepobjClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildOMPDepobjClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Line
Count
Source
1859
72
                                    SourceLocation EndLoc) {
1860
72
    return getSema().ActOnOpenMPDepobjClause(Depobj, StartLoc, LParenLoc,
1861
72
                                             EndLoc);
1862
72
  }
1863
1864
  /// Build a new OpenMP 'depend' pseudo clause.
1865
  ///
1866
  /// By default, performs semantic analysis to build the new OpenMP clause.
1867
  /// Subclasses may override this routine to provide different behavior.
1868
  OMPClause *
1869
  RebuildOMPDependClause(Expr *DepModifier, OpenMPDependClauseKind DepKind,
1870
                         SourceLocation DepLoc, SourceLocation ColonLoc,
1871
                         ArrayRef<Expr *> VarList, SourceLocation StartLoc,
1872
622
                         SourceLocation LParenLoc, SourceLocation EndLoc) {
1873
622
    return getSema().ActOnOpenMPDependClause(DepModifier, DepKind, DepLoc,
1874
622
                                             ColonLoc, VarList, StartLoc,
1875
622
                                             LParenLoc, EndLoc);
1876
622
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildOMPDependClause(clang::Expr*, clang::OpenMPDependClauseKind, clang::SourceLocation, clang::SourceLocation, llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildOMPDependClause(clang::Expr*, clang::OpenMPDependClauseKind, clang::SourceLocation, clang::SourceLocation, llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildOMPDependClause(clang::Expr*, clang::OpenMPDependClauseKind, clang::SourceLocation, clang::SourceLocation, llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildOMPDependClause(clang::Expr*, clang::OpenMPDependClauseKind, clang::SourceLocation, clang::SourceLocation, llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildOMPDependClause(clang::Expr*, clang::OpenMPDependClauseKind, clang::SourceLocation, clang::SourceLocation, llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildOMPDependClause(clang::Expr*, clang::OpenMPDependClauseKind, clang::SourceLocation, clang::SourceLocation, llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildOMPDependClause(clang::Expr*, clang::OpenMPDependClauseKind, clang::SourceLocation, clang::SourceLocation, llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildOMPDependClause(clang::Expr*, clang::OpenMPDependClauseKind, clang::SourceLocation, clang::SourceLocation, llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildOMPDependClause(clang::Expr*, clang::OpenMPDependClauseKind, clang::SourceLocation, clang::SourceLocation, llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Line
Count
Source
1872
622
                         SourceLocation LParenLoc, SourceLocation EndLoc) {
1873
622
    return getSema().ActOnOpenMPDependClause(DepModifier, DepKind, DepLoc,
1874
622
                                             ColonLoc, VarList, StartLoc,
1875
622
                                             LParenLoc, EndLoc);
1876
622
  }
1877
1878
  /// Build a new OpenMP 'device' clause.
1879
  ///
1880
  /// By default, performs semantic analysis to build the new statement.
1881
  /// Subclasses may override this routine to provide different behavior.
1882
  OMPClause *RebuildOMPDeviceClause(OpenMPDeviceClauseModifier Modifier,
1883
                                    Expr *Device, SourceLocation StartLoc,
1884
                                    SourceLocation LParenLoc,
1885
                                    SourceLocation ModifierLoc,
1886
126
                                    SourceLocation EndLoc) {
1887
126
    return getSema().ActOnOpenMPDeviceClause(Modifier, Device, StartLoc,
1888
126
                                             LParenLoc, ModifierLoc, EndLoc);
1889
126
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildOMPDeviceClause(clang::OpenMPDeviceClauseModifier, clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildOMPDeviceClause(clang::OpenMPDeviceClauseModifier, clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildOMPDeviceClause(clang::OpenMPDeviceClauseModifier, clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildOMPDeviceClause(clang::OpenMPDeviceClauseModifier, clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildOMPDeviceClause(clang::OpenMPDeviceClauseModifier, clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildOMPDeviceClause(clang::OpenMPDeviceClauseModifier, clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildOMPDeviceClause(clang::OpenMPDeviceClauseModifier, clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildOMPDeviceClause(clang::OpenMPDeviceClauseModifier, clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildOMPDeviceClause(clang::OpenMPDeviceClauseModifier, clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Line
Count
Source
1886
126
                                    SourceLocation EndLoc) {
1887
126
    return getSema().ActOnOpenMPDeviceClause(Modifier, Device, StartLoc,
1888
126
                                             LParenLoc, ModifierLoc, EndLoc);
1889
126
  }
1890
1891
  /// Build a new OpenMP 'map' clause.
1892
  ///
1893
  /// By default, performs semantic analysis to build the new OpenMP clause.
1894
  /// Subclasses may override this routine to provide different behavior.
1895
  OMPClause *RebuildOMPMapClause(
1896
      ArrayRef<OpenMPMapModifierKind> MapTypeModifiers,
1897
      ArrayRef<SourceLocation> MapTypeModifiersLoc,
1898
      CXXScopeSpec MapperIdScopeSpec, DeclarationNameInfo MapperId,
1899
      OpenMPMapClauseKind MapType, bool IsMapTypeImplicit,
1900
      SourceLocation MapLoc, SourceLocation ColonLoc, ArrayRef<Expr *> VarList,
1901
9.95k
      const OMPVarListLocTy &Locs, ArrayRef<Expr *> UnresolvedMappers) {
1902
9.95k
    return getSema().ActOnOpenMPMapClause(MapTypeModifiers, MapTypeModifiersLoc,
1903
9.95k
                                          MapperIdScopeSpec, MapperId, MapType,
1904
9.95k
                                          IsMapTypeImplicit, MapLoc, ColonLoc,
1905
9.95k
                                          VarList, Locs, UnresolvedMappers);
1906
9.95k
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildOMPMapClause(llvm::ArrayRef<clang::OpenMPMapModifierKind>, llvm::ArrayRef<clang::SourceLocation>, clang::CXXScopeSpec, clang::DeclarationNameInfo, clang::OpenMPMapClauseKind, bool, clang::SourceLocation, clang::SourceLocation, llvm::ArrayRef<clang::Expr*>, clang::OMPVarListLocTy const&, llvm::ArrayRef<clang::Expr*>)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildOMPMapClause(llvm::ArrayRef<clang::OpenMPMapModifierKind>, llvm::ArrayRef<clang::SourceLocation>, clang::CXXScopeSpec, clang::DeclarationNameInfo, clang::OpenMPMapClauseKind, bool, clang::SourceLocation, clang::SourceLocation, llvm::ArrayRef<clang::Expr*>, clang::OMPVarListLocTy const&, llvm::ArrayRef<clang::Expr*>)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildOMPMapClause(llvm::ArrayRef<clang::OpenMPMapModifierKind>, llvm::ArrayRef<clang::SourceLocation>, clang::CXXScopeSpec, clang::DeclarationNameInfo, clang::OpenMPMapClauseKind, bool, clang::SourceLocation, clang::SourceLocation, llvm::ArrayRef<clang::Expr*>, clang::OMPVarListLocTy const&, llvm::ArrayRef<clang::Expr*>)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildOMPMapClause(llvm::ArrayRef<clang::OpenMPMapModifierKind>, llvm::ArrayRef<clang::SourceLocation>, clang::CXXScopeSpec, clang::DeclarationNameInfo, clang::OpenMPMapClauseKind, bool, clang::SourceLocation, clang::SourceLocation, llvm::ArrayRef<clang::Expr*>, clang::OMPVarListLocTy const&, llvm::ArrayRef<clang::Expr*>)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildOMPMapClause(llvm::ArrayRef<clang::OpenMPMapModifierKind>, llvm::ArrayRef<clang::SourceLocation>, clang::CXXScopeSpec, clang::DeclarationNameInfo, clang::OpenMPMapClauseKind, bool, clang::SourceLocation, clang::SourceLocation, llvm::ArrayRef<clang::Expr*>, clang::OMPVarListLocTy const&, llvm::ArrayRef<clang::Expr*>)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildOMPMapClause(llvm::ArrayRef<clang::OpenMPMapModifierKind>, llvm::ArrayRef<clang::SourceLocation>, clang::CXXScopeSpec, clang::DeclarationNameInfo, clang::OpenMPMapClauseKind, bool, clang::SourceLocation, clang::SourceLocation, llvm::ArrayRef<clang::Expr*>, clang::OMPVarListLocTy const&, llvm::ArrayRef<clang::Expr*>)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildOMPMapClause(llvm::ArrayRef<clang::OpenMPMapModifierKind>, llvm::ArrayRef<clang::SourceLocation>, clang::CXXScopeSpec, clang::DeclarationNameInfo, clang::OpenMPMapClauseKind, bool, clang::SourceLocation, clang::SourceLocation, llvm::ArrayRef<clang::Expr*>, clang::OMPVarListLocTy const&, llvm::ArrayRef<clang::Expr*>)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildOMPMapClause(llvm::ArrayRef<clang::OpenMPMapModifierKind>, llvm::ArrayRef<clang::SourceLocation>, clang::CXXScopeSpec, clang::DeclarationNameInfo, clang::OpenMPMapClauseKind, bool, clang::SourceLocation, clang::SourceLocation, llvm::ArrayRef<clang::Expr*>, clang::OMPVarListLocTy const&, llvm::ArrayRef<clang::Expr*>)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildOMPMapClause(llvm::ArrayRef<clang::OpenMPMapModifierKind>, llvm::ArrayRef<clang::SourceLocation>, clang::CXXScopeSpec, clang::DeclarationNameInfo, clang::OpenMPMapClauseKind, bool, clang::SourceLocation, clang::SourceLocation, llvm::ArrayRef<clang::Expr*>, clang::OMPVarListLocTy const&, llvm::ArrayRef<clang::Expr*>)
Line
Count
Source
1901
9.95k
      const OMPVarListLocTy &Locs, ArrayRef<Expr *> UnresolvedMappers) {
1902
9.95k
    return getSema().ActOnOpenMPMapClause(MapTypeModifiers, MapTypeModifiersLoc,
1903
9.95k
                                          MapperIdScopeSpec, MapperId, MapType,
1904
9.95k
                                          IsMapTypeImplicit, MapLoc, ColonLoc,
1905
9.95k
                                          VarList, Locs, UnresolvedMappers);
1906
9.95k
  }
1907
1908
  /// Build a new OpenMP 'allocate' clause.
1909
  ///
1910
  /// By default, performs semantic analysis to build the new OpenMP clause.
1911
  /// Subclasses may override this routine to provide different behavior.
1912
  OMPClause *RebuildOMPAllocateClause(Expr *Allocate, ArrayRef<Expr *> VarList,
1913
                                      SourceLocation StartLoc,
1914
                                      SourceLocation LParenLoc,
1915
                                      SourceLocation ColonLoc,
1916
863
                                      SourceLocation EndLoc) {
1917
863
    return getSema().ActOnOpenMPAllocateClause(Allocate, VarList, StartLoc,
1918
863
                                               LParenLoc, ColonLoc, EndLoc);
1919
863
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildOMPAllocateClause(clang::Expr*, llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildOMPAllocateClause(clang::Expr*, llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildOMPAllocateClause(clang::Expr*, llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildOMPAllocateClause(clang::Expr*, llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildOMPAllocateClause(clang::Expr*, llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildOMPAllocateClause(clang::Expr*, llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildOMPAllocateClause(clang::Expr*, llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildOMPAllocateClause(clang::Expr*, llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildOMPAllocateClause(clang::Expr*, llvm::ArrayRef<clang::Expr*>, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Line
Count
Source
1916
863
                                      SourceLocation EndLoc) {
1917
863
    return getSema().ActOnOpenMPAllocateClause(Allocate, VarList, StartLoc,
1918
863
                                               LParenLoc, ColonLoc, EndLoc);
1919
863
  }
1920
1921
  /// Build a new OpenMP 'num_teams' clause.
1922
  ///
1923
  /// By default, performs semantic analysis to build the new statement.
1924
  /// Subclasses may override this routine to provide different behavior.
1925
  OMPClause *RebuildOMPNumTeamsClause(Expr *NumTeams, SourceLocation StartLoc,
1926
                                      SourceLocation LParenLoc,
1927
420
                                      SourceLocation EndLoc) {
1928
420
    return getSema().ActOnOpenMPNumTeamsClause(NumTeams, StartLoc, LParenLoc,
1929
420
                                               EndLoc);
1930
420
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildOMPNumTeamsClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildOMPNumTeamsClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildOMPNumTeamsClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildOMPNumTeamsClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildOMPNumTeamsClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildOMPNumTeamsClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildOMPNumTeamsClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildOMPNumTeamsClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildOMPNumTeamsClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Line
Count
Source
1927
420
                                      SourceLocation EndLoc) {
1928
420
    return getSema().ActOnOpenMPNumTeamsClause(NumTeams, StartLoc, LParenLoc,
1929
420
                                               EndLoc);
1930
420
  }
1931
1932
  /// Build a new OpenMP 'thread_limit' clause.
1933
  ///
1934
  /// By default, performs semantic analysis to build the new statement.
1935
  /// Subclasses may override this routine to provide different behavior.
1936
  OMPClause *RebuildOMPThreadLimitClause(Expr *ThreadLimit,
1937
                                         SourceLocation StartLoc,
1938
                                         SourceLocation LParenLoc,
1939
364
                                         SourceLocation EndLoc) {
1940
364
    return getSema().ActOnOpenMPThreadLimitClause(ThreadLimit, StartLoc,
1941
364
                                                  LParenLoc, EndLoc);
1942
364
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildOMPThreadLimitClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildOMPThreadLimitClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildOMPThreadLimitClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildOMPThreadLimitClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildOMPThreadLimitClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildOMPThreadLimitClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildOMPThreadLimitClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildOMPThreadLimitClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildOMPThreadLimitClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Line
Count
Source
1939
364
                                         SourceLocation EndLoc) {
1940
364
    return getSema().ActOnOpenMPThreadLimitClause(ThreadLimit, StartLoc,
1941
364
                                                  LParenLoc, EndLoc);
1942
364
  }
1943
1944
  /// Build a new OpenMP 'priority' clause.
1945
  ///
1946
  /// By default, performs semantic analysis to build the new statement.
1947
  /// Subclasses may override this routine to provide different behavior.
1948
  OMPClause *RebuildOMPPriorityClause(Expr *Priority, SourceLocation StartLoc,
1949
                                      SourceLocation LParenLoc,
1950
244
                                      SourceLocation EndLoc) {
1951
244
    return getSema().ActOnOpenMPPriorityClause(Priority, StartLoc, LParenLoc,
1952
244
                                               EndLoc);
1953
244
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildOMPPriorityClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildOMPPriorityClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildOMPPriorityClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildOMPPriorityClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildOMPPriorityClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildOMPPriorityClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildOMPPriorityClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildOMPPriorityClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildOMPPriorityClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Line
Count
Source
1950
244
                                      SourceLocation EndLoc) {
1951
244
    return getSema().ActOnOpenMPPriorityClause(Priority, StartLoc, LParenLoc,
1952
244
                                               EndLoc);
1953
244
  }
1954
1955
  /// Build a new OpenMP 'grainsize' clause.
1956
  ///
1957
  /// By default, performs semantic analysis to build the new statement.
1958
  /// Subclasses may override this routine to provide different behavior.
1959
  OMPClause *RebuildOMPGrainsizeClause(Expr *Grainsize, SourceLocation StartLoc,
1960
                                       SourceLocation LParenLoc,
1961
132
                                       SourceLocation EndLoc) {
1962
132
    return getSema().ActOnOpenMPGrainsizeClause(Grainsize, StartLoc, LParenLoc,
1963
132
                                                EndLoc);
1964
132
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildOMPGrainsizeClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildOMPGrainsizeClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildOMPGrainsizeClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildOMPGrainsizeClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildOMPGrainsizeClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildOMPGrainsizeClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildOMPGrainsizeClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildOMPGrainsizeClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildOMPGrainsizeClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Line
Count
Source
1961
132
                                       SourceLocation EndLoc) {
1962
132
    return getSema().ActOnOpenMPGrainsizeClause(Grainsize, StartLoc, LParenLoc,
1963
132
                                                EndLoc);
1964
132
  }
1965
1966
  /// Build a new OpenMP 'num_tasks' clause.
1967
  ///
1968
  /// By default, performs semantic analysis to build the new statement.
1969
  /// Subclasses may override this routine to provide different behavior.
1970
  OMPClause *RebuildOMPNumTasksClause(Expr *NumTasks, SourceLocation StartLoc,
1971
                                      SourceLocation LParenLoc,
1972
132
                                      SourceLocation EndLoc) {
1973
132
    return getSema().ActOnOpenMPNumTasksClause(NumTasks, StartLoc, LParenLoc,
1974
132
                                               EndLoc);
1975
132
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildOMPNumTasksClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildOMPNumTasksClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildOMPNumTasksClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildOMPNumTasksClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildOMPNumTasksClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildOMPNumTasksClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildOMPNumTasksClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildOMPNumTasksClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildOMPNumTasksClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Line
Count
Source
1972
132
                                      SourceLocation EndLoc) {
1973
132
    return getSema().ActOnOpenMPNumTasksClause(NumTasks, StartLoc, LParenLoc,
1974
132
                                               EndLoc);
1975
132
  }
1976
1977
  /// Build a new OpenMP 'hint' clause.
1978
  ///
1979
  /// By default, performs semantic analysis to build the new statement.
1980
  /// Subclasses may override this routine to provide different behavior.
1981
  OMPClause *RebuildOMPHintClause(Expr *Hint, SourceLocation StartLoc,
1982
                                  SourceLocation LParenLoc,
1983
32
                                  SourceLocation EndLoc) {
1984
32
    return getSema().ActOnOpenMPHintClause(Hint, StartLoc, LParenLoc, EndLoc);
1985
32
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildOMPHintClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildOMPHintClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildOMPHintClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildOMPHintClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildOMPHintClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildOMPHintClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildOMPHintClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildOMPHintClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildOMPHintClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Line
Count
Source
1983
32
                                  SourceLocation EndLoc) {
1984
32
    return getSema().ActOnOpenMPHintClause(Hint, StartLoc, LParenLoc, EndLoc);
1985
32
  }
1986
1987
  /// Build a new OpenMP 'detach' clause.
1988
  ///
1989
  /// By default, performs semantic analysis to build the new statement.
1990
  /// Subclasses may override this routine to provide different behavior.
1991
  OMPClause *RebuildOMPDetachClause(Expr *Evt, SourceLocation StartLoc,
1992
                                    SourceLocation LParenLoc,
1993
36
                                    SourceLocation EndLoc) {
1994
36
    return getSema().ActOnOpenMPDetachClause(Evt, StartLoc, LParenLoc, EndLoc);
1995
36
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildOMPDetachClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildOMPDetachClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildOMPDetachClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildOMPDetachClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildOMPDetachClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildOMPDetachClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildOMPDetachClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildOMPDetachClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildOMPDetachClause(clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Line
Count
Source
1993
36
                                    SourceLocation EndLoc) {
1994
36
    return getSema().ActOnOpenMPDetachClause(Evt, StartLoc, LParenLoc, EndLoc);
1995
36
  }
1996
1997
  /// Build a new OpenMP 'dist_schedule' clause.
1998
  ///
1999
  /// By default, performs semantic analysis to build the new OpenMP clause.
2000
  /// Subclasses may override this routine to provide different behavior.
2001
  OMPClause *
2002
  RebuildOMPDistScheduleClause(OpenMPDistScheduleClauseKind Kind,
2003
                               Expr *ChunkSize, SourceLocation StartLoc,
2004
                               SourceLocation LParenLoc, SourceLocation KindLoc,
2005
722
                               SourceLocation CommaLoc, SourceLocation EndLoc) {
2006
722
    return getSema().ActOnOpenMPDistScheduleClause(
2007
722
        Kind, ChunkSize, StartLoc, LParenLoc, KindLoc, CommaLoc, EndLoc);
2008
722
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildOMPDistScheduleClause(clang::OpenMPDistScheduleClauseKind, clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildOMPDistScheduleClause(clang::OpenMPDistScheduleClauseKind, clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildOMPDistScheduleClause(clang::OpenMPDistScheduleClauseKind, clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildOMPDistScheduleClause(clang::OpenMPDistScheduleClauseKind, clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildOMPDistScheduleClause(clang::OpenMPDistScheduleClauseKind, clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildOMPDistScheduleClause(clang::OpenMPDistScheduleClauseKind, clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildOMPDistScheduleClause(clang::OpenMPDistScheduleClauseKind, clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildOMPDistScheduleClause(clang::OpenMPDistScheduleClauseKind, clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildOMPDistScheduleClause(clang::OpenMPDistScheduleClauseKind, clang::Expr*, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation, clang::SourceLocation)
Line
Count
Source
2005
722
                               SourceLocation CommaLoc, SourceLocation EndLoc) {
2006
722
    return getSema().ActOnOpenMPDistScheduleClause(
2007
722
        Kind, ChunkSize, StartLoc, LParenLoc, KindLoc, CommaLoc, EndLoc);
2008
722
  }
2009
2010
  /// Build a new OpenMP 'to' clause.
2011
  ///
2012
  /// By default, performs semantic analysis to build the new statement.
2013
  /// Subclasses may override this routine to provide different behavior.
2014
  OMPClause *
2015
  RebuildOMPToClause(ArrayRef<OpenMPMotionModifierKind> MotionModifiers,
2016
                     ArrayRef<SourceLocation> MotionModifiersLoc,
2017
                     CXXScopeSpec &MapperIdScopeSpec,
2018
                     DeclarationNameInfo &MapperId, SourceLocation ColonLoc,
2019
                     ArrayRef<Expr *> VarList, const OMPVarListLocTy &Locs,
2020
718
                     ArrayRef<Expr *> UnresolvedMappers) {
2021
718
    return getSema().ActOnOpenMPToClause(MotionModifiers, MotionModifiersLoc,
2022
718
                                         MapperIdScopeSpec, MapperId, ColonLoc,
2023
718
                                         VarList, Locs, UnresolvedMappers);
2024
718
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildOMPToClause(llvm::ArrayRef<clang::OpenMPMotionModifierKind>, llvm::ArrayRef<clang::SourceLocation>, clang::CXXScopeSpec&, clang::DeclarationNameInfo&, clang::SourceLocation, llvm::ArrayRef<clang::Expr*>, clang::OMPVarListLocTy const&, llvm::ArrayRef<clang::Expr*>)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildOMPToClause(llvm::ArrayRef<clang::OpenMPMotionModifierKind>, llvm::ArrayRef<clang::SourceLocation>, clang::CXXScopeSpec&, clang::DeclarationNameInfo&, clang::SourceLocation, llvm::ArrayRef<clang::Expr*>, clang::OMPVarListLocTy const&, llvm::ArrayRef<clang::Expr*>)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildOMPToClause(llvm::ArrayRef<clang::OpenMPMotionModifierKind>, llvm::ArrayRef<clang::SourceLocation>, clang::CXXScopeSpec&, clang::DeclarationNameInfo&, clang::SourceLocation, llvm::ArrayRef<clang::Expr*>, clang::OMPVarListLocTy const&, llvm::ArrayRef<clang::Expr*>)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildOMPToClause(llvm::ArrayRef<clang::OpenMPMotionModifierKind>, llvm::ArrayRef<clang::SourceLocation>, clang::CXXScopeSpec&, clang::DeclarationNameInfo&, clang::SourceLocation, llvm::ArrayRef<clang::Expr*>, clang::OMPVarListLocTy const&, llvm::ArrayRef<clang::Expr*>)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildOMPToClause(llvm::ArrayRef<clang::OpenMPMotionModifierKind>, llvm::ArrayRef<clang::SourceLocation>, clang::CXXScopeSpec&, clang::DeclarationNameInfo&, clang::SourceLocation, llvm::ArrayRef<clang::Expr*>, clang::OMPVarListLocTy const&, llvm::ArrayRef<clang::Expr*>)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildOMPToClause(llvm::ArrayRef<clang::OpenMPMotionModifierKind>, llvm::ArrayRef<clang::SourceLocation>, clang::CXXScopeSpec&, clang::DeclarationNameInfo&, clang::SourceLocation, llvm::ArrayRef<clang::Expr*>, clang::OMPVarListLocTy const&, llvm::ArrayRef<clang::Expr*>)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildOMPToClause(llvm::ArrayRef<clang::OpenMPMotionModifierKind>, llvm::ArrayRef<clang::SourceLocation>, clang::CXXScopeSpec&, clang::DeclarationNameInfo&, clang::SourceLocation, llvm::ArrayRef<clang::Expr*>, clang::OMPVarListLocTy const&, llvm::ArrayRef<clang::Expr*>)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildOMPToClause(llvm::ArrayRef<clang::OpenMPMotionModifierKind>, llvm::ArrayRef<clang::SourceLocation>, clang::CXXScopeSpec&, clang::DeclarationNameInfo&, clang::SourceLocation, llvm::ArrayRef<clang::Expr*>, clang::OMPVarListLocTy const&, llvm::ArrayRef<clang::Expr*>)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildOMPToClause(llvm::ArrayRef<clang::OpenMPMotionModifierKind>, llvm::ArrayRef<clang::SourceLocation>, clang::CXXScopeSpec&, clang::DeclarationNameInfo&, clang::SourceLocation, llvm::ArrayRef<clang::Expr*>, clang::OMPVarListLocTy const&, llvm::ArrayRef<clang::Expr*>)
Line
Count
Source
2020
718
                     ArrayRef<Expr *> UnresolvedMappers) {
2021
718
    return getSema().ActOnOpenMPToClause(MotionModifiers, MotionModifiersLoc,
2022
718
                                         MapperIdScopeSpec, MapperId, ColonLoc,
2023
718
                                         VarList, Locs, UnresolvedMappers);
2024
718
  }
2025
2026
  /// Build a new OpenMP 'from' clause.
2027
  ///
2028
  /// By default, performs semantic analysis to build the new statement.
2029
  /// Subclasses may override this routine to provide different behavior.
2030
  OMPClause *
2031
  RebuildOMPFromClause(ArrayRef<OpenMPMotionModifierKind> MotionModifiers,
2032
                       ArrayRef<SourceLocation> MotionModifiersLoc,
2033
                       CXXScopeSpec &MapperIdScopeSpec,
2034
                       DeclarationNameInfo &MapperId, SourceLocation ColonLoc,
2035
                       ArrayRef<Expr *> VarList, const OMPVarListLocTy &Locs,
2036
374
                       ArrayRef<Expr *> UnresolvedMappers) {
2037
374
    return getSema().ActOnOpenMPFromClause(
2038
374
        MotionModifiers, MotionModifiersLoc, MapperIdScopeSpec, MapperId,
2039
374
        ColonLoc, VarList, Locs, UnresolvedMappers);
2040
374
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildOMPFromClause(llvm::ArrayRef<clang::OpenMPMotionModifierKind>, llvm::ArrayRef<clang::SourceLocation>, clang::CXXScopeSpec&, clang::DeclarationNameInfo&, clang::SourceLocation, llvm::ArrayRef<clang::Expr*>, clang::OMPVarListLocTy const&, llvm::ArrayRef<clang::Expr*>)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildOMPFromClause(llvm::ArrayRef<clang::OpenMPMotionModifierKind>, llvm::ArrayRef<clang::SourceLocation>, clang::CXXScopeSpec&, clang::DeclarationNameInfo&, clang::SourceLocation, llvm::ArrayRef<clang::Expr*>, clang::OMPVarListLocTy const&, llvm::ArrayRef<clang::Expr*>)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildOMPFromClause(llvm::ArrayRef<clang::OpenMPMotionModifierKind>, llvm::ArrayRef<clang::SourceLocation>, clang::CXXScopeSpec&, clang::DeclarationNameInfo&, clang::SourceLocation, llvm::ArrayRef<clang::Expr*>, clang::OMPVarListLocTy const&, llvm::ArrayRef<clang::Expr*>)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildOMPFromClause(llvm::ArrayRef<clang::OpenMPMotionModifierKind>, llvm::ArrayRef<clang::SourceLocation>, clang::CXXScopeSpec&, clang::DeclarationNameInfo&, clang::SourceLocation, llvm::ArrayRef<clang::Expr*>, clang::OMPVarListLocTy const&, llvm::ArrayRef<clang::Expr*>)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildOMPFromClause(llvm::ArrayRef<clang::OpenMPMotionModifierKind>, llvm::ArrayRef<clang::SourceLocation>, clang::CXXScopeSpec&, clang::DeclarationNameInfo&, clang::SourceLocation, llvm::ArrayRef<clang::Expr*>, clang::OMPVarListLocTy const&, llvm::ArrayRef<clang::Expr*>)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildOMPFromClause(llvm::ArrayRef<clang::OpenMPMotionModifierKind>, llvm::ArrayRef<clang::SourceLocation>, clang::CXXScopeSpec&, clang::DeclarationNameInfo&, clang::SourceLocation, llvm::ArrayRef<clang::Expr*>, clang::OMPVarListLocTy const&, llvm::ArrayRef<clang::Expr*>)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildOMPFromClause(llvm::ArrayRef<clang::OpenMPMotionModifierKind>, llvm::ArrayRef<clang::SourceLocation>, clang::CXXScopeSpec&, clang::DeclarationNameInfo&, clang::SourceLocation, llvm::ArrayRef<clang::Expr*>, clang::OMPVarListLocTy const&, llvm::ArrayRef<clang::Expr*>)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildOMPFromClause(llvm::ArrayRef<clang::OpenMPMotionModifierKind>, llvm::ArrayRef<clang::SourceLocation>, clang::CXXScopeSpec&, clang::DeclarationNameInfo&, clang::SourceLocation, llvm::ArrayRef<clang::Expr*>, clang::OMPVarListLocTy const&, llvm::ArrayRef<clang::Expr*>)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildOMPFromClause(llvm::ArrayRef<clang::OpenMPMotionModifierKind>, llvm::ArrayRef<clang::SourceLocation>, clang::CXXScopeSpec&, clang::DeclarationNameInfo&, clang::SourceLocation, llvm::ArrayRef<clang::Expr*>, clang::OMPVarListLocTy const&, llvm::ArrayRef<clang::Expr*>)
Line
Count
Source
2036
374
                       ArrayRef<Expr *> UnresolvedMappers) {
2037
374
    return getSema().ActOnOpenMPFromClause(
2038
374
        MotionModifiers, MotionModifiersLoc, MapperIdScopeSpec, MapperId,
2039
374
        ColonLoc, VarList, Locs, UnresolvedMappers);
2040
374
  }
2041
2042
  /// Build a new OpenMP 'use_device_ptr' clause.
2043
  ///
2044
  /// By default, performs semantic analysis to build the new OpenMP clause.
2045
  /// Subclasses may override this routine to provide different behavior.
2046
  OMPClause *RebuildOMPUseDevicePtrClause(ArrayRef<Expr *> VarList,
2047
196
                                          const OMPVarListLocTy &Locs) {
2048
196
    return getSema().ActOnOpenMPUseDevicePtrClause(VarList, Locs);
2049
196
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildOMPUseDevicePtrClause(llvm::ArrayRef<clang::Expr*>, clang::OMPVarListLocTy const&)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildOMPUseDevicePtrClause(llvm::ArrayRef<clang::Expr*>, clang::OMPVarListLocTy const&)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildOMPUseDevicePtrClause(llvm::ArrayRef<clang::Expr*>, clang::OMPVarListLocTy const&)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildOMPUseDevicePtrClause(llvm::ArrayRef<clang::Expr*>, clang::OMPVarListLocTy const&)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildOMPUseDevicePtrClause(llvm::ArrayRef<clang::Expr*>, clang::OMPVarListLocTy const&)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildOMPUseDevicePtrClause(llvm::ArrayRef<clang::Expr*>, clang::OMPVarListLocTy const&)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildOMPUseDevicePtrClause(llvm::ArrayRef<clang::Expr*>, clang::OMPVarListLocTy const&)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildOMPUseDevicePtrClause(llvm::ArrayRef<clang::Expr*>, clang::OMPVarListLocTy const&)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildOMPUseDevicePtrClause(llvm::ArrayRef<clang::Expr*>, clang::OMPVarListLocTy const&)
Line
Count
Source
2047
196
                                          const OMPVarListLocTy &Locs) {
2048
196
    return getSema().ActOnOpenMPUseDevicePtrClause(VarList, Locs);
2049
196
  }
2050
2051
  /// Build a new OpenMP 'use_device_addr' clause.
2052
  ///
2053
  /// By default, performs semantic analysis to build the new OpenMP clause.
2054
  /// Subclasses may override this routine to provide different behavior.
2055
  OMPClause *RebuildOMPUseDeviceAddrClause(ArrayRef<Expr *> VarList,
2056
22
                                           const OMPVarListLocTy &Locs) {
2057
22
    return getSema().ActOnOpenMPUseDeviceAddrClause(VarList, Locs);
2058
22
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildOMPUseDeviceAddrClause(llvm::ArrayRef<clang::Expr*>, clang::OMPVarListLocTy const&)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildOMPUseDeviceAddrClause(llvm::ArrayRef<clang::Expr*>, clang::OMPVarListLocTy const&)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildOMPUseDeviceAddrClause(llvm::ArrayRef<clang::Expr*>, clang::OMPVarListLocTy const&)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildOMPUseDeviceAddrClause(llvm::ArrayRef<clang::Expr*>, clang::OMPVarListLocTy const&)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildOMPUseDeviceAddrClause(llvm::ArrayRef<clang::Expr*>, clang::OMPVarListLocTy const&)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildOMPUseDeviceAddrClause(llvm::ArrayRef<clang::Expr*>, clang::OMPVarListLocTy const&)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildOMPUseDeviceAddrClause(llvm::ArrayRef<clang::Expr*>, clang::OMPVarListLocTy const&)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildOMPUseDeviceAddrClause(llvm::ArrayRef<clang::Expr*>, clang::OMPVarListLocTy const&)
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildOMPUseDeviceAddrClause(llvm::ArrayRef<clang::Expr*>, clang::OMPVarListLocTy const&)
Line
Count
Source
2056
22
                                           const OMPVarListLocTy &Locs) {
2057
22
    return getSema().ActOnOpenMPUseDeviceAddrClause(VarList, Locs);
2058
22
  }
2059
2060
  /// Build a new OpenMP 'is_device_ptr' clause.
2061
  ///
2062
  /// By default, performs semantic analysis to build the new OpenMP clause.
2063
  /// Subclasses may override this routine to provide different behavior.
2064
  OMPClause *RebuildOMPIsDevicePtrClause(ArrayRef<Expr *> VarList,
2065
1.06k
                                         const OMPVarListLocTy &Locs) {
2066
1.06k
    return getSema().ActOnOpenMPIsDevicePtrClause(VarList, Locs);
2067
1.06k
  }
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<RemoveNestedImmediateInvocation(clang::Sema&, clang::Sema::ExpressionEvaluationContextRecord&, std::__1::reverse_iterator<llvm::PointerIntPair<clang::ConstantExpr*, 1u, unsigned int, llvm::PointerLikeTypeTraits<clang::ConstantExpr*>, llvm::PointerIntPairInfo<clang::ConstantExpr*, 1u, llvm::PointerLikeTypeTraits<clang::ConstantExpr*> > >*>)::ComplexRemove>::RebuildOMPIsDevicePtrClause(llvm::ArrayRef<clang::Expr*>, clang::OMPVarListLocTy const&)
Unexecuted instantiation: SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::RebuildOMPIsDevicePtrClause(llvm::ArrayRef<clang::Expr*>, clang::OMPVarListLocTy const&)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildOMPIsDevicePtrClause(llvm::ArrayRef<clang::Expr*>, clang::OMPVarListLocTy const&)
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::RebuildOMPIsDevicePtrClause(llvm::ArrayRef<clang::Expr*>, clang::OMPVarListLocTy const&)
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::RebuildOMPIsDevicePtrClause(llvm::ArrayRef<clang::Expr*>, clang::OMPVarListLocTy const&)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::RebuildOMPIsDevicePtrClause(llvm::ArrayRef<clang::Expr*>, clang::OMPVarListLocTy const&)
Unexecuted instantiation: SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildOMPIsDevicePtrClause(llvm::ArrayRef<clang::Expr*>, clang::OMPVarListLocTy const&)
Unexecuted instantiation: SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::Rebu