| 
									
										
										
										
											2018-01-16 19:20:12 -08:00
										 |  |  | // Copyright 2018 yuzu emulator team
 | 
					
						
							|  |  |  | // Licensed under GPLv2 or any later version
 | 
					
						
							|  |  |  | // Refer to the license.txt file included.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #pragma once
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <memory>
 | 
					
						
							|  |  |  | #include "common/common_types.h"
 | 
					
						
							| 
									
										
										
										
											2018-07-18 21:07:11 -04:00
										 |  |  | #include "core/file_sys/directory.h"
 | 
					
						
							| 
									
										
										
										
											2018-01-16 19:20:12 -08:00
										 |  |  | #include "core/hle/result.h"
 | 
					
						
							| 
									
										
										
										
											2018-01-20 21:32:36 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-20 20:36:36 -04:00
										 |  |  | namespace FileSys { | 
					
						
							|  |  |  | class BISFactory; | 
					
						
							|  |  |  | class RegisteredCache; | 
					
						
							|  |  |  | class RomFSFactory; | 
					
						
							|  |  |  | class SaveDataFactory; | 
					
						
							|  |  |  | class SDMCFactory; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | enum class ContentRecordType : u8; | 
					
						
							| 
									
										
										
										
											2018-08-21 10:48:24 -04:00
										 |  |  | enum class Mode : u32; | 
					
						
							| 
									
										
										
										
											2018-08-20 20:36:36 -04:00
										 |  |  | enum class SaveDataSpaceId : u8; | 
					
						
							|  |  |  | enum class StorageId : u8; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | struct SaveDataDescriptor; | 
					
						
							|  |  |  | } // namespace FileSys
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-16 19:20:12 -08:00
										 |  |  | namespace Service { | 
					
						
							| 
									
										
										
										
											2018-01-20 21:32:36 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | namespace SM { | 
					
						
							|  |  |  | class ServiceManager; | 
					
						
							|  |  |  | } // namespace SM
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-16 19:20:12 -08:00
										 |  |  | namespace FileSystem { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-17 15:42:15 -04:00
										 |  |  | ResultCode RegisterRomFS(std::unique_ptr<FileSys::RomFSFactory>&& factory); | 
					
						
							|  |  |  | ResultCode RegisterSaveData(std::unique_ptr<FileSys::SaveDataFactory>&& factory); | 
					
						
							|  |  |  | ResultCode RegisterSDMC(std::unique_ptr<FileSys::SDMCFactory>&& factory); | 
					
						
							| 
									
										
										
										
											2018-08-09 20:50:10 -04:00
										 |  |  | ResultCode RegisterBIS(std::unique_ptr<FileSys::BISFactory>&& factory); | 
					
						
							| 
									
										
										
										
											2018-07-17 15:42:15 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-18 21:28:17 -04:00
										 |  |  | ResultVal<FileSys::VirtualFile> OpenRomFSCurrentProcess(); | 
					
						
							|  |  |  | ResultVal<FileSys::VirtualFile> OpenRomFS(u64 title_id, FileSys::StorageId storage_id, | 
					
						
							|  |  |  |                                           FileSys::ContentRecordType type); | 
					
						
							| 
									
										
										
										
											2018-07-18 21:07:11 -04:00
										 |  |  | ResultVal<FileSys::VirtualDir> OpenSaveData(FileSys::SaveDataSpaceId space, | 
					
						
							|  |  |  |                                             FileSys::SaveDataDescriptor save_struct); | 
					
						
							|  |  |  | ResultVal<FileSys::VirtualDir> OpenSDMC(); | 
					
						
							| 
									
										
										
										
											2018-07-17 15:42:15 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-09 20:50:10 -04:00
										 |  |  | std::shared_ptr<FileSys::RegisteredCache> GetSystemNANDContents(); | 
					
						
							|  |  |  | std::shared_ptr<FileSys::RegisteredCache> GetUserNANDContents(); | 
					
						
							| 
									
										
										
										
											2018-08-16 17:04:38 -04:00
										 |  |  | std::shared_ptr<FileSys::RegisteredCache> GetSDMCContents(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // Creates the SaveData, SDMC, and BIS Factories. Should be called once and before any function
 | 
					
						
							|  |  |  | // above is called.
 | 
					
						
							|  |  |  | void CreateFactories(const FileSys::VirtualFilesystem& vfs, bool overwrite = true); | 
					
						
							| 
									
										
										
										
											2018-03-04 13:03:58 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-08-03 11:51:48 -04:00
										 |  |  | void InstallInterfaces(SM::ServiceManager& service_manager, const FileSys::VirtualFilesystem& vfs); | 
					
						
							| 
									
										
										
										
											2018-01-16 19:20:12 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-07-18 21:07:11 -04:00
										 |  |  | // A class that wraps a VfsDirectory with methods that return ResultVal and ResultCode instead of
 | 
					
						
							|  |  |  | // pointers and booleans. This makes using a VfsDirectory with switch services much easier and
 | 
					
						
							|  |  |  | // avoids repetitive code.
 | 
					
						
							|  |  |  | class VfsDirectoryServiceWrapper { | 
					
						
							|  |  |  | public: | 
					
						
							|  |  |  |     explicit VfsDirectoryServiceWrapper(FileSys::VirtualDir backing); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * Get a descriptive name for the archive (e.g. "RomFS", "SaveData", etc.) | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     std::string GetName() const; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * Create a file specified by its path | 
					
						
							|  |  |  |      * @param path Path relative to the Archive | 
					
						
							|  |  |  |      * @param size The size of the new file, filled with zeroes | 
					
						
							|  |  |  |      * @return Result of the operation | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     ResultCode CreateFile(const std::string& path, u64 size) const; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * Delete a file specified by its path | 
					
						
							|  |  |  |      * @param path Path relative to the archive | 
					
						
							|  |  |  |      * @return Result of the operation | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     ResultCode DeleteFile(const std::string& path) const; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * Create a directory specified by its path | 
					
						
							|  |  |  |      * @param path Path relative to the archive | 
					
						
							|  |  |  |      * @return Result of the operation | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     ResultCode CreateDirectory(const std::string& path) const; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * Delete a directory specified by its path | 
					
						
							|  |  |  |      * @param path Path relative to the archive | 
					
						
							|  |  |  |      * @return Result of the operation | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     ResultCode DeleteDirectory(const std::string& path) const; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * Delete a directory specified by its path and anything under it | 
					
						
							|  |  |  |      * @param path Path relative to the archive | 
					
						
							|  |  |  |      * @return Result of the operation | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     ResultCode DeleteDirectoryRecursively(const std::string& path) const; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * Rename a File specified by its path | 
					
						
							|  |  |  |      * @param src_path Source path relative to the archive | 
					
						
							|  |  |  |      * @param dest_path Destination path relative to the archive | 
					
						
							|  |  |  |      * @return Result of the operation | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     ResultCode RenameFile(const std::string& src_path, const std::string& dest_path) const; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * Rename a Directory specified by its path | 
					
						
							|  |  |  |      * @param src_path Source path relative to the archive | 
					
						
							|  |  |  |      * @param dest_path Destination path relative to the archive | 
					
						
							|  |  |  |      * @return Result of the operation | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     ResultCode RenameDirectory(const std::string& src_path, const std::string& dest_path) const; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * Open a file specified by its path, using the specified mode | 
					
						
							|  |  |  |      * @param path Path relative to the archive | 
					
						
							|  |  |  |      * @param mode Mode to open the file with | 
					
						
							|  |  |  |      * @return Opened file, or error code | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     ResultVal<FileSys::VirtualFile> OpenFile(const std::string& path, FileSys::Mode mode) const; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * Open a directory specified by its path | 
					
						
							|  |  |  |      * @param path Path relative to the archive | 
					
						
							|  |  |  |      * @return Opened directory, or error code | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     ResultVal<FileSys::VirtualDir> OpenDirectory(const std::string& path); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * Get the free space | 
					
						
							|  |  |  |      * @return The number of free bytes in the archive | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     u64 GetFreeSpaceSize() const; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * Get the type of the specified path | 
					
						
							|  |  |  |      * @return The type of the specified path or error code | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     ResultVal<FileSys::EntryType> GetEntryType(const std::string& path) const; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | private: | 
					
						
							|  |  |  |     FileSys::VirtualDir backing; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2018-01-20 21:32:36 -05:00
										 |  |  | } // namespace FileSystem
 | 
					
						
							| 
									
										
										
										
											2018-01-16 19:20:12 -08:00
										 |  |  | } // namespace Service
 |