From c56bdc5520ae014aff90886ed9521e67e45d97a8 Mon Sep 17 00:00:00 2001 From: Chris Lattner Date: Thu, 22 May 2003 18:26:48 +0000 Subject: Do not assert fail or crash when a bytecode parse fails! llvm-svn: 6284 --- llvm/lib/Bytecode/Reader/Reader.cpp | 1 + llvm/lib/Bytecode/Reader/ReaderInternals.h | 3 +++ 2 files changed, 4 insertions(+) (limited to 'llvm/lib/Bytecode') diff --git a/llvm/lib/Bytecode/Reader/Reader.cpp b/llvm/lib/Bytecode/Reader/Reader.cpp index 7c0e6d43897..1a7e3d5e56b 100644 --- a/llvm/lib/Bytecode/Reader/Reader.cpp +++ b/llvm/lib/Bytecode/Reader/Reader.cpp @@ -642,6 +642,7 @@ Module *BytecodeParser::ParseBytecode(const unsigned char *Buf, TheModule = new Module(ModuleID); if (ParseModule(Buf, EndBuf)) { + freeState(); // Must destroy handles before deleting module! delete TheModule; TheModule = 0; } diff --git a/llvm/lib/Bytecode/Reader/ReaderInternals.h b/llvm/lib/Bytecode/Reader/ReaderInternals.h index 6709bc2d4d6..a8ee6fc8b94 100644 --- a/llvm/lib/Bytecode/Reader/ReaderInternals.h +++ b/llvm/lib/Bytecode/Reader/ReaderInternals.h @@ -45,6 +45,9 @@ public: FirstDerivedTyID = Type::FirstDerivedTyID; } ~BytecodeParser() { + freeState(); + } + void freeState() { freeTable(Values); freeTable(LateResolveValues); freeTable(ModuleValues); -- cgit v1.2.3