AuroraRuntime/Source/Console/Console.cpp

139 lines
3.1 KiB
C++
Raw Normal View History

2021-06-27 21:25:29 +00:00
/***
Copyright (C) 2021 J Reece Wilson (a/k/a "Reece"). All rights reserved.
File: Console.cpp
Date: 2021-6-8
Author: Reece
***/
2021-09-30 14:57:41 +00:00
#include <Source/RuntimeInternal.hpp>
2021-06-27 21:25:29 +00:00
#include "Console.hpp"
#include "Commands/Commands.hpp"
#include "Hooks/Hooks.hpp"
#include "Logging/Logger.hpp"
2021-09-06 10:58:08 +00:00
#include "ConsoleStd/ConsoleStd.hpp"
2021-06-27 21:25:29 +00:00
#include "ConsoleWxWidgets/ConsoleWxWidgets.hpp"
2021-09-06 10:58:08 +00:00
#include "ConsoleFIO/ConsoleFIO.hpp"
#include "Flusher.hpp"
2021-06-27 21:25:29 +00:00
namespace Aurora::Console
{
2022-01-21 22:37:29 +00:00
static AuList<AuSPtr<IBasicSink>> gDefaultSinks;
static AuSPtr<ILogger> gDefaultLogger;
static AuSPtr<ILogger> gUserLogger;
static AuSPtr<ILogger> CreateDefaultLogger()
{
return Logging::NewLoggerShared(gDefaultSinks);
2022-01-21 22:37:29 +00:00
}
AUKN_SYM void WriteLine(AuUInt8 level, const ConsoleMessage &msg)
2021-06-27 21:25:29 +00:00
{
Hooks::WriteLine(msg);
2022-01-21 22:37:29 +00:00
if (gUserLogger)
{
gUserLogger->WriteMessage(level, msg);
}
else if (!gDefaultLogger)
{
auto tmp = CreateDefaultLogger();
if (tmp)
{
tmp->WriteMessage(level, msg);
}
}
else
{
gDefaultLogger->WriteMessage(level, msg);
}
2021-06-27 21:25:29 +00:00
}
2022-01-21 22:37:29 +00:00
void AddDefaultLogger(const AuSPtr<IBasicSink> &logger)
{
gDefaultSinks.push_back(logger);
}
static void FinailizeDefaultLogger()
{
gDefaultLogger = CreateDefaultLogger();
//gDefaultSinks.clear();
}
AUKN_SYM void SetGlobalLogger(const AuSPtr<Logging::ILogger> &defaultGlobalLogger)
{
gUserLogger = defaultGlobalLogger;
}
AUKN_SYM AuSPtr<Logging::ILogger> GetDefaultLogInterface()
{
return gDefaultLogger;
}
2022-01-21 22:37:29 +00:00
2021-09-06 10:58:08 +00:00
AUKN_SYM AuUInt32 ReadStdIn(void *buffer, AuUInt32 length)
{
return ConsoleStd::ReadStdIn(buffer, length);
}
AUKN_SYM AuUInt32 WriteStdOut(const void *buffer, AuUInt32 length)
2021-09-06 10:58:08 +00:00
{
return ConsoleStd::WriteStdOut(buffer, length);
}
AUKN_SYM bool DispatchRawLine(const AuString &string)
{
if (Hooks::gExternalLineProcessor)
{
Hooks::gExternalLineProcessor->OnProcessedLineUTF8(string);
return true;
}
return Commands::DispatchCommand(string);
}
2021-06-27 21:25:29 +00:00
void Init()
{
2021-09-06 10:58:08 +00:00
Hooks::Init();
ConsoleStd::Init();
2021-06-27 21:25:29 +00:00
ConsoleWxWidgets::Init();
}
void Init2()
{
2021-09-06 10:58:08 +00:00
ConsoleFIO::Init();
InitFlusher();
2022-01-21 22:37:29 +00:00
FinailizeDefaultLogger();
Logging::InitLoggers();
2021-06-27 21:25:29 +00:00
}
void Pump()
{
Commands::PumpCommands();
2021-09-06 10:58:08 +00:00
ConsoleStd::Pump();
2021-06-27 21:25:29 +00:00
ConsoleWxWidgets::Pump();
2021-09-06 10:58:08 +00:00
ConsoleFIO::Pump();
2021-06-27 21:25:29 +00:00
}
void Exit()
{
gDefaultSinks.clear();
gDefaultLogger.reset();
gUserLogger.reset();
2021-09-06 10:58:08 +00:00
DeinitFlusher();
Logging::DeinitLoggers();
2021-09-06 10:58:08 +00:00
ConsoleFIO::Exit();
ConsoleWxWidgets::Exit();
ConsoleStd::Exit();
2021-09-06 10:58:08 +00:00
Hooks::Deinit();
}
AUKN_SYM void OpenLateStd()
{
ConsoleStd::Start();
2022-01-21 22:37:29 +00:00
FinailizeDefaultLogger();
2021-09-06 10:58:08 +00:00
}
AUKN_SYM void OpenLateGUI()
{
ConsoleWxWidgets::Start();
2021-06-27 21:25:29 +00:00
}
}