diff options
author | Charles Krinke | 2009-08-02 19:30:25 +0000 |
---|---|---|
committer | Charles Krinke | 2009-08-02 19:30:25 +0000 |
commit | acf7206f4ba31c7068d9d235c5bd36bb039eb72d (patch) | |
tree | fa6b199c9ec48e2b88a3fc7d2e544ff4864296d4 | |
parent | * An enum for The VisualParams array that the viewer sends us with 90% of the... (diff) | |
download | opensim-SC-acf7206f4ba31c7068d9d235c5bd36bb039eb72d.zip opensim-SC-acf7206f4ba31c7068d9d235c5bd36bb039eb72d.tar.gz opensim-SC-acf7206f4ba31c7068d9d235c5bd36bb039eb72d.tar.bz2 opensim-SC-acf7206f4ba31c7068d9d235c5bd36bb039eb72d.tar.xz |
Thank you kindly, dslake, for a patch that:
The region dearchive module assumes extra null bytes will be appended
to the end of every OAR file. This may be due to the block nature of
storage but it seems like an unsafe assumption. When streaming region
archives over a network or through a memory stream, no additional null
bytes are added to the end and this an exception.
-rw-r--r-- | OpenSim/Framework/Serialization/TarArchiveReader.cs | 4 |
1 files changed, 4 insertions, 0 deletions
diff --git a/OpenSim/Framework/Serialization/TarArchiveReader.cs b/OpenSim/Framework/Serialization/TarArchiveReader.cs index 694ea70..77c29f8 100644 --- a/OpenSim/Framework/Serialization/TarArchiveReader.cs +++ b/OpenSim/Framework/Serialization/TarArchiveReader.cs | |||
@@ -105,6 +105,10 @@ namespace OpenSim.Framework.Serialization | |||
105 | { | 105 | { |
106 | byte[] header = m_br.ReadBytes(512); | 106 | byte[] header = m_br.ReadBytes(512); |
107 | 107 | ||
108 | // If there are no more bytes in the stream, return null header | ||
109 | if (header.Length == 0) | ||
110 | return null; | ||
111 | |||
108 | // If we've reached the end of the archive we'll be in null block territory, which means | 112 | // If we've reached the end of the archive we'll be in null block territory, which means |
109 | // the next byte will be 0 | 113 | // the next byte will be 0 |
110 | if (header[0] == 0) | 114 | if (header[0] == 0) |