| 
									
										
										
										
											2014-04-08 19:15:46 -04:00
										 |  |  | // Copyright 2014 Citra Emulator Project
 | 
					
						
							|  |  |  | // Licensed under GPLv2
 | 
					
						
							|  |  |  | // Refer to the license.txt file included.
 | 
					
						
							| 
									
										
										
										
											2013-09-19 23:21:22 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-04-08 19:15:46 -04:00
										 |  |  | #pragma once
 | 
					
						
							| 
									
										
										
										
											2013-09-19 23:21:22 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-06-18 18:58:09 -04:00
										 |  |  | #include <vector>
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-04-08 20:15:08 -04:00
										 |  |  | #include "common/common.h"
 | 
					
						
							| 
									
										
										
										
											2013-09-19 23:21:22 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | ////////////////////////////////////////////////////////////////////////////////////////////////////
 | 
					
						
							| 
									
										
										
										
											2014-06-16 23:18:10 -04:00
										 |  |  | // Loader namespace
 | 
					
						
							| 
									
										
										
										
											2013-09-19 23:21:22 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | namespace Loader { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-06-18 18:58:09 -04:00
										 |  |  | /// File types supported by CTR
 | 
					
						
							|  |  |  | enum class FileType { | 
					
						
							|  |  |  |     Error, | 
					
						
							|  |  |  |     Unknown, | 
					
						
							|  |  |  |     CCI, | 
					
						
							|  |  |  |     CXI, | 
					
						
							|  |  |  |     CIA, | 
					
						
							|  |  |  |     ELF, | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /// Return type for functions in Loader namespace
 | 
					
						
							|  |  |  | enum class ResultStatus { | 
					
						
							|  |  |  |     Success, | 
					
						
							|  |  |  |     Error, | 
					
						
							|  |  |  |     ErrorInvalidFormat, | 
					
						
							|  |  |  |     ErrorNotImplemented, | 
					
						
							|  |  |  |     ErrorNotLoaded, | 
					
						
							|  |  |  |     ErrorAlreadyLoaded, | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /// Interface for loading an application
 | 
					
						
							|  |  |  | class AppLoader : NonCopyable { | 
					
						
							|  |  |  | public: | 
					
						
							|  |  |  |     AppLoader() { } | 
					
						
							|  |  |  |     virtual ~AppLoader() { } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * Load the application | 
					
						
							|  |  |  |      * @return ResultStatus result of function | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     virtual const ResultStatus Load() = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * Get the code (typically .code section) of the application | 
					
						
							|  |  |  |      * @param error ResultStatus result of function | 
					
						
							|  |  |  |      * @return Reference to code buffer | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     virtual const std::vector<u8>& GetCode(ResultStatus& error) const { | 
					
						
							|  |  |  |         error = ResultStatus::ErrorNotImplemented; | 
					
						
							|  |  |  |         return code; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * Get the icon (typically .icon section) of the application | 
					
						
							|  |  |  |      * @param error ResultStatus result of function | 
					
						
							|  |  |  |      * @return Reference to icon buffer | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     virtual const std::vector<u8>& GetIcon(ResultStatus& error) const { | 
					
						
							|  |  |  |         error = ResultStatus::ErrorNotImplemented; | 
					
						
							|  |  |  |         return icon; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * Get the banner (typically .banner section) of the application | 
					
						
							|  |  |  |      * @param error ResultStatus result of function | 
					
						
							|  |  |  |      * @return Reference to banner buffer | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     virtual const std::vector<u8>& GetBanner(ResultStatus& error) const { | 
					
						
							|  |  |  |         error = ResultStatus::ErrorNotImplemented; | 
					
						
							|  |  |  |         return banner; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     /**
 | 
					
						
							|  |  |  |      * Get the logo (typically .logo section) of the application | 
					
						
							|  |  |  |      * @param error ResultStatus result of function | 
					
						
							|  |  |  |      * @return Reference to logo buffer | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     virtual const std::vector<u8>& GetLogo(ResultStatus& error) const { | 
					
						
							|  |  |  |         error = ResultStatus::ErrorNotImplemented; | 
					
						
							|  |  |  |         return logo; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2013-09-19 23:21:22 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-06-18 18:58:09 -04:00
										 |  |  |     /**
 | 
					
						
							|  |  |  |      * Get the RomFs archive of the application | 
					
						
							|  |  |  |      * @param error ResultStatus result of function | 
					
						
							|  |  |  |      * @return Reference to RomFs archive buffer | 
					
						
							|  |  |  |      */ | 
					
						
							|  |  |  |     virtual const std::vector<u8>& GetRomFs(ResultStatus error) const { | 
					
						
							|  |  |  |         error = ResultStatus::ErrorNotImplemented; | 
					
						
							|  |  |  |         return romfs; | 
					
						
							|  |  |  |     } | 
					
						
							| 
									
										
										
										
											2013-09-19 23:21:22 -04:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2014-06-18 18:58:09 -04:00
										 |  |  | protected: | 
					
						
							|  |  |  |     std::vector<u8> code;   ///< ExeFS .code section
 | 
					
						
							|  |  |  |     std::vector<u8> icon;   ///< ExeFS .icon section
 | 
					
						
							|  |  |  |     std::vector<u8> banner; ///< ExeFS .banner section
 | 
					
						
							|  |  |  |     std::vector<u8> logo;   ///< ExeFS .logo section
 | 
					
						
							|  |  |  |     std::vector<u8> romfs;  ///< RomFs archive
 | 
					
						
							| 
									
										
										
										
											2013-09-19 23:21:22 -04:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Identifies the type of a bootable file | 
					
						
							|  |  |  |  * @param filename String filename of bootable file | 
					
						
							|  |  |  |  * @return FileType of file | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2014-06-18 18:58:09 -04:00
										 |  |  | const FileType IdentifyFile(const std::string &filename); | 
					
						
							| 
									
										
										
										
											2013-09-19 23:21:22 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | /**
 | 
					
						
							|  |  |  |  * Identifies and loads a bootable file | 
					
						
							|  |  |  |  * @param filename String filename of bootable file | 
					
						
							| 
									
										
										
										
											2014-06-18 18:58:09 -04:00
										 |  |  |  * @return ResultStatus result of function | 
					
						
							| 
									
										
										
										
											2013-09-19 23:21:22 -04:00
										 |  |  |  */ | 
					
						
							| 
									
										
										
										
											2014-06-18 18:58:09 -04:00
										 |  |  | const ResultStatus LoadFile(std::string& filename); | 
					
						
							| 
									
										
										
										
											2013-09-19 23:21:22 -04:00
										 |  |  | 
 | 
					
						
							|  |  |  | } // namespace
 |