forked from OSchip/llvm-project
Fix serialization of uninstantiated exception specifications. Patch by Li Kan,
test by me. llvm-svn: 155289
This commit is contained in:
parent
0ab75fd27f
commit
8b987a9976
|
@ -3866,6 +3866,9 @@ QualType ASTReader::readTypeRecord(unsigned Index) {
|
|||
EPI.Exceptions = Exceptions.data();
|
||||
} else if (EST == EST_ComputedNoexcept) {
|
||||
EPI.NoexceptExpr = ReadExpr(*Loc.F);
|
||||
} else if (EST == EST_Uninstantiated) {
|
||||
EPI.ExceptionSpecDecl = ReadDeclAs<FunctionDecl>(*Loc.F, Record, Idx);
|
||||
EPI.ExceptionSpecTemplate = ReadDeclAs<FunctionDecl>(*Loc.F, Record, Idx);
|
||||
}
|
||||
return Context.getFunctionType(ResultType, ParamTypes.data(), NumParams,
|
||||
EPI);
|
||||
|
|
|
@ -195,6 +195,9 @@ void ASTTypeWriter::VisitFunctionProtoType(const FunctionProtoType *T) {
|
|||
Writer.AddTypeRef(T->getExceptionType(I), Record);
|
||||
} else if (T->getExceptionSpecType() == EST_ComputedNoexcept) {
|
||||
Writer.AddStmt(T->getNoexceptExpr());
|
||||
} else if (T->getExceptionSpecType() == EST_Uninstantiated) {
|
||||
Writer.AddDeclRef(T->getExceptionSpecDecl(), Record);
|
||||
Writer.AddDeclRef(T->getExceptionSpecTemplate(), Record);
|
||||
}
|
||||
Code = TYPE_FUNCTION_PROTO;
|
||||
}
|
||||
|
|
|
@ -0,0 +1,17 @@
|
|||
// RUN: %clang_cc1 -pedantic-errors -std=c++11 -emit-pch %s -o %t
|
||||
// RUN: %clang_cc1 -pedantic-errors -std=c++11 -include-pch %t -verify %s
|
||||
|
||||
#ifndef HEADER_INCLUDED
|
||||
|
||||
#define HEADER_INCLUDED
|
||||
|
||||
template<bool b> int f() noexcept(b) {}
|
||||
decltype(f<false>()) a;
|
||||
decltype(f<true>()) b;
|
||||
|
||||
#else
|
||||
|
||||
static_assert(!noexcept(f<false>()), "");
|
||||
static_assert(noexcept(f<true>()), "");
|
||||
|
||||
#endif
|
Loading…
Reference in New Issue