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, 16 insertions, 44 deletions
diff --git a/src/core/loader/loader.cpp b/src/core/loader/loader.cpp
index af3f62248..9719d30d5 100644
--- a/src/core/loader/loader.cpp
+++ b/src/core/loader/loader.cpp
@@ -8,9 +8,7 @@
8#include "common/logging/log.h" 8#include "common/logging/log.h"
9#include "common/string_util.h" 9#include "common/string_util.h"
10 10
11#include "core/file_sys/archive_romfs.h"
12#include "core/hle/kernel/process.h" 11#include "core/hle/kernel/process.h"
13#include "core/hle/service/fs/archive.h"
14#include "core/loader/3dsx.h" 12#include "core/loader/3dsx.h"
15#include "core/loader/elf.h" 13#include "core/loader/elf.h"
16#include "core/loader/ncch.h" 14#include "core/loader/ncch.h"
@@ -67,6 +65,9 @@ FileType GuessFromExtension(const std::string& extension_) {
67 if (extension == ".3dsx") 65 if (extension == ".3dsx")
68 return FileType::THREEDSX; 66 return FileType::THREEDSX;
69 67
68 if (extension == ".cia")
69 return FileType::CIA;
70
70 return FileType::Unknown; 71 return FileType::Unknown;
71} 72}
72 73
@@ -90,7 +91,15 @@ const char* GetFileTypeString(FileType type) {
90 return "unknown"; 91 return "unknown";
91} 92}
92 93
93std::unique_ptr<AppLoader> GetLoader(FileUtil::IOFile&& file, FileType type, 94/**
95 * Get a loader for a file with a specific type
96 * @param file The file to load
97 * @param type The type of the file
98 * @param filename the file name (without path)
99 * @param filepath the file full path (with name)
100 * @return std::unique_ptr<AppLoader> a pointer to a loader object; nullptr for unsupported type
101 */
102static std::unique_ptr<AppLoader> GetFileLoader(FileUtil::IOFile&& file, FileType type,
94 const std::string& filename, const std::string& filepath) { 103 const std::string& filename, const std::string& filepath) {
95 switch (type) { 104 switch (type) {
96 105
@@ -108,15 +117,15 @@ std::unique_ptr<AppLoader> GetLoader(FileUtil::IOFile&& file, FileType type,
108 return std::make_unique<AppLoader_NCCH>(std::move(file), filepath); 117 return std::make_unique<AppLoader_NCCH>(std::move(file), filepath);
109 118
110 default: 119 default:
111 return std::unique_ptr<AppLoader>(); 120 return nullptr;
112 } 121 }
113} 122}
114 123
115ResultStatus LoadFile(const std::string& filename) { 124std::unique_ptr<AppLoader> GetLoader(const std::string& filename) {
116 FileUtil::IOFile file(filename, "rb"); 125 FileUtil::IOFile file(filename, "rb");
117 if (!file.IsOpen()) { 126 if (!file.IsOpen()) {
118 LOG_ERROR(Loader, "Failed to load file %s", filename.c_str()); 127 LOG_ERROR(Loader, "Failed to load file %s", filename.c_str());
119 return ResultStatus::Error; 128 return nullptr;
120 } 129 }
121 130
122 std::string filename_filename, filename_extension; 131 std::string filename_filename, filename_extension;
@@ -133,44 +142,7 @@ ResultStatus LoadFile(const std::string& filename) {
133 142
134 LOG_INFO(Loader, "Loading file %s as %s...", filename.c_str(), GetFileTypeString(type)); 143 LOG_INFO(Loader, "Loading file %s as %s...", filename.c_str(), GetFileTypeString(type));
135 144
136 std::unique_ptr<AppLoader> app_loader = GetLoader(std::move(file), type, filename_filename, filename); 145 return GetFileLoader(std::move(file), type, filename_filename, filename);
137
138 switch (type) {
139
140 // 3DSX file format...
141 // or NCCH/NCSD container formats...
142 case FileType::THREEDSX:
143 case FileType::CXI:
144 case FileType::CCI:
145 {
146 // Load application and RomFS
147 ResultStatus result = app_loader->Load();
148 if (ResultStatus::Success == result) {
149 Service::FS::RegisterArchiveType(std::make_unique<FileSys::ArchiveFactory_RomFS>(*app_loader), Service::FS::ArchiveIdCode::RomFS);
150 return ResultStatus::Success;
151 }
152 return result;
153 }
154
155 // Standard ELF file format...
156 case FileType::ELF:
157 return app_loader->Load();
158
159 // CIA file format...
160 case FileType::CIA:
161 return ResultStatus::ErrorNotImplemented;
162
163 // Error occurred durring IdentifyFile...
164 case FileType::Error:
165
166 // IdentifyFile could know identify file type...
167 case FileType::Unknown:
168 {
169 LOG_CRITICAL(Loader, "File %s is of unknown type.", filename.c_str());
170 return ResultStatus::ErrorInvalidFormat;
171 }
172 }
173 return ResultStatus::Error;
174} 146}
175 147
176} // namespace Loader 148} // namespace Loader