diff options
| author | 2018-04-24 10:56:05 +0300 | |
|---|---|---|
| committer | 2018-04-24 10:56:05 +0300 | |
| commit | a0179e5ca5bc54491f03ff60d2f971197eb03e88 (patch) | |
| tree | 99ba0561c6fe429169a40e76a70db7b3f99a71ee /src/core/hle | |
| parent | Merge pull request #379 from Subv/multi_buffers (diff) | |
| download | yuzu-a0179e5ca5bc54491f03ff60d2f971197eb03e88.tar.gz yuzu-a0179e5ca5bc54491f03ff60d2f971197eb03e88.tar.xz yuzu-a0179e5ca5bc54491f03ff60d2f971197eb03e88.zip | |
Service/FS: implement IFileSystem::RenameFile
Diffstat (limited to 'src/core/hle')
| -rw-r--r-- | src/core/hle/service/filesystem/fsp_srv.cpp | 22 |
1 files changed, 21 insertions, 1 deletions
diff --git a/src/core/hle/service/filesystem/fsp_srv.cpp b/src/core/hle/service/filesystem/fsp_srv.cpp index 2f476c869..02e270f26 100644 --- a/src/core/hle/service/filesystem/fsp_srv.cpp +++ b/src/core/hle/service/filesystem/fsp_srv.cpp | |||
| @@ -239,7 +239,7 @@ public: | |||
| 239 | {2, &IFileSystem::CreateDirectory, "CreateDirectory"}, | 239 | {2, &IFileSystem::CreateDirectory, "CreateDirectory"}, |
| 240 | {3, nullptr, "DeleteDirectory"}, | 240 | {3, nullptr, "DeleteDirectory"}, |
| 241 | {4, nullptr, "DeleteDirectoryRecursively"}, | 241 | {4, nullptr, "DeleteDirectoryRecursively"}, |
| 242 | {5, nullptr, "RenameFile"}, | 242 | {5, &IFileSystem::RenameFile, "RenameFile"}, |
| 243 | {6, nullptr, "RenameDirectory"}, | 243 | {6, nullptr, "RenameDirectory"}, |
| 244 | {7, &IFileSystem::GetEntryType, "GetEntryType"}, | 244 | {7, &IFileSystem::GetEntryType, "GetEntryType"}, |
| 245 | {8, &IFileSystem::OpenFile, "OpenFile"}, | 245 | {8, &IFileSystem::OpenFile, "OpenFile"}, |
| @@ -300,6 +300,26 @@ public: | |||
| 300 | rb.Push(backend->CreateDirectory(name)); | 300 | rb.Push(backend->CreateDirectory(name)); |
| 301 | } | 301 | } |
| 302 | 302 | ||
| 303 | void RenameFile(Kernel::HLERequestContext& ctx) { | ||
| 304 | IPC::RequestParser rp{ctx}; | ||
| 305 | |||
| 306 | std::vector<u8> buffer; | ||
| 307 | buffer.resize(ctx.BufferDescriptorX()[0].Size()); | ||
| 308 | Memory::ReadBlock(ctx.BufferDescriptorX()[0].Address(), buffer.data(), buffer.size()); | ||
| 309 | auto end = std::find(buffer.begin(), buffer.end(), '\0'); | ||
| 310 | std::string src_name(buffer.begin(), end); | ||
| 311 | |||
| 312 | buffer.resize(ctx.BufferDescriptorX()[1].Size()); | ||
| 313 | Memory::ReadBlock(ctx.BufferDescriptorX()[1].Address(), buffer.data(), buffer.size()); | ||
| 314 | end = std::find(buffer.begin(), buffer.end(), '\0'); | ||
| 315 | std::string dst_name(buffer.begin(), end); | ||
| 316 | |||
| 317 | LOG_DEBUG(Service_FS, "called file '%s' to file '%s'", src_name.c_str(), dst_name.c_str()); | ||
| 318 | |||
| 319 | IPC::ResponseBuilder rb{ctx, 2}; | ||
| 320 | rb.Push(backend->RenameFile(src_name, dst_name)); | ||
| 321 | } | ||
| 322 | |||
| 303 | void OpenFile(Kernel::HLERequestContext& ctx) { | 323 | void OpenFile(Kernel::HLERequestContext& ctx) { |
| 304 | IPC::RequestParser rp{ctx}; | 324 | IPC::RequestParser rp{ctx}; |
| 305 | 325 | ||