diff options
| author | David Majnemer <david.majnemer@gmail.com> | 2016-06-11 01:25:04 +0000 |
|---|---|---|
| committer | David Majnemer <david.majnemer@gmail.com> | 2016-06-11 01:25:04 +0000 |
| commit | 5d321e63c02c0399739d4f48695086b7dc2306db (patch) | |
| tree | 230c1cd013c92d92990c40fda9e9706ed3342ddc /clang/lib | |
| parent | 959a8c974df3c0b9240172b685cd1563171b30a0 (diff) | |
| download | bcm5719-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.cpp | 7 |
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; } |

