X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/a1b82138efe9aacda4e0ad7ce4b1551d624524c4..d2f5093319b09251870da78e5578eec55942a531:/src/common/textfile.cpp diff --git a/src/common/textfile.cpp b/src/common/textfile.cpp index b2a1c2afa7..3ab5dc94c3 100644 --- a/src/common/textfile.cpp +++ b/src/common/textfile.cpp @@ -53,6 +53,8 @@ const wxTextFileType wxTextFile::typeDefault = wxTextFileType_Unix; #elif defined(__WXMAC__) wxTextFileType_Mac; +#elif defined(__WXPM__) + wxTextFileType_Os2; #else wxTextFileType_None; #error "wxTextFile: unsupported platform." @@ -62,17 +64,16 @@ const wxChar *wxTextFile::GetEOL(wxTextFileType type) { switch ( type ) { default: - wxFAIL_MSG(_T("bad file type in wxTextFile::GetEOL.")); + wxFAIL_MSG(wxT("bad file type in wxTextFile::GetEOL.")); // fall through nevertheless - we must return something... - case wxTextFileType_None: return _T(""); - case wxTextFileType_Unix: return _T("\n"); - case wxTextFileType_Dos: return _T("\r\n"); - case wxTextFileType_Mac: return _T("\r"); + case wxTextFileType_None: return wxT(_T("")); + case wxTextFileType_Unix: return wxT(_T("\n")); + case wxTextFileType_Dos: return wxT(_T("\r\n")); + case wxTextFileType_Mac: return wxT(_T("\r")); } } - wxString wxTextFile::Translate(const wxString& text, wxTextFileType type) { // don't do anything if there is nothing to do @@ -91,34 +92,40 @@ wxString wxTextFile::Translate(const wxString& text, wxTextFileType type) { wxChar ch = *pc; switch ( ch ) { - case '\n': + case _T('\n'): // Dos/Unix line termination result += eol; - chLast = '\n'; + chLast = 0; break; - case '\r': - if ( chLast == '\r' ) { + case _T('\r'): + if ( chLast == _T('\r') ) { // Mac empty line result += eol; } - else - chLast = '\r'; + else { + // just remember it: we don't know whether it is just "\r" + // or "\r\n" yet + chLast = _T('\r'); + } break; default: - if ( chLast == '\r' ) { + if ( chLast == _T('\r') ) { // Mac line termination result += eol; - chLast = ch; - } - else { - // add to the current line - result += ch; } + + // add to the current line + result += ch; } } + if ( chLast ) { + // trailing '\r' + result += eol; + } + return result; } @@ -143,6 +150,11 @@ wxTextFile::~wxTextFile() // file operations // ---------------------------------------------------------------------------- +bool wxTextFile::Exists() const +{ + return wxFile::Exists(m_strFile); +} + bool wxTextFile::Open(const wxString& strFile) { m_strFile = strFile; @@ -262,7 +274,7 @@ bool wxTextFile::Read() case '\r': if ( chLast == '\r' ) { // Mac empty line - m_aLines.Add(""); + m_aLines.Add(wxEmptyString); m_aTypes.Add(wxTextFileType_Mac); } else