1
0
Fork 0
mirror of https://github.com/OpenMW/openmw.git synced 2025-01-16 19:59:55 +00:00
openmw/components/vfs/manager.cpp

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

93 lines
2.6 KiB
C++
Raw Normal View History

#include "manager.hpp"
#include <algorithm>
2024-01-16 22:53:55 +00:00
#include <cassert>
#include <stdexcept>
#include <components/files/conversion.hpp>
#include <components/misc/strings/lower.hpp>
#include <components/vfs/recursivedirectoryiterator.hpp>
#include "archive.hpp"
#include "file.hpp"
2023-05-31 21:11:03 +00:00
#include "pathutil.hpp"
#include "recursivedirectoryiterator.hpp"
namespace VFS
{
Manager::Manager() = default;
Manager::~Manager() = default;
void Manager::reset()
{
mIndex.clear();
mArchives.clear();
}
void Manager::addArchive(std::unique_ptr<Archive>&& archive)
{
mArchives.push_back(std::move(archive));
}
void Manager::buildIndex()
{
mIndex.clear();
for (const auto& archive : mArchives)
2023-05-31 21:11:03 +00:00
archive->listResources(mIndex);
}
Files::IStreamPtr Manager::get(const Path::Normalized& name) const
{
return getNormalized(name);
2015-03-26 17:02:51 +00:00
}
2023-12-17 14:20:48 +00:00
Files::IStreamPtr Manager::getNormalized(std::string_view normalizedName) const
2015-03-26 17:02:51 +00:00
{
2024-01-16 22:53:55 +00:00
assert(Path::isNormalized(normalizedName));
2023-12-17 14:20:48 +00:00
const auto found = mIndex.find(normalizedName);
if (found == mIndex.end())
2023-12-17 14:20:48 +00:00
throw std::runtime_error("Resource '" + std::string(normalizedName) + "' not found");
return found->second->open();
}
bool Manager::exists(const Path::Normalized& name) const
{
return mIndex.find(name) != mIndex.end();
2015-03-26 17:02:51 +00:00
}
std::string Manager::getArchive(const Path::Normalized& name) const
2020-12-29 20:45:59 +00:00
{
2020-12-30 09:35:51 +00:00
for (auto it = mArchives.rbegin(); it != mArchives.rend(); ++it)
2020-12-29 20:45:59 +00:00
{
if ((*it)->contains(name))
2020-12-30 09:35:51 +00:00
return (*it)->getDescription();
2020-12-29 20:45:59 +00:00
}
return {};
}
std::filesystem::path Manager::getAbsoluteFileName(const std::filesystem::path& name) const
2022-05-14 01:58:00 +00:00
{
std::string normalized = Files::pathToUnicodeString(name);
2023-05-31 21:11:03 +00:00
Path::normalizeFilenameInPlace(normalized);
2022-05-14 01:58:00 +00:00
const auto found = mIndex.find(normalized);
2022-05-14 01:58:00 +00:00
if (found == mIndex.end())
throw std::runtime_error("Resource '" + normalized + "' not found");
return found->second->getPath();
2022-05-14 01:58:00 +00:00
}
RecursiveDirectoryRange Manager::getRecursiveDirectoryIterator(std::string_view path) const
{
if (path.empty())
return { mIndex.begin(), mIndex.end() };
2023-05-31 21:11:03 +00:00
std::string normalized = Path::normalizeFilename(path);
const auto it = mIndex.lower_bound(normalized);
if (it == mIndex.end() || !it->first.view().starts_with(normalized))
return { it, it };
++normalized.back();
return { it, mIndex.lower_bound(normalized) };
}
}