diff options
-rw-r--r-- | include/clang/AST/Type.h | 4 | ||||
-rw-r--r-- | lib/AST/Type.cpp | 11 | ||||
-rw-r--r-- | lib/Sema/SemaExpr.cpp | 1 |
3 files changed, 15 insertions, 1 deletions
diff --git a/include/clang/AST/Type.h b/include/clang/AST/Type.h index 40d550a0ac..952a5dd9ba 100644 --- a/include/clang/AST/Type.h +++ b/include/clang/AST/Type.h @@ -161,7 +161,8 @@ public: } void getAsStringInternal(std::string &Str) const; - void dump(const char *s = 0) const; + void dump(const char *s) const; + void dump() const; void Profile(llvm::FoldingSetNodeID &ID) const { ID.AddPointer(getAsOpaquePtr()); @@ -394,6 +395,7 @@ private: QualType getCanonicalTypeInternal() const { return CanonicalType; } friend class QualType; public: + void dump() const; virtual void getAsStringInternal(std::string &InnerString) const = 0; static bool classof(const Type *) { return true; } diff --git a/lib/AST/Type.cpp b/lib/AST/Type.cpp index d5bef07ca9..d32f963acb 100644 --- a/lib/AST/Type.cpp +++ b/lib/AST/Type.cpp @@ -810,6 +810,17 @@ void QualType::dump(const char *msg) const { else fprintf(stderr, "%s\n", R.c_str()); } +void QualType::dump() const { + dump(""); +} + +void Type::dump() const { + std::string S = "identifier"; + getAsStringInternal(S); + fprintf(stderr, "%s\n", S.c_str()); +} + + static void AppendTypeQualList(std::string &S, unsigned TypeQuals) { // Note: funkiness to ensure we get a space only between quals. diff --git a/lib/Sema/SemaExpr.cpp b/lib/Sema/SemaExpr.cpp index 37e4ec715b..56632d1d77 100644 --- a/lib/Sema/SemaExpr.cpp +++ b/lib/Sema/SemaExpr.cpp @@ -2052,6 +2052,7 @@ QualType Sema::CheckAddressOfOperand(Expr *op, SourceLocation OpLoc) { } else assert(0 && "Unknown/unexpected decl type"); } + // If the operand has type "type", the result has type "pointer to type". return Context.getPointerType(op->getType()); } |