aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--include/clang/AST/Type.h4
-rw-r--r--lib/AST/Type.cpp11
-rw-r--r--lib/Sema/SemaExpr.cpp1
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());
}