diff options
author | Douglas Gregor <dgregor@apple.com> | 2013-03-08 22:43:48 +0000 |
---|---|---|
committer | Douglas Gregor <dgregor@apple.com> | 2013-03-08 22:43:48 +0000 |
commit | f9b76cd8b5e4eeb1ae13af9f7d55f83d0e98e2b1 (patch) | |
tree | 9547d8b97086e858135e7194084af17f3e6edb9b | |
parent | 058927b8d4ddb539721d2a5e1c6dbab7cb2d47a4 (diff) | |
download | bcm5719-llvm-f9b76cd8b5e4eeb1ae13af9f7d55f83d0e98e2b1.tar.gz bcm5719-llvm-f9b76cd8b5e4eeb1ae13af9f7d55f83d0e98e2b1.zip |
<rdar://problem/13170740> Be a little more careful when instantiating 'this' expressions.
llvm-svn: 176731
-rw-r--r-- | clang/lib/Sema/TreeTransform.h | 9 |
1 files changed, 7 insertions, 2 deletions
diff --git a/clang/lib/Sema/TreeTransform.h b/clang/lib/Sema/TreeTransform.h index 7112e7d5f31..1dde87d2e6d 100644 --- a/clang/lib/Sema/TreeTransform.h +++ b/clang/lib/Sema/TreeTransform.h @@ -7167,9 +7167,14 @@ TreeTransform<Derived>::TransformCXXThisExpr(CXXThisExpr *E) { QualType T; if (CXXMethodDecl *MD = dyn_cast<CXXMethodDecl>(DC)) T = MD->getThisType(getSema().Context); - else + else if (CXXRecordDecl *Record = dyn_cast<CXXRecordDecl>(DC)) { T = getSema().Context.getPointerType( - getSema().Context.getRecordType(cast<CXXRecordDecl>(DC))); + getSema().Context.getRecordType(Record)); + } else { + assert(SemaRef.Context.getDiagnostics().hasErrorOccurred() && + "this in the wrong scope?"); + return ExprError(); + } if (!getDerived().AlwaysRebuild() && T == E->getType()) { // Make sure that we capture 'this'. |