diff options
author | Anders Carlsson <andersca@mac.com> | 2009-07-10 21:35:09 +0000 |
---|---|---|
committer | Anders Carlsson <andersca@mac.com> | 2009-07-10 21:35:09 +0000 |
commit | 7ca3f6feeaab0e741a2fa542c7d9bdf16642afb0 (patch) | |
tree | c455f6177200853edfcbbcaf86e8c68263d916a8 | |
parent | 7997cbf2d57e4c7f33aacef6d73a946f73cb03ab (diff) | |
download | bcm5719-llvm-7ca3f6feeaab0e741a2fa542c7d9bdf16642afb0.tar.gz bcm5719-llvm-7ca3f6feeaab0e741a2fa542c7d9bdf16642afb0.zip |
Fix type of 'this' and add a decltype test.
llvm-svn: 75291
-rw-r--r-- | clang/lib/AST/DeclCXX.cpp | 2 | ||||
-rw-r--r-- | clang/test/SemaCXX/decltype-this.cpp | 15 | ||||
-rw-r--r-- | clang/test/SemaTemplate/instantiate-function-1.cpp | 2 |
3 files changed, 17 insertions, 2 deletions
diff --git a/clang/lib/AST/DeclCXX.cpp b/clang/lib/AST/DeclCXX.cpp index b7051f8d2c5..45825e10324 100644 --- a/clang/lib/AST/DeclCXX.cpp +++ b/clang/lib/AST/DeclCXX.cpp @@ -360,7 +360,7 @@ QualType CXXMethodDecl::getThisType(ASTContext &C) const { else ClassTy = C.getTagDeclType(const_cast<CXXRecordDecl*>(getParent())); ClassTy = ClassTy.getWithAdditionalQualifiers(getTypeQualifiers()); - return C.getPointerType(ClassTy).withConst(); + return C.getPointerType(ClassTy); } CXXBaseOrMemberInitializer:: diff --git a/clang/test/SemaCXX/decltype-this.cpp b/clang/test/SemaCXX/decltype-this.cpp new file mode 100644 index 00000000000..fc001063c51 --- /dev/null +++ b/clang/test/SemaCXX/decltype-this.cpp @@ -0,0 +1,15 @@ +// RUN: clang-cc -fsyntax-only -verify -std=c++0x %t +template<typename T, typename U> struct is_same { + static const bool value = false; +}; + +template<typename T> struct is_same<T, T> { + static const bool value = true; +}; + +struct S { + void f() { static_assert(is_same<decltype(this), S*>::value, ""); } + void g() const { static_assert(is_same<decltype(this), const S*>::value, ""); } + void h() volatile { static_assert(is_same<decltype(this), volatile S*>::value, ""); } + void i() const volatile { static_assert(is_same<decltype(this), const volatile S*>::value, ""); } +}; diff --git a/clang/test/SemaTemplate/instantiate-function-1.cpp b/clang/test/SemaTemplate/instantiate-function-1.cpp index 023cc5437f6..2749ec24401 100644 --- a/clang/test/SemaTemplate/instantiate-function-1.cpp +++ b/clang/test/SemaTemplate/instantiate-function-1.cpp @@ -140,7 +140,7 @@ template<typename T> struct Member0 { tp->f; this->f; - this.f; // expected-error{{member reference base type 'Member0<T> *const' is not a structure or union}} + this.f; // expected-error{{member reference base type 'Member0<T> *' is not a structure or union}} } }; |