summary |
shortlog |
log |
commit | commitdiff |
tree
raw |
patch |
inline | side by side (from parent 1:
f260c47)
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@32193
c3d73ce0-8a6f-49c7-b76d-
6d57e0e08775
#include "wx/filesys.h"
#include "wx/hashmap.h"
#include "wx/filesys.h"
#include "wx/hashmap.h"
+
+WX_DECLARE_STRING_HASH_MAP(int, wxZipFilenameHashMap);
+
+
//---------------------------------------------------------------------------
// wxZipFSHandler
//---------------------------------------------------------------------------
//---------------------------------------------------------------------------
// wxZipFSHandler
//---------------------------------------------------------------------------
class wxZipInputStream *m_Archive;
wxString m_Pattern, m_BaseDir, m_ZipFile;
bool m_AllowDirs, m_AllowFiles;
class wxZipInputStream *m_Archive;
wxString m_Pattern, m_BaseDir, m_ZipFile;
bool m_AllowDirs, m_AllowFiles;
- wxLongToLongHashMap *m_DirsFound;
+ wxZipFilenameHashMap *m_DirsFound;
wxString DoFind();
void CloseArchive(class wxZipInputStream *archive);
wxString DoFind();
void CloseArchive(class wxZipInputStream *archive);
if (m_AllowDirs)
{
delete m_DirsFound;
if (m_AllowDirs)
{
delete m_DirsFound;
- m_DirsFound = new wxLongToLongHashMap();
+ m_DirsFound = new wxZipFilenameHashMap();
dir = namestr.BeforeLast(wxT('/'));
while (!dir.IsEmpty())
{
dir = namestr.BeforeLast(wxT('/'));
while (!dir.IsEmpty())
{
- long key = 0;
- for (size_t i = 0; i < dir.Length(); i++) key += (wxUChar)dir[i];
- wxLongToLongHashMap::iterator it = m_DirsFound->find(key);
- if (it == m_DirsFound->end())
+ if( m_DirsFound->find(dir) == m_DirsFound->end() )
- (*m_DirsFound)[key] = 1;
+ (*m_DirsFound)[dir] = 1;
filename = dir.AfterLast(wxT('/'));
dir = dir.BeforeLast(wxT('/'));
if (!filename.IsEmpty() && m_BaseDir == dir &&
filename = dir.AfterLast(wxT('/'));
dir = dir.BeforeLast(wxT('/'));
if (!filename.IsEmpty() && m_BaseDir == dir &&