forked from eden-emu/eden
		
	filesystem: Use a std::string_view in OpenFile()
Rather than make a full copy of the path, we can just use a string view and truncate the viewed portion of the string instead of creating a totally new truncated string.
This commit is contained in:
		
							parent
							
								
									804c35a561
								
							
						
					
					
						commit
						f1694034e8
					
				
					 1 changed files with 8 additions and 5 deletions
				
			
		|  | @ -197,13 +197,16 @@ ResultCode VfsDirectoryServiceWrapper::RenameDirectory(const std::string& src_pa | ||||||
| 
 | 
 | ||||||
| ResultVal<FileSys::VirtualFile> VfsDirectoryServiceWrapper::OpenFile(const std::string& path_, | ResultVal<FileSys::VirtualFile> VfsDirectoryServiceWrapper::OpenFile(const std::string& path_, | ||||||
|                                                                      FileSys::Mode mode) const { |                                                                      FileSys::Mode mode) const { | ||||||
|     std::string path(FileUtil::SanitizePath(path_)); |     const std::string path(FileUtil::SanitizePath(path_)); | ||||||
|     auto npath = path; |     std::string_view npath = path; | ||||||
|     while (npath.size() > 0 && (npath[0] == '/' || npath[0] == '\\')) |     while (!npath.empty() && (npath[0] == '/' || npath[0] == '\\')) { | ||||||
|         npath = npath.substr(1); |         npath.remove_prefix(1); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|     auto file = backing->GetFileRelative(npath); |     auto file = backing->GetFileRelative(npath); | ||||||
|     if (file == nullptr) |     if (file == nullptr) { | ||||||
|         return FileSys::ERROR_PATH_NOT_FOUND; |         return FileSys::ERROR_PATH_NOT_FOUND; | ||||||
|  |     } | ||||||
| 
 | 
 | ||||||
|     if (mode == FileSys::Mode::Append) { |     if (mode == FileSys::Mode::Append) { | ||||||
|         return MakeResult<FileSys::VirtualFile>( |         return MakeResult<FileSys::VirtualFile>( | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Lioncash
						Lioncash