summaryrefslogtreecommitdiffstats
path: root/clang/lib
diff options
context:
space:
mode:
authorDavid Majnemer <david.majnemer@gmail.com>2016-06-11 01:25:04 +0000
committerDavid Majnemer <david.majnemer@gmail.com>2016-06-11 01:25:04 +0000
commit5d321e63c02c0399739d4f48695086b7dc2306db (patch)
tree230c1cd013c92d92990c40fda9e9706ed3342ddc /clang/lib
parent959a8c974df3c0b9240172b685cd1563171b30a0 (diff)
downloadbcm5719-llvm-5d321e63c02c0399739d4f48695086b7dc2306db.tar.gz
bcm5719-llvm-5d321e63c02c0399739d4f48695086b7dc2306db.zip
[Sema] Return an appropriate result from CheckSpecifiedExceptionType
We shouldn't return true from CheckSpecifiedExceptionType if the record type is incomplete and -fms-extensions is engaged. Otherwise we will have an incomplete AST. llvm-svn: 272447
Diffstat (limited to 'clang/lib')
-rw-r--r--clang/lib/Sema/SemaExceptionSpec.cpp7
1 files changed, 5 insertions, 2 deletions
diff --git a/clang/lib/Sema/SemaExceptionSpec.cpp b/clang/lib/Sema/SemaExceptionSpec.cpp
index f2ae6bfe2ff..b7bed6de2d7 100644
--- a/clang/lib/Sema/SemaExceptionSpec.cpp
+++ b/clang/lib/Sema/SemaExceptionSpec.cpp
@@ -112,12 +112,15 @@ bool Sema::CheckSpecifiedExceptionType(QualType &T, SourceRange Range) {
// pointer or reference to a class currently being defined.
// In Microsoft mode, downgrade this to a warning.
unsigned DiagID = diag::err_incomplete_in_exception_spec;
- if (getLangOpts().MicrosoftExt)
+ bool ReturnValueOnError = true;
+ if (getLangOpts().MicrosoftExt) {
DiagID = diag::ext_incomplete_in_exception_spec;
+ ReturnValueOnError = false;
+ }
if (!(PointeeT->isRecordType() &&
PointeeT->getAs<RecordType>()->isBeingDefined()) &&
RequireCompleteType(Range.getBegin(), PointeeT, DiagID, Kind, Range))
- return true;
+ return ReturnValueOnError;
return false;
}
OpenPOWER on IntegriCloud