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:
@@ -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;
|
||||||
};
|
};
|
||||||
|
|
||||||
// ----------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
|
@@ -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
|
||||||
{
|
{
|
||||||
|
Reference in New Issue
Block a user