Add command line argument for disabling the logfile
This commit is contained in:
parent
36be4a89f8
commit
832298e7aa
12
src/Logger.h
12
src/Logger.h
@ -27,15 +27,27 @@ public:
|
||||
{
|
||||
public:
|
||||
|
||||
cAttachment() : m_listener(nullptr) {}
|
||||
cAttachment(cAttachment && a_other)
|
||||
: m_listener(a_other.m_listener)
|
||||
{
|
||||
a_other.m_listener = nullptr;
|
||||
}
|
||||
|
||||
~cAttachment()
|
||||
{
|
||||
if (m_listener != nullptr)
|
||||
{
|
||||
cLogger::GetInstance().DetachListener(m_listener);
|
||||
}
|
||||
}
|
||||
|
||||
cAttachment & operator=(cAttachment && a_other)
|
||||
{
|
||||
m_listener = a_other.m_listener;
|
||||
a_other.m_listener = nullptr;
|
||||
return *this;
|
||||
}
|
||||
|
||||
private:
|
||||
|
||||
|
@ -116,6 +116,10 @@ void cRoot::Start(std::unique_ptr<cSettingsRepositoryInterface> a_OverridesRepo)
|
||||
|
||||
auto consoleLogListener = MakeConsoleListener(m_RunAsService);
|
||||
auto consoleAttachment = cLogger::GetInstance().AttachListener(std::move(consoleLogListener));
|
||||
|
||||
cLogger::cAttachment fileAttachment;
|
||||
if (!a_OverridesRepo->HasValue("Server","DisableLogFile"))
|
||||
{
|
||||
auto fileLogListenerRet = MakeFileListener();
|
||||
if (!fileLogListenerRet.first)
|
||||
{
|
||||
@ -123,7 +127,8 @@ void cRoot::Start(std::unique_ptr<cSettingsRepositoryInterface> a_OverridesRepo)
|
||||
LOGERROR("Failed to open log file, aborting");
|
||||
return;
|
||||
}
|
||||
auto fileAttachment = cLogger::GetInstance().AttachListener(std::move(fileLogListenerRet.second));
|
||||
fileAttachment = cLogger::GetInstance().AttachListener(std::move(fileLogListenerRet.second));
|
||||
}
|
||||
|
||||
LOG("--- Started Log ---");
|
||||
|
||||
|
@ -391,6 +391,7 @@ static std::unique_ptr<cMemorySettingsRepository> ParseArguments(int argc, char
|
||||
TCLAP::SwitchArg crashDumpFull ("", "crash-dump-full", "Crashdumps created by the server will contain full server memory", cmd);
|
||||
TCLAP::SwitchArg crashDumpGlobals("", "crash-dump-globals", "Crashdumps created by the server will contain the global variables' values", cmd);
|
||||
TCLAP::SwitchArg noBufArg ("", "no-output-buffering", "Disable output buffering", cmd);
|
||||
TCLAP::SwitchArg noFileLogArg ("", "no-log-file", "Disable logging to file", cmd);
|
||||
TCLAP::SwitchArg runAsServiceArg ("d", "service", "Run as a service on Windows, or daemon on UNIX like systems", cmd);
|
||||
cmd.parse(argc, argv);
|
||||
|
||||
@ -413,6 +414,10 @@ static std::unique_ptr<cMemorySettingsRepository> ParseArguments(int argc, char
|
||||
repo->AddValue("Server", "Ports", std::to_string(port));
|
||||
}
|
||||
}
|
||||
if (noFileLogArg.getValue())
|
||||
{
|
||||
repo->AddValue("Server", "DisableLogFile", true);
|
||||
}
|
||||
if (commLogArg.getValue())
|
||||
{
|
||||
g_ShouldLogCommIn = true;
|
||||
|
Loading…
Reference in New Issue
Block a user