X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/af49c4b8a2d3553e733e71c7dd3911881f4c1a2a..efe66bbc0e9f463a6dd3ad49717474dd801bebf3:/include/wx/fs_mem.h diff --git a/include/wx/fs_mem.h b/include/wx/fs_mem.h index 0d70b7be9e..9a46b264f4 100644 --- a/include/wx/fs_mem.h +++ b/include/wx/fs_mem.h @@ -9,13 +9,20 @@ #ifndef _WX_FS_MEM_H_ #define _WX_FS_MEM_H_ -#if defined(__GNUG__) && !defined(__APPLE__) +#if defined(__GNUG__) && !defined(NO_GCC_PRAGMA) && !defined(__EMX__) +// Some older compilers (such as EMX) cannot handle +// #pragma interface/implementation correctly, iff +// #pragma implementation is used in _two_ translation +// units (as created by e.g. event.cpp compiled for +// libwx_base and event.cpp compiled for libwx_gui_core). +// So we must not use those pragmas for those compilers in +// such files. #pragma interface "fs_mem.h" #endif #include "wx/wxprec.h" -#ifdef __BORDLANDC__ +#ifdef __BORLANDC__ #pragma hdrstop #endif @@ -24,46 +31,83 @@ #include "wx/filesys.h" #if wxUSE_GUI - #include "wx/image.h" - #include "wx/bitmap.h" -#endif + class WXDLLIMPEXP_CORE wxBitmap; + class WXDLLIMPEXP_CORE wxImage; +#endif // wxUSE_GUI -//-------------------------------------------------------------------------------- -// wxMemoryFSHandler -//-------------------------------------------------------------------------------- +// ---------------------------------------------------------------------------- +// wxMemoryFSHandlerBase +// ---------------------------------------------------------------------------- -class WXDLLEXPORT wxMemoryFSHandler : public wxFileSystemHandler +class WXDLLIMPEXP_BASE wxMemoryFSHandlerBase : public wxFileSystemHandler { - public: - wxMemoryFSHandler(); - ~wxMemoryFSHandler(); +public: + wxMemoryFSHandlerBase(); + ~wxMemoryFSHandlerBase(); + + // Add file to list of files stored in memory. Stored data (bitmap, text or + // raw data) will be copied into private memory stream and available under + // name "memory:" + filename + static void AddFile(const wxString& filename, const wxString& textdata); + static void AddFile(const wxString& filename, const void *binarydata, size_t size); + + // Remove file from memory FS and free occupied memory + static void RemoveFile(const wxString& filename); + + virtual bool CanOpen(const wxString& location); + virtual wxFSFile* OpenFile(wxFileSystem& fs, const wxString& location); + virtual wxString FindFirst(const wxString& spec, int flags = 0); + virtual wxString FindNext(); + +protected: + static bool CheckHash(const wxString& filename); + static wxHashTable *m_Hash; +}; - // Add file to list of files stored in memory. Stored data (bitmap, text or raw data) - // will be copied into private memory stream and available under name "memory:" + filename -#if wxUSE_GUI - static void AddFile(const wxString& filename, wxImage& image, long type); - static void AddFile(const wxString& filename, const wxBitmap& bitmap, long type); -#endif - static void AddFile(const wxString& filename, const wxString& textdata); - static void AddFile(const wxString& filename, const void *binarydata, size_t size); +// ---------------------------------------------------------------------------- +// wxMemoryFSHandler +// ---------------------------------------------------------------------------- - // Remove file from memory FS and free occupied memory - static void RemoveFile(const wxString& filename); +#if wxUSE_GUI - virtual bool CanOpen(const wxString& location); - virtual wxFSFile* OpenFile(wxFileSystem& fs, const wxString& location); - virtual wxString FindFirst(const wxString& spec, int flags = 0); - virtual wxString FindNext(); +// add GUI-only operations to the base class +class WXDLLIMPEXP_CORE wxMemoryFSHandler : public wxMemoryFSHandlerBase +{ +public: + // bring the base class versions into the scope, otherwise they would be + // inaccessible in wxMemoryFSHandler + // (unfortunately "using" can't be used as gcc 2.95 doesn't have it...) + static void AddFile(const wxString& filename, const wxString& textdata) + { + wxMemoryFSHandlerBase::AddFile(filename, textdata); + } + + static void AddFile(const wxString& filename, + const void *binarydata, + size_t size) + { + wxMemoryFSHandlerBase::AddFile(filename, binarydata, size); + } + +#if wxUSE_IMAGE + static void AddFile(const wxString& filename, wxImage& image, long type); +#endif // wxUSE_IMAGE + + static void AddFile(const wxString& filename, + const wxBitmap& bitmap, + long type); +}; - private: - static wxHashTable *m_Hash; +#else // !wxUSE_GUI - static bool CheckHash(const wxString& filename); +// just the same thing as the base class in wxBase +class WXDLLIMPEXP_BASE wxMemoryFSHandler : public wxMemoryFSHandlerBase +{ }; -#endif - // wxUSE_FILESYSTEM +#endif // wxUSE_GUI/!wxUSE_GUI +#endif // wxUSE_FILESYSTEM #endif // _WX_FS_MEM_H_