mirror of https://github.com/AxioDL/metaforce.git
driver/main: Factor out tool construction code to its own function
Isolates the tool construction code and also makes the assignment within main more straightforward. While we're at it, we can also make use of std::make_unique within the relocated function.
This commit is contained in:
parent
fd61ba6cc7
commit
d76d776a0e
|
@ -77,8 +77,8 @@ static void SIGINTHandler(int sig) {
|
||||||
}
|
}
|
||||||
|
|
||||||
static logvisor::Module AthenaLog("Athena");
|
static logvisor::Module AthenaLog("Athena");
|
||||||
static void AthenaExc(athena::error::Level level, const char* file, const char*, int line,
|
static void AthenaExc(athena::error::Level level, const char* file, const char*, int line, fmt::string_view fmt,
|
||||||
fmt::string_view fmt, fmt::format_args args) {
|
fmt::format_args args) {
|
||||||
AthenaLog.vreport(logvisor::Level(level), fmt, args);
|
AthenaLog.vreport(logvisor::Level(level), fmt, args);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -103,6 +103,52 @@ static std::unique_ptr<hecl::Database::Project> FindProject(hecl::SystemStringVi
|
||||||
return newProj;
|
return newProj;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static std::unique_ptr<ToolBase> MakeSelectedTool(hecl::SystemString toolName, ToolPassInfo& info) {
|
||||||
|
hecl::SystemString toolNameLower = toolName;
|
||||||
|
hecl::ToLower(toolNameLower);
|
||||||
|
|
||||||
|
if (toolNameLower == _SYS_STR("init")) {
|
||||||
|
return std::make_unique<ToolInit>(info);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (toolNameLower == _SYS_STR("spec")) {
|
||||||
|
return std::make_unique<ToolSpec>(info);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (toolNameLower == _SYS_STR("extract")) {
|
||||||
|
return std::make_unique<ToolExtract>(info);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (toolNameLower == _SYS_STR("cook")) {
|
||||||
|
return std::make_unique<ToolCook>(info);
|
||||||
|
}
|
||||||
|
|
||||||
|
if (toolNameLower == _SYS_STR("package") || toolNameLower == _SYS_STR("pack")) {
|
||||||
|
return std::make_unique<ToolPackage>(info);
|
||||||
|
}
|
||||||
|
|
||||||
|
#if HECL_HAS_NOD
|
||||||
|
if (toolNameLower == _SYS_STR("image")) {
|
||||||
|
return std::make_unique<ToolImage>(info);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
if (toolNameLower == _SYS_STR("help")) {
|
||||||
|
return std::make_unique<ToolHelp>(info);
|
||||||
|
}
|
||||||
|
|
||||||
|
std::unique_ptr<FILE, decltype(&std::fclose)> fp{hecl::Fopen(toolName.c_str(), _SYS_STR("rb")), std::fclose};
|
||||||
|
if (fp == nullptr) {
|
||||||
|
LogModule.report(logvisor::Error, fmt(_SYS_STR("unrecognized tool '{}'")), toolNameLower);
|
||||||
|
return nullptr;
|
||||||
|
}
|
||||||
|
fp.reset();
|
||||||
|
|
||||||
|
/* Shortcut-case: implicit extract */
|
||||||
|
info.args.insert(info.args.begin(), std::move(toolName));
|
||||||
|
return std::make_unique<ToolExtract>(info);
|
||||||
|
}
|
||||||
|
|
||||||
#if _WIN32
|
#if _WIN32
|
||||||
int wmain(int argc, const wchar_t** argv)
|
int wmain(int argc, const wchar_t** argv)
|
||||||
#else
|
#else
|
||||||
|
@ -238,8 +284,7 @@ int main(int argc, const char** argv)
|
||||||
else
|
else
|
||||||
threadArg = true;
|
threadArg = true;
|
||||||
break;
|
break;
|
||||||
}
|
} else
|
||||||
else
|
|
||||||
info.flags.push_back(*chit);
|
info.flags.push_back(*chit);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -259,38 +304,8 @@ int main(int argc, const char** argv)
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Construct selected tool */
|
/* Construct selected tool */
|
||||||
hecl::SystemString toolName(argv[1]);
|
|
||||||
hecl::ToLower(toolName);
|
|
||||||
std::unique_ptr<ToolBase> tool;
|
|
||||||
|
|
||||||
size_t ErrorRef = logvisor::ErrorCount;
|
size_t ErrorRef = logvisor::ErrorCount;
|
||||||
if (toolName == _SYS_STR("init"))
|
auto tool = MakeSelectedTool(argv[1], info);
|
||||||
tool.reset(new ToolInit(info));
|
|
||||||
else if (toolName == _SYS_STR("spec"))
|
|
||||||
tool.reset(new ToolSpec(info));
|
|
||||||
else if (toolName == _SYS_STR("extract"))
|
|
||||||
tool.reset(new ToolExtract(info));
|
|
||||||
else if (toolName == _SYS_STR("cook"))
|
|
||||||
tool.reset(new ToolCook(info));
|
|
||||||
else if (toolName == _SYS_STR("package") || toolName == _SYS_STR("pack"))
|
|
||||||
tool.reset(new ToolPackage(info));
|
|
||||||
#if HECL_HAS_NOD
|
|
||||||
else if (toolName == _SYS_STR("image"))
|
|
||||||
tool.reset(new ToolImage(info));
|
|
||||||
#endif
|
|
||||||
else if (toolName == _SYS_STR("help"))
|
|
||||||
tool.reset(new ToolHelp(info));
|
|
||||||
else {
|
|
||||||
FILE* fp = hecl::Fopen(argv[1], _SYS_STR("rb"));
|
|
||||||
if (!fp)
|
|
||||||
LogModule.report(logvisor::Error, fmt(_SYS_STR("unrecognized tool '{}'")), toolName);
|
|
||||||
else {
|
|
||||||
/* Shortcut-case: implicit extract */
|
|
||||||
fclose(fp);
|
|
||||||
info.args.insert(info.args.begin(), argv[1]);
|
|
||||||
tool.reset(new ToolExtract(info));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (logvisor::ErrorCount > ErrorRef) {
|
if (logvisor::ErrorCount > ErrorRef) {
|
||||||
#if WIN_PAUSE
|
#if WIN_PAUSE
|
||||||
|
@ -299,8 +314,10 @@ int main(int argc, const char** argv)
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (info.verbosityLevel)
|
if (info.verbosityLevel) {
|
||||||
LogModule.report(logvisor::Info, fmt(_SYS_STR("Constructed tool '{}' {}\n")), tool->toolName(), info.verbosityLevel);
|
LogModule.report(logvisor::Info, fmt(_SYS_STR("Constructed tool '{}' {}\n")), tool->toolName(),
|
||||||
|
info.verbosityLevel);
|
||||||
|
}
|
||||||
|
|
||||||
/* Run tool */
|
/* Run tool */
|
||||||
ErrorRef = logvisor::ErrorCount;
|
ErrorRef = logvisor::ErrorCount;
|
||||||
|
|
Loading…
Reference in New Issue