Try to get filesystem to compile

This commit is contained in:
Zach Hilman
2018-06-27 11:12:17 -04:00
parent 80f2c08f31
commit 666892034f
5 changed files with 57 additions and 18 deletions

View File

@@ -4,7 +4,7 @@
#pragma once #pragma once
#if _MSC_VER || (__GNUC__ > 8) #if _MSC_VER
#include <filesystem> #include <filesystem>
namespace filesystem = std::filesystem; namespace filesystem = std::filesystem;
#else #else

View File

@@ -23,7 +23,8 @@ bool OffsetVfsFile::Resize(size_t new_size) {
size = new_size; size = new_size;
} else { } else {
auto res = file->Resize(offset + new_size); auto res = file->Resize(offset + new_size);
if (!res) return false; if (!res)
return false;
size = new_size; size = new_size;
} }

View File

@@ -69,6 +69,9 @@ bool RealVfsFile::Rename(const std::string& name) {
RealVfsDirectory::RealVfsDirectory(const filesystem::path& path_, filesystem::perms perms_) RealVfsDirectory::RealVfsDirectory(const filesystem::path& path_, filesystem::perms perms_)
: path(path_), perms(perms_) { : path(path_), perms(perms_) {
path.make_preferred(); 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)) { for (const auto& entry : filesystem::directory_iterator(path)) {
if (filesystem::is_directory(entry.path())) if (filesystem::is_directory(entry.path()))
subdirectories.emplace_back(std::make_shared<RealVfsDirectory>(entry.path(), perms)); subdirectories.emplace_back(std::make_shared<RealVfsDirectory>(entry.path(), perms));

View File

@@ -5,10 +5,13 @@
#include "boost/container/flat_map.hpp" #include "boost/container/flat_map.hpp"
#include "common/common_paths.h" #include "common/common_paths.h"
#include "common/file_util.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/filesystem.h"
#include "core/file_sys/vfs.h" #include "core/file_sys/vfs.h"
#include "core/file_sys/vfs_offset.h" #include "core/file_sys/vfs_offset.h"
#include "core/file_sys/vfs_real.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/filesystem.h"
#include "core/hle/service/filesystem/fsp_srv.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 { FileSys::Mode mode) const {
auto file = backing->GetFileRelative(filesystem::path(path)); auto file = backing->GetFileRelative(filesystem::path(path));
if (file == nullptr) if (file == nullptr)
return ResultCode(-1); return FileSys::ERROR_FILE_NOT_FOUND;
if (mode == FileSys::Mode::Append) if (mode == FileSys::Mode::Append)
return MakeResult<v_file>( return MakeResult<v_file>(
std::make_shared<FileSys::OffsetVfsFile>(file, 0, file->GetSize())); std::make_shared<FileSys::OffsetVfsFile>(file, 0, file->GetSize()));
@@ -135,22 +138,36 @@ ResultVal<FileSys::EntryType> VfsDirectoryServiceWrapper::GetEntryType(
return ResultCode(-1); 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 * Map of registered file systems, identified by type. Once an file system is registered here, it
* is never removed until UnregisterFileSystems is called. * 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; static v_file filesystem_romfs;
ResultCode RegisterFileSystem(v_dir factory, Type type) { ResultCode RegisterFileSystem(std::unique_ptr<DeferredFilesystem>&& factory, Type type) {
auto result = filesystem_map.emplace(type, factory); auto result = filesystem_map.emplace(type, std::move(factory));
bool inserted = result.second; bool inserted = result.second;
ASSERT_MSG(inserted, "Tried to register more than one system with same id code"); ASSERT_MSG(inserted, "Tried to register more than one system with same id code");
auto& filesystem = result.first->second; auto& filesystem = result.first->second;
LOG_DEBUG(Service_FS, "Registered file system {} with id code 0x{:08X}", filesystem->GetName(), NGLOG_DEBUG(Service_FS, "Registered file system with id code 0x{:08X}", static_cast<u32>(type));
static_cast<u32>(type));
return RESULT_SUCCESS; return RESULT_SUCCESS;
} }
@@ -173,7 +190,7 @@ ResultVal<v_dir> OpenFileSystem(Type type) {
return ResultCode(-1); return ResultCode(-1);
} }
return MakeResult(itr->second); return MakeResult(itr->second->Get());
} }
ResultVal<v_file> OpenRomFS() { ResultVal<v_file> OpenRomFS() {
@@ -191,7 +208,8 @@ ResultCode FormatFileSystem(Type type) {
return ResultCode(-1); return ResultCode(-1);
} }
return itr->second->GetParentDirectory()->DeleteSubdirectory(itr->second->GetName()) return itr->second->Get()->GetParentDirectory()->DeleteSubdirectory(
itr->second->Get()->GetName())
? RESULT_SUCCESS ? RESULT_SUCCESS
: ResultCode(-1); : ResultCode(-1);
} }
@@ -199,15 +217,11 @@ ResultCode FormatFileSystem(Type type) {
void RegisterFileSystems() { void RegisterFileSystems() {
filesystem_map.clear(); filesystem_map.clear();
std::string nand_directory = FileUtil::GetUserPath(D_NAND_IDX);
std::string sd_directory = FileUtil::GetUserPath(D_SDMC_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 = RegisterFileSystem(std::make_unique<SaveDataDeferredFilesystem>(), Type::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);
} }
void InstallInterfaces(SM::ServiceManager& service_manager) { void InstallInterfaces(SM::ServiceManager& service_manager) {

View File

@@ -122,12 +122,33 @@ public:
ResultVal<FileSys::EntryType> GetEntryType(const std::string& path) const; 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. * Registers a FileSystem, instances of which can later be opened using its IdCode.
* @param factory FileSystem backend interface to use * @param factory FileSystem backend interface to use
* @param type Type used to access this type of FileSystem * @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); ResultCode RegisterRomFS(v_file fs);