Always write end record unless one has already been written.

git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@51008 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
Michael Wetherell
2008-01-03 17:09:10 +00:00
parent e60f8377be
commit dd0af4bb63
4 changed files with 18 additions and 9 deletions

View File

@@ -280,6 +280,7 @@ private:
char *m_extendedHdr; char *m_extendedHdr;
size_t m_extendedSize; size_t m_extendedSize;
wxString m_badfit; wxString m_badfit;
bool m_endrecWritten;
DECLARE_NO_COPY_CLASS(wxTarOutputStream) DECLARE_NO_COPY_CLASS(wxTarOutputStream)
}; };

View File

@@ -346,6 +346,7 @@ private:
int m_level; int m_level;
wxFileOffset m_offsetAdjustment; wxFileOffset m_offsetAdjustment;
wxString m_Comment; wxString m_Comment;
bool m_endrecWritten;
DECLARE_NO_COPY_CLASS(wxZipOutputStream) DECLARE_NO_COPY_CLASS(wxZipOutputStream)
}; };

View File

@@ -1083,12 +1083,12 @@ void wxTarOutputStream::Init(wxTarFormat format)
m_extendedHdr = NULL; m_extendedHdr = NULL;
m_extendedSize = 0; m_extendedSize = 0;
m_lasterror = m_parent_o_stream->GetLastError(); m_lasterror = m_parent_o_stream->GetLastError();
m_endrecWritten = false;
} }
wxTarOutputStream::~wxTarOutputStream() wxTarOutputStream::~wxTarOutputStream()
{ {
if (m_tarsize) Close();
Close();
delete m_hdr; delete m_hdr;
delete m_hdr2; delete m_hdr2;
delete [] m_extendedHdr; delete [] m_extendedHdr;
@@ -1207,9 +1207,9 @@ bool wxTarOutputStream::CloseEntry()
bool wxTarOutputStream::Close() bool wxTarOutputStream::Close()
{ {
if (!CloseEntry()) if (!CloseEntry() || (m_tarsize == 0 && m_endrecWritten))
return false; return false;
memset(m_hdr, 0, sizeof(*m_hdr)); memset(m_hdr, 0, sizeof(*m_hdr));
int count = (RoundUpSize(m_tarsize + 2 * TAR_BLOCKSIZE, m_BlockingFactor) int count = (RoundUpSize(m_tarsize + 2 * TAR_BLOCKSIZE, m_BlockingFactor)
- m_tarsize) / TAR_BLOCKSIZE; - m_tarsize) / TAR_BLOCKSIZE;
@@ -1219,6 +1219,7 @@ bool wxTarOutputStream::Close()
m_tarsize = 0; m_tarsize = 0;
m_tarstart = wxInvalidOffset; m_tarstart = wxInvalidOffset;
m_lasterror = m_parent_o_stream->GetLastError(); m_lasterror = m_parent_o_stream->GetLastError();
m_endrecWritten = true;
return IsOk(); return IsOk();
} }

View File

@@ -1463,11 +1463,13 @@ bool wxZipInputStream::LoadEndRecord()
m_TotalEntries = endrec.GetTotalEntries(); m_TotalEntries = endrec.GetTotalEntries();
m_Comment = endrec.GetComment(); m_Comment = endrec.GetComment();
wxUint32 magic = m_TotalEntries ? CENTRAL_MAGIC : END_MAGIC;
// Now find the central-directory. we have the file offset of // Now find the central-directory. we have the file offset of
// the CD, so look there first. // the CD, so look there first.
if (m_parent_i_stream->SeekI(endrec.GetOffset()) != wxInvalidOffset && if (m_parent_i_stream->SeekI(endrec.GetOffset()) != wxInvalidOffset &&
ReadSignature() == CENTRAL_MAGIC) { ReadSignature() == magic) {
m_signature = CENTRAL_MAGIC; m_signature = magic;
m_position = endrec.GetOffset(); m_position = endrec.GetOffset();
m_offsetAdjustment = 0; m_offsetAdjustment = 0;
return true; return true;
@@ -1477,8 +1479,8 @@ bool wxZipInputStream::LoadEndRecord()
// to a self extractor, so take the CD size (also in endrec), subtract // to a self extractor, so take the CD size (also in endrec), subtract
// it from the file offset of the end-central-directory and look there. // it from the file offset of the end-central-directory and look there.
if (m_parent_i_stream->SeekI(endPos - endrec.GetSize()) if (m_parent_i_stream->SeekI(endPos - endrec.GetSize())
!= wxInvalidOffset && ReadSignature() == CENTRAL_MAGIC) { != wxInvalidOffset && ReadSignature() == magic) {
m_signature = CENTRAL_MAGIC; m_signature = magic;
m_position = endPos - endrec.GetSize(); m_position = endPos - endrec.GetSize();
m_offsetAdjustment = m_position - endrec.GetOffset(); m_offsetAdjustment = m_position - endrec.GetOffset();
return true; return true;
@@ -1988,6 +1990,7 @@ void wxZipOutputStream::Init(int level)
m_comp = NULL; m_comp = NULL;
m_level = level; m_level = level;
m_offsetAdjustment = wxInvalidOffset; m_offsetAdjustment = wxInvalidOffset;
m_endrecWritten = false;
} }
wxZipOutputStream::~wxZipOutputStream() wxZipOutputStream::~wxZipOutputStream()
@@ -2287,7 +2290,9 @@ bool wxZipOutputStream::Close()
{ {
CloseEntry(); CloseEntry();
if (m_lasterror == wxSTREAM_WRITE_ERROR) { if (m_lasterror == wxSTREAM_WRITE_ERROR
|| (m_entries.size() == 0 && m_endrecWritten))
{
wxFilterOutputStream::Close(); wxFilterOutputStream::Close();
return false; return false;
} }
@@ -2312,6 +2317,7 @@ bool wxZipOutputStream::Close()
endrec.Write(*m_parent_o_stream, GetConv()); endrec.Write(*m_parent_o_stream, GetConv());
m_lasterror = m_parent_o_stream->GetLastError(); m_lasterror = m_parent_o_stream->GetLastError();
m_endrecWritten = true;
if (!wxFilterOutputStream::Close() || !IsOk()) if (!wxFilterOutputStream::Close() || !IsOk())
return false; return false;