// 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_
-#if defined(__GNUG__) && !defined(__APPLE__)
-#pragma interface "fs_zip.h"
-#endif
-
-#include "wx/wxprec.h"
-
-#ifdef __BORLANDC__
-#pragma hdrstop
-#endif
+#include "wx/defs.h"
#if wxUSE_FILESYSTEM && wxUSE_FS_ZIP && wxUSE_STREAMS
#include "wx/filesys.h"
+#include "wx/hashmap.h"
-class WXDLLEXPORT wxHashTableLong;
-//--------------------------------------------------------------------------------
+WX_DECLARE_STRING_HASH_MAP(int, wxZipFilenameHashMap);
+
+
+//---------------------------------------------------------------------------
// wxZipFSHandler
-//--------------------------------------------------------------------------------
+//---------------------------------------------------------------------------
-class WXDLLEXPORT wxZipFSHandler : public wxFileSystemHandler
+class WXDLLIMPEXP_BASE wxZipFSHandler : public wxFileSystemHandler
{
public:
wxZipFSHandler();
virtual wxFSFile* OpenFile(wxFileSystem& fs, const wxString& location);
virtual wxString FindFirst(const wxString& spec, int flags = 0);
virtual wxString FindNext();
+ void Cleanup();
~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)
};