108 lines
3.3 KiB
C++
108 lines
3.3 KiB
C++
/** @file Filesystem wrapper for C++. Inherit this class to supply custom file handling
|
|
* logic to the Import library.
|
|
*/
|
|
|
|
#ifndef AI_IOSYSTEM_H_INC
|
|
#define AI_IOSYSTEM_H_INC
|
|
|
|
#ifndef __cplusplus
|
|
#error This header requires C++ to be used.
|
|
#endif
|
|
|
|
#include <string>
|
|
|
|
#include "aiDefines.h"
|
|
|
|
namespace Assimp
|
|
{
|
|
|
|
class IOStream;
|
|
|
|
// ---------------------------------------------------------------------------
|
|
/** Interface to the file system.
|
|
*
|
|
* Derive an own implementation from this interface to supply custom file handling
|
|
* to the importer library. If you implement this interface, you also want to
|
|
* supply a custom implementation for IOStream.
|
|
*/
|
|
class ASSIMP_API IOSystem
|
|
{
|
|
public:
|
|
/** Constructor. Create an instance of your derived class and assign it to
|
|
* the #Importer instance by calling Importer::SetIOHandler().
|
|
*/
|
|
IOSystem();
|
|
|
|
/** Destructor. */
|
|
virtual ~IOSystem();
|
|
|
|
// -------------------------------------------------------------------
|
|
/** Tests for the existence of a file at the given path.
|
|
*
|
|
* @param pFile Path to the file
|
|
* @return true if there is a file with this path, else false.
|
|
*/
|
|
virtual bool Exists( const std::string& pFile) const = 0;
|
|
|
|
// -------------------------------------------------------------------
|
|
/** Returns the system specific directory separator
|
|
* @return System specific directory separator
|
|
*/
|
|
virtual std::string getOsSeparator() const = 0;
|
|
|
|
// -------------------------------------------------------------------
|
|
/** Open a new file with a given path. When the access to the file
|
|
* is finished, call Close() to release all associated resources.
|
|
*
|
|
* @param pFile Path to the file
|
|
* @param pMode Desired file I/O mode. Required are: "wb", "w", "wt",
|
|
* "rb", "r", "rt".
|
|
*
|
|
* @return New IOStream interface allowing the lib to access
|
|
* the underlying file.
|
|
* @note When implementing this class to provide custom IO handling,
|
|
* you propably have to supply an own implementation of IOStream as well.
|
|
*/
|
|
virtual IOStream* Open(
|
|
const std::string& pFile,
|
|
const std::string& pMode = std::string("rb")) = 0;
|
|
|
|
// -------------------------------------------------------------------
|
|
/** Closes the given file and releases all resources associated with it.
|
|
* @param pFile The file instance previously created by Open().
|
|
*/
|
|
virtual void Close( IOStream* pFile) = 0;
|
|
|
|
|
|
// -------------------------------------------------------------------
|
|
/** Compares two paths and check whether the point to identical files.
|
|
*
|
|
* The dummy implementation of this virtual performs a
|
|
* case-insensitive comparison of the absolute path strings.
|
|
* @param one First file
|
|
* @param second Second file
|
|
* @return true if the paths point to the same file. The file needn't
|
|
* be existing, however.
|
|
*/
|
|
virtual bool ComparePaths (const std::string& one,
|
|
const std::string& second);
|
|
};
|
|
|
|
// ----------------------------------------------------------------------------
|
|
inline IOSystem::IOSystem()
|
|
{
|
|
// empty
|
|
}
|
|
|
|
// ----------------------------------------------------------------------------
|
|
inline IOSystem::~IOSystem()
|
|
{
|
|
// empty
|
|
}
|
|
// ----------------------------------------------------------------------------
|
|
|
|
|
|
} //!ns Assimp
|
|
|
|
#endif //AI_IOSYSTEM_H_INC
|