made m_Hash object, not a pointer and moved hash declaration into the header as it's needed by the upcoming FindFirst/Next() implementation

git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@56119 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
Vadim Zeitlin
2008-10-06 13:37:04 +00:00
parent bf9ce2abdf
commit 8c9d760210
2 changed files with 39 additions and 48 deletions

View File

@@ -15,7 +15,10 @@
#include "wx/filesys.h" #include "wx/filesys.h"
class wxMemoryFSHash; #include "wx/hashmap.h"
class wxMemoryFSFile;
WX_DECLARE_STRING_HASH_MAP(wxMemoryFSFile *, wxMemoryFSHash);
#if wxUSE_GUI #if wxUSE_GUI
#include "wx/bitmap.h" #include "wx/bitmap.h"
@@ -52,8 +55,12 @@ public:
virtual wxString FindNext(); virtual wxString FindNext();
protected: protected:
static bool CheckHash(const wxString& filename); // check that the given file is not already present in m_Hash; logs an
static wxMemoryFSHash *m_Hash; // 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;
}; };
// ---------------------------------------------------------------------------- // ----------------------------------------------------------------------------

View File

@@ -20,7 +20,6 @@
#ifndef WX_PRECOMP #ifndef WX_PRECOMP
#include "wx/intl.h" #include "wx/intl.h"
#include "wx/log.h" #include "wx/log.h"
#include "wx/hashmap.h"
#include "wx/wxcrtvararg.h" #include "wx/wxcrtvararg.h"
#if wxUSE_GUI #if wxUSE_GUI
#include "wx/image.h" #include "wx/image.h"
@@ -29,10 +28,11 @@
#include "wx/mstream.h" #include "wx/mstream.h"
class MemFSHashObj // represents a file entry in wxMemoryFS
class wxMemoryFSFile
{ {
public: public:
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]; m_Data = new char[len];
memcpy(m_Data, data, len); memcpy(m_Data, data, len);
@@ -41,7 +41,7 @@ public:
InitTime(); InitTime();
} }
MemFSHashObj(const wxMemoryOutputStream& stream, const wxString& mime) wxMemoryFSFile(const wxMemoryOutputStream& stream, const wxString& mime)
{ {
m_Len = stream.GetSize(); m_Len = stream.GetSize();
m_Data = new char[m_Len]; m_Data = new char[m_Len];
@@ -50,7 +50,7 @@ public:
InitTime(); InitTime();
} }
virtual ~MemFSHashObj() virtual ~wxMemoryFSFile()
{ {
delete[] m_Data; delete[] m_Data;
} }
@@ -62,8 +62,6 @@ public:
wxDateTime m_Time; wxDateTime m_Time;
#endif // wxUSE_DATETIME #endif // wxUSE_DATETIME
DECLARE_NO_COPY_CLASS(MemFSHashObj)
private: private:
void InitTime() void InitTime()
{ {
@@ -71,9 +69,9 @@ private:
m_Time = wxDateTime::Now(); m_Time = wxDateTime::Now();
#endif // wxUSE_DATETIME #endif // wxUSE_DATETIME
} }
};
WX_DECLARE_STRING_HASH_MAP(MemFSHashObj *, wxMemoryFSHash); DECLARE_NO_COPY_CLASS(wxMemoryFSFile)
};
#if wxUSE_BASE #if wxUSE_BASE
@@ -83,7 +81,7 @@ WX_DECLARE_STRING_HASH_MAP(MemFSHashObj *, wxMemoryFSHash);
//-------------------------------------------------------------------------------- //--------------------------------------------------------------------------------
wxMemoryFSHash *wxMemoryFSHandlerBase::m_Hash = NULL; wxMemoryFSHash wxMemoryFSHandlerBase::m_Hash;
wxMemoryFSHandlerBase::wxMemoryFSHandlerBase() : wxFileSystemHandler() wxMemoryFSHandlerBase::wxMemoryFSHandlerBase() : wxFileSystemHandler()
@@ -95,13 +93,7 @@ wxMemoryFSHandlerBase::~wxMemoryFSHandlerBase()
// as only one copy of FS handler is supposed to exist, we may silently // 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 // delete static data here. (There is no way how to remove FS handler from
// wxFileSystem other than releasing _all_ handlers.) // wxFileSystem other than releasing _all_ handlers.)
WX_CLEAR_HASH_MAP(wxMemoryFSHash, m_Hash);
if (m_Hash)
{
WX_CLEAR_HASH_MAP(wxMemoryFSHash, *m_Hash);
delete m_Hash;
m_Hash = NULL;
}
} }
bool wxMemoryFSHandlerBase::CanOpen(const wxString& location) bool wxMemoryFSHandlerBase::CanOpen(const wxString& location)
@@ -112,14 +104,11 @@ bool wxMemoryFSHandlerBase::CanOpen(const wxString& location)
wxFSFile * wxMemoryFSHandlerBase::OpenFile(wxFileSystem& WXUNUSED(fs), wxFSFile * wxMemoryFSHandlerBase::OpenFile(wxFileSystem& WXUNUSED(fs),
const wxString& location) const wxString& location)
{ {
if ( !m_Hash ) wxMemoryFSHash::const_iterator i = m_Hash.find(GetRightLocation(location));
if ( i == m_Hash.end() )
return NULL; return NULL;
wxMemoryFSHash::const_iterator i = m_Hash->find(GetRightLocation(location)); const wxMemoryFSFile * const obj = i->second;
if ( i == m_Hash->end() )
return NULL;
const MemFSHashObj * const obj = i->second;
return new wxFSFile return new wxFSFile
( (
@@ -134,7 +123,7 @@ wxFSFile * wxMemoryFSHandlerBase::OpenFile(wxFileSystem& WXUNUSED(fs),
} }
wxString wxMemoryFSHandlerBase::FindFirst(const wxString& WXUNUSED(spec), wxString wxMemoryFSHandlerBase::FindFirst(const wxString& WXUNUSED(spec),
int WXUNUSED(flags)) int WXUNUSED(flags))
{ {
wxFAIL_MSG(wxT("wxMemoryFSHandlerBase::FindFirst not implemented")); wxFAIL_MSG(wxT("wxMemoryFSHandlerBase::FindFirst not implemented"));
@@ -148,12 +137,9 @@ wxString wxMemoryFSHandlerBase::FindNext()
return wxEmptyString; return wxEmptyString;
} }
bool wxMemoryFSHandlerBase::CheckHash(const wxString& filename) bool wxMemoryFSHandlerBase::CheckDoesntExist(const wxString& filename)
{ {
if ( !m_Hash ) if ( m_Hash.count(filename) )
m_Hash = new wxMemoryFSHash;
if ( m_Hash->count(filename) )
{ {
wxLogError(_("Memory VFS already contains file '%s'!"), filename); wxLogError(_("Memory VFS already contains file '%s'!"), filename);
return false; return false;
@@ -179,10 +165,10 @@ void wxMemoryFSHandlerBase::AddFileWithMimeType(const wxString& filename,
const void *binarydata, size_t size, const void *binarydata, size_t size,
const wxString& mimetype) const wxString& mimetype)
{ {
if ( !CheckHash(filename) ) if ( !CheckDoesntExist(filename) )
return; return;
(*m_Hash)[filename] = new MemFSHashObj(binarydata, size, mimetype); m_Hash[filename] = new wxMemoryFSFile(binarydata, size, mimetype);
} }
/*static*/ /*static*/
@@ -204,19 +190,17 @@ void wxMemoryFSHandlerBase::AddFile(const wxString& filename,
/*static*/ void wxMemoryFSHandlerBase::RemoveFile(const wxString& filename) /*static*/ void wxMemoryFSHandlerBase::RemoveFile(const wxString& filename)
{ {
if ( m_Hash ) wxMemoryFSHash::iterator i = m_Hash.find(filename);
if ( i == m_Hash.end() )
{ {
wxMemoryFSHash::iterator i = m_Hash->find(filename); wxLogError(_("Trying to remove file '%s' from memory VFS, "
if ( i != m_Hash->end() ) "but it is not loaded!"),
{ filename);
delete i->second; return;
m_Hash->erase(i);
}
} }
wxLogError(_("Trying to remove file '%s' from memory VFS, " delete i->second;
"but it is not loaded!"), m_Hash.erase(i);
filename);
} }
#endif // wxUSE_BASE #endif // wxUSE_BASE
@@ -229,17 +213,17 @@ wxMemoryFSHandler::AddFile(const wxString& filename,
const wxImage& image, const wxImage& image,
wxBitmapType type) wxBitmapType type)
{ {
if ( !CheckHash(filename) ) if ( !CheckDoesntExist(filename) )
return; return;
wxMemoryOutputStream mems; wxMemoryOutputStream mems;
if ( image.Ok() && image.SaveFile(mems, type) ) if ( image.Ok() && image.SaveFile(mems, type) )
{ {
(*m_Hash)[filename] = new MemFSHashObj m_Hash[filename] = new wxMemoryFSFile
( (
mems, mems,
wxImage::FindHandler(type)->GetMimeType() wxImage::FindHandler(type)->GetMimeType()
); );
} }
else else
{ {