| 
									
										
										
										
											2014-12-29 13:04:37 -05:00
										 |  |  | // Copyright 2014 Citra Emulator Project
 | 
					
						
							|  |  |  | // Licensed under GPLv2 or any later version
 | 
					
						
							|  |  |  | // Refer to the license.txt file included.
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #pragma once
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-06-21 15:44:11 +01:00
										 |  |  | #include <memory>
 | 
					
						
							|  |  |  | #include <string>
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-12-29 13:04:37 -05:00
										 |  |  | #include "common/common_types.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-06-21 15:44:11 +01:00
										 |  |  | #include "core/file_sys/archive_backend.h"
 | 
					
						
							|  |  |  | #include "core/hle/result.h"
 | 
					
						
							| 
									
										
										
										
											2014-12-29 13:04:37 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  | ////////////////////////////////////////////////////////////////////////////////////////////////////
 | 
					
						
							|  |  |  | // FileSys namespace
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | namespace FileSys { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /// File system interface to the ExtSaveData archive
 | 
					
						
							| 
									
										
										
										
											2015-02-06 11:53:14 -02:00
										 |  |  | class ArchiveFactory_ExtSaveData final : public ArchiveFactory { | 
					
						
							| 
									
										
										
										
											2014-12-29 13:04:37 -05:00
										 |  |  | public: | 
					
						
							| 
									
										
										
										
											2015-02-06 11:53:14 -02:00
										 |  |  |     ArchiveFactory_ExtSaveData(const std::string& mount_point, bool shared); | 
					
						
							| 
									
										
										
										
											2014-12-29 13:04:37 -05:00
										 |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * Initialize the archive. | 
					
						
							|  |  |  |      * @return true if it initialized successfully | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     bool Initialize(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     std::string GetName() const override { return "ExtSaveData"; } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-06 11:53:14 -02:00
										 |  |  |     ResultVal<std::unique_ptr<ArchiveBackend>> Open(const Path& path) override; | 
					
						
							| 
									
										
										
										
											2015-12-28 13:51:44 -05:00
										 |  |  |     ResultCode Format(const Path& path, const FileSys::ArchiveFormatInfo& format_info) override; | 
					
						
							|  |  |  |     ResultVal<ArchiveFormatInfo> GetFormatInfo(const Path& path) const override; | 
					
						
							| 
									
										
										
										
											2014-12-29 13:04:37 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-06 11:53:14 -02:00
										 |  |  |     const std::string& GetMountPoint() const { return mount_point; } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-01-16 17:01:01 -05:00
										 |  |  |     /**
 | 
					
						
							| 
									
										
										
										
											2015-12-28 13:51:44 -05:00
										 |  |  |      * Writes the SMDH icon of the ExtSaveData to file | 
					
						
							|  |  |  |      * @param path Path of this ExtSaveData | 
					
						
							|  |  |  |      * @param icon_data Binary data of the icon | 
					
						
							|  |  |  |      * @param icon_size Size of the icon data | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2016-01-16 17:01:01 -05:00
										 |  |  |     void WriteIcon(const Path& path, const u8* icon_data, u32 icon_size); | 
					
						
							| 
									
										
										
										
											2015-12-28 13:51:44 -05:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-02-06 11:53:14 -02:00
										 |  |  | private: | 
					
						
							| 
									
										
										
										
											2014-12-29 13:04:37 -05:00
										 |  |  |     /**
 | 
					
						
							| 
									
										
										
										
											2015-02-06 11:53:14 -02:00
										 |  |  |      * This holds the full directory path for this archive, it is only set after a successful call | 
					
						
							| 
									
										
										
										
											2015-05-25 20:34:09 +02:00
										 |  |  |      * to Open, this is formed as <base extsavedatapath>/<type>/<high>/<low>. | 
					
						
							| 
									
										
										
										
											2014-12-29 13:04:37 -05:00
										 |  |  |      * See GetExtSaveDataPath for the code that extracts this data from an archive path. | 
					
						
							|  |  |  |      */ | 
					
						
							| 
									
										
										
										
											2015-02-06 11:53:14 -02:00
										 |  |  |     std::string mount_point; | 
					
						
							| 
									
										
										
										
											2014-12-29 13:04:37 -05:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-01-13 23:56:00 -05:00
										 |  |  | /**
 | 
					
						
							| 
									
										
										
										
											2015-05-25 20:34:09 +02:00
										 |  |  |  * Constructs a path to the concrete ExtData archive in the host filesystem based on the | 
					
						
							| 
									
										
										
										
											2015-01-13 23:56:00 -05:00
										 |  |  |  * input Path and base mount point. | 
					
						
							|  |  |  |  * @param mount_point The base mount point of the ExtSaveData archives. | 
					
						
							|  |  |  |  * @param path The path that identifies the requested concrete ExtSaveData archive. | 
					
						
							|  |  |  |  * @returns The complete path to the specified extdata archive in the host filesystem | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | std::string GetExtSaveDataPath(const std::string& mount_point, const Path& path); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Constructs a path to the base folder to hold concrete ExtSaveData archives in the host file system. | 
					
						
							|  |  |  |  * @param mount_point The base folder where this folder resides, ie. SDMC or NAND. | 
					
						
							|  |  |  |  * @param shared Whether this ExtSaveData container is for SharedExtSaveDatas or not. | 
					
						
							|  |  |  |  * @returns The path to the base ExtSaveData archives' folder in the host file system | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | std::string GetExtDataContainerPath(const std::string& mount_point, bool shared); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2015-03-14 12:00:01 -05:00
										 |  |  | /**
 | 
					
						
							|  |  |  |  * Constructs a FileSys::Path object that refers to the ExtData archive identified by | 
					
						
							|  |  |  |  * the specified media type, high save id and low save id. | 
					
						
							|  |  |  |  * @param media_type The media type where the archive is located (NAND / SDMC) | 
					
						
							|  |  |  |  * @param high The high word of the save id for the archive | 
					
						
							|  |  |  |  * @param low The low word of the save id for the archive | 
					
						
							|  |  |  |  * @returns A FileSys::Path to the wanted archive | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | Path ConstructExtDataBinaryPath(u32 media_type, u32 high, u32 low); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-12-29 13:04:37 -05:00
										 |  |  | } // namespace FileSys
 |