git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@56119
c3d73ce0-8a6f-49c7-b76d-
6d57e0e08775
+#include "wx/hashmap.h"
+
+class wxMemoryFSFile;
+WX_DECLARE_STRING_HASH_MAP(wxMemoryFSFile *, wxMemoryFSHash);
#if wxUSE_GUI
#include "wx/bitmap.h"
#if wxUSE_GUI
#include "wx/bitmap.h"
virtual wxString FindNext();
protected:
virtual wxString FindNext();
protected:
- static bool CheckHash(const wxString& filename);
- static wxMemoryFSHash *m_Hash;
+ // check that the given file is not already present in m_Hash; logs an
+ // error and returns false if it does exist
+ static bool CheckDoesntExist(const wxString& filename);
+
+ // the hash map indexed by the names of the files stored in the memory FS
+ static wxMemoryFSHash m_Hash;
};
// ----------------------------------------------------------------------------
};
// ----------------------------------------------------------------------------
#ifndef WX_PRECOMP
#include "wx/intl.h"
#include "wx/log.h"
#ifndef WX_PRECOMP
#include "wx/intl.h"
#include "wx/log.h"
- #include "wx/hashmap.h"
#include "wx/wxcrtvararg.h"
#if wxUSE_GUI
#include "wx/image.h"
#include "wx/wxcrtvararg.h"
#if wxUSE_GUI
#include "wx/image.h"
+// represents a file entry in wxMemoryFS
+class wxMemoryFSFile
- MemFSHashObj(const void *data, size_t len, const wxString& mime)
+ wxMemoryFSFile(const void *data, size_t len, const wxString& mime)
{
m_Data = new char[len];
memcpy(m_Data, data, len);
{
m_Data = new char[len];
memcpy(m_Data, data, len);
- MemFSHashObj(const wxMemoryOutputStream& stream, const wxString& mime)
+ wxMemoryFSFile(const wxMemoryOutputStream& stream, const wxString& mime)
{
m_Len = stream.GetSize();
m_Data = new char[m_Len];
{
m_Len = stream.GetSize();
m_Data = new char[m_Len];
- virtual ~MemFSHashObj()
+ virtual ~wxMemoryFSFile()
wxDateTime m_Time;
#endif // wxUSE_DATETIME
wxDateTime m_Time;
#endif // wxUSE_DATETIME
-DECLARE_NO_COPY_CLASS(MemFSHashObj)
-
private:
void InitTime()
{
private:
void InitTime()
{
m_Time = wxDateTime::Now();
#endif // wxUSE_DATETIME
}
m_Time = wxDateTime::Now();
#endif // wxUSE_DATETIME
}
-WX_DECLARE_STRING_HASH_MAP(MemFSHashObj *, wxMemoryFSHash);
+ DECLARE_NO_COPY_CLASS(wxMemoryFSFile)
+};
//--------------------------------------------------------------------------------
//--------------------------------------------------------------------------------
-wxMemoryFSHash *wxMemoryFSHandlerBase::m_Hash = NULL;
+wxMemoryFSHash wxMemoryFSHandlerBase::m_Hash;
wxMemoryFSHandlerBase::wxMemoryFSHandlerBase() : wxFileSystemHandler()
wxMemoryFSHandlerBase::wxMemoryFSHandlerBase() : wxFileSystemHandler()
// as only one copy of FS handler is supposed to exist, we may silently
// delete static data here. (There is no way how to remove FS handler from
// wxFileSystem other than releasing _all_ handlers.)
// as only one copy of FS handler is supposed to exist, we may silently
// delete static data here. (There is no way how to remove FS handler from
// wxFileSystem other than releasing _all_ handlers.)
-
- if (m_Hash)
- {
- WX_CLEAR_HASH_MAP(wxMemoryFSHash, *m_Hash);
- delete m_Hash;
- m_Hash = NULL;
- }
+ WX_CLEAR_HASH_MAP(wxMemoryFSHash, m_Hash);
}
bool wxMemoryFSHandlerBase::CanOpen(const wxString& location)
}
bool wxMemoryFSHandlerBase::CanOpen(const wxString& location)
wxFSFile * wxMemoryFSHandlerBase::OpenFile(wxFileSystem& WXUNUSED(fs),
const wxString& location)
{
wxFSFile * wxMemoryFSHandlerBase::OpenFile(wxFileSystem& WXUNUSED(fs),
const wxString& location)
{
- if ( !m_Hash )
- return NULL;
-
- wxMemoryFSHash::const_iterator i = m_Hash->find(GetRightLocation(location));
- if ( i == m_Hash->end() )
+ wxMemoryFSHash::const_iterator i = m_Hash.find(GetRightLocation(location));
+ if ( i == m_Hash.end() )
- const MemFSHashObj * const obj = i->second;
+ const wxMemoryFSFile * const obj = i->second;
}
wxString wxMemoryFSHandlerBase::FindFirst(const wxString& WXUNUSED(spec),
}
wxString wxMemoryFSHandlerBase::FindFirst(const wxString& WXUNUSED(spec),
{
wxFAIL_MSG(wxT("wxMemoryFSHandlerBase::FindFirst not implemented"));
{
wxFAIL_MSG(wxT("wxMemoryFSHandlerBase::FindFirst not implemented"));
-bool wxMemoryFSHandlerBase::CheckHash(const wxString& filename)
+bool wxMemoryFSHandlerBase::CheckDoesntExist(const wxString& filename)
- if ( !m_Hash )
- m_Hash = new wxMemoryFSHash;
-
- if ( m_Hash->count(filename) )
+ if ( m_Hash.count(filename) )
{
wxLogError(_("Memory VFS already contains file '%s'!"), filename);
return false;
{
wxLogError(_("Memory VFS already contains file '%s'!"), filename);
return false;
const void *binarydata, size_t size,
const wxString& mimetype)
{
const void *binarydata, size_t size,
const wxString& mimetype)
{
- if ( !CheckHash(filename) )
+ if ( !CheckDoesntExist(filename) )
- (*m_Hash)[filename] = new MemFSHashObj(binarydata, size, mimetype);
+ m_Hash[filename] = new wxMemoryFSFile(binarydata, size, mimetype);
/*static*/ void wxMemoryFSHandlerBase::RemoveFile(const wxString& filename)
{
/*static*/ void wxMemoryFSHandlerBase::RemoveFile(const wxString& filename)
{
+ wxMemoryFSHash::iterator i = m_Hash.find(filename);
+ if ( i == m_Hash.end() )
- wxMemoryFSHash::iterator i = m_Hash->find(filename);
- if ( i != m_Hash->end() )
- {
- delete i->second;
- m_Hash->erase(i);
- }
+ wxLogError(_("Trying to remove file '%s' from memory VFS, "
+ "but it is not loaded!"),
+ filename);
+ return;
- wxLogError(_("Trying to remove file '%s' from memory VFS, "
- "but it is not loaded!"),
- filename);
+ delete i->second;
+ m_Hash.erase(i);
const wxImage& image,
wxBitmapType type)
{
const wxImage& image,
wxBitmapType type)
{
- if ( !CheckHash(filename) )
+ if ( !CheckDoesntExist(filename) )
return;
wxMemoryOutputStream mems;
if ( image.Ok() && image.SaveFile(mems, type) )
{
return;
wxMemoryOutputStream mems;
if ( image.Ok() && image.SaveFile(mems, type) )
{
- (*m_Hash)[filename] = new MemFSHashObj
- (
+ m_Hash[filename] = new wxMemoryFSFile
+ (
mems,
wxImage::FindHandler(type)->GetMimeType()
mems,
wxImage::FindHandler(type)->GetMimeType()