/* XMRig * Copyright 2010 Jeff Garzik * Copyright 2012-2014 pooler * Copyright 2014 Lucas Jones * Copyright 2014-2016 Wolf9466 * Copyright 2016 Jay D Dee * Copyright 2017-2018 XMR-Stak , * Copyright 2018-2019 SChernykh * Copyright 2016-2019 XMRig , * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see . */ #include #include #include #include #include #include "common/interfaces/ILogBackend.h" #include "common/log/BasicLog.h" #include "common/log/Log.h" namespace xmrig { Log *Log::m_self = nullptr; bool Log::colors = true; static const char *color[5] = { "\x1B[0;31m", /* ERR */ "\x1B[0;33m", /* WARNING */ "\x1B[1;37m", /* NOTICE */ "", /* INFO */ # ifdef WIN32 "\x1B[1;30m" /* DEBUG */ # else "\x1B[90m" /* DEBUG */ # endif }; } /* namespace xmrig */ void xmrig::Log::message(ILogBackend::Level level, const char* fmt, ...) { uv_mutex_lock(&m_mutex); va_list args; va_list copy; va_start(args, fmt); for (ILogBackend *backend : m_backends) { va_copy(copy, args); backend->message(level, fmt, copy); va_end(copy); } va_end(args); uv_mutex_unlock(&m_mutex); } void xmrig::Log::text(const char* fmt, ...) { uv_mutex_lock(&m_mutex); va_list args; va_list copy; va_start(args, fmt); for (ILogBackend *backend : m_backends) { va_copy(copy, args); backend->text(fmt, copy); va_end(copy); } va_end(args); uv_mutex_unlock(&m_mutex); } const char *xmrig::Log::colorByLevel(ILogBackend::Level level, bool isColors) { if (!isColors) { return ""; } return color[level]; } const char *xmrig::Log::endl(bool isColors) { # ifdef _WIN32 return isColors ? "\x1B[0m\r\n" : "\r\n"; # else return isColors ? "\x1B[0m\n" : "\n"; # endif } void xmrig::Log::defaultInit() { m_self = new Log(); add(new BasicLog()); } xmrig::Log::~Log() { m_self = nullptr; for (auto backend : m_backends) { delete backend; } }