no changes, just some minor cleanup
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@56115 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -31,47 +31,46 @@
|
|||||||
|
|
||||||
class MemFSHashObj : public wxObject
|
class MemFSHashObj : public wxObject
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
MemFSHashObj(const void *data, size_t len, const wxString& mime)
|
||||||
|
{
|
||||||
|
m_Data = new char[len];
|
||||||
|
memcpy(m_Data, data, len);
|
||||||
|
m_Len = len;
|
||||||
|
m_MimeType = mime;
|
||||||
|
InitTime();
|
||||||
|
}
|
||||||
|
|
||||||
MemFSHashObj(const void *data, size_t len, const wxString& mime)
|
MemFSHashObj(const wxMemoryOutputStream& stream, const wxString& mime)
|
||||||
{
|
{
|
||||||
m_Data = new char[len];
|
m_Len = stream.GetSize();
|
||||||
memcpy(m_Data, data, len);
|
m_Data = new char[m_Len];
|
||||||
m_Len = len;
|
stream.CopyTo(m_Data, m_Len);
|
||||||
m_MimeType = mime;
|
m_MimeType = mime;
|
||||||
InitTime();
|
InitTime();
|
||||||
}
|
}
|
||||||
|
|
||||||
MemFSHashObj(const wxMemoryOutputStream& stream, const wxString& mime)
|
virtual ~MemFSHashObj()
|
||||||
{
|
{
|
||||||
m_Len = stream.GetSize();
|
delete[] m_Data;
|
||||||
m_Data = new char[m_Len];
|
}
|
||||||
stream.CopyTo(m_Data, m_Len);
|
|
||||||
m_MimeType = mime;
|
|
||||||
InitTime();
|
|
||||||
}
|
|
||||||
|
|
||||||
virtual ~MemFSHashObj()
|
char *m_Data;
|
||||||
{
|
size_t m_Len;
|
||||||
delete[] m_Data;
|
wxString m_MimeType;
|
||||||
}
|
|
||||||
|
|
||||||
char *m_Data;
|
|
||||||
size_t m_Len;
|
|
||||||
wxString m_MimeType;
|
|
||||||
#if wxUSE_DATETIME
|
#if wxUSE_DATETIME
|
||||||
wxDateTime m_Time;
|
wxDateTime m_Time;
|
||||||
#endif // wxUSE_DATETIME
|
#endif // wxUSE_DATETIME
|
||||||
|
|
||||||
DECLARE_NO_COPY_CLASS(MemFSHashObj)
|
DECLARE_NO_COPY_CLASS(MemFSHashObj)
|
||||||
|
|
||||||
private:
|
private:
|
||||||
void InitTime()
|
void InitTime()
|
||||||
{
|
{
|
||||||
#if wxUSE_DATETIME
|
#if wxUSE_DATETIME
|
||||||
m_Time = wxDateTime::Now();
|
m_Time = wxDateTime::Now();
|
||||||
#endif // wxUSE_DATETIME
|
#endif // wxUSE_DATETIME
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
#if wxUSE_BASE
|
#if wxUSE_BASE
|
||||||
@@ -89,8 +88,6 @@ wxMemoryFSHandlerBase::wxMemoryFSHandlerBase() : wxFileSystemHandler()
|
|||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
wxMemoryFSHandlerBase::~wxMemoryFSHandlerBase()
|
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
|
||||||
@@ -105,47 +102,39 @@ wxMemoryFSHandlerBase::~wxMemoryFSHandlerBase()
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
bool wxMemoryFSHandlerBase::CanOpen(const wxString& location)
|
bool wxMemoryFSHandlerBase::CanOpen(const wxString& location)
|
||||||
{
|
{
|
||||||
wxString p = GetProtocol(location);
|
return GetProtocol(location) == "memory";
|
||||||
return (p == wxT("memory"));
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
wxFSFile * wxMemoryFSHandlerBase::OpenFile(wxFileSystem& WXUNUSED(fs),
|
||||||
|
const wxString& location)
|
||||||
|
|
||||||
wxFSFile* wxMemoryFSHandlerBase::OpenFile(wxFileSystem& WXUNUSED(fs), const wxString& location)
|
|
||||||
{
|
{
|
||||||
if (m_Hash)
|
if ( !m_Hash )
|
||||||
{
|
return NULL;
|
||||||
MemFSHashObj *obj = (MemFSHashObj*) m_Hash -> Get(GetRightLocation(location));
|
|
||||||
if (obj == NULL) return NULL;
|
MemFSHashObj *obj = (MemFSHashObj*) m_Hash->Get(GetRightLocation(location));
|
||||||
else return new wxFSFile(new wxMemoryInputStream(obj -> m_Data, obj -> m_Len),
|
if ( !obj )
|
||||||
location,
|
return NULL;
|
||||||
obj->m_MimeType,
|
|
||||||
GetAnchor(location)
|
else return new wxFSFile(new wxMemoryInputStream(obj->m_Data, obj->m_Len),
|
||||||
|
location,
|
||||||
|
obj->m_MimeType,
|
||||||
|
GetAnchor(location)
|
||||||
#if wxUSE_DATETIME
|
#if wxUSE_DATETIME
|
||||||
, obj -> m_Time
|
, obj->m_Time
|
||||||
#endif // wxUSE_DATETIME
|
#endif // wxUSE_DATETIME
|
||||||
);
|
);
|
||||||
}
|
|
||||||
else return NULL;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
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"));
|
||||||
|
|
||||||
return wxEmptyString;
|
return wxEmptyString;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
wxString wxMemoryFSHandlerBase::FindNext()
|
wxString wxMemoryFSHandlerBase::FindNext()
|
||||||
{
|
{
|
||||||
wxFAIL_MSG(wxT("wxMemoryFSHandlerBase::FindNext not implemented"));
|
wxFAIL_MSG(wxT("wxMemoryFSHandlerBase::FindNext not implemented"));
|
||||||
@@ -153,23 +142,20 @@ wxString wxMemoryFSHandlerBase::FindNext()
|
|||||||
return wxEmptyString;
|
return wxEmptyString;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
bool wxMemoryFSHandlerBase::CheckHash(const wxString& filename)
|
bool wxMemoryFSHandlerBase::CheckHash(const wxString& filename)
|
||||||
{
|
{
|
||||||
if (m_Hash == NULL)
|
if ( !m_Hash )
|
||||||
{
|
{
|
||||||
m_Hash = new wxHashTable(wxKEY_STRING);
|
m_Hash = new wxHashTable(wxKEY_STRING);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (m_Hash -> Get(filename) != NULL)
|
if ( m_Hash->Get(filename) )
|
||||||
{
|
{
|
||||||
wxString s;
|
wxLogError(_("Memory VFS already contains file '%s'!"), filename);
|
||||||
s.Printf(_("Memory VFS already contains file '%s'!"), filename.c_str());
|
|
||||||
wxLogError(s);
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
else
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@@ -189,8 +175,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)) return;
|
if ( !CheckHash(filename) )
|
||||||
m_Hash -> Put(filename, new MemFSHashObj(binarydata, size, mimetype));
|
return;
|
||||||
|
|
||||||
|
m_Hash->Put(filename, new MemFSHashObj(binarydata, size, mimetype));
|
||||||
}
|
}
|
||||||
|
|
||||||
/*static*/
|
/*static*/
|
||||||
@@ -212,16 +200,16 @@ void wxMemoryFSHandlerBase::AddFile(const wxString& filename,
|
|||||||
|
|
||||||
/*static*/ void wxMemoryFSHandlerBase::RemoveFile(const wxString& filename)
|
/*static*/ void wxMemoryFSHandlerBase::RemoveFile(const wxString& filename)
|
||||||
{
|
{
|
||||||
if (m_Hash == NULL ||
|
if ( !m_Hash || !m_Hash->Get(filename) )
|
||||||
m_Hash -> Get(filename) == NULL)
|
|
||||||
{
|
{
|
||||||
wxString s;
|
wxLogError(_("Trying to remove file '%s' from memory VFS, "
|
||||||
s.Printf(_("Trying to remove file '%s' from memory VFS, but it is not loaded!"), filename.c_str());
|
"but it is not loaded!"),
|
||||||
wxLogError(s);
|
filename);
|
||||||
}
|
}
|
||||||
|
|
||||||
else
|
else
|
||||||
delete m_Hash -> Delete(filename);
|
{
|
||||||
|
delete m_Hash->Delete(filename);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#endif // wxUSE_BASE
|
#endif // wxUSE_BASE
|
||||||
@@ -234,7 +222,8 @@ wxMemoryFSHandler::AddFile(const wxString& filename,
|
|||||||
const wxImage& image,
|
const wxImage& image,
|
||||||
wxBitmapType type)
|
wxBitmapType type)
|
||||||
{
|
{
|
||||||
if (!CheckHash(filename)) return;
|
if ( !CheckHash(filename) )
|
||||||
|
return;
|
||||||
|
|
||||||
wxMemoryOutputStream mems;
|
wxMemoryOutputStream mems;
|
||||||
if (image.Ok() && image.SaveFile(mems, type))
|
if (image.Ok() && image.SaveFile(mems, type))
|
||||||
@@ -251,10 +240,7 @@ wxMemoryFSHandler::AddFile(const wxString& filename,
|
|||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
wxString s;
|
wxLogError(_("Failed to store image '%s' to memory VFS!"), filename);
|
||||||
s.Printf(_("Failed to store image '%s' to memory VFS!"), filename.c_str());
|
|
||||||
wxPrintf(wxT("'%s'\n"), s.c_str());
|
|
||||||
wxLogError(s);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user