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:
@@ -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)
|
||||||
};
|
};
|
||||||
|
@@ -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)
|
||||||
};
|
};
|
||||||
|
@@ -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();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@@ -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;
|
||||||
|
Reference in New Issue
Block a user