summaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
-rw-r--r--editor/app.cpp53
-rw-r--r--editor/draw.cpp7
-rw-r--r--floormat/settings.hpp6
-rw-r--r--main/debug.cpp1
-rw-r--r--main/setup.cpp14
5 files changed, 25 insertions, 56 deletions
diff --git a/editor/app.cpp b/editor/app.cpp
index 9ee59844..5920c6fb 100644
--- a/editor/app.cpp
+++ b/editor/app.cpp
@@ -30,36 +30,23 @@ int app::exec()
return M->exec();
}
-static const char* const true_values[] = { "1", "true", "yes", "y", "Y", "on", "ON", };
-static const char* const false_values[] = { "0", "false", "no", "n", "N", "off", "OFF", };
+static const char* const true_values[] = { "1", "true", "yes", "y", "Y", "on", "ON", "enable", "enabled", };
+static const char* const false_values[] = { "0", "false", "no", "n", "N", "off", "OFF", "disable", "disabled", };
static const char* const maybe_values[] = { "maybe", "m", "M", "default", };
template<typename T, typename U>
static inline bool find_arg(const T& list, const U& value) {
- return std::find_if(std::cbegin(list), std::cend(list),
- [&](const auto& x) { return x == value; }) != std::cend(list);
+ return std::find_if(std::cbegin(list), std::cend(list), [&](const auto& x) { return x == value; }) != std::cend(list);
}
-static fm_tristate parse_tristate(StringView name, StringView str, fm_tristate def)
-{
- if (find_arg(true_values, str))
- return fm_tristate::on;
- else if (find_arg(false_values, str))
- return fm_tristate::off;
- else if (find_arg(maybe_values, str))
- return fm_tristate::maybe;
-
- fm_warn("invalid '%s' argument '%s': should be true, false or default", name.data(), str.data());
- return def;
-}
-
-static bool parse_bool(StringView name, StringView str, bool def)
+static bool parse_bool(StringView name, const Corrade::Utility::Arguments& args, bool def)
{
+ StringView str = args.value<StringView>(name);
if (find_arg(true_values, str))
return true;
else if (find_arg(false_values, str))
return false;
- fm_warn("invalid '%s' argument '%s': should be true or false", name.data(), str.data());
+ fm_warn("invalid '--%s' argument '%s': should be true or false", name.data(), str.data());
return def;
}
@@ -68,25 +55,19 @@ int app::run_from_argv(const int argc, const char* const* const argv)
fm_settings opts;
Corrade::Utility::Arguments args{};
args.addOption("vsync", "m")
- .addOption("gpu-validation", "m")
+ .addOption("gpu-debug", "m")
.addOption("msaa", "1")
.parse(argc, argv);
- opts.vsync = parse_tristate("--vsync", args.value<StringView>("vsync"), opts.vsync);
- opts.msaa = parse_bool("--msaa", args.value<StringView>("msaa"), opts.msaa);
- {
- auto str = args.value<StringView>("gpu-validation");
- if (str == "no-error" || str == "NO-ERROR")
- opts.gpu_debug = fm_gpu_debug::no_error;
- else if (str == "robust" || str == "ROBUST")
- opts.gpu_debug = fm_gpu_debug::robust;
- else switch (parse_tristate("--gpu-validation", args.value<StringView>("gpu-validation"), fm_tristate::maybe))
- {
- default:
- case fm_tristate::on: opts.gpu_debug = fm_gpu_debug::on; break;
- case fm_tristate::off: opts.gpu_debug = fm_gpu_debug::off; break;
- }
- }
- opts.vsync = parse_tristate("--vsync", args.value<StringView>("vsync"), opts.vsync);
+ opts.vsync = parse_bool("vsync", args, opts.vsync);
+ opts.msaa = parse_bool("msaa", args, opts.msaa);
+ if (auto str = args.value<StringView>("gpu-validation"); str == "no-error" || str == "NO-ERROR")
+ opts.gpu_debug = fm_gpu_debug::no_error;
+ else if (str == "robust" || str == "ROBUST")
+ opts.gpu_debug = fm_gpu_debug::robust;
+ else
+ opts.gpu_debug = parse_bool("gpu-validation", args, opts.gpu_debug > fm_gpu_debug::off)
+ ? fm_gpu_debug::on
+ : fm_gpu_debug::off;
int ret;
Pointer<floormat_main> ptr;
diff --git a/editor/draw.cpp b/editor/draw.cpp
index c0ee7d1a..0c356268 100644
--- a/editor/draw.cpp
+++ b/editor/draw.cpp
@@ -12,7 +12,6 @@ void app::draw_wireframe_quad(global_coords pos)
const auto pt = pos.to_signed();
auto& shader = M->shader();
- //if (const auto& [c, tile] = _world[pos]; tile.ground_image)
{
const Vector3 center{pt[0]*TILE_SIZE[0], pt[1]*TILE_SIZE[1], 0};
shader.set_tint({1, 0, 0, 1});
@@ -46,13 +45,7 @@ void app::draw_msaa()
void app::draw()
{
- const bool debug = M->settings().gpu_debug >= fm_gpu_debug::on;
- if (debug)
- GL::DebugOutput::setEnabled(GL::DebugOutput::Source::Api, GL::DebugOutput::Type::Other, {131185}, false); // nvidia krap
render_menu();
- if (debug)
- GL::DebugOutput::setEnabled(GL::DebugOutput::Source::Api, GL::DebugOutput::Type::Other, {131185}, true); // nvidia krap
}
} // namespace floormat
-
diff --git a/floormat/settings.hpp b/floormat/settings.hpp
index 0a526478..5dcdf26e 100644
--- a/floormat/settings.hpp
+++ b/floormat/settings.hpp
@@ -21,15 +21,15 @@ struct fm_settings
Corrade::Containers::String title{"Test"};
Corrade::Containers::String disabled_extensions; // TODO
std::uint8_t msaa_samples = 16;
- fm_tristate vsync = fm_tristate::maybe;
+ bool vsync = true;
fm_gpu_debug gpu_debug = fm_gpu_debug::on;
fm_log_level log_level = fm_log_level::normal;
std::uint8_t resizable : 1 = true,
fullscreen : 1 = false,
fullscreen_desktop : 1 = false,
borderless : 1 = false,
- maximized : 1 = false,
- msaa : 1 = true;
+ maximized : 1 = true,
+ msaa : 1 = false;
};
} // namespace floormat
diff --git a/main/debug.cpp b/main/debug.cpp
index e5b3c2cf..14f6131e 100644
--- a/main/debug.cpp
+++ b/main/debug.cpp
@@ -59,6 +59,7 @@ static void _debug_callback(GL::DebugOutput::Source src, GL::DebugOutput::Type t
void main_impl::register_debug_callback()
{
+ GL::DebugOutput::setEnabled(GL::DebugOutput::Source::Api, GL::DebugOutput::Type::Other, {131185}, false); // nvidia krap
GL::DebugOutput::setCallback(_debug_callback, this);
}
diff --git a/main/setup.cpp b/main/setup.cpp
index 48ee7832..b6488bad 100644
--- a/main/setup.cpp
+++ b/main/setup.cpp
@@ -8,20 +8,15 @@ main_impl::main_impl(floormat_app& app, fm_settings&& s, int& fake_argc) noexcep
make_conf(s), make_gl_conf(s)},
s{std::move(s)}, app{app}
{
- switch (s.vsync) // NOLINT(bugprone-use-after-move)
+ if (s.vsync)
{
- case fm_tristate::on:
(void)setSwapInterval(1);
if (const auto list = GL::Context::current().extensionStrings();
std::find(list.cbegin(), list.cend(), "EXT_swap_control_tear") != list.cbegin())
(void)setSwapInterval(-1);
- break;
- case fm_tristate::off:
- setSwapInterval(0);
- break;
- default:
- break;
}
+ else
+ (void)setSwapInterval(0);
set_fp_mask();
fm_assert(framebufferSize() == windowSize());
timeline.start();
@@ -97,8 +92,7 @@ void main_impl::update_window_state()
dt_expected.jitter = 0;
if (flags & SDL_WINDOW_HIDDEN)
dt_expected.value = 1;
- else if (int interval = std::abs(SDL_GL_GetSwapInterval());
- s.vsync >= fm_tristate::maybe && interval > 0)
+ else if (int interval = std::abs(SDL_GL_GetSwapInterval()); s.vsync && interval > 0)
{
int hz = get_window_refresh_rate(window()) / interval;
if (!(flags & SDL_WINDOW_INPUT_FOCUS))