mirror of
https://gitlab.com/OpenMW/openmw.git
synced 2025-01-01 03:21:41 +00:00
d147d1d250
It should be initialize for each created archive anyway. There is no good reason to have additional complexity for lazy initialization. And it helps to catch problems with specific directory when it's added to the VFS not when all are added and index is built.
45 lines
964 B
C++
45 lines
964 B
C++
#ifndef OPENMW_COMPONENTS_RESOURCE_FILESYSTEMARCHIVE_H
|
|
#define OPENMW_COMPONENTS_RESOURCE_FILESYSTEMARCHIVE_H
|
|
|
|
#include "archive.hpp"
|
|
#include "file.hpp"
|
|
|
|
#include <filesystem>
|
|
#include <string>
|
|
|
|
namespace VFS
|
|
{
|
|
|
|
class FileSystemArchiveFile : public File
|
|
{
|
|
public:
|
|
FileSystemArchiveFile(const std::filesystem::path& path);
|
|
|
|
Files::IStreamPtr open() override;
|
|
|
|
std::filesystem::path getPath() override { return mPath; }
|
|
|
|
private:
|
|
std::filesystem::path mPath;
|
|
};
|
|
|
|
class FileSystemArchive : public Archive
|
|
{
|
|
public:
|
|
FileSystemArchive(const std::filesystem::path& path);
|
|
|
|
void listResources(FileMap& out) override;
|
|
|
|
bool contains(Path::NormalizedView file) const override;
|
|
|
|
std::string getDescription() const override;
|
|
|
|
private:
|
|
std::map<VFS::Path::Normalized, FileSystemArchiveFile, std::less<>> mIndex;
|
|
std::filesystem::path mPath;
|
|
};
|
|
|
|
}
|
|
|
|
#endif
|