X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/f3ff38139d1a9f285f25e5a70cb0f5ad301fd897..0598e263cecc205aff9a6735cf41803205fabbcb:/src/common/txtstrm.cpp?ds=sidebyside diff --git a/src/common/txtstrm.cpp b/src/common/txtstrm.cpp index f90acd13fd..14b8e4a626 100644 --- a/src/common/txtstrm.cpp +++ b/src/common/txtstrm.cpp @@ -412,33 +412,41 @@ void wxTextOutputStream::WriteDouble(double d) void wxTextOutputStream::WriteString(const wxString& string) { - for (size_t i = 0; i < string.Len(); i++) + size_t len = string.length(); + + wxString out; + out.reserve(len); + + for ( size_t i = 0; i < len; i++ ) { - wxChar c = string[i]; - if (c == wxT('\n')) + const wxChar c = string[i]; + if ( c == wxT('\n') ) { - if (m_mode == wxEOL_DOS) - { - c = wxT('\r'); - m_output.Write( (const void*)(&c), sizeof(wxChar) ); - c = wxT('\n'); - m_output.Write( (const void*)(&c), sizeof(wxChar) ); - } else - if (m_mode == wxEOL_MAC) + switch ( m_mode ) { - c = wxT('\r'); - m_output.Write( (const void*)(&c), sizeof(wxChar) ); - } else - { - c = wxT('\n'); - m_output.Write( (const void*)(&c), sizeof(wxChar) ); + case wxEOL_DOS: + out << _T("\r\n"); + continue; + + case wxEOL_MAC: + out << _T('\r'); + continue; + + default: + wxFAIL_MSG( _T("unknown EOL mode in wxTextOutputStream") ); + // fall through + + case wxEOL_UNIX: + // don't treat '\n' specially + ; } } - else - { - m_output.Write( (const void*)(&c), sizeof(wxChar) ); - } + + out << c; } + + // NB: we don't need to write the trailing NUL here + m_output.Write(out.c_str(), out.length() * sizeof(wxChar)); } wxTextOutputStream& wxTextOutputStream::operator<<(const wxChar *string)