removed caching from wxInternetFSHandler
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@23299 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -250,6 +250,20 @@ Checking in docs/changes.txt;
|
|||||||
new revision: 1.299; previous revision: 1.298
|
new revision: 1.299; previous revision: 1.298
|
||||||
|
|
||||||
|
|
||||||
|
26. Remove caching from wxInternetFSHandler
|
||||||
|
|
||||||
|
Notes: leave in m_Chache variable (no longer used) and destructor (now empty)
|
||||||
|
in order to preserve binary compatibility
|
||||||
|
Checking in fs_inet.h;
|
||||||
|
/pack/cvsroots/wxwindows/wxWindows/include/wx/fs_inet.h,v <-- fs_inet.h
|
||||||
|
new revision: 1.15; previous revision: 1.14
|
||||||
|
Checking in fs_inet.cpp;
|
||||||
|
/pack/cvsroots/wxwindows/wxWindows/src/common/fs_inet.cpp,v <-- fs_inet.cpp
|
||||||
|
new revision: 1.30; previous revision: 1.29
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
TODO for 2.4 (items that are not backports)
|
TODO for 2.4 (items that are not backports)
|
||||||
===========================================
|
===========================================
|
||||||
|
|
||||||
|
@@ -6,18 +6,6 @@
|
|||||||
// Licence: wxWindows Licence
|
// Licence: wxWindows Licence
|
||||||
/////////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
/*
|
|
||||||
|
|
||||||
REMARKS :
|
|
||||||
|
|
||||||
This FS creates local cache (in /tmp directory). The cache is freed
|
|
||||||
on program exit.
|
|
||||||
|
|
||||||
Size of cache is limited to cca 1000 items (due to GetTempFileName
|
|
||||||
limitation)
|
|
||||||
|
|
||||||
|
|
||||||
*/
|
|
||||||
#ifndef _WX_FS_INET_H_
|
#ifndef _WX_FS_INET_H_
|
||||||
#define _WX_FS_INET_H_
|
#define _WX_FS_INET_H_
|
||||||
|
|
||||||
@@ -29,25 +17,17 @@ limitation)
|
|||||||
|
|
||||||
#if wxUSE_FILESYSTEM && wxUSE_FS_INET && wxUSE_STREAMS && wxUSE_SOCKETS
|
#if wxUSE_FILESYSTEM && wxUSE_FS_INET && wxUSE_STREAMS && wxUSE_SOCKETS
|
||||||
|
|
||||||
#ifndef WXPRECOMP
|
|
||||||
#include "wx/hash.h"
|
|
||||||
#endif
|
|
||||||
|
|
||||||
#include "wx/filesys.h"
|
#include "wx/filesys.h"
|
||||||
|
|
||||||
//--------------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
// wxInternetFSHandler
|
// wxInternetFSHandler
|
||||||
//--------------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
class WXDLLIMPEXP_NET wxInternetFSHandler : public wxFileSystemHandler
|
class WXDLLIMPEXP_NET wxInternetFSHandler : public wxFileSystemHandler
|
||||||
{
|
{
|
||||||
private:
|
|
||||||
wxHashTable m_Cache;
|
|
||||||
|
|
||||||
public:
|
public:
|
||||||
virtual bool CanOpen(const wxString& location);
|
virtual bool CanOpen(const wxString& location);
|
||||||
virtual wxFSFile* OpenFile(wxFileSystem& fs, const wxString& location);
|
virtual wxFSFile* OpenFile(wxFileSystem& fs, const wxString& location);
|
||||||
~wxInternetFSHandler();
|
|
||||||
};
|
};
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
@@ -6,19 +6,6 @@
|
|||||||
// Licence: wxWindows Licence
|
// Licence: wxWindows Licence
|
||||||
/////////////////////////////////////////////////////////////////////////////
|
/////////////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
/*
|
|
||||||
|
|
||||||
REMARKS :
|
|
||||||
|
|
||||||
This FS creates local cache (in /tmp directory). The cache is freed
|
|
||||||
on program exit.
|
|
||||||
|
|
||||||
Size of cache is limited to cca 1000 items (due to GetTempFileName
|
|
||||||
limitation)
|
|
||||||
|
|
||||||
|
|
||||||
*/
|
|
||||||
|
|
||||||
#if defined(__GNUG__) && !defined(NO_GCC_PRAGMA)
|
#if defined(__GNUG__) && !defined(NO_GCC_PRAGMA)
|
||||||
#pragma implementation "fs_inet.h"
|
#pragma implementation "fs_inet.h"
|
||||||
#endif
|
#endif
|
||||||
@@ -45,26 +32,37 @@ limitation)
|
|||||||
#include "wx/fs_inet.h"
|
#include "wx/fs_inet.h"
|
||||||
#include "wx/module.h"
|
#include "wx/module.h"
|
||||||
|
|
||||||
class wxInetCacheNode : public wxObject
|
// ----------------------------------------------------------------------------
|
||||||
{
|
// Helper classes
|
||||||
private:
|
// ----------------------------------------------------------------------------
|
||||||
wxString m_Temp;
|
|
||||||
wxString m_Mime;
|
|
||||||
|
|
||||||
public:
|
// This stream deletes the file when destroyed
|
||||||
wxInetCacheNode(const wxString& l, const wxString& m) : wxObject() {m_Temp = l; m_Mime = m;}
|
class wxTemporaryFileInputStream : public wxFileInputStream
|
||||||
const wxString& GetTemp() const {return m_Temp;}
|
{
|
||||||
const wxString& GetMime() const {return m_Mime;}
|
public:
|
||||||
|
wxTemporaryFileInputStream(const wxString& filename) :
|
||||||
|
wxFileInputStream(filename), m_filename(filename) {}
|
||||||
|
|
||||||
|
~wxTemporaryFileInputStream()
|
||||||
|
{
|
||||||
|
// NB: copied from wxFileInputStream dtor, we need to do it before
|
||||||
|
// wxRemoveFile
|
||||||
|
if (m_file_destroy)
|
||||||
|
{
|
||||||
|
delete m_file;
|
||||||
|
m_file_destroy = false;
|
||||||
|
}
|
||||||
|
wxRemoveFile(m_filename);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected:
|
||||||
|
wxString m_filename;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
|
||||||
//--------------------------------------------------------------------------------
|
|
||||||
// wxInternetFSHandler
|
// wxInternetFSHandler
|
||||||
//--------------------------------------------------------------------------------
|
// ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
|
||||||
static wxString StripProtocolAnchor(const wxString& location)
|
static wxString StripProtocolAnchor(const wxString& location)
|
||||||
{
|
{
|
||||||
@@ -84,7 +82,6 @@ static wxString StripProtocolAnchor(const wxString& location)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
bool wxInternetFSHandler::CanOpen(const wxString& location)
|
bool wxInternetFSHandler::CanOpen(const wxString& location)
|
||||||
{
|
{
|
||||||
wxString p = GetProtocol(location);
|
wxString p = GetProtocol(location);
|
||||||
@@ -98,76 +95,44 @@ bool wxInternetFSHandler::CanOpen(const wxString& location)
|
|||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
wxFSFile* wxInternetFSHandler::OpenFile(wxFileSystem& WXUNUSED(fs), const wxString& location)
|
wxFSFile* wxInternetFSHandler::OpenFile(wxFileSystem& WXUNUSED(fs),
|
||||||
|
const wxString& location)
|
||||||
{
|
{
|
||||||
wxString right = GetProtocol(location) + wxT(":") + StripProtocolAnchor(location);
|
wxString right =
|
||||||
wxInputStream *s;
|
GetProtocol(location) + wxT(":") + StripProtocolAnchor(location);
|
||||||
wxString content;
|
|
||||||
wxInetCacheNode *info;
|
|
||||||
|
|
||||||
info = (wxInetCacheNode*) m_Cache.Get(right);
|
wxURL url(right);
|
||||||
|
if (url.GetError() == wxURL_NOERR)
|
||||||
// Add item into cache:
|
|
||||||
if (info == NULL)
|
|
||||||
{
|
{
|
||||||
wxURL url(right);
|
wxInputStream *s = url.GetInputStream();
|
||||||
if (url.GetError() == wxURL_NOERR)
|
wxString content = url.GetProtocol().GetContentType();
|
||||||
|
if (content == wxEmptyString) content = GetMimeTypeFromExt(location);
|
||||||
|
if (s)
|
||||||
{
|
{
|
||||||
s = url.GetInputStream();
|
wxString tmpfile =
|
||||||
content = url.GetProtocol().GetContentType();
|
wxFileName::CreateTempFileName(wxT("wxhtml"));
|
||||||
if (content == wxEmptyString) content = GetMimeTypeFromExt(location);
|
|
||||||
if (s)
|
|
||||||
{
|
|
||||||
wxChar buf[256];
|
|
||||||
|
|
||||||
wxGetTempFileName( wxT("wxhtml"), buf);
|
{ // now copy streams content to temporary file:
|
||||||
info = new wxInetCacheNode(buf, content);
|
wxFileOutputStream sout(tmpfile);
|
||||||
m_Cache.Put(right, info);
|
s->Read(sout);
|
||||||
|
|
||||||
{ // ok, now copy it:
|
|
||||||
wxFileOutputStream sout((wxString)buf);
|
|
||||||
s -> Read(sout); // copy the stream
|
|
||||||
}
|
|
||||||
delete s;
|
|
||||||
}
|
}
|
||||||
else
|
delete s;
|
||||||
return (wxFSFile*) NULL; // we can't open the URL
|
|
||||||
}
|
return new wxFSFile(new wxTemporaryFileInputStream(tmpfile),
|
||||||
else
|
right,
|
||||||
return (wxFSFile*) NULL; // incorrect URL
|
content,
|
||||||
}
|
GetAnchor(location)
|
||||||
|
|
||||||
// Load item from cache:
|
|
||||||
s = new wxFileInputStream(info->GetTemp());
|
|
||||||
if (!s)
|
|
||||||
return (wxFSFile*) NULL;
|
|
||||||
|
|
||||||
return new wxFSFile(s,
|
|
||||||
right,
|
|
||||||
info->GetMime(),
|
|
||||||
GetAnchor(location)
|
|
||||||
#if wxUSE_DATETIME
|
#if wxUSE_DATETIME
|
||||||
, wxDateTime::Now()
|
, wxDateTime::Now()
|
||||||
#endif // wxUSE_DATETIME
|
#endif // wxUSE_DATETIME
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
wxInternetFSHandler::~wxInternetFSHandler()
|
|
||||||
{
|
|
||||||
wxHashTable::compatibility_iterator n;
|
|
||||||
wxInetCacheNode *n2;
|
|
||||||
|
|
||||||
m_Cache.BeginFind();
|
|
||||||
while ((n = m_Cache.Next()) != 0)
|
|
||||||
{
|
|
||||||
n2 = (wxInetCacheNode*) n->GetData();
|
|
||||||
wxRemoveFile(n2->GetTemp());
|
|
||||||
delete n2;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return (wxFSFile*) NULL; // incorrect URL
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
class wxFileSystemInternetModule : public wxModule
|
class wxFileSystemInternetModule : public wxModule
|
||||||
{
|
{
|
||||||
DECLARE_DYNAMIC_CLASS(wxFileSystemInternetModule)
|
DECLARE_DYNAMIC_CLASS(wxFileSystemInternetModule)
|
||||||
|
Reference in New Issue
Block a user