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
This commit is contained in:
Ted Kremenek 2007-11-05 21:36:35 +00:00
parent eb57ea7ea2
commit 0a6d98e10e
4 changed files with 40 additions and 5 deletions

View File

@ -153,6 +153,8 @@ public:
void RegisterPtr(const void* Ptr) {
RegisterPtr(ReadInt(),Ptr);
}
bool AtEnd();
private:
void ReadRecord();

View File

@ -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; }

View File

@ -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() {

View File

@ -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); }