Merge pull request #6974 from ogniK5377/fs-recursive-createdir
FS: Recursively create directories for CreateDirectory
This commit is contained in:
		| @@ -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
	
	Block a user