#include <wx/filesys.h>
Classes derived from wxFileSystemHandler are used to access virtual file systems.
Its public interface consists of two methods: wxFileSystemHandler::CanOpen and wxFileSystemHandler::OpenFile.
It provides additional protected methods to simplify the process of opening the file: GetProtocol(), GetLeftLocation(), GetRightLocation(), GetAnchor(), GetMimeTypeFromExt().
Please have a look at overview (see wxFileSystem) if you don't know how locations are constructed.
Also consult the list of available handlers.
Note that the handlers are shared by all instances of wxFileSystem.
wxPerl Note: In wxPerl, you need to derive your file system handler class from Wx::PlFileSystemHandler
.
Public Member Functions | |
wxFileSystemHandler () | |
Constructor. More... | |
virtual bool | CanOpen (const wxString &location)=0 |
Returns true if the handler is able to open this file. More... | |
virtual wxString | FindFirst (const wxString &wildcard, int flags=0) |
Works like wxFindFirstFile(). More... | |
virtual wxString | FindNext () |
Returns next filename that matches parameters passed to wxFileSystem::FindFirst. More... | |
virtual wxFSFile * | OpenFile (wxFileSystem &fs, const wxString &location)=0 |
Opens the file and returns wxFSFile pointer or NULL if failed. More... | |
Public Member Functions inherited from wxObject | |
wxObject () | |
Default ctor; initializes to NULL the internal reference data. More... | |
wxObject (const wxObject &other) | |
Copy ctor. More... | |
virtual | ~wxObject () |
Destructor. More... | |
virtual wxClassInfo * | GetClassInfo () const |
This virtual function is redefined for every class that requires run-time type information, when using the wxDECLARE_CLASS macro (or similar). More... | |
wxObjectRefData * | GetRefData () const |
Returns the wxObject::m_refData pointer, i.e. the data referenced by this object. More... | |
bool | IsKindOf (const wxClassInfo *info) const |
Determines whether this class is a subclass of (or the same class as) the given class. More... | |
bool | IsSameAs (const wxObject &obj) const |
Returns true if this object has the same data pointer as obj. More... | |
void | Ref (const wxObject &clone) |
Makes this object refer to the data in clone. More... | |
void | SetRefData (wxObjectRefData *data) |
Sets the wxObject::m_refData pointer. More... | |
void | UnRef () |
Decrements the reference count in the associated data, and if it is zero, deletes the data. More... | |
void | UnShare () |
This is the same of AllocExclusive() but this method is public. More... | |
void | operator delete (void *buf) |
The delete operator is defined for debugging versions of the library only, when the identifier __WXDEBUG__ is defined. More... | |
void * | operator new (size_t size, const wxString &filename=NULL, int lineNum=0) |
The new operator is defined for debugging versions of the library only, when the identifier __WXDEBUG__ is defined. More... | |
Static Public Member Functions | |
static wxString | GetMimeTypeFromExt (const wxString &location) |
Returns the MIME type based on extension of location. More... | |
Static Protected Member Functions | |
static wxString | GetAnchor (const wxString &location) |
Returns the anchor if present in the location. More... | |
static wxString | GetLeftLocation (const wxString &location) |
Returns the left location string extracted from location. More... | |
static wxString | GetProtocol (const wxString &location) |
Returns the protocol string extracted from location. More... | |
static wxString | GetRightLocation (const wxString &location) |
Returns the right location string extracted from location. More... | |
Additional Inherited Members | |
Protected Member Functions inherited from wxObject | |
void | AllocExclusive () |
Ensure that this object's data is not shared with any other object. More... | |
virtual wxObjectRefData * | CreateRefData () const |
Creates a new instance of the wxObjectRefData-derived class specific to this object and returns it. More... | |
virtual wxObjectRefData * | CloneRefData (const wxObjectRefData *data) const |
Creates a new instance of the wxObjectRefData-derived class specific to this object and initializes it copying data. More... | |
Protected Attributes inherited from wxObject | |
wxObjectRefData * | m_refData |
Pointer to an object which is the object's reference-counted data. More... | |
wxFileSystemHandler::wxFileSystemHandler | ( | ) |
Constructor.
|
pure virtual |
Returns true if the handler is able to open this file.
This function doesn't check whether the file exists or not, it only checks if it knows the protocol. Example:
Must be overridden in derived handlers.
|
virtual |
Works like wxFindFirstFile().
Returns the name of the first filename (within filesystem's current path) that matches wildcard. flags may be one of wxFILE (only files), wxDIR (only directories) or 0 (both).
This method is only called if CanOpen() returns true.
|
virtual |
Returns next filename that matches parameters passed to wxFileSystem::FindFirst.
This method is only called if CanOpen() returns true and FindFirst() returned a non-empty string.
Returns the anchor if present in the location.
See wxFSFile::GetAnchor for details.
Example:
Returns the left location string extracted from location.
Example:
Returns the MIME type based on extension of location.
(While wxFSFile::GetMimeType() returns real MIME type - either extension-based or queried from HTTP.)
Example:
Returns the protocol string extracted from location.
Example:
Returns the right location string extracted from location.
Example:
|
pure virtual |
Opens the file and returns wxFSFile pointer or NULL if failed.
Must be overridden in derived handlers.
fs | Parent FS (the FS from that OpenFile was called). See the ZIP handler for details of how to use it. |
location | The absolute location of file. |