blob: 5012b5a0d6f7a912043e17c85018dad21c33988e [file] [log] [blame]
Douglas Gregor5c193b92009-07-28 00:33:38 +00001//===---- StmtProfile.cpp - Profile implementation for Stmt ASTs ----------===//
2//
3// The LLVM Compiler Infrastructure
4//
5// This file is distributed under the University of Illinois Open Source
6// License. See LICENSE.TXT for details.
7//
8//===----------------------------------------------------------------------===//
9//
10// This file implements the Stmt::Profile method, which builds a unique bit
Douglas Gregor32615a12009-07-28 16:39:25 +000011// representation that identifies a statement/expression.
Douglas Gregor5c193b92009-07-28 00:33:38 +000012//
13//===----------------------------------------------------------------------===//
14#include "clang/AST/ASTContext.h"
Douglas Gregora7095092009-07-28 14:44:31 +000015#include "clang/AST/DeclCXX.h"
16#include "clang/AST/DeclObjC.h"
Douglas Gregor5c193b92009-07-28 00:33:38 +000017#include "clang/AST/DeclTemplate.h"
18#include "clang/AST/Expr.h"
19#include "clang/AST/ExprCXX.h"
20#include "clang/AST/ExprObjC.h"
21#include "clang/AST/StmtVisitor.h"
22#include "llvm/ADT/FoldingSet.h"
Douglas Gregor5c193b92009-07-28 00:33:38 +000023using namespace clang;
24
25namespace {
Chandler Carruth631abd92011-06-16 06:47:06 +000026 class StmtProfiler : public ConstStmtVisitor<StmtProfiler> {
Douglas Gregor5c193b92009-07-28 00:33:38 +000027 llvm::FoldingSetNodeID &ID;
Jay Foad39c79802011-01-12 09:06:06 +000028 const ASTContext &Context;
Douglas Gregor5c193b92009-07-28 00:33:38 +000029 bool Canonical;
Mike Stump11289f42009-09-09 15:08:12 +000030
Douglas Gregor5c193b92009-07-28 00:33:38 +000031 public:
Jay Foad39c79802011-01-12 09:06:06 +000032 StmtProfiler(llvm::FoldingSetNodeID &ID, const ASTContext &Context,
Mike Stump11289f42009-09-09 15:08:12 +000033 bool Canonical)
Douglas Gregor5c193b92009-07-28 00:33:38 +000034 : ID(ID), Context(Context), Canonical(Canonical) { }
Mike Stump11289f42009-09-09 15:08:12 +000035
Chandler Carruth631abd92011-06-16 06:47:06 +000036 void VisitStmt(const Stmt *S);
Mike Stump11289f42009-09-09 15:08:12 +000037
Chandler Carruth631abd92011-06-16 06:47:06 +000038#define STMT(Node, Base) void Visit##Node(const Node *S);
Alexis Hunt656bb312010-05-05 15:24:00 +000039#include "clang/AST/StmtNodes.inc"
Mike Stump11289f42009-09-09 15:08:12 +000040
Douglas Gregor5c193b92009-07-28 00:33:38 +000041 /// \brief Visit a declaration that is referenced within an expression
42 /// or statement.
Chandler Carruth631abd92011-06-16 06:47:06 +000043 void VisitDecl(const Decl *D);
Mike Stump11289f42009-09-09 15:08:12 +000044
45 /// \brief Visit a type that is referenced within an expression or
Douglas Gregor5c193b92009-07-28 00:33:38 +000046 /// statement.
47 void VisitType(QualType T);
Mike Stump11289f42009-09-09 15:08:12 +000048
Douglas Gregor5c193b92009-07-28 00:33:38 +000049 /// \brief Visit a name that occurs within an expression or statement.
50 void VisitName(DeclarationName Name);
Mike Stump11289f42009-09-09 15:08:12 +000051
Douglas Gregor5c193b92009-07-28 00:33:38 +000052 /// \brief Visit a nested-name-specifier that occurs within an expression
53 /// or statement.
54 void VisitNestedNameSpecifier(NestedNameSpecifier *NNS);
Mike Stump11289f42009-09-09 15:08:12 +000055
Douglas Gregor5c193b92009-07-28 00:33:38 +000056 /// \brief Visit a template name that occurs within an expression or
57 /// statement.
58 void VisitTemplateName(TemplateName Name);
Mike Stump11289f42009-09-09 15:08:12 +000059
Douglas Gregor5c193b92009-07-28 00:33:38 +000060 /// \brief Visit template arguments that occur within an expression or
61 /// statement.
Chandler Carruth631abd92011-06-16 06:47:06 +000062 void VisitTemplateArguments(const TemplateArgumentLoc *Args,
63 unsigned NumArgs);
John McCall0ad16662009-10-29 08:12:44 +000064
65 /// \brief Visit a single template argument.
66 void VisitTemplateArgument(const TemplateArgument &Arg);
Douglas Gregor5c193b92009-07-28 00:33:38 +000067 };
68}
69
Chandler Carruth631abd92011-06-16 06:47:06 +000070void StmtProfiler::VisitStmt(const Stmt *S) {
Douglas Gregor5c193b92009-07-28 00:33:38 +000071 ID.AddInteger(S->getStmtClass());
Peter Collingbournecdb9f302012-03-01 16:34:31 +000072 for (Stmt::const_child_range C = S->children(); C; ++C) {
73 if (*C)
74 Visit(*C);
75 else
76 ID.AddInteger(0);
77 }
Douglas Gregor5c193b92009-07-28 00:33:38 +000078}
79
Chandler Carruth631abd92011-06-16 06:47:06 +000080void StmtProfiler::VisitDeclStmt(const DeclStmt *S) {
Douglas Gregor44882592009-07-28 15:27:13 +000081 VisitStmt(S);
Aaron Ballman535bbcc2014-03-14 17:01:24 +000082 for (const auto *D : S->decls())
83 VisitDecl(D);
Douglas Gregor44882592009-07-28 15:27:13 +000084}
85
Chandler Carruth631abd92011-06-16 06:47:06 +000086void StmtProfiler::VisitNullStmt(const NullStmt *S) {
Douglas Gregor44882592009-07-28 15:27:13 +000087 VisitStmt(S);
88}
89
Chandler Carruth631abd92011-06-16 06:47:06 +000090void StmtProfiler::VisitCompoundStmt(const CompoundStmt *S) {
Douglas Gregor44882592009-07-28 15:27:13 +000091 VisitStmt(S);
92}
93
Chandler Carruth631abd92011-06-16 06:47:06 +000094void StmtProfiler::VisitSwitchCase(const SwitchCase *S) {
Douglas Gregor44882592009-07-28 15:27:13 +000095 VisitStmt(S);
96}
97
Chandler Carruth631abd92011-06-16 06:47:06 +000098void StmtProfiler::VisitCaseStmt(const CaseStmt *S) {
Douglas Gregor44882592009-07-28 15:27:13 +000099 VisitStmt(S);
100}
101
Chandler Carruth631abd92011-06-16 06:47:06 +0000102void StmtProfiler::VisitDefaultStmt(const DefaultStmt *S) {
Douglas Gregor44882592009-07-28 15:27:13 +0000103 VisitStmt(S);
104}
105
Chandler Carruth631abd92011-06-16 06:47:06 +0000106void StmtProfiler::VisitLabelStmt(const LabelStmt *S) {
Douglas Gregor44882592009-07-28 15:27:13 +0000107 VisitStmt(S);
Chris Lattnerc8e630e2011-02-17 07:39:24 +0000108 VisitDecl(S->getDecl());
Douglas Gregor44882592009-07-28 15:27:13 +0000109}
110
Richard Smithc202b282012-04-14 00:33:13 +0000111void StmtProfiler::VisitAttributedStmt(const AttributedStmt *S) {
112 VisitStmt(S);
113 // TODO: maybe visit attributes?
114}
115
Chandler Carruth631abd92011-06-16 06:47:06 +0000116void StmtProfiler::VisitIfStmt(const IfStmt *S) {
Douglas Gregor44882592009-07-28 15:27:13 +0000117 VisitStmt(S);
Douglas Gregor7bab5ff2009-11-25 00:27:52 +0000118 VisitDecl(S->getConditionVariable());
Douglas Gregor44882592009-07-28 15:27:13 +0000119}
120
Chandler Carruth631abd92011-06-16 06:47:06 +0000121void StmtProfiler::VisitSwitchStmt(const SwitchStmt *S) {
Douglas Gregor00044172009-07-29 16:09:57 +0000122 VisitStmt(S);
Douglas Gregor7bab5ff2009-11-25 00:27:52 +0000123 VisitDecl(S->getConditionVariable());
Douglas Gregor00044172009-07-29 16:09:57 +0000124}
125
Chandler Carruth631abd92011-06-16 06:47:06 +0000126void StmtProfiler::VisitWhileStmt(const WhileStmt *S) {
Douglas Gregor44882592009-07-28 15:27:13 +0000127 VisitStmt(S);
Douglas Gregor7bab5ff2009-11-25 00:27:52 +0000128 VisitDecl(S->getConditionVariable());
Douglas Gregor44882592009-07-28 15:27:13 +0000129}
130
Chandler Carruth631abd92011-06-16 06:47:06 +0000131void StmtProfiler::VisitDoStmt(const DoStmt *S) {
Douglas Gregor44882592009-07-28 15:27:13 +0000132 VisitStmt(S);
133}
134
Chandler Carruth631abd92011-06-16 06:47:06 +0000135void StmtProfiler::VisitForStmt(const ForStmt *S) {
Douglas Gregor44882592009-07-28 15:27:13 +0000136 VisitStmt(S);
137}
138
Chandler Carruth631abd92011-06-16 06:47:06 +0000139void StmtProfiler::VisitGotoStmt(const GotoStmt *S) {
Douglas Gregor44882592009-07-28 15:27:13 +0000140 VisitStmt(S);
Chris Lattnerc8e630e2011-02-17 07:39:24 +0000141 VisitDecl(S->getLabel());
Douglas Gregor44882592009-07-28 15:27:13 +0000142}
143
Chandler Carruth631abd92011-06-16 06:47:06 +0000144void StmtProfiler::VisitIndirectGotoStmt(const IndirectGotoStmt *S) {
Douglas Gregor44882592009-07-28 15:27:13 +0000145 VisitStmt(S);
146}
147
Chandler Carruth631abd92011-06-16 06:47:06 +0000148void StmtProfiler::VisitContinueStmt(const ContinueStmt *S) {
Douglas Gregor44882592009-07-28 15:27:13 +0000149 VisitStmt(S);
150}
151
Chandler Carruth631abd92011-06-16 06:47:06 +0000152void StmtProfiler::VisitBreakStmt(const BreakStmt *S) {
Douglas Gregor44882592009-07-28 15:27:13 +0000153 VisitStmt(S);
154}
155
Chandler Carruth631abd92011-06-16 06:47:06 +0000156void StmtProfiler::VisitReturnStmt(const ReturnStmt *S) {
Douglas Gregor44882592009-07-28 15:27:13 +0000157 VisitStmt(S);
158}
159
Chad Rosierde70e0e2012-08-25 00:11:56 +0000160void StmtProfiler::VisitGCCAsmStmt(const GCCAsmStmt *S) {
Douglas Gregor44882592009-07-28 15:27:13 +0000161 VisitStmt(S);
162 ID.AddBoolean(S->isVolatile());
163 ID.AddBoolean(S->isSimple());
164 VisitStringLiteral(S->getAsmString());
165 ID.AddInteger(S->getNumOutputs());
166 for (unsigned I = 0, N = S->getNumOutputs(); I != N; ++I) {
167 ID.AddString(S->getOutputName(I));
168 VisitStringLiteral(S->getOutputConstraintLiteral(I));
169 }
170 ID.AddInteger(S->getNumInputs());
171 for (unsigned I = 0, N = S->getNumInputs(); I != N; ++I) {
172 ID.AddString(S->getInputName(I));
173 VisitStringLiteral(S->getInputConstraintLiteral(I));
174 }
175 ID.AddInteger(S->getNumClobbers());
176 for (unsigned I = 0, N = S->getNumClobbers(); I != N; ++I)
Chad Rosierd9fb09a2012-08-27 23:28:41 +0000177 VisitStringLiteral(S->getClobberStringLiteral(I));
Douglas Gregor44882592009-07-28 15:27:13 +0000178}
179
Chad Rosier32503022012-06-11 20:47:18 +0000180void StmtProfiler::VisitMSAsmStmt(const MSAsmStmt *S) {
181 // FIXME: Implement MS style inline asm statement profiler.
182 VisitStmt(S);
183}
184
Chandler Carruth631abd92011-06-16 06:47:06 +0000185void StmtProfiler::VisitCXXCatchStmt(const CXXCatchStmt *S) {
Douglas Gregor44882592009-07-28 15:27:13 +0000186 VisitStmt(S);
187 VisitType(S->getCaughtType());
188}
189
Chandler Carruth631abd92011-06-16 06:47:06 +0000190void StmtProfiler::VisitCXXTryStmt(const CXXTryStmt *S) {
Douglas Gregor44882592009-07-28 15:27:13 +0000191 VisitStmt(S);
192}
193
Chandler Carruth631abd92011-06-16 06:47:06 +0000194void StmtProfiler::VisitCXXForRangeStmt(const CXXForRangeStmt *S) {
Richard Smith02e85f32011-04-14 22:09:26 +0000195 VisitStmt(S);
196}
197
Douglas Gregordeb4a2be2011-10-25 01:33:02 +0000198void StmtProfiler::VisitMSDependentExistsStmt(const MSDependentExistsStmt *S) {
199 VisitStmt(S);
200 ID.AddBoolean(S->isIfExists());
201 VisitNestedNameSpecifier(S->getQualifierLoc().getNestedNameSpecifier());
202 VisitName(S->getNameInfo().getName());
203}
204
Chandler Carruth631abd92011-06-16 06:47:06 +0000205void StmtProfiler::VisitSEHTryStmt(const SEHTryStmt *S) {
John Wiegley1c0675e2011-04-28 01:08:34 +0000206 VisitStmt(S);
207}
208
Chandler Carruth631abd92011-06-16 06:47:06 +0000209void StmtProfiler::VisitSEHFinallyStmt(const SEHFinallyStmt *S) {
John Wiegley1c0675e2011-04-28 01:08:34 +0000210 VisitStmt(S);
211}
212
Chandler Carruth631abd92011-06-16 06:47:06 +0000213void StmtProfiler::VisitSEHExceptStmt(const SEHExceptStmt *S) {
John Wiegley1c0675e2011-04-28 01:08:34 +0000214 VisitStmt(S);
215}
216
Nico Weber9b982072014-07-07 00:12:30 +0000217void StmtProfiler::VisitSEHLeaveStmt(const SEHLeaveStmt *S) {
218 VisitStmt(S);
219}
220
Tareq A. Siraj24110cc2013-04-16 18:53:08 +0000221void StmtProfiler::VisitCapturedStmt(const CapturedStmt *S) {
222 VisitStmt(S);
223}
224
Chandler Carruth631abd92011-06-16 06:47:06 +0000225void StmtProfiler::VisitObjCForCollectionStmt(const ObjCForCollectionStmt *S) {
Douglas Gregor44882592009-07-28 15:27:13 +0000226 VisitStmt(S);
227}
228
Chandler Carruth631abd92011-06-16 06:47:06 +0000229void StmtProfiler::VisitObjCAtCatchStmt(const ObjCAtCatchStmt *S) {
Douglas Gregor44882592009-07-28 15:27:13 +0000230 VisitStmt(S);
231 ID.AddBoolean(S->hasEllipsis());
232 if (S->getCatchParamDecl())
233 VisitType(S->getCatchParamDecl()->getType());
234}
235
Chandler Carruth631abd92011-06-16 06:47:06 +0000236void StmtProfiler::VisitObjCAtFinallyStmt(const ObjCAtFinallyStmt *S) {
Douglas Gregor44882592009-07-28 15:27:13 +0000237 VisitStmt(S);
238}
239
Chandler Carruth631abd92011-06-16 06:47:06 +0000240void StmtProfiler::VisitObjCAtTryStmt(const ObjCAtTryStmt *S) {
Douglas Gregor44882592009-07-28 15:27:13 +0000241 VisitStmt(S);
242}
243
Chandler Carruth631abd92011-06-16 06:47:06 +0000244void
245StmtProfiler::VisitObjCAtSynchronizedStmt(const ObjCAtSynchronizedStmt *S) {
Douglas Gregor44882592009-07-28 15:27:13 +0000246 VisitStmt(S);
247}
248
Chandler Carruth631abd92011-06-16 06:47:06 +0000249void StmtProfiler::VisitObjCAtThrowStmt(const ObjCAtThrowStmt *S) {
Douglas Gregor44882592009-07-28 15:27:13 +0000250 VisitStmt(S);
251}
252
Chandler Carruth631abd92011-06-16 06:47:06 +0000253void
254StmtProfiler::VisitObjCAutoreleasePoolStmt(const ObjCAutoreleasePoolStmt *S) {
John McCall31168b02011-06-15 23:02:42 +0000255 VisitStmt(S);
256}
257
Alexey Bataev5ec3eb12013-07-19 03:13:43 +0000258namespace {
259class OMPClauseProfiler : public ConstOMPClauseVisitor<OMPClauseProfiler> {
260 StmtProfiler *Profiler;
Alexey Bataev756c1962013-09-24 03:17:45 +0000261 /// \brief Process clauses with list of variables.
262 template <typename T>
263 void VisitOMPClauseList(T *Node);
Alexey Bataev5ec3eb12013-07-19 03:13:43 +0000264public:
265 OMPClauseProfiler(StmtProfiler *P) : Profiler(P) { }
266#define OPENMP_CLAUSE(Name, Class) \
267 void Visit##Class(const Class *C);
268#include "clang/Basic/OpenMPKinds.def"
269};
270
Alexey Bataevaadd52e2014-02-13 05:29:23 +0000271void OMPClauseProfiler::VisitOMPIfClause(const OMPIfClause *C) {
272 if (C->getCondition())
273 Profiler->VisitStmt(C->getCondition());
274}
275
Alexey Bataev3778b602014-07-17 07:32:53 +0000276void OMPClauseProfiler::VisitOMPFinalClause(const OMPFinalClause *C) {
277 if (C->getCondition())
278 Profiler->VisitStmt(C->getCondition());
279}
280
Alexey Bataev568a8332014-03-06 06:15:19 +0000281void OMPClauseProfiler::VisitOMPNumThreadsClause(const OMPNumThreadsClause *C) {
282 if (C->getNumThreads())
283 Profiler->VisitStmt(C->getNumThreads());
284}
285
Alexey Bataev62c87d22014-03-21 04:51:18 +0000286void OMPClauseProfiler::VisitOMPSafelenClause(const OMPSafelenClause *C) {
287 if (C->getSafelen())
288 Profiler->VisitStmt(C->getSafelen());
289}
290
Alexander Musman8bd31e62014-05-27 15:12:19 +0000291void OMPClauseProfiler::VisitOMPCollapseClause(const OMPCollapseClause *C) {
292 if (C->getNumForLoops())
293 Profiler->VisitStmt(C->getNumForLoops());
294}
295
Alexey Bataev5ec3eb12013-07-19 03:13:43 +0000296void OMPClauseProfiler::VisitOMPDefaultClause(const OMPDefaultClause *C) { }
Alexey Bataev756c1962013-09-24 03:17:45 +0000297
Alexey Bataevbcbadb62014-05-06 06:04:14 +0000298void OMPClauseProfiler::VisitOMPProcBindClause(const OMPProcBindClause *C) { }
299
Alexey Bataev56dafe82014-06-20 07:16:17 +0000300void OMPClauseProfiler::VisitOMPScheduleClause(const OMPScheduleClause *C) {
301 if (C->getChunkSize())
302 Profiler->VisitStmt(C->getChunkSize());
303}
304
Alexey Bataev142e1fc2014-06-20 09:44:06 +0000305void OMPClauseProfiler::VisitOMPOrderedClause(const OMPOrderedClause *) {}
306
Alexey Bataev236070f2014-06-20 11:19:47 +0000307void OMPClauseProfiler::VisitOMPNowaitClause(const OMPNowaitClause *) {}
308
Alexey Bataev7aea99a2014-07-17 12:19:31 +0000309void OMPClauseProfiler::VisitOMPUntiedClause(const OMPUntiedClause *) {}
310
Alexey Bataev74ba3a52014-07-17 12:47:03 +0000311void OMPClauseProfiler::VisitOMPMergeableClause(const OMPMergeableClause *) {}
312
Alexey Bataevf98b00c2014-07-23 02:27:21 +0000313void OMPClauseProfiler::VisitOMPReadClause(const OMPReadClause *) {}
314
Alexey Bataevdea47612014-07-23 07:46:59 +0000315void OMPClauseProfiler::VisitOMPWriteClause(const OMPWriteClause *) {}
316
Alexey Bataev67a4f222014-07-23 10:25:33 +0000317void OMPClauseProfiler::VisitOMPUpdateClause(const OMPUpdateClause *) {}
318
Alexey Bataev459dec02014-07-24 06:46:57 +0000319void OMPClauseProfiler::VisitOMPCaptureClause(const OMPCaptureClause *) {}
320
Alexey Bataev82bad8b2014-07-24 08:55:34 +0000321void OMPClauseProfiler::VisitOMPSeqCstClause(const OMPSeqCstClause *) {}
322
Alexey Bataev756c1962013-09-24 03:17:45 +0000323template<typename T>
324void OMPClauseProfiler::VisitOMPClauseList(T *Node) {
Alexey Bataev03b340a2014-10-21 03:16:40 +0000325 for (auto *E : Node->varlists()) {
326 Profiler->VisitStmt(E);
327 }
Alexey Bataev756c1962013-09-24 03:17:45 +0000328}
Alexey Bataev5ec3eb12013-07-19 03:13:43 +0000329
330void OMPClauseProfiler::VisitOMPPrivateClause(const OMPPrivateClause *C) {
Alexey Bataev756c1962013-09-24 03:17:45 +0000331 VisitOMPClauseList(C);
Alexey Bataev03b340a2014-10-21 03:16:40 +0000332 for (auto *E : C->private_copies()) {
333 Profiler->VisitStmt(E);
334 }
Alexey Bataev5ec3eb12013-07-19 03:13:43 +0000335}
Alexey Bataev4a5bb772014-10-08 14:01:46 +0000336void
337OMPClauseProfiler::VisitOMPFirstprivateClause(const OMPFirstprivateClause *C) {
Alexey Bataevd5af8e42013-10-01 05:32:34 +0000338 VisitOMPClauseList(C);
Alexey Bataev4a5bb772014-10-08 14:01:46 +0000339 for (auto *E : C->private_copies()) {
340 Profiler->VisitStmt(E);
341 }
342 for (auto *E : C->inits()) {
343 Profiler->VisitStmt(E);
344 }
Alexey Bataevd5af8e42013-10-01 05:32:34 +0000345}
Alexander Musman1bb328c2014-06-04 13:06:39 +0000346void
347OMPClauseProfiler::VisitOMPLastprivateClause(const OMPLastprivateClause *C) {
348 VisitOMPClauseList(C);
Alexey Bataev38e89532015-04-16 04:54:05 +0000349 for (auto *E : C->source_exprs()) {
350 Profiler->VisitStmt(E);
351 }
352 for (auto *E : C->destination_exprs()) {
353 Profiler->VisitStmt(E);
354 }
355 for (auto *E : C->assignment_ops()) {
356 Profiler->VisitStmt(E);
357 }
Alexander Musman1bb328c2014-06-04 13:06:39 +0000358}
Alexey Bataev758e55e2013-09-06 18:03:48 +0000359void OMPClauseProfiler::VisitOMPSharedClause(const OMPSharedClause *C) {
Alexey Bataev756c1962013-09-24 03:17:45 +0000360 VisitOMPClauseList(C);
Alexey Bataev758e55e2013-09-06 18:03:48 +0000361}
Alexey Bataevc5e02582014-06-16 07:08:35 +0000362void OMPClauseProfiler::VisitOMPReductionClause(
363 const OMPReductionClause *C) {
364 Profiler->VisitNestedNameSpecifier(
365 C->getQualifierLoc().getNestedNameSpecifier());
366 Profiler->VisitName(C->getNameInfo().getName());
367 VisitOMPClauseList(C);
Alexey Bataev794ba0d2015-04-10 10:43:45 +0000368 for (auto *E : C->lhs_exprs()) {
369 Profiler->VisitStmt(E);
370 }
371 for (auto *E : C->rhs_exprs()) {
372 Profiler->VisitStmt(E);
373 }
374 for (auto *E : C->reduction_ops()) {
375 Profiler->VisitStmt(E);
376 }
Alexey Bataevc5e02582014-06-16 07:08:35 +0000377}
Alexander Musman8dba6642014-04-22 13:09:42 +0000378void OMPClauseProfiler::VisitOMPLinearClause(const OMPLinearClause *C) {
379 VisitOMPClauseList(C);
Alexander Musman3276a272015-03-21 10:12:56 +0000380 for (auto *E : C->inits()) {
381 Profiler->VisitStmt(E);
382 }
383 for (auto *E : C->updates()) {
384 Profiler->VisitStmt(E);
385 }
386 for (auto *E : C->finals()) {
387 Profiler->VisitStmt(E);
388 }
Alexander Musman8dba6642014-04-22 13:09:42 +0000389 Profiler->VisitStmt(C->getStep());
Alexander Musman3276a272015-03-21 10:12:56 +0000390 Profiler->VisitStmt(C->getCalcStep());
Alexander Musman8dba6642014-04-22 13:09:42 +0000391}
Alexander Musmanf0d76e72014-05-29 14:36:25 +0000392void OMPClauseProfiler::VisitOMPAlignedClause(const OMPAlignedClause *C) {
393 VisitOMPClauseList(C);
394 Profiler->VisitStmt(C->getAlignment());
395}
Alexey Bataevd48bcd82014-03-31 03:36:38 +0000396void OMPClauseProfiler::VisitOMPCopyinClause(const OMPCopyinClause *C) {
397 VisitOMPClauseList(C);
398}
Alexey Bataevbae9a792014-06-27 10:37:06 +0000399void
400OMPClauseProfiler::VisitOMPCopyprivateClause(const OMPCopyprivateClause *C) {
401 VisitOMPClauseList(C);
Alexey Bataeva63048e2015-03-23 06:18:07 +0000402 for (auto *E : C->source_exprs()) {
403 Profiler->VisitStmt(E);
404 }
405 for (auto *E : C->destination_exprs()) {
406 Profiler->VisitStmt(E);
407 }
408 for (auto *E : C->assignment_ops()) {
409 Profiler->VisitStmt(E);
410 }
Alexey Bataevbae9a792014-06-27 10:37:06 +0000411}
Alexey Bataev6125da92014-07-21 11:26:11 +0000412void OMPClauseProfiler::VisitOMPFlushClause(const OMPFlushClause *C) {
413 VisitOMPClauseList(C);
414}
Alexey Bataev5ec3eb12013-07-19 03:13:43 +0000415}
416
417void
Alexey Bataev1b59ab52014-02-27 08:29:12 +0000418StmtProfiler::VisitOMPExecutableDirective(const OMPExecutableDirective *S) {
Alexey Bataev5ec3eb12013-07-19 03:13:43 +0000419 VisitStmt(S);
420 OMPClauseProfiler P(this);
421 ArrayRef<OMPClause *> Clauses = S->clauses();
422 for (ArrayRef<OMPClause *>::iterator I = Clauses.begin(), E = Clauses.end();
423 I != E; ++I)
424 if (*I)
425 P.Visit(*I);
426}
427
Alexander Musman3aaab662014-08-19 11:27:13 +0000428void StmtProfiler::VisitOMPLoopDirective(const OMPLoopDirective *S) {
429 VisitOMPExecutableDirective(S);
430}
431
Alexey Bataev1b59ab52014-02-27 08:29:12 +0000432void StmtProfiler::VisitOMPParallelDirective(const OMPParallelDirective *S) {
433 VisitOMPExecutableDirective(S);
434}
435
436void StmtProfiler::VisitOMPSimdDirective(const OMPSimdDirective *S) {
Alexander Musman3aaab662014-08-19 11:27:13 +0000437 VisitOMPLoopDirective(S);
Alexey Bataev1b59ab52014-02-27 08:29:12 +0000438}
439
Alexey Bataevf29276e2014-06-18 04:14:57 +0000440void StmtProfiler::VisitOMPForDirective(const OMPForDirective *S) {
Alexander Musman3aaab662014-08-19 11:27:13 +0000441 VisitOMPLoopDirective(S);
Alexey Bataevf29276e2014-06-18 04:14:57 +0000442}
443
Alexander Musmanf82886e2014-09-18 05:12:34 +0000444void StmtProfiler::VisitOMPForSimdDirective(const OMPForSimdDirective *S) {
445 VisitOMPLoopDirective(S);
446}
447
Alexey Bataevd3f8dd22014-06-25 11:44:49 +0000448void StmtProfiler::VisitOMPSectionsDirective(const OMPSectionsDirective *S) {
449 VisitOMPExecutableDirective(S);
450}
451
Alexey Bataev1e0498a2014-06-26 08:21:58 +0000452void StmtProfiler::VisitOMPSectionDirective(const OMPSectionDirective *S) {
453 VisitOMPExecutableDirective(S);
454}
455
Alexey Bataevd1e40fb2014-06-26 12:05:45 +0000456void StmtProfiler::VisitOMPSingleDirective(const OMPSingleDirective *S) {
457 VisitOMPExecutableDirective(S);
458}
459
Alexander Musman80c22892014-07-17 08:54:58 +0000460void StmtProfiler::VisitOMPMasterDirective(const OMPMasterDirective *S) {
461 VisitOMPExecutableDirective(S);
462}
463
Alexander Musmand9ed09f2014-07-21 09:42:05 +0000464void StmtProfiler::VisitOMPCriticalDirective(const OMPCriticalDirective *S) {
465 VisitOMPExecutableDirective(S);
466 VisitName(S->getDirectiveName().getName());
467}
468
Alexey Bataev4acb8592014-07-07 13:01:15 +0000469void
470StmtProfiler::VisitOMPParallelForDirective(const OMPParallelForDirective *S) {
Alexander Musman3aaab662014-08-19 11:27:13 +0000471 VisitOMPLoopDirective(S);
Alexey Bataev4acb8592014-07-07 13:01:15 +0000472}
473
Alexander Musmane4e893b2014-09-23 09:33:00 +0000474void StmtProfiler::VisitOMPParallelForSimdDirective(
475 const OMPParallelForSimdDirective *S) {
476 VisitOMPLoopDirective(S);
477}
478
Alexey Bataev84d0b3e2014-07-08 08:12:03 +0000479void StmtProfiler::VisitOMPParallelSectionsDirective(
480 const OMPParallelSectionsDirective *S) {
481 VisitOMPExecutableDirective(S);
482}
483
Alexey Bataev9c2e8ee2014-07-11 11:25:16 +0000484void StmtProfiler::VisitOMPTaskDirective(const OMPTaskDirective *S) {
485 VisitOMPExecutableDirective(S);
486}
487
Alexey Bataev68446b72014-07-18 07:47:19 +0000488void StmtProfiler::VisitOMPTaskyieldDirective(const OMPTaskyieldDirective *S) {
489 VisitOMPExecutableDirective(S);
490}
491
Alexey Bataev4d1dfea2014-07-18 09:11:51 +0000492void StmtProfiler::VisitOMPBarrierDirective(const OMPBarrierDirective *S) {
493 VisitOMPExecutableDirective(S);
494}
495
Alexey Bataev2df347a2014-07-18 10:17:07 +0000496void StmtProfiler::VisitOMPTaskwaitDirective(const OMPTaskwaitDirective *S) {
497 VisitOMPExecutableDirective(S);
498}
499
Alexey Bataev6125da92014-07-21 11:26:11 +0000500void StmtProfiler::VisitOMPFlushDirective(const OMPFlushDirective *S) {
501 VisitOMPExecutableDirective(S);
502}
503
Alexey Bataev9fb6e642014-07-22 06:45:04 +0000504void StmtProfiler::VisitOMPOrderedDirective(const OMPOrderedDirective *S) {
505 VisitOMPExecutableDirective(S);
506}
507
Alexey Bataev0162e452014-07-22 10:10:35 +0000508void StmtProfiler::VisitOMPAtomicDirective(const OMPAtomicDirective *S) {
509 VisitOMPExecutableDirective(S);
510}
511
Alexey Bataev0bd520b2014-09-19 08:19:49 +0000512void StmtProfiler::VisitOMPTargetDirective(const OMPTargetDirective *S) {
513 VisitOMPExecutableDirective(S);
514}
515
Alexey Bataev13314bf2014-10-09 04:18:56 +0000516void StmtProfiler::VisitOMPTeamsDirective(const OMPTeamsDirective *S) {
517 VisitOMPExecutableDirective(S);
518}
519
Chandler Carruth631abd92011-06-16 06:47:06 +0000520void StmtProfiler::VisitExpr(const Expr *S) {
Douglas Gregor5c193b92009-07-28 00:33:38 +0000521 VisitStmt(S);
522}
523
Chandler Carruth631abd92011-06-16 06:47:06 +0000524void StmtProfiler::VisitDeclRefExpr(const DeclRefExpr *S) {
Douglas Gregor5c193b92009-07-28 00:33:38 +0000525 VisitExpr(S);
Douglas Gregorf5b160f2010-07-13 08:37:11 +0000526 if (!Canonical)
527 VisitNestedNameSpecifier(S->getQualifier());
Douglas Gregor5c193b92009-07-28 00:33:38 +0000528 VisitDecl(S->getDecl());
Douglas Gregorf5b160f2010-07-13 08:37:11 +0000529 if (!Canonical)
530 VisitTemplateArguments(S->getTemplateArgs(), S->getNumTemplateArgs());
Douglas Gregor5c193b92009-07-28 00:33:38 +0000531}
532
Chandler Carruth631abd92011-06-16 06:47:06 +0000533void StmtProfiler::VisitPredefinedExpr(const PredefinedExpr *S) {
Douglas Gregor5c193b92009-07-28 00:33:38 +0000534 VisitExpr(S);
535 ID.AddInteger(S->getIdentType());
536}
537
Chandler Carruth631abd92011-06-16 06:47:06 +0000538void StmtProfiler::VisitIntegerLiteral(const IntegerLiteral *S) {
Douglas Gregor5c193b92009-07-28 00:33:38 +0000539 VisitExpr(S);
540 S->getValue().Profile(ID);
Richard Smithe9f130c2014-11-20 03:37:32 +0000541 ID.AddInteger(S->getType()->castAs<BuiltinType>()->getKind());
Douglas Gregor5c193b92009-07-28 00:33:38 +0000542}
543
Chandler Carruth631abd92011-06-16 06:47:06 +0000544void StmtProfiler::VisitCharacterLiteral(const CharacterLiteral *S) {
Douglas Gregor5c193b92009-07-28 00:33:38 +0000545 VisitExpr(S);
Douglas Gregorfb65e592011-07-27 05:40:30 +0000546 ID.AddInteger(S->getKind());
Douglas Gregor5c193b92009-07-28 00:33:38 +0000547 ID.AddInteger(S->getValue());
548}
549
Chandler Carruth631abd92011-06-16 06:47:06 +0000550void StmtProfiler::VisitFloatingLiteral(const FloatingLiteral *S) {
Douglas Gregor5c193b92009-07-28 00:33:38 +0000551 VisitExpr(S);
552 S->getValue().Profile(ID);
553 ID.AddBoolean(S->isExact());
Richard Smithe9f130c2014-11-20 03:37:32 +0000554 ID.AddInteger(S->getType()->castAs<BuiltinType>()->getKind());
Douglas Gregor5c193b92009-07-28 00:33:38 +0000555}
556
Chandler Carruth631abd92011-06-16 06:47:06 +0000557void StmtProfiler::VisitImaginaryLiteral(const ImaginaryLiteral *S) {
Douglas Gregor5c193b92009-07-28 00:33:38 +0000558 VisitExpr(S);
559}
560
Chandler Carruth631abd92011-06-16 06:47:06 +0000561void StmtProfiler::VisitStringLiteral(const StringLiteral *S) {
Douglas Gregor5c193b92009-07-28 00:33:38 +0000562 VisitExpr(S);
Douglas Gregor9d0eb8f2011-11-02 17:26:05 +0000563 ID.AddString(S->getBytes());
Douglas Gregorfb65e592011-07-27 05:40:30 +0000564 ID.AddInteger(S->getKind());
Douglas Gregor5c193b92009-07-28 00:33:38 +0000565}
566
Chandler Carruth631abd92011-06-16 06:47:06 +0000567void StmtProfiler::VisitParenExpr(const ParenExpr *S) {
Douglas Gregor5c193b92009-07-28 00:33:38 +0000568 VisitExpr(S);
569}
570
Chandler Carruth631abd92011-06-16 06:47:06 +0000571void StmtProfiler::VisitParenListExpr(const ParenListExpr *S) {
Nate Begeman5ec4b312009-08-10 23:49:36 +0000572 VisitExpr(S);
573}
574
Chandler Carruth631abd92011-06-16 06:47:06 +0000575void StmtProfiler::VisitUnaryOperator(const UnaryOperator *S) {
Douglas Gregor5c193b92009-07-28 00:33:38 +0000576 VisitExpr(S);
577 ID.AddInteger(S->getOpcode());
578}
579
Chandler Carruth631abd92011-06-16 06:47:06 +0000580void StmtProfiler::VisitOffsetOfExpr(const OffsetOfExpr *S) {
Douglas Gregor882211c2010-04-28 22:16:22 +0000581 VisitType(S->getTypeSourceInfo()->getType());
582 unsigned n = S->getNumComponents();
583 for (unsigned i = 0; i < n; ++i) {
584 const OffsetOfExpr::OffsetOfNode& ON = S->getComponent(i);
585 ID.AddInteger(ON.getKind());
586 switch (ON.getKind()) {
587 case OffsetOfExpr::OffsetOfNode::Array:
588 // Expressions handled below.
589 break;
590
591 case OffsetOfExpr::OffsetOfNode::Field:
592 VisitDecl(ON.getField());
593 break;
594
595 case OffsetOfExpr::OffsetOfNode::Identifier:
596 ID.AddPointer(ON.getFieldName());
597 break;
Alexis Hunta8136cc2010-05-05 15:23:54 +0000598
Douglas Gregord1702062010-04-29 00:18:15 +0000599 case OffsetOfExpr::OffsetOfNode::Base:
600 // These nodes are implicit, and therefore don't need profiling.
601 break;
Douglas Gregor882211c2010-04-28 22:16:22 +0000602 }
603 }
Alexis Hunta8136cc2010-05-05 15:23:54 +0000604
Douglas Gregor882211c2010-04-28 22:16:22 +0000605 VisitExpr(S);
606}
607
Chandler Carruth631abd92011-06-16 06:47:06 +0000608void
609StmtProfiler::VisitUnaryExprOrTypeTraitExpr(const UnaryExprOrTypeTraitExpr *S) {
Douglas Gregor5c193b92009-07-28 00:33:38 +0000610 VisitExpr(S);
Peter Collingbournee190dee2011-03-11 19:24:49 +0000611 ID.AddInteger(S->getKind());
Douglas Gregor5c193b92009-07-28 00:33:38 +0000612 if (S->isArgumentType())
613 VisitType(S->getArgumentType());
614}
615
Chandler Carruth631abd92011-06-16 06:47:06 +0000616void StmtProfiler::VisitArraySubscriptExpr(const ArraySubscriptExpr *S) {
Douglas Gregor5c193b92009-07-28 00:33:38 +0000617 VisitExpr(S);
618}
619
Chandler Carruth631abd92011-06-16 06:47:06 +0000620void StmtProfiler::VisitCallExpr(const CallExpr *S) {
Douglas Gregor5c193b92009-07-28 00:33:38 +0000621 VisitExpr(S);
622}
623
Chandler Carruth631abd92011-06-16 06:47:06 +0000624void StmtProfiler::VisitMemberExpr(const MemberExpr *S) {
Douglas Gregor5c193b92009-07-28 00:33:38 +0000625 VisitExpr(S);
626 VisitDecl(S->getMemberDecl());
Douglas Gregorf5b160f2010-07-13 08:37:11 +0000627 if (!Canonical)
628 VisitNestedNameSpecifier(S->getQualifier());
Douglas Gregor5c193b92009-07-28 00:33:38 +0000629 ID.AddBoolean(S->isArrow());
630}
631
Chandler Carruth631abd92011-06-16 06:47:06 +0000632void StmtProfiler::VisitCompoundLiteralExpr(const CompoundLiteralExpr *S) {
Douglas Gregor5c193b92009-07-28 00:33:38 +0000633 VisitExpr(S);
634 ID.AddBoolean(S->isFileScope());
635}
636
Chandler Carruth631abd92011-06-16 06:47:06 +0000637void StmtProfiler::VisitCastExpr(const CastExpr *S) {
Douglas Gregor5c193b92009-07-28 00:33:38 +0000638 VisitExpr(S);
639}
640
Chandler Carruth631abd92011-06-16 06:47:06 +0000641void StmtProfiler::VisitImplicitCastExpr(const ImplicitCastExpr *S) {
Douglas Gregor5c193b92009-07-28 00:33:38 +0000642 VisitCastExpr(S);
John McCall2536c6d2010-08-25 10:28:54 +0000643 ID.AddInteger(S->getValueKind());
Douglas Gregor5c193b92009-07-28 00:33:38 +0000644}
645
Chandler Carruth631abd92011-06-16 06:47:06 +0000646void StmtProfiler::VisitExplicitCastExpr(const ExplicitCastExpr *S) {
Douglas Gregor5c193b92009-07-28 00:33:38 +0000647 VisitCastExpr(S);
648 VisitType(S->getTypeAsWritten());
649}
650
Chandler Carruth631abd92011-06-16 06:47:06 +0000651void StmtProfiler::VisitCStyleCastExpr(const CStyleCastExpr *S) {
Douglas Gregor5c193b92009-07-28 00:33:38 +0000652 VisitExplicitCastExpr(S);
653}
654
Chandler Carruth631abd92011-06-16 06:47:06 +0000655void StmtProfiler::VisitBinaryOperator(const BinaryOperator *S) {
Douglas Gregor5c193b92009-07-28 00:33:38 +0000656 VisitExpr(S);
657 ID.AddInteger(S->getOpcode());
658}
659
Chandler Carruth631abd92011-06-16 06:47:06 +0000660void
661StmtProfiler::VisitCompoundAssignOperator(const CompoundAssignOperator *S) {
Douglas Gregor5c193b92009-07-28 00:33:38 +0000662 VisitBinaryOperator(S);
663}
664
Chandler Carruth631abd92011-06-16 06:47:06 +0000665void StmtProfiler::VisitConditionalOperator(const ConditionalOperator *S) {
Douglas Gregor5c193b92009-07-28 00:33:38 +0000666 VisitExpr(S);
667}
668
Chandler Carruth631abd92011-06-16 06:47:06 +0000669void StmtProfiler::VisitBinaryConditionalOperator(
Chandler Carruthcf5f43c2011-06-21 23:26:32 +0000670 const BinaryConditionalOperator *S) {
John McCallc07a0c72011-02-17 10:25:35 +0000671 VisitExpr(S);
672}
673
Chandler Carruth631abd92011-06-16 06:47:06 +0000674void StmtProfiler::VisitAddrLabelExpr(const AddrLabelExpr *S) {
Douglas Gregor5c193b92009-07-28 00:33:38 +0000675 VisitExpr(S);
Chris Lattnerc8e630e2011-02-17 07:39:24 +0000676 VisitDecl(S->getLabel());
Douglas Gregor5c193b92009-07-28 00:33:38 +0000677}
678
Chandler Carruth631abd92011-06-16 06:47:06 +0000679void StmtProfiler::VisitStmtExpr(const StmtExpr *S) {
Douglas Gregor5c193b92009-07-28 00:33:38 +0000680 VisitExpr(S);
681}
682
Chandler Carruth631abd92011-06-16 06:47:06 +0000683void StmtProfiler::VisitShuffleVectorExpr(const ShuffleVectorExpr *S) {
Douglas Gregor5c193b92009-07-28 00:33:38 +0000684 VisitExpr(S);
685}
686
Hal Finkelc4d7c822013-09-18 03:29:45 +0000687void StmtProfiler::VisitConvertVectorExpr(const ConvertVectorExpr *S) {
688 VisitExpr(S);
689}
690
Chandler Carruth631abd92011-06-16 06:47:06 +0000691void StmtProfiler::VisitChooseExpr(const ChooseExpr *S) {
Douglas Gregor5c193b92009-07-28 00:33:38 +0000692 VisitExpr(S);
693}
694
Chandler Carruth631abd92011-06-16 06:47:06 +0000695void StmtProfiler::VisitGNUNullExpr(const GNUNullExpr *S) {
Douglas Gregor5c193b92009-07-28 00:33:38 +0000696 VisitExpr(S);
697}
698
Chandler Carruth631abd92011-06-16 06:47:06 +0000699void StmtProfiler::VisitVAArgExpr(const VAArgExpr *S) {
Douglas Gregor00044172009-07-29 16:09:57 +0000700 VisitExpr(S);
701}
702
Chandler Carruth631abd92011-06-16 06:47:06 +0000703void StmtProfiler::VisitInitListExpr(const InitListExpr *S) {
Douglas Gregor5c193b92009-07-28 00:33:38 +0000704 if (S->getSyntacticForm()) {
705 VisitInitListExpr(S->getSyntacticForm());
706 return;
707 }
Mike Stump11289f42009-09-09 15:08:12 +0000708
Douglas Gregor5c193b92009-07-28 00:33:38 +0000709 VisitExpr(S);
710}
711
Chandler Carruth631abd92011-06-16 06:47:06 +0000712void StmtProfiler::VisitDesignatedInitExpr(const DesignatedInitExpr *S) {
Douglas Gregor5c193b92009-07-28 00:33:38 +0000713 VisitExpr(S);
714 ID.AddBoolean(S->usesGNUSyntax());
Chandler Carruth631abd92011-06-16 06:47:06 +0000715 for (DesignatedInitExpr::const_designators_iterator D =
716 S->designators_begin(), DEnd = S->designators_end();
Douglas Gregor5c193b92009-07-28 00:33:38 +0000717 D != DEnd; ++D) {
718 if (D->isFieldDesignator()) {
719 ID.AddInteger(0);
720 VisitName(D->getFieldName());
721 continue;
722 }
Mike Stump11289f42009-09-09 15:08:12 +0000723
Douglas Gregor5c193b92009-07-28 00:33:38 +0000724 if (D->isArrayDesignator()) {
725 ID.AddInteger(1);
726 } else {
727 assert(D->isArrayRangeDesignator());
728 ID.AddInteger(2);
729 }
730 ID.AddInteger(D->getFirstExprIndex());
731 }
732}
733
Chandler Carruth631abd92011-06-16 06:47:06 +0000734void StmtProfiler::VisitImplicitValueInitExpr(const ImplicitValueInitExpr *S) {
Douglas Gregor5c193b92009-07-28 00:33:38 +0000735 VisitExpr(S);
736}
737
Chandler Carruth631abd92011-06-16 06:47:06 +0000738void StmtProfiler::VisitExtVectorElementExpr(const ExtVectorElementExpr *S) {
Douglas Gregor5c193b92009-07-28 00:33:38 +0000739 VisitExpr(S);
740 VisitName(&S->getAccessor());
741}
742
Chandler Carruth631abd92011-06-16 06:47:06 +0000743void StmtProfiler::VisitBlockExpr(const BlockExpr *S) {
Douglas Gregor5c193b92009-07-28 00:33:38 +0000744 VisitExpr(S);
745 VisitDecl(S->getBlockDecl());
746}
747
Chandler Carruth631abd92011-06-16 06:47:06 +0000748void StmtProfiler::VisitGenericSelectionExpr(const GenericSelectionExpr *S) {
Peter Collingbourne91147592011-04-15 00:35:48 +0000749 VisitExpr(S);
750 for (unsigned i = 0; i != S->getNumAssocs(); ++i) {
751 QualType T = S->getAssocType(i);
752 if (T.isNull())
Craig Topper36250ad2014-05-12 05:36:57 +0000753 ID.AddPointer(nullptr);
Peter Collingbourne91147592011-04-15 00:35:48 +0000754 else
755 VisitType(T);
756 VisitExpr(S->getAssocExpr(i));
757 }
758}
759
John McCallfe96e0b2011-11-06 09:01:30 +0000760void StmtProfiler::VisitPseudoObjectExpr(const PseudoObjectExpr *S) {
761 VisitExpr(S);
762 for (PseudoObjectExpr::const_semantics_iterator
763 i = S->semantics_begin(), e = S->semantics_end(); i != e; ++i)
764 // Normally, we would not profile the source expressions of OVEs.
765 if (const OpaqueValueExpr *OVE = dyn_cast<OpaqueValueExpr>(*i))
766 Visit(OVE->getSourceExpr());
767}
768
Eli Friedmandf14b3a2011-10-11 02:20:01 +0000769void StmtProfiler::VisitAtomicExpr(const AtomicExpr *S) {
770 VisitExpr(S);
Eli Friedman4b72fdd2011-10-14 20:59:01 +0000771 ID.AddInteger(S->getOp());
Eli Friedmandf14b3a2011-10-11 02:20:01 +0000772}
773
Chandler Carruth631abd92011-06-16 06:47:06 +0000774static Stmt::StmtClass DecodeOperatorCall(const CXXOperatorCallExpr *S,
John McCalle3027922010-08-25 11:45:40 +0000775 UnaryOperatorKind &UnaryOp,
776 BinaryOperatorKind &BinaryOp) {
Douglas Gregore9ceb312010-05-19 04:13:23 +0000777 switch (S->getOperator()) {
778 case OO_None:
779 case OO_New:
780 case OO_Delete:
781 case OO_Array_New:
782 case OO_Array_Delete:
783 case OO_Arrow:
784 case OO_Call:
785 case OO_Conditional:
786 case NUM_OVERLOADED_OPERATORS:
787 llvm_unreachable("Invalid operator call kind");
Douglas Gregore9ceb312010-05-19 04:13:23 +0000788
789 case OO_Plus:
790 if (S->getNumArgs() == 1) {
John McCalle3027922010-08-25 11:45:40 +0000791 UnaryOp = UO_Plus;
Douglas Gregore9ceb312010-05-19 04:13:23 +0000792 return Stmt::UnaryOperatorClass;
793 }
794
John McCalle3027922010-08-25 11:45:40 +0000795 BinaryOp = BO_Add;
Douglas Gregore9ceb312010-05-19 04:13:23 +0000796 return Stmt::BinaryOperatorClass;
797
798 case OO_Minus:
799 if (S->getNumArgs() == 1) {
John McCalle3027922010-08-25 11:45:40 +0000800 UnaryOp = UO_Minus;
Douglas Gregore9ceb312010-05-19 04:13:23 +0000801 return Stmt::UnaryOperatorClass;
802 }
803
John McCalle3027922010-08-25 11:45:40 +0000804 BinaryOp = BO_Sub;
Douglas Gregore9ceb312010-05-19 04:13:23 +0000805 return Stmt::BinaryOperatorClass;
806
807 case OO_Star:
808 if (S->getNumArgs() == 1) {
Richard Smithf15acc52014-06-05 22:43:40 +0000809 UnaryOp = UO_Deref;
Douglas Gregore9ceb312010-05-19 04:13:23 +0000810 return Stmt::UnaryOperatorClass;
811 }
812
Richard Smithf15acc52014-06-05 22:43:40 +0000813 BinaryOp = BO_Mul;
Douglas Gregore9ceb312010-05-19 04:13:23 +0000814 return Stmt::BinaryOperatorClass;
815
816 case OO_Slash:
John McCalle3027922010-08-25 11:45:40 +0000817 BinaryOp = BO_Div;
Douglas Gregore9ceb312010-05-19 04:13:23 +0000818 return Stmt::BinaryOperatorClass;
819
820 case OO_Percent:
John McCalle3027922010-08-25 11:45:40 +0000821 BinaryOp = BO_Rem;
Douglas Gregore9ceb312010-05-19 04:13:23 +0000822 return Stmt::BinaryOperatorClass;
823
824 case OO_Caret:
John McCalle3027922010-08-25 11:45:40 +0000825 BinaryOp = BO_Xor;
Douglas Gregore9ceb312010-05-19 04:13:23 +0000826 return Stmt::BinaryOperatorClass;
827
828 case OO_Amp:
829 if (S->getNumArgs() == 1) {
John McCalle3027922010-08-25 11:45:40 +0000830 UnaryOp = UO_AddrOf;
Douglas Gregore9ceb312010-05-19 04:13:23 +0000831 return Stmt::UnaryOperatorClass;
832 }
833
John McCalle3027922010-08-25 11:45:40 +0000834 BinaryOp = BO_And;
Douglas Gregore9ceb312010-05-19 04:13:23 +0000835 return Stmt::BinaryOperatorClass;
836
837 case OO_Pipe:
John McCalle3027922010-08-25 11:45:40 +0000838 BinaryOp = BO_Or;
Douglas Gregore9ceb312010-05-19 04:13:23 +0000839 return Stmt::BinaryOperatorClass;
840
841 case OO_Tilde:
John McCalle3027922010-08-25 11:45:40 +0000842 UnaryOp = UO_Not;
Douglas Gregore9ceb312010-05-19 04:13:23 +0000843 return Stmt::UnaryOperatorClass;
844
845 case OO_Exclaim:
John McCalle3027922010-08-25 11:45:40 +0000846 UnaryOp = UO_LNot;
Douglas Gregore9ceb312010-05-19 04:13:23 +0000847 return Stmt::UnaryOperatorClass;
848
849 case OO_Equal:
John McCalle3027922010-08-25 11:45:40 +0000850 BinaryOp = BO_Assign;
Douglas Gregore9ceb312010-05-19 04:13:23 +0000851 return Stmt::BinaryOperatorClass;
852
853 case OO_Less:
John McCalle3027922010-08-25 11:45:40 +0000854 BinaryOp = BO_LT;
Douglas Gregore9ceb312010-05-19 04:13:23 +0000855 return Stmt::BinaryOperatorClass;
856
857 case OO_Greater:
John McCalle3027922010-08-25 11:45:40 +0000858 BinaryOp = BO_GT;
Douglas Gregore9ceb312010-05-19 04:13:23 +0000859 return Stmt::BinaryOperatorClass;
860
861 case OO_PlusEqual:
John McCalle3027922010-08-25 11:45:40 +0000862 BinaryOp = BO_AddAssign;
Douglas Gregore9ceb312010-05-19 04:13:23 +0000863 return Stmt::CompoundAssignOperatorClass;
864
865 case OO_MinusEqual:
John McCalle3027922010-08-25 11:45:40 +0000866 BinaryOp = BO_SubAssign;
Douglas Gregore9ceb312010-05-19 04:13:23 +0000867 return Stmt::CompoundAssignOperatorClass;
868
869 case OO_StarEqual:
John McCalle3027922010-08-25 11:45:40 +0000870 BinaryOp = BO_MulAssign;
Douglas Gregore9ceb312010-05-19 04:13:23 +0000871 return Stmt::CompoundAssignOperatorClass;
872
873 case OO_SlashEqual:
John McCalle3027922010-08-25 11:45:40 +0000874 BinaryOp = BO_DivAssign;
Douglas Gregore9ceb312010-05-19 04:13:23 +0000875 return Stmt::CompoundAssignOperatorClass;
876
877 case OO_PercentEqual:
John McCalle3027922010-08-25 11:45:40 +0000878 BinaryOp = BO_RemAssign;
Douglas Gregore9ceb312010-05-19 04:13:23 +0000879 return Stmt::CompoundAssignOperatorClass;
880
881 case OO_CaretEqual:
John McCalle3027922010-08-25 11:45:40 +0000882 BinaryOp = BO_XorAssign;
Douglas Gregore9ceb312010-05-19 04:13:23 +0000883 return Stmt::CompoundAssignOperatorClass;
884
885 case OO_AmpEqual:
John McCalle3027922010-08-25 11:45:40 +0000886 BinaryOp = BO_AndAssign;
Douglas Gregore9ceb312010-05-19 04:13:23 +0000887 return Stmt::CompoundAssignOperatorClass;
888
889 case OO_PipeEqual:
John McCalle3027922010-08-25 11:45:40 +0000890 BinaryOp = BO_OrAssign;
Douglas Gregore9ceb312010-05-19 04:13:23 +0000891 return Stmt::CompoundAssignOperatorClass;
892
893 case OO_LessLess:
John McCalle3027922010-08-25 11:45:40 +0000894 BinaryOp = BO_Shl;
Douglas Gregore9ceb312010-05-19 04:13:23 +0000895 return Stmt::BinaryOperatorClass;
896
897 case OO_GreaterGreater:
John McCalle3027922010-08-25 11:45:40 +0000898 BinaryOp = BO_Shr;
Douglas Gregore9ceb312010-05-19 04:13:23 +0000899 return Stmt::BinaryOperatorClass;
900
901 case OO_LessLessEqual:
John McCalle3027922010-08-25 11:45:40 +0000902 BinaryOp = BO_ShlAssign;
Douglas Gregore9ceb312010-05-19 04:13:23 +0000903 return Stmt::CompoundAssignOperatorClass;
904
905 case OO_GreaterGreaterEqual:
John McCalle3027922010-08-25 11:45:40 +0000906 BinaryOp = BO_ShrAssign;
Douglas Gregore9ceb312010-05-19 04:13:23 +0000907 return Stmt::CompoundAssignOperatorClass;
908
909 case OO_EqualEqual:
John McCalle3027922010-08-25 11:45:40 +0000910 BinaryOp = BO_EQ;
Douglas Gregore9ceb312010-05-19 04:13:23 +0000911 return Stmt::BinaryOperatorClass;
912
913 case OO_ExclaimEqual:
John McCalle3027922010-08-25 11:45:40 +0000914 BinaryOp = BO_NE;
Douglas Gregore9ceb312010-05-19 04:13:23 +0000915 return Stmt::BinaryOperatorClass;
916
917 case OO_LessEqual:
John McCalle3027922010-08-25 11:45:40 +0000918 BinaryOp = BO_LE;
Douglas Gregore9ceb312010-05-19 04:13:23 +0000919 return Stmt::BinaryOperatorClass;
920
921 case OO_GreaterEqual:
John McCalle3027922010-08-25 11:45:40 +0000922 BinaryOp = BO_GE;
Douglas Gregore9ceb312010-05-19 04:13:23 +0000923 return Stmt::BinaryOperatorClass;
924
925 case OO_AmpAmp:
John McCalle3027922010-08-25 11:45:40 +0000926 BinaryOp = BO_LAnd;
Douglas Gregore9ceb312010-05-19 04:13:23 +0000927 return Stmt::BinaryOperatorClass;
928
929 case OO_PipePipe:
John McCalle3027922010-08-25 11:45:40 +0000930 BinaryOp = BO_LOr;
Douglas Gregore9ceb312010-05-19 04:13:23 +0000931 return Stmt::BinaryOperatorClass;
932
933 case OO_PlusPlus:
John McCalle3027922010-08-25 11:45:40 +0000934 UnaryOp = S->getNumArgs() == 1? UO_PreInc
935 : UO_PostInc;
Douglas Gregore9ceb312010-05-19 04:13:23 +0000936 return Stmt::UnaryOperatorClass;
937
938 case OO_MinusMinus:
John McCalle3027922010-08-25 11:45:40 +0000939 UnaryOp = S->getNumArgs() == 1? UO_PreDec
940 : UO_PostDec;
Douglas Gregore9ceb312010-05-19 04:13:23 +0000941 return Stmt::UnaryOperatorClass;
942
943 case OO_Comma:
John McCalle3027922010-08-25 11:45:40 +0000944 BinaryOp = BO_Comma;
Douglas Gregore9ceb312010-05-19 04:13:23 +0000945 return Stmt::BinaryOperatorClass;
946
947
948 case OO_ArrowStar:
John McCalle3027922010-08-25 11:45:40 +0000949 BinaryOp = BO_PtrMemI;
Douglas Gregore9ceb312010-05-19 04:13:23 +0000950 return Stmt::BinaryOperatorClass;
951
952 case OO_Subscript:
953 return Stmt::ArraySubscriptExprClass;
954 }
955
956 llvm_unreachable("Invalid overloaded operator expression");
957}
Richard Smithf15acc52014-06-05 22:43:40 +0000958
Douglas Gregore9ceb312010-05-19 04:13:23 +0000959
Chandler Carruth631abd92011-06-16 06:47:06 +0000960void StmtProfiler::VisitCXXOperatorCallExpr(const CXXOperatorCallExpr *S) {
Douglas Gregore9ceb312010-05-19 04:13:23 +0000961 if (S->isTypeDependent()) {
962 // Type-dependent operator calls are profiled like their underlying
963 // syntactic operator.
John McCalle3027922010-08-25 11:45:40 +0000964 UnaryOperatorKind UnaryOp = UO_Extension;
965 BinaryOperatorKind BinaryOp = BO_Comma;
Douglas Gregore9ceb312010-05-19 04:13:23 +0000966 Stmt::StmtClass SC = DecodeOperatorCall(S, UnaryOp, BinaryOp);
Richard Smithf15acc52014-06-05 22:43:40 +0000967
Douglas Gregore9ceb312010-05-19 04:13:23 +0000968 ID.AddInteger(SC);
969 for (unsigned I = 0, N = S->getNumArgs(); I != N; ++I)
970 Visit(S->getArg(I));
971 if (SC == Stmt::UnaryOperatorClass)
972 ID.AddInteger(UnaryOp);
973 else if (SC == Stmt::BinaryOperatorClass ||
974 SC == Stmt::CompoundAssignOperatorClass)
975 ID.AddInteger(BinaryOp);
976 else
977 assert(SC == Stmt::ArraySubscriptExprClass);
Richard Smithf15acc52014-06-05 22:43:40 +0000978
Douglas Gregore9ceb312010-05-19 04:13:23 +0000979 return;
980 }
Richard Smithf15acc52014-06-05 22:43:40 +0000981
Douglas Gregor5c193b92009-07-28 00:33:38 +0000982 VisitCallExpr(S);
983 ID.AddInteger(S->getOperator());
984}
985
Chandler Carruth631abd92011-06-16 06:47:06 +0000986void StmtProfiler::VisitCXXMemberCallExpr(const CXXMemberCallExpr *S) {
Douglas Gregor5c193b92009-07-28 00:33:38 +0000987 VisitCallExpr(S);
988}
989
Chandler Carruth631abd92011-06-16 06:47:06 +0000990void StmtProfiler::VisitCUDAKernelCallExpr(const CUDAKernelCallExpr *S) {
Peter Collingbourne41f85462011-02-09 21:07:24 +0000991 VisitCallExpr(S);
992}
993
Chandler Carruth631abd92011-06-16 06:47:06 +0000994void StmtProfiler::VisitAsTypeExpr(const AsTypeExpr *S) {
Tanya Lattner55808c12011-06-04 00:47:47 +0000995 VisitExpr(S);
996}
997
Chandler Carruth631abd92011-06-16 06:47:06 +0000998void StmtProfiler::VisitCXXNamedCastExpr(const CXXNamedCastExpr *S) {
Douglas Gregor5c193b92009-07-28 00:33:38 +0000999 VisitExplicitCastExpr(S);
1000}
1001
Chandler Carruth631abd92011-06-16 06:47:06 +00001002void StmtProfiler::VisitCXXStaticCastExpr(const CXXStaticCastExpr *S) {
Douglas Gregor5c193b92009-07-28 00:33:38 +00001003 VisitCXXNamedCastExpr(S);
1004}
1005
Chandler Carruth631abd92011-06-16 06:47:06 +00001006void StmtProfiler::VisitCXXDynamicCastExpr(const CXXDynamicCastExpr *S) {
Douglas Gregor5c193b92009-07-28 00:33:38 +00001007 VisitCXXNamedCastExpr(S);
1008}
1009
Chandler Carruth631abd92011-06-16 06:47:06 +00001010void
1011StmtProfiler::VisitCXXReinterpretCastExpr(const CXXReinterpretCastExpr *S) {
Douglas Gregor5c193b92009-07-28 00:33:38 +00001012 VisitCXXNamedCastExpr(S);
1013}
1014
Chandler Carruth631abd92011-06-16 06:47:06 +00001015void StmtProfiler::VisitCXXConstCastExpr(const CXXConstCastExpr *S) {
Douglas Gregor5c193b92009-07-28 00:33:38 +00001016 VisitCXXNamedCastExpr(S);
1017}
1018
Richard Smithc67fdd42012-03-07 08:35:16 +00001019void StmtProfiler::VisitUserDefinedLiteral(const UserDefinedLiteral *S) {
1020 VisitCallExpr(S);
1021}
1022
Chandler Carruth631abd92011-06-16 06:47:06 +00001023void StmtProfiler::VisitCXXBoolLiteralExpr(const CXXBoolLiteralExpr *S) {
Douglas Gregor5c193b92009-07-28 00:33:38 +00001024 VisitExpr(S);
1025 ID.AddBoolean(S->getValue());
1026}
1027
Chandler Carruth631abd92011-06-16 06:47:06 +00001028void StmtProfiler::VisitCXXNullPtrLiteralExpr(const CXXNullPtrLiteralExpr *S) {
Douglas Gregor00044172009-07-29 16:09:57 +00001029 VisitExpr(S);
1030}
1031
Richard Smithcc1b96d2013-06-12 22:31:48 +00001032void StmtProfiler::VisitCXXStdInitializerListExpr(
1033 const CXXStdInitializerListExpr *S) {
1034 VisitExpr(S);
1035}
1036
Chandler Carruth631abd92011-06-16 06:47:06 +00001037void StmtProfiler::VisitCXXTypeidExpr(const CXXTypeidExpr *S) {
Douglas Gregor5c193b92009-07-28 00:33:38 +00001038 VisitExpr(S);
1039 if (S->isTypeOperand())
David Majnemer143c55e2013-09-27 07:04:31 +00001040 VisitType(S->getTypeOperandSourceInfo()->getType());
Douglas Gregor5c193b92009-07-28 00:33:38 +00001041}
1042
Chandler Carruth631abd92011-06-16 06:47:06 +00001043void StmtProfiler::VisitCXXUuidofExpr(const CXXUuidofExpr *S) {
Francois Pichet9f4f2072010-09-08 12:20:18 +00001044 VisitExpr(S);
1045 if (S->isTypeOperand())
David Majnemer143c55e2013-09-27 07:04:31 +00001046 VisitType(S->getTypeOperandSourceInfo()->getType());
Francois Pichet9f4f2072010-09-08 12:20:18 +00001047}
1048
John McCall5e77d762013-04-16 07:28:30 +00001049void StmtProfiler::VisitMSPropertyRefExpr(const MSPropertyRefExpr *S) {
1050 VisitExpr(S);
1051 VisitDecl(S->getPropertyDecl());
1052}
1053
Chandler Carruth631abd92011-06-16 06:47:06 +00001054void StmtProfiler::VisitCXXThisExpr(const CXXThisExpr *S) {
Douglas Gregor5c193b92009-07-28 00:33:38 +00001055 VisitExpr(S);
Douglas Gregor3024f072012-04-16 07:05:22 +00001056 ID.AddBoolean(S->isImplicit());
Douglas Gregor5c193b92009-07-28 00:33:38 +00001057}
1058
Chandler Carruth631abd92011-06-16 06:47:06 +00001059void StmtProfiler::VisitCXXThrowExpr(const CXXThrowExpr *S) {
Douglas Gregor5c193b92009-07-28 00:33:38 +00001060 VisitExpr(S);
1061}
1062
Chandler Carruth631abd92011-06-16 06:47:06 +00001063void StmtProfiler::VisitCXXDefaultArgExpr(const CXXDefaultArgExpr *S) {
Douglas Gregor5c193b92009-07-28 00:33:38 +00001064 VisitExpr(S);
1065 VisitDecl(S->getParam());
1066}
1067
Richard Smith852c9db2013-04-20 22:23:05 +00001068void StmtProfiler::VisitCXXDefaultInitExpr(const CXXDefaultInitExpr *S) {
1069 VisitExpr(S);
1070 VisitDecl(S->getField());
1071}
1072
Chandler Carruth631abd92011-06-16 06:47:06 +00001073void StmtProfiler::VisitCXXBindTemporaryExpr(const CXXBindTemporaryExpr *S) {
Douglas Gregor5c193b92009-07-28 00:33:38 +00001074 VisitExpr(S);
1075 VisitDecl(
1076 const_cast<CXXDestructorDecl *>(S->getTemporary()->getDestructor()));
1077}
1078
Chandler Carruth631abd92011-06-16 06:47:06 +00001079void StmtProfiler::VisitCXXConstructExpr(const CXXConstructExpr *S) {
Douglas Gregor5c193b92009-07-28 00:33:38 +00001080 VisitExpr(S);
1081 VisitDecl(S->getConstructor());
1082 ID.AddBoolean(S->isElidable());
1083}
1084
Chandler Carruth631abd92011-06-16 06:47:06 +00001085void StmtProfiler::VisitCXXFunctionalCastExpr(const CXXFunctionalCastExpr *S) {
Douglas Gregor5c193b92009-07-28 00:33:38 +00001086 VisitExplicitCastExpr(S);
1087}
1088
Chandler Carruth631abd92011-06-16 06:47:06 +00001089void
1090StmtProfiler::VisitCXXTemporaryObjectExpr(const CXXTemporaryObjectExpr *S) {
Douglas Gregor5c193b92009-07-28 00:33:38 +00001091 VisitCXXConstructExpr(S);
1092}
1093
Chandler Carruth631abd92011-06-16 06:47:06 +00001094void
Douglas Gregore31e6062012-02-07 10:09:13 +00001095StmtProfiler::VisitLambdaExpr(const LambdaExpr *S) {
1096 VisitExpr(S);
1097 for (LambdaExpr::capture_iterator C = S->explicit_capture_begin(),
1098 CEnd = S->explicit_capture_end();
1099 C != CEnd; ++C) {
1100 ID.AddInteger(C->getCaptureKind());
Richard Smithba71c082013-05-16 06:20:58 +00001101 switch (C->getCaptureKind()) {
1102 case LCK_This:
1103 break;
1104 case LCK_ByRef:
1105 case LCK_ByCopy:
Douglas Gregore31e6062012-02-07 10:09:13 +00001106 VisitDecl(C->getCapturedVar());
1107 ID.AddBoolean(C->isPackExpansion());
Richard Smithba71c082013-05-16 06:20:58 +00001108 break;
Alexey Bataev39c81e22014-08-28 04:28:19 +00001109 case LCK_VLAType:
1110 llvm_unreachable("VLA type in explicit captures.");
Douglas Gregore31e6062012-02-07 10:09:13 +00001111 }
1112 }
1113 // Note: If we actually needed to be able to match lambda
1114 // expressions, we would have to consider parameters and return type
1115 // here, among other things.
1116 VisitStmt(S->getBody());
1117}
1118
1119void
Chandler Carruth631abd92011-06-16 06:47:06 +00001120StmtProfiler::VisitCXXScalarValueInitExpr(const CXXScalarValueInitExpr *S) {
Douglas Gregor5c193b92009-07-28 00:33:38 +00001121 VisitExpr(S);
1122}
1123
Chandler Carruth631abd92011-06-16 06:47:06 +00001124void StmtProfiler::VisitCXXDeleteExpr(const CXXDeleteExpr *S) {
Douglas Gregor5c193b92009-07-28 00:33:38 +00001125 VisitExpr(S);
1126 ID.AddBoolean(S->isGlobalDelete());
1127 ID.AddBoolean(S->isArrayForm());
1128 VisitDecl(S->getOperatorDelete());
1129}
1130
1131
Chandler Carruth631abd92011-06-16 06:47:06 +00001132void StmtProfiler::VisitCXXNewExpr(const CXXNewExpr *S) {
Douglas Gregor5c193b92009-07-28 00:33:38 +00001133 VisitExpr(S);
1134 VisitType(S->getAllocatedType());
1135 VisitDecl(S->getOperatorNew());
1136 VisitDecl(S->getOperatorDelete());
Douglas Gregor5c193b92009-07-28 00:33:38 +00001137 ID.AddBoolean(S->isArray());
1138 ID.AddInteger(S->getNumPlacementArgs());
1139 ID.AddBoolean(S->isGlobalNew());
1140 ID.AddBoolean(S->isParenTypeId());
Sebastian Redl6047f072012-02-16 12:22:20 +00001141 ID.AddInteger(S->getInitializationStyle());
Douglas Gregor5c193b92009-07-28 00:33:38 +00001142}
1143
Chandler Carruth631abd92011-06-16 06:47:06 +00001144void
1145StmtProfiler::VisitCXXPseudoDestructorExpr(const CXXPseudoDestructorExpr *S) {
Douglas Gregorad8a3362009-09-04 17:36:40 +00001146 VisitExpr(S);
1147 ID.AddBoolean(S->isArrow());
1148 VisitNestedNameSpecifier(S->getQualifier());
Craig Topper36250ad2014-05-12 05:36:57 +00001149 ID.AddBoolean(S->getScopeTypeInfo() != nullptr);
Eli Friedman85641392013-08-09 23:37:05 +00001150 if (S->getScopeTypeInfo())
1151 VisitType(S->getScopeTypeInfo()->getType());
Craig Topper36250ad2014-05-12 05:36:57 +00001152 ID.AddBoolean(S->getDestroyedTypeInfo() != nullptr);
Eli Friedman85641392013-08-09 23:37:05 +00001153 if (S->getDestroyedTypeInfo())
1154 VisitType(S->getDestroyedType());
1155 else
1156 ID.AddPointer(S->getDestroyedTypeIdentifier());
Douglas Gregorad8a3362009-09-04 17:36:40 +00001157}
1158
Chandler Carruth631abd92011-06-16 06:47:06 +00001159void StmtProfiler::VisitOverloadExpr(const OverloadExpr *S) {
Argyrios Kyrtzidisb482eb82010-08-15 20:53:20 +00001160 VisitExpr(S);
John McCalle66edc12009-11-24 19:00:30 +00001161 VisitNestedNameSpecifier(S->getQualifier());
Douglas Gregor5c193b92009-07-28 00:33:38 +00001162 VisitName(S->getName());
John McCalle66edc12009-11-24 19:00:30 +00001163 ID.AddBoolean(S->hasExplicitTemplateArgs());
1164 if (S->hasExplicitTemplateArgs())
Argyrios Kyrtzidisf4505452010-08-15 01:15:38 +00001165 VisitTemplateArguments(S->getExplicitTemplateArgs().getTemplateArgs(),
1166 S->getExplicitTemplateArgs().NumTemplateArgs);
1167}
1168
1169void
Chandler Carruth631abd92011-06-16 06:47:06 +00001170StmtProfiler::VisitUnresolvedLookupExpr(const UnresolvedLookupExpr *S) {
Argyrios Kyrtzidisf4505452010-08-15 01:15:38 +00001171 VisitOverloadExpr(S);
Douglas Gregor5c193b92009-07-28 00:33:38 +00001172}
1173
Douglas Gregor29c42f22012-02-24 07:38:34 +00001174void StmtProfiler::VisitTypeTraitExpr(const TypeTraitExpr *S) {
1175 VisitExpr(S);
1176 ID.AddInteger(S->getTrait());
1177 ID.AddInteger(S->getNumArgs());
1178 for (unsigned I = 0, N = S->getNumArgs(); I != N; ++I)
1179 VisitType(S->getArg(I)->getType());
1180}
1181
Chandler Carruth631abd92011-06-16 06:47:06 +00001182void StmtProfiler::VisitArrayTypeTraitExpr(const ArrayTypeTraitExpr *S) {
John Wiegley6242b6a2011-04-28 00:16:57 +00001183 VisitExpr(S);
1184 ID.AddInteger(S->getTrait());
1185 VisitType(S->getQueriedType());
1186}
1187
Chandler Carruth631abd92011-06-16 06:47:06 +00001188void StmtProfiler::VisitExpressionTraitExpr(const ExpressionTraitExpr *S) {
John Wiegleyf9f65842011-04-25 06:54:41 +00001189 VisitExpr(S);
1190 ID.AddInteger(S->getTrait());
1191 VisitExpr(S->getQueriedExpression());
1192}
1193
Chandler Carruth631abd92011-06-16 06:47:06 +00001194void StmtProfiler::VisitDependentScopeDeclRefExpr(
1195 const DependentScopeDeclRefExpr *S) {
Douglas Gregor5c193b92009-07-28 00:33:38 +00001196 VisitExpr(S);
1197 VisitName(S->getDeclName());
1198 VisitNestedNameSpecifier(S->getQualifier());
John McCalle66edc12009-11-24 19:00:30 +00001199 ID.AddBoolean(S->hasExplicitTemplateArgs());
1200 if (S->hasExplicitTemplateArgs())
1201 VisitTemplateArguments(S->getTemplateArgs(), S->getNumTemplateArgs());
Douglas Gregor5c193b92009-07-28 00:33:38 +00001202}
1203
Chandler Carruth631abd92011-06-16 06:47:06 +00001204void StmtProfiler::VisitExprWithCleanups(const ExprWithCleanups *S) {
Douglas Gregora7095092009-07-28 14:44:31 +00001205 VisitExpr(S);
Douglas Gregora7095092009-07-28 14:44:31 +00001206}
1207
Chandler Carruth631abd92011-06-16 06:47:06 +00001208void StmtProfiler::VisitCXXUnresolvedConstructExpr(
1209 const CXXUnresolvedConstructExpr *S) {
Douglas Gregora7095092009-07-28 14:44:31 +00001210 VisitExpr(S);
1211 VisitType(S->getTypeAsWritten());
1212}
1213
Chandler Carruth631abd92011-06-16 06:47:06 +00001214void StmtProfiler::VisitCXXDependentScopeMemberExpr(
1215 const CXXDependentScopeMemberExpr *S) {
John McCall2d74de92009-12-01 22:10:20 +00001216 ID.AddBoolean(S->isImplicitAccess());
1217 if (!S->isImplicitAccess()) {
1218 VisitExpr(S);
1219 ID.AddBoolean(S->isArrow());
1220 }
Douglas Gregorc26e0f62009-09-03 16:14:30 +00001221 VisitNestedNameSpecifier(S->getQualifier());
Douglas Gregora7095092009-07-28 14:44:31 +00001222 VisitName(S->getMember());
John McCall2d74de92009-12-01 22:10:20 +00001223 ID.AddBoolean(S->hasExplicitTemplateArgs());
1224 if (S->hasExplicitTemplateArgs())
John McCall10eae182009-11-30 22:42:35 +00001225 VisitTemplateArguments(S->getTemplateArgs(), S->getNumTemplateArgs());
1226}
1227
Chandler Carruth631abd92011-06-16 06:47:06 +00001228void StmtProfiler::VisitUnresolvedMemberExpr(const UnresolvedMemberExpr *S) {
John McCall2d74de92009-12-01 22:10:20 +00001229 ID.AddBoolean(S->isImplicitAccess());
1230 if (!S->isImplicitAccess()) {
1231 VisitExpr(S);
1232 ID.AddBoolean(S->isArrow());
1233 }
John McCall10eae182009-11-30 22:42:35 +00001234 VisitNestedNameSpecifier(S->getQualifier());
1235 VisitName(S->getMemberName());
1236 ID.AddBoolean(S->hasExplicitTemplateArgs());
1237 if (S->hasExplicitTemplateArgs())
1238 VisitTemplateArguments(S->getTemplateArgs(), S->getNumTemplateArgs());
Douglas Gregora7095092009-07-28 14:44:31 +00001239}
1240
Chandler Carruth631abd92011-06-16 06:47:06 +00001241void StmtProfiler::VisitCXXNoexceptExpr(const CXXNoexceptExpr *S) {
Sebastian Redl4202c0f2010-09-10 20:55:43 +00001242 VisitExpr(S);
1243}
1244
Chandler Carruth631abd92011-06-16 06:47:06 +00001245void StmtProfiler::VisitPackExpansionExpr(const PackExpansionExpr *S) {
Douglas Gregore8e9dd62011-01-03 17:17:50 +00001246 VisitExpr(S);
1247}
1248
Chandler Carruth631abd92011-06-16 06:47:06 +00001249void StmtProfiler::VisitSizeOfPackExpr(const SizeOfPackExpr *S) {
Douglas Gregor820ba7b2011-01-04 17:33:58 +00001250 VisitExpr(S);
1251 VisitDecl(S->getPack());
1252}
1253
Douglas Gregorcdbc5392011-01-15 01:15:58 +00001254void StmtProfiler::VisitSubstNonTypeTemplateParmPackExpr(
Chandler Carruth631abd92011-06-16 06:47:06 +00001255 const SubstNonTypeTemplateParmPackExpr *S) {
Douglas Gregorcdbc5392011-01-15 01:15:58 +00001256 VisitExpr(S);
1257 VisitDecl(S->getParameterPack());
1258 VisitTemplateArgument(S->getArgumentPack());
1259}
1260
John McCall7c454bb2011-07-15 05:09:51 +00001261void StmtProfiler::VisitSubstNonTypeTemplateParmExpr(
1262 const SubstNonTypeTemplateParmExpr *E) {
1263 // Profile exactly as the replacement expression.
1264 Visit(E->getReplacement());
1265}
1266
Richard Smithb15fe3a2012-09-12 00:56:43 +00001267void StmtProfiler::VisitFunctionParmPackExpr(const FunctionParmPackExpr *S) {
1268 VisitExpr(S);
1269 VisitDecl(S->getParameterPack());
1270 ID.AddInteger(S->getNumExpansions());
1271 for (FunctionParmPackExpr::iterator I = S->begin(), E = S->end(); I != E; ++I)
1272 VisitDecl(*I);
1273}
1274
Douglas Gregorfe314812011-06-21 17:03:29 +00001275void StmtProfiler::VisitMaterializeTemporaryExpr(
1276 const MaterializeTemporaryExpr *S) {
1277 VisitExpr(S);
1278}
1279
Richard Smith0f0af192014-11-08 05:07:16 +00001280void StmtProfiler::VisitCXXFoldExpr(const CXXFoldExpr *S) {
1281 VisitExpr(S);
1282 ID.AddInteger(S->getOperator());
1283}
1284
Chandler Carruth631abd92011-06-16 06:47:06 +00001285void StmtProfiler::VisitOpaqueValueExpr(const OpaqueValueExpr *E) {
John McCall8d69a212010-11-15 23:31:06 +00001286 VisitExpr(E);
1287}
1288
Kaelyn Takatae1f49d52014-10-27 18:07:20 +00001289void StmtProfiler::VisitTypoExpr(const TypoExpr *E) {
1290 VisitExpr(E);
1291}
1292
Chandler Carruth631abd92011-06-16 06:47:06 +00001293void StmtProfiler::VisitObjCStringLiteral(const ObjCStringLiteral *S) {
Douglas Gregora7095092009-07-28 14:44:31 +00001294 VisitExpr(S);
1295}
1296
Patrick Beard0caa3942012-04-19 00:25:12 +00001297void StmtProfiler::VisitObjCBoxedExpr(const ObjCBoxedExpr *E) {
Ted Kremeneke65b0862012-03-06 20:05:56 +00001298 VisitExpr(E);
1299}
1300
1301void StmtProfiler::VisitObjCArrayLiteral(const ObjCArrayLiteral *E) {
1302 VisitExpr(E);
1303}
1304
1305void StmtProfiler::VisitObjCDictionaryLiteral(const ObjCDictionaryLiteral *E) {
1306 VisitExpr(E);
1307}
1308
Chandler Carruth631abd92011-06-16 06:47:06 +00001309void StmtProfiler::VisitObjCEncodeExpr(const ObjCEncodeExpr *S) {
Douglas Gregora7095092009-07-28 14:44:31 +00001310 VisitExpr(S);
1311 VisitType(S->getEncodedType());
1312}
1313
Chandler Carruth631abd92011-06-16 06:47:06 +00001314void StmtProfiler::VisitObjCSelectorExpr(const ObjCSelectorExpr *S) {
Douglas Gregora7095092009-07-28 14:44:31 +00001315 VisitExpr(S);
1316 VisitName(S->getSelector());
1317}
1318
Chandler Carruth631abd92011-06-16 06:47:06 +00001319void StmtProfiler::VisitObjCProtocolExpr(const ObjCProtocolExpr *S) {
Douglas Gregora7095092009-07-28 14:44:31 +00001320 VisitExpr(S);
1321 VisitDecl(S->getProtocol());
1322}
1323
Chandler Carruth631abd92011-06-16 06:47:06 +00001324void StmtProfiler::VisitObjCIvarRefExpr(const ObjCIvarRefExpr *S) {
Douglas Gregora7095092009-07-28 14:44:31 +00001325 VisitExpr(S);
1326 VisitDecl(S->getDecl());
1327 ID.AddBoolean(S->isArrow());
1328 ID.AddBoolean(S->isFreeIvar());
1329}
1330
Chandler Carruth631abd92011-06-16 06:47:06 +00001331void StmtProfiler::VisitObjCPropertyRefExpr(const ObjCPropertyRefExpr *S) {
Douglas Gregora7095092009-07-28 14:44:31 +00001332 VisitExpr(S);
John McCallb7bd14f2010-12-02 01:19:52 +00001333 if (S->isImplicitProperty()) {
1334 VisitDecl(S->getImplicitPropertyGetter());
1335 VisitDecl(S->getImplicitPropertySetter());
1336 } else {
1337 VisitDecl(S->getExplicitProperty());
Fariborz Jahanian681c0752010-10-14 16:04:05 +00001338 }
Fariborz Jahanian681c0752010-10-14 16:04:05 +00001339 if (S->isSuperReceiver()) {
1340 ID.AddBoolean(S->isSuperReceiver());
John McCallb7bd14f2010-12-02 01:19:52 +00001341 VisitType(S->getSuperReceiverType());
Fariborz Jahanian681c0752010-10-14 16:04:05 +00001342 }
Douglas Gregora7095092009-07-28 14:44:31 +00001343}
1344
Ted Kremeneke65b0862012-03-06 20:05:56 +00001345void StmtProfiler::VisitObjCSubscriptRefExpr(const ObjCSubscriptRefExpr *S) {
1346 VisitExpr(S);
1347 VisitDecl(S->getAtIndexMethodDecl());
1348 VisitDecl(S->setAtIndexMethodDecl());
1349}
1350
Chandler Carruth631abd92011-06-16 06:47:06 +00001351void StmtProfiler::VisitObjCMessageExpr(const ObjCMessageExpr *S) {
Douglas Gregora7095092009-07-28 14:44:31 +00001352 VisitExpr(S);
1353 VisitName(S->getSelector());
1354 VisitDecl(S->getMethodDecl());
1355}
1356
Chandler Carruth631abd92011-06-16 06:47:06 +00001357void StmtProfiler::VisitObjCIsaExpr(const ObjCIsaExpr *S) {
Douglas Gregora7095092009-07-28 14:44:31 +00001358 VisitExpr(S);
1359 ID.AddBoolean(S->isArrow());
1360}
1361
Ted Kremeneke65b0862012-03-06 20:05:56 +00001362void StmtProfiler::VisitObjCBoolLiteralExpr(const ObjCBoolLiteralExpr *S) {
1363 VisitExpr(S);
1364 ID.AddBoolean(S->getValue());
1365}
1366
Chandler Carruth631abd92011-06-16 06:47:06 +00001367void StmtProfiler::VisitObjCIndirectCopyRestoreExpr(
1368 const ObjCIndirectCopyRestoreExpr *S) {
John McCall31168b02011-06-15 23:02:42 +00001369 VisitExpr(S);
1370 ID.AddBoolean(S->shouldCopy());
1371}
1372
Chandler Carruth631abd92011-06-16 06:47:06 +00001373void StmtProfiler::VisitObjCBridgedCastExpr(const ObjCBridgedCastExpr *S) {
John McCall31168b02011-06-15 23:02:42 +00001374 VisitExplicitCastExpr(S);
1375 ID.AddBoolean(S->getBridgeKind());
1376}
1377
Chandler Carruth631abd92011-06-16 06:47:06 +00001378void StmtProfiler::VisitDecl(const Decl *D) {
Douglas Gregor70317122009-07-31 15:45:02 +00001379 ID.AddInteger(D? D->getKind() : 0);
Mike Stump11289f42009-09-09 15:08:12 +00001380
Douglas Gregora5dd9f82009-07-30 23:18:24 +00001381 if (Canonical && D) {
Chandler Carruth631abd92011-06-16 06:47:06 +00001382 if (const NonTypeTemplateParmDecl *NTTP =
1383 dyn_cast<NonTypeTemplateParmDecl>(D)) {
Douglas Gregord9aedfa2009-07-28 15:32:17 +00001384 ID.AddInteger(NTTP->getDepth());
1385 ID.AddInteger(NTTP->getIndex());
Douglas Gregorf5500772011-01-05 15:48:55 +00001386 ID.AddBoolean(NTTP->isParameterPack());
Douglas Gregor00044172009-07-29 16:09:57 +00001387 VisitType(NTTP->getType());
Douglas Gregor5c193b92009-07-28 00:33:38 +00001388 return;
1389 }
Mike Stump11289f42009-09-09 15:08:12 +00001390
Chandler Carruth631abd92011-06-16 06:47:06 +00001391 if (const ParmVarDecl *Parm = dyn_cast<ParmVarDecl>(D)) {
John McCall8fb0d9d2011-05-01 22:35:37 +00001392 // The Itanium C++ ABI uses the type, scope depth, and scope
1393 // index of a parameter when mangling expressions that involve
1394 // function parameters, so we will use the parameter's type for
1395 // establishing function parameter identity. That way, our
1396 // definition of "equivalent" (per C++ [temp.over.link]) is at
1397 // least as strong as the definition of "equivalent" used for
1398 // name mangling.
Douglas Gregor70317122009-07-31 15:45:02 +00001399 VisitType(Parm->getType());
John McCall8fb0d9d2011-05-01 22:35:37 +00001400 ID.AddInteger(Parm->getFunctionScopeDepth());
1401 ID.AddInteger(Parm->getFunctionScopeIndex());
Douglas Gregor70317122009-07-31 15:45:02 +00001402 return;
1403 }
Mike Stump11289f42009-09-09 15:08:12 +00001404
Richard Smithd9a1cd82012-04-02 18:53:24 +00001405 if (const TemplateTypeParmDecl *TTP =
1406 dyn_cast<TemplateTypeParmDecl>(D)) {
1407 ID.AddInteger(TTP->getDepth());
1408 ID.AddInteger(TTP->getIndex());
1409 ID.AddBoolean(TTP->isParameterPack());
1410 return;
1411 }
1412
Chandler Carruth631abd92011-06-16 06:47:06 +00001413 if (const TemplateTemplateParmDecl *TTP =
1414 dyn_cast<TemplateTemplateParmDecl>(D)) {
Douglas Gregorc97f09f2009-07-31 15:46:56 +00001415 ID.AddInteger(TTP->getDepth());
1416 ID.AddInteger(TTP->getIndex());
Douglas Gregorf5500772011-01-05 15:48:55 +00001417 ID.AddBoolean(TTP->isParameterPack());
Douglas Gregorc97f09f2009-07-31 15:46:56 +00001418 return;
1419 }
Douglas Gregor5c193b92009-07-28 00:33:38 +00001420 }
Mike Stump11289f42009-09-09 15:08:12 +00001421
Craig Topper36250ad2014-05-12 05:36:57 +00001422 ID.AddPointer(D? D->getCanonicalDecl() : nullptr);
Douglas Gregord9aedfa2009-07-28 15:32:17 +00001423}
1424
1425void StmtProfiler::VisitType(QualType T) {
1426 if (Canonical)
1427 T = Context.getCanonicalType(T);
Mike Stump11289f42009-09-09 15:08:12 +00001428
Douglas Gregor5c193b92009-07-28 00:33:38 +00001429 ID.AddPointer(T.getAsOpaquePtr());
1430}
1431
1432void StmtProfiler::VisitName(DeclarationName Name) {
1433 ID.AddPointer(Name.getAsOpaquePtr());
1434}
1435
1436void StmtProfiler::VisitNestedNameSpecifier(NestedNameSpecifier *NNS) {
1437 if (Canonical)
1438 NNS = Context.getCanonicalNestedNameSpecifier(NNS);
1439 ID.AddPointer(NNS);
1440}
1441
1442void StmtProfiler::VisitTemplateName(TemplateName Name) {
1443 if (Canonical)
1444 Name = Context.getCanonicalTemplateName(Name);
Mike Stump11289f42009-09-09 15:08:12 +00001445
Douglas Gregor5c193b92009-07-28 00:33:38 +00001446 Name.Profile(ID);
1447}
1448
John McCall0ad16662009-10-29 08:12:44 +00001449void StmtProfiler::VisitTemplateArguments(const TemplateArgumentLoc *Args,
Douglas Gregor5c193b92009-07-28 00:33:38 +00001450 unsigned NumArgs) {
1451 ID.AddInteger(NumArgs);
John McCall0ad16662009-10-29 08:12:44 +00001452 for (unsigned I = 0; I != NumArgs; ++I)
1453 VisitTemplateArgument(Args[I].getArgument());
1454}
Mike Stump11289f42009-09-09 15:08:12 +00001455
John McCall0ad16662009-10-29 08:12:44 +00001456void StmtProfiler::VisitTemplateArgument(const TemplateArgument &Arg) {
1457 // Mostly repetitive with TemplateArgument::Profile!
1458 ID.AddInteger(Arg.getKind());
1459 switch (Arg.getKind()) {
1460 case TemplateArgument::Null:
1461 break;
Mike Stump11289f42009-09-09 15:08:12 +00001462
John McCall0ad16662009-10-29 08:12:44 +00001463 case TemplateArgument::Type:
1464 VisitType(Arg.getAsType());
1465 break;
Mike Stump11289f42009-09-09 15:08:12 +00001466
Douglas Gregor9167f8b2009-11-11 01:00:40 +00001467 case TemplateArgument::Template:
Douglas Gregore4ff4b52011-01-05 18:58:31 +00001468 case TemplateArgument::TemplateExpansion:
1469 VisitTemplateName(Arg.getAsTemplateOrTemplatePattern());
Douglas Gregor9167f8b2009-11-11 01:00:40 +00001470 break;
Alexis Hunta8136cc2010-05-05 15:23:54 +00001471
John McCall0ad16662009-10-29 08:12:44 +00001472 case TemplateArgument::Declaration:
1473 VisitDecl(Arg.getAsDecl());
1474 break;
Mike Stump11289f42009-09-09 15:08:12 +00001475
Eli Friedmanb826a002012-09-26 02:36:12 +00001476 case TemplateArgument::NullPtr:
1477 VisitType(Arg.getNullPtrType());
1478 break;
1479
John McCall0ad16662009-10-29 08:12:44 +00001480 case TemplateArgument::Integral:
Benjamin Kramer6003ad52012-06-07 15:09:51 +00001481 Arg.getAsIntegral().Profile(ID);
John McCall0ad16662009-10-29 08:12:44 +00001482 VisitType(Arg.getIntegralType());
1483 break;
Mike Stump11289f42009-09-09 15:08:12 +00001484
John McCall0ad16662009-10-29 08:12:44 +00001485 case TemplateArgument::Expression:
1486 Visit(Arg.getAsExpr());
1487 break;
Mike Stump11289f42009-09-09 15:08:12 +00001488
John McCall0ad16662009-10-29 08:12:44 +00001489 case TemplateArgument::Pack:
Aaron Ballman2a89e852014-07-15 21:32:31 +00001490 for (const auto &P : Arg.pack_elements())
1491 VisitTemplateArgument(P);
John McCall0ad16662009-10-29 08:12:44 +00001492 break;
Douglas Gregor5c193b92009-07-28 00:33:38 +00001493 }
1494}
1495
Jay Foad39c79802011-01-12 09:06:06 +00001496void Stmt::Profile(llvm::FoldingSetNodeID &ID, const ASTContext &Context,
Chandler Carruth631abd92011-06-16 06:47:06 +00001497 bool Canonical) const {
Douglas Gregor5c193b92009-07-28 00:33:38 +00001498 StmtProfiler Profiler(ID, Context, Canonical);
1499 Profiler.Visit(this);
1500}