| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314 |
- /////////////////////////////////////////////////////////////////////////////
- // Name: wx/filesys.h
- // Purpose: class for opening files - virtual file system
- // Author: Vaclav Slavik
- // Copyright: (c) 1999 Vaclav Slavik
- // Licence: wxWindows licence
- /////////////////////////////////////////////////////////////////////////////
- #ifndef __FILESYS_H__
- #define __FILESYS_H__
- #include "wx/defs.h"
- #if wxUSE_FILESYSTEM
- #if !wxUSE_STREAMS
- #error You cannot compile virtual file systems without wxUSE_STREAMS
- #endif
- #if wxUSE_HTML && !wxUSE_FILESYSTEM
- #error You cannot compile wxHTML without virtual file systems
- #endif
- #include "wx/stream.h"
- #include "wx/datetime.h"
- #include "wx/filename.h"
- #include "wx/hashmap.h"
- class WXDLLIMPEXP_FWD_BASE wxFSFile;
- class WXDLLIMPEXP_FWD_BASE wxFileSystemHandler;
- class WXDLLIMPEXP_FWD_BASE wxFileSystem;
- //--------------------------------------------------------------------------------
- // wxFSFile
- // This class is a file opened using wxFileSystem. It consists of
- // input stream, location, mime type & optional anchor
- // (in 'index.htm#chapter2', 'chapter2' is anchor)
- //--------------------------------------------------------------------------------
- class WXDLLIMPEXP_BASE wxFSFile : public wxObject
- {
- public:
- wxFSFile(wxInputStream *stream, const wxString& loc,
- const wxString& mimetype, const wxString& anchor
- #if wxUSE_DATETIME
- , wxDateTime modif
- #endif // wxUSE_DATETIME
- )
- {
- m_Stream = stream;
- m_Location = loc;
- m_MimeType = mimetype.Lower();
- m_Anchor = anchor;
- #if wxUSE_DATETIME
- m_Modif = modif;
- #endif // wxUSE_DATETIME
- }
- virtual ~wxFSFile() { delete m_Stream; }
- // returns stream. This doesn't give away ownership of the stream object.
- wxInputStream *GetStream() const { return m_Stream; }
- // gives away the ownership of the current stream.
- wxInputStream *DetachStream()
- {
- wxInputStream *stream = m_Stream;
- m_Stream = NULL;
- return stream;
- }
- // deletes the current stream and takes ownership of another.
- void SetStream(wxInputStream *stream)
- {
- delete m_Stream;
- m_Stream = stream;
- }
- // returns file's mime type
- const wxString& GetMimeType() const;
- // returns the original location (aka filename) of the file
- const wxString& GetLocation() const { return m_Location; }
- const wxString& GetAnchor() const { return m_Anchor; }
- #if wxUSE_DATETIME
- wxDateTime GetModificationTime() const { return m_Modif; }
- #endif // wxUSE_DATETIME
- private:
- wxInputStream *m_Stream;
- wxString m_Location;
- wxString m_MimeType;
- wxString m_Anchor;
- #if wxUSE_DATETIME
- wxDateTime m_Modif;
- #endif // wxUSE_DATETIME
- DECLARE_ABSTRACT_CLASS(wxFSFile)
- wxDECLARE_NO_COPY_CLASS(wxFSFile);
- };
- //--------------------------------------------------------------------------------
- // wxFileSystemHandler
- // This class is FS handler for wxFileSystem. It provides
- // interface to access certain
- // kinds of files (HTPP, FTP, local, tar.gz etc..)
- //--------------------------------------------------------------------------------
- class WXDLLIMPEXP_BASE wxFileSystemHandler : public wxObject
- {
- public:
- wxFileSystemHandler() : wxObject() {}
- // returns true if this handler is able to open given location
- virtual bool CanOpen(const wxString& location) = 0;
- // opens given file and returns pointer to input stream.
- // Returns NULL if opening failed.
- // The location is always absolute path.
- virtual wxFSFile* OpenFile(wxFileSystem& fs, const wxString& location) = 0;
- // Finds first/next file that matches spec wildcard. flags can be wxDIR for restricting
- // the query to directories or wxFILE for files only or 0 for either.
- // Returns filename or empty string if no more matching file exists
- virtual wxString FindFirst(const wxString& spec, int flags = 0);
- virtual wxString FindNext();
- // Returns MIME type of the file - w/o need to open it
- // (default behaviour is that it returns type based on extension)
- static wxString GetMimeTypeFromExt(const wxString& location);
- protected:
- // returns protocol ("file", "http", "tar" etc.) The last (most right)
- // protocol is used:
- // {it returns "tar" for "file:subdir/archive.tar.gz#tar:/README.txt"}
- static wxString GetProtocol(const wxString& location);
- // returns left part of address:
- // {it returns "file:subdir/archive.tar.gz" for "file:subdir/archive.tar.gz#tar:/README.txt"}
- static wxString GetLeftLocation(const wxString& location);
- // returns anchor part of address:
- // {it returns "anchor" for "file:subdir/archive.tar.gz#tar:/README.txt#anchor"}
- // NOTE: anchor is NOT a part of GetLeftLocation()'s return value
- static wxString GetAnchor(const wxString& location);
- // returns right part of address:
- // {it returns "/README.txt" for "file:subdir/archive.tar.gz#tar:/README.txt"}
- static wxString GetRightLocation(const wxString& location);
- DECLARE_ABSTRACT_CLASS(wxFileSystemHandler)
- };
- //--------------------------------------------------------------------------------
- // wxFileSystem
- // This class provides simple interface for opening various
- // kinds of files (HTPP, FTP, local, tar.gz etc..)
- //--------------------------------------------------------------------------------
- // Open Bit Flags
- enum wxFileSystemOpenFlags
- {
- wxFS_READ = 1, // Open for reading
- wxFS_SEEKABLE = 4 // Returned stream will be seekable
- };
- WX_DECLARE_VOIDPTR_HASH_MAP_WITH_DECL(wxFileSystemHandler*, wxFSHandlerHash, class WXDLLIMPEXP_BASE);
- class WXDLLIMPEXP_BASE wxFileSystem : public wxObject
- {
- public:
- wxFileSystem() : wxObject() { m_FindFileHandler = NULL;}
- virtual ~wxFileSystem();
- // sets the current location. Every call to OpenFile is
- // relative to this location.
- // NOTE !!
- // unless is_dir = true 'location' is *not* the directory but
- // file contained in this directory
- // (so ChangePathTo("dir/subdir/xh.htm") sets m_Path to "dir/subdir/")
- void ChangePathTo(const wxString& location, bool is_dir = false);
- wxString GetPath() const {return m_Path;}
- // opens given file and returns pointer to input stream.
- // Returns NULL if opening failed.
- // It first tries to open the file in relative scope
- // (based on ChangePathTo()'s value) and then as an absolute
- // path.
- wxFSFile* OpenFile(const wxString& location, int flags = wxFS_READ);
- // Finds first/next file that matches spec wildcard. flags can be wxDIR for restricting
- // the query to directories or wxFILE for files only or 0 for either.
- // Returns filename or empty string if no more matching file exists
- wxString FindFirst(const wxString& spec, int flags = 0);
- wxString FindNext();
- // find a file in a list of directories, returns false if not found
- bool FindFileInPath(wxString *pStr,
- const wxString& path, const wxString& file);
- // Adds FS handler.
- // In fact, this class is only front-end to the FS handlers :-)
- static void AddHandler(wxFileSystemHandler *handler);
- // Removes FS handler
- static wxFileSystemHandler* RemoveHandler(wxFileSystemHandler *handler);
- // Returns true if there is a handler which can open the given location.
- static bool HasHandlerForPath(const wxString& location);
- // remove all items from the m_Handlers list
- static void CleanUpHandlers();
- // Returns the native path for a file URL
- static wxFileName URLToFileName(const wxString& url);
- // Returns the file URL for a native path
- static wxString FileNameToURL(const wxFileName& filename);
- protected:
- wxFileSystemHandler *MakeLocal(wxFileSystemHandler *h);
- wxString m_Path;
- // the path (location) we are currently in
- // this is path, not file!
- // (so if you opened test/demo.htm, it is
- // "test/", not "test/demo.htm")
- wxString m_LastName;
- // name of last opened file (full path)
- static wxList m_Handlers;
- // list of FS handlers
- wxFileSystemHandler *m_FindFileHandler;
- // handler that succeed in FindFirst query
- wxFSHandlerHash m_LocalHandlers;
- // Handlers local to this instance
- DECLARE_DYNAMIC_CLASS(wxFileSystem)
- wxDECLARE_NO_COPY_CLASS(wxFileSystem);
- };
- /*
- 'location' syntax:
- To determine FS type, we're using standard KDE notation:
- file:/absolute/path/file.htm
- file:relative_path/xxxxx.html
- /some/path/x.file ('file:' is default)
- http://www.gnome.org
- file:subdir/archive.tar.gz#tar:/README.txt
- special characters :
- ':' - FS identificator is before this char
- '#' - separator. It can be either HTML anchor ("index.html#news")
- (in case there is no ':' in the string to the right from it)
- or FS separator
- (example : http://www.wxhtml.org/wxhtml-0.1.tar.gz#tar:/include/wxhtml/filesys.h"
- this would access tgz archive stored on web)
- '/' - directory (path) separator. It is used to determine upper-level path.
- HEY! Don't use \ even if you're on Windows!
- */
- class WXDLLIMPEXP_BASE wxLocalFSHandler : public wxFileSystemHandler
- {
- public:
- 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();
- // wxLocalFSHandler will prefix all filenames with 'root' before accessing
- // files on disk. This effectively makes 'root' the top-level directory
- // and prevents access to files outside this directory.
- // (This is similar to Unix command 'chroot'.)
- static void Chroot(const wxString& root) { ms_root = root; }
- protected:
- static wxString ms_root;
- };
- // Stream reading data from wxFSFile: this allows to use virtual files with any
- // wx functions accepting streams.
- class WXDLLIMPEXP_BASE wxFSInputStream : public wxWrapperInputStream
- {
- public:
- // Notice that wxFS_READ is implied in flags.
- wxFSInputStream(const wxString& filename, int flags = 0);
- virtual ~wxFSInputStream();
- private:
- wxFSFile* m_file;
- wxDECLARE_NO_COPY_CLASS(wxFSInputStream);
- };
- #endif
- // wxUSE_FILESYSTEM
- #endif
- // __FILESYS_H__
|