mirror of
https://github.com/PabloMK7/citra.git
synced 2025-01-23 23:14:13 +01:00
66 lines
1.9 KiB
C++
66 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
|