X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/588066b7a39629e44bb39f1ab436b80f38c13f33..f2fe4f677724f4eced0ce62d0fded6fe3dda6bf7:/src/common/wfstream.cpp diff --git a/src/common/wfstream.cpp b/src/common/wfstream.cpp index 8e731791bf..59d89d127e 100644 --- a/src/common/wfstream.cpp +++ b/src/common/wfstream.cpp @@ -69,7 +69,7 @@ wxFileOffset wxFileInputStream::GetLength() const size_t wxFileInputStream::OnSysRead(void *buffer, size_t size) { - size_t ret = m_file->Read(buffer, size); + ssize_t ret = m_file->Read(buffer, size); // NB: we can't use a switch here because HP-UX CC doesn't allow // switching over long long (which size_t is in 64bit mode) @@ -79,7 +79,7 @@ size_t wxFileInputStream::OnSysRead(void *buffer, size_t size) // nothing read, so nothing more to read m_lasterror = wxSTREAM_EOF; } - else if ( ret == (size_t)wxInvalidOffset ) + else if ( ret == wxInvalidOffset ) { m_lasterror = wxSTREAM_READ_ERROR; ret = 0; @@ -234,11 +234,12 @@ wxFileOffset wxFFileInputStream::GetLength() const size_t wxFFileInputStream::OnSysRead(void *buffer, size_t size) { - size_t ret = m_file->Read(buffer, size); + ssize_t ret = m_file->Read(buffer, size); - if (m_file->Eof()) + // It is not safe to call Eof() if the file is not opened. + if (!m_file->IsOpened() || m_file->Eof()) m_lasterror = wxSTREAM_EOF; - if (ret == (size_t)wxInvalidOffset) + if (ret == wxInvalidOffset) { m_lasterror = wxSTREAM_READ_ERROR; ret = 0; @@ -314,7 +315,8 @@ wxFFileOutputStream::~wxFFileOutputStream() size_t wxFFileOutputStream::OnSysWrite(const void *buffer, size_t size) { size_t ret = m_file->Write(buffer, size); - if (m_file->Error()) + // It is not safe to call Error() if the file is not opened. + if (!m_file->IsOpened() || m_file->Error()) m_lasterror = wxSTREAM_WRITE_ERROR; else m_lasterror = wxSTREAM_NO_ERROR;