summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorGravatar Morph2021-09-12 12:02:39 -0400
committerGravatar GitHub2021-09-12 12:02:39 -0400
commitf0f416e85cd23c97c51f33413b4f8eed57622502 (patch)
tree8fd6687dc1f364d3bd701b0b3e92c6751b903664 /src
parentMerge pull request #6997 from ameerj/stop-emulation-confirmation (diff)
parentAddressed issues (diff)
downloadyuzu-f0f416e85cd23c97c51f33413b4f8eed57622502.tar.gz
yuzu-f0f416e85cd23c97c51f33413b4f8eed57622502.tar.xz
yuzu-f0f416e85cd23c97c51f33413b4f8eed57622502.zip
Merge pull request #6974 from ogniK5377/fs-recursive-createdir
FS: Recursively create directories for CreateDirectory
Diffstat (limited to 'src')
-rw-r--r--src/core/hle/service/filesystem/filesystem.cpp21
1 files changed, 13 insertions, 8 deletions
diff --git a/src/core/hle/service/filesystem/filesystem.cpp b/src/core/hle/service/filesystem/filesystem.cpp
index 4a9b13e45..db17d61e4 100644
--- a/src/core/hle/service/filesystem/filesystem.cpp
+++ b/src/core/hle/service/filesystem/filesystem.cpp
@@ -97,14 +97,19 @@ ResultCode VfsDirectoryServiceWrapper::DeleteFile(const std::string& path_) cons
97 97
98ResultCode VfsDirectoryServiceWrapper::CreateDirectory(const std::string& path_) const { 98ResultCode VfsDirectoryServiceWrapper::CreateDirectory(const std::string& path_) const {
99 std::string path(Common::FS::SanitizePath(path_)); 99 std::string path(Common::FS::SanitizePath(path_));
100 auto dir = GetDirectoryRelativeWrapped(backing, Common::FS::GetParentPath(path)); 100 const auto components = Common::FS::SplitPathComponents(path);
101 if (dir == nullptr || Common::FS::GetFilename(Common::FS::GetParentPath(path)).empty()) { 101 std::string relative_path;
102 dir = backing; 102 for (const auto& component : components) {
103 } 103 // Skip empty path components
104 auto new_dir = dir->CreateSubdirectory(Common::FS::GetFilename(path)); 104 if (component.empty()) {
105 if (new_dir == nullptr) { 105 continue;
106 // TODO(DarkLordZach): Find a better error code for this 106 }
107 return ResultUnknown; 107 relative_path = Common::FS::SanitizePath(relative_path + '/' + component);
108 auto new_dir = backing->CreateSubdirectory(relative_path);
109 if (new_dir == nullptr) {
110 // TODO(DarkLordZach): Find a better error code for this
111 return ResultUnknown;
112 }
108 } 113 }
109 return ResultSuccess; 114 return ResultSuccess;
110} 115}