Make the Stmt::Profile method const, and the StmtProfile visitor

a ConstStmtVisitor. This also required adding some const iteration
support for designated initializers and making some of the getters on
the designators const.

It also made the formatting of StmtProfile.cpp rather awkward. I'm happy
to adjust any of the formatting if folks have suggestions. I've at least
fitted it all within 80 columns.

llvm-svn: 133152
This commit is contained in:
Chandler Carruth 2011-06-16 06:47:06 +00:00
parent 0585a61821
commit 631abd9365
4 changed files with 171 additions and 144 deletions

View File

@ -3539,9 +3539,9 @@ public:
bool isArrayDesignator() const { return Kind == ArrayDesignator; } bool isArrayDesignator() const { return Kind == ArrayDesignator; }
bool isArrayRangeDesignator() const { return Kind == ArrayRangeDesignator; } bool isArrayRangeDesignator() const { return Kind == ArrayRangeDesignator; }
IdentifierInfo * getFieldName(); IdentifierInfo *getFieldName() const;
FieldDecl *getField() { FieldDecl *getField() const {
assert(Kind == FieldDesignator && "Only valid on a field designator"); assert(Kind == FieldDesignator && "Only valid on a field designator");
if (Field.NameOrField & 0x01) if (Field.NameOrField & 0x01)
return 0; return 0;
@ -3620,6 +3620,12 @@ public:
return Designators + NumDesignators; return Designators + NumDesignators;
} }
typedef const Designator *const_designators_iterator;
const_designators_iterator designators_begin() const { return Designators; }
const_designators_iterator designators_end() const {
return Designators + NumDesignators;
}
typedef std::reverse_iterator<designators_iterator> typedef std::reverse_iterator<designators_iterator>
reverse_designators_iterator; reverse_designators_iterator;
reverse_designators_iterator designators_rbegin() { reverse_designators_iterator designators_rbegin() {
@ -3629,6 +3635,15 @@ public:
return reverse_designators_iterator(designators_begin()); return reverse_designators_iterator(designators_begin());
} }
typedef std::reverse_iterator<const_designators_iterator>
const_reverse_designators_iterator;
const_reverse_designators_iterator designators_rbegin() const {
return const_reverse_designators_iterator(designators_end());
}
const_reverse_designators_iterator designators_rend() const {
return const_reverse_designators_iterator(designators_begin());
}
Designator *getDesignator(unsigned Idx) { return &designators_begin()[Idx]; } Designator *getDesignator(unsigned Idx) { return &designators_begin()[Idx]; }
void setDesignators(ASTContext &C, const Designator *Desigs, void setDesignators(ASTContext &C, const Designator *Desigs,

View File

@ -335,7 +335,7 @@ public:
/// declaration pointers) or the exact representation of the statement as /// declaration pointers) or the exact representation of the statement as
/// written in the source. /// written in the source.
void Profile(llvm::FoldingSetNodeID &ID, const ASTContext &Context, void Profile(llvm::FoldingSetNodeID &ID, const ASTContext &Context,
bool Canonical); bool Canonical) const;
}; };
/// DeclStmt - Adaptor class for mixing declarations with statements and /// DeclStmt - Adaptor class for mixing declarations with statements and

View File

@ -2815,7 +2815,7 @@ GenericSelectionExpr::GenericSelectionExpr(ASTContext &Context,
// DesignatedInitExpr // DesignatedInitExpr
//===----------------------------------------------------------------------===// //===----------------------------------------------------------------------===//
IdentifierInfo *DesignatedInitExpr::Designator::getFieldName() { IdentifierInfo *DesignatedInitExpr::Designator::getFieldName() const {
assert(Kind == FieldDesignator && "Only valid on a field designator"); assert(Kind == FieldDesignator && "Only valid on a field designator");
if (Field.NameOrField & 0x01) if (Field.NameOrField & 0x01)
return reinterpret_cast<IdentifierInfo *>(Field.NameOrField&~0x01); return reinterpret_cast<IdentifierInfo *>(Field.NameOrField&~0x01);

View File

@ -23,7 +23,7 @@
using namespace clang; using namespace clang;
namespace { namespace {
class StmtProfiler : public StmtVisitor<StmtProfiler> { class StmtProfiler : public ConstStmtVisitor<StmtProfiler> {
llvm::FoldingSetNodeID &ID; llvm::FoldingSetNodeID &ID;
const ASTContext &Context; const ASTContext &Context;
bool Canonical; bool Canonical;
@ -33,14 +33,14 @@ namespace {
bool Canonical) bool Canonical)
: ID(ID), Context(Context), Canonical(Canonical) { } : ID(ID), Context(Context), Canonical(Canonical) { }
void VisitStmt(Stmt *S); void VisitStmt(const Stmt *S);
#define STMT(Node, Base) void Visit##Node(Node *S); #define STMT(Node, Base) void Visit##Node(const Node *S);
#include "clang/AST/StmtNodes.inc" #include "clang/AST/StmtNodes.inc"
/// \brief Visit a declaration that is referenced within an expression /// \brief Visit a declaration that is referenced within an expression
/// or statement. /// or statement.
void VisitDecl(Decl *D); void VisitDecl(const Decl *D);
/// \brief Visit a type that is referenced within an expression or /// \brief Visit a type that is referenced within an expression or
/// statement. /// statement.
@ -59,96 +59,97 @@ namespace {
/// \brief Visit template arguments that occur within an expression or /// \brief Visit template arguments that occur within an expression or
/// statement. /// statement.
void VisitTemplateArguments(const TemplateArgumentLoc *Args, unsigned NumArgs); void VisitTemplateArguments(const TemplateArgumentLoc *Args,
unsigned NumArgs);
/// \brief Visit a single template argument. /// \brief Visit a single template argument.
void VisitTemplateArgument(const TemplateArgument &Arg); void VisitTemplateArgument(const TemplateArgument &Arg);
}; };
} }
void StmtProfiler::VisitStmt(Stmt *S) { void StmtProfiler::VisitStmt(const Stmt *S) {
ID.AddInteger(S->getStmtClass()); ID.AddInteger(S->getStmtClass());
for (Stmt::child_range C = S->children(); C; ++C) for (Stmt::const_child_range C = S->children(); C; ++C)
Visit(*C); Visit(*C);
} }
void StmtProfiler::VisitDeclStmt(DeclStmt *S) { void StmtProfiler::VisitDeclStmt(const DeclStmt *S) {
VisitStmt(S); VisitStmt(S);
for (DeclStmt::decl_iterator D = S->decl_begin(), DEnd = S->decl_end(); for (DeclStmt::const_decl_iterator D = S->decl_begin(), DEnd = S->decl_end();
D != DEnd; ++D) D != DEnd; ++D)
VisitDecl(*D); VisitDecl(*D);
} }
void StmtProfiler::VisitNullStmt(NullStmt *S) { void StmtProfiler::VisitNullStmt(const NullStmt *S) {
VisitStmt(S); VisitStmt(S);
} }
void StmtProfiler::VisitCompoundStmt(CompoundStmt *S) { void StmtProfiler::VisitCompoundStmt(const CompoundStmt *S) {
VisitStmt(S); VisitStmt(S);
} }
void StmtProfiler::VisitSwitchCase(SwitchCase *S) { void StmtProfiler::VisitSwitchCase(const SwitchCase *S) {
VisitStmt(S); VisitStmt(S);
} }
void StmtProfiler::VisitCaseStmt(CaseStmt *S) { void StmtProfiler::VisitCaseStmt(const CaseStmt *S) {
VisitStmt(S); VisitStmt(S);
} }
void StmtProfiler::VisitDefaultStmt(DefaultStmt *S) { void StmtProfiler::VisitDefaultStmt(const DefaultStmt *S) {
VisitStmt(S); VisitStmt(S);
} }
void StmtProfiler::VisitLabelStmt(LabelStmt *S) { void StmtProfiler::VisitLabelStmt(const LabelStmt *S) {
VisitStmt(S); VisitStmt(S);
VisitDecl(S->getDecl()); VisitDecl(S->getDecl());
} }
void StmtProfiler::VisitIfStmt(IfStmt *S) { void StmtProfiler::VisitIfStmt(const IfStmt *S) {
VisitStmt(S); VisitStmt(S);
VisitDecl(S->getConditionVariable()); VisitDecl(S->getConditionVariable());
} }
void StmtProfiler::VisitSwitchStmt(SwitchStmt *S) { void StmtProfiler::VisitSwitchStmt(const SwitchStmt *S) {
VisitStmt(S); VisitStmt(S);
VisitDecl(S->getConditionVariable()); VisitDecl(S->getConditionVariable());
} }
void StmtProfiler::VisitWhileStmt(WhileStmt *S) { void StmtProfiler::VisitWhileStmt(const WhileStmt *S) {
VisitStmt(S); VisitStmt(S);
VisitDecl(S->getConditionVariable()); VisitDecl(S->getConditionVariable());
} }
void StmtProfiler::VisitDoStmt(DoStmt *S) { void StmtProfiler::VisitDoStmt(const DoStmt *S) {
VisitStmt(S); VisitStmt(S);
} }
void StmtProfiler::VisitForStmt(ForStmt *S) { void StmtProfiler::VisitForStmt(const ForStmt *S) {
VisitStmt(S); VisitStmt(S);
} }
void StmtProfiler::VisitGotoStmt(GotoStmt *S) { void StmtProfiler::VisitGotoStmt(const GotoStmt *S) {
VisitStmt(S); VisitStmt(S);
VisitDecl(S->getLabel()); VisitDecl(S->getLabel());
} }
void StmtProfiler::VisitIndirectGotoStmt(IndirectGotoStmt *S) { void StmtProfiler::VisitIndirectGotoStmt(const IndirectGotoStmt *S) {
VisitStmt(S); VisitStmt(S);
} }
void StmtProfiler::VisitContinueStmt(ContinueStmt *S) { void StmtProfiler::VisitContinueStmt(const ContinueStmt *S) {
VisitStmt(S); VisitStmt(S);
} }
void StmtProfiler::VisitBreakStmt(BreakStmt *S) { void StmtProfiler::VisitBreakStmt(const BreakStmt *S) {
VisitStmt(S); VisitStmt(S);
} }
void StmtProfiler::VisitReturnStmt(ReturnStmt *S) { void StmtProfiler::VisitReturnStmt(const ReturnStmt *S) {
VisitStmt(S); VisitStmt(S);
} }
void StmtProfiler::VisitAsmStmt(AsmStmt *S) { void StmtProfiler::VisitAsmStmt(const AsmStmt *S) {
VisitStmt(S); VisitStmt(S);
ID.AddBoolean(S->isVolatile()); ID.AddBoolean(S->isVolatile());
ID.AddBoolean(S->isSimple()); ID.AddBoolean(S->isSimple());
@ -168,67 +169,69 @@ void StmtProfiler::VisitAsmStmt(AsmStmt *S) {
VisitStringLiteral(S->getClobber(I)); VisitStringLiteral(S->getClobber(I));
} }
void StmtProfiler::VisitCXXCatchStmt(CXXCatchStmt *S) { void StmtProfiler::VisitCXXCatchStmt(const CXXCatchStmt *S) {
VisitStmt(S); VisitStmt(S);
VisitType(S->getCaughtType()); VisitType(S->getCaughtType());
} }
void StmtProfiler::VisitCXXTryStmt(CXXTryStmt *S) { void StmtProfiler::VisitCXXTryStmt(const CXXTryStmt *S) {
VisitStmt(S); VisitStmt(S);
} }
void StmtProfiler::VisitCXXForRangeStmt(CXXForRangeStmt *S) { void StmtProfiler::VisitCXXForRangeStmt(const CXXForRangeStmt *S) {
VisitStmt(S); VisitStmt(S);
} }
void StmtProfiler::VisitSEHTryStmt(SEHTryStmt *S) { void StmtProfiler::VisitSEHTryStmt(const SEHTryStmt *S) {
VisitStmt(S); VisitStmt(S);
} }
void StmtProfiler::VisitSEHFinallyStmt(SEHFinallyStmt *S) { void StmtProfiler::VisitSEHFinallyStmt(const SEHFinallyStmt *S) {
VisitStmt(S); VisitStmt(S);
} }
void StmtProfiler::VisitSEHExceptStmt(SEHExceptStmt *S) { void StmtProfiler::VisitSEHExceptStmt(const SEHExceptStmt *S) {
VisitStmt(S); VisitStmt(S);
} }
void StmtProfiler::VisitObjCForCollectionStmt(ObjCForCollectionStmt *S) { void StmtProfiler::VisitObjCForCollectionStmt(const ObjCForCollectionStmt *S) {
VisitStmt(S); VisitStmt(S);
} }
void StmtProfiler::VisitObjCAtCatchStmt(ObjCAtCatchStmt *S) { void StmtProfiler::VisitObjCAtCatchStmt(const ObjCAtCatchStmt *S) {
VisitStmt(S); VisitStmt(S);
ID.AddBoolean(S->hasEllipsis()); ID.AddBoolean(S->hasEllipsis());
if (S->getCatchParamDecl()) if (S->getCatchParamDecl())
VisitType(S->getCatchParamDecl()->getType()); VisitType(S->getCatchParamDecl()->getType());
} }
void StmtProfiler::VisitObjCAtFinallyStmt(ObjCAtFinallyStmt *S) { void StmtProfiler::VisitObjCAtFinallyStmt(const ObjCAtFinallyStmt *S) {
VisitStmt(S); VisitStmt(S);
} }
void StmtProfiler::VisitObjCAtTryStmt(ObjCAtTryStmt *S) { void StmtProfiler::VisitObjCAtTryStmt(const ObjCAtTryStmt *S) {
VisitStmt(S); VisitStmt(S);
} }
void StmtProfiler::VisitObjCAtSynchronizedStmt(ObjCAtSynchronizedStmt *S) { void
StmtProfiler::VisitObjCAtSynchronizedStmt(const ObjCAtSynchronizedStmt *S) {
VisitStmt(S); VisitStmt(S);
} }
void StmtProfiler::VisitObjCAtThrowStmt(ObjCAtThrowStmt *S) { void StmtProfiler::VisitObjCAtThrowStmt(const ObjCAtThrowStmt *S) {
VisitStmt(S); VisitStmt(S);
} }
void StmtProfiler::VisitObjCAutoreleasePoolStmt(ObjCAutoreleasePoolStmt *S) { void
StmtProfiler::VisitObjCAutoreleasePoolStmt(const ObjCAutoreleasePoolStmt *S) {
VisitStmt(S); VisitStmt(S);
} }
void StmtProfiler::VisitExpr(Expr *S) { void StmtProfiler::VisitExpr(const Expr *S) {
VisitStmt(S); VisitStmt(S);
} }
void StmtProfiler::VisitDeclRefExpr(DeclRefExpr *S) { void StmtProfiler::VisitDeclRefExpr(const DeclRefExpr *S) {
VisitExpr(S); VisitExpr(S);
if (!Canonical) if (!Canonical)
VisitNestedNameSpecifier(S->getQualifier()); VisitNestedNameSpecifier(S->getQualifier());
@ -237,52 +240,52 @@ void StmtProfiler::VisitDeclRefExpr(DeclRefExpr *S) {
VisitTemplateArguments(S->getTemplateArgs(), S->getNumTemplateArgs()); VisitTemplateArguments(S->getTemplateArgs(), S->getNumTemplateArgs());
} }
void StmtProfiler::VisitPredefinedExpr(PredefinedExpr *S) { void StmtProfiler::VisitPredefinedExpr(const PredefinedExpr *S) {
VisitExpr(S); VisitExpr(S);
ID.AddInteger(S->getIdentType()); ID.AddInteger(S->getIdentType());
} }
void StmtProfiler::VisitIntegerLiteral(IntegerLiteral *S) { void StmtProfiler::VisitIntegerLiteral(const IntegerLiteral *S) {
VisitExpr(S); VisitExpr(S);
S->getValue().Profile(ID); S->getValue().Profile(ID);
} }
void StmtProfiler::VisitCharacterLiteral(CharacterLiteral *S) { void StmtProfiler::VisitCharacterLiteral(const CharacterLiteral *S) {
VisitExpr(S); VisitExpr(S);
ID.AddBoolean(S->isWide()); ID.AddBoolean(S->isWide());
ID.AddInteger(S->getValue()); ID.AddInteger(S->getValue());
} }
void StmtProfiler::VisitFloatingLiteral(FloatingLiteral *S) { void StmtProfiler::VisitFloatingLiteral(const FloatingLiteral *S) {
VisitExpr(S); VisitExpr(S);
S->getValue().Profile(ID); S->getValue().Profile(ID);
ID.AddBoolean(S->isExact()); ID.AddBoolean(S->isExact());
} }
void StmtProfiler::VisitImaginaryLiteral(ImaginaryLiteral *S) { void StmtProfiler::VisitImaginaryLiteral(const ImaginaryLiteral *S) {
VisitExpr(S); VisitExpr(S);
} }
void StmtProfiler::VisitStringLiteral(StringLiteral *S) { void StmtProfiler::VisitStringLiteral(const StringLiteral *S) {
VisitExpr(S); VisitExpr(S);
ID.AddString(S->getString()); ID.AddString(S->getString());
ID.AddBoolean(S->isWide()); ID.AddBoolean(S->isWide());
} }
void StmtProfiler::VisitParenExpr(ParenExpr *S) { void StmtProfiler::VisitParenExpr(const ParenExpr *S) {
VisitExpr(S); VisitExpr(S);
} }
void StmtProfiler::VisitParenListExpr(ParenListExpr *S) { void StmtProfiler::VisitParenListExpr(const ParenListExpr *S) {
VisitExpr(S); VisitExpr(S);
} }
void StmtProfiler::VisitUnaryOperator(UnaryOperator *S) { void StmtProfiler::VisitUnaryOperator(const UnaryOperator *S) {
VisitExpr(S); VisitExpr(S);
ID.AddInteger(S->getOpcode()); ID.AddInteger(S->getOpcode());
} }
void StmtProfiler::VisitOffsetOfExpr(OffsetOfExpr *S) { void StmtProfiler::VisitOffsetOfExpr(const OffsetOfExpr *S) {
VisitType(S->getTypeSourceInfo()->getType()); VisitType(S->getTypeSourceInfo()->getType());
unsigned n = S->getNumComponents(); unsigned n = S->getNumComponents();
for (unsigned i = 0; i < n; ++i) { for (unsigned i = 0; i < n; ++i) {
@ -310,22 +313,23 @@ void StmtProfiler::VisitOffsetOfExpr(OffsetOfExpr *S) {
VisitExpr(S); VisitExpr(S);
} }
void StmtProfiler::VisitUnaryExprOrTypeTraitExpr(UnaryExprOrTypeTraitExpr *S) { void
StmtProfiler::VisitUnaryExprOrTypeTraitExpr(const UnaryExprOrTypeTraitExpr *S) {
VisitExpr(S); VisitExpr(S);
ID.AddInteger(S->getKind()); ID.AddInteger(S->getKind());
if (S->isArgumentType()) if (S->isArgumentType())
VisitType(S->getArgumentType()); VisitType(S->getArgumentType());
} }
void StmtProfiler::VisitArraySubscriptExpr(ArraySubscriptExpr *S) { void StmtProfiler::VisitArraySubscriptExpr(const ArraySubscriptExpr *S) {
VisitExpr(S); VisitExpr(S);
} }
void StmtProfiler::VisitCallExpr(CallExpr *S) { void StmtProfiler::VisitCallExpr(const CallExpr *S) {
VisitExpr(S); VisitExpr(S);
} }
void StmtProfiler::VisitMemberExpr(MemberExpr *S) { void StmtProfiler::VisitMemberExpr(const MemberExpr *S) {
VisitExpr(S); VisitExpr(S);
VisitDecl(S->getMemberDecl()); VisitDecl(S->getMemberDecl());
if (!Canonical) if (!Canonical)
@ -333,72 +337,74 @@ void StmtProfiler::VisitMemberExpr(MemberExpr *S) {
ID.AddBoolean(S->isArrow()); ID.AddBoolean(S->isArrow());
} }
void StmtProfiler::VisitCompoundLiteralExpr(CompoundLiteralExpr *S) { void StmtProfiler::VisitCompoundLiteralExpr(const CompoundLiteralExpr *S) {
VisitExpr(S); VisitExpr(S);
ID.AddBoolean(S->isFileScope()); ID.AddBoolean(S->isFileScope());
} }
void StmtProfiler::VisitCastExpr(CastExpr *S) { void StmtProfiler::VisitCastExpr(const CastExpr *S) {
VisitExpr(S); VisitExpr(S);
} }
void StmtProfiler::VisitImplicitCastExpr(ImplicitCastExpr *S) { void StmtProfiler::VisitImplicitCastExpr(const ImplicitCastExpr *S) {
VisitCastExpr(S); VisitCastExpr(S);
ID.AddInteger(S->getValueKind()); ID.AddInteger(S->getValueKind());
} }
void StmtProfiler::VisitExplicitCastExpr(ExplicitCastExpr *S) { void StmtProfiler::VisitExplicitCastExpr(const ExplicitCastExpr *S) {
VisitCastExpr(S); VisitCastExpr(S);
VisitType(S->getTypeAsWritten()); VisitType(S->getTypeAsWritten());
} }
void StmtProfiler::VisitCStyleCastExpr(CStyleCastExpr *S) { void StmtProfiler::VisitCStyleCastExpr(const CStyleCastExpr *S) {
VisitExplicitCastExpr(S); VisitExplicitCastExpr(S);
} }
void StmtProfiler::VisitBinaryOperator(BinaryOperator *S) { void StmtProfiler::VisitBinaryOperator(const BinaryOperator *S) {
VisitExpr(S); VisitExpr(S);
ID.AddInteger(S->getOpcode()); ID.AddInteger(S->getOpcode());
} }
void StmtProfiler::VisitCompoundAssignOperator(CompoundAssignOperator *S) { void
StmtProfiler::VisitCompoundAssignOperator(const CompoundAssignOperator *S) {
VisitBinaryOperator(S); VisitBinaryOperator(S);
} }
void StmtProfiler::VisitConditionalOperator(ConditionalOperator *S) { void StmtProfiler::VisitConditionalOperator(const ConditionalOperator *S) {
VisitExpr(S); VisitExpr(S);
} }
void StmtProfiler::VisitBinaryConditionalOperator(BinaryConditionalOperator *S){ void StmtProfiler::VisitBinaryConditionalOperator(
const BinaryConditionalOperator *S){
VisitExpr(S); VisitExpr(S);
} }
void StmtProfiler::VisitAddrLabelExpr(AddrLabelExpr *S) { void StmtProfiler::VisitAddrLabelExpr(const AddrLabelExpr *S) {
VisitExpr(S); VisitExpr(S);
VisitDecl(S->getLabel()); VisitDecl(S->getLabel());
} }
void StmtProfiler::VisitStmtExpr(StmtExpr *S) { void StmtProfiler::VisitStmtExpr(const StmtExpr *S) {
VisitExpr(S); VisitExpr(S);
} }
void StmtProfiler::VisitShuffleVectorExpr(ShuffleVectorExpr *S) { void StmtProfiler::VisitShuffleVectorExpr(const ShuffleVectorExpr *S) {
VisitExpr(S); VisitExpr(S);
} }
void StmtProfiler::VisitChooseExpr(ChooseExpr *S) { void StmtProfiler::VisitChooseExpr(const ChooseExpr *S) {
VisitExpr(S); VisitExpr(S);
} }
void StmtProfiler::VisitGNUNullExpr(GNUNullExpr *S) { void StmtProfiler::VisitGNUNullExpr(const GNUNullExpr *S) {
VisitExpr(S); VisitExpr(S);
} }
void StmtProfiler::VisitVAArgExpr(VAArgExpr *S) { void StmtProfiler::VisitVAArgExpr(const VAArgExpr *S) {
VisitExpr(S); VisitExpr(S);
} }
void StmtProfiler::VisitInitListExpr(InitListExpr *S) { void StmtProfiler::VisitInitListExpr(const InitListExpr *S) {
if (S->getSyntacticForm()) { if (S->getSyntacticForm()) {
VisitInitListExpr(S->getSyntacticForm()); VisitInitListExpr(S->getSyntacticForm());
return; return;
@ -407,11 +413,11 @@ void StmtProfiler::VisitInitListExpr(InitListExpr *S) {
VisitExpr(S); VisitExpr(S);
} }
void StmtProfiler::VisitDesignatedInitExpr(DesignatedInitExpr *S) { void StmtProfiler::VisitDesignatedInitExpr(const DesignatedInitExpr *S) {
VisitExpr(S); VisitExpr(S);
ID.AddBoolean(S->usesGNUSyntax()); ID.AddBoolean(S->usesGNUSyntax());
for (DesignatedInitExpr::designators_iterator D = S->designators_begin(), for (DesignatedInitExpr::const_designators_iterator D =
DEnd = S->designators_end(); S->designators_begin(), DEnd = S->designators_end();
D != DEnd; ++D) { D != DEnd; ++D) {
if (D->isFieldDesignator()) { if (D->isFieldDesignator()) {
ID.AddInteger(0); ID.AddInteger(0);
@ -429,28 +435,28 @@ void StmtProfiler::VisitDesignatedInitExpr(DesignatedInitExpr *S) {
} }
} }
void StmtProfiler::VisitImplicitValueInitExpr(ImplicitValueInitExpr *S) { void StmtProfiler::VisitImplicitValueInitExpr(const ImplicitValueInitExpr *S) {
VisitExpr(S); VisitExpr(S);
} }
void StmtProfiler::VisitExtVectorElementExpr(ExtVectorElementExpr *S) { void StmtProfiler::VisitExtVectorElementExpr(const ExtVectorElementExpr *S) {
VisitExpr(S); VisitExpr(S);
VisitName(&S->getAccessor()); VisitName(&S->getAccessor());
} }
void StmtProfiler::VisitBlockExpr(BlockExpr *S) { void StmtProfiler::VisitBlockExpr(const BlockExpr *S) {
VisitExpr(S); VisitExpr(S);
VisitDecl(S->getBlockDecl()); VisitDecl(S->getBlockDecl());
} }
void StmtProfiler::VisitBlockDeclRefExpr(BlockDeclRefExpr *S) { void StmtProfiler::VisitBlockDeclRefExpr(const BlockDeclRefExpr *S) {
VisitExpr(S); VisitExpr(S);
VisitDecl(S->getDecl()); VisitDecl(S->getDecl());
ID.AddBoolean(S->isByRef()); ID.AddBoolean(S->isByRef());
ID.AddBoolean(S->isConstQualAdded()); ID.AddBoolean(S->isConstQualAdded());
} }
void StmtProfiler::VisitGenericSelectionExpr(GenericSelectionExpr *S) { void StmtProfiler::VisitGenericSelectionExpr(const GenericSelectionExpr *S) {
VisitExpr(S); VisitExpr(S);
for (unsigned i = 0; i != S->getNumAssocs(); ++i) { for (unsigned i = 0; i != S->getNumAssocs(); ++i) {
QualType T = S->getAssocType(i); QualType T = S->getAssocType(i);
@ -462,7 +468,7 @@ void StmtProfiler::VisitGenericSelectionExpr(GenericSelectionExpr *S) {
} }
} }
static Stmt::StmtClass DecodeOperatorCall(CXXOperatorCallExpr *S, static Stmt::StmtClass DecodeOperatorCall(const CXXOperatorCallExpr *S,
UnaryOperatorKind &UnaryOp, UnaryOperatorKind &UnaryOp,
BinaryOperatorKind &BinaryOp) { BinaryOperatorKind &BinaryOp) {
switch (S->getOperator()) { switch (S->getOperator()) {
@ -649,7 +655,7 @@ static Stmt::StmtClass DecodeOperatorCall(CXXOperatorCallExpr *S,
} }
void StmtProfiler::VisitCXXOperatorCallExpr(CXXOperatorCallExpr *S) { void StmtProfiler::VisitCXXOperatorCallExpr(const CXXOperatorCallExpr *S) {
if (S->isTypeDependent()) { if (S->isTypeDependent()) {
// Type-dependent operator calls are profiled like their underlying // Type-dependent operator calls are profiled like their underlying
// syntactic operator. // syntactic operator.
@ -675,97 +681,100 @@ void StmtProfiler::VisitCXXOperatorCallExpr(CXXOperatorCallExpr *S) {
ID.AddInteger(S->getOperator()); ID.AddInteger(S->getOperator());
} }
void StmtProfiler::VisitCXXMemberCallExpr(CXXMemberCallExpr *S) { void StmtProfiler::VisitCXXMemberCallExpr(const CXXMemberCallExpr *S) {
VisitCallExpr(S); VisitCallExpr(S);
} }
void StmtProfiler::VisitCUDAKernelCallExpr(CUDAKernelCallExpr *S) { void StmtProfiler::VisitCUDAKernelCallExpr(const CUDAKernelCallExpr *S) {
VisitCallExpr(S); VisitCallExpr(S);
} }
void StmtProfiler::VisitAsTypeExpr(AsTypeExpr *S) { void StmtProfiler::VisitAsTypeExpr(const AsTypeExpr *S) {
VisitExpr(S); VisitExpr(S);
} }
void StmtProfiler::VisitCXXNamedCastExpr(CXXNamedCastExpr *S) { void StmtProfiler::VisitCXXNamedCastExpr(const CXXNamedCastExpr *S) {
VisitExplicitCastExpr(S); VisitExplicitCastExpr(S);
} }
void StmtProfiler::VisitCXXStaticCastExpr(CXXStaticCastExpr *S) { void StmtProfiler::VisitCXXStaticCastExpr(const CXXStaticCastExpr *S) {
VisitCXXNamedCastExpr(S); VisitCXXNamedCastExpr(S);
} }
void StmtProfiler::VisitCXXDynamicCastExpr(CXXDynamicCastExpr *S) { void StmtProfiler::VisitCXXDynamicCastExpr(const CXXDynamicCastExpr *S) {
VisitCXXNamedCastExpr(S); VisitCXXNamedCastExpr(S);
} }
void StmtProfiler::VisitCXXReinterpretCastExpr(CXXReinterpretCastExpr *S) { void
StmtProfiler::VisitCXXReinterpretCastExpr(const CXXReinterpretCastExpr *S) {
VisitCXXNamedCastExpr(S); VisitCXXNamedCastExpr(S);
} }
void StmtProfiler::VisitCXXConstCastExpr(CXXConstCastExpr *S) { void StmtProfiler::VisitCXXConstCastExpr(const CXXConstCastExpr *S) {
VisitCXXNamedCastExpr(S); VisitCXXNamedCastExpr(S);
} }
void StmtProfiler::VisitCXXBoolLiteralExpr(CXXBoolLiteralExpr *S) { void StmtProfiler::VisitCXXBoolLiteralExpr(const CXXBoolLiteralExpr *S) {
VisitExpr(S); VisitExpr(S);
ID.AddBoolean(S->getValue()); ID.AddBoolean(S->getValue());
} }
void StmtProfiler::VisitCXXNullPtrLiteralExpr(CXXNullPtrLiteralExpr *S) { void StmtProfiler::VisitCXXNullPtrLiteralExpr(const CXXNullPtrLiteralExpr *S) {
VisitExpr(S); VisitExpr(S);
} }
void StmtProfiler::VisitCXXTypeidExpr(CXXTypeidExpr *S) { void StmtProfiler::VisitCXXTypeidExpr(const CXXTypeidExpr *S) {
VisitExpr(S); VisitExpr(S);
if (S->isTypeOperand()) if (S->isTypeOperand())
VisitType(S->getTypeOperand()); VisitType(S->getTypeOperand());
} }
void StmtProfiler::VisitCXXUuidofExpr(CXXUuidofExpr *S) { void StmtProfiler::VisitCXXUuidofExpr(const CXXUuidofExpr *S) {
VisitExpr(S); VisitExpr(S);
if (S->isTypeOperand()) if (S->isTypeOperand())
VisitType(S->getTypeOperand()); VisitType(S->getTypeOperand());
} }
void StmtProfiler::VisitCXXThisExpr(CXXThisExpr *S) { void StmtProfiler::VisitCXXThisExpr(const CXXThisExpr *S) {
VisitExpr(S); VisitExpr(S);
} }
void StmtProfiler::VisitCXXThrowExpr(CXXThrowExpr *S) { void StmtProfiler::VisitCXXThrowExpr(const CXXThrowExpr *S) {
VisitExpr(S); VisitExpr(S);
} }
void StmtProfiler::VisitCXXDefaultArgExpr(CXXDefaultArgExpr *S) { void StmtProfiler::VisitCXXDefaultArgExpr(const CXXDefaultArgExpr *S) {
VisitExpr(S); VisitExpr(S);
VisitDecl(S->getParam()); VisitDecl(S->getParam());
} }
void StmtProfiler::VisitCXXBindTemporaryExpr(CXXBindTemporaryExpr *S) { void StmtProfiler::VisitCXXBindTemporaryExpr(const CXXBindTemporaryExpr *S) {
VisitExpr(S); VisitExpr(S);
VisitDecl( VisitDecl(
const_cast<CXXDestructorDecl *>(S->getTemporary()->getDestructor())); const_cast<CXXDestructorDecl *>(S->getTemporary()->getDestructor()));
} }
void StmtProfiler::VisitCXXConstructExpr(CXXConstructExpr *S) { void StmtProfiler::VisitCXXConstructExpr(const CXXConstructExpr *S) {
VisitExpr(S); VisitExpr(S);
VisitDecl(S->getConstructor()); VisitDecl(S->getConstructor());
ID.AddBoolean(S->isElidable()); ID.AddBoolean(S->isElidable());
} }
void StmtProfiler::VisitCXXFunctionalCastExpr(CXXFunctionalCastExpr *S) { void StmtProfiler::VisitCXXFunctionalCastExpr(const CXXFunctionalCastExpr *S) {
VisitExplicitCastExpr(S); VisitExplicitCastExpr(S);
} }
void StmtProfiler::VisitCXXTemporaryObjectExpr(CXXTemporaryObjectExpr *S) { void
StmtProfiler::VisitCXXTemporaryObjectExpr(const CXXTemporaryObjectExpr *S) {
VisitCXXConstructExpr(S); VisitCXXConstructExpr(S);
} }
void StmtProfiler::VisitCXXScalarValueInitExpr(CXXScalarValueInitExpr *S) { void
StmtProfiler::VisitCXXScalarValueInitExpr(const CXXScalarValueInitExpr *S) {
VisitExpr(S); VisitExpr(S);
} }
void StmtProfiler::VisitCXXDeleteExpr(CXXDeleteExpr *S) { void StmtProfiler::VisitCXXDeleteExpr(const CXXDeleteExpr *S) {
VisitExpr(S); VisitExpr(S);
ID.AddBoolean(S->isGlobalDelete()); ID.AddBoolean(S->isGlobalDelete());
ID.AddBoolean(S->isArrayForm()); ID.AddBoolean(S->isArrayForm());
@ -773,7 +782,7 @@ void StmtProfiler::VisitCXXDeleteExpr(CXXDeleteExpr *S) {
} }
void StmtProfiler::VisitCXXNewExpr(CXXNewExpr *S) { void StmtProfiler::VisitCXXNewExpr(const CXXNewExpr *S) {
VisitExpr(S); VisitExpr(S);
VisitType(S->getAllocatedType()); VisitType(S->getAllocatedType());
VisitDecl(S->getOperatorNew()); VisitDecl(S->getOperatorNew());
@ -787,14 +796,15 @@ void StmtProfiler::VisitCXXNewExpr(CXXNewExpr *S) {
ID.AddInteger(S->getNumConstructorArgs()); ID.AddInteger(S->getNumConstructorArgs());
} }
void StmtProfiler::VisitCXXPseudoDestructorExpr(CXXPseudoDestructorExpr *S) { void
StmtProfiler::VisitCXXPseudoDestructorExpr(const CXXPseudoDestructorExpr *S) {
VisitExpr(S); VisitExpr(S);
ID.AddBoolean(S->isArrow()); ID.AddBoolean(S->isArrow());
VisitNestedNameSpecifier(S->getQualifier()); VisitNestedNameSpecifier(S->getQualifier());
VisitType(S->getDestroyedType()); VisitType(S->getDestroyedType());
} }
void StmtProfiler::VisitOverloadExpr(OverloadExpr *S) { void StmtProfiler::VisitOverloadExpr(const OverloadExpr *S) {
VisitExpr(S); VisitExpr(S);
VisitNestedNameSpecifier(S->getQualifier()); VisitNestedNameSpecifier(S->getQualifier());
VisitName(S->getName()); VisitName(S->getName());
@ -805,37 +815,37 @@ void StmtProfiler::VisitOverloadExpr(OverloadExpr *S) {
} }
void void
StmtProfiler::VisitUnresolvedLookupExpr(UnresolvedLookupExpr *S) { StmtProfiler::VisitUnresolvedLookupExpr(const UnresolvedLookupExpr *S) {
VisitOverloadExpr(S); VisitOverloadExpr(S);
} }
void StmtProfiler::VisitUnaryTypeTraitExpr(UnaryTypeTraitExpr *S) { void StmtProfiler::VisitUnaryTypeTraitExpr(const UnaryTypeTraitExpr *S) {
VisitExpr(S); VisitExpr(S);
ID.AddInteger(S->getTrait()); ID.AddInteger(S->getTrait());
VisitType(S->getQueriedType()); VisitType(S->getQueriedType());
} }
void StmtProfiler::VisitBinaryTypeTraitExpr(BinaryTypeTraitExpr *S) { void StmtProfiler::VisitBinaryTypeTraitExpr(const BinaryTypeTraitExpr *S) {
VisitExpr(S); VisitExpr(S);
ID.AddInteger(S->getTrait()); ID.AddInteger(S->getTrait());
VisitType(S->getLhsType()); VisitType(S->getLhsType());
VisitType(S->getRhsType()); VisitType(S->getRhsType());
} }
void StmtProfiler::VisitArrayTypeTraitExpr(ArrayTypeTraitExpr *S) { void StmtProfiler::VisitArrayTypeTraitExpr(const ArrayTypeTraitExpr *S) {
VisitExpr(S); VisitExpr(S);
ID.AddInteger(S->getTrait()); ID.AddInteger(S->getTrait());
VisitType(S->getQueriedType()); VisitType(S->getQueriedType());
} }
void StmtProfiler::VisitExpressionTraitExpr(ExpressionTraitExpr *S) { void StmtProfiler::VisitExpressionTraitExpr(const ExpressionTraitExpr *S) {
VisitExpr(S); VisitExpr(S);
ID.AddInteger(S->getTrait()); ID.AddInteger(S->getTrait());
VisitExpr(S->getQueriedExpression()); VisitExpr(S->getQueriedExpression());
} }
void void StmtProfiler::VisitDependentScopeDeclRefExpr(
StmtProfiler::VisitDependentScopeDeclRefExpr(DependentScopeDeclRefExpr *S) { const DependentScopeDeclRefExpr *S) {
VisitExpr(S); VisitExpr(S);
VisitName(S->getDeclName()); VisitName(S->getDeclName());
VisitNestedNameSpecifier(S->getQualifier()); VisitNestedNameSpecifier(S->getQualifier());
@ -844,18 +854,18 @@ StmtProfiler::VisitDependentScopeDeclRefExpr(DependentScopeDeclRefExpr *S) {
VisitTemplateArguments(S->getTemplateArgs(), S->getNumTemplateArgs()); VisitTemplateArguments(S->getTemplateArgs(), S->getNumTemplateArgs());
} }
void StmtProfiler::VisitExprWithCleanups(ExprWithCleanups *S) { void StmtProfiler::VisitExprWithCleanups(const ExprWithCleanups *S) {
VisitExpr(S); VisitExpr(S);
} }
void void StmtProfiler::VisitCXXUnresolvedConstructExpr(
StmtProfiler::VisitCXXUnresolvedConstructExpr(CXXUnresolvedConstructExpr *S) { const CXXUnresolvedConstructExpr *S) {
VisitExpr(S); VisitExpr(S);
VisitType(S->getTypeAsWritten()); VisitType(S->getTypeAsWritten());
} }
void void StmtProfiler::VisitCXXDependentScopeMemberExpr(
StmtProfiler::VisitCXXDependentScopeMemberExpr(CXXDependentScopeMemberExpr *S) { const CXXDependentScopeMemberExpr *S) {
ID.AddBoolean(S->isImplicitAccess()); ID.AddBoolean(S->isImplicitAccess());
if (!S->isImplicitAccess()) { if (!S->isImplicitAccess()) {
VisitExpr(S); VisitExpr(S);
@ -868,7 +878,7 @@ StmtProfiler::VisitCXXDependentScopeMemberExpr(CXXDependentScopeMemberExpr *S) {
VisitTemplateArguments(S->getTemplateArgs(), S->getNumTemplateArgs()); VisitTemplateArguments(S->getTemplateArgs(), S->getNumTemplateArgs());
} }
void StmtProfiler::VisitUnresolvedMemberExpr(UnresolvedMemberExpr *S) { void StmtProfiler::VisitUnresolvedMemberExpr(const UnresolvedMemberExpr *S) {
ID.AddBoolean(S->isImplicitAccess()); ID.AddBoolean(S->isImplicitAccess());
if (!S->isImplicitAccess()) { if (!S->isImplicitAccess()) {
VisitExpr(S); VisitExpr(S);
@ -881,57 +891,57 @@ void StmtProfiler::VisitUnresolvedMemberExpr(UnresolvedMemberExpr *S) {
VisitTemplateArguments(S->getTemplateArgs(), S->getNumTemplateArgs()); VisitTemplateArguments(S->getTemplateArgs(), S->getNumTemplateArgs());
} }
void StmtProfiler::VisitCXXNoexceptExpr(CXXNoexceptExpr *S) { void StmtProfiler::VisitCXXNoexceptExpr(const CXXNoexceptExpr *S) {
VisitExpr(S); VisitExpr(S);
} }
void StmtProfiler::VisitPackExpansionExpr(PackExpansionExpr *S) { void StmtProfiler::VisitPackExpansionExpr(const PackExpansionExpr *S) {
VisitExpr(S); VisitExpr(S);
} }
void StmtProfiler::VisitSizeOfPackExpr(SizeOfPackExpr *S) { void StmtProfiler::VisitSizeOfPackExpr(const SizeOfPackExpr *S) {
VisitExpr(S); VisitExpr(S);
VisitDecl(S->getPack()); VisitDecl(S->getPack());
} }
void StmtProfiler::VisitSubstNonTypeTemplateParmPackExpr( void StmtProfiler::VisitSubstNonTypeTemplateParmPackExpr(
SubstNonTypeTemplateParmPackExpr *S) { const SubstNonTypeTemplateParmPackExpr *S) {
VisitExpr(S); VisitExpr(S);
VisitDecl(S->getParameterPack()); VisitDecl(S->getParameterPack());
VisitTemplateArgument(S->getArgumentPack()); VisitTemplateArgument(S->getArgumentPack());
} }
void StmtProfiler::VisitOpaqueValueExpr(OpaqueValueExpr *E) { void StmtProfiler::VisitOpaqueValueExpr(const OpaqueValueExpr *E) {
VisitExpr(E); VisitExpr(E);
} }
void StmtProfiler::VisitObjCStringLiteral(ObjCStringLiteral *S) { void StmtProfiler::VisitObjCStringLiteral(const ObjCStringLiteral *S) {
VisitExpr(S); VisitExpr(S);
} }
void StmtProfiler::VisitObjCEncodeExpr(ObjCEncodeExpr *S) { void StmtProfiler::VisitObjCEncodeExpr(const ObjCEncodeExpr *S) {
VisitExpr(S); VisitExpr(S);
VisitType(S->getEncodedType()); VisitType(S->getEncodedType());
} }
void StmtProfiler::VisitObjCSelectorExpr(ObjCSelectorExpr *S) { void StmtProfiler::VisitObjCSelectorExpr(const ObjCSelectorExpr *S) {
VisitExpr(S); VisitExpr(S);
VisitName(S->getSelector()); VisitName(S->getSelector());
} }
void StmtProfiler::VisitObjCProtocolExpr(ObjCProtocolExpr *S) { void StmtProfiler::VisitObjCProtocolExpr(const ObjCProtocolExpr *S) {
VisitExpr(S); VisitExpr(S);
VisitDecl(S->getProtocol()); VisitDecl(S->getProtocol());
} }
void StmtProfiler::VisitObjCIvarRefExpr(ObjCIvarRefExpr *S) { void StmtProfiler::VisitObjCIvarRefExpr(const ObjCIvarRefExpr *S) {
VisitExpr(S); VisitExpr(S);
VisitDecl(S->getDecl()); VisitDecl(S->getDecl());
ID.AddBoolean(S->isArrow()); ID.AddBoolean(S->isArrow());
ID.AddBoolean(S->isFreeIvar()); ID.AddBoolean(S->isFreeIvar());
} }
void StmtProfiler::VisitObjCPropertyRefExpr(ObjCPropertyRefExpr *S) { void StmtProfiler::VisitObjCPropertyRefExpr(const ObjCPropertyRefExpr *S) {
VisitExpr(S); VisitExpr(S);
if (S->isImplicitProperty()) { if (S->isImplicitProperty()) {
VisitDecl(S->getImplicitPropertyGetter()); VisitDecl(S->getImplicitPropertyGetter());
@ -945,33 +955,34 @@ void StmtProfiler::VisitObjCPropertyRefExpr(ObjCPropertyRefExpr *S) {
} }
} }
void StmtProfiler::VisitObjCMessageExpr(ObjCMessageExpr *S) { void StmtProfiler::VisitObjCMessageExpr(const ObjCMessageExpr *S) {
VisitExpr(S); VisitExpr(S);
VisitName(S->getSelector()); VisitName(S->getSelector());
VisitDecl(S->getMethodDecl()); VisitDecl(S->getMethodDecl());
} }
void StmtProfiler::VisitObjCIsaExpr(ObjCIsaExpr *S) { void StmtProfiler::VisitObjCIsaExpr(const ObjCIsaExpr *S) {
VisitExpr(S); VisitExpr(S);
ID.AddBoolean(S->isArrow()); ID.AddBoolean(S->isArrow());
} }
void void StmtProfiler::VisitObjCIndirectCopyRestoreExpr(
StmtProfiler::VisitObjCIndirectCopyRestoreExpr(ObjCIndirectCopyRestoreExpr *S) { const ObjCIndirectCopyRestoreExpr *S) {
VisitExpr(S); VisitExpr(S);
ID.AddBoolean(S->shouldCopy()); ID.AddBoolean(S->shouldCopy());
} }
void StmtProfiler::VisitObjCBridgedCastExpr(ObjCBridgedCastExpr *S) { void StmtProfiler::VisitObjCBridgedCastExpr(const ObjCBridgedCastExpr *S) {
VisitExplicitCastExpr(S); VisitExplicitCastExpr(S);
ID.AddBoolean(S->getBridgeKind()); ID.AddBoolean(S->getBridgeKind());
} }
void StmtProfiler::VisitDecl(Decl *D) { void StmtProfiler::VisitDecl(const Decl *D) {
ID.AddInteger(D? D->getKind() : 0); ID.AddInteger(D? D->getKind() : 0);
if (Canonical && D) { if (Canonical && D) {
if (NonTypeTemplateParmDecl *NTTP = dyn_cast<NonTypeTemplateParmDecl>(D)) { if (const NonTypeTemplateParmDecl *NTTP =
dyn_cast<NonTypeTemplateParmDecl>(D)) {
ID.AddInteger(NTTP->getDepth()); ID.AddInteger(NTTP->getDepth());
ID.AddInteger(NTTP->getIndex()); ID.AddInteger(NTTP->getIndex());
ID.AddBoolean(NTTP->isParameterPack()); ID.AddBoolean(NTTP->isParameterPack());
@ -979,7 +990,7 @@ void StmtProfiler::VisitDecl(Decl *D) {
return; return;
} }
if (ParmVarDecl *Parm = dyn_cast<ParmVarDecl>(D)) { if (const ParmVarDecl *Parm = dyn_cast<ParmVarDecl>(D)) {
// The Itanium C++ ABI uses the type, scope depth, and scope // The Itanium C++ ABI uses the type, scope depth, and scope
// index of a parameter when mangling expressions that involve // index of a parameter when mangling expressions that involve
// function parameters, so we will use the parameter's type for // function parameters, so we will use the parameter's type for
@ -993,7 +1004,8 @@ void StmtProfiler::VisitDecl(Decl *D) {
return; return;
} }
if (TemplateTemplateParmDecl *TTP = dyn_cast<TemplateTemplateParmDecl>(D)) { if (const TemplateTemplateParmDecl *TTP =
dyn_cast<TemplateTemplateParmDecl>(D)) {
ID.AddInteger(TTP->getDepth()); ID.AddInteger(TTP->getDepth());
ID.AddInteger(TTP->getIndex()); ID.AddInteger(TTP->getIndex());
ID.AddBoolean(TTP->isParameterPack()); ID.AddBoolean(TTP->isParameterPack());
@ -1073,7 +1085,7 @@ void StmtProfiler::VisitTemplateArgument(const TemplateArgument &Arg) {
} }
void Stmt::Profile(llvm::FoldingSetNodeID &ID, const ASTContext &Context, void Stmt::Profile(llvm::FoldingSetNodeID &ID, const ASTContext &Context,
bool Canonical) { bool Canonical) const {
StmtProfiler Profiler(ID, Context, Canonical); StmtProfiler Profiler(ID, Context, Canonical);
Profiler.Visit(this); Profiler.Visit(this);
} }