metaforce/Editor/main.cpp

268 lines
8.3 KiB
C++
Raw Normal View History

2016-03-04 23:04:53 +00:00
#include "logvisor/logvisor.hpp"
#include "boo/boo.hpp"
#include "specter/specter.hpp"
#include "hecl/CVarManager.hpp"
#include "Runtime/CBasics.hpp"
#include "ViewManager.hpp"
2017-11-19 07:10:54 +00:00
#include "hecl/hecl.hpp"
2018-01-10 06:20:34 +00:00
#include "hecl/CVarCommons.hpp"
2018-01-11 09:38:08 +00:00
#include "hecl/Console.hpp"
2015-11-21 01:16:07 +00:00
static logvisor::Module AthenaLog("Athena");
static void AthenaExc(athena::error::Level level, const char* file,
const char*, int line, const char* fmt, ...)
{
va_list ap;
va_start(ap, fmt);
2016-09-11 21:17:27 +00:00
AthenaLog.report(logvisor::Level(level), fmt, ap);
va_end(ap);
}
2016-03-05 00:03:41 +00:00
namespace urde
2015-11-21 01:16:07 +00:00
{
2016-03-05 00:03:41 +00:00
static logvisor::Module Log{"URDE"};
2016-02-15 17:35:20 +00:00
2017-12-12 02:06:19 +00:00
static hecl::SystemString CPUFeatureString(const zeus::CPUInfo& cpuInf)
{
hecl::SystemString features;
2017-12-27 00:51:02 +00:00
auto AddFeature = [&features](const hecl::SystemChar* str)
2017-12-12 02:06:19 +00:00
{
if (!features.empty())
2018-10-14 20:16:21 +00:00
features += _SYS_STR(", ");
2017-12-27 00:51:02 +00:00
features += str;
};
if (cpuInf.AESNI)
2018-10-14 20:16:21 +00:00
AddFeature(_SYS_STR("AES-NI"));
2017-12-27 00:51:02 +00:00
if (cpuInf.SSE1)
2018-10-14 20:16:21 +00:00
AddFeature(_SYS_STR("SSE"));
2017-12-12 02:06:19 +00:00
if (cpuInf.SSE2)
2018-10-14 20:16:21 +00:00
AddFeature(_SYS_STR("SSE2"));
2017-12-12 02:06:19 +00:00
if (cpuInf.SSE3)
2018-10-14 20:16:21 +00:00
AddFeature(_SYS_STR("SSE3"));
2017-12-12 02:06:19 +00:00
if (cpuInf.SSSE3)
2018-10-14 20:16:21 +00:00
AddFeature(_SYS_STR("SSSE3"));
2017-12-12 02:06:19 +00:00
if (cpuInf.SSE4a)
2018-10-14 20:16:21 +00:00
AddFeature(_SYS_STR("SSE4a"));
2017-12-12 02:06:19 +00:00
if (cpuInf.SSE41)
2018-10-14 20:16:21 +00:00
AddFeature(_SYS_STR("SSE4.1"));
2017-12-12 02:06:19 +00:00
if (cpuInf.SSE42)
2018-10-14 20:16:21 +00:00
AddFeature(_SYS_STR("SSE4.2"));
2017-12-27 00:51:02 +00:00
if (cpuInf.AVX)
2018-10-14 20:16:21 +00:00
AddFeature(_SYS_STR("AVX"));
2017-12-27 00:51:02 +00:00
if (cpuInf.AVX2)
2018-10-14 20:16:21 +00:00
AddFeature(_SYS_STR("AVX2"));
2017-12-12 02:06:19 +00:00
return features;
}
2015-11-21 01:16:07 +00:00
struct Application : boo::IApplicationCallback
{
2016-03-04 23:04:53 +00:00
hecl::Runtime::FileStoreManager m_fileMgr;
hecl::CVarManager m_cvarManager;
2018-01-10 06:20:34 +00:00
hecl::CVarCommons m_cvarCommons;
2016-02-20 05:49:47 +00:00
std::unique_ptr<ViewManager> m_viewManager;
2018-06-02 00:03:31 +00:00
std::atomic_bool m_running = {true};
2015-11-22 04:35:24 +00:00
2015-11-23 08:47:57 +00:00
Application() :
2018-10-14 20:16:21 +00:00
m_fileMgr(_SYS_STR("urde")),
2018-01-10 06:20:34 +00:00
m_cvarManager(m_fileMgr),
m_cvarCommons(m_cvarManager)
2016-02-20 05:49:47 +00:00
{
m_viewManager = std::make_unique<ViewManager>(m_fileMgr, m_cvarManager);
2016-02-20 05:49:47 +00:00
}
2015-11-22 04:35:24 +00:00
virtual ~Application() = default;
2015-11-21 01:16:07 +00:00
int appMain(boo::IApplication* app)
{
2016-02-15 17:35:20 +00:00
initialize(app);
2016-02-20 05:49:47 +00:00
m_viewManager->init(app);
2018-06-02 00:03:31 +00:00
while (m_running.load())
2015-11-22 04:35:24 +00:00
{
2016-02-20 05:49:47 +00:00
if (!m_viewManager->proc())
2015-11-26 23:04:11 +00:00
break;
2015-11-22 04:35:24 +00:00
}
2016-02-20 05:49:47 +00:00
m_viewManager->stop();
2016-12-13 02:56:43 +00:00
m_viewManager->projectManager().saveProject();
2015-12-04 01:44:35 +00:00
m_cvarManager.serialize();
2016-02-20 05:49:47 +00:00
m_viewManager.reset();
2015-11-21 01:16:07 +00:00
return 0;
}
void appQuitting(boo::IApplication*)
{
2018-06-02 00:03:31 +00:00
m_running.store(false);
2015-11-21 01:16:07 +00:00
}
void appFilesOpen(boo::IApplication*, const std::vector<boo::SystemString>& paths)
{
for (const auto& path : paths)
{
hecl::ProjectRootPath projPath = hecl::SearchForProject(path);
if (projPath)
{
m_viewManager->deferOpenProject(path);
break;
}
}
}
2016-02-15 17:35:20 +00:00
void initialize(boo::IApplication* app)
2016-02-15 17:35:20 +00:00
{
2016-03-04 23:04:53 +00:00
zeus::detectCPU();
createGlobalCVars();
for (const boo::SystemString& arg : app->getArgs())
{
2018-10-14 20:16:21 +00:00
if (arg.find(_SYS_STR("--verbosity=")) == 0 || arg.find(_SYS_STR("-v=")) == 0)
{
2017-11-13 06:19:18 +00:00
hecl::SystemUTF8Conv utf8Arg(arg.substr(arg.find_last_of('=') + 1));
hecl::VerbosityLevel = atoi(utf8Arg.c_str());
hecl::LogModule.report(logvisor::Info, "Set verbosity level to %i", hecl::VerbosityLevel);
}
}
2016-02-15 17:35:20 +00:00
m_cvarManager.parseCommandLine(app->getArgs());
2016-03-04 23:04:53 +00:00
const zeus::CPUInfo& cpuInf = zeus::cpuFeatures();
Log.report(logvisor::Info, "CPU Name: %s", cpuInf.cpuBrand);
Log.report(logvisor::Info, "CPU Vendor: %s", cpuInf.cpuVendor);
2018-10-14 20:16:21 +00:00
Log.report(logvisor::Info, _SYS_STR("CPU Features: %s"), CPUFeatureString(cpuInf).c_str());
2016-02-15 17:35:20 +00:00
}
2018-01-07 05:19:49 +00:00
2018-01-10 06:20:34 +00:00
std::string getGraphicsApi() const
{
return m_cvarCommons.getGraphicsApi();
}
uint32_t getSamples() const
2018-01-07 05:19:49 +00:00
{
2018-01-10 06:20:34 +00:00
return m_cvarCommons.getSamples();
2018-01-07 05:19:49 +00:00
}
2018-01-10 06:20:34 +00:00
uint32_t getAnisotropy() const
2018-01-07 05:19:49 +00:00
{
2018-01-10 06:20:34 +00:00
return m_cvarCommons.getAnisotropy();
2018-01-07 05:19:49 +00:00
}
2018-01-11 09:38:08 +00:00
bool getDeepColor() const
{
return m_cvarCommons.getDeepColor();
}
void createGlobalCVars()
{
m_cvarManager.findOrMakeCVar("debugOverlay.playerInfo"sv, "Displays information about the player, such as location and orientation"sv, false,
hecl::CVar::EFlags::Game | hecl::CVar::EFlags::Archive | hecl::CVar::EFlags::ReadOnly);
m_cvarManager.findOrMakeCVar("debugOverlay.worldInfo"sv, "Displays information about the current world, such as world asset ID, and areaId"sv, false,
hecl::CVar::EFlags::Game | hecl::CVar::EFlags::Archive | hecl::CVar::EFlags::ReadOnly);
m_cvarManager.findOrMakeCVar("debugOverlay.areaInfo"sv, "Displays information about the current area, such as asset ID, object/layer counts, and active layer bits"sv, false,
hecl::CVar::EFlags::Game | hecl::CVar::EFlags::Archive | hecl::CVar::EFlags::ReadOnly);
m_cvarManager.findOrMakeCVar("debugOverlay.showFrameCounter"sv, "Displays the current frame index"sv, false,
hecl::CVar::EFlags::Game | hecl::CVar::EFlags::Archive | hecl::CVar::EFlags::ReadOnly);
}
2015-11-21 01:16:07 +00:00
};
}
2017-02-24 08:28:44 +00:00
static hecl::SystemChar CwdBuf[1024];
hecl::SystemString ExeDir;
2017-11-19 07:10:54 +00:00
static void SetupBasics(bool logging)
2017-10-24 03:12:10 +00:00
{
2017-12-12 02:06:19 +00:00
auto result = zeus::validateCPU();
if (!result.first)
{
#if _WIN32 && !WINDOWS_STORE
char* msg;
asprintf(&msg, "ERROR: This build of URDE requires the following CPU features:\n%s\n",
urde::CPUFeatureString(result.second).c_str());
MessageBoxA(nullptr, msg, "CPU error", MB_OK | MB_ICONERROR);
free(msg);
#else
fprintf(stderr, "ERROR: This build of URDE requires the following CPU features:\n%s\n",
urde::CPUFeatureString(result.second).c_str());
#endif
exit(1);
}
2017-10-24 03:12:10 +00:00
logvisor::RegisterStandardExceptions();
2017-11-19 07:10:54 +00:00
if (logging)
logvisor::RegisterConsoleLogger();
2017-10-24 03:12:10 +00:00
atSetExceptionHandler(AthenaExc);
}
2017-11-19 07:10:54 +00:00
static bool IsClientLoggingEnabled(int argc, const boo::SystemChar** argv)
{
for (int i = 1; i < argc; ++i)
2018-10-14 20:16:21 +00:00
if (!hecl::StrNCmp(argv[i], _SYS_STR("-l"), 2))
2017-12-06 03:26:15 +00:00
return true;
return false;
2017-11-19 07:10:54 +00:00
}
2017-12-06 03:26:15 +00:00
#if !WINDOWS_STORE
2015-11-21 01:16:07 +00:00
#if _WIN32
int wmain(int argc, const boo::SystemChar** argv)
#else
int main(int argc, const boo::SystemChar** argv)
#endif
{
2018-10-14 20:16:21 +00:00
if (argc > 1 && !hecl::StrCmp(argv[1], _SYS_STR("--dlpackage")))
2017-12-27 00:51:02 +00:00
{
printf("%s\n", URDE_DLPACKAGE);
return 100;
}
2017-11-19 07:10:54 +00:00
SetupBasics(IsClientLoggingEnabled(argc, argv));
2017-02-24 08:28:44 +00:00
if (hecl::SystemChar* cwd = hecl::Getcwd(CwdBuf, 1024))
{
2017-02-25 07:59:37 +00:00
if (hecl::PathRelative(argv[0]))
2018-10-14 20:16:21 +00:00
ExeDir = hecl::SystemString(cwd) + _SYS_STR('/');
2017-02-24 08:28:44 +00:00
hecl::SystemString Argv0(argv[0]);
2018-10-14 20:16:21 +00:00
hecl::SystemString::size_type lastIdx = Argv0.find_last_of(_SYS_STR("/\\"));
2017-02-24 08:28:44 +00:00
if (lastIdx != hecl::SystemString::npos)
ExeDir.insert(ExeDir.end(), Argv0.begin(), Argv0.begin() + lastIdx);
}
2016-03-05 00:03:41 +00:00
urde::Application appCb;
int ret = boo::ApplicationRun(boo::IApplication::EPlatformType::Auto,
2018-10-14 20:16:21 +00:00
appCb, _SYS_STR("urde"), _SYS_STR("URDE"), argc, argv, appCb.getGraphicsApi(),
appCb.getSamples(), appCb.getAnisotropy(), appCb.getDeepColor(), false);
2018-01-10 06:20:34 +00:00
//printf("IM DYING!!\n");
2015-11-21 01:16:07 +00:00
return ret;
}
2017-12-06 03:26:15 +00:00
#endif
2015-11-21 01:16:07 +00:00
2017-12-06 03:26:15 +00:00
#if WINDOWS_STORE
2017-12-07 04:13:12 +00:00
#include "boo/UWPViewProvider.hpp"
2017-10-24 03:12:10 +00:00
using namespace Windows::ApplicationModel::Core;
[Platform::MTAThread]
int WINAPIV main(Platform::Array<Platform::String^>^ params)
{
2017-12-06 03:26:15 +00:00
SetupBasics(false);
2017-10-24 03:12:10 +00:00
urde::Application appCb;
2018-10-14 20:16:21 +00:00
auto viewProvider = ref new boo::ViewProvider(appCb, _SYS_STR("urde"), _SYS_STR("URDE"), _SYS_STR("urde"), params, false);
2017-10-24 03:12:10 +00:00
CoreApplication::Run(viewProvider);
return 0;
}
#elif _WIN32
2015-11-21 01:16:07 +00:00
int APIENTRY wWinMain(HINSTANCE hInstance, HINSTANCE, LPWSTR lpCmdLine, int)
{
int argc = 0;
2018-05-28 20:27:41 +00:00
const boo::SystemChar** argv;
if (lpCmdLine[0])
argv = (const wchar_t**)(CommandLineToArgvW(lpCmdLine, &argc));
2015-11-21 01:16:07 +00:00
static boo::SystemChar selfPath[1024];
GetModuleFileNameW(nullptr, selfPath, 1024);
static const boo::SystemChar* booArgv[32] = {};
booArgv[0] = selfPath;
for (int i=0 ; i<argc ; ++i)
booArgv[i+1] = argv[i];
2017-11-19 07:10:54 +00:00
if (IsClientLoggingEnabled(argc+1, booArgv))
logvisor::CreateWin32Console();
2018-05-28 20:27:41 +00:00
return wmain(argc + 1, booArgv);
2015-11-21 01:16:07 +00:00
}
#endif
2017-10-24 03:12:10 +00:00