diff options
Diffstat (limited to 'lib/Bitcode')
-rw-r--r-- | lib/Bitcode/Reader/Deserialize.cpp | 16 | ||||
-rw-r--r-- | lib/Bitcode/Writer/Serialize.cpp | 22 |
2 files changed, 34 insertions, 4 deletions
diff --git a/lib/Bitcode/Reader/Deserialize.cpp b/lib/Bitcode/Reader/Deserialize.cpp index 31d180ff32..ef4e4f7e00 100644 --- a/lib/Bitcode/Reader/Deserialize.cpp +++ b/lib/Bitcode/Reader/Deserialize.cpp @@ -47,10 +47,15 @@ void Deserializer::ReadRecord() { // FIXME: Check if we haven't run off the edge of the stream. // FIXME: Handle abbreviations. + assert (Record.size() == 0); + unsigned Code; while (true) { + if (Stream.AtEndOfStream()) + return; + Code = Stream.ReadCode(); if (Code == bitc::ENTER_SUBBLOCK) { @@ -71,7 +76,16 @@ void Deserializer::ReadRecord() { assert (Record.size() == 0); Stream.ReadRecord(Code,Record); - assert (Record.size() > 0); + assert (Record.size() > 0 || Stream.AtEndOfStream()); +} + +bool Deserializer::AtEnd() { + if (inRecord()) + return false; + + ReadRecord(); + + return Stream.AtEndOfStream(); } uint64_t Deserializer::ReadInt() { diff --git a/lib/Bitcode/Writer/Serialize.cpp b/lib/Bitcode/Writer/Serialize.cpp index 58baf104c7..f25a1542d3 100644 --- a/lib/Bitcode/Writer/Serialize.cpp +++ b/lib/Bitcode/Writer/Serialize.cpp @@ -17,16 +17,17 @@ using namespace llvm; Serializer::Serializer(BitstreamWriter& stream, unsigned BlockID) - : Stream(stream), inBlock(BlockID >= 8) { + : Stream(stream), BlockLevel(0) { - if (inBlock) Stream.EnterSubblock(8,3); + if (BlockID >= 8) + EnterBlock(8,3); } Serializer::~Serializer() { if (inRecord()) EmitRecord(); - if (inBlock) + while (BlockLevel > 0) Stream.ExitBlock(); Stream.FlushToWord(); @@ -38,7 +39,21 @@ void Serializer::EmitRecord() { Record.clear(); } +void Serializer::EnterBlock(unsigned BlockID,unsigned CodeLen) { + Flush(); + Stream.EnterSubblock(BlockID,CodeLen); + ++BlockLevel; +} + +void Serializer::ExitBlock() { + assert (BlockLevel > 0); + --BlockLevel; + Flush(); + Stream.ExitBlock(); +} + void Serializer::EmitInt(unsigned X) { + assert (BlockLevel > 0); Record.push_back(X); } @@ -71,6 +86,7 @@ unsigned Serializer::getPtrId(const void* ptr) { else return I->second; } + #define INT_EMIT(TYPE)\ void SerializeTrait<TYPE>::Emit(Serializer&S, TYPE X) { S.EmitInt(X); } |