Files
deskflow/src/lib/base/LogOutputters.cpp
2025-03-25 14:11:23 +00:00

209 lines
3.4 KiB
C++

/*
* Deskflow -- mouse and keyboard sharing utility
* SPDX-FileCopyrightText: (C) 2025 Deskflow Developers
* SPDX-FileCopyrightText: (C) 2012 - 2016 Symless Ltd.
* SPDX-FileCopyrightText: (C) 2002 Chris Schoeneman
* SPDX-License-Identifier: GPL-2.0-only WITH LicenseRef-OpenSSL-Exception
*/
#include "base/LogOutputters.h"
#include "arch/Arch.h"
#include "base/Path.h"
#include "base/String.h"
#include <fstream>
enum EFileLogOutputter
{
kFileSizeLimit = 1024 // kb
};
//
// StopLogOutputter
//
StopLogOutputter::StopLogOutputter()
{
// do nothing
}
StopLogOutputter::~StopLogOutputter()
{
// do nothing
}
void StopLogOutputter::open(const char *)
{
// do nothing
}
void StopLogOutputter::close()
{
// do nothing
}
void StopLogOutputter::show(bool)
{
// do nothing
}
bool StopLogOutputter::write(ELevel, const char *)
{
return false;
}
//
// ConsoleLogOutputter
//
ConsoleLogOutputter::ConsoleLogOutputter()
{
}
ConsoleLogOutputter::~ConsoleLogOutputter()
{
}
void ConsoleLogOutputter::open(const char *title)
{
ARCH->openConsole(title);
}
void ConsoleLogOutputter::close()
{
ARCH->closeConsole();
}
void ConsoleLogOutputter::show(bool showIfEmpty)
{
ARCH->showConsole(showIfEmpty);
}
bool ConsoleLogOutputter::write(ELevel level, const char *msg)
{
ARCH->writeConsole(level, msg);
return true;
}
void ConsoleLogOutputter::flush()
{
}
//
// SystemLogOutputter
//
SystemLogOutputter::SystemLogOutputter()
{
// do nothing
}
SystemLogOutputter::~SystemLogOutputter()
{
// do nothing
}
void SystemLogOutputter::open(const char *title)
{
ARCH->openLog(title);
}
void SystemLogOutputter::close()
{
ARCH->closeLog();
}
void SystemLogOutputter::show(bool showIfEmpty)
{
ARCH->showLog(showIfEmpty);
}
bool SystemLogOutputter::write(ELevel level, const char *msg)
{
ARCH->writeLog(level, msg);
return true;
}
//
// SystemLogger
//
SystemLogger::SystemLogger(const char *title, bool blockConsole) : m_stop(NULL)
{
// redirect log messages
if (blockConsole) {
m_stop = new StopLogOutputter; // NOSONAR - Adopted by `Log`
CLOG->insert(m_stop);
}
m_syslog = new SystemLogOutputter; // NOSONAR - Adopted by `Log`
m_syslog->open(title);
CLOG->insert(m_syslog);
}
SystemLogger::~SystemLogger()
{
CLOG->remove(m_syslog);
delete m_syslog;
if (m_stop != NULL) {
CLOG->remove(m_stop);
delete m_stop;
}
}
//
// FileLogOutputter
//
FileLogOutputter::FileLogOutputter(const char *logFile)
{
setLogFilename(logFile);
}
FileLogOutputter::~FileLogOutputter()
{
}
void FileLogOutputter::setLogFilename(const char *logFile)
{
assert(logFile != NULL);
m_fileName = logFile;
}
bool FileLogOutputter::write(ELevel level, const char *message)
{
bool moveFile = false;
std::ofstream m_handle;
m_handle.open(deskflow::filesystem::path(m_fileName), std::fstream::app);
if (m_handle.is_open() && m_handle.fail() != true) {
m_handle << message << std::endl;
// when file size exceeds limits, move to 'old log' filename.
size_t p = m_handle.tellp();
if (p > (kFileSizeLimit * 1024)) {
moveFile = true;
}
}
m_handle.close();
if (moveFile) {
std::string oldLogFilename = deskflow::string::sprintf("%s.1", m_fileName.c_str());
remove(oldLogFilename.c_str());
rename(m_fileName.c_str(), oldLogFilename.c_str());
}
return true;
}
void FileLogOutputter::open(const char *title)
{
}
void FileLogOutputter::close()
{
}
void FileLogOutputter::show(bool showIfEmpty)
{
}