X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/e06cac589d01918e1eeb34dc08ed67719a6cb44f..5c840e5ba4254d45747d21f92ab7710e4c136b48:/src/common/fs_zip.cpp?ds=inline diff --git a/src/common/fs_zip.cpp b/src/common/fs_zip.cpp index 136cbb9d37..eb61864d7c 100644 --- a/src/common/fs_zip.cpp +++ b/src/common/fs_zip.cpp @@ -83,7 +83,7 @@ wxFSFile* wxZipFSHandler::OpenFile(wxFileSystem& WXUNUSED(fs), const wxString& l wxString left = GetLeftLocation(location); wxInputStream *s; - if (GetProtocol(left) != wxT("file")) + if (!GetProtocol(left).IsSameAs(wxT("file"))) { wxLogError(_("ZIP handler currently supports only local files!")); return NULL; @@ -133,7 +133,7 @@ wxString wxZipFSHandler::FindFirst(const wxString& spec, int flags) m_Archive = NULL; } - if (GetProtocol(left) != wxT("file")) + if (!GetProtocol(left).IsSameAs(wxT("file"))) { wxLogError(_("ZIP handler currently supports only local files!")); return wxEmptyString; @@ -166,7 +166,7 @@ wxString wxZipFSHandler::FindFirst(const wxString& spec, int flags) if (m_AllowDirs) { delete m_DirsFound; - m_DirsFound = new wxLongToLongHashMap(); + m_DirsFound = new wxZipFilenameHashMap(); } return DoFind(); } @@ -203,17 +203,14 @@ wxString wxZipFSHandler::DoFind() if (m_AllowDirs) { dir = namestr.BeforeLast(wxT('/')); - while (!dir.IsEmpty()) + while (!dir.empty()) { - 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 && + if (!filename.empty() && m_BaseDir == dir && wxMatchWild(m_Pattern, filename, false)) match = m_ZipFile + wxT("#zip:") + dir + wxT("/") + filename; } @@ -224,7 +221,7 @@ wxString wxZipFSHandler::DoFind() filename = namestr.AfterLast(wxT('/')); dir = namestr.BeforeLast(wxT('/')); - if (m_AllowFiles && !filename.IsEmpty() && m_BaseDir == dir && + if (m_AllowFiles && !filename.empty() && m_BaseDir == dir && wxMatchWild(m_Pattern, filename, false)) match = m_ZipFile + wxT("#zip:") + namestr; }