Simplify handling of decompression
authorReid Spencer <rspencer@reidspencer.com>
Sun, 14 Nov 2004 22:00:09 +0000 (22:00 +0000)
committerReid Spencer <rspencer@reidspencer.com>
Sun, 14 Nov 2004 22:00:09 +0000 (22:00 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@17769 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Bytecode/Reader/Reader.h

index 72a6040366403950cfe797eb47d10e3bd2e15a17..c78faf625fe694bf5777baf6125e73ebee1b3ab4 100644 (file)
@@ -47,13 +47,14 @@ public:
   BytecodeReader( 
     BytecodeHandler* h = 0
   ) { 
+    decompressedBlock = 0;
     Handler = h;
   }
 
   ~BytecodeReader() { 
     freeState(); 
-    if (bi.buff != 0)
-      ::free(bi.buff);
+    if (decompressedBlock)
+      ::free(decompressedBlock);
   }
 
 /// @}
@@ -67,18 +68,6 @@ public:
   /// @brief The type used for a vector of potentially abstract types
   typedef std::vector<PATypeHolder> TypeListTy;
 
-  /// This structure is only used when a bytecode file is compressed.
-  /// As bytecode is being decompressed, the memory buffer might need
-  /// to be reallocated. The buffer allocation is handled in a callback 
-  /// and this structure is needed to retain information across calls
-  /// to the callback.
-  /// @brief An internal buffer object used for handling decompression
-  struct BufferInfo {
-    char* buff;
-    unsigned size;
-    BufferInfo() { buff = 0; size = 0; }
-  };
-
   /// This type provides a vector of Value* via the User class for
   /// storage of Values that have been constructed when reading the
   /// bytecode. Because of forward referencing, constant replacement
@@ -251,7 +240,7 @@ protected:
 /// @name Data
 /// @{
 private:
-  BufferInfo bi;       ///< Buffer info for decompression
+  char*  decompressedBlock; ///< Result of decompression 
   BufPtr MemStart;     ///< Start of the memory buffer
   BufPtr MemEnd;       ///< End of the memory buffer
   BufPtr BlockStart;   ///< Start of current block being parsed