summaryrefslogtreecommitdiff
path: root/lib/Bitcode/Reader/Deserialize.cpp
diff options
context:
space:
mode:
authorTed Kremenek <kremenek@apple.com>2007-11-05 20:47:27 +0000
committerTed Kremenek <kremenek@apple.com>2007-11-05 20:47:27 +0000
commit14ac17e2dfa9cf66dec0da3618badf87163c9bf9 (patch)
tree74da4fa1925ce1bdfd2bdc8a86b6b428d3d076d5 /lib/Bitcode/Reader/Deserialize.cpp
parent619bc0ac1729090fa419606cb1ef5c5df9b58569 (diff)
downloadllvm-14ac17e2dfa9cf66dec0da3618badf87163c9bf9.tar.gz
llvm-14ac17e2dfa9cf66dec0da3618badf87163c9bf9.tar.bz2
llvm-14ac17e2dfa9cf66dec0da3618badf87163c9bf9.tar.xz
Added default creation of root-level block by bitstream serializer.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@43732 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Bitcode/Reader/Deserialize.cpp')
-rw-r--r--lib/Bitcode/Reader/Deserialize.cpp25
1 files changed, 22 insertions, 3 deletions
diff --git a/lib/Bitcode/Reader/Deserialize.cpp b/lib/Bitcode/Reader/Deserialize.cpp
index 0482b1f7e9..31d180ff32 100644
--- a/lib/Bitcode/Reader/Deserialize.cpp
+++ b/lib/Bitcode/Reader/Deserialize.cpp
@@ -47,9 +47,28 @@ void Deserializer::ReadRecord() {
// FIXME: Check if we haven't run off the edge of the stream.
// FIXME: Handle abbreviations.
- // FIXME: Check for the correct code.
- unsigned Code = Stream.ReadCode();
+ unsigned Code;
+ while (true) {
+
+ Code = Stream.ReadCode();
+
+ if (Code == bitc::ENTER_SUBBLOCK) {
+ // No known subblocks, always skip them.
+ unsigned id = Stream.ReadSubBlockID();
+ Stream.EnterSubBlock(id);
+ continue;
+ }
+
+ if (Code == bitc::END_BLOCK) {
+ bool x = Stream.ReadBlockEnd();
+ assert (!x && "Error at block end.");
+ continue;
+ }
+
+ break;
+ }
+
assert (Record.size() == 0);
Stream.ReadRecord(Code,Record);
assert (Record.size() > 0);
@@ -141,7 +160,7 @@ uintptr_t Deserializer::ReadInternalRefPtr() {
MapTy::value_type& E = BPatchMap.FindAndConstruct(BPKey(PtrId));
- assert (!HasFinalPtr(E) &&
+ assert (HasFinalPtr(E) &&
"Cannot backpatch references. Object must be already deserialized.");
return GetFinalPtr(E);