diff options
Diffstat (limited to 'clang/lib/Frontend')
-rw-r--r-- | clang/lib/Frontend/PCHReader.cpp | 7 | ||||
-rw-r--r-- | clang/lib/Frontend/PCHReaderDecl.cpp | 4 | ||||
-rw-r--r-- | clang/lib/Frontend/PCHWriterDecl.cpp | 2 |
3 files changed, 11 insertions, 2 deletions
diff --git a/clang/lib/Frontend/PCHReader.cpp b/clang/lib/Frontend/PCHReader.cpp index c220e269c23..386462443ef 100644 --- a/clang/lib/Frontend/PCHReader.cpp +++ b/clang/lib/Frontend/PCHReader.cpp @@ -3012,8 +3012,11 @@ PCHReader::ReadTemplateArgument(const RecordData &Record, unsigned &Idx) { return TemplateArgument(GetType(Record[Idx++])); case TemplateArgument::Declaration: return TemplateArgument(GetDecl(Record[Idx++])); - case TemplateArgument::Integral: - return TemplateArgument(ReadAPSInt(Record, Idx), GetType(Record[Idx++])); + case TemplateArgument::Integral: { + llvm::APSInt Value = ReadAPSInt(Record, Idx); + QualType T = GetType(Record[Idx++]); + return TemplateArgument(Value, T); + } case TemplateArgument::Template: return TemplateArgument(ReadTemplateName(Record, Idx)); case TemplateArgument::Expression: diff --git a/clang/lib/Frontend/PCHReaderDecl.cpp b/clang/lib/Frontend/PCHReaderDecl.cpp index 028c563a074..d7c5d77eb9a 100644 --- a/clang/lib/Frontend/PCHReaderDecl.cpp +++ b/clang/lib/Frontend/PCHReaderDecl.cpp @@ -216,6 +216,8 @@ void PCHDeclReader::VisitFunctionDecl(FunctionDecl *FD) { FD->setLocEnd(SourceLocation::getFromRawEncoding(Record[Idx++])); switch ((FunctionDecl::TemplatedKind)Record[Idx++]) { + default: assert(false && "Unhandled TemplatedKind!"); + break; case FunctionDecl::TK_NonTemplate: break; case FunctionDecl::TK_FunctionTemplate: @@ -257,6 +259,7 @@ void PCHDeclReader::VisitFunctionDecl(FunctionDecl *FD) { NumTemplateArgLocs, NumTemplateArgLocs ? TemplArgLocs.data() : 0, LAngleLoc, RAngleLoc); + break; } case FunctionDecl::TK_DependentFunctionTemplateSpecialization: { // Templates. @@ -273,6 +276,7 @@ void PCHDeclReader::VisitFunctionDecl(FunctionDecl *FD) { FD->setDependentTemplateSpecialization(*Reader.getContext(), TemplDecls, TemplArgs); + break; } } diff --git a/clang/lib/Frontend/PCHWriterDecl.cpp b/clang/lib/Frontend/PCHWriterDecl.cpp index 36a1848d2ae..42d506953cb 100644 --- a/clang/lib/Frontend/PCHWriterDecl.cpp +++ b/clang/lib/Frontend/PCHWriterDecl.cpp @@ -225,6 +225,8 @@ void PCHDeclWriter::VisitFunctionDecl(FunctionDecl *D) { Record.push_back(D->getTemplatedKind()); switch (D->getTemplatedKind()) { + default: assert(false && "Unhandled TemplatedKind!"); + break; case FunctionDecl::TK_NonTemplate: break; case FunctionDecl::TK_FunctionTemplate: |