diff options
Diffstat (limited to 'src/core/loader/loader.cpp')
| -rw-r--r-- | src/core/loader/loader.cpp | 60 |
1 files changed, 45 insertions, 15 deletions
diff --git a/src/core/loader/loader.cpp b/src/core/loader/loader.cpp index fd32b7b20..01b415215 100644 --- a/src/core/loader/loader.cpp +++ b/src/core/loader/loader.cpp | |||
| @@ -19,11 +19,32 @@ namespace Loader { | |||
| 19 | 19 | ||
| 20 | /** | 20 | /** |
| 21 | * Identifies the type of a bootable file | 21 | * Identifies the type of a bootable file |
| 22 | * @param file open file | ||
| 23 | * @return FileType of file | ||
| 24 | */ | ||
| 25 | static FileType IdentifyFile(FileUtil::IOFile& file) { | ||
| 26 | FileType type; | ||
| 27 | |||
| 28 | #define CHECK_TYPE(loader) \ | ||
| 29 | type = AppLoader_##loader::IdentifyType(file); \ | ||
| 30 | if (FileType::Error != type) \ | ||
| 31 | return type; | ||
| 32 | |||
| 33 | CHECK_TYPE(THREEDSX) | ||
| 34 | CHECK_TYPE(ELF) | ||
| 35 | CHECK_TYPE(NCCH) | ||
| 36 | |||
| 37 | #undef CHECK_TYPE | ||
| 38 | |||
| 39 | return FileType::Unknown; | ||
| 40 | } | ||
| 41 | |||
| 42 | /** | ||
| 43 | * Guess the type of a bootable file from its extension | ||
| 22 | * @param filename String filename of bootable file | 44 | * @param filename String filename of bootable file |
| 23 | * @todo (ShizZy) this function sucks... make it actually check file contents etc. | ||
| 24 | * @return FileType of file | 45 | * @return FileType of file |
| 25 | */ | 46 | */ |
| 26 | FileType IdentifyFile(const std::string &filename) { | 47 | static FileType GuessFromFilename(const std::string& filename) { |
| 27 | if (filename.size() == 0) { | 48 | if (filename.size() == 0) { |
| 28 | LOG_ERROR(Loader, "invalid filename %s", filename.c_str()); | 49 | LOG_ERROR(Loader, "invalid filename %s", filename.c_str()); |
| 29 | return FileType::Error; | 50 | return FileType::Error; |
| @@ -34,22 +55,20 @@ FileType IdentifyFile(const std::string &filename) { | |||
| 34 | return FileType::Unknown; | 55 | return FileType::Unknown; |
| 35 | std::string extension = Common::ToLower(filename.substr(extension_loc)); | 56 | std::string extension = Common::ToLower(filename.substr(extension_loc)); |
| 36 | 57 | ||
| 37 | // TODO(bunnei): Do actual filetype checking instead of naively checking the extension | 58 | if (extension == ".elf") |
| 38 | if (extension == ".elf") { | ||
| 39 | return FileType::ELF; | 59 | return FileType::ELF; |
| 40 | } else if (extension == ".axf") { | 60 | else if (extension == ".axf") |
| 41 | return FileType::ELF; | 61 | return FileType::ELF; |
| 42 | } else if (extension == ".cxi") { | 62 | else if (extension == ".cxi") |
| 43 | return FileType::CXI; | 63 | return FileType::CXI; |
| 44 | } else if (extension == ".cci") { | 64 | else if (extension == ".cci") |
| 45 | return FileType::CCI; | 65 | return FileType::CCI; |
| 46 | } else if (extension == ".bin") { | 66 | else if (extension == ".bin") |
| 47 | return FileType::BIN; | 67 | return FileType::BIN; |
| 48 | } else if (extension == ".3ds") { | 68 | else if (extension == ".3ds") |
| 49 | return FileType::CCI; | 69 | return FileType::CCI; |
| 50 | } else if (extension == ".3dsx") { | 70 | else if (extension == ".3dsx") |
| 51 | return FileType::THREEDSX; | 71 | return FileType::THREEDSX; |
| 52 | } | ||
| 53 | return FileType::Unknown; | 72 | return FileType::Unknown; |
| 54 | } | 73 | } |
| 55 | 74 | ||
| @@ -60,7 +79,16 @@ ResultStatus LoadFile(const std::string& filename) { | |||
| 60 | if (!file->IsOpen()) | 79 | if (!file->IsOpen()) |
| 61 | return ResultStatus::Error; | 80 | return ResultStatus::Error; |
| 62 | 81 | ||
| 63 | switch (IdentifyFile(filename)) { | 82 | FileType type = IdentifyFile(*file); |
| 83 | FileType filename_type = GuessFromFilename(filename); | ||
| 84 | |||
| 85 | if (type != filename_type) { | ||
| 86 | LOG_WARNING(Loader, "File %s has a different type than its extension.", filename.c_str()); | ||
| 87 | if (FileType::Unknown == type) | ||
| 88 | type = filename_type; | ||
| 89 | } | ||
| 90 | |||
| 91 | switch (type) { | ||
| 64 | 92 | ||
| 65 | //3DSX file format... | 93 | //3DSX file format... |
| 66 | case FileType::THREEDSX: | 94 | case FileType::THREEDSX: |
| @@ -72,7 +100,8 @@ ResultStatus LoadFile(const std::string& filename) { | |||
| 72 | 100 | ||
| 73 | // NCCH/NCSD container formats... | 101 | // NCCH/NCSD container formats... |
| 74 | case FileType::CXI: | 102 | case FileType::CXI: |
| 75 | case FileType::CCI: { | 103 | case FileType::CCI: |
| 104 | { | ||
| 76 | AppLoader_NCCH app_loader(std::move(file)); | 105 | AppLoader_NCCH app_loader(std::move(file)); |
| 77 | 106 | ||
| 78 | // Load application and RomFS | 107 | // Load application and RomFS |
| @@ -100,10 +129,11 @@ ResultStatus LoadFile(const std::string& filename) { | |||
| 100 | 129 | ||
| 101 | // IdentifyFile could know identify file type... | 130 | // IdentifyFile could know identify file type... |
| 102 | case FileType::Unknown: | 131 | case FileType::Unknown: |
| 103 | 132 | { | |
| 104 | default: | 133 | LOG_CRITICAL(Loader, "File %s is of unknown type."); |
| 105 | return ResultStatus::ErrorInvalidFormat; | 134 | return ResultStatus::ErrorInvalidFormat; |
| 106 | } | 135 | } |
| 136 | } | ||
| 107 | return ResultStatus::Error; | 137 | return ResultStatus::Error; |
| 108 | } | 138 | } |
| 109 | 139 | ||