diff options
author | Stanislaw Halik <sthalik@misaki.pl> | 2022-10-09 01:06:02 +0200 |
---|---|---|
committer | Stanislaw Halik <sthalik@misaki.pl> | 2022-10-09 01:06:02 +0200 |
commit | 70dc294b8ac3a62b9c61a75e0aec3064eef72122 (patch) | |
tree | b687d0676f90051dc35f6938b2c8c151f9ed6966 /main | |
parent | 23529e7ab310764cdf1b99015fce0814b4955210 (diff) |
a
Diffstat (limited to 'main')
-rw-r--r-- | main/debug.cpp | 26 |
1 files changed, 25 insertions, 1 deletions
diff --git a/main/debug.cpp b/main/debug.cpp index ee160136..c7eeaebf 100644 --- a/main/debug.cpp +++ b/main/debug.cpp @@ -1,4 +1,5 @@ #include "app.hpp" +#include <cstring> #include <Magnum/GL/Renderer.h> namespace Magnum::Examples { @@ -14,15 +15,36 @@ using GL::DebugOutput; void app::debug_callback(GL::DebugOutput::Source src, GL::DebugOutput::Type type, UnsignedInt id, Severity severity, Containers::StringView str) const { + static thread_local Magnum::Timeline t{}; + [[maybe_unused]] volatile auto _type = type; [[maybe_unused]] volatile auto _id = id; [[maybe_unused]] volatile auto _src = src; [[maybe_unused]] volatile auto _severity = severity; [[maybe_unused]] volatile const char* _str = str.data(); + const Containers::ArrayView<const char> prefix{"Buffer detailed info: "}; + if (!std::strncmp(str.data(), prefix.data(), prefix.size()-1)) + str = str.exceptPrefix(prefix.size()-1); + + switch (severity) + { + using enum GL::DebugOutput::Severity; + case Notification: std::fputs("[DEBUG] ", stdout); break; + case Low: std::fputs("[INFO ] ", stdout); break; + case Medium: std::fputs("[NOTICE] ", stdout); break; + case High: std::fputs("[ERROR] ", stdout); break; + default: std::fputs("[?????] ", stdout); break; + } + std::puts(str.data()); std::fflush(stdout); std::fputs("", stdout); // put breakpoint here + + if (severity != Severity::Notification) + std::abort(); + + std::fputs("", stdout); // put breakpoint here } static void _debug_callback(GL::DebugOutput::Source src, GL::DebugOutput::Type type, UnsignedInt id, @@ -37,7 +59,9 @@ void* app::register_debug_callback() GL::Renderer::setFeature(Feature::DebugOutputSynchronous, true); GL::DebugOutput::setCallback(_debug_callback, this); GL::DebugOutput::setEnabled(true); - //GL::DebugOutput::setEnabled(Severity::Notification, false); + + /* Disable rather spammy "Buffer detailed info" debug messages on NVidia drivers */ + GL::DebugOutput::setEnabled(GL::DebugOutput::Source::Api, GL::DebugOutput::Type::Other, {131185}, false); return nullptr; } |