Try to get filesystem to compile
This commit is contained in:
@@ -4,7 +4,7 @@
|
||||
|
||||
#pragma once
|
||||
|
||||
#if _MSC_VER || (__GNUC__ > 8)
|
||||
#if _MSC_VER
|
||||
#include <filesystem>
|
||||
namespace filesystem = std::filesystem;
|
||||
#else
|
||||
|
||||
@@ -23,7 +23,8 @@ bool OffsetVfsFile::Resize(size_t new_size) {
|
||||
size = new_size;
|
||||
} else {
|
||||
auto res = file->Resize(offset + new_size);
|
||||
if (!res) return false;
|
||||
if (!res)
|
||||
return false;
|
||||
size = new_size;
|
||||
}
|
||||
|
||||
|
||||
@@ -69,6 +69,9 @@ bool RealVfsFile::Rename(const std::string& name) {
|
||||
RealVfsDirectory::RealVfsDirectory(const filesystem::path& path_, filesystem::perms perms_)
|
||||
: path(path_), perms(perms_) {
|
||||
path.make_preferred();
|
||||
if (!filesystem::exists(path) &&
|
||||
(perms_ & filesystem::perms::owner_write) != filesystem::perms::none)
|
||||
filesystem::create_directory(path);
|
||||
for (const auto& entry : filesystem::directory_iterator(path)) {
|
||||
if (filesystem::is_directory(entry.path()))
|
||||
subdirectories.emplace_back(std::make_shared<RealVfsDirectory>(entry.path(), perms));
|
||||
|
||||
@@ -5,10 +5,13 @@
|
||||
#include "boost/container/flat_map.hpp"
|
||||
#include "common/common_paths.h"
|
||||
#include "common/file_util.h"
|
||||
#include "core/core.h"
|
||||
#include "core/file_sys/errors.h"
|
||||
#include "core/file_sys/filesystem.h"
|
||||
#include "core/file_sys/vfs.h"
|
||||
#include "core/file_sys/vfs_offset.h"
|
||||
#include "core/file_sys/vfs_real.h"
|
||||
#include "core/hle/kernel/process.h"
|
||||
#include "core/hle/service/filesystem/filesystem.h"
|
||||
#include "core/hle/service/filesystem/fsp_srv.h"
|
||||
|
||||
@@ -96,7 +99,7 @@ ResultVal<v_file> VfsDirectoryServiceWrapper::OpenFile(const std::string& path,
|
||||
FileSys::Mode mode) const {
|
||||
auto file = backing->GetFileRelative(filesystem::path(path));
|
||||
if (file == nullptr)
|
||||
return ResultCode(-1);
|
||||
return FileSys::ERROR_FILE_NOT_FOUND;
|
||||
if (mode == FileSys::Mode::Append)
|
||||
return MakeResult<v_file>(
|
||||
std::make_shared<FileSys::OffsetVfsFile>(file, 0, file->GetSize()));
|
||||
@@ -135,22 +138,36 @@ ResultVal<FileSys::EntryType> VfsDirectoryServiceWrapper::GetEntryType(
|
||||
return ResultCode(-1);
|
||||
}
|
||||
|
||||
struct SaveDataDeferredFilesystem : DeferredFilesystem {
|
||||
protected:
|
||||
v_dir CreateFilesystem() override {
|
||||
u64 title_id = Core::CurrentProcess()->program_id;
|
||||
// TODO(DarkLordZach): Users
|
||||
u32 user_id = 0;
|
||||
std::string nand_directory = fmt::format(
|
||||
"{}save/{:016X}/{:08X}/", FileUtil::GetUserPath(D_NAND_IDX), title_id, user_id);
|
||||
|
||||
auto savedata =
|
||||
std::make_shared<FileSys::RealVfsDirectory>(nand_directory, filesystem::perms::all);
|
||||
return savedata;
|
||||
}
|
||||
};
|
||||
|
||||
/**
|
||||
* Map of registered file systems, identified by type. Once an file system is registered here, it
|
||||
* is never removed until UnregisterFileSystems is called.
|
||||
*/
|
||||
static boost::container::flat_map<Type, v_dir> filesystem_map;
|
||||
static boost::container::flat_map<Type, std::unique_ptr<DeferredFilesystem>> filesystem_map;
|
||||
static v_file filesystem_romfs;
|
||||
|
||||
ResultCode RegisterFileSystem(v_dir factory, Type type) {
|
||||
auto result = filesystem_map.emplace(type, factory);
|
||||
ResultCode RegisterFileSystem(std::unique_ptr<DeferredFilesystem>&& factory, Type type) {
|
||||
auto result = filesystem_map.emplace(type, std::move(factory));
|
||||
|
||||
bool inserted = result.second;
|
||||
ASSERT_MSG(inserted, "Tried to register more than one system with same id code");
|
||||
|
||||
auto& filesystem = result.first->second;
|
||||
LOG_DEBUG(Service_FS, "Registered file system {} with id code 0x{:08X}", filesystem->GetName(),
|
||||
static_cast<u32>(type));
|
||||
NGLOG_DEBUG(Service_FS, "Registered file system with id code 0x{:08X}", static_cast<u32>(type));
|
||||
return RESULT_SUCCESS;
|
||||
}
|
||||
|
||||
@@ -173,7 +190,7 @@ ResultVal<v_dir> OpenFileSystem(Type type) {
|
||||
return ResultCode(-1);
|
||||
}
|
||||
|
||||
return MakeResult(itr->second);
|
||||
return MakeResult(itr->second->Get());
|
||||
}
|
||||
|
||||
ResultVal<v_file> OpenRomFS() {
|
||||
@@ -191,7 +208,8 @@ ResultCode FormatFileSystem(Type type) {
|
||||
return ResultCode(-1);
|
||||
}
|
||||
|
||||
return itr->second->GetParentDirectory()->DeleteSubdirectory(itr->second->GetName())
|
||||
return itr->second->Get()->GetParentDirectory()->DeleteSubdirectory(
|
||||
itr->second->Get()->GetName())
|
||||
? RESULT_SUCCESS
|
||||
: ResultCode(-1);
|
||||
}
|
||||
@@ -199,15 +217,11 @@ ResultCode FormatFileSystem(Type type) {
|
||||
void RegisterFileSystems() {
|
||||
filesystem_map.clear();
|
||||
|
||||
std::string nand_directory = FileUtil::GetUserPath(D_NAND_IDX);
|
||||
std::string sd_directory = FileUtil::GetUserPath(D_SDMC_IDX);
|
||||
auto sdcard = std::make_shared<FileSys::RealVfsDirectory>(sd_directory, filesystem::perms::all);
|
||||
RegisterFileSystem(std::make_unique<DeferredFilesystem>(sdcard), Type::SDMC);
|
||||
|
||||
auto savedata =
|
||||
std::make_unique<FileSys::RealVfsDirectory>(nand_directory, filesystem::perms::all);
|
||||
RegisterFileSystem(std::move(savedata), Type::SaveData);
|
||||
|
||||
auto sdcard = std::make_unique<FileSys::RealVfsDirectory>(sd_directory, filesystem::perms::all);
|
||||
RegisterFileSystem(std::move(sdcard), Type::SDMC);
|
||||
RegisterFileSystem(std::make_unique<SaveDataDeferredFilesystem>(), Type::SaveData);
|
||||
}
|
||||
|
||||
void InstallInterfaces(SM::ServiceManager& service_manager) {
|
||||
|
||||
@@ -122,12 +122,33 @@ public:
|
||||
ResultVal<FileSys::EntryType> GetEntryType(const std::string& path) const;
|
||||
};
|
||||
|
||||
struct DeferredFilesystem {
|
||||
DeferredFilesystem(){};
|
||||
|
||||
explicit DeferredFilesystem(v_dir vfs_directory) : fs(vfs_directory) {}
|
||||
|
||||
v_dir Get() {
|
||||
if (fs == nullptr)
|
||||
fs = CreateFilesystem();
|
||||
|
||||
return fs;
|
||||
}
|
||||
|
||||
protected:
|
||||
virtual v_dir CreateFilesystem() {
|
||||
return fs;
|
||||
}
|
||||
|
||||
private:
|
||||
v_dir fs;
|
||||
};
|
||||
|
||||
/**
|
||||
* Registers a FileSystem, instances of which can later be opened using its IdCode.
|
||||
* @param factory FileSystem backend interface to use
|
||||
* @param type Type used to access this type of FileSystem
|
||||
*/
|
||||
ResultCode RegisterFileSystem(v_dir fs, Type type);
|
||||
ResultCode RegisterFileSystem(std::unique_ptr<DeferredFilesystem>&& fs, Type type);
|
||||
|
||||
ResultCode RegisterRomFS(v_file fs);
|
||||
|
||||
|
||||
Reference in New Issue
Block a user