// 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__
+#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"
+
-class WXDLLEXPORT wxHashTableLong;
+WX_DECLARE_STRING_HASH_MAP(int, wxZipFilenameHashMap);
-//--------------------------------------------------------------------------------
+
+//---------------------------------------------------------------------------
// wxZipFSHandler
-//--------------------------------------------------------------------------------
+//---------------------------------------------------------------------------
-class WXDLLEXPORT wxZipFSHandler : public wxFileSystemHandler
+class WXDLLIMPEXP_BASE wxZipFSHandler : public wxFileSystemHandler
{
public:
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();
+ void CloseArchive(class wxZipInputStream *archive);
+
+ DECLARE_NO_COPY_CLASS(wxZipFSHandler)
};