Coverage Report

Created: 2021-01-26 06:56

/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
542
    ForgetPartiallySubstitutedPackRAII(Derived &Self) : Self(Self) {
111
542
      Old = Self.ForgetPartiallySubstitutedPack();
112
542
    }
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
542
    ForgetPartiallySubstitutedPackRAII(Derived &Self) : Self(Self) {
111
542
      Old = Self.ForgetPartiallySubstitutedPack();
112
542
    }
113
114
542
    ~ForgetPartiallySubstitutedPackRAII() {
115
542
      Self.RememberPartiallySubstitutedPack(Old);
116
542
    }
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
542
    ~ForgetPartiallySubstitutedPackRAII() {
115
542
      Self.RememberPartiallySubstitutedPack(Old);
116
542
    }
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.47M
  TreeTransform(Sema &SemaRef) : SemaRef(SemaRef) { }
SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::TreeTransform(clang::Sema&)
Line
Count
Source
129
489
  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.94k
  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
452
  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.26k
  TreeTransform(Sema &SemaRef) : SemaRef(SemaRef) { }
SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::TreeTransform(clang::Sema&)
Line
Count
Source
129
291k
  TreeTransform(Sema &SemaRef) : SemaRef(SemaRef) { }
SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::TreeTransform(clang::Sema&)
Line
Count
Source
129
52.5k
  TreeTransform(Sema &SemaRef) : SemaRef(SemaRef) { }
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::TreeTransform(clang::Sema&)
Line
Count
Source
129
9.12M
  TreeTransform(Sema &SemaRef) : SemaRef(SemaRef) { }
130
131
  /// Retrieves a reference to the derived class.
132
180M
  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.36k
  Derived &getDerived() { return static_cast<Derived&>(*this); }
SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::getDerived()
Line
Count
Source
132
12.4k
  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
3.52k
  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
79.3k
  Derived &getDerived() { return static_cast<Derived&>(*this); }
SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::getDerived()
Line
Count
Source
132
10.1M
  Derived &getDerived() { return static_cast<Derived&>(*this); }
SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::getDerived()
Line
Count
Source
132
190k
  Derived &getDerived() { return static_cast<Derived&>(*this); }
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::getDerived()
Line
Count
Source
132
169M
  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
146
  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
146
  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.9M
  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.41k
  Sema &getSema() const { return SemaRef; }
SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::getSema() const
Line
Count
Source
144
1.21k
  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
776
  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
906
  Sema &getSema() const { return SemaRef; }
SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::getSema() const
Line
Count
Source
144
232k
  Sema &getSema() const { return SemaRef; }
SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::getSema() const
Line
Count
Source
144
9.03k
  Sema &getSema() const { return SemaRef; }
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::getSema() const
Line
Count
Source
144
23.7M
  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.6M
  bool AlwaysRebuild() { return SemaRef.ArgumentPackSubstitutionIndex != -1; }
SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::AlwaysRebuild()
Line
Count
Source
155
976
  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
431
  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
3.97k
  bool AlwaysRebuild() { return SemaRef.ArgumentPackSubstitutionIndex != -1; }
SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::AlwaysRebuild()
Line
Count
Source
155
455k
  bool AlwaysRebuild() { return SemaRef.ArgumentPackSubstitutionIndex != -1; }
SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::AlwaysRebuild()
Line
Count
Source
155
7.31k
  bool AlwaysRebuild() { return SemaRef.ArgumentPackSubstitutionIndex != -1; }
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::AlwaysRebuild()
Line
Count
Source
155
12.1M
  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
2.46k
  bool ReplacingOriginal() { return false; }
SemaExprCXX.cpp:clang::TreeTransform<clang::Sema::CorrectDelayedTyposInExpr(clang::Expr*, clang::VarDecl*, bool, llvm::function_ref<clang::ActionResult<clang::Expr*, true> (clang::Expr*)>)::TyposReplace>::ReplacingOriginal()
Line
Count
Source
160
1
  bool ReplacingOriginal() { return false; }
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
2.46k
  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.39k
  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.39k
  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
24.2k
  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
131
  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
47
  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
5.24k
  SourceLocation getBaseLocation() { return SourceLocation(); }
SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::getBaseLocation()
Line
Count
Source
175
18.5k
  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
37.1k
  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
202
  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
71
  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
11.2k
  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
25.2k
  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
20.6k
  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
172
  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
59
  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
10.4k
  void setBase(SourceLocation Loc, DeclarationName Entity) { }
SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::setBase(clang::SourceLocation, clang::DeclarationName)
Line
Count
Source
189
9.61k
  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.47M
                  DeclarationName Entity) : Self(Self) {
201
9.47M
      OldLocation = Self.getDerived().getBaseLocation();
202
9.47M
      OldEntity = Self.getDerived().getBaseEntity();
203
204
9.47M
      if (Location.isValid())
205
9.43M
        Self.getDerived().setBase(Location, Entity);
206
9.47M
    }
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
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
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
101
                  DeclarationName Entity) : Self(Self) {
201
101
      OldLocation = Self.getDerived().getBaseLocation();
202
101
      OldEntity = Self.getDerived().getBaseEntity();
203
204
101
      if (Location.isValid())
205
71
        Self.getDerived().setBase(Location, Entity);
206
101
    }
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
35
                  DeclarationName Entity) : Self(Self) {
201
35
      OldLocation = Self.getDerived().getBaseLocation();
202
35
      OldEntity = Self.getDerived().getBaseEntity();
203
204
35
      if (Location.isValid())
205
24
        Self.getDerived().setBase(Location, Entity);
206
35
    }
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
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
5.24k
                  DeclarationName Entity) : Self(Self) {
201
5.24k
      OldLocation = Self.getDerived().getBaseLocation();
202
5.24k
      OldEntity = Self.getDerived().getBaseEntity();
203
204
5.24k
      if (Location.isValid())
205
5.24k
        Self.getDerived().setBase(Location, Entity);
206
5.24k
    }
SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::TemporaryBase::TemporaryBase(clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>&, clang::SourceLocation, clang::DeclarationName)
Line
Count
Source
200
682k
                  DeclarationName Entity) : Self(Self) {
201
682k
      OldLocation = Self.getDerived().getBaseLocation();
202
682k
      OldEntity = Self.getDerived().getBaseEntity();
203
204
682k
      if (Location.isValid())
205
682k
        Self.getDerived().setBase(Location, Entity);
206
682k
    }
SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::TemporaryBase::TemporaryBase(clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>&, clang::SourceLocation, clang::DeclarationName)
Line
Count
Source
200
9.32k
                  DeclarationName Entity) : Self(Self) {
201
9.32k
      OldLocation = Self.getDerived().getBaseLocation();
202
9.32k
      OldEntity = Self.getDerived().getBaseEntity();
203
204
9.32k
      if (Location.isValid())
205
287
        Self.getDerived().setBase(Location, Entity);
206
9.32k
    }
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::TemporaryBase::TemporaryBase(clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>&, clang::SourceLocation, clang::DeclarationName)
Line
Count
Source
200
8.77M
                  DeclarationName Entity) : Self(Self) {
201
8.77M
      OldLocation = Self.getDerived().getBaseLocation();
202
8.77M
      OldEntity = Self.getDerived().getBaseEntity();
203
204
8.77M
      if (Location.isValid())
205
8.74M
        Self.getDerived().setBase(Location, Entity);
206
8.77M
    }
207
208
9.47M
    ~TemporaryBase() {
209
9.47M
      Self.getDerived().setBase(OldLocation, OldEntity);
210
9.47M
    }
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
101
    ~TemporaryBase() {
209
101
      Self.getDerived().setBase(OldLocation, OldEntity);
210
101
    }
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
35
    ~TemporaryBase() {
209
35
      Self.getDerived().setBase(OldLocation, OldEntity);
210
35
    }
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
5.24k
    ~TemporaryBase() {
209
5.24k
      Self.getDerived().setBase(OldLocation, OldEntity);
210
5.24k
    }
SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::TemporaryBase::~TemporaryBase()
Line
Count
Source
208
682k
    ~TemporaryBase() {
209
682k
      Self.getDerived().setBase(OldLocation, OldEntity);
210
682k
    }
SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::TemporaryBase::~TemporaryBase()
Line
Count
Source
208
9.32k
    ~TemporaryBase() {
209
9.32k
      Self.getDerived().setBase(OldLocation, OldEntity);
210
9.32k
    }
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::TemporaryBase::~TemporaryBase()
Line
Count
Source
208
8.77M
    ~TemporaryBase() {
209
8.77M
      Self.getDerived().setBase(OldLocation, OldEntity);
210
8.77M
    }
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
26.5k
  bool AlreadyTransformed(QualType T) {
221
26.5k
    return T.isNull();
222
26.5k
  }
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
205
  bool AlreadyTransformed(QualType T) {
221
205
    return T.isNull();
222
205
  }
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
70
  bool AlreadyTransformed(QualType T) {
221
70
    return T.isNull();
222
70
  }
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
7.86k
  bool AlreadyTransformed(QualType T) {
221
7.86k
    return T.isNull();
222
7.86k
  }
SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::AlreadyTransformed(clang::QualType)
Line
Count
Source
220
18.1k
  bool AlreadyTransformed(QualType T) {
221
18.1k
    return T.isNull();
222
18.1k
  }
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
367k
  bool DropCallArgument(Expr *E) {
239
367k
    return E->isDefaultArgument();
240
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>::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
432
  bool DropCallArgument(Expr *E) {
239
432
    return E->isDefaultArgument();
240
432
  }
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
134
  bool DropCallArgument(Expr *E) {
239
134
    return E->isDefaultArgument();
240
134
  }
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
366k
  bool DropCallArgument(Expr *E) {
239
366k
    return E->isDefaultArgument();
240
366k
  }
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
25.0k
                               Optional<unsigned> &NumExpansions) {
285
25.0k
    ShouldExpand = false;
286
25.0k
    return false;
287
25.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>::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
24.9k
                               Optional<unsigned> &NumExpansions) {
285
24.9k
    ShouldExpand = false;
286
24.9k
    return false;
287
24.9k
  }
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>&)
Line
Count
Source
284
12
                               Optional<unsigned> &NumExpansions) {
285
12
    ShouldExpand = false;
286
12
    return false;
287
12
  }
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
1
      return Known->second;
453
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
454
224
    return D;
455
224
  }
SemaExpr.cpp:clang::TreeTransform<(anonymous namespace)::TransformToPE>::TransformDecl(clang::SourceLocation, clang::Decl*)
Line
Count
Source
448
577
  Decl *TransformDecl(SourceLocation Loc, Decl *D) {
449
577
    llvm::DenseMap<Decl *, Decl *>::iterator Known
450
577
      = TransformedLocalDecls.find(D);
451
577
    if (Known != TransformedLocalDecls.end())
452
0
      return Known->second;
453
454
577
    return D;
455
577
  }
SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::TransformDecl(clang::SourceLocation, clang::Decl*)
Line
Count
Source
448
606
  Decl *TransformDecl(SourceLocation Loc, Decl *D) {
449
606
    llvm::DenseMap<Decl *, Decl *>::iterator Known
450
606
      = TransformedLocalDecls.find(D);
451
606
    if (Known != TransformedLocalDecls.end())
452
0
      return Known->second;
453
454
606
    return D;
455
606
  }
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
202
  Decl *TransformDecl(SourceLocation Loc, Decl *D) {
449
202
    llvm::DenseMap<Decl *, Decl *>::iterator Known
450
202
      = TransformedLocalDecls.find(D);
451
202
    if (Known != TransformedLocalDecls.end())
452
1
      return Known->second;
453
454
201
    return D;
455
201
  }
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
454
72
    return D;
455
72
  }
SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::TransformDecl(clang::SourceLocation, clang::Decl*)
Line
Count
Source
448
2.42k
  Decl *TransformDecl(SourceLocation Loc, Decl *D) {
449
2.42k
    llvm::DenseMap<Decl *, Decl *>::iterator Known
450
2.42k
      = TransformedLocalDecls.find(D);
451
2.42k
    if (Known != TransformedLocalDecls.end())
452
0
      return Known->second;
453
454
2.42k
    return D;
455
2.42k
  }
SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::TransformDecl(clang::SourceLocation, clang::Decl*)
Line
Count
Source
448
363k
  Decl *TransformDecl(SourceLocation Loc, Decl *D) {
449
363k
    llvm::DenseMap<Decl *, Decl *>::iterator Known
450
363k
      = TransformedLocalDecls.find(D);
451
363k
    if (Known != TransformedLocalDecls.end())
452
0
      return Known->second;
453
454
363k
    return D;
455
363k
  }
SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::TransformDecl(clang::SourceLocation, clang::Decl*)
Line
Count
Source
448
255
  Decl *TransformDecl(SourceLocation Loc, Decl *D) {
449
255
    llvm::DenseMap<Decl *, Decl *>::iterator Known
450
255
      = TransformedLocalDecls.find(D);
451
255
    if (Known != TransformedLocalDecls.end())
452
0
      return Known->second;
453
454
255
    return D;
455
255
  }
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
8
  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) { }
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*)
Line
Count
Source
470
1
  void transformAttrs(Decl *Old, Decl *New) { }
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
13.4k
  void transformedLocalDecl(Decl *Old, ArrayRef<Decl *> New) {
480
13.4k
    assert(New.size() == 1 &&
481
13.4k
           "must override transformedLocalDecl if performing pack expansion");
482
13.4k
    TransformedLocalDecls[Old] = New.front();
483
13.4k
  }
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
15
  void transformedLocalDecl(Decl *Old, ArrayRef<Decl *> New) {
480
15
    assert(New.size() == 1 &&
481
15
           "must override transformedLocalDecl if performing pack expansion");
482
15
    TransformedLocalDecls[Old] = New.front();
483
15
  }
SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::transformedLocalDecl(clang::Decl*, llvm::ArrayRef<clang::Decl*>)
Line
Count
Source
479
2
  void transformedLocalDecl(Decl *Old, ArrayRef<Decl *> New) {
480
2
    assert(New.size() == 1 &&
481
2
           "must override transformedLocalDecl if performing pack expansion");
482
2
    TransformedLocalDecls[Old] = New.front();
483
2
  }
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*>)
Line
Count
Source
479
4
  void transformedLocalDecl(Decl *Old, ArrayRef<Decl *> New) {
480
4
    assert(New.size() == 1 &&
481
4
           "must override transformedLocalDecl if performing pack expansion");
482
4
    TransformedLocalDecls[Old] = New.front();
483
4
  }
Unexecuted instantiation: SemaOpenMP.cpp:clang::TreeTransform<(anonymous namespace)::TransformExprToCaptures>::transformedLocalDecl(clang::Decl*, llvm::ArrayRef<clang::Decl*>)
SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::ExtractTypeForDeductionGuide>::transformedLocalDecl(clang::Decl*, llvm::ArrayRef<clang::Decl*>)
Line
Count
Source
479
2
  void transformedLocalDecl(Decl *Old, ArrayRef<Decl *> New) {
480
2
    assert(New.size() == 1 &&
481
2
           "must override transformedLocalDecl if performing pack expansion");
482
2
    TransformedLocalDecls[Old] = New.front();
483
2
  }
SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::transformedLocalDecl(clang::Decl*, llvm::ArrayRef<clang::Decl*>)
Line
Count
Source
479
13.3k
  void transformedLocalDecl(Decl *Old, ArrayRef<Decl *> New) {
480
13.3k
    assert(New.size() == 1 &&
481
13.3k
           "must override transformedLocalDecl if performing pack expansion");
482
13.3k
    TransformedLocalDecls[Old] = New.front();
483
13.3k
  }
SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::transformedLocalDecl(clang::Decl*, llvm::ArrayRef<clang::Decl*>)
Line
Count
Source
479
47
  void transformedLocalDecl(Decl *Old, ArrayRef<Decl *> New) {
480
47
    assert(New.size() == 1 &&
481
47
           "must override transformedLocalDecl if performing pack expansion");
482
47
    TransformedLocalDecls[Old] = New.front();
483
47
  }
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
140
  NamedDecl *TransformFirstQualifierInScope(NamedDecl *D, SourceLocation Loc) {
503
140
    return cast_or_null<NamedDecl>(getDerived().TransformDecl(Loc, D));
504
140
  }
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
106
  NamedDecl *TransformFirstQualifierInScope(NamedDecl *D, SourceLocation Loc) {
503
106
    return cast_or_null<NamedDecl>(getDerived().TransformDecl(Loc, D));
504
106
  }
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
34
  NamedDecl *TransformFirstQualifierInScope(NamedDecl *D, SourceLocation Loc) {
503
34
    return cast_or_null<NamedDecl>(getDerived().TransformDecl(Loc, D));
504
34
  }
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
395k
                                  bool Uneval = false) {
600
395k
    return TransformTemplateArguments(Inputs, Inputs + NumInputs, Outputs,
601
395k
                                      Uneval);
602
395k
  }
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.55k
                                  bool Uneval = false) {
600
9.55k
    return TransformTemplateArguments(Inputs, Inputs + NumInputs, Outputs,
601
9.55k
                                      Uneval);
602
9.55k
  }
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
385k
                                  bool Uneval = false) {
600
385k
    return TransformTemplateArguments(Inputs, Inputs + NumInputs, Outputs,
601
385k
                                      Uneval);
602
385k
  }
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
8
        TemplateParameterList *TPL) {
705
8
    return TPL;
706
8
  }
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*)
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*)
Line
Count
Source
704
1
        TemplateParameterList *TPL) {
705
1
    return TPL;
706
1
  }
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 GEN_CLANG_CLAUSE_CLASS
735
#define CLAUSE_CLASS(Enum, Str, Class)                                         \
736
  LLVM_ATTRIBUTE_NOINLINE                                                      \
737
  OMPClause *Transform##Class(Class *S);
738
#include "llvm/Frontend/OpenMP/OMP.inc"
739
740
  /// Build a new qualified type given its unqualified type and type location.
741
  ///
742
  /// By default, this routine adds type qualifiers only to types that can
743
  /// have qualifiers, and silently suppresses those qualifiers that are not
744
  /// permitted. Subclasses may override this routine to provide different
745
  /// behavior.
746
  QualType RebuildQualifiedType(QualType T, QualifiedTypeLoc TL);
747
748
  /// Build a new pointer type given its pointee type.
749
  ///
750
  /// By default, performs semantic analysis when building the pointer type.
751
  /// Subclasses may override this routine to provide different behavior.
752
  QualType RebuildPointerType(QualType PointeeType, SourceLocation Sigil);
753
754
  /// Build a new block pointer type given its pointee type.
755
  ///
756
  /// By default, performs semantic analysis when building the block pointer
757
  /// type. Subclasses may override this routine to provide different behavior.
758
  QualType RebuildBlockPointerType(QualType PointeeType, SourceLocation Sigil);
759
760
  /// Build a new reference type given the type it references.
761
  ///
762
  /// By default, performs semantic analysis when building the
763
  /// reference type. Subclasses may override this routine to provide
764
  /// different behavior.
765
  ///
766
  /// \param LValue whether the type was written with an lvalue sigil
767
  /// or an rvalue sigil.
768
  QualType RebuildReferenceType(QualType ReferentType,
769
                                bool LValue,
770
                                SourceLocation Sigil);
771
772
  /// Build a new member pointer type given the pointee type and the
773
  /// class type it refers into.
774
  ///
775
  /// By default, performs semantic analysis when building the member pointer
776
  /// type. Subclasses may override this routine to provide different behavior.
777
  QualType RebuildMemberPointerType(QualType PointeeType, QualType ClassType,
778
                                    SourceLocation Sigil);
779
780
  QualType RebuildObjCTypeParamType(const ObjCTypeParamDecl *Decl,
781
                                    SourceLocation ProtocolLAngleLoc,
782
                                    ArrayRef<ObjCProtocolDecl *> Protocols,
783
                                    ArrayRef<SourceLocation> ProtocolLocs,
784
                                    SourceLocation ProtocolRAngleLoc);
785
786
  /// Build an Objective-C object type.
787
  ///
788
  /// By default, performs semantic analysis when building the object type.
789
  /// Subclasses may override this routine to provide different behavior.
790
  QualType RebuildObjCObjectType(QualType BaseType,
791
                                 SourceLocation Loc,
792
                                 SourceLocation TypeArgsLAngleLoc,
793
                                 ArrayRef<TypeSourceInfo *> TypeArgs,
794
                                 SourceLocation TypeArgsRAngleLoc,
795
                                 SourceLocation ProtocolLAngleLoc,
796
                                 ArrayRef<ObjCProtocolDecl *> Protocols,
797
                                 ArrayRef<SourceLocation> ProtocolLocs,
798
                                 SourceLocation ProtocolRAngleLoc);
799
800
  /// Build a new Objective-C object pointer type given the pointee type.
801
  ///
802
  /// By default, directly builds the pointer type, with no additional semantic
803
  /// analysis.
804
  QualType RebuildObjCObjectPointerType(QualType PointeeType,
805
                                        SourceLocation Star);
806
807
  /// Build a new array type given the element type, size
808
  /// modifier, size of the array (if known), size expression, and index type
809
  /// qualifiers.
810
  ///
811
  /// By default, performs semantic analysis when building the array type.
812
  /// Subclasses may override this routine to provide different behavior.
813
  /// Also by default, all of the other Rebuild*Array
814
  QualType RebuildArrayType(QualType ElementType,
815
                            ArrayType::ArraySizeModifier SizeMod,
816
                            const llvm::APInt *Size,
817
                            Expr *SizeExpr,
818
                            unsigned IndexTypeQuals,
819
                            SourceRange BracketsRange);
820
821
  /// Build a new constant array type given the element type, size
822
  /// modifier, (known) size of the array, and index type qualifiers.
823
  ///
824
  /// By default, performs semantic analysis when building the array type.
825
  /// Subclasses may override this routine to provide different behavior.
826
  QualType RebuildConstantArrayType(QualType ElementType,
827
                                    ArrayType::ArraySizeModifier SizeMod,
828
                                    const llvm::APInt &Size,
829
                                    Expr *SizeExpr,
830
                                    unsigned IndexTypeQuals,
831
                                    SourceRange BracketsRange);
832
833
  /// Build a new incomplete array type given the element type, size
834
  /// modifier, and index type qualifiers.
835
  ///
836
  /// By default, performs semantic analysis when building the array type.
837
  /// Subclasses may override this routine to provide different behavior.
838
  QualType RebuildIncompleteArrayType(QualType ElementType,
839
                                      ArrayType::ArraySizeModifier SizeMod,
840
                                      unsigned IndexTypeQuals,
841
                                      SourceRange BracketsRange);
842
843
  /// Build a new variable-length array type given the element type,
844
  /// size modifier, size expression, and index type qualifiers.
845
  ///
846
  /// By default, performs semantic analysis when building the array type.
847
  /// Subclasses may override this routine to provide different behavior.
848
  QualType RebuildVariableArrayType(QualType ElementType,
849
                                    ArrayType::ArraySizeModifier SizeMod,
850
                                    Expr *SizeExpr,
851
                                    unsigned IndexTypeQuals,
852
                                    SourceRange BracketsRange);
853
854
  /// Build a new dependent-sized array type given the element type,
855
  /// size modifier, size expression, and index type qualifiers.
856
  ///
857
  /// By default, performs semantic analysis when building the array type.
858
  /// Subclasses may override this routine to provide different behavior.
859
  QualType RebuildDependentSizedArrayType(QualType ElementType,
860
                                          ArrayType::ArraySizeModifier SizeMod,
861
                                          Expr *SizeExpr,
862
                                          unsigned IndexTypeQuals,
863
                                          SourceRange BracketsRange);
864
865
  /// Build a new vector type given the element type and
866
  /// number of elements.
867
  ///
868
  /// By default, performs semantic analysis when building the vector type.
869
  /// Subclasses may override this routine to provide different behavior.
870
  QualType RebuildVectorType(QualType ElementType, unsigned NumElements,
871
                             VectorType::VectorKind VecKind);
872
873
  /// Build a new potentially dependently-sized extended vector type
874
  /// given the element type and number of elements.
875
  ///
876
  /// By default, performs semantic analysis when building the vector type.
877
  /// Subclasses may override this routine to provide different behavior.
878
  QualType RebuildDependentVectorType(QualType ElementType, Expr *SizeExpr,
879
                                           SourceLocation AttributeLoc,
880
                                           VectorType::VectorKind);
881
882
  /// Build a new extended vector type given the element type and
883
  /// number of elements.
884
  ///
885
  /// By default, performs semantic analysis when building the vector type.
886
  /// Subclasses may override this routine to provide different behavior.
887
  QualType RebuildExtVectorType(QualType ElementType, unsigned NumElements,
888
                                SourceLocation AttributeLoc);
889
890
  /// Build a new potentially dependently-sized extended vector type
891
  /// given the element type and number of elements.
892
  ///
893
  /// By default, performs semantic analysis when building the vector type.
894
  /// Subclasses may override this routine to provide different behavior.
895
  QualType RebuildDependentSizedExtVectorType(QualType ElementType,
896
                                              Expr *SizeExpr,
897
                                              SourceLocation AttributeLoc);
898
899
  /// Build a new matrix type given the element type and dimensions.
900
  QualType RebuildConstantMatrixType(QualType ElementType, unsigned NumRows,
901
                                     unsigned NumColumns);
902
903
  /// Build a new matrix type given the type and dependently-defined
904
  /// dimensions.
905
  QualType RebuildDependentSizedMatrixType(QualType ElementType, Expr *RowExpr,
906
                                           Expr *ColumnExpr,
907
                                           SourceLocation AttributeLoc);
908
909
  /// Build a new DependentAddressSpaceType or return the pointee
910
  /// type variable with the correct address space (retrieved from
911
  /// AddrSpaceExpr) applied to it. The former will be returned in cases
912
  /// where the address space remains dependent.
913
  ///
914
  /// By default, performs semantic analysis when building the type with address
915
  /// space applied. Subclasses may override this routine to provide different
916
  /// behavior.
917
  QualType RebuildDependentAddressSpaceType(QualType PointeeType,
918
                                            Expr *AddrSpaceExpr,
919
                                            SourceLocation AttributeLoc);
920
921
  /// Build a new function type.
922
  ///
923
  /// By default, performs semantic analysis when building the function type.
924
  /// Subclasses may override this routine to provide different behavior.
925
  QualType RebuildFunctionProtoType(QualType T,
926
                                    MutableArrayRef<QualType> ParamTypes,
927
                                    const FunctionProtoType::ExtProtoInfo &EPI);
928
929
  /// Build a new unprototyped function type.
930
  QualType RebuildFunctionNoProtoType(QualType ResultType);
931
932
  /// Rebuild an unresolved typename type, given the decl that
933
  /// the UnresolvedUsingTypenameDecl was transformed to.
934
  QualType RebuildUnresolvedUsingType(SourceLocation NameLoc, Decl *D);
935
936
  /// Build a new typedef type.
937
1.07M
  QualType RebuildTypedefType(TypedefNameDecl *Typedef) {
938
1.07M
    return SemaRef.Context.getTypeDeclType(Typedef);
939
1.07M
  }
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
937
1
  QualType RebuildTypedefType(TypedefNameDecl *Typedef) {
938
1
    return SemaRef.Context.getTypeDeclType(Typedef);
939
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
937
1.07M
  QualType RebuildTypedefType(TypedefNameDecl *Typedef) {
938
1.07M
    return SemaRef.Context.getTypeDeclType(Typedef);
939
1.07M
  }
940
941
  /// Build a new MacroDefined type.
942
  QualType RebuildMacroQualifiedType(QualType T,
943
23
                                     const IdentifierInfo *MacroII) {
944
23
    return SemaRef.Context.getMacroQualifiedType(T, MacroII);
945
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
943
8
                                     const IdentifierInfo *MacroII) {
944
8
    return SemaRef.Context.getMacroQualifiedType(T, MacroII);
945
8
  }
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildMacroQualifiedType(clang::QualType, clang::IdentifierInfo const*)
Line
Count
Source
943
15
                                     const IdentifierInfo *MacroII) {
944
15
    return SemaRef.Context.getMacroQualifiedType(T, MacroII);
945
15
  }
946
947
  /// Build a new class/struct/union type.
948
36.5k
  QualType RebuildRecordType(RecordDecl *Record) {
949
36.5k
    return SemaRef.Context.getTypeDeclType(Record);
950
36.5k
  }
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
948
32
  QualType RebuildRecordType(RecordDecl *Record) {
949
32
    return SemaRef.Context.getTypeDeclType(Record);
950
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
948
36.5k
  QualType RebuildRecordType(RecordDecl *Record) {
949
36.5k
    return SemaRef.Context.getTypeDeclType(Record);
950
36.5k
  }
951
952
  /// Build a new Enum type.
953
103
  QualType RebuildEnumType(EnumDecl *Enum) {
954
103
    return SemaRef.Context.getTypeDeclType(Enum);
955
103
  }
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
953
103
  QualType RebuildEnumType(EnumDecl *Enum) {
954
103
    return SemaRef.Context.getTypeDeclType(Enum);
955
103
  }
956
957
  /// Build a new typeof(expr) type.
958
  ///
959
  /// By default, performs semantic analysis when building the typeof type.
960
  /// Subclasses may override this routine to provide different behavior.
961
  QualType RebuildTypeOfExprType(Expr *Underlying, SourceLocation Loc);
962
963
  /// Build a new typeof(type) type.
964
  ///
965
  /// By default, builds a new TypeOfType with the given underlying type.
966
  QualType RebuildTypeOfType(QualType Underlying);
967
968
  /// Build a new unary transform type.
969
  QualType RebuildUnaryTransformType(QualType BaseType,
970
                                     UnaryTransformType::UTTKind UKind,
971
                                     SourceLocation Loc);
972
973
  /// Build a new C++11 decltype type.
974
  ///
975
  /// By default, performs semantic analysis when building the decltype type.
976
  /// Subclasses may override this routine to provide different behavior.
977
  QualType RebuildDecltypeType(Expr *Underlying, SourceLocation Loc);
978
979
  /// Build a new C++11 auto type.
980
  ///
981
  /// By default, builds a new AutoType with the given deduced type.
982
  QualType RebuildAutoType(QualType Deduced, AutoTypeKeyword Keyword,
983
                           ConceptDecl *TypeConstraintConcept,
984
2.45k
                           ArrayRef<TemplateArgument> TypeConstraintArgs) {
985
    // Note, IsDependent is always false here: we implicitly convert an 'auto'
986
    // which has been deduced to a dependent type into an undeduced 'auto', so
987
    // that we'll retry deduction after the transformation.
988
2.45k
    return SemaRef.Context.getAutoType(Deduced, Keyword,
989
2.45k
                                       /*IsDependent*/ false, /*IsPack=*/false,
990
2.45k
                                       TypeConstraintConcept,
991
2.45k
                                       TypeConstraintArgs);
992
2.45k
  }
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
984
9
                           ArrayRef<TemplateArgument> TypeConstraintArgs) {
985
    // Note, IsDependent is always false here: we implicitly convert an 'auto'
986
    // which has been deduced to a dependent type into an undeduced 'auto', so
987
    // that we'll retry deduction after the transformation.
988
9
    return SemaRef.Context.getAutoType(Deduced, Keyword,
989
9
                                       /*IsDependent*/ false, /*IsPack=*/false,
990
9
                                       TypeConstraintConcept,
991
9
                                       TypeConstraintArgs);
992
9
  }
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildAutoType(clang::QualType, clang::AutoTypeKeyword, clang::ConceptDecl*, llvm::ArrayRef<clang::TemplateArgument>)
Line
Count
Source
984
2.44k
                           ArrayRef<TemplateArgument> TypeConstraintArgs) {
985
    // Note, IsDependent is always false here: we implicitly convert an 'auto'
986
    // which has been deduced to a dependent type into an undeduced 'auto', so
987
    // that we'll retry deduction after the transformation.
988
2.44k
    return SemaRef.Context.getAutoType(Deduced, Keyword,
989
2.44k
                                       /*IsDependent*/ false, /*IsPack=*/false,
990
2.44k
                                       TypeConstraintConcept,
991
2.44k
                                       TypeConstraintArgs);
992
2.44k
  }
993
994
  /// By default, builds a new DeducedTemplateSpecializationType with the given
995
  /// deduced type.
996
  QualType RebuildDeducedTemplateSpecializationType(TemplateName Template,
997
69
      QualType Deduced) {
998
69
    return SemaRef.Context.getDeducedTemplateSpecializationType(
999
69
        Template, Deduced, /*IsDependent*/ false);
1000
69
  }
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
997
69
      QualType Deduced) {
998
69
    return SemaRef.Context.getDeducedTemplateSpecializationType(
999
69
        Template, Deduced, /*IsDependent*/ false);
1000
69
  }
1001
1002
  /// Build a new template specialization type.
1003
  ///
1004
  /// By default, performs semantic analysis when building the template
1005
  /// specialization type. Subclasses may override this routine to provide
1006
  /// different behavior.
1007
  QualType RebuildTemplateSpecializationType(TemplateName Template,
1008
                                             SourceLocation TemplateLoc,
1009
                                             TemplateArgumentListInfo &Args);
1010
1011
  /// Build a new parenthesized type.
1012
  ///
1013
  /// By default, builds a new ParenType type from the inner type.
1014
  /// Subclasses may override this routine to provide different behavior.
1015
4.88k
  QualType RebuildParenType(QualType InnerType) {
1016
4.88k
    return SemaRef.BuildParenType(InnerType);
1017
4.88k
  }
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
1015
14
  QualType RebuildParenType(QualType InnerType) {
1016
14
    return SemaRef.BuildParenType(InnerType);
1017
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
1015
120
  QualType RebuildParenType(QualType InnerType) {
1016
120
    return SemaRef.BuildParenType(InnerType);
1017
120
  }
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildParenType(clang::QualType)
Line
Count
Source
1015
4.75k
  QualType RebuildParenType(QualType InnerType) {
1016
4.75k
    return SemaRef.BuildParenType(InnerType);
1017
4.75k
  }
1018
1019
  /// Build a new qualified name type.
1020
  ///
1021
  /// By default, builds a new ElaboratedType type from the keyword,
1022
  /// the nested-name-specifier and the named type.
1023
  /// Subclasses may override this routine to provide different behavior.
1024
  QualType RebuildElaboratedType(SourceLocation KeywordLoc,
1025
                                 ElaboratedTypeKeyword Keyword,
1026
                                 NestedNameSpecifierLoc QualifierLoc,
1027
25.3k
                                 QualType Named) {
1028
25.3k
    return SemaRef.Context.getElaboratedType(Keyword,
1029
25.3k
                                         QualifierLoc.getNestedNameSpecifier(),
1030
25.3k
                                             Named);
1031
25.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>::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
1027
2
                                 QualType Named) {
1028
2
    return SemaRef.Context.getElaboratedType(Keyword,
1029
2
                                         QualifierLoc.getNestedNameSpecifier(),
1030
2
                                             Named);
1031
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
1027
9
                                 QualType Named) {
1028
9
    return SemaRef.Context.getElaboratedType(Keyword,
1029
9
                                         QualifierLoc.getNestedNameSpecifier(),
1030
9
                                             Named);
1031
9
  }
SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildElaboratedType(clang::SourceLocation, clang::ElaboratedTypeKeyword, clang::NestedNameSpecifierLoc, clang::QualType)
Line
Count
Source
1027
6
                                 QualType Named) {
1028
6
    return SemaRef.Context.getElaboratedType(Keyword,
1029
6
                                         QualifierLoc.getNestedNameSpecifier(),
1030
6
                                             Named);
1031
6
  }
SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildElaboratedType(clang::SourceLocation, clang::ElaboratedTypeKeyword, clang::NestedNameSpecifierLoc, clang::QualType)
Line
Count
Source
1027
34
                                 QualType Named) {
1028
34
    return SemaRef.Context.getElaboratedType(Keyword,
1029
34
                                         QualifierLoc.getNestedNameSpecifier(),
1030
34
                                             Named);
1031
34
  }
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildElaboratedType(clang::SourceLocation, clang::ElaboratedTypeKeyword, clang::NestedNameSpecifierLoc, clang::QualType)
Line
Count
Source
1027
25.3k
                                 QualType Named) {
1028
25.3k
    return SemaRef.Context.getElaboratedType(Keyword,
1029
25.3k
                                         QualifierLoc.getNestedNameSpecifier(),
1030
25.3k
                                             Named);
1031
25.3k
  }
1032
1033
  /// Build a new typename type that refers to a template-id.
1034
  ///
1035
  /// By default, builds a new DependentNameType type from the
1036
  /// nested-name-specifier and the given type. Subclasses may override
1037
  /// this routine to provide different behavior.
1038
  QualType RebuildDependentTemplateSpecializationType(
1039
                                          ElaboratedTypeKeyword Keyword,
1040
                                          NestedNameSpecifierLoc QualifierLoc,
1041
                                          SourceLocation TemplateKWLoc,
1042
                                          const IdentifierInfo *Name,
1043
                                          SourceLocation NameLoc,
1044
                                          TemplateArgumentListInfo &Args,
1045
143k
                                          bool AllowInjectedClassName) {
1046
    // Rebuild the template name.
1047
    // TODO: avoid TemplateName abstraction
1048
143k
    CXXScopeSpec SS;
1049
143k
    SS.Adopt(QualifierLoc);
1050
143k
    TemplateName InstName = getDerived().RebuildTemplateName(
1051
143k
        SS, TemplateKWLoc, *Name, NameLoc, QualType(), nullptr,
1052
143k
        AllowInjectedClassName);
1053
1054
143k
    if (InstName.isNull())
1055
14.7k
      return QualType();
1056
1057
    // If it's still dependent, make a dependent specialization.
1058
128k
    if (InstName.getAsDependentTemplateName())
1059
100k
      return SemaRef.Context.getDependentTemplateSpecializationType(Keyword,
1060
100k
                                          QualifierLoc.getNestedNameSpecifier(),
1061
100k
                                                                    Name,
1062
100k
                                                                    Args);
1063
1064
    // Otherwise, make an elaborated type wrapping a non-dependent
1065
    // specialization.
1066
28.1k
    QualType T =
1067
28.1k
    getDerived().RebuildTemplateSpecializationType(InstName, NameLoc, Args);
1068
28.1k
    if (T.isNull()) 
return QualType()13
;
1069
1070
28.1k
    if (Keyword == ETK_None && 
QualifierLoc.getNestedNameSpecifier() == nullptr10
)
1071
0
      return T;
1072
1073
28.1k
    return SemaRef.Context.getElaboratedType(Keyword,
1074
28.1k
                                       QualifierLoc.getNestedNameSpecifier(),
1075
28.1k
                                             T);
1076
28.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
1045
12
                                          bool AllowInjectedClassName) {
1046
    // Rebuild the template name.
1047
    // TODO: avoid TemplateName abstraction
1048
12
    CXXScopeSpec SS;
1049
12
    SS.Adopt(QualifierLoc);
1050
12
    TemplateName InstName = getDerived().RebuildTemplateName(
1051
12
        SS, TemplateKWLoc, *Name, NameLoc, QualType(), nullptr,
1052
12
        AllowInjectedClassName);
1053
1054
12
    if (InstName.isNull())
1055
0
      return QualType();
1056
1057
    // If it's still dependent, make a dependent specialization.
1058
12
    if (InstName.getAsDependentTemplateName())
1059
4
      return SemaRef.Context.getDependentTemplateSpecializationType(Keyword,
1060
4
                                          QualifierLoc.getNestedNameSpecifier(),
1061
4
                                                                    Name,
1062
4
                                                                    Args);
1063
1064
    // Otherwise, make an elaborated type wrapping a non-dependent
1065
    // specialization.
1066
8
    QualType T =
1067
8
    getDerived().RebuildTemplateSpecializationType(InstName, NameLoc, Args);
1068
8
    if (T.isNull()) 
return QualType()0
;
1069
1070
8
    if (Keyword == ETK_None && 
QualifierLoc.getNestedNameSpecifier() == nullptr0
)
1071
0
      return T;
1072
1073
8
    return SemaRef.Context.getElaboratedType(Keyword,
1074
8
                                       QualifierLoc.getNestedNameSpecifier(),
1075
8
                                             T);
1076
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
1045
1
                                          bool AllowInjectedClassName) {
1046
    // Rebuild the template name.
1047
    // TODO: avoid TemplateName abstraction
1048
1
    CXXScopeSpec SS;
1049
1
    SS.Adopt(QualifierLoc);
1050
1
    TemplateName InstName = getDerived().RebuildTemplateName(
1051
1
        SS, TemplateKWLoc, *Name, NameLoc, QualType(), nullptr,
1052
1
        AllowInjectedClassName);
1053
1054
1
    if (InstName.isNull())
1055
0
      return QualType();
1056
1057
    // If it's still dependent, make a dependent specialization.
1058
1
    if (InstName.getAsDependentTemplateName())
1059
1
      return SemaRef.Context.getDependentTemplateSpecializationType(Keyword,
1060
1
                                          QualifierLoc.getNestedNameSpecifier(),
1061
1
                                                                    Name,
1062
1
                                                                    Args);
1063
1064
    // Otherwise, make an elaborated type wrapping a non-dependent
1065
    // specialization.
1066
0
    QualType T =
1067
0
    getDerived().RebuildTemplateSpecializationType(InstName, NameLoc, Args);
1068
0
    if (T.isNull()) return QualType();
1069
1070
0
    if (Keyword == ETK_None && QualifierLoc.getNestedNameSpecifier() == nullptr)
1071
0
      return T;
1072
1073
0
    return SemaRef.Context.getElaboratedType(Keyword,
1074
0
                                       QualifierLoc.getNestedNameSpecifier(),
1075
0
                                             T);
1076
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
1045
143k
                                          bool AllowInjectedClassName) {
1046
    // Rebuild the template name.
1047
    // TODO: avoid TemplateName abstraction
1048
143k
    CXXScopeSpec SS;
1049
143k
    SS.Adopt(QualifierLoc);
1050
143k
    TemplateName InstName = getDerived().RebuildTemplateName(
1051
143k
        SS, TemplateKWLoc, *Name, NameLoc, QualType(), nullptr,
1052
143k
        AllowInjectedClassName);
1053
1054
143k
    if (InstName.isNull())
1055
14.7k
      return QualType();
1056
1057
    // If it's still dependent, make a dependent specialization.
1058
128k
    if (InstName.getAsDependentTemplateName())
1059
100k
      return SemaRef.Context.getDependentTemplateSpecializationType(Keyword,
1060
100k
                                          QualifierLoc.getNestedNameSpecifier(),
1061
100k
                                                                    Name,
1062
100k
                                                                    Args);
1063
1064
    // Otherwise, make an elaborated type wrapping a non-dependent
1065
    // specialization.
1066
28.1k
    QualType T =
1067
28.1k
    getDerived().RebuildTemplateSpecializationType(InstName, NameLoc, Args);
1068
28.1k
    if (T.isNull()) 
return QualType()13
;
1069
1070
28.1k
    if (Keyword == ETK_None && 
QualifierLoc.getNestedNameSpecifier() == nullptr10
)
1071
0
      return T;
1072
1073
28.1k
    return SemaRef.Context.getElaboratedType(Keyword,
1074
28.1k
                                       QualifierLoc.getNestedNameSpecifier(),
1075
28.1k
                                             T);
1076
28.1k
  }
1077
1078
  /// Build a new typename type that refers to an identifier.
1079
  ///
1080
  /// By default, performs semantic analysis when building the typename type
1081
  /// (or elaborated type). Subclasses may override this routine to provide
1082
  /// different behavior.
1083
  QualType RebuildDependentNameType(ElaboratedTypeKeyword Keyword,
1084
                                    SourceLocation KeywordLoc,
1085
                                    NestedNameSpecifierLoc QualifierLoc,
1086
                                    const IdentifierInfo *Id,
1087
                                    SourceLocation IdLoc,
1088
1.18M
                                    bool DeducedTSTContext) {
1089
1.18M
    CXXScopeSpec SS;
1090
1.18M
    SS.Adopt(QualifierLoc);
1091
1092
1.18M
    if (QualifierLoc.getNestedNameSpecifier()->isDependent()) {
1093
      // If the name is still dependent, just build a new dependent name type.
1094
416k
      if (!SemaRef.computeDeclContext(SS))
1095
386k
        return SemaRef.Context.getDependentNameType(Keyword,
1096
386k
                                          QualifierLoc.getNestedNameSpecifier(),
1097
386k
                                                    Id);
1098
798k
    }
1099
1100
798k
    if (Keyword == ETK_None || 
Keyword == ETK_Typename795k
) {
1101
798k
      return SemaRef.CheckTypenameType(Keyword, KeywordLoc, QualifierLoc,
1102
798k
                                       *Id, IdLoc, DeducedTSTContext);
1103
798k
    }
1104
1105
47
    TagTypeKind Kind = TypeWithKeyword::getTagTypeKindForKeyword(Keyword);
1106
1107
    // We had a dependent elaborated-type-specifier that has been transformed
1108
    // into a non-dependent elaborated-type-specifier. Find the tag we're
1109
    // referring to.
1110
47
    LookupResult Result(SemaRef, Id, IdLoc, Sema::LookupTagName);
1111
47
    DeclContext *DC = SemaRef.computeDeclContext(SS, false);
1112
47
    if (!DC)
1113
0
      return QualType();
1114
1115
47
    if (SemaRef.RequireCompleteDeclContext(SS, DC))
1116
2
      return QualType();
1117
1118
45
    TagDecl *Tag = nullptr;
1119
45
    SemaRef.LookupQualifiedName(Result, DC);
1120
45
    switch (Result.getResultKind()) {
1121
4
      case LookupResult::NotFound:
1122
4
      case LookupResult::NotFoundInCurrentInstantiation:
1123
4
        break;
1124
1125
41
      case LookupResult::Found:
1126
41
        Tag = Result.getAsSingle<TagDecl>();
1127
41
        break;
1128
1129
0
      case LookupResult::FoundOverloaded:
1130
0
      case LookupResult::FoundUnresolvedValue:
1131
0
        llvm_unreachable("Tag lookup cannot find non-tags");
1132
1133
0
      case LookupResult::Ambiguous:
1134
        // Let the LookupResult structure handle ambiguities.
1135
0
        return QualType();
1136
45
    }
1137
1138
45
    if (!Tag) {
1139
      // Check where the name exists but isn't a tag type and use that to emit
1140
      // better diagnostics.
1141
10
      LookupResult Result(SemaRef, Id, IdLoc, Sema::LookupTagName);
1142
10
      SemaRef.LookupQualifiedName(Result, DC);
1143
10
      switch (Result.getResultKind()) {
1144
6
        case LookupResult::Found:
1145
6
        case LookupResult::FoundOverloaded:
1146
6
        case LookupResult::FoundUnresolvedValue: {
1147
6
          NamedDecl *SomeDecl = Result.getRepresentativeDecl();
1148
6
          Sema::NonTagKind NTK = SemaRef.getNonTagTypeDeclKind(SomeDecl, Kind);
1149
6
          SemaRef.Diag(IdLoc, diag::err_tag_reference_non_tag) << SomeDecl
1150
6
                                                               << NTK << Kind;
1151
6
          SemaRef.Diag(SomeDecl->getLocation(), diag::note_declared_at);
1152
6
          break;
1153
6
        }
1154
4
        default:
1155
4
          SemaRef.Diag(IdLoc, diag::err_not_tag_in_scope)
1156
4
              << Kind << Id << DC << QualifierLoc.getSourceRange();
1157
4
          break;
1158
10
      }
1159
10
      return QualType();
1160
10
    }
1161
1162
35
    if (!SemaRef.isAcceptableTagRedeclaration(Tag, Kind, /*isDefinition*/false,
1163
4
                                              IdLoc, Id)) {
1164
4
      SemaRef.Diag(KeywordLoc, diag::err_use_with_wrong_tag) << Id;
1165
4
      SemaRef.Diag(Tag->getLocation(), diag::note_previous_use);
1166
4
      return QualType();
1167
4
    }
1168
1169
    // Build the elaborated-type-specifier type.
1170
31
    QualType T = SemaRef.Context.getTypeDeclType(Tag);
1171
31
    return SemaRef.Context.getElaboratedType(Keyword,
1172
31
                                         QualifierLoc.getNestedNameSpecifier(),
1173
31
                                             T);
1174
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
1088
1.11k
                                    bool DeducedTSTContext) {
1089
1.11k
    CXXScopeSpec SS;
1090
1.11k
    SS.Adopt(QualifierLoc);
1091
1092
1.11k
    if (QualifierLoc.getNestedNameSpecifier()->isDependent()) {
1093
      // If the name is still dependent, just build a new dependent name type.
1094
1.11k
      if (!SemaRef.computeDeclContext(SS))
1095
1.11k
        return SemaRef.Context.getDependentNameType(Keyword,
1096
1.11k
                                          QualifierLoc.getNestedNameSpecifier(),
1097
1.11k
                                                    Id);
1098
2
    }
1099
1100
2
    if (Keyword == ETK_None || Keyword == ETK_Typename) {
1101
2
      return SemaRef.CheckTypenameType(Keyword, KeywordLoc, QualifierLoc,
1102
2
                                       *Id, IdLoc, DeducedTSTContext);
1103
2
    }
1104
1105
0
    TagTypeKind Kind = TypeWithKeyword::getTagTypeKindForKeyword(Keyword);
1106
1107
    // We had a dependent elaborated-type-specifier that has been transformed
1108
    // into a non-dependent elaborated-type-specifier. Find the tag we're
1109
    // referring to.
1110
0
    LookupResult Result(SemaRef, Id, IdLoc, Sema::LookupTagName);
1111
0
    DeclContext *DC = SemaRef.computeDeclContext(SS, false);
1112
0
    if (!DC)
1113
0
      return QualType();
1114
1115
0
    if (SemaRef.RequireCompleteDeclContext(SS, DC))
1116
0
      return QualType();
1117
1118
0
    TagDecl *Tag = nullptr;
1119
0
    SemaRef.LookupQualifiedName(Result, DC);
1120
0
    switch (Result.getResultKind()) {
1121
0
      case LookupResult::NotFound:
1122
0
      case LookupResult::NotFoundInCurrentInstantiation:
1123
0
        break;
1124
1125
0
      case LookupResult::Found:
1126
0
        Tag = Result.getAsSingle<TagDecl>();
1127
0
        break;
1128
1129
0
      case LookupResult::FoundOverloaded:
1130
0
      case LookupResult::FoundUnresolvedValue:
1131
0
        llvm_unreachable("Tag lookup cannot find non-tags");
1132
1133
0
      case LookupResult::Ambiguous:
1134
        // Let the LookupResult structure handle ambiguities.
1135
0
        return QualType();
1136
0
    }
1137
1138
0
    if (!Tag) {
1139
      // Check where the name exists but isn't a tag type and use that to emit
1140
      // better diagnostics.
1141
0
      LookupResult Result(SemaRef, Id, IdLoc, Sema::LookupTagName);
1142
0
      SemaRef.LookupQualifiedName(Result, DC);
1143
0
      switch (Result.getResultKind()) {
1144
0
        case LookupResult::Found:
1145
0
        case LookupResult::FoundOverloaded:
1146
0
        case LookupResult::FoundUnresolvedValue: {
1147
0
          NamedDecl *SomeDecl = Result.getRepresentativeDecl();
1148
0
          Sema::NonTagKind NTK = SemaRef.getNonTagTypeDeclKind(SomeDecl, Kind);
1149
0
          SemaRef.Diag(IdLoc, diag::err_tag_reference_non_tag) << SomeDecl
1150
0
                                                               << NTK << Kind;
1151
0
          SemaRef.Diag(SomeDecl->getLocation(), diag::note_declared_at);
1152
0
          break;
1153
0
        }
1154
0
        default:
1155
0
          SemaRef.Diag(IdLoc, diag::err_not_tag_in_scope)
1156
0
              << Kind << Id << DC << QualifierLoc.getSourceRange();
1157
0
          break;
1158
0
      }
1159
0
      return QualType();
1160
0
    }
1161
1162
0
    if (!SemaRef.isAcceptableTagRedeclaration(Tag, Kind, /*isDefinition*/false,
1163
0
                                              IdLoc, Id)) {
1164
0
      SemaRef.Diag(KeywordLoc, diag::err_use_with_wrong_tag) << Id;
1165
0
      SemaRef.Diag(Tag->getLocation(), diag::note_previous_use);
1166
0
      return QualType();
1167
0
    }
1168
1169
    // Build the elaborated-type-specifier type.
1170
0
    QualType T = SemaRef.Context.getTypeDeclType(Tag);
1171
0
    return SemaRef.Context.getElaboratedType(Keyword,
1172
0
                                         QualifierLoc.getNestedNameSpecifier(),
1173
0
                                             T);
1174
0
  }
SemaTemplate.cpp:clang::TreeTransform<(anonymous namespace)::CurrentInstantiationRebuilder>::RebuildDependentNameType(clang::ElaboratedTypeKeyword, clang::SourceLocation, clang::NestedNameSpecifierLoc, clang::IdentifierInfo const*, clang::SourceLocation, bool)
Line
Count
Source
1088
40.9k
                                    bool DeducedTSTContext) {
1089
40.9k
    CXXScopeSpec SS;
1090
40.9k
    SS.Adopt(QualifierLoc);
1091
1092
40.9k
    if (QualifierLoc.getNestedNameSpecifier()->isDependent()) {
1093
      // If the name is still dependent, just build a new dependent name type.
1094
40.9k
      if (!SemaRef.computeDeclContext(SS))
1095
12.2k
        return SemaRef.Context.getDependentNameType(Keyword,
1096
12.2k
                                          QualifierLoc.getNestedNameSpecifier(),
1097
12.2k
                                                    Id);
1098
28.6k
    }
1099
1100
28.6k
    if (Keyword == ETK_None || 
Keyword == ETK_Typename28.6k
) {
1101
28.6k
      return SemaRef.CheckTypenameType(Keyword, KeywordLoc, QualifierLoc,
1102
28.6k
                                       *Id, IdLoc, DeducedTSTContext);
1103
28.6k
    }
1104
1105
2
    TagTypeKind Kind = TypeWithKeyword::getTagTypeKindForKeyword(Keyword);
1106
1107
    // We had a dependent elaborated-type-specifier that has been transformed
1108
    // into a non-dependent elaborated-type-specifier. Find the tag we're
1109
    // referring to.
1110
2
    LookupResult Result(SemaRef, Id, IdLoc, Sema::LookupTagName);
1111
2
    DeclContext *DC = SemaRef.computeDeclContext(SS, false);
1112
2
    if (!DC)
1113
0
      return QualType();
1114
1115
2
    if (SemaRef.RequireCompleteDeclContext(SS, DC))
1116
0
      return QualType();
1117
1118
2
    TagDecl *Tag = nullptr;
1119
2
    SemaRef.LookupQualifiedName(Result, DC);
1120
2
    switch (Result.getResultKind()) {
1121
0
      case LookupResult::NotFound:
1122
0
      case LookupResult::NotFoundInCurrentInstantiation:
1123
0
        break;
1124
1125
2
      case LookupResult::Found:
1126
2
        Tag = Result.getAsSingle<TagDecl>();
1127
2
        break;
1128
1129
0
      case LookupResult::FoundOverloaded:
1130
0
      case LookupResult::FoundUnresolvedValue:
1131
0
        llvm_unreachable("Tag lookup cannot find non-tags");
1132
1133
0
      case LookupResult::Ambiguous:
1134
        // Let the LookupResult structure handle ambiguities.
1135
0
        return QualType();
1136
2
    }
1137
1138
2
    if (!Tag) {
1139
      // Check where the name exists but isn't a tag type and use that to emit
1140
      // better diagnostics.
1141
0
      LookupResult Result(SemaRef, Id, IdLoc, Sema::LookupTagName);
1142
0
      SemaRef.LookupQualifiedName(Result, DC);
1143
0
      switch (Result.getResultKind()) {
1144
0
        case LookupResult::Found:
1145
0
        case LookupResult::FoundOverloaded:
1146
0
        case LookupResult::FoundUnresolvedValue: {
1147
0
          NamedDecl *SomeDecl = Result.getRepresentativeDecl();
1148
0
          Sema::NonTagKind NTK = SemaRef.getNonTagTypeDeclKind(SomeDecl, Kind);
1149
0
          SemaRef.Diag(IdLoc, diag::err_tag_reference_non_tag) << SomeDecl
1150
0
                                                               << NTK << Kind;
1151
0
          SemaRef.Diag(SomeDecl->getLocation(), diag::note_declared_at);
1152
0
          break;
1153
0
        }
1154
0
        default:
1155
0
          SemaRef.Diag(IdLoc, diag::err_not_tag_in_scope)
1156
0
              << Kind << Id << DC << QualifierLoc.getSourceRange();
1157
0
          break;
1158
0
      }
1159
0
      return QualType();
1160
0
    }
1161
1162
2
    if (!SemaRef.isAcceptableTagRedeclaration(Tag, Kind, /*isDefinition*/false,
1163
0
                                              IdLoc, Id)) {
1164
0
      SemaRef.Diag(KeywordLoc, diag::err_use_with_wrong_tag) << Id;
1165
0
      SemaRef.Diag(Tag->getLocation(), diag::note_previous_use);
1166
0
      return QualType();
1167
0
    }
1168
1169
    // Build the elaborated-type-specifier type.
1170
2
    QualType T = SemaRef.Context.getTypeDeclType(Tag);
1171
2
    return SemaRef.Context.getElaboratedType(Keyword,
1172
2
                                         QualifierLoc.getNestedNameSpecifier(),
1173
2
                                             T);
1174
2
  }
SemaTemplateDeduction.cpp:clang::TreeTransform<(anonymous namespace)::SubstituteDeducedTypeTransform>::RebuildDependentNameType(clang::ElaboratedTypeKeyword, clang::SourceLocation, clang::NestedNameSpecifierLoc, clang::IdentifierInfo const*, clang::SourceLocation, bool)
Line
Count
Source
1088
8
                                    bool DeducedTSTContext) {
1089
8
    CXXScopeSpec SS;
1090
8
    SS.Adopt(QualifierLoc);
1091
1092
8
    if (QualifierLoc.getNestedNameSpecifier()->isDependent()) {
1093
      // If the name is still dependent, just build a new dependent name type.
1094
8
      if (!SemaRef.computeDeclContext(SS))
1095
8
        return SemaRef.Context.getDependentNameType(Keyword,
1096
8
                                          QualifierLoc.getNestedNameSpecifier(),
1097
8
                                                    Id);
1098
0
    }
1099
1100
0
    if (Keyword == ETK_None || Keyword == ETK_Typename) {
1101
0
      return SemaRef.CheckTypenameType(Keyword, KeywordLoc, QualifierLoc,
1102
0
                                       *Id, IdLoc, DeducedTSTContext);
1103
0
    }
1104
1105
0
    TagTypeKind Kind = TypeWithKeyword::getTagTypeKindForKeyword(Keyword);
1106
1107
    // We had a dependent elaborated-type-specifier that has been transformed
1108
    // into a non-dependent elaborated-type-specifier. Find the tag we're
1109
    // referring to.
1110
0
    LookupResult Result(SemaRef, Id, IdLoc, Sema::LookupTagName);
1111
0
    DeclContext *DC = SemaRef.computeDeclContext(SS, false);
1112
0
    if (!DC)
1113
0
      return QualType();
1114
1115
0
    if (SemaRef.RequireCompleteDeclContext(SS, DC))
1116
0
      return QualType();
1117
1118
0
    TagDecl *Tag = nullptr;
1119
0
    SemaRef.LookupQualifiedName(Result, DC);
1120
0
    switch (Result.getResultKind()) {
1121
0
      case LookupResult::NotFound:
1122
0
      case LookupResult::NotFoundInCurrentInstantiation:
1123
0
        break;
1124
1125
0
      case LookupResult::Found:
1126
0
        Tag = Result.getAsSingle<TagDecl>();
1127
0
        break;
1128
1129
0
      case LookupResult::FoundOverloaded:
1130
0
      case LookupResult::FoundUnresolvedValue:
1131
0
        llvm_unreachable("Tag lookup cannot find non-tags");
1132
1133
0
      case LookupResult::Ambiguous:
1134
        // Let the LookupResult structure handle ambiguities.
1135
0
        return QualType();
1136
0
    }
1137
1138
0
    if (!Tag) {
1139
      // Check where the name exists but isn't a tag type and use that to emit
1140
      // better diagnostics.
1141
0
      LookupResult Result(SemaRef, Id, IdLoc, Sema::LookupTagName);
1142
0
      SemaRef.LookupQualifiedName(Result, DC);
1143
0
      switch (Result.getResultKind()) {
1144
0
        case LookupResult::Found:
1145
0
        case LookupResult::FoundOverloaded:
1146
0
        case LookupResult::FoundUnresolvedValue: {
1147
0
          NamedDecl *SomeDecl = Result.getRepresentativeDecl();
1148
0
          Sema::NonTagKind NTK = SemaRef.getNonTagTypeDeclKind(SomeDecl, Kind);
1149
0
          SemaRef.Diag(IdLoc, diag::err_tag_reference_non_tag) << SomeDecl
1150
0
                                                               << NTK << Kind;
1151
0
          SemaRef.Diag(SomeDecl->getLocation(), diag::note_declared_at);
1152
0
          break;
1153
0
        }
1154
0
        default:
1155
0
          SemaRef.Diag(IdLoc, diag::err_not_tag_in_scope)
1156
0
              << Kind << Id << DC << QualifierLoc.getSourceRange();
1157
0
          break;
1158
0
      }
1159
0
      return QualType();
1160
0
    }
1161
1162
0
    if (!SemaRef.isAcceptableTagRedeclaration(Tag, Kind, /*isDefinition*/false,
1163
0
                                              IdLoc, Id)) {
1164
0
      SemaRef.Diag(KeywordLoc, diag::err_use_with_wrong_tag) << Id;
1165
0
      SemaRef.Diag(Tag->getLocation(), diag::note_previous_use);
1166
0
      return QualType();
1167
0
    }
1168
1169
    // Build the elaborated-type-specifier type.
1170
0
    QualType T = SemaRef.Context.getTypeDeclType(Tag);
1171
0
    return SemaRef.Context.getElaboratedType(Keyword,
1172
0
                                         QualifierLoc.getNestedNameSpecifier(),
1173
0
                                             T);
1174
0
  }
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildDependentNameType(clang::ElaboratedTypeKeyword, clang::SourceLocation, clang::NestedNameSpecifierLoc, clang::IdentifierInfo const*, clang::SourceLocation, bool)
Line
Count
Source
1088
1.14M
                                    bool DeducedTSTContext) {
1089
1.14M
    CXXScopeSpec SS;
1090
1.14M
    SS.Adopt(QualifierLoc);
1091
1092
1.14M
    if (QualifierLoc.getNestedNameSpecifier()->isDependent()) {
1093
      // If the name is still dependent, just build a new dependent name type.
1094
374k
      if (!SemaRef.computeDeclContext(SS))
1095
373k
        return SemaRef.Context.getDependentNameType(Keyword,
1096
373k
                                          QualifierLoc.getNestedNameSpecifier(),
1097
373k
                                                    Id);
1098
769k
    }
1099
1100
769k
    if (Keyword == ETK_None || 
Keyword == ETK_Typename767k
) {
1101
769k
      return SemaRef.CheckTypenameType(Keyword, KeywordLoc, QualifierLoc,
1102
769k
                                       *Id, IdLoc, DeducedTSTContext);
1103
769k
    }
1104
1105
45
    TagTypeKind Kind = TypeWithKeyword::getTagTypeKindForKeyword(Keyword);
1106
1107
    // We had a dependent elaborated-type-specifier that has been transformed
1108
    // into a non-dependent elaborated-type-specifier. Find the tag we're
1109
    // referring to.
1110
45
    LookupResult Result(SemaRef, Id, IdLoc, Sema::LookupTagName);
1111
45
    DeclContext *DC = SemaRef.computeDeclContext(SS, false);
1112
45
    if (!DC)
1113
0
      return QualType();
1114
1115
45
    if (SemaRef.RequireCompleteDeclContext(SS, DC))
1116
2
      return QualType();
1117
1118
43
    TagDecl *Tag = nullptr;
1119
43
    SemaRef.LookupQualifiedName(Result, DC);
1120
43
    switch (Result.getResultKind()) {
1121
4
      case LookupResult::NotFound:
1122
4
      case LookupResult::NotFoundInCurrentInstantiation:
1123
4
        break;
1124
1125
39
      case LookupResult::Found:
1126
39
        Tag = Result.getAsSingle<TagDecl>();
1127
39
        break;
1128
1129
0
      case LookupResult::FoundOverloaded:
1130
0
      case LookupResult::FoundUnresolvedValue:
1131
0
        llvm_unreachable("Tag lookup cannot find non-tags");
1132
1133
0
      case LookupResult::Ambiguous:
1134
        // Let the LookupResult structure handle ambiguities.
1135
0
        return QualType();
1136
43
    }
1137
1138
43
    if (!Tag) {
1139
      // Check where the name exists but isn't a tag type and use that to emit
1140
      // better diagnostics.
1141
10
      LookupResult Result(SemaRef, Id, IdLoc, Sema::LookupTagName);
1142
10
      SemaRef.LookupQualifiedName(Result, DC);
1143
10
      switch (Result.getResultKind()) {
1144
6
        case LookupResult::Found:
1145
6
        case LookupResult::FoundOverloaded:
1146
6
        case LookupResult::FoundUnresolvedValue: {
1147
6
          NamedDecl *SomeDecl = Result.getRepresentativeDecl();
1148
6
          Sema::NonTagKind NTK = SemaRef.getNonTagTypeDeclKind(SomeDecl, Kind);
1149
6
          SemaRef.Diag(IdLoc, diag::err_tag_reference_non_tag) << SomeDecl
1150
6
                                                               << NTK << Kind;
1151
6
          SemaRef.Diag(SomeDecl->getLocation(), diag::note_declared_at);
1152
6
          break;
1153
6
        }
1154
4
        default:
1155
4
          SemaRef.Diag(IdLoc, diag::err_not_tag_in_scope)
1156
4
              << Kind << Id << DC << QualifierLoc.getSourceRange();
1157
4
          break;
1158
10
      }
1159
10
      return QualType();
1160
10
    }
1161
1162
33
    if (!SemaRef.isAcceptableTagRedeclaration(Tag, Kind, /*isDefinition*/false,
1163
4
                                              IdLoc, Id)) {
1164
4
      SemaRef.Diag(KeywordLoc, diag::err_use_with_wrong_tag) << Id;
1165
4
      SemaRef.Diag(Tag->getLocation(), diag::note_previous_use);
1166
4
      return QualType();
1167
4
    }
1168
1169
    // Build the elaborated-type-specifier type.
1170
29
    QualType T = SemaRef.Context.getTypeDeclType(Tag);
1171
29
    return SemaRef.Context.getElaboratedType(Keyword,
1172
29
                                         QualifierLoc.getNestedNameSpecifier(),
1173
29
                                             T);
1174
29
  }
1175
1176
  /// Build a new pack expansion type.
1177
  ///
1178
  /// By default, builds a new PackExpansionType type from the given pattern.
1179
  /// Subclasses may override this routine to provide different behavior.
1180
  QualType RebuildPackExpansionType(QualType Pattern,
1181
                                    SourceRange PatternRange,
1182
                                    SourceLocation EllipsisLoc,
1183
219
                                    Optional<unsigned> NumExpansions) {
1184
219
    return getSema().CheckPackExpansion(Pattern, PatternRange, EllipsisLoc,
1185
219
                                        NumExpansions);
1186
219
  }
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
1183
2
                                    Optional<unsigned> NumExpansions) {
1184
2
    return getSema().CheckPackExpansion(Pattern, PatternRange, EllipsisLoc,
1185
2
                                        NumExpansions);
1186
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
1183
63
                                    Optional<unsigned> NumExpansions) {
1184
63
    return getSema().CheckPackExpansion(Pattern, PatternRange, EllipsisLoc,
1185
63
                                        NumExpansions);
1186
63
  }
SemaTemplateInstantiate.cpp:clang::TreeTransform<(anonymous namespace)::TemplateInstantiator>::RebuildPackExpansionType(clang::QualType, clang::SourceRange, clang::SourceLocation, llvm::Optional<unsigned int>)
Line
Count
Source
1183
154
                                    Optional<unsigned> NumExpansions) {
1184
154
    return getSema().CheckPackExpansion(Pattern, PatternRange, EllipsisLoc,
1185
154
                                        NumExpansions);
1186
154
  }
1187
1188
  /// Build a new atomic type given its value type.
1189
  ///
1190
  /// By default, performs semantic analysis when building the atomic type.
1191
  /// Subclasses may override this routine to provide different behavior.
1192
  QualType RebuildAtomicType(QualType ValueType, SourceLocation KWLoc);
1193
1194
  /// Build a new pipe type given its value type.
1195
  QualType RebuildPipeType(QualType ValueType, SourceLocation KWLoc,
1196
                           bool isReadPipe);
1197
1198
   /// Build an extended int given its value type.
1199
  QualType RebuildExtIntType(bool IsUnsigned, unsigned NumBits,
1200
                             SourceLocation Loc);
1201
1202
  /// Build a dependent extended int given its value type.
1203
  QualType RebuildDependentExtIntType(bool IsUnsigned, Expr *NumBitsExpr,
1204
                                      SourceLocation Loc);
1205
1206
  /// Build a new template name given a nested name specifier, a flag
1207
  /// indicating whether the "template" keyword was provided, and the template
1208
  /// that the template name refers to.
1209
  ///
1210
  /// By default, builds the new template name directly. Subclasses may override
1211
  /// this routine to provide different behavior.
1212
  TemplateName RebuildTemplateName(CXXScopeSpec &SS,
1213
                                   bool TemplateKW,
1214
                                   TemplateDecl *Template);
1215
1216
  /// Build a new template name given a nested name specifier and the
1217
  /// name that is referred to as a template.
1218
  ///
1219
  /// By default, performs semantic analysis to determine whether the name can
1220
  /// be resolved to a specific template, then builds the appropriate kind of
1221
  /// template name. Subclasses may override this routine to provide different
1222
  /// behavior.
1223
  TemplateName RebuildTemplateName(CXXScopeSpec &SS,
1224
                                   SourceLocation TemplateKWLoc,
1225
                                   const IdentifierInfo &Name,
1226
                                   SourceLocation NameLoc, QualType ObjectType,
1227
                                   NamedDecl *FirstQualifierInScope,
1228
                                   bool AllowInjectedClassName);
1229
1230
  /// Build a new template name given a nested name specifier and the
1231
  /// overloaded operator name that is referred to as a template.
1232
  ///
1233
  /// By default, performs semantic analysis to determine whether the name can
1234
  /// be resolved to a specific template, then builds the appropriate kind of
1235
  /// template name. Subclasses may override this routine to provide different
1236
  /// behavior.
1237
  TemplateName RebuildTemplateName(CXXScopeSpec &SS,
1238
                                   SourceLocation TemplateKWLoc,
1239
                                   OverloadedOperatorKind Operator,
1240
                                   SourceLocation NameLoc, QualType ObjectType,
1241
                                   bool AllowInjectedClassName);
1242
1243
  /// Build a new template name given a template template parameter pack
1244
  /// and the
1245
  ///
1246
  /// By default, performs semantic analysis to determine whether the name can
1247
  /// be resolved to a specific template, then builds the appropriate kind of
1248
  /// template name. Subclasses may override this routine to provide different
1249
  /// behavior.
1250
  TemplateName RebuildTemplateName(TemplateTemplateParmDecl *Param,
1251
0
                                   const TemplateArgument &ArgPack) {
1252
0
    return getSema().Context.getSubstTemplateTemplateParmPack(Param, ArgPack);
1253
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&)
1254
1255
  /// Build a new compound statement.
1256
  ///
1257
  /// By default, performs semantic analysis to build the new statement.
1258
  /// Subclasses may override this routine to provide different behavior.
1259
  StmtResult RebuildCompoundStmt(SourceLocation LBraceLoc,
1260
                                       MultiStmtArg Statements,
1261
                                       SourceLocation RBraceLoc,
1262
177k
                                       bool IsStmtExpr) {
1263
177k
    return getSema().ActOnCompoundStmt(LBraceLoc, RBraceLoc, Statements,
1264
177k
                                       IsStmtExpr);
1265
177k
  }
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
1262
1
                                       bool IsStmtExpr) {
1263
1
    return getSema().ActOnCompoundStmt(LBraceLoc, RBraceLoc, Statements,
1264
1
                                       IsStmtExpr);
1265
1
  }
Unexecuted instantiation: SemaExprCXX.cpp:clang::TreeTransform<(anonymous namespace)::TransformTypos>::RebuildCompoundStmt(clang::SourceLocation, llvm::MutableArrayRef<clang::Stmt*>, clang::SourceLocation, bool)
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)
Line
Count
Source
1262
1
                                       bool IsStmtExpr) {
1263
1
    return getSema().ActOnCompoundStmt(LBraceLoc, RBraceLoc, Statements,
1264
1
                                       IsStmtExpr);
1265
1
  }
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
1262
177k
                                       bool IsStmtExpr) {
1263
177k
    return getSema().ActOnCompoundStmt(LBraceLoc, RBraceLoc, Statements,
1264
177k
                                       IsStmtExpr);
1265
177k
  }
1266
1267
  /// Build a new case statement.
1268
  ///
1269
  /// By default, performs semantic analysis to build the new statement.
1270
  /// Subclasses may override this routine to provide different behavior.
1271
  StmtResult RebuildCaseStmt(SourceLocation CaseLoc,
1272
                                   Expr *LHS,
1273
                                   SourceLocation EllipsisLoc,
1274
                                   Expr *RHS,
1275
472
                                   SourceLocation ColonLoc) {
1276
472
    return getSema().ActOnCaseStmt(CaseLoc, LHS, EllipsisLoc, RHS,
1277
472
                                   ColonLoc);
1278
472
  }
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
1275
472
                                   SourceLocation ColonLoc) {
1276
472
    return getSema().ActOnCaseStmt(CaseLoc, LHS, EllipsisLoc, RHS,
1277
472
                                   ColonLoc);
1278
472
  }
1279
1280
  /// Attach the body to a new case statement.
1281
  ///
1282
  /// By default, performs semantic analysis to build the new statement.
1283
  /// Subclasses may override this routine to provide different behavior.
1284
472
  StmtResult RebuildCaseStmtBody(Stmt *S, Stmt *Body) {
1285
472
    getSema().ActOnCaseStmtBody(S, Body);
1286
472
    return S;
1287
472
  }
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
1284
472
  StmtResult RebuildCaseStmtBody(Stmt *S, Stmt *Body) {
1285
472
    getSema().ActOnCaseStmtBody(S, Body);
1286
472
    return S;
1287
472
  }
1288
1289
  /// Build a new default statement.
1290
  ///
1291
  /// By default, performs semantic analysis to build the new statement.
1292
  /// Subclasses may override this routine to provide different behavior.
1293
  StmtResult RebuildDefaultStmt(SourceLocation DefaultLoc,
1294
                                      SourceLocation ColonLoc,
1295
50
                                      Stmt *SubStmt) {
1296
50
    return getSema().ActOnDefaultStmt(DefaultLoc, ColonLoc, SubStmt,
1297
50
                                      /*CurScope=*/nullptr);
1298
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
1295
50
                                      Stmt *SubStmt) {
1296
50
    return getSema().ActOnDefaultStmt(DefaultLoc, ColonLoc, SubStmt,
1297
50
                                      /*CurScope=*/nullptr);
1298
50
  }
1299
1300
  /// Build a new label statement.
1301
  ///
1302
  /// By default, performs semantic analysis to build the new statement.
1303
  /// Subclasses may override this routine to provide different behavior.
1304
  StmtResult RebuildLabelStmt(SourceLocation IdentLoc, LabelDecl *L,
1305
70
                              SourceLocation ColonLoc, Stmt *SubStmt) {
1306
70
    return SemaRef.ActOnLabelStmt(IdentLoc, L, ColonLoc, SubStmt);
1307
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
1305
1
                              SourceLocation ColonLoc, Stmt *SubStmt) {
1306
1
    return SemaRef.ActOnLabelStmt(IdentLoc, L, ColonLoc, SubStmt);
1307
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
1305
69
                              SourceLocation ColonLoc, Stmt *SubStmt) {
1306
69
    return SemaRef.ActOnLabelStmt(IdentLoc, L, ColonLoc, SubStmt);
1307
69
  }
1308
1309
  /// Build a new attributed statement.
1310
  ///
1311
  /// By default, performs semantic analysis to build the new statement.
1312
  /// Subclasses may override this routine to provide different behavior.
1313
  StmtResult RebuildAttributedStmt(SourceLocation AttrLoc,
1314
                                   ArrayRef<const Attr*> Attrs,
1315
28
                                   Stmt *SubStmt) {
1316
28
    return SemaRef.ActOnAttributedStmt(AttrLoc, Attrs, SubStmt);
1317
28
  }
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
1315
28
                                   Stmt *SubStmt) {
1316
28
    return SemaRef.ActOnAttributedStmt(AttrLoc, Attrs, SubStmt);
1317
28
  }
1318
1319
  /// Build a new "if" statement.
1320
  ///
1321
  /// By default, performs semantic analysis to build the new statement.
1322
  /// Subclasses may override this routine to provide different behavior.
1323
  StmtResult RebuildIfStmt(SourceLocation IfLoc, bool IsConstexpr,
1324
                           SourceLocation LParenLoc, Sema::ConditionResult Cond,
1325
                           SourceLocation RParenLoc, Stmt *Init, Stmt *Then,
1326
25.4k
                           SourceLocation ElseLoc, Stmt *Else) {
1327
25.4k
    return getSema().ActOnIfStmt(IfLoc, IsConstexpr, LParenLoc, Init, Cond,
1328
25.4k
                                 RParenLoc, Then, ElseLoc, Else);
1329
25.4k
  }
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
1326
25.4k
                           SourceLocation ElseLoc, Stmt *Else) {
1327
25.4k
    return getSema().ActOnIfStmt(IfLoc, IsConstexpr, LParenLoc, Init, Cond,
1328
25.4k
                                 RParenLoc, Then, ElseLoc, Else);
1329
25.4k
  }
1330
1331
  /// Start building a new switch statement.
1332
  ///
1333
  /// By default, performs semantic analysis to build the new statement.
1334
  /// Subclasses may override this routine to provide different behavior.
1335
  StmtResult RebuildSwitchStmtStart(SourceLocation SwitchLoc,
1336
                                    SourceLocation LParenLoc, Stmt *Init,
1337
                                    Sema::ConditionResult Cond,
1338
155
                                    SourceLocation RParenLoc) {
1339
155
    return getSema().ActOnStartOfSwitchStmt(SwitchLoc, LParenLoc, Init, Cond,
1340
155
                                            RParenLoc);
1341
155
  }
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
1338
155
                                    SourceLocation RParenLoc) {
1339
155
    return getSema().ActOnStartOfSwitchStmt(SwitchLoc, LParenLoc, Init, Cond,
1340
155
                                            RParenLoc);
1341
155
  }
1342
1343
  /// Attach the body to the switch statement.
1344
  ///
1345
  /// By default, performs semantic analysis to build the new statement.
1346
  /// Subclasses may override this routine to provide different behavior.
1347
  StmtResult RebuildSwitchStmtBody(SourceLocation SwitchLoc,
1348
155
                                   Stmt *Switch, Stmt *Body) {
1349
155
    return getSema().ActOnFinishSwitchStmt(SwitchLoc, Switch, Body);
1350
155
  }
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
1348
155
                                   Stmt *Switch, Stmt *Body) {
1349
155
    return getSema().ActOnFinishSwitchStmt(SwitchLoc, Switch, Body);
1350
155
  }
1351
1352
  /// Build a new while statement.
1353
  ///
1354
  /// By default, performs semantic analysis to build the new statement.
1355
  /// Subclasses may override this routine to provide different behavior.
1356
  StmtResult RebuildWhileStmt(SourceLocation WhileLoc, SourceLocation LParenLoc,
1357
                              Sema::ConditionResult Cond,
1358
1.67k
                              SourceLocation RParenLoc, Stmt *Body) {
1359
1.67k
    return getSema().ActOnWhileStmt(WhileLoc, LParenLoc, Cond, RParenLoc, Body);
1360
1.67k
  }
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
1358
1.67k
                              SourceLocation RParenLoc, Stmt *Body) {
1359
1.67k
    return getSema().ActOnWhileStmt(WhileLoc, LParenLoc, Cond, RParenLoc, Body);
1360
1.67k
  }
1361
1362
  /// Build a new do-while statement.
1363
  ///
1364
  /// By default, performs semantic analysis to build the new statement.
1365
  /// Subclasses may override this routine to provide different behavior.
1366
  StmtResult RebuildDoStmt(SourceLocation DoLoc, Stmt *Body,
1367
                           SourceLocation WhileLoc, SourceLocation LParenLoc,
1368
530
                           Expr *Cond, SourceLocation RParenLoc) {
1369
530
    return getSema().ActOnDoStmt(DoLoc, Body, WhileLoc, LParenLoc,
1370
530
                                 Cond, RParenLoc);
1371
530
  }
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
1368
530
                           Expr *Cond, SourceLocation RParenLoc) {
1369
530
    return getSema().ActOnDoStmt(DoLoc, Body, WhileLoc, LParenLoc,
1370
530
                                 Cond, RParenLoc);
1371
530
  }
1372
1373
  /// Build a new for statement.
1374
  ///
1375
  /// By default, performs semantic analysis to build the new statement.
1376
  /// Subclasses may override this routine to provide different behavior.
1377
  StmtResult RebuildForStmt(SourceLocation ForLoc, SourceLocation LParenLoc,
1378
                            Stmt *Init, Sema::ConditionResult Cond,
1379
                            Sema::FullExprArg Inc, SourceLocation RParenLoc,
1380
59.7k
                            Stmt *Body) {
1381
59.7k
    return getSema().ActOnForStmt(ForLoc, LParenLoc, Init, Cond,
1382
59.7k
                                  Inc, RParenLoc, Body);
1383
59.7k
  }
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
1380
59.7k
                            Stmt *Body) {
1381
59.7k
    return getSema().ActOnForStmt(ForLoc, LParenLoc, Init, Cond,
1382
59.7k
                                  Inc, RParenLoc, Body);
1383
59.7k
  }
1384
1385
  /// Build a new goto statement.
1386
  ///
1387
  /// By default, performs semantic analysis to build the new statement.
1388
  /// Subclasses may override this routine to provide different behavior.
1389
  StmtResult RebuildGotoStmt(SourceLocation GotoLoc, SourceLocation LabelLoc,
1390
34
                             LabelDecl *Label) {
1391
34
    return getSema().ActOnGotoStmt(GotoLoc, LabelLoc, Label);
1392
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
1390
1
                             LabelDecl *Label) {
1391
1
    return getSema().ActOnGotoStmt(GotoLoc, LabelLoc, Label);
1392
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
1390
33
                             LabelDecl *Label) {
1391
33
    return getSema().ActOnGotoStmt(GotoLoc, LabelLoc, Label);
1392
33
  }
1393
1394
  /// Build a new indirect goto statement.
1395
  ///
1396
  /// By default, performs semantic analysis to build the new statement.
1397
  /// Subclasses may override this routine to provide different behavior.
1398
  StmtResult RebuildIndirectGotoStmt(SourceLocation GotoLoc,
1399
                                     SourceLocation StarLoc,
1400
2
                                     Expr *Target) {
1401
2
    return getSema().ActOnIndirectGotoStmt(GotoLoc, StarLoc, Target);
1402
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
1400
2
                                     Expr *Target) {
1401
2
    return getSema().ActOnIndirectGotoStmt(GotoLoc, StarLoc, Target);
1402
2
  }
1403
1404
  /// Build a new return statement.
1405
  ///
1406
  /// By default, performs semantic analysis to build the new statement.
1407
  /// Subclasses may override this routine to provide different behavior.
1408
125k
  StmtResult RebuildReturnStmt(SourceLocation ReturnLoc, Expr *Result) {
1409
125k
    return getSema().BuildReturnStmt(ReturnLoc, Result);
1410
125k
  }
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*)
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*)
Line
Count
Source
1408
1
  StmtResult RebuildReturnStmt(SourceLocation ReturnLoc, Expr *Result) {
1409
1
    return getSema().BuildReturnStmt(ReturnLoc, Result);
1410
1
  }
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
1408
125k
  StmtResult RebuildReturnStmt(SourceLocation ReturnLoc, Expr *Result) {
1409
125k
    return getSema().BuildReturnStmt(ReturnLoc, Result);
1410
125k
  }
1411
1412
  /// Build a new declaration statement.
1413
  ///
1414
  /// By default, performs semantic analysis to build the new statement.
1415
  /// Subclasses may override this routine to provide different behavior.
1416
  StmtResult RebuildDeclStmt(MutableArrayRef<Decl *> Decls,
1417
133k
                             SourceLocation StartLoc, SourceLocation EndLoc) {
1418
133k
    Sema::DeclGroupPtrTy DG = getSema().BuildDeclaratorGroup(Decls);
1419
133k
    return getSema().ActOnDeclStmt(DG, StartLoc, EndLoc);
1420
133k
  }
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
1417
133k
                             SourceLocation StartLoc, SourceLocation EndLoc) {
1418
133k
    Sema::DeclGroupPtrTy DG = getSema().BuildDeclaratorGroup(Decls);
1419
133k
    return getSema().ActOnDeclStmt(DG, StartLoc, EndLoc);
1420
133k
  }
1421
1422
  /// Build a new inline asm statement.
1423
  ///
1424
  /// By default, performs semantic analysis to build the new statement.
1425
  /// Subclasses may override this routine to provide different behavior.
1426
  StmtResult RebuildGCCAsmStmt(SourceLocation AsmLoc, bool IsSimple,
1427
                               bool IsVolatile, unsigned NumOutputs,
1428
                               unsigned NumInputs, IdentifierInfo **Names,
1429
                               MultiExprArg Constraints, MultiExprArg Exprs,
1430
                               Expr *AsmString, MultiExprArg Clobbers,
1431
                               unsigned NumLabels,
1432
9
                               SourceLocation RParenLoc) {
1433
9
    return getSema().ActOnGCCAsmStmt(AsmLoc, IsSimple, IsVolatile, NumOutputs,
1434
9
                                     NumInputs, Names, Constraints, Exprs,
1435
9
                                     AsmString, Clobbers, NumLabels, RParenLoc);
1436
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
1432
9
                               SourceLocation RParenLoc) {
1433
9
    return getSema().ActOnGCCAsmStmt(AsmLoc, IsSimple, IsVolatile, NumOutputs,
1434
9
                                     NumInputs, Names, Constraints, Exprs,
1435
9
                                     AsmString, Clobbers, NumLabels, RParenLoc);
1436
9
  }
1437
1438
  /// Build a new MS style inline asm statement.
1439
  ///
1440
  /// By default, performs semantic analysis to build the new statement.
1441
  /// Subclasses may override this routine to provide different behavior.
1442
  StmtResult RebuildMSAsmStmt(SourceLocation AsmLoc, SourceLocation LBraceLoc,
1443
                              ArrayRef<Token> AsmToks,
1444
                              StringRef AsmString,
1445
                              unsigned NumOutputs, unsigned NumInputs,
1446
                              ArrayRef<StringRef> Constraints,
1447
                              ArrayRef<StringRef> Clobbers,
1448
                              ArrayRef<Expr*> Exprs,
1449
1
                              SourceLocation EndLoc) {
1450
1
    return getSema().ActOnMSAsmStmt(AsmLoc, LBraceLoc, AsmToks, AsmString,
1451
1
                                    NumOutputs, NumInputs,
1452
1
                                    Constraints, Clobbers, Exprs, EndLoc);
1453
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
1449
1
                              SourceLocation EndLoc) {
1450
1
    return getSema().ActOnMSAsmStmt(AsmLoc, LBraceLoc, AsmToks, AsmString,
1451
1
                                    NumOutputs, NumInputs,
1452
1
                                    Constraints, Clobbers, Exprs, EndLoc);
1453
1
  }
1454
1455
  /// Build a new co_return statement.
1456
  ///
1457
  /// By default, performs semantic analysis to build the new statement.
1458
  /// Subclasses may override this routine to provide different behavior.
1459
  StmtResult RebuildCoreturnStmt(SourceLocation CoreturnLoc, Expr *Result,
1460
17
                                 bool IsImplicit) {
1461
17
    return getSema().BuildCoreturnStmt(CoreturnLoc, Result, IsImplicit);
1462
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
1460
17
                                 bool IsImplicit) {
1461
17
    return getSema().BuildCoreturnStmt(CoreturnLoc, Result, IsImplicit);
1462
17
  }
1463
1464
  /// Build a new co_await expression.
1465
  ///
1466
  /// By default, performs semantic analysis to build the new expression.
1467
  /// Subclasses may override this routine to provide different behavior.
1468
  ExprResult RebuildCoawaitExpr(SourceLocation CoawaitLoc, Expr *Result,
1469
118
                                bool IsImplicit) {
1470
118
    return getSema().BuildResolvedCoawaitExpr(CoawaitLoc, Result, IsImplicit);
1471
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
1469
4
                                bool IsImplicit) {
1470
4
    return getSema().BuildResolvedCoawaitExpr(CoawaitLoc, Result, IsImplicit);
1471
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
1469
114
                                bool IsImplicit) {
1470
114
    return getSema().BuildResolvedCoawaitExpr(CoawaitLoc, Result, IsImplicit);
1471
114
  }
1472
1473
  /// Build a new co_await expression.
1474
  ///
1475
  /// By default, performs semantic analysis to build the new expression.
1476
  /// Subclasses may override this routine to provide different behavior.
1477
  ExprResult RebuildDependentCoawaitExpr(SourceLocation CoawaitLoc,
1478
                                         Expr *Result,
1479
25
                                         UnresolvedLookupExpr *Lookup) {
1480
25
    return getSema().BuildUnresolvedCoawaitExpr(CoawaitLoc, Result, Lookup);
1481
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
1479
25
                                         UnresolvedLookupExpr *Lookup) {
1480
25
    return getSema().BuildUnresolvedCoawaitExpr(CoawaitLoc, Result, Lookup);
1481
25
  }
1482
1483
  /// Build a new co_yield expression.
1484
  ///
1485
  /// By default, performs semantic analysis to build the new expression.
1486
  /// Subclasses may override this routine to provide different behavior.
1487
21
  ExprResult RebuildCoyieldExpr(SourceLocation CoyieldLoc, Expr *Result) {
1488
21
    return getSema().BuildCoyieldExpr(CoyieldLoc, Result);
1489
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
1487
2
  ExprResult RebuildCoyieldExpr(SourceLocation CoyieldLoc, Expr *Result) {
1488
2
    return getSema().BuildCoyieldExpr(CoyieldLoc, Result);
1489
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
1487
19
  ExprResult RebuildCoyieldExpr(SourceLocation CoyieldLoc, Expr *Result) {
1488
19
    return getSema().BuildCoyieldExpr(CoyieldLoc, Result);
1489
19
  }
1490
1491
44
  StmtResult RebuildCoroutineBodyStmt(CoroutineBodyStmt::CtorArgs Args) {
1492
44
    return getSema().BuildCoroutineBodyStmt(Args);
1493
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
1491
44
  StmtResult RebuildCoroutineBodyStmt(CoroutineBodyStmt::CtorArgs Args) {
1492
44
    return getSema().BuildCoroutineBodyStmt(Args);
1493
44
  }
1494
1495
  /// Build a new Objective-C \@try statement.
1496
  ///
1497
  /// By default, performs semantic analysis to build the new statement.
1498
  /// Subclasses may override this routine to provide different behavior.
1499
  StmtResult RebuildObjCAtTryStmt(SourceLocation AtLoc,
1500
                                        Stmt *TryBody,
1501
                                        MultiStmtArg CatchStmts,
1502
1
                                        Stmt *Finally) {
1503
1
    return getSema().ActOnObjCAtTryStmt(AtLoc, TryBody, CatchStmts,
1504
1
                                        Finally);
1505
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
1502
1
                                        Stmt *Finally) {
1503
1
    return getSema().ActOnObjCAtTryStmt(AtLoc, TryBody, CatchStmts,
1504
1
                                        Finally);
1505
1
  }
1506
1507
  /// Rebuild an Objective-C exception declaration.
1508
  ///
1509
  /// By default, performs semantic analysis to build the new declaration.
1510
  /// Subclasses may override this routine to provide different behavior.
1511
  VarDecl *RebuildObjCExceptionDecl(VarDecl *ExceptionDecl,
1512
2
                                    TypeSourceInfo *TInfo, QualType T) {
1513
2
    return getSema().BuildObjCExceptionDecl(TInfo, T,
1514
2
                                            ExceptionDecl->getInnerLocStart(),
1515
2
                                            ExceptionDecl->getLocation(),
1516
2
                                            ExceptionDecl->getIdentifier());
1517
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
1512
2
                                    TypeSourceInfo *TInfo, QualType T) {
1513
2
    return getSema().BuildObjCExceptionDecl(TInfo, T,
1514
2
                                            ExceptionDecl->getInnerLocStart(),
1515
2
                                            ExceptionDecl->getLocation(),
1516
2
                                            ExceptionDecl->getIdentifier());
1517
2
  }
1518
1519
  /// Build a new Objective-C \@catch statement.
1520
  ///
1521
  /// By default, performs semantic analysis to build the new statement.
1522
  /// Subclasses may override this routine to provide different behavior.
1523
  StmtResult RebuildObjCAtCatchStmt(SourceLocation AtLoc,
1524
                                          SourceLocation RParenLoc,
1525
                                          VarDecl *Var,
1526
2
                                          Stmt *Body) {
1527
2
    return getSema().ActOnObjCAtCatchStmt(AtLoc, RParenLoc,
1528
2
                                          Var, Body);
1529
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
1526
2
                                          Stmt *Body) {
1527
2
    return getSema().ActOnObjCAtCatchStmt(AtLoc, RParenLoc,
1528
2
                                          Var, Body);
1529
2
  }
1530
1531
  /// Build a new Objective-C \@finally statement.
1532
  ///
1533
  /// By default, performs semantic analysis to build the new statement.
1534
  /// Subclasses may override this routine to provide different behavior.
1535
  StmtResult RebuildObjCAtFinallyStmt(SourceLocation AtLoc,
1536
1
                                            Stmt *Body) {
1537
1
    return getSema().ActOnObjCAtFinallyStmt(AtLoc, Body);
1538
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
1536
1
                                            Stmt *Body) {
1537
1
    return getSema().ActOnObjCAtFinallyStmt(AtLoc, Body);
1538
1
  }
1539
1540
  /// Build a new Objective-C \@throw statement.
1541
  ///
1542
  /// By default, performs semantic analysis to build the new statement.
1543
  /// Subclasses may override this routine to provide different behavior.
1544
  StmtResult RebuildObjCAtThrowStmt(SourceLocation AtLoc,
1545
2
                                          Expr *Operand) {
1546
2
    return getSema().BuildObjCAtThrowStmt(AtLoc, Operand);
1547
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
1545
2
                                          Expr *Operand) {
1546
2
    return getSema().BuildObjCAtThrowStmt(AtLoc, Operand);
1547
2
  }
1548
1549
  /// Build a new OpenMP executable directive.
1550
  ///
1551
  /// By default, performs semantic analysis to build the new statement.
1552
  /// Subclasses may override this routine to provide different behavior.
1553
  StmtResult RebuildOMPExecutableDirective(OpenMPDirectiveKind Kind,
1554
                                           DeclarationNameInfo DirName,
1555
                                           OpenMPDirectiveKind CancelRegion,
1556
                                           ArrayRef<OMPClause *> Clauses,
1557
                                           Stmt *AStmt, SourceLocation StartLoc,
1558
89.0k
                                           SourceLocation EndLoc) {
1559
89.0k
    return getSema().ActOnOpenMPExecutableDirective(
1560
89.0k
        Kind, DirName, CancelRegion, Clauses, AStmt, StartLoc, EndLoc);
1561
89.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>::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
1558
89.0k
                                           SourceLocation EndLoc) {
1559
89.0k
    return getSema().ActOnOpenMPExecutableDirective(
1560
89.0k
        Kind, DirName, CancelRegion, Clauses, AStmt, StartLoc, EndLoc);
1561
89.0k
  }
1562
1563
  /// Build a new OpenMP 'if' clause.
1564
  ///
1565
  /// By default, performs semantic analysis to build the new OpenMP clause.
1566
  /// Subclasses may override this routine to provide different behavior.
1567
  OMPClause *RebuildOMPIfClause(OpenMPDirectiveKind NameModifier,
1568
                                Expr *Condition, SourceLocation StartLoc,
1569
                                SourceLocation LParenLoc,
1570
                                SourceLocation NameModifierLoc,
1571
                                SourceLocation ColonLoc,
1572
2.62k
                                SourceLocation EndLoc) {
1573
2.62k
    return getSema().ActOnOpenMPIfClause(NameModifier, Condition, StartLoc,
1574
2.62k
                                         LParenLoc, NameModifierLoc, ColonLoc,
1575
2.62k
                                         EndLoc);
1576
2.62k
  }
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
1572
2.62k
                                SourceLocation EndLoc) {
1573
2.62k
    return getSema().ActOnOpenMPIfClause(NameModifier, Condition, StartLoc,
1574
2.62k
                                         LParenLoc, NameModifierLoc, ColonLoc,
1575
2.62k
                                         EndLoc);
1576
2.62k
  }
1577
1578
  /// Build a new OpenMP 'final' clause.
1579
  ///
1580
  /// By default, performs semantic analysis to build the new OpenMP clause.
1581
  /// Subclasses may override this routine to provide different behavior.
1582
  OMPClause *RebuildOMPFinalClause(Expr *Condition, SourceLocation StartLoc,
1583
                                   SourceLocation LParenLoc,
1584
178
                                   SourceLocation EndLoc) {
1585
178
    return getSema().ActOnOpenMPFinalClause(Condition, StartLoc, LParenLoc,
1586
178
                                            EndLoc);
1587
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
1584
178
                                   SourceLocation EndLoc) {
1585
178
    return getSema().ActOnOpenMPFinalClause(Condition, StartLoc, LParenLoc,
1586
178
                                            EndLoc);
1587
178
  }
1588
1589
  /// Build a new OpenMP 'num_threads' clause.
1590
  ///
1591
  /// By default, performs semantic analysis to build the new OpenMP clause.
1592
  /// Subclasses may override this routine to provide different behavior.
1593
  OMPClause *RebuildOMPNumThreadsClause(Expr *NumThreads,
1594
                                        SourceLocation StartLoc,
1595
                                        SourceLocation LParenLoc,
1596
832
                                        SourceLocation EndLoc) {
1597
832
    return getSema().ActOnOpenMPNumThreadsClause(NumThreads, StartLoc,
1598
832
                                                 LParenLoc, EndLoc);
1599
832
  }
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
1596
832
                                        SourceLocation EndLoc) {
1597
832
    return getSema().ActOnOpenMPNumThreadsClause(NumThreads, StartLoc,
1598
832
                                                 LParenLoc, EndLoc);
1599
832
  }
1600
1601
  /// Build a new OpenMP 'safelen' clause.
1602
  ///
1603
  /// By default, performs semantic analysis to build the new OpenMP clause.
1604
  /// Subclasses may override this routine to provide different behavior.
1605
  OMPClause *RebuildOMPSafelenClause(Expr *Len, SourceLocation StartLoc,
1606
                                     SourceLocation LParenLoc,
1607
1.96k
                                     SourceLocation EndLoc) {
1608
1.96k
    return getSema().ActOnOpenMPSafelenClause(Len, StartLoc, LParenLoc, EndLoc);
1609
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
1607
1.96k
                                     SourceLocation EndLoc) {
1608
1.96k
    return getSema().ActOnOpenMPSafelenClause(Len, StartLoc, LParenLoc, EndLoc);
1609
1.96k
  }
1610
1611
  /// Build a new OpenMP 'simdlen' clause.
1612
  ///
1613
  /// By default, performs semantic analysis to build the new OpenMP clause.
1614
  /// Subclasses may override this routine to provide different behavior.
1615
  OMPClause *RebuildOMPSimdlenClause(Expr *Len, SourceLocation StartLoc,
1616
                                     SourceLocation LParenLoc,
1617
992
                                     SourceLocation EndLoc) {
1618
992
    return getSema().ActOnOpenMPSimdlenClause(Len, StartLoc, LParenLoc, EndLoc);
1619
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
1617
992
                                     SourceLocation EndLoc) {
1618
992
    return getSema().ActOnOpenMPSimdlenClause(Len, StartLoc, LParenLoc, EndLoc);
1619
992
  }
1620
1621
  /// Build a new OpenMP 'allocator' clause.
1622
  ///
1623
  /// By default, performs semantic analysis to build the new OpenMP clause.
1624
  /// Subclasses may override this routine to provide different behavior.
1625
  OMPClause *RebuildOMPAllocatorClause(Expr *A, SourceLocation StartLoc,
1626
                                       SourceLocation LParenLoc,
1627
0
                                       SourceLocation EndLoc) {
1628
0
    return getSema().ActOnOpenMPAllocatorClause(A, StartLoc, LParenLoc, EndLoc);
1629
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)
1630
1631
  /// Build a new OpenMP 'collapse' clause.
1632
  ///
1633
  /// By default, performs semantic analysis to build the new OpenMP clause.
1634
  /// Subclasses may override this routine to provide different behavior.
1635
  OMPClause *RebuildOMPCollapseClause(Expr *Num, SourceLocation StartLoc,
1636
                                      SourceLocation LParenLoc,
1637
2.96k
                                      SourceLocation EndLoc) {
1638
2.96k
    return getSema().ActOnOpenMPCollapseClause(Num, StartLoc, LParenLoc,
1639
2.96k
                                               EndLoc);
1640
2.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>::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
1637
2.96k
                                      SourceLocation EndLoc) {
1638
2.96k
    return getSema().ActOnOpenMPCollapseClause(Num, StartLoc, LParenLoc,
1639
2.96k
                                               EndLoc);
1640
2.96k
  }
1641
1642
  /// Build a new OpenMP 'default' clause.
1643
  ///
1644
  /// By default, performs semantic analysis to build the new OpenMP clause.
1645
  /// Subclasses may override this routine to provide different behavior.
1646
  OMPClause *RebuildOMPDefaultClause(DefaultKind Kind, SourceLocation KindKwLoc,
1647
                                     SourceLocation StartLoc,
1648
                                     SourceLocation LParenLoc,
1649
436
                                     SourceLocation EndLoc) {
1650
436
    return getSema().ActOnOpenMPDefaultClause(Kind, KindKwLoc,
1651
436
                                              StartLoc, LParenLoc, EndLoc);
1652
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
1649
436
                                     SourceLocation EndLoc) {
1650
436
    return getSema().ActOnOpenMPDefaultClause(Kind, KindKwLoc,
1651
436
                                              StartLoc, LParenLoc, EndLoc);
1652
436
  }
1653
1654
  /// Build a new OpenMP 'proc_bind' clause.
1655
  ///
1656
  /// By default, performs semantic analysis to build the new OpenMP clause.
1657
  /// Subclasses may override this routine to provide different behavior.
1658
  OMPClause *RebuildOMPProcBindClause(ProcBindKind Kind,
1659
                                      SourceLocation KindKwLoc,
1660
                                      SourceLocation StartLoc,
1661
                                      SourceLocation LParenLoc,
1662
254
                                      SourceLocation EndLoc) {
1663
254
    return getSema().ActOnOpenMPProcBindClause(Kind, KindKwLoc,
1664
254
                                               StartLoc, LParenLoc, EndLoc);
1665
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
1662
254
                                      SourceLocation EndLoc) {
1663
254
    return getSema().ActOnOpenMPProcBindClause(Kind, KindKwLoc,
1664
254
                                               StartLoc, LParenLoc, EndLoc);
1665
254
  }
1666
1667
  /// Build a new OpenMP 'schedule' clause.
1668
  ///
1669
  /// By default, performs semantic analysis to build the new OpenMP clause.
1670
  /// Subclasses may override this routine to provide different behavior.
1671
  OMPClause *RebuildOMPScheduleClause(
1672
      OpenMPScheduleClauseModifier M1, OpenMPScheduleClauseModifier M2,
1673
      OpenMPScheduleClauseKind Kind, Expr *ChunkSize, SourceLocation StartLoc,
1674
      SourceLocation LParenLoc, SourceLocation M1Loc, SourceLocation M2Loc,
1675
1.26k
      SourceLocation KindLoc, SourceLocation CommaLoc, SourceLocation EndLoc) {
1676
1.26k
    return getSema().ActOnOpenMPScheduleClause(
1677
1.26k
        M1, M2, Kind, ChunkSize, StartLoc, LParenLoc, M1Loc, M2Loc, KindLoc,
1678
1.26k
        CommaLoc, EndLoc);
1679
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
1675
1.26k
      SourceLocation KindLoc, SourceLocation CommaLoc, SourceLocation EndLoc) {
1676
1.26k
    return getSema().ActOnOpenMPScheduleClause(
1677
1.26k
        M1, M2, Kind, ChunkSize, StartLoc, LParenLoc, M1Loc, M2Loc, KindLoc,
1678
1.26k
        CommaLoc, EndLoc);
1679
1.26k
  }
1680
1681
  /// Build a new OpenMP 'ordered' clause.
1682
  ///
1683
  /// By default, performs semantic analysis to build the new OpenMP clause.
1684
  /// Subclasses may override this routine to provide different behavior.
1685
  OMPClause *RebuildOMPOrderedClause(SourceLocation StartLoc,
1686
                                     SourceLocation EndLoc,
1687
498
                                     SourceLocation LParenLoc, Expr *Num) {
1688
498
    return getSema().ActOnOpenMPOrderedClause(StartLoc, EndLoc, LParenLoc, Num);
1689
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
1687
498
                                     SourceLocation LParenLoc, Expr *Num) {
1688
498
    return getSema().ActOnOpenMPOrderedClause(StartLoc, EndLoc, LParenLoc, Num);
1689
498
  }
1690
1691
  /// Build a new OpenMP 'private' clause.
1692
  ///
1693
  /// By default, performs semantic analysis to build the new OpenMP clause.
1694
  /// Subclasses may override this routine to provide different behavior.
1695
  OMPClause *RebuildOMPPrivateClause(ArrayRef<Expr *> VarList,
1696
                                     SourceLocation StartLoc,
1697
                                     SourceLocation LParenLoc,
1698
4.48k
                                     SourceLocation EndLoc) {
1699
4.48k
    return getSema().ActOnOpenMPPrivateClause(VarList, StartLoc, LParenLoc,
1700
4.48k
                                              EndLoc);
1701
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
1698
4.48k
                                     SourceLocation EndLoc) {
1699
4.48k
    return getSema().ActOnOpenMPPrivateClause(VarList, StartLoc, LParenLoc,
1700
4.48k
                                              EndLoc);
1701
4.48k
  }
1702
1703
  /// Build a new OpenMP 'firstprivate' clause.
1704
  ///
1705
  /// By default, performs semantic analysis to build the new OpenMP clause.
1706
  /// Subclasses may override this routine to provide different behavior.
1707
  OMPClause *RebuildOMPFirstprivateClause(ArrayRef<Expr *> VarList,
1708
                                          SourceLocation StartLoc,
1709
                                          SourceLocation LParenLoc,
1710
1.21k
                                          SourceLocation EndLoc) {
1711
1.21k
    return getSema().ActOnOpenMPFirstprivateClause(VarList, StartLoc, LParenLoc,
1712
1.21k
                                                   EndLoc);
1713
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
1710
1.21k
                                          SourceLocation EndLoc) {
1711
1.21k
    return getSema().ActOnOpenMPFirstprivateClause(VarList, StartLoc, LParenLoc,
1712
1.21k
                                                   EndLoc);
1713
1.21k
  }
1714
1715
  /// Build a new OpenMP 'lastprivate' clause.
1716
  ///
1717
  /// By default, performs semantic analysis to build the new OpenMP clause.
1718
  /// Subclasses may override this routine to provide different behavior.
1719
  OMPClause *RebuildOMPLastprivateClause(ArrayRef<Expr *> VarList,
1720
                                         OpenMPLastprivateModifier LPKind,
1721
                                         SourceLocation LPKindLoc,
1722
                                         SourceLocation ColonLoc,
1723
                                         SourceLocation StartLoc,
1724
                                         SourceLocation LParenLoc,
1725
1.37k
                                         SourceLocation EndLoc) {
1726
1.37k
    return getSema().ActOnOpenMPLastprivateClause(
1727
1.37k
        VarList, LPKind, LPKindLoc, ColonLoc, StartLoc, LParenLoc, EndLoc);
1728
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
1725
1.37k
                                         SourceLocation EndLoc) {
1726
1.37k
    return getSema().ActOnOpenMPLastprivateClause(
1727
1.37k
        VarList, LPKind, LPKindLoc, ColonLoc, StartLoc, LParenLoc, EndLoc);
1728
1.37k
  }
1729
1730
  /// Build a new OpenMP 'shared' clause.
1731
  ///
1732
  /// By default, performs semantic analysis to build the new OpenMP clause.
1733
  /// Subclasses may override this routine to provide different behavior.
1734
  OMPClause *RebuildOMPSharedClause(ArrayRef<Expr *> VarList,
1735
                                    SourceLocation StartLoc,
1736
                                    SourceLocation LParenLoc,
1737
1.37k
                                    SourceLocation EndLoc) {
1738
1.37k
    return getSema().ActOnOpenMPSharedClause(VarList, StartLoc, LParenLoc,
1739
1.37k
                                             EndLoc);
1740
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
1737
1.37k
                                    SourceLocation EndLoc) {
1738
1.37k
    return getSema().ActOnOpenMPSharedClause(VarList, StartLoc, LParenLoc,
1739
1.37k
                                             EndLoc);
1740
1.37k
  }
1741
1742
  /// Build a new OpenMP 'reduction' clause.
1743
  ///
1744
  /// By default, performs semantic analysis to build the new statement.
1745
  /// Subclasses may override this routine to provide different behavior.
1746
  OMPClause *RebuildOMPReductionClause(
1747
      ArrayRef<Expr *> VarList, OpenMPReductionClauseModifier Modifier,
1748
      SourceLocation StartLoc, SourceLocation LParenLoc,
1749
      SourceLocation ModifierLoc, SourceLocation ColonLoc,
1750
      SourceLocation EndLoc, CXXScopeSpec &ReductionIdScopeSpec,
1751
      const DeclarationNameInfo &ReductionId,
1752
17.3k
      ArrayRef<Expr *> UnresolvedReductions) {
1753
17.3k
    return getSema().ActOnOpenMPReductionClause(
1754
17.3k
        VarList, Modifier, StartLoc, LParenLoc, ModifierLoc, ColonLoc, EndLoc,
1755
17.3k
        ReductionIdScopeSpec, ReductionId, UnresolvedReductions);
1756
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
1752
17.3k
      ArrayRef<Expr *> UnresolvedReductions) {
1753
17.3k
    return getSema().ActOnOpenMPReductionClause(
1754
17.3k
        VarList, Modifier, StartLoc, LParenLoc, ModifierLoc, ColonLoc, EndLoc,
1755
17.3k
        ReductionIdScopeSpec, ReductionId, UnresolvedReductions);
1756
17.3k
  }
1757
1758
  /// Build a new OpenMP 'task_reduction' clause.
1759
  ///
1760
  /// By default, performs semantic analysis to build the new statement.
1761
  /// Subclasses may override this routine to provide different behavior.
1762
  OMPClause *RebuildOMPTaskReductionClause(
1763
      ArrayRef<Expr *> VarList, SourceLocation StartLoc,
1764
      SourceLocation LParenLoc, SourceLocation ColonLoc, SourceLocation EndLoc,
1765
      CXXScopeSpec &ReductionIdScopeSpec,
1766
      const DeclarationNameInfo &ReductionId,
1767
1.24k
      ArrayRef<Expr *> UnresolvedReductions) {
1768
1.24k
    return getSema().ActOnOpenMPTaskReductionClause(
1769
1.24k
        VarList, StartLoc, LParenLoc, ColonLoc, EndLoc, ReductionIdScopeSpec,
1770
1.24k
        ReductionId, UnresolvedReductions);
1771
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
1767
1.24k
      ArrayRef<Expr *> UnresolvedReductions) {
1768
1.24k
    return getSema().ActOnOpenMPTaskReductionClause(
1769
1.24k
        VarList, StartLoc, LParenLoc, ColonLoc, EndLoc, ReductionIdScopeSpec,
1770
1.24k
        ReductionId, UnresolvedReductions);
1771
1.24k
  }
1772
1773
  /// Build a new OpenMP 'in_reduction' clause.
1774
  ///
1775
  /// By default, performs semantic analysis to build the new statement.
1776
  /// Subclasses may override this routine to provide different behavior.
1777
  OMPClause *
1778
  RebuildOMPInReductionClause(ArrayRef<Expr *> VarList, SourceLocation StartLoc,
1779
                              SourceLocation LParenLoc, SourceLocation ColonLoc,
1780
                              SourceLocation EndLoc,
1781
                              CXXScopeSpec &ReductionIdScopeSpec,
1782
                              const DeclarationNameInfo &ReductionId,
1783
1.12k
                              ArrayRef<Expr *> UnresolvedReductions) {
1784
1.12k
    return getSema().ActOnOpenMPInReductionClause(
1785
1.12k
        VarList, StartLoc, LParenLoc, ColonLoc, EndLoc, ReductionIdScopeSpec,
1786
1.12k
        ReductionId, UnresolvedReductions);
1787
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
1783
1.12k
                              ArrayRef<Expr *> UnresolvedReductions) {
1784
1.12k
    return getSema().ActOnOpenMPInReductionClause(
1785
1.12k
        VarList, StartLoc, LParenLoc, ColonLoc, EndLoc, ReductionIdScopeSpec,
1786
1.12k
        ReductionId, UnresolvedReductions);
1787
1.12k
  }
1788
1789
  /// Build a new OpenMP 'linear' clause.
1790
  ///
1791
  /// By default, performs semantic analysis to build the new OpenMP clause.
1792
  /// Subclasses may override this routine to provide different behavior.
1793
  OMPClause *RebuildOMPLinearClause(ArrayRef<Expr *> VarList, Expr *Step,
1794
                                    SourceLocation StartLoc,
1795
                                    SourceLocation LParenLoc,
1796
                                    OpenMPLinearClauseKind Modifier,
1797
                                    SourceLocation ModifierLoc,
1798
                                    SourceLocation ColonLoc,
1799
534
                                    SourceLocation EndLoc) {
1800
534
    return getSema().ActOnOpenMPLinearClause(VarList, Step, StartLoc, LParenLoc,
1801
534
                                             Modifier, ModifierLoc, ColonLoc,
1802
534
                                             EndLoc);
1803
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
1799
534
                                    SourceLocation EndLoc) {
1800
534
    return getSema().ActOnOpenMPLinearClause(VarList, Step, StartLoc, LParenLoc,
1801
534
                                             Modifier, ModifierLoc, ColonLoc,
1802
534
                                             EndLoc);
1803
534
  }
1804
1805
  /// Build a new OpenMP 'aligned' clause.
1806
  ///
1807
  /// By default, performs semantic analysis to build the new OpenMP clause.
1808
  /// Subclasses may override this routine to provide different behavior.
1809
  OMPClause *RebuildOMPAlignedClause(ArrayRef<Expr *> VarList, Expr *Alignment,
1810
                                     SourceLocation StartLoc,
1811
                                     SourceLocation LParenLoc,
1812
                                     SourceLocation ColonLoc,
1813
468
                                     SourceLocation EndLoc) {
1814
468
    return getSema().ActOnOpenMPAlignedClause(VarList, Alignment, StartLoc,
1815
468
                                              LParenLoc, ColonLoc, EndLoc);
1816
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
1813
468
                                     SourceLocation EndLoc) {
1814
468
    return getSema().ActOnOpenMPAlignedClause(VarList, Alignment, StartLoc,
1815
468
                                              LParenLoc, ColonLoc, EndLoc);
1816
468
  }
1817
1818
  /// Build a new OpenMP 'copyin' clause.
1819
  ///
1820
  /// By default, performs semantic analysis to build the new OpenMP clause.
1821
  /// Subclasses may override this routine to provide different behavior.
1822
  OMPClause *RebuildOMPCopyinClause(ArrayRef<Expr *> VarList,
1823
                                    SourceLocation StartLoc,
1824
                                    SourceLocation LParenLoc,
1825
112
                                    SourceLocation EndLoc) {
1826
112
    return getSema().ActOnOpenMPCopyinClause(VarList, StartLoc, LParenLoc,
1827
112
                                             EndLoc);
1828
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
1825
112
                                    SourceLocation EndLoc) {
1826
112
    return getSema().ActOnOpenMPCopyinClause(VarList, StartLoc, LParenLoc,
1827
112
                                             EndLoc);
1828
112
  }
1829
1830
  /// Build a new OpenMP 'copyprivate' clause.
1831
  ///
1832
  /// By default, performs semantic analysis to build the new OpenMP clause.
1833
  /// Subclasses may override this routine to provide different behavior.
1834
  OMPClause *RebuildOMPCopyprivateClause(ArrayRef<Expr *> VarList,
1835
                                         SourceLocation StartLoc,
1836
                                         SourceLocation LParenLoc,
1837
62
                                         SourceLocation EndLoc) {
1838
62
    return getSema().ActOnOpenMPCopyprivateClause(VarList, StartLoc, LParenLoc,
1839
62
                                                  EndLoc);
1840
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
1837
62
                                         SourceLocation EndLoc) {
1838
62
    return getSema().ActOnOpenMPCopyprivateClause(VarList, StartLoc, LParenLoc,
1839
62
                                                  EndLoc);
1840
62
  }
1841
1842
  /// Build a new OpenMP 'flush' pseudo clause.
1843
  ///
1844
  /// By default, performs semantic analysis to build the new OpenMP clause.
1845
  /// Subclasses may override this routine to provide different behavior.
1846
  OMPClause *RebuildOMPFlushClause(ArrayRef<Expr *> VarList,
1847
                                   SourceLocation StartLoc,
1848
                                   SourceLocation LParenLoc,
1849
30
                                   SourceLocation EndLoc) {
1850
30
    return getSema().ActOnOpenMPFlushClause(VarList, StartLoc, LParenLoc,
1851
30
                                            EndLoc);
1852
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
1849
30
                                   SourceLocation EndLoc) {
1850
30
    return getSema().ActOnOpenMPFlushClause(VarList, StartLoc, LParenLoc,
1851
30
                                            EndLoc);
1852
30
  }
1853
1854
  /// Build a new OpenMP 'depobj' pseudo clause.
1855
  ///
1856
  /// By default, performs semantic analysis to build the new OpenMP clause.
1857
  /// Subclasses may override this routine to provide different behavior.
1858
  OMPClause *RebuildOMPDepobjClause(Expr *Depobj, SourceLocation StartLoc,
1859
                                    SourceLocation LParenLoc,
1860
72
                                    SourceLocation EndLoc) {
1861
72
    return getSema().ActOnOpenMPDepobjClause(Depobj, StartLoc, LParenLoc,
1862
72
                                             EndLoc);
1863
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
1860
72
                                    SourceLocation EndLoc) {
1861
72
    return getSema().ActOnOpenMPDepobjClause(Depobj, StartLoc, LParenLoc,
1862
72
                                             EndLoc);
1863
72
  }
1864
1865
  /// Build a new OpenMP 'depend' pseudo clause.
1866
  ///
1867
  /// By default, performs semantic analysis to build the new OpenMP clause.
1868
  /// Subclasses may override this routine to provide different behavior.
1869
  OMPClause *
1870
  RebuildOMPDependClause(Expr *DepModifier, OpenMPDependClauseKind DepKind,
1871
                         SourceLocation DepLoc, SourceLocation ColonLoc,
1872
                         ArrayRef<Expr *> VarList, SourceLocation StartLoc,
1873
622
                         SourceLocation LParenLoc, SourceLocation EndLoc) {
1874
622
    return getSema().ActOnOpenMPDependClause(DepModifier, DepKind, DepLoc,
1875
622
                                             ColonLoc, VarList, StartLoc,
1876
622
                                             LParenLoc, EndLoc);
1877
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
1873
622
                         SourceLocation LParenLoc, SourceLocation EndLoc) {
1874
622
    return getSema().ActOnOpenMPDependClause(DepModifier, DepKind, DepLoc,
1875
622
                                             ColonLoc, VarList, StartLoc,
1876
622
                                             LParenLoc, EndLoc);
1877
622
  }
1878
1879
  /// Build a new OpenMP 'device' clause.
1880
  ///
1881
  /// By default, performs semantic analysis to build the new statement.
1882
  /// Subclasses may override this routine to provide different behavior.
1883
  OMPClause *RebuildOMPDeviceClause(OpenMPDeviceClauseModifier Modifier,
1884
                                    Expr *Device, SourceLocation StartLoc,
1885
                                    SourceLocation LParenLoc,
1886
                                    SourceLocation ModifierLoc,
1887
126
                                    SourceLocation EndLoc) {
1888
126
    return getSema().ActOnOpenMPDeviceClause(Modifier, Device, StartLoc,
1889
126
                                             LParenLoc, ModifierLoc, EndLoc);
1890
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
1887
126
                                    SourceLocation EndLoc) {
1888
126
    return getSema().ActOnOpenMPDeviceClause(Modifier, Device, StartLoc,
1889
126
                                             LParenLoc, ModifierLoc, EndLoc);
1890
126
  }
1891
1892
  /// Build a new OpenMP 'map' clause.
1893
  ///
1894
  /// By default, performs semantic analysis to build the new OpenMP clause.
1895
  /// Subclasses may override this routine to provide different behavior.
1896
  OMPClause *RebuildOMPMapClause(
1897
      ArrayRef<OpenMPMapModifierKind> MapTypeModifiers,
1898
      ArrayRef<SourceLocation> MapTypeModifiersLoc,
1899
      CXXScopeSpec MapperIdScopeSpec, DeclarationNameInfo MapperId,
1900
      OpenMPMapClauseKind MapType, bool IsMapTypeImplicit,
1901
      SourceLocation MapLoc, SourceLocation ColonLoc, ArrayRef<Expr *> VarList,
1902
9.95k
      const OMPVarListLocTy &Locs, ArrayRef<Expr *> UnresolvedMappers) {
1903
9.95k
    return getSema().ActOnOpenMPMapClause(MapTypeModifiers, MapTypeModifiersLoc,
1904
9.95k
                                          MapperIdScopeSpec, MapperId, MapType,
1905
9.95k
                                          IsMapTypeImplicit, MapLoc, ColonLoc,
1906
9.95k
                                          VarList, Locs, UnresolvedMappers);
1907
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
1902
9.95k
      const OMPVarListLocTy &Locs, ArrayRef<Expr *> UnresolvedMappers) {
1903
9.95k
    return getSema().ActOnOpenMPMapClause(MapTypeModifiers, MapTypeModifiersLoc,
1904
9.95k
                                          MapperIdScopeSpec, MapperId, MapType,
1905
9.95k
                                          IsMapTypeImplicit, MapLoc, ColonLoc,
1906
9.95k
                                          VarList, Locs, UnresolvedMappers);
1907
9.95k
  }
1908
1909
  /// Build a new OpenMP 'allocate' clause.
1910
  ///
1911
  /// By default, performs semantic analysis to build the new OpenMP clause.
1912
  /// Subclasses may override this routine to provide different behavior.
1913
  OMPClause *RebuildOMPAllocateClause(Expr *Allocate, ArrayRef<Expr *> VarList,
1914
                                      SourceLocation StartLoc,
1915
                                      SourceLocation LParenLoc,
1916
                                      SourceLocation ColonLoc,
1917
863
                                      SourceLocation EndLoc) {
1918
863
    return getSema().ActOnOpenMPAllocateClause(Allocate, VarList, StartLoc,
1919
863
                                               LParenLoc, ColonLoc, EndLoc);
1920
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
1917
863
                                      SourceLocation EndLoc) {
1918
863
    return getSema().ActOnOpenMPAllocateClause(Allocate, VarList, StartLoc,
1919
863
                                               LParenLoc, ColonLoc, EndLoc);
1920
863
  }
1921
1922
  /// Build a new OpenMP 'num_teams' clause.
1923
  ///
1924
  /// By default, performs semantic analysis to build the new statement.
1925
  /// Subclasses may override this routine to provide different behavior.
1926
  OMPClause *RebuildOMPNumTeamsClause(Expr *NumTeams, SourceLocation StartLoc,
1927
                                      SourceLocation LParenLoc,
1928
420
                                      SourceLocation EndLoc) {
1929
420
    return getSema().ActOnOpenMPNumTeamsClause(NumTeams, StartLoc, LParenLoc,
1930
420
                                               EndLoc);
1931
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
1928
420
                                      SourceLocation EndLoc) {
1929
420
    return getSema().ActOnOpenMPNumTeamsClause(NumTeams, StartLoc, LParenLoc,
1930
420
                                               EndLoc);
1931
420
  }
1932
1933
  /// Build a new OpenMP 'thread_limit' clause.
1934
  ///
1935
  /// By default, performs semantic analysis to build the new statement.
1936
  /// Subclasses may override this routine to provide different behavior.
1937
  OMPClause *RebuildOMPThreadLimitClause(Expr *ThreadLimit,
1938
                                         SourceLocation StartLoc,
1939
                                         SourceLocation LParenLoc,
1940
364
                                         SourceLocation EndLoc) {
1941
364
    return getSema().ActOnOpenMPThreadLimitClause(ThreadLimit, StartLoc,
1942
364
                                                  LParenLoc, EndLoc);
1943
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
1940
364
                                         SourceLocation EndLoc) {
1941
364
    return getSema().ActOnOpenMPThreadLimitClause(ThreadLimit, StartLoc,
1942
364
                                                  LParenLoc, EndLoc);
1943
364
  }
1944
1945
  /// Build a new OpenMP 'priority' clause.
1946
  ///
1947
  /// By default, performs semantic analysis to build the new statement.
1948
  /// Subclasses may override this routine to provide different behavior.
1949
  OMPClause *RebuildOMPPriorityClause(Expr *Priority, SourceLocation StartLoc,
1950
                                      SourceLocation LParenLoc,
1951
244
                                      SourceLocation EndLoc) {
1952
244
    return getSema().ActOnOpenMPPriorityClause(Priority, StartLoc, LParenLoc,
1953
244
                                               EndLoc);
1954
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
1951
244
                                      SourceLocation EndLoc) {
1952
244
    return getSema().ActOnOpenMPPriorityClause(Priority, StartLoc, LParenLoc,
1953
244
                                               EndLoc);
1954
244
  }
1955
1956
  /// Build a new OpenMP 'grainsize' clause.
1957
  ///
1958
  /// By default, performs semantic analysis to build the new statement.
1959
  /// Subclasses may override this routine to provide different behavior.
1960
  OMPClause *RebuildOMPGrainsizeClause(Expr *Grainsize, SourceLocation StartLoc,
1961
                                       SourceLocation LParenLoc,
1962
132
                                       SourceLocation EndLoc) {
1963
132
    return getSema().ActOnOpenMPGrainsizeClause(Grainsize, StartLoc, LParenLoc,
1964
132
                                                EndLoc);
1965
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
1962
132
                                       SourceLocation EndLoc) {
1963
132
    return getSema().ActOnOpenMPGrainsizeClause(Grainsize, StartLoc, LParenLoc,
1964
132
                                                EndLoc);
1965
132
  }
1966
1967
  /// Build a new OpenMP 'num_tasks' clause.
1968
  ///
1969
  /// By default, performs semantic analysis to build the new statement.
1970
  /// Subclasses may override this routine to provide different behavior.
1971
  OMPClause *RebuildOMPNumTasksClause(Expr *NumTasks, SourceLocation StartLoc,
1972
                                      SourceLocation LParenLoc,
1973
132
                                      SourceLocation EndLoc) {
1974
132
    return getSema().ActOnOpenMPNumTasksClause(NumTasks, StartLoc, LParenLoc,
1975
132
                                               EndLoc);
1976
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
1973
132
                                      SourceLocation EndLoc) {
1974
132
    return getSema().ActOnOpenMPNumTasksClause(NumTasks, StartLoc, LParenLoc,
1975
132
                                               EndLoc);
1976
132
  }
1977
1978
  /// Build a new OpenMP 'hint' clause.
1979
  ///
1980
  /// By default, performs semantic analysis to build the new statement.
1981
  /// Subclasses may override this routine to provide different behavior.
1982
  OMPClause *RebuildOMPHintClause(Expr *Hint, SourceLocation StartLoc,
1983
                                  SourceLocation LParenLoc,
1984
32
                                  SourceLocation EndLoc) {
1985
32
    return getSema().ActOnOpenMPHintClause(Hint, StartLoc, LParenLoc, EndLoc);
1986
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
1984
32
                                  SourceLocation EndLoc) {
1985
32
    return getSema().ActOnOpenMPHintClause(Hint, StartLoc, LParenLoc, EndLoc);
1986
32
  }
1987
1988
  /// Build a new OpenMP 'detach' clause.
1989
  ///
1990
  /// By default, performs semantic analysis to build the new statement.
1991
  /// Subclasses may override this routine to provide different behavior.
1992
  OMPClause *RebuildOMPDetachClause(Expr *Evt, SourceLocation StartLoc,
1993
                                    SourceLocation LParenLoc,
1994
36
                                    SourceLocation EndLoc) {
1995
36
    return getSema().ActOnOpenMPDetachClause(Evt, StartLoc, LParenLoc, EndLoc);
1996
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
1994
36
                                    SourceLocation EndLoc) {
1995
36
    return getSema().ActOnOpenMPDetachClause(Evt, StartLoc, LParenLoc, EndLoc);
1996
36
  }
1997
1998
  /// Build a new OpenMP 'dist_schedule' clause.
1999
  ///
2000
  /// By default, performs semantic analysis to build the new OpenMP clause.
2001
  /// Subclasses may override this routine to provide different behavior.
2002
  OMPClause *
2003
  RebuildOMPDistScheduleClause(OpenMPDistScheduleClauseKind Kind,
2004
                               Expr *ChunkSize, SourceLocation StartLoc,
2005
                               SourceLocation LParenLoc, SourceLocation KindLoc,
2006
722
                               SourceLocation CommaLoc, SourceLocation EndLoc) {
2007
722
    return getSema().ActOnOpenMPDistScheduleClause(
2008
722
        Kind, ChunkSize, StartLoc, LParenLoc, KindLoc, CommaLoc, EndLoc);
2009
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
2006
722
                               SourceLocation CommaLoc, SourceLocation EndLoc) {
2007
722
    return getSema().ActOnOpenMPDistScheduleClause(
2008
722
        Kind, ChunkSize, StartLoc, LParenLoc, KindLoc, CommaLoc, EndLoc);
2009
722
  }
2010
2011
  /// Build a new OpenMP 'to' clause.
2012
  ///
2013
  /// By default, performs semantic analysis to build the new statement.
2014
  /// Subclasses may override this routine to provide different behavior.
2015
  OMPClause *
2016
  RebuildOMPToClause(ArrayRef<OpenMPMotionModifierKind> MotionModifiers,
2017
                     ArrayRef<SourceLocation> MotionModifiersLoc,
2018
                     CXXScopeSpec &MapperIdScopeSpec,
2019
                     DeclarationNameInfo &MapperId, SourceLocation ColonLoc,
2020
                     ArrayRef<Expr *> VarList, const OMPVarListLocTy &Locs,
2021
830
                     ArrayRef<Expr *> UnresolvedMappers) {
2022
830
    return getSema().ActOnOpenMPToClause(MotionModifiers, MotionModifiersLoc,
2023
830
                                         MapperIdScopeSpec, MapperId, ColonLoc,
2024
830
                                         VarList, Locs, UnresolvedMappers);
2025
830
  }
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
2021
830
                     ArrayRef<Expr *> UnresolvedMappers) {
2022
830
    return getSema().ActOnOpenMPToClause(MotionModifiers, MotionModifiersLoc,
2023
830
                                         MapperIdScopeSpec, MapperId, ColonLoc,
2024
830
                                         VarList, Locs, UnresolvedMappers);
2025
830
  }
2026
2027
  /// Build a new OpenMP 'from' clause.
2028
  ///
2029
  /// By default, performs semantic analysis to build the new statement.
2030
  /// Subclasses may override this routine to provide different behavior.
2031
  OMPClause *
2032
  RebuildOMPFromClause(ArrayRef<OpenMPMotionModifierKind> MotionModifiers,
2033
                       ArrayRef<SourceLocation> MotionModifiersLoc,
2034
                       CXXScopeSpec &MapperIdScopeSpec,
2035
                       DeclarationNameInfo &MapperId, SourceLocation ColonLoc,
2036
                       ArrayRef<Expr *> VarList, const OMPVarListLocTy &Locs,
2037
486
                       ArrayRef<Expr *> UnresolvedMappers) {
2038
486
    return getSema().ActOnOpenMPFromClause(
2039
486
        MotionModifiers, MotionModifiersLoc, MapperIdScopeSpec, MapperId,
2040
486
        ColonLoc, VarList, Locs, UnresolvedMappers);
2041
486
  }
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
2037
486
                       ArrayRef<Expr *> UnresolvedMappers) {
2038
486
    return getSema().ActOnOpenMPFromClause(
2039
486
        MotionModifiers, MotionModifiersLoc, MapperIdScopeSpec, MapperId,
2040
486
        ColonLoc, VarList, Locs, UnresolvedMappers);
2041
486
  }
2042
2043
  /// Build a new OpenMP 'use_device_ptr' clause.
2044
  ///
2045
  /// By default, performs semantic analysis to build the new OpenMP clause.
2046
  /// Subclasses may override this routine to provide different behavior.
2047
  OMPClause *RebuildOMPUseDevicePtrClause(ArrayRef<Expr *> VarList,
2048
196
                                          const OMPVarListLocTy &Locs) {
2049
196
    return getSema().ActOnOpenMPUseDevicePtrClause(VarList, Locs);
2050
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
2048
196
                                          const OMPVarListLocTy &Locs) {
2049
196
    return getSema().ActOnOpenMPUseDevicePtrClause(VarList, Locs);
2050
196
  }
2051
2052
  /// Build a new OpenMP 'use_device_addr' clause.
2053
  ///
2054
  /// By default, performs semantic analysis to build the new OpenMP clause.
2055
  /// Subclasses may override this routine to provide different behavior.
2056
  OMPClause *RebuildOMPUseDeviceAddrClause(ArrayRef<Expr *> VarList,
2057
22
                                           const OMPVarListLocTy &Locs) {
2058
22
    return getSema().ActOnOpenMPUseDeviceAddrClause(VarList, Locs);
2059
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: SemaEx