FS: Recursively create directories for CreateDirectory
Originally we only created the parent directory, this caused issues for creating directories which also contained subdirectories, eg `/Folder1/Folder2` This allows the ultimate mod manager homebrew to at least boot
This commit is contained in:
parent
b2572a56d3
commit
0b891c9245
|
@ -97,14 +97,19 @@ ResultCode VfsDirectoryServiceWrapper::DeleteFile(const std::string& path_) cons
|
||||||
|
|
||||||
ResultCode VfsDirectoryServiceWrapper::CreateDirectory(const std::string& path_) const {
|
ResultCode VfsDirectoryServiceWrapper::CreateDirectory(const std::string& path_) const {
|
||||||
std::string path(Common::FS::SanitizePath(path_));
|
std::string path(Common::FS::SanitizePath(path_));
|
||||||
auto dir = GetDirectoryRelativeWrapped(backing, Common::FS::GetParentPath(path));
|
const auto components = Common::FS::SplitPathComponents(path);
|
||||||
if (dir == nullptr || Common::FS::GetFilename(Common::FS::GetParentPath(path)).empty()) {
|
std::string relative_path = "";
|
||||||
dir = backing;
|
for (const auto& component : components) {
|
||||||
}
|
// Skip empty path components
|
||||||
auto new_dir = dir->CreateSubdirectory(Common::FS::GetFilename(path));
|
if (component.empty()) {
|
||||||
if (new_dir == nullptr) {
|
continue;
|
||||||
// TODO(DarkLordZach): Find a better error code for this
|
}
|
||||||
return ResultUnknown;
|
relative_path = Common::FS::SanitizePath(relative_path + '/' + component);
|
||||||
|
auto new_dir = backing->CreateSubdirectory(relative_path);
|
||||||
|
if (new_dir == nullptr) {
|
||||||
|
// TODO(DarkLordZach): Find a better error code for this
|
||||||
|
return ResultUnknown;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
return ResultSuccess;
|
return ResultSuccess;
|
||||||
}
|
}
|
||||||
|
|
Reference in New Issue