diff options
author | Ted Kremenek <kremenek@apple.com> | 2007-11-05 21:36:35 +0000 |
---|---|---|
committer | Ted Kremenek <kremenek@apple.com> | 2007-11-05 21:36:35 +0000 |
commit | 0a6d98e10e3b5080861bc1e06c2053d7941f319a (patch) | |
tree | 864684a5e5e7b95e1e2b6c38a2903a4eeae4bc25 | |
parent | eb57ea7ea2378b77bc995371c1888193b960cd03 (diff) |
Added support in serializer and deserializer to create arbitrary blocks.
Added detection of end-of-stream in deserializer.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@43736 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | include/llvm/Bitcode/Deserialize.h | 2 | ||||
-rw-r--r-- | include/llvm/Bitcode/Serialize.h | 5 | ||||
-rw-r--r-- | lib/Bitcode/Reader/Deserialize.cpp | 16 | ||||
-rw-r--r-- | lib/Bitcode/Writer/Serialize.cpp | 22 |
4 files changed, 40 insertions, 5 deletions
diff --git a/include/llvm/Bitcode/Deserialize.h b/include/llvm/Bitcode/Deserialize.h index 2454dca565..0398e434ca 100644 --- a/include/llvm/Bitcode/Deserialize.h +++ b/include/llvm/Bitcode/Deserialize.h @@ -153,6 +153,8 @@ public: void RegisterPtr(const void* Ptr) { RegisterPtr(ReadInt(),Ptr); } + + bool AtEnd(); private: void ReadRecord(); diff --git a/include/llvm/Bitcode/Serialize.h b/include/llvm/Bitcode/Serialize.h index a465beca9d..74637f5d87 100644 --- a/include/llvm/Bitcode/Serialize.h +++ b/include/llvm/Bitcode/Serialize.h @@ -25,7 +25,7 @@ namespace llvm { class Serializer { BitstreamWriter& Stream; SmallVector<uint64_t,10> Record; - bool inBlock; + unsigned BlockLevel; typedef DenseMap<const void*,unsigned> MapTy; MapTy PtrMap; @@ -56,6 +56,9 @@ public: void Flush() { if (inRecord()) EmitRecord(); } + void EnterBlock(unsigned BlockID = 8, unsigned CodeLen = 3); + void ExitBlock(); + private: void EmitRecord(); inline bool inRecord() { return Record.size() > 0; } 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); } |