forked from eden-emu/eden
		
	Merge pull request #5151 from comex/xx-vfs
vfs_real: When moving files or directories, don't assume file opening will succeed
This commit is contained in:
		
						commit
						9b37211cd5
					
				
					 1 changed files with 10 additions and 4 deletions
				
			
		|  | @ -133,8 +133,11 @@ VirtualFile RealVfsFilesystem::MoveFile(std::string_view old_path_, std::string_ | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         cache.erase(old_path); |         cache.erase(old_path); | ||||||
|         file->Open(new_path, "r+b"); |         if (file->Open(new_path, "r+b")) { | ||||||
|         cache.insert_or_assign(new_path, std::move(file)); |             cache.insert_or_assign(new_path, std::move(file)); | ||||||
|  |         } else { | ||||||
|  |             LOG_ERROR(Service_FS, "Failed to open path {} in order to re-cache it", new_path); | ||||||
|  |         } | ||||||
|     } else { |     } else { | ||||||
|         UNREACHABLE(); |         UNREACHABLE(); | ||||||
|         return nullptr; |         return nullptr; | ||||||
|  | @ -214,9 +217,12 @@ VirtualDir RealVfsFilesystem::MoveDirectory(std::string_view old_path_, | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         auto file = cached.lock(); |         auto file = cached.lock(); | ||||||
|         file->Open(file_new_path, "r+b"); |  | ||||||
|         cache.erase(file_old_path); |         cache.erase(file_old_path); | ||||||
|         cache.insert_or_assign(std::move(file_new_path), std::move(file)); |         if (file->Open(file_new_path, "r+b")) { | ||||||
|  |             cache.insert_or_assign(std::move(file_new_path), std::move(file)); | ||||||
|  |         } else { | ||||||
|  |             LOG_ERROR(Service_FS, "Failed to open path {} in order to re-cache it", file_new_path); | ||||||
|  |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     return OpenDirectory(new_path, Mode::ReadWrite); |     return OpenDirectory(new_path, Mode::ReadWrite); | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 bunnei
						bunnei