mirror of
https://gitlab.com/OpenMW/openmw.git
synced 2025-01-18 04:10:06 +00:00
8c4b12a603
Added ability to reset a VFS::Manager. Removed ability to rebuild the index for a VFS::Manager. Moved VFS creation to CSM::Data.
129 lines
4.1 KiB
C++
129 lines
4.1 KiB
C++
#ifndef CSM_DOC_DOCUMENTMGR_H
|
|
#define CSM_DOC_DOCUMENTMGR_H
|
|
|
|
#include <vector>
|
|
#include <string>
|
|
|
|
#include <boost/filesystem/path.hpp>
|
|
|
|
#include <QObject>
|
|
#include <QThread>
|
|
|
|
#include <components/to_utf8/to_utf8.hpp>
|
|
#include <components/fallback/fallback.hpp>
|
|
#include <components/files/multidircollection.hpp>
|
|
|
|
#include "loader.hpp"
|
|
|
|
namespace VFS
|
|
{
|
|
class Manager;
|
|
}
|
|
|
|
namespace Files
|
|
{
|
|
struct ConfigurationManager;
|
|
}
|
|
|
|
namespace CSMDoc
|
|
{
|
|
class Document;
|
|
|
|
class DocumentManager : public QObject
|
|
{
|
|
Q_OBJECT
|
|
|
|
std::vector<Document *> mDocuments;
|
|
const Files::ConfigurationManager& mConfiguration;
|
|
QThread mLoaderThread;
|
|
Loader mLoader;
|
|
ToUTF8::FromType mEncoding;
|
|
std::vector<std::string> mBlacklistedScripts;
|
|
|
|
boost::filesystem::path mResDir;
|
|
Fallback::Map mFallbackMap;
|
|
|
|
bool mFsStrict;
|
|
Files::PathContainer mDataPaths;
|
|
std::vector<std::string> mArchives;
|
|
|
|
DocumentManager (const DocumentManager&);
|
|
DocumentManager& operator= (const DocumentManager&);
|
|
|
|
public:
|
|
|
|
DocumentManager (const Files::ConfigurationManager& configuration);
|
|
|
|
~DocumentManager();
|
|
|
|
void addDocument (const std::vector< boost::filesystem::path >& files,
|
|
const boost::filesystem::path& savePath, bool new_);
|
|
///< \param new_ Do not load the last content file in \a files and instead create in an
|
|
/// appropriate way.
|
|
|
|
/// Create a new document. The ownership of the created document is transferred to
|
|
/// the calling function. The DocumentManager does not manage it. Loading has not
|
|
/// taken place at the point when the document is returned.
|
|
///
|
|
/// \param new_ Do not load the last content file in \a files and instead create in an
|
|
/// appropriate way.
|
|
Document *makeDocument (const std::vector< boost::filesystem::path >& files,
|
|
const boost::filesystem::path& savePath, bool new_);
|
|
|
|
void setResourceDir (const boost::filesystem::path& parResDir);
|
|
|
|
void setFallbackMap (const std::map<std::string, std::string>& fallbackMap);
|
|
|
|
void setEncoding (ToUTF8::FromType encoding);
|
|
|
|
void setBlacklistedScripts (const std::vector<std::string>& scriptIds);
|
|
|
|
/// Sets the file data that gets passed to newly created documents.
|
|
void setFileData(bool strict, const Files::PathContainer& dataPaths, const std::vector<std::string>& archives);
|
|
|
|
bool isEmpty();
|
|
|
|
private slots:
|
|
|
|
void documentLoaded (Document *document);
|
|
///< The ownership of \a document is not transferred.
|
|
|
|
void documentNotLoaded (Document *document, const std::string& error);
|
|
///< Document load has been interrupted either because of a call to abortLoading
|
|
/// or a problem during loading). In the former case error will be an empty string.
|
|
|
|
public slots:
|
|
|
|
void removeDocument (CSMDoc::Document *document);
|
|
///< Emits the lastDocumentDeleted signal, if applicable.
|
|
|
|
/// Hand over document to *this. The ownership is transferred. The DocumentManager
|
|
/// will initiate the load procedure, if necessary
|
|
void insertDocument (CSMDoc::Document *document);
|
|
|
|
signals:
|
|
|
|
void documentAdded (CSMDoc::Document *document);
|
|
|
|
void documentAboutToBeRemoved (CSMDoc::Document *document);
|
|
|
|
void loadRequest (CSMDoc::Document *document);
|
|
|
|
void lastDocumentDeleted();
|
|
|
|
void loadingStopped (CSMDoc::Document *document, bool completed,
|
|
const std::string& error);
|
|
|
|
void nextStage (CSMDoc::Document *document, const std::string& name,
|
|
int totalRecords);
|
|
|
|
void nextRecord (CSMDoc::Document *document, int records);
|
|
|
|
void cancelLoading (CSMDoc::Document *document);
|
|
|
|
void loadMessage (CSMDoc::Document *document, const std::string& message);
|
|
};
|
|
}
|
|
|
|
#endif
|