mirror of
https://github.com/yuzu-emu/yuzu-android.git
synced 2025-06-13 10:47:58 -05:00
loader: Refactor to also pass filepath into IdentifyType.
This commit is contained in:
@ -21,11 +21,11 @@ const std::initializer_list<Kernel::AddressMapping> default_address_mappings = {
|
||||
{0x1F000000, 0x600000, false}, // entire VRAM
|
||||
};
|
||||
|
||||
FileType IdentifyFile(FileUtil::IOFile& file) {
|
||||
FileType IdentifyFile(FileUtil::IOFile& file, const std::string& filepath) {
|
||||
FileType type;
|
||||
|
||||
#define CHECK_TYPE(loader) \
|
||||
type = AppLoader_##loader::IdentifyType(file); \
|
||||
type = AppLoader_##loader::IdentifyType(file, filepath); \
|
||||
if (FileType::Error != type) \
|
||||
return type;
|
||||
|
||||
@ -45,13 +45,13 @@ FileType IdentifyFile(const std::string& file_name) {
|
||||
return FileType::Unknown;
|
||||
}
|
||||
|
||||
return IdentifyFile(file);
|
||||
return IdentifyFile(file, file_name);
|
||||
}
|
||||
|
||||
FileType GuessFromExtension(const std::string& extension_) {
|
||||
std::string extension = Common::ToLower(extension_);
|
||||
|
||||
if (extension == ".elf" || extension == ".axf")
|
||||
if (extension == ".elf")
|
||||
return FileType::ELF;
|
||||
else if (extension == ".nro")
|
||||
return FileType::NRO;
|
||||
@ -117,7 +117,7 @@ std::unique_ptr<AppLoader> GetLoader(const std::string& filename) {
|
||||
std::string filename_filename, filename_extension;
|
||||
Common::SplitPath(filename, nullptr, &filename_filename, &filename_extension);
|
||||
|
||||
FileType type = IdentifyFile(file);
|
||||
FileType type = IdentifyFile(file, filename);
|
||||
FileType filename_type = GuessFromExtension(filename_extension);
|
||||
|
||||
if (type != filename_type) {
|
||||
|
Reference in New Issue
Block a user