Maps a Multifile's contents into the VirtualFileSystem. More...
#include "virtualFileMountMultifile.h"
Public Member Functions | |
VirtualFileMountMultifile (Multifile *multifile) | |
virtual TypeHandle | force_init_type () |
virtual std::streamsize | get_file_size (const Filename &file, std::istream *stream) const |
Returns the current size on disk (or wherever it is) of the already-open file. More... | |
virtual std::streamsize | get_file_size (const Filename &file) const |
Returns the current size on disk (or wherever it is) of the file before it has been opened. More... | |
Multifile * | get_multifile () const |
Returns the Multifile pointer that this mount object is based on. More... | |
virtual bool | get_system_info (const Filename &file, SubfileInfo &info) |
Populates the SubfileInfo structure with the data representing where the file actually resides on disk, if this is knowable. More... | |
virtual time_t | get_timestamp (const Filename &file) const |
Returns a time_t value that represents the time the file was last modified, to within whatever precision the operating system records this information (on a Windows95 system, for instance, this may only be accurate to within 2 seconds). More... | |
virtual TypeHandle | get_type () const |
virtual bool | has_file (const Filename &file) const |
Returns true if the indicated file exists within the mount system. More... | |
virtual bool | is_directory (const Filename &file) const |
Returns true if the indicated file exists within the mount system and is a directory. More... | |
virtual bool | is_regular_file (const Filename &file) const |
Returns true if the indicated file exists within the mount system and is a regular file. More... | |
virtual std::istream * | open_read_file (const Filename &file) const |
Opens the file for reading, if it exists. More... | |
virtual void | output (std::ostream &out) const |
virtual bool | read_file (const Filename &file, bool do_uncompress, vector_uchar &result) const |
Fills up the indicated pvector with the contents of the file, if it is a regular file. More... | |
virtual bool | scan_directory (vector_string &contents, const Filename &dir) const |
Fills the given vector up with the list of filenames that are local to this directory, if the filename is a directory. More... | |
![]() | |
virtual bool | atomic_compare_and_exchange_contents (const Filename &file, std::string &orig_contents, const std::string &old_contents, const std::string &new_contents) |
See Filename::atomic_compare_and_exchange_contents(). More... | |
virtual bool | atomic_read_contents (const Filename &file, std::string &contents) const |
See Filename::atomic_read_contents(). More... | |
virtual void | close_read_file (std::istream *stream) const |
Closes a file opened by a previous call to open_read_file(). More... | |
virtual void | close_read_write_file (std::iostream *stream) |
Closes a file opened by a previous call to open_read_write_file(). More... | |
virtual void | close_write_file (std::ostream *stream) |
Closes a file opened by a previous call to open_write_file(). More... | |
virtual bool | copy_file (const Filename &orig_filename, const Filename &new_filename) |
Attempts to copy the contents of the indicated file to the indicated file. More... | |
virtual bool | create_file (const Filename &file) |
Attempts to create the indicated file within the mount, if it does not already exist. More... | |
virtual bool | delete_file (const Filename &file) |
Attempts to delete the indicated file or directory within the mount. More... | |
VirtualFileSystem * | get_file_system () const |
Returns the file system this mount object is attached to. More... | |
int | get_mount_flags () const |
Returns the set of flags passed by the user to the VirtualFileSystem::mount() command. More... | |
const Filename & | get_mount_point () const |
Returns the name of the directory within the virtual file system that this mount object is attached to. More... | |
virtual bool | is_writable (const Filename &file) const |
Returns true if the named file or directory may be written to, false otherwise. More... | |
virtual bool | make_directory (const Filename &file) |
Attempts to create the indicated file within the mount, if it does not already exist. More... | |
virtual PointerTo< VirtualFile > | make_virtual_file (const Filename &local_filename, const Filename &original_filename, bool implicit_pz_file, int open_flags) |
Constructs and returns a new VirtualFile instance that corresponds to the indicated filename within this mount point. More... | |
virtual std::ostream * | open_append_file (const Filename &file) |
Works like open_write_file(), but the file is opened in append mode. More... | |
virtual std::iostream * | open_read_append_file (const Filename &file) |
Works like open_read_write_file(), but the file is opened in append mode. More... | |
std::istream * | open_read_file (const Filename &file, bool do_uncompress) const |
Opens the file for reading. More... | |
virtual std::iostream * | open_read_write_file (const Filename &file, bool truncate) |
Opens the file for writing. More... | |
virtual std::ostream * | open_write_file (const Filename &file, bool truncate) |
Opens the file for writing. More... | |
std::ostream * | open_write_file (const Filename &file, bool do_compress, bool truncate) |
Opens the file for writing. More... | |
virtual bool | rename_file (const Filename &orig_filename, const Filename &new_filename) |
Attempts to rename the contents of the indicated file to the indicated file. More... | |
virtual void | write (std::ostream &out) const |
virtual bool | write_file (const Filename &file, bool do_compress, const unsigned char *data, size_t data_size) |
Writes the indicated data to the file, if it is a writable file. More... | |
![]() | |
TypedReferenceCount (const TypedReferenceCount ©) | |
void | operator= (const TypedReferenceCount ©) |
![]() | |
TypedObject (const TypedObject ©)=default | |
TypedObject * | as_typed_object () |
Returns the object, upcast (if necessary) to a TypedObject pointer. More... | |
const TypedObject * | as_typed_object () const |
Returns the object, upcast (if necessary) to a TypedObject pointer. More... | |
int | get_best_parent_from_Set (const std::set< int > &) const |
int | get_type_index () const |
Returns the internal index number associated with this object's TypeHandle, a unique number for each different type. More... | |
bool | is_exact_type (TypeHandle handle) const |
Returns true if the current object is the indicated type exactly. More... | |
bool | is_of_type (TypeHandle handle) const |
Returns true if the current object is or derives from the indicated type. More... | |
TypedObject & | operator= (const TypedObject ©)=default |
![]() | |
int | get_ref_count () const |
WeakReferenceList * | get_weak_list () const |
Returns the WeakReferenceList associated with this ReferenceCount object. More... | |
bool | has_weak_list () const |
Returns true if this particular ReferenceCount object has a WeakReferenceList created, false otherwise. More... | |
void | local_object () |
This function should be called, once, immediately after creating a new instance of some ReferenceCount-derived object on the stack. More... | |
void | ref () const |
Explicitly increments the reference count. More... | |
bool | ref_if_nonzero () const |
Atomically increases the reference count of this object if it is not zero. More... | |
bool | test_ref_count_integrity () const |
Does some easy checks to make sure that the reference count isn't completely bogus. More... | |
bool | test_ref_count_nonzero () const |
Does some easy checks to make sure that the reference count isn't zero, or completely bogus. More... | |
virtual bool | unref () const |
Explicitly decrements the reference count. More... | |
WeakReferenceList * | weak_ref () |
Adds the indicated PointerToVoid as a weak reference to this object. More... | |
void | weak_unref () |
Removes the indicated PointerToVoid as a weak reference to this object. More... | |
Static Public Member Functions | |
static TypeHandle | get_class_type () |
static void | init_type () |
![]() | |
static TypeHandle | get_class_type () |
static void | init_type () |
![]() | |
static TypeHandle | get_class_type () |
static void | init_type () |
![]() | |
static TypeHandle | get_class_type () |
static void | init_type () |
This function is declared non-inline to work around a compiler bug in g++ 2.96. More... | |
![]() | |
static TypeHandle | get_class_type () |
static void | init_type () |
Additional Inherited Members | |
![]() | |
get_type | |
![]() | |
get_ref_count | |
Returns the current reference count. More... | |
Maps a Multifile's contents into the VirtualFileSystem.
Definition at line 26 of file virtualFileMountMultifile.h.
|
virtual |
Returns the current size on disk (or wherever it is) of the already-open file.
Pass in the stream that was returned by open_read_file(); some implementations may require this stream to determine the size.
Implements VirtualFileMount.
Definition at line 108 of file virtualFileMountMultifile.cxx.
|
virtual |
Returns the current size on disk (or wherever it is) of the file before it has been opened.
Implements VirtualFileMount.
Definition at line 121 of file virtualFileMountMultifile.cxx.
|
inline |
Returns the Multifile pointer that this mount object is based on.
Definition at line 27 of file virtualFileMountMultifile.I.
|
virtual |
Populates the SubfileInfo structure with the data representing where the file actually resides on disk, if this is knowable.
Returns true if the file might reside on disk, and the info is populated, or false if it might not (or it is not known where the file resides), in which case the info is meaningless.
Reimplemented from VirtualFileMount.
Definition at line 156 of file virtualFileMountMultifile.cxx.
|
virtual |
Returns a time_t value that represents the time the file was last modified, to within whatever precision the operating system records this information (on a Windows95 system, for instance, this may only be accurate to within 2 seconds).
If the timestamp cannot be determined, either because it is not supported by the operating system or because there is some error (such as file not found), returns 0.
Implements VirtualFileMount.
Definition at line 140 of file virtualFileMountMultifile.cxx.
|
virtual |
Returns true if the indicated file exists within the mount system.
Implements VirtualFileMount.
Definition at line 32 of file virtualFileMountMultifile.cxx.
|
virtual |
Returns true if the indicated file exists within the mount system and is a directory.
Implements VirtualFileMount.
Definition at line 43 of file virtualFileMountMultifile.cxx.
|
virtual |
Returns true if the indicated file exists within the mount system and is a regular file.
Implements VirtualFileMount.
Definition at line 52 of file virtualFileMountMultifile.cxx.
|
virtual |
Opens the file for reading, if it exists.
Returns a newly allocated istream on success (which you should eventually delete when you are done reading). Returns NULL on failure.
Implements VirtualFileMount.
Definition at line 89 of file virtualFileMountMultifile.cxx.
|
virtual |
Fills up the indicated pvector with the contents of the file, if it is a regular file.
Returns true on success, false otherwise.
Reimplemented from VirtualFileMount.
Definition at line 61 of file virtualFileMountMultifile.cxx.
References VirtualFileMount::read_file().
|
virtual |
Fills the given vector up with the list of filenames that are local to this directory, if the filename is a directory.
Returns true if successful, or false if the file is not a directory or cannot be read.
Implements VirtualFileMount.
Definition at line 183 of file virtualFileMountMultifile.cxx.