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:
Václav Slavík
2003-08-29 22:54:45 +00:00
parent d8771ac734
commit 3caa34b771
3 changed files with 68 additions and 109 deletions

View File

@@ -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)
=========================================== ===========================================

View File

@@ -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

View File

@@ -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)