diff options
| author | Dimitry Andric <dim@FreeBSD.org> | 2012-05-22 21:36:38 +0000 | 
|---|---|---|
| committer | Dimitry Andric <dim@FreeBSD.org> | 2012-05-22 21:36:38 +0000 | 
| commit | e51da3eab6ad2d02fcd8f68bdaef22d33a855210 (patch) | |
| tree | 1bfa44f5a9427d658426ac7786a70741e36d1bc8 /lib/Serialization | |
| parent | 6b9a6e390fbb92c40eb9c6ac9e7abbd88dd7a767 (diff) | |
Notes
Diffstat (limited to 'lib/Serialization')
| -rw-r--r-- | lib/Serialization/ASTReader.cpp | 3 | ||||
| -rw-r--r-- | lib/Serialization/ASTWriter.cpp | 3 | 
2 files changed, 6 insertions, 0 deletions
diff --git a/lib/Serialization/ASTReader.cpp b/lib/Serialization/ASTReader.cpp index 06b42f3ab130..fd0c17139468 100644 --- a/lib/Serialization/ASTReader.cpp +++ b/lib/Serialization/ASTReader.cpp @@ -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); diff --git a/lib/Serialization/ASTWriter.cpp b/lib/Serialization/ASTWriter.cpp index 81c0a9dd48ac..36933a9d9b8c 100644 --- a/lib/Serialization/ASTWriter.cpp +++ b/lib/Serialization/ASTWriter.cpp @@ -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;  }  | 
