]> git.saurik.com Git - wxWidgets.git/blobdiff - include/wx/fs_zip.h
Some code tidying; removing dibutils.cpp which
[wxWidgets.git] / include / wx / fs_zip.h
index f891349cbf0ba9dc2aad07d98d63f050d6512357..5f4dc0b883f167ed91cc3c57ba81c94ace0859ca 100644 (file)
@@ -3,30 +3,28 @@
 // Purpose:     ZIP file system
 // Author:      Vaclav Slavik
 // Copyright:   (c) 1999 Vaclav Slavik
+// CVS-ID:      $Id$
 // Licence:     wxWindows Licence
 /////////////////////////////////////////////////////////////////////////////
 
+#ifndef _WX_FS_ZIP_H_
+#define _WX_FS_ZIP_H_
 
-#ifdef __GNUG__
-#pragma implementation
+#if defined(__GNUG__) && !defined(__APPLE__)
+#pragma interface "fs_zip.h"
 #endif
 
-#include <wx/wxprec.h>
+#include "wx/wxprec.h"
 
-#ifdef __BORDLANDC__
+#ifdef __BORLANDC__
 #pragma hdrstop
 #endif
 
-#if wxUSE_FS_ZIP && wxUSE_STREAMS
-
-
-#ifndef WXPRECOMP
-#include <wx/wx.h>
-#endif
-
-#include <wx/filesys.h>
+#if wxUSE_FILESYSTEM && wxUSE_FS_ZIP && wxUSE_STREAMS
 
+#include "wx/filesys.h"
 
+class WXDLLEXPORT wxHashTableLong;
 
 //--------------------------------------------------------------------------------
 // wxZipFSHandler
 class WXDLLEXPORT wxZipFSHandler : public wxFileSystemHandler
 {
     public:
+        wxZipFSHandler();
         virtual bool CanOpen(const wxString& location);
         virtual wxFSFile* OpenFile(wxFileSystem& fs, const wxString& location);
+        virtual wxString FindFirst(const wxString& spec, int flags = 0);
+        virtual wxString FindNext();
         ~wxZipFSHandler();
+
+    private:
+        // these vars are used by FindFirst/Next:
+        void *m_Archive;
+        wxString m_Pattern, m_BaseDir, m_ZipFile;
+        bool m_AllowDirs, m_AllowFiles;
+        wxHashTableLong *m_DirsFound;
+
+        wxString DoFind();
+
+    DECLARE_NO_COPY_CLASS(wxZipFSHandler)
 };
 
 
 #endif
-  // wxUSE_FS_ZIP && wxUSE_STREAMS
+  // wxUSE_FILESYSTEM && wxUSE_FS_ZIP && wxUSE_STREAMS
+
+#endif // _WX_FS_ZIP_H_