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

View File

@@ -6,18 +6,6 @@
// 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_
#define _WX_FS_INET_H_
@@ -29,25 +17,17 @@ limitation)
#if wxUSE_FILESYSTEM && wxUSE_FS_INET && wxUSE_STREAMS && wxUSE_SOCKETS
#ifndef WXPRECOMP
#include "wx/hash.h"
#endif
#include "wx/filesys.h"
//--------------------------------------------------------------------------------
// ----------------------------------------------------------------------------
// wxInternetFSHandler
//--------------------------------------------------------------------------------
// ----------------------------------------------------------------------------
class WXDLLIMPEXP_NET wxInternetFSHandler : public wxFileSystemHandler
{
private:
wxHashTable m_Cache;
public:
virtual bool CanOpen(const wxString& location);
virtual wxFSFile* OpenFile(wxFileSystem& fs, const wxString& location);
~wxInternetFSHandler();
};
#endif

View File

@@ -6,19 +6,6 @@
// 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)
#pragma implementation "fs_inet.h"
#endif
@@ -45,26 +32,37 @@ limitation)
#include "wx/fs_inet.h"
#include "wx/module.h"
class wxInetCacheNode : public wxObject
{
private:
wxString m_Temp;
wxString m_Mime;
// ----------------------------------------------------------------------------
// Helper classes
// ----------------------------------------------------------------------------
public:
wxInetCacheNode(const wxString& l, const wxString& m) : wxObject() {m_Temp = l; m_Mime = m;}
const wxString& GetTemp() const {return m_Temp;}
const wxString& GetMime() const {return m_Mime;}
// This stream deletes the file when destroyed
class wxTemporaryFileInputStream : public wxFileInputStream
{
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
//--------------------------------------------------------------------------------
// ----------------------------------------------------------------------------
static wxString StripProtocolAnchor(const wxString& location)
{
@@ -84,7 +82,6 @@ static wxString StripProtocolAnchor(const wxString& location)
}
bool wxInternetFSHandler::CanOpen(const wxString& 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);
wxInputStream *s;
wxString content;
wxInetCacheNode *info;
wxString right =
GetProtocol(location) + wxT(":") + StripProtocolAnchor(location);
info = (wxInetCacheNode*) m_Cache.Get(right);
// Add item into cache:
if (info == NULL)
wxURL url(right);
if (url.GetError() == wxURL_NOERR)
{
wxURL url(right);
if (url.GetError() == wxURL_NOERR)
wxInputStream *s = url.GetInputStream();
wxString content = url.GetProtocol().GetContentType();
if (content == wxEmptyString) content = GetMimeTypeFromExt(location);
if (s)
{
s = url.GetInputStream();
content = url.GetProtocol().GetContentType();
if (content == wxEmptyString) content = GetMimeTypeFromExt(location);
if (s)
{
wxChar buf[256];
wxString tmpfile =
wxFileName::CreateTempFileName(wxT("wxhtml"));
wxGetTempFileName( wxT("wxhtml"), buf);
info = new wxInetCacheNode(buf, content);
m_Cache.Put(right, info);
{ // ok, now copy it:
wxFileOutputStream sout((wxString)buf);
s -> Read(sout); // copy the stream
}
delete s;
{ // now copy streams content to temporary file:
wxFileOutputStream sout(tmpfile);
s->Read(sout);
}
else
return (wxFSFile*) NULL; // we can't open the URL
}
else
return (wxFSFile*) NULL; // incorrect URL
}
// Load item from cache:
s = new wxFileInputStream(info->GetTemp());
if (!s)
return (wxFSFile*) NULL;
return new wxFSFile(s,
right,
info->GetMime(),
GetAnchor(location)
delete s;
return new wxFSFile(new wxTemporaryFileInputStream(tmpfile),
right,
content,
GetAnchor(location)
#if wxUSE_DATETIME
, wxDateTime::Now()
, wxDateTime::Now()
#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
{
DECLARE_DYNAMIC_CLASS(wxFileSystemInternetModule)