forked from eden-emu/eden
		
	
		
			
				
	
	
		
			65 lines
		
	
	
	
		
			1.9 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			65 lines
		
	
	
	
		
			1.9 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
| // Copyright 2014 Dolphin Emulator Project / Citra Emulator Project
 | |
| // Licensed under GPLv2 or any later version
 | |
| // Refer to the license.txt file included.
 | |
| 
 | |
| #pragma once
 | |
| 
 | |
| #include <string>
 | |
| 
 | |
| #include "common/common_types.h"
 | |
| #include "core/loader/loader.h"
 | |
| 
 | |
| ////////////////////////////////////////////////////////////////////////////////////////////////////
 | |
| // Loader namespace
 | |
| 
 | |
| namespace Loader {
 | |
| 
 | |
| /// Loads an 3DSX file
 | |
| class AppLoader_THREEDSX final : public AppLoader {
 | |
| public:
 | |
|     AppLoader_THREEDSX(FileUtil::IOFile&& file, const std::string& filename, const std::string& filepath)
 | |
|         : AppLoader(std::move(file)), filename(std::move(filename)), filepath(filepath) {}
 | |
| 
 | |
|     /**
 | |
|      * Returns the type of the file
 | |
|      * @param file FileUtil::IOFile open file
 | |
|      * @return FileType found, or FileType::Error if this loader doesn't know it
 | |
|      */
 | |
|     static FileType IdentifyType(FileUtil::IOFile& file);
 | |
| 
 | |
|     /**
 | |
|      * Returns the type of this file
 | |
|      * @return FileType corresponding to the loaded file
 | |
|      */
 | |
|     FileType GetFileType() override {
 | |
|         return IdentifyType(file);
 | |
|     }
 | |
| 
 | |
|     /**
 | |
|      * Load the bootable file
 | |
|      * @return ResultStatus result of function
 | |
|      */
 | |
|     ResultStatus Load() override;
 | |
| 
 | |
|     /**
 | |
|      * Get the icon (typically icon section) of the application
 | |
|      * @param buffer Reference to buffer to store data
 | |
|      * @return ResultStatus result of function
 | |
|      */
 | |
|     ResultStatus ReadIcon(std::vector<u8>& buffer) override;
 | |
| 
 | |
|     /**
 | |
|      * Get the RomFS of the application
 | |
|      * @param romfs_file Reference to buffer to store data
 | |
|      * @param offset     Offset in the file to the RomFS
 | |
|      * @param size       Size of the RomFS in bytes
 | |
|      * @return ResultStatus result of function
 | |
|      */
 | |
|     ResultStatus ReadRomFS(std::shared_ptr<FileUtil::IOFile>& romfs_file, u64& offset, u64& size) override;
 | |
| 
 | |
| private:
 | |
|     std::string filename;
 | |
|     std::string filepath;
 | |
| };
 | |
| 
 | |
| } // namespace Loader
 | 
