]> git.saurik.com Git - wxWidgets.git/blobdiff - include/wx/fs_zip.h
optimizing gauge cpu usage
[wxWidgets.git] / include / wx / fs_zip.h
index 53d866fd81663ec69fdca69a253e4db6bb966318..d449cb072a852c0d0161d91a3a4d77a7149d07b5 100644 (file)
@@ -3,34 +3,29 @@
 // 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_FS_ZIP && wxUSE_STREAMS
-
-
-#ifndef WXPRECOMP
-#include "wx/wx.h"
-#endif
+#if wxUSE_FILESYSTEM && wxUSE_FS_ZIP && wxUSE_STREAMS
 
 #include "wx/filesys.h"
+#include "wx/hashmap.h"
 
-//--------------------------------------------------------------------------------
+//---------------------------------------------------------------------------
 // wxZipFSHandler
-//--------------------------------------------------------------------------------
+//---------------------------------------------------------------------------
 
-class WXDLLEXPORT wxZipFSHandler : public wxFileSystemHandler
+class WXDLLIMPEXP_BASE wxZipFSHandler : public wxFileSystemHandler
 {
     public:
         wxZipFSHandler();
@@ -39,17 +34,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;
-        
+        wxLongToLongHashMap *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_