clearerr(m_fp);
- const size_t fileLen = Length();
- wxCharBuffer buf(fileLen + 1);
- if ( (fread(buf.data(), sizeof(char), fileLen, m_fp) < fileLen) || Error() )
+ wxCharBuffer buf(length + 1);
+
+ // note that real length may be less than file length for text files with DOS EOLs
+ // ('\r's get dropped by CRT when reading which means that we have
+ // realLen = fileLen - numOfLinesInTheFile)
+ length = fread(buf.data(), sizeof(char), length, m_fp);
+
+ if ( Error() )
{
wxLogSysError(_("Read error on file '%s'"), m_name.c_str());
return false;
}
- buf.data()[fileLen] = 0;
+ buf.data()[length] = 0;
*str = wxString(buf, conv);
return true;
size_t wxFFile::Read(void *pBuf, size_t nCount)
{
- wxCHECK_MSG( pBuf, FALSE, wxT("invalid parameter") );
- wxCHECK_MSG( IsOpened(), FALSE, wxT("can't read from closed file") );
+ wxCHECK_MSG( pBuf, 0, wxT("invalid parameter") );
+ wxCHECK_MSG( IsOpened(), 0, wxT("can't read from closed file") );
size_t nRead = fread(pBuf, 1, nCount, m_fp);
if ( (nRead < nCount) && Error() )
size_t wxFFile::Write(const void *pBuf, size_t nCount)
{
- wxCHECK_MSG( pBuf, FALSE, wxT("invalid parameter") );
- wxCHECK_MSG( IsOpened(), FALSE, wxT("can't write to closed file") );
+ wxCHECK_MSG( pBuf, 0, wxT("invalid parameter") );
+ wxCHECK_MSG( IsOpened(), 0, wxT("can't write to closed file") );
size_t nWritten = fwrite(pBuf, 1, nCount, m_fp);
if ( nWritten < nCount )