|
|
@ -11,6 +11,8 @@
|
|
|
|
#include <components/esm/cellref.hpp>
|
|
|
|
#include <components/esm/cellref.hpp>
|
|
|
|
|
|
|
|
|
|
|
|
#include <components/resource/scenemanager.hpp>
|
|
|
|
#include <components/resource/scenemanager.hpp>
|
|
|
|
|
|
|
|
#include <components/vfs/manager.hpp>
|
|
|
|
|
|
|
|
#include <components/vfs/registerarchives.hpp>
|
|
|
|
|
|
|
|
|
|
|
|
#include "idtable.hpp"
|
|
|
|
#include "idtable.hpp"
|
|
|
|
#include "idtree.hpp"
|
|
|
|
#include "idtree.hpp"
|
|
|
@ -61,11 +63,18 @@ int CSMWorld::Data::count (RecordBase::State state, const CollectionBase& collec
|
|
|
|
return number;
|
|
|
|
return number;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
CSMWorld::Data::Data (ToUTF8::FromType encoding, const ResourcesManager& resourcesManager, const Fallback::Map* fallback, const boost::filesystem::path& resDir)
|
|
|
|
CSMWorld::Data::Data (ToUTF8::FromType encoding, bool fsStrict, const Files::PathContainer& dataPaths,
|
|
|
|
|
|
|
|
const std::vector<std::string>& archives, const Fallback::Map* fallback, const boost::filesystem::path& resDir)
|
|
|
|
: mEncoder (encoding), mPathgrids (mCells), mRefs (mCells),
|
|
|
|
: mEncoder (encoding), mPathgrids (mCells), mRefs (mCells),
|
|
|
|
mResourcesManager (resourcesManager), mFallbackMap(fallback),
|
|
|
|
mFallbackMap(fallback), mReader (0), mDialogue (0), mReaderIndex(1),
|
|
|
|
mReader (0), mDialogue (0), mReaderIndex(1), mResourceSystem(new Resource::ResourceSystem(resourcesManager.getVFS()))
|
|
|
|
mFsStrict(fsStrict), mDataPaths(dataPaths), mArchives(archives)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
|
|
|
|
mVFS.reset(new VFS::Manager(mFsStrict));
|
|
|
|
|
|
|
|
VFS::registerArchives(mVFS.get(), Files::Collections(mDataPaths, !mFsStrict), mArchives, true);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
mResourcesManager.setVFS(mVFS.get());
|
|
|
|
|
|
|
|
mResourceSystem.reset(new Resource::ResourceSystem(mVFS.get()));
|
|
|
|
|
|
|
|
|
|
|
|
mResourceSystem->getSceneManager()->setShaderPath((resDir / "shaders").string());
|
|
|
|
mResourceSystem->getSceneManager()->setShaderPath((resDir / "shaders").string());
|
|
|
|
|
|
|
|
|
|
|
|
int index = 0;
|
|
|
|
int index = 0;
|
|
|
@ -1215,6 +1224,43 @@ std::vector<std::string> CSMWorld::Data::getIds (bool listDeleted) const
|
|
|
|
return ids;
|
|
|
|
return ids;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void CSMWorld::Data::assetsChanged()
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
mVFS.get()->reset();
|
|
|
|
|
|
|
|
VFS::registerArchives(mVFS.get(), Files::Collections(mDataPaths, !mFsStrict), mArchives, true);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
const UniversalId assetTableIds[] = {
|
|
|
|
|
|
|
|
UniversalId::Type_Meshes,
|
|
|
|
|
|
|
|
UniversalId::Type_Icons,
|
|
|
|
|
|
|
|
UniversalId::Type_Musics,
|
|
|
|
|
|
|
|
UniversalId::Type_SoundsRes,
|
|
|
|
|
|
|
|
UniversalId::Type_Textures,
|
|
|
|
|
|
|
|
UniversalId::Type_Videos
|
|
|
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
size_t numAssetTables = sizeof(assetTableIds) / sizeof(UniversalId);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
for (size_t i = 0; i < numAssetTables; ++i)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
ResourceTable* table = static_cast<ResourceTable*>(getTableModel(assetTableIds[i]));
|
|
|
|
|
|
|
|
table->beginReset();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Trigger recreation
|
|
|
|
|
|
|
|
mResourcesManager.recreateResources();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
for (size_t i = 0; i < numAssetTables; ++i)
|
|
|
|
|
|
|
|
{
|
|
|
|
|
|
|
|
ResourceTable* table = static_cast<ResourceTable*>(getTableModel(assetTableIds[i]));
|
|
|
|
|
|
|
|
table->endReset();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Get rid of potentially old cached assets
|
|
|
|
|
|
|
|
mResourceSystem->clearCache();
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
emit assetTablesChanged();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void CSMWorld::Data::dataChanged (const QModelIndex& topLeft, const QModelIndex& bottomRight)
|
|
|
|
void CSMWorld::Data::dataChanged (const QModelIndex& topLeft, const QModelIndex& bottomRight)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if (topLeft.column()<=0)
|
|
|
|
if (topLeft.column()<=0)
|
|
|
@ -1228,7 +1274,7 @@ void CSMWorld::Data::rowsChanged (const QModelIndex& parent, int start, int end)
|
|
|
|
|
|
|
|
|
|
|
|
const VFS::Manager* CSMWorld::Data::getVFS() const
|
|
|
|
const VFS::Manager* CSMWorld::Data::getVFS() const
|
|
|
|
{
|
|
|
|
{
|
|
|
|
return mResourcesManager.getVFS();
|
|
|
|
return mVFS.get();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
const Fallback::Map* CSMWorld::Data::getFallbackMap() const
|
|
|
|
const Fallback::Map* CSMWorld::Data::getFallbackMap() const
|
|
|
|