X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/c3816108b4545342713f928e5708cf679d933e12..64f9c1009476cd0a347d6c3dfc93993652cbd199:/src/common/ffile.cpp diff --git a/src/common/ffile.cpp b/src/common/ffile.cpp index 736bbea55f..42a43f2cb4 100644 --- a/src/common/ffile.cpp +++ b/src/common/ffile.cpp @@ -103,7 +103,7 @@ bool wxFFile::Close() // read/write // ---------------------------------------------------------------------------- -bool wxFFile::ReadAll(wxString *str) +bool wxFFile::ReadAll(wxString *str, wxMBConv& conv) { wxCHECK_MSG( str, false, wxT("invalid parameter") ); wxCHECK_MSG( IsOpened(), false, wxT("can't read from closed file") ); @@ -113,26 +113,18 @@ bool wxFFile::ReadAll(wxString *str) clearerr(m_fp); - str->Empty(); - str->Alloc(length); - - wxChar buf[1024]; - static const size_t nSize = WXSIZEOF(buf) - 1; // -1 for trailing '\0' - while ( !Eof() ) + const size_t fileLen = Length(); + wxCharBuffer buf(fileLen + 1); + if ( (fread(buf.data(), sizeof(char), fileLen, m_fp) < fileLen) || Error() ) { - size_t nRead = fread(buf, sizeof(wxChar), nSize, m_fp); - if ( (nRead < nSize) && Error() ) - { - wxLogSysError(_("Read error on file '%s'"), m_name.c_str()); - - return false; - } - //else: just EOF + wxLogSysError(_("Read error on file '%s'"), m_name.c_str()); - buf[nRead] = 0; - *str += buf; + return false; } + buf.data()[fileLen] = 0; + *str = wxString(buf, conv); + return true; }