| 
									
										
										
										
											2014-06-27 16:18:56 -04:00
										 |  |  | // Copyright 2014 Citra Emulator Project
 | 
					
						
							| 
									
										
										
										
											2014-12-16 21:38:14 -08:00
										 |  |  | // Licensed under GPLv2 or any later version
 | 
					
						
							| 
									
										
										
										
											2014-06-27 16:18:56 -04:00
										 |  |  | // Refer to the license.txt file included.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #pragma once
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-12 00:42:59 +02:00
										 |  |  | #include <memory>
 | 
					
						
							| 
									
										
										
										
											2015-05-06 02:15:46 -03:00
										 |  |  | #include <string>
 | 
					
						
							|  |  |  | #include <utility>
 | 
					
						
							|  |  |  | #include <vector>
 | 
					
						
							|  |  |  | #include "common/bit_field.h"
 | 
					
						
							| 
									
										
										
										
											2014-06-27 16:18:56 -04:00
										 |  |  | #include "common/common_types.h"
 | 
					
						
							| 
									
										
										
										
											2016-03-03 13:05:50 -05:00
										 |  |  | #include "common/swap.h"
 | 
					
						
							| 
									
										
										
										
											2015-05-06 02:15:46 -03:00
										 |  |  | #include "core/hle/result.h"
 | 
					
						
							| 
									
										
										
										
											2014-06-27 16:18:56 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | namespace FileSys { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-05-06 02:15:46 -03:00
										 |  |  | class FileBackend; | 
					
						
							|  |  |  | class DirectoryBackend; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-11-10 14:36:32 -08:00
										 |  |  | // Path string type
 | 
					
						
							| 
									
										
										
										
											2016-09-18 18:01:46 -07:00
										 |  |  | enum LowPathType : u32 { | 
					
						
							|  |  |  |     Invalid = 0, | 
					
						
							|  |  |  |     Empty = 1, | 
					
						
							|  |  |  |     Binary = 2, | 
					
						
							|  |  |  |     Char = 3, | 
					
						
							|  |  |  |     Wchar = 4, | 
					
						
							|  |  |  | }; | 
					
						
							| 
									
										
										
										
											2014-11-10 14:36:32 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-12 00:42:59 +02:00
										 |  |  | union Mode { | 
					
						
							|  |  |  |     u32 hex; | 
					
						
							|  |  |  |     BitField<0, 1, u32> read_flag; | 
					
						
							|  |  |  |     BitField<1, 1, u32> write_flag; | 
					
						
							|  |  |  |     BitField<2, 1, u32> create_flag; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-11-10 14:36:32 -08:00
										 |  |  | class Path { | 
					
						
							|  |  |  | public: | 
					
						
							| 
									
										
										
										
											2016-09-18 18:01:46 -07:00
										 |  |  |     Path() : type(Invalid) {} | 
					
						
							|  |  |  |     Path(const char* path) : type(Char), string(path) {} | 
					
						
							|  |  |  |     Path(std::vector<u8> binary_data) : type(Binary), binary(std::move(binary_data)) {} | 
					
						
							| 
									
										
										
										
											2015-05-06 02:29:11 -03:00
										 |  |  |     Path(LowPathType type, u32 size, u32 pointer); | 
					
						
							| 
									
										
										
										
											2014-11-10 14:36:32 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-18 09:38:01 +09:00
										 |  |  |     LowPathType GetType() const { | 
					
						
							|  |  |  |         return type; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2014-11-10 14:36:32 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-11-13 19:26:33 -05:00
										 |  |  |     /**
 | 
					
						
							|  |  |  |      * Gets the string representation of the path for debugging | 
					
						
							|  |  |  |      * @return String representation of the path for debugging | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-01-25 00:10:05 -05:00
										 |  |  |     std::string DebugStr() const; | 
					
						
							| 
									
										
										
										
											2014-11-10 14:36:32 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-25 00:10:05 -05:00
										 |  |  |     std::string AsString() const; | 
					
						
							|  |  |  |     std::u16string AsU16Str() const; | 
					
						
							|  |  |  |     std::vector<u8> AsBinary() const; | 
					
						
							| 
									
										
										
										
											2014-11-10 14:36:32 -08:00
										 |  |  | 
 | 
					
						
							|  |  |  | private: | 
					
						
							|  |  |  |     LowPathType type; | 
					
						
							|  |  |  |     std::vector<u8> binary; | 
					
						
							|  |  |  |     std::string string; | 
					
						
							|  |  |  |     std::u16string u16str; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-09-18 18:01:46 -07:00
										 |  |  | /// Parameters of the archive, as specified in the Create or Format call.
 | 
					
						
							| 
									
										
										
										
											2015-12-28 13:51:44 -05:00
										 |  |  | struct ArchiveFormatInfo { | 
					
						
							| 
									
										
										
										
											2016-09-18 18:01:46 -07:00
										 |  |  |     u32_le total_size;         ///< The pre-defined size of the archive.
 | 
					
						
							|  |  |  |     u32_le number_directories; ///< The pre-defined number of directories in the archive.
 | 
					
						
							|  |  |  |     u32_le number_files;       ///< The pre-defined number of files in the archive.
 | 
					
						
							|  |  |  |     u8 duplicate_data;         ///< Whether the archive should duplicate the data.
 | 
					
						
							| 
									
										
										
										
											2015-12-28 13:51:44 -05:00
										 |  |  | }; | 
					
						
							|  |  |  | static_assert(std::is_pod<ArchiveFormatInfo>::value, "ArchiveFormatInfo is not POD"); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-12-15 02:51:38 -02:00
										 |  |  | class ArchiveBackend : NonCopyable { | 
					
						
							| 
									
										
										
										
											2014-06-27 16:18:56 -04:00
										 |  |  | public: | 
					
						
							| 
									
										
										
										
											2016-09-18 18:01:46 -07:00
										 |  |  |     virtual ~ArchiveBackend() {} | 
					
						
							| 
									
										
										
										
											2014-06-27 16:18:56 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							| 
									
										
										
										
											2014-12-15 02:44:04 -02:00
										 |  |  |      * Get a descriptive name for the archive (e.g. "RomFS", "SaveData", etc.) | 
					
						
							| 
									
										
										
										
											2014-06-27 16:18:56 -04:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2014-12-15 02:44:04 -02:00
										 |  |  |     virtual std::string GetName() const = 0; | 
					
						
							| 
									
										
										
										
											2014-06-27 16:18:56 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-12 00:42:59 +02:00
										 |  |  |     /**
 | 
					
						
							|  |  |  |      * 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 | 
					
						
							| 
									
										
										
										
											2015-12-28 10:17:06 -05:00
										 |  |  |      * @return Opened file, or error code | 
					
						
							| 
									
										
										
										
											2014-09-12 00:42:59 +02:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-09-18 09:38:01 +09:00
										 |  |  |     virtual ResultVal<std::unique_ptr<FileBackend>> OpenFile(const Path& path, | 
					
						
							|  |  |  |                                                              const Mode mode) const = 0; | 
					
						
							| 
									
										
										
										
											2014-09-12 00:42:59 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-11-11 10:37:26 -08:00
										 |  |  |     /**
 | 
					
						
							|  |  |  |      * Delete a file specified by its path | 
					
						
							|  |  |  |      * @param path Path relative to the archive | 
					
						
							| 
									
										
										
										
											2015-12-28 09:59:27 -05:00
										 |  |  |      * @return Result of the operation | 
					
						
							| 
									
										
										
										
											2014-11-11 10:37:26 -08:00
										 |  |  |      */ | 
					
						
							| 
									
										
										
										
											2015-12-28 09:59:27 -05:00
										 |  |  |     virtual ResultCode DeleteFile(const Path& path) const = 0; | 
					
						
							| 
									
										
										
										
											2014-11-11 10:37:26 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-11-23 23:20:04 -08:00
										 |  |  |     /**
 | 
					
						
							|  |  |  |      * 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 Whether rename succeeded | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2014-12-18 14:06:37 +00:00
										 |  |  |     virtual bool RenameFile(const Path& src_path, const Path& dest_path) const = 0; | 
					
						
							| 
									
										
										
										
											2014-11-23 23:20:04 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-11-11 10:37:26 -08:00
										 |  |  |     /**
 | 
					
						
							|  |  |  |      * Delete a directory specified by its path | 
					
						
							|  |  |  |      * @param path Path relative to the archive | 
					
						
							|  |  |  |      * @return Whether the directory could be deleted | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2014-12-18 14:06:37 +00:00
										 |  |  |     virtual bool DeleteDirectory(const Path& path) const = 0; | 
					
						
							| 
									
										
										
										
											2014-11-11 10:37:26 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-12-20 12:43:50 -03:00
										 |  |  |     /**
 | 
					
						
							|  |  |  |      * 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 File creation result code | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2015-12-28 09:38:10 -05:00
										 |  |  |     virtual ResultCode CreateFile(const Path& path, u64 size) const = 0; | 
					
						
							| 
									
										
										
										
											2014-12-20 12:43:50 -03:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-10-28 22:52:56 -07:00
										 |  |  |     /**
 | 
					
						
							|  |  |  |      * Create a directory specified by its path | 
					
						
							|  |  |  |      * @param path Path relative to the archive | 
					
						
							|  |  |  |      * @return Whether the directory could be created | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2014-11-11 19:27:35 -05:00
										 |  |  |     virtual bool CreateDirectory(const Path& path) const = 0; | 
					
						
							| 
									
										
										
										
											2014-10-28 22:52:56 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-11-24 01:12:58 -08:00
										 |  |  |     /**
 | 
					
						
							|  |  |  |      * 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 Whether rename succeeded | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2014-12-18 14:06:37 +00:00
										 |  |  |     virtual bool RenameDirectory(const Path& src_path, const Path& dest_path) const = 0; | 
					
						
							| 
									
										
										
										
											2014-11-24 01:12:58 -08:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-09-12 00:47:05 +02:00
										 |  |  |     /**
 | 
					
						
							|  |  |  |      * Open a directory specified by its path | 
					
						
							|  |  |  |      * @param path Path relative to the archive | 
					
						
							|  |  |  |      * @return Opened directory, or nullptr | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2014-12-15 04:59:29 -02:00
										 |  |  |     virtual std::unique_ptr<DirectoryBackend> OpenDirectory(const Path& path) const = 0; | 
					
						
							| 
									
										
										
										
											2015-10-18 15:52:37 -07:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * Get the free space | 
					
						
							|  |  |  |      * @return The number of free bytes in the archive | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     virtual u64 GetFreeBytes() const = 0; | 
					
						
							| 
									
										
										
										
											2014-06-27 16:18:56 -04:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-06 11:53:14 -02:00
										 |  |  | class ArchiveFactory : NonCopyable { | 
					
						
							|  |  |  | public: | 
					
						
							| 
									
										
										
										
											2016-09-18 18:01:46 -07:00
										 |  |  |     virtual ~ArchiveFactory() {} | 
					
						
							| 
									
										
										
										
											2015-02-06 11:53:14 -02:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * Get a descriptive name for the archive (e.g. "RomFS", "SaveData", etc.) | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     virtual std::string GetName() const = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * Tries to open the archive of this type with the specified path | 
					
						
							|  |  |  |      * @param path Path to the archive | 
					
						
							|  |  |  |      * @return An ArchiveBackend corresponding operating specified archive path. | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     virtual ResultVal<std::unique_ptr<ArchiveBackend>> Open(const Path& path) = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * Deletes the archive contents and then re-creates the base folder | 
					
						
							|  |  |  |      * @param path Path to the archive | 
					
						
							| 
									
										
										
										
											2015-12-28 13:51:44 -05:00
										 |  |  |      * @param format_info Format information for the new archive | 
					
						
							| 
									
										
										
										
											2015-02-06 11:53:14 -02:00
										 |  |  |      * @return ResultCode of the operation, 0 on success | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2015-12-28 13:51:44 -05:00
										 |  |  |     virtual ResultCode Format(const Path& path, const FileSys::ArchiveFormatInfo& format_info) = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-16 17:01:01 -05:00
										 |  |  |     /**
 | 
					
						
							| 
									
										
										
										
											2015-12-28 13:51:44 -05:00
										 |  |  |      * Retrieves the format info about the archive with the specified path | 
					
						
							|  |  |  |      * @param path Path to the archive | 
					
						
							|  |  |  |      * @return Format information about the archive or error code | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     virtual ResultVal<ArchiveFormatInfo> GetFormatInfo(const Path& path) const = 0; | 
					
						
							| 
									
										
										
										
											2015-02-06 11:53:14 -02:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-06-27 16:18:56 -04:00
										 |  |  | } // namespace FileSys
 |