summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDouglas Gregor <dgregor@apple.com>2013-03-08 22:43:48 +0000
committerDouglas Gregor <dgregor@apple.com>2013-03-08 22:43:48 +0000
commitf9b76cd8b5e4eeb1ae13af9f7d55f83d0e98e2b1 (patch)
tree9547d8b97086e858135e7194084af17f3e6edb9b
parent058927b8d4ddb539721d2a5e1c6dbab7cb2d47a4 (diff)
downloadbcm5719-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.h9
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'.
OpenPOWER on IntegriCloud