Base interface for a file stream provider. It is intended to be implemented for specific file protocol. More...
#include <OSD_FileSystem.hxx>

Public Member Functions | |
| virtual Standard_Boolean | IsSupportedPath (const TCollection_AsciiString &theUrl) const =0 |
| Returns TRUE if URL defines a supported protocol. | |
| virtual Standard_Boolean | IsOpenIStream (const std::shared_ptr< std::istream > &theStream) const =0 |
| Returns TRUE if current input stream is opened for reading operations. | |
| virtual Standard_Boolean | IsOpenOStream (const std::shared_ptr< std::ostream > &theStream) const =0 |
| Returns TRUE if current output stream is opened for writing operations. | |
| virtual std::shared_ptr< std::istream > | OpenIStream (const TCollection_AsciiString &theUrl, const std::ios_base::openmode theMode, const int64_t theOffset=0, const std::shared_ptr< std::istream > &theOldStream=std::shared_ptr< std::istream >()) |
| Opens stream for specified file URL for reading operations (std::istream). Default implementation create a stream from file buffer returned by OSD_FileSystem::OpenFileBuffer(). | |
| virtual std::shared_ptr< std::ostream > | OpenOStream (const TCollection_AsciiString &theUrl, const std::ios_base::openmode theMode) |
| Opens stream for specified file URL for writing operations (std::ostream). Default implementation create a stream from file buffer returned by OSD_FileSystem::OpenFileBuffer(). | |
| virtual std::shared_ptr< std::streambuf > | OpenStreamBuffer (const TCollection_AsciiString &theUrl, const std::ios_base::openmode theMode, const int64_t theOffset=0, int64_t *theOutBufSize=NULL)=0 |
| Opens stream buffer for specified file URL. | |
| OSD_FileSystem () | |
| Constructor. | |
| virtual | ~OSD_FileSystem () |
| Destructor. | |
Public Member Functions inherited from Standard_Transient | |
| Standard_Transient () | |
| Empty constructor. | |
| Standard_Transient (const Standard_Transient &) | |
| Copy constructor – does nothing. | |
| Standard_Transient & | operator= (const Standard_Transient &) |
| Assignment operator, needed to avoid copying reference counter. | |
| virtual | ~Standard_Transient () |
| Destructor must be virtual. | |
| virtual const opencascade::handle< Standard_Type > & | DynamicType () const |
| Returns a type descriptor about this object. | |
| Standard_Boolean | IsInstance (const opencascade::handle< Standard_Type > &theType) const |
| Returns a true value if this is an instance of Type. | |
| Standard_Boolean | IsInstance (const Standard_CString theTypeName) const |
| Returns a true value if this is an instance of TypeName. | |
| Standard_Boolean | IsKind (const opencascade::handle< Standard_Type > &theType) const |
| Returns true if this is an instance of Type or an instance of any class that inherits from Type. Note that multiple inheritance is not supported by OCCT RTTI mechanism. | |
| Standard_Boolean | IsKind (const Standard_CString theTypeName) const |
| Returns true if this is an instance of TypeName or an instance of any class that inherits from TypeName. Note that multiple inheritance is not supported by OCCT RTTI mechanism. | |
| Standard_Transient * | This () const |
| Returns non-const pointer to this object (like const_cast). For protection against creating handle to objects allocated in stack or call from constructor, it will raise exception Standard_ProgramError if reference counter is zero. | |
| Standard_Integer | GetRefCount () const noexcept |
| Get the reference counter of this object. | |
| void | IncrementRefCounter () noexcept |
| Increments the reference counter of this object. | |
| Standard_Integer | DecrementRefCounter () noexcept |
| Decrements the reference counter of this object; returns the decremented value. | |
| virtual void | Delete () const |
| Memory deallocator for transient classes. | |
Static Public Member Functions | |
| static const Handle< OSD_FileSystem > & | DefaultFileSystem () |
| Returns a global file system, which a selector between registered file systems (OSD_FileSystemSelector). | |
| static void | AddDefaultProtocol (const Handle< OSD_FileSystem > &theFileSystem, bool theIsPreferred=false) |
| Registers file system within the global file system selector returned by OSD_FileSystem::DefaultFileSystem(). Note that registering protocols is not thread-safe operation and expected to be done once at application startup. | |
| static void | RemoveDefaultProtocol (const Handle< OSD_FileSystem > &theFileSystem) |
| Unregisters file system within the global file system selector returned by OSD_FileSystem::DefaultFileSystem(). | |
| static constexpr const char * | get_type_name () |
| Returns a type descriptor about this object. | |
| static const opencascade::handle< Standard_Type > & | get_type_descriptor () |
| Returns type descriptor of Standard_Transient class. | |
Additional Inherited Members | |
| typedef void | base_type |
| Returns a type descriptor about this object. | |
Base interface for a file stream provider. It is intended to be implemented for specific file protocol.
| OSD_FileSystem::OSD_FileSystem | ( | ) |
Constructor.
|
virtual |
Destructor.
|
static |
Registers file system within the global file system selector returned by OSD_FileSystem::DefaultFileSystem(). Note that registering protocols is not thread-safe operation and expected to be done once at application startup.
| [in] | theFileSystem | file system to register |
| [in] | theIsPreferred | add to the beginning of the list when TRUE, or add to the end otherwise |
|
static |
Returns a global file system, which a selector between registered file systems (OSD_FileSystemSelector).
|
pure virtual |
Returns TRUE if current input stream is opened for reading operations.
Implemented in OSD_CachedFileSystem, OSD_FileSystemSelector, and OSD_LocalFileSystem.
|
pure virtual |
Returns TRUE if current output stream is opened for writing operations.
Implemented in OSD_CachedFileSystem, OSD_FileSystemSelector, and OSD_LocalFileSystem.
|
pure virtual |
Returns TRUE if URL defines a supported protocol.
Implemented in OSD_CachedFileSystem, OSD_FileSystemSelector, and OSD_LocalFileSystem.
|
virtual |
Opens stream for specified file URL for reading operations (std::istream). Default implementation create a stream from file buffer returned by OSD_FileSystem::OpenFileBuffer().
| [in] | theUrl | path to open |
| [in] | theMode | flags describing the requested input mode for the stream (std::ios_base::in will be implicitly added) |
| [in] | theOffset | expected stream position from the beginning of the file (beginning of the stream by default); -1 would keep seek position undefined (in case of reusing theOldStream) |
| [in] | theOldStream | a pointer to existing stream pointing to theUrl to be reused (without re-opening) |
Reimplemented in OSD_CachedFileSystem, and OSD_FileSystemSelector.
|
virtual |
Opens stream for specified file URL for writing operations (std::ostream). Default implementation create a stream from file buffer returned by OSD_FileSystem::OpenFileBuffer().
| [in] | theUrl | path to open |
| [in] | theMode | flags describing the requested output mode for the stream (std::ios_base::out will be implicitly added) |
Reimplemented in OSD_CachedFileSystem, and OSD_FileSystemSelector.
|
pure virtual |
Opens stream buffer for specified file URL.
| [in] | theUrl | path to open |
| [in] | theMode | flags describing the requested input mode for the stream |
| [in] | theOffset | expected stream position from the beginning of the buffer (beginning of the stream buffer by default) |
| [out] | theOutBufSize | total buffer size (only if buffer is opened for read) |
Implemented in OSD_CachedFileSystem, OSD_FileSystemSelector, and OSD_LocalFileSystem.
|
static |
Unregisters file system within the global file system selector returned by OSD_FileSystem::DefaultFileSystem().