/*** Copyright (C) 2022 J Reece Wilson (a/k/a "Reece"). All rights reserved. File: StdConsole.cpp Date: 2022-2-5 Author: Reece ***/ #include #include "StdConsole.hpp" #include #include namespace Aurora::Logging::Sinks { void ConsoleStdLogger::OnMessageBlocking(AuUInt8 level, const ConsoleMessage &msg) { if (!gRuntimeConfig.console.asyncWrite) return; if (Console::ConsoleTTY::gTTYConsoleEnabled) { Console::ConsoleTTY::WriteTTYOut(msg); } else { Console::ConsoleStd::WriteStdOut(level, msg); } } bool ConsoleStdLogger::OnMessageNonblocking(AuUInt8 level, const ConsoleMessage &msg) { if (gRuntimeConfig.console.asyncWrite) return true; if (Console::ConsoleTTY::gTTYConsoleEnabled) { Console::ConsoleTTY::WriteTTYOut(msg); } else { Console::ConsoleStd::WriteStdOut(level, msg); } return {}; } // Flushing is handled by grug -> console subsystem -> console std void ConsoleStdLogger::OnFlush() {} IBasicSink *NewStdSinkNew() { return &gStdConsoleSink; } void NewStdSinkRelease(IBasicSink *registry) {} }