X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/f42d2aba7645ab25ed3764d55394e58649ab0363..b0a6c154dec4a98e0a232196fd2b9ad1b02b6199:/include/wx/textfile.h diff --git a/include/wx/textfile.h b/include/wx/textfile.h index 9cfd0794e4..6c617bb624 100644 --- a/include/wx/textfile.h +++ b/include/wx/textfile.h @@ -11,14 +11,22 @@ // Licence: wxWindows license /////////////////////////////////////////////////////////////////////////////// -#ifndef _TEXTFILE_H -#define _TEXTFILE_H +#ifndef _WX_TEXTFILE_H +#define _WX_TEXTFILE_H #ifdef __GNUG__ -#pragma interface "textfile.h" + #pragma interface "textfile.h" #endif #include "wx/defs.h" + +#if !wxUSE_FILE + #undef wxUSE_TEXTFILE + #define wxUSE_TEXTFILE 0 +#endif // wxUSE_FILE + +#if wxUSE_TEXTFILE + #include "wx/string.h" #include "wx/file.h" #include "wx/dynarray.h" @@ -33,17 +41,29 @@ enum wxTextFileType wxTextFileType_None, // incomplete (the last line of the file only) wxTextFileType_Unix, // line is terminated with 'LF' = 0xA = 10 = '\n' wxTextFileType_Dos, // 'CR' 'LF' - wxTextFileType_Mac // 'CR' = 0xD = 13 = '\r' + wxTextFileType_Mac, // 'CR' = 0xD = 13 = '\r' + wxTextFileType_Os2 // 'CR' 'LF' }; -WX_DEFINE_ARRAY(wxTextFileType, ArrayFileType); +WX_DEFINE_EXPORTED_ARRAY(wxTextFileType, ArrayFileType); -class wxTextFile +class WXDLLEXPORT wxTextFile { public: - // default type for current platform (determined at compile time) + // constants and static functions + // default type for current platform (determined at compile time) static const wxTextFileType typeDefault; + // this function returns a string which is identical to "text" passed in + // except that the line terminator characters are changed to correspond the + // given type. Called with the default argument, the function translates + // the string to the native format (Unix for Unix, DOS for Windows, ...). + static wxString Translate(const wxString& text, + wxTextFileType type = typeDefault); + + // get the file termination string + static const wxChar *GetEOL(wxTextFileType type = typeDefault); + // ctors // def ctor, use Open(string) wxTextFile() { } @@ -60,7 +80,7 @@ public: // closes the file and frees memory, losing all changes bool Close(); // is file currently opened? - bool IsOpened() const { return m_file.IsOpened(); } + bool IsOpened() const { return m_isOpened; } // accessors // get the number of lines in the file @@ -94,7 +114,7 @@ public: // guess the type of file (m_file is supposed to be opened) wxTextFileType GuessType() const; // get the name of the file - const char *GetName() const { return m_strFile.c_str(); } + const wxChar *GetName() const { return m_strFile.c_str(); } // add/remove lines // add a line to the end @@ -112,10 +132,6 @@ public: // possibly in another format bool Write(wxTextFileType typeNew = wxTextFileType_None); - // get the file termination string - // Note: implementation moved to textfile to prevent warning due to switch. - static const char *GetEOL(wxTextFileType type = typeDefault); - // dtor ~wxTextFile(); @@ -134,7 +150,39 @@ private: size_t m_nCurLine; // number of current line in the file + bool m_isOpened; // was the file successfully opened the last time? + wxString m_strFile; // name of the file }; -#endif //_TEXTFILE_H +#else // !wxUSE_TEXTFILE + +// these static wxTextFile methods are used internally by wxWindows, so should +// be defined even if we're compiling without wxTextFile at all. + +class WXDLLEXPORT wxTextFile +{ +public: + // default type for current platform (determined at compile time) + static const wxTextFileType typeDefault; + + // this function returns a string which is identical to "text" passed in + // except that the line terminator characters are changed to correspond the + // given type. Called with the default argument, the function translates + // the string to the native format (Unix for Unix, DOS for Windows, ...). + static wxString Translate(const wxString& text, + wxTextFileType type = typeDefault); + + // get the file termination string + static const wxChar *GetEOL(wxTextFileType type = typeDefault); + +private: + // copy ctor/assignment operator not implemented + wxTextFile(const wxTextFile&); + wxTextFile& operator=(const wxTextFile&); +}; + +#endif // wxUSE_TEXTFILE + +#endif // _WX_TEXTFILE_H +