summaryrefslogtreecommitdiffhomepage
path: root/main/debug.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'main/debug.cpp')
-rw-r--r--main/debug.cpp26
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;
}