From 03b1a38cd9b723be107b0b3f12b7d9e383185e2f Mon Sep 17 00:00:00 2001 From: Mark Jansen Date: Sat, 2 Jan 2021 17:21:07 +0100 Subject: [PATCH] Fix reading binary columns --- src/MSIExtract.Core/Msi/ViewWrapper.cs | 28 +++++++++++++------------- 1 file changed, 14 insertions(+), 14 deletions(-) diff --git a/src/MSIExtract.Core/Msi/ViewWrapper.cs b/src/MSIExtract.Core/Msi/ViewWrapper.cs index 9636057..b7dba83 100644 --- a/src/MSIExtract.Core/Msi/ViewWrapper.cs +++ b/src/MSIExtract.Core/Msi/ViewWrapper.cs @@ -98,21 +98,21 @@ public IList Records values[i] = sourceRecord.GetInteger(i + 1); else if (_columns[i].IsStream) { - var tempBuffer = new byte[_columns[i].Size + 1]; - var allData = new byte[_columns[i].Size + 1]; - int totalBytesRead = 0; - int bytesReadThisCall; - - using var stream = sourceRecord.GetStream(i); - do + using (var stream = sourceRecord.GetStream(i + 1)) { - // It seems to read the Binary table with _columns[i].Size ==0 tempBuffer must be at least 1 in length or an ExecutionEngineException occurs. - bytesReadThisCall = stream.Read(tempBuffer, 0, tempBuffer.Length); - Buffer.BlockCopy(tempBuffer, 0, allData, totalBytesRead, bytesReadThisCall); - totalBytesRead += bytesReadThisCall; - Debug.Assert(bytesReadThisCall > 0); - } while (bytesReadThisCall > 0 && (totalBytesRead < _columns[i].Size)); - values[i] = allData; + var tempBuffer = new byte[512]; + var allData = new byte[stream.Length]; + int totalBytesRead = 0; + int bytesReadThisCall; + do + { + bytesReadThisCall = stream.Read(tempBuffer, 0, tempBuffer.Length); + Buffer.BlockCopy(tempBuffer, 0, allData, totalBytesRead, bytesReadThisCall); + totalBytesRead += bytesReadThisCall; + Debug.Assert(bytesReadThisCall > 0); + } while (bytesReadThisCall > 0 && (totalBytesRead < allData.Length)); + values[i] = allData; + } } else if (_columns[i].IsObject) {