stub out code for reading record with blobs as blobs. Not active yet.
authorChris Lattner <sabre@nondot.org>
Mon, 6 Apr 2009 22:44:40 +0000 (22:44 +0000)
committerChris Lattner <sabre@nondot.org>
Mon, 6 Apr 2009 22:44:40 +0000 (22:44 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@68472 91177308-0d34-0410-b5e6-96231b3b80d8

tools/llvm-bcanalyzer/llvm-bcanalyzer.cpp

index cde27fac48ce2ec0a128ecfd380149da3c5bfd05..2953e08afa560250080507bdc8095020f99232ec 100644 (file)
@@ -341,12 +341,33 @@ static bool ParseBlock(BitstreamReader &Stream, unsigned IndentLevel) {
       ++BlockStats.NumAbbrevs;
       break;
     default:
+      Record.clear();
+      bool HasBlob = false;
+
       ++BlockStats.NumRecords;
-      if (AbbrevID != bitc::UNABBREV_RECORD)
+      if (AbbrevID != bitc::UNABBREV_RECORD) {
         ++BlockStats.NumAbbreviatedRecords;
-      
-      Record.clear();
-      unsigned Code = Stream.ReadRecord(AbbrevID, Record);
+        const BitCodeAbbrev *Abbv = Stream.getAbbrev(AbbrevID);
+        if (Abbv->getNumOperandInfos() != 0) {
+          const BitCodeAbbrevOp &LastOp =  
+            Abbv->getOperandInfo(Abbv->getNumOperandInfos()-1);
+          // If the last operand is a blob, then this record has blob data.
+          if (LastOp.isEncoding() && 
+              LastOp.getEncoding() == BitCodeAbbrevOp::Blob)
+            HasBlob = true;
+        }
+      }
+        
+      unsigned Code;
+      const char *BlobStart = 0;
+      unsigned BlobLen = 0;
+      if (!HasBlob)
+        Code = Stream.ReadRecord(AbbrevID, Record);
+      else {
+        Code = Stream.ReadRecord(AbbrevID, Record);
+        BlobStart = BlobStart;
+        BlobLen = BlobLen;
+      }
 
       // Increment the # occurrences of this code.
       if (BlockStats.CodeFreq.size() <= Code)