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"
|
2022-01-24 18:37:06 +00:00
|
|
|
#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()
|
|
|
|
{
|
2022-01-24 18:37:06 +00:00
|
|
|
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();
|
|
|
|
}
|
2022-01-24 18:37:06 +00:00
|
|
|
|
|
|
|
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);
|
|
|
|
}
|
|
|
|
|
2021-11-05 17:34:23 +00:00
|
|
|
AUKN_SYM AuUInt32 WriteStdOut(const void *buffer, AuUInt32 length)
|
2021-09-06 10:58:08 +00:00
|
|
|
{
|
|
|
|
return ConsoleStd::WriteStdOut(buffer, length);
|
|
|
|
}
|
|
|
|
|
2021-11-05 17:34:23 +00:00
|
|
|
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();
|
2022-01-24 18:37:06 +00:00
|
|
|
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()
|
|
|
|
{
|
2022-01-24 18:37:06 +00:00
|
|
|
gDefaultSinks.clear();
|
|
|
|
gDefaultLogger.reset();
|
|
|
|
gUserLogger.reset();
|
|
|
|
|
2021-09-06 10:58:08 +00:00
|
|
|
DeinitFlusher();
|
2022-01-24 18:37:06 +00:00
|
|
|
Logging::DeinitLoggers();
|
2021-09-06 10:58:08 +00:00
|
|
|
ConsoleFIO::Exit();
|
2022-01-24 18:37:06 +00:00
|
|
|
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
|
|
|
}
|
|
|
|
}
|