X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/de0702d065066f8ef63a9581985def172777ebb6..ad0ac642d5764497804bee2caad4fc1f20fc6cea:/include/wx/fs_zip.h diff --git a/include/wx/fs_zip.h b/include/wx/fs_zip.h index 94d10c8f25..46426f971f 100644 --- a/include/wx/fs_zip.h +++ b/include/wx/fs_zip.h @@ -4,36 +4,32 @@ // Author: Vaclav Slavik // Copyright: (c) 1999 Vaclav Slavik // CVS-ID: $Id$ -// Licence: wxWindows Licence +// Licence: wxWindows licence ///////////////////////////////////////////////////////////////////////////// +#ifndef _WX_FS_ZIP_H_ +#define _WX_FS_ZIP_H_ -#ifdef __GNUG__ -#pragma implementation +#if defined(__GNUG__) && !defined(NO_GCC_PRAGMA) +#pragma interface "fs_zip.h" #endif -#include "wx/wxprec.h" - -#ifdef __BORDLANDC__ -#pragma hdrstop -#endif +#include "wx/defs.h" #if wxUSE_FILESYSTEM && wxUSE_FS_ZIP && wxUSE_STREAMS +#include "wx/filesys.h" +#include "wx/hashmap.h" -#ifndef WXPRECOMP -#include "wx/wx.h" -#endif -#include "wx/filesys.h" +WX_DECLARE_STRING_HASH_MAP(int, wxZipFilenameHashMap); -class WXDLLEXPORT wxHashTableLong; -//-------------------------------------------------------------------------------- +//--------------------------------------------------------------------------- // wxZipFSHandler -//-------------------------------------------------------------------------------- +//--------------------------------------------------------------------------- -class WXDLLEXPORT wxZipFSHandler : public wxFileSystemHandler +class WXDLLIMPEXP_BASE wxZipFSHandler : public wxFileSystemHandler { public: wxZipFSHandler(); @@ -41,19 +37,26 @@ class WXDLLEXPORT wxZipFSHandler : public wxFileSystemHandler virtual wxFSFile* OpenFile(wxFileSystem& fs, const wxString& location); virtual wxString FindFirst(const wxString& spec, int flags = 0); virtual wxString FindNext(); +#if wxABI_VERSION >= 20602 /* 2.6.2+ only */ + void Cleanup(); +#endif ~wxZipFSHandler(); - + private: // these vars are used by FindFirst/Next: - void *m_Archive; + class wxZipInputStream *m_Archive; wxString m_Pattern, m_BaseDir, m_ZipFile; bool m_AllowDirs, m_AllowFiles; - wxHashTableLong *m_DirsFound; - + wxZipFilenameHashMap *m_DirsFound; + wxString DoFind(); + + DECLARE_NO_COPY_CLASS(wxZipFSHandler) }; #endif // wxUSE_FILESYSTEM && wxUSE_FS_ZIP && wxUSE_STREAMS +#endif // _WX_FS_ZIP_H_ +