| 
									
										
										
										
											2014-06-27 16:18:56 -04:00
										 |  |  | // Copyright 2014 Citra Emulator Project
 | 
					
						
							|  |  |  | // Licensed under GPLv2
 | 
					
						
							|  |  |  | // Refer to the license.txt file included.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #pragma once
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <vector>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "common/common_types.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "core/file_sys/archive.h"
 | 
					
						
							|  |  |  | #include "core/loader/loader.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | ////////////////////////////////////////////////////////////////////////////////////////////////////
 | 
					
						
							|  |  |  | // FileSys namespace
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace FileSys { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /// File system interface to the RomFS archive
 | 
					
						
							| 
									
										
										
										
											2014-07-04 13:20:40 -04:00
										 |  |  | class Archive_RomFS final : public Archive { | 
					
						
							| 
									
										
										
										
											2014-06-27 16:18:56 -04:00
										 |  |  | public: | 
					
						
							| 
									
										
										
										
											2014-07-04 13:11:09 -04:00
										 |  |  |     Archive_RomFS(const Loader::AppLoader& app_loader); | 
					
						
							| 
									
										
										
										
											2014-07-04 13:25:30 -04:00
										 |  |  |     ~Archive_RomFS() override; | 
					
						
							| 
									
										
										
										
											2014-06-27 16:18:56 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * Get the IdCode of the archive (e.g. RomFS, SaveData, etc.) | 
					
						
							|  |  |  |      * @return IdCode of the archive | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2014-11-18 08:27:16 -05:00
										 |  |  |     IdCode GetIdCode() const override { return IdCode::RomFS; } | 
					
						
							| 
									
										
										
										
											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 | 
					
						
							|  |  |  |      * @return Opened file, or nullptr | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2014-11-11 19:27:35 -05:00
										 |  |  |     std::unique_ptr<File> OpenFile(const Path& path, const Mode mode) const override; | 
					
						
							| 
									
										
										
										
											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 | 
					
						
							|  |  |  |      * @return Whether the file could be deleted | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     bool DeleteFile(const FileSys::Path& path) const override; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											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 | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     bool RenameFile(const FileSys::Path& src_path, const FileSys::Path& dest_path) const override; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											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 | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     bool DeleteDirectory(const FileSys::Path& path) const override; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											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
										 |  |  |     bool CreateDirectory(const Path& path) const override; | 
					
						
							| 
									
										
										
										
											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 | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     bool RenameDirectory(const FileSys::Path& src_path, const FileSys::Path& dest_path) const override; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											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-11-11 19:27:35 -05:00
										 |  |  |     std::unique_ptr<Directory> OpenDirectory(const Path& path) const override; | 
					
						
							| 
									
										
										
										
											2014-09-12 00:47:05 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-06-27 16:18:56 -04:00
										 |  |  |     /**
 | 
					
						
							|  |  |  |      * Read data from the archive | 
					
						
							| 
									
										
										
										
											2014-08-20 22:03:31 -07:00
										 |  |  |      * @param offset Offset in bytes to start reading data from | 
					
						
							|  |  |  |      * @param length Length in bytes of data to read from archive | 
					
						
							| 
									
										
										
										
											2014-06-27 16:18:56 -04:00
										 |  |  |      * @param buffer Buffer to read data into | 
					
						
							|  |  |  |      * @return Number of bytes read | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2014-07-04 13:25:30 -04:00
										 |  |  |     size_t Read(const u64 offset, const u32 length, u8* buffer) const override; | 
					
						
							| 
									
										
										
										
											2014-06-27 16:18:56 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-08-20 22:03:31 -07:00
										 |  |  |     /**
 | 
					
						
							|  |  |  |      * Write data to the archive | 
					
						
							|  |  |  |      * @param offset Offset in bytes to start writing data to | 
					
						
							|  |  |  |      * @param length Length in bytes of data to write to archive | 
					
						
							|  |  |  |      * @param buffer Buffer to write data from | 
					
						
							|  |  |  |      * @param flush  The flush parameters (0 == do not flush) | 
					
						
							|  |  |  |      * @return Number of bytes written | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     size_t Write(const u64 offset, const u32 length, const u32 flush, u8* buffer) override; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-06-27 16:18:56 -04:00
										 |  |  |     /**
 | 
					
						
							|  |  |  |      * Get the size of the archive in bytes | 
					
						
							|  |  |  |      * @return Size of the archive in bytes | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2014-07-04 13:25:30 -04:00
										 |  |  |     size_t GetSize() const override; | 
					
						
							| 
									
										
										
										
											2014-11-19 08:49:13 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-08-20 22:03:31 -07:00
										 |  |  |     /**
 | 
					
						
							|  |  |  |      * Set the size of the archive in bytes | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     void SetSize(const u64 size) override; | 
					
						
							| 
									
										
										
										
											2014-06-27 16:18:56 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | private: | 
					
						
							|  |  |  |     std::vector<u8> raw_data; | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | } // namespace FileSys
 |