1999-11-22 12:13:55 +00:00
|
|
|
\section{wxFileSystem}\label{fs}
|
1999-07-10 21:17:24 +00:00
|
|
|
|
1999-07-30 12:02:28 +00:00
|
|
|
The wxHTML library uses a {\bf virtual file systems} mechanism
|
|
|
|
similar to the one used in Midnight Commander, Dos Navigator,
|
2000-07-15 19:51:35 +00:00
|
|
|
FAR or almost any modern file manager. It allows the user to access
|
|
|
|
data stored in archives as if they were ordinary files. On-the-fly
|
|
|
|
generated files that exist only in memory are also supported.
|
1999-07-10 21:17:24 +00:00
|
|
|
|
|
|
|
\wxheading{Classes}
|
|
|
|
|
2000-07-15 19:51:35 +00:00
|
|
|
Three classes are used in order to provide virtual file systems mechanism:
|
1999-07-10 21:17:24 +00:00
|
|
|
|
1999-08-05 22:05:15 +00:00
|
|
|
\begin{itemize}\itemsep=0pt
|
1999-07-30 12:02:28 +00:00
|
|
|
\item The \helpref{wxFSFile}{wxfsfile} class provides information
|
2000-07-15 19:51:35 +00:00
|
|
|
about opened file (name, input stream, mime type and anchor).
|
1999-07-30 12:02:28 +00:00
|
|
|
\item The \helpref{wxFileSystem}{wxfilesystem} class is the interface.
|
|
|
|
Its main methods are ChangePathTo() and OpenFile(). This class
|
1999-07-10 21:17:24 +00:00
|
|
|
is most often used by the end user.
|
1999-07-30 12:02:28 +00:00
|
|
|
\item The \helpref{wxFileSystemHandler}{wxfilesystemhandler} is the core
|
2000-07-15 19:51:35 +00:00
|
|
|
of virtual file systems mechanism. You can derive your own handler and pass it to
|
2005-01-16 13:33:19 +00:00
|
|
|
the VFS mechanism. You can derive your own handler and pass it to
|
1999-07-10 21:17:24 +00:00
|
|
|
wxFileSystem's AddHandler() method. In the new handler you only need to
|
2000-07-15 19:51:35 +00:00
|
|
|
override the OpenFile() and CanOpen() methods.
|
1999-07-10 21:17:24 +00:00
|
|
|
\end{itemize}
|
|
|
|
|
|
|
|
\wxheading{Locations}
|
|
|
|
|
2000-07-15 19:51:35 +00:00
|
|
|
Locations (aka filenames aka addresses) are constructed from four parts:
|
1999-07-10 21:17:24 +00:00
|
|
|
|
1999-08-05 22:05:15 +00:00
|
|
|
\begin{itemize}\itemsep=0pt
|
1999-07-30 12:02:28 +00:00
|
|
|
\item {\bf protocol} - handler can recognize if it is able to open a
|
|
|
|
file by checking its protocol. Examples are "http", "file" or "ftp".
|
1999-07-10 21:17:24 +00:00
|
|
|
\item {\bf right location} - is the name of file within the protocol.
|
2004-05-04 08:27:20 +00:00
|
|
|
In "http://www.wxwidgets.org/index.html" the right location is "//www.wxwidgets.org/index.html".
|
2000-07-15 19:51:35 +00:00
|
|
|
\item {\bf anchor} - an anchor is optional and is usually not present.
|
1999-07-30 12:02:28 +00:00
|
|
|
In "index.htm\#chapter2" the anchor is "chapter2".
|
|
|
|
\item {\bf left location} - this is usually an empty string.
|
1999-07-10 21:17:24 +00:00
|
|
|
It is used by 'local' protocols such as ZIP.
|
|
|
|
See Combined Protocols paragraph for details.
|
|
|
|
\end{itemize}
|
|
|
|
|
|
|
|
\wxheading{Combined Protocols}
|
|
|
|
|
2000-07-15 19:51:35 +00:00
|
|
|
The left location precedes the protocol in the URL string.
|
|
|
|
It is not used by global protocols like HTTP but it becomes handy when nesting
|
2001-02-20 16:03:01 +00:00
|
|
|
protocols - for example you may want to access files in a ZIP archive:
|
1999-07-10 21:17:24 +00:00
|
|
|
|
|
|
|
file:archives/cpp\_doc.zip\#zip:reference/fopen.htm\#syntax
|
|
|
|
|
2002-12-13 23:50:04 +00:00
|
|
|
In this example, the protocol is "zip", right location is
|
|
|
|
"reference/fopen.htm", anchor is "syntax" and left location
|
2000-07-15 19:51:35 +00:00
|
|
|
is "file:archives/cpp\_doc.zip".
|
1999-07-10 21:17:24 +00:00
|
|
|
|
2000-07-15 19:51:35 +00:00
|
|
|
There are {\bf two} protocols used in this example: "zip" and "file".
|
1999-07-10 21:17:24 +00:00
|
|
|
|
|
|
|
\wxheading{File Systems Included in wxHTML}
|
|
|
|
|
2004-05-04 08:27:20 +00:00
|
|
|
The following virtual file system handlers are part of wxWidgets so far:
|
2000-02-27 21:07:04 +00:00
|
|
|
|
|
|
|
\begin{twocollist}
|
2000-07-15 19:51:35 +00:00
|
|
|
\twocolitem{{\bf wxInternetFSHandler}}{A handler for accessing documents
|
2001-05-24 10:39:33 +00:00
|
|
|
via HTTP or FTP protocols. Include file is <wx/fs\_inet.h>.}
|
2000-07-15 19:51:35 +00:00
|
|
|
\twocolitem{{\bf wxZipFSHandler}}{A handler for ZIP archives.
|
2001-05-24 10:39:33 +00:00
|
|
|
Include file is <wx/fs\_zip.h>. URL is in form "archive.zip\#zip:filename".}
|
2000-02-27 21:07:04 +00:00
|
|
|
\twocolitem{{\bf wxMemoryFSHandler}}{This handler allows you to access
|
|
|
|
data stored in memory (such as bitmaps) as if they were regular files.
|
|
|
|
See \helpref{wxMemoryFSHandler documentation}{wxmemoryfshandler} for details.
|
2002-06-07 20:15:28 +00:00
|
|
|
Include file is <wx/fs\_mem.h>. URL is prefixed with memory:, e.g.
|
2000-02-27 21:07:04 +00:00
|
|
|
"memory:myfile.htm"}
|
|
|
|
\end{twocollist}
|
|
|
|
|
2000-07-15 19:51:35 +00:00
|
|
|
In addition, wxFileSystem itself can access local files.
|
|
|
|
|
2000-02-27 21:07:04 +00:00
|
|
|
|
2000-07-15 19:51:35 +00:00
|
|
|
\wxheading{Initializing file system handlers}
|
2000-02-27 21:07:04 +00:00
|
|
|
|
|
|
|
Use \helpref{wxFileSystem::AddHandler}{wxfilesystemaddhandler} to initialize
|
|
|
|
a handler, for example:
|
|
|
|
|
|
|
|
\begin{verbatim}
|
|
|
|
#include <wx/fs_mem.h>
|
|
|
|
|
|
|
|
...
|
|
|
|
|
|
|
|
bool MyApp::OnInit()
|
|
|
|
{
|
|
|
|
wxFileSystem::AddHandler(new wxMemoryFSHandler);
|
|
|
|
...
|
2000-07-15 19:51:35 +00:00
|
|
|
}
|
2000-02-27 21:07:04 +00:00
|
|
|
\end{verbatim}
|
|
|
|
|