summaryrefslogtreecommitdiff
path: root/src/core/loader/loader.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/core/loader/loader.cpp')
-rw-r--r--src/core/loader/loader.cpp60
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 */
25static 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 */
26FileType IdentifyFile(const std::string &filename) { 47static 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