X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/aaa66113dfa36c1636a646e3feb748c298806ccb..823c4e96f9656176562b5baf7d1b64a8a3dfb3d8:/include/wx/fs_zip.h diff --git a/include/wx/fs_zip.h b/include/wx/fs_zip.h index 53d866fd81..3276be7186 100644 --- a/include/wx/fs_zip.h +++ b/include/wx/fs_zip.h @@ -3,34 +3,33 @@ // Purpose: ZIP file system // Author: Vaclav Slavik // Copyright: (c) 1999 Vaclav Slavik -// Licence: wxWindows Licence +// CVS-ID: $Id$ +// 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" +#include "wx/defs.h" -#ifdef __BORDLANDC__ -#pragma hdrstop -#endif +#if wxUSE_FILESYSTEM && wxUSE_FS_ZIP && wxUSE_STREAMS -#if wxUSE_FS_ZIP && wxUSE_STREAMS +#include "wx/filesys.h" +#include "wx/hashmap.h" -#ifndef WXPRECOMP -#include "wx/wx.h" -#endif +WX_DECLARE_STRING_HASH_MAP(int, wxZipFilenameHashMap); -#include "wx/filesys.h" -//-------------------------------------------------------------------------------- +//--------------------------------------------------------------------------- // wxZipFSHandler -//-------------------------------------------------------------------------------- +//--------------------------------------------------------------------------- -class WXDLLEXPORT wxZipFSHandler : public wxFileSystemHandler +class WXDLLIMPEXP_BASE wxZipFSHandler : public wxFileSystemHandler { public: wxZipFSHandler(); @@ -39,17 +38,23 @@ class WXDLLEXPORT wxZipFSHandler : public wxFileSystemHandler virtual wxString FindFirst(const wxString& spec, int flags = 0); virtual wxString FindNext(); ~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; - + wxZipFilenameHashMap *m_DirsFound; + wxString DoFind(); + void CloseArchive(class wxZipInputStream *archive); + + DECLARE_NO_COPY_CLASS(wxZipFSHandler) }; #endif - // wxUSE_FS_ZIP && wxUSE_STREAMS + // wxUSE_FILESYSTEM && wxUSE_FS_ZIP && wxUSE_STREAMS + +#endif // _WX_FS_ZIP_H_