From c8c86bd0ba6afbdea60fb6c6986cb72e2d750a8d Mon Sep 17 00:00:00 2001 From: Vadim Zeitlin Date: Tue, 14 Oct 2008 14:13:15 +0000 Subject: [PATCH] fix bugs in FindFirst() (it gets URL, not filename, on input) and FindNext() (which always forgot the last match) (fixes #10077) git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@56307 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775 --- src/common/fs_mem.cpp | 16 ++++++++++------ 1 file changed, 10 insertions(+), 6 deletions(-) diff --git a/src/common/fs_mem.cpp b/src/common/fs_mem.cpp index f13ab26c5d..2e9927590d 100644 --- a/src/common/fs_mem.cpp +++ b/src/common/fs_mem.cpp @@ -122,7 +122,7 @@ wxFSFile * wxMemoryFSHandlerBase::OpenFile(wxFileSystem& WXUNUSED(fs), ); } -wxString wxMemoryFSHandlerBase::FindFirst(const wxString& spec, int flags) +wxString wxMemoryFSHandlerBase::FindFirst(const wxString& url, int flags) { if ( (flags & wxDIR) && !(flags & wxFILE) ) { @@ -131,11 +131,12 @@ wxString wxMemoryFSHandlerBase::FindFirst(const wxString& spec, int flags) return wxString(); } + const wxString spec = GetRightLocation(url); if ( spec.find_first_of("?*") == wxString::npos ) { // simple case: there are no wildcard characters so we can return // either 0 or 1 results and we can find the potential match quickly - return m_Hash.count(spec) ? spec : wxString(); + return m_Hash.count(spec) ? url : wxString(); } //else: deal with wildcards in FindNext() @@ -151,15 +152,18 @@ wxString wxMemoryFSHandlerBase::FindNext() // it to empty string after iterating over all elements while ( !m_findArgument.empty() ) { - // advance m_findIter before checking the value at the current position - // as we need to do it anyhow, whether it matches or not + // test for the match before (possibly) clearing m_findArgument below + const bool found = m_findIter->first.Matches(m_findArgument); + + // advance m_findIter first as we need to do it anyhow, whether it + // matches or not const wxMemoryFSHash::const_iterator current = m_findIter; if ( ++m_findIter == m_Hash.end() ) m_findArgument.clear(); - if ( current->first.Matches(m_findArgument) ) - return current->first; + if ( found ) + return "memory:" + current->first; } return wxString();