2018-12-31 22:04:05 +03:00
|
|
|
//
|
2018-01-02 16:42:31 +03:00
|
|
|
// Copyright Aliaksei Levin (levlam@telegram.org), Arseny Smirnov (arseny30@gmail.com) 2014-2018
|
2018-12-31 22:04:05 +03:00
|
|
|
//
|
|
|
|
// Distributed under the Boost Software License, Version 1.0. (See accompanying
|
|
|
|
// file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)
|
|
|
|
//
|
|
|
|
#include "td/telegram/Log.h"
|
|
|
|
|
2018-01-09 12:40:56 +03:00
|
|
|
#include "td/utils/common.h"
|
2018-12-31 22:04:05 +03:00
|
|
|
#include "td/utils/FileLog.h"
|
|
|
|
#include "td/utils/logging.h"
|
2018-01-28 21:13:25 +03:00
|
|
|
#include "td/utils/Slice.h"
|
2018-12-31 22:04:05 +03:00
|
|
|
|
2018-09-01 22:44:20 +03:00
|
|
|
#include <mutex>
|
|
|
|
|
2018-12-31 22:04:05 +03:00
|
|
|
namespace td {
|
2018-01-09 12:40:56 +03:00
|
|
|
|
2018-09-01 22:44:20 +03:00
|
|
|
static std::mutex log_mutex;
|
2018-01-09 12:40:56 +03:00
|
|
|
static FileLog file_log;
|
|
|
|
static TsLog ts_log(&file_log);
|
|
|
|
static int64 max_log_file_size = 10 << 20;
|
2018-01-24 18:45:57 +03:00
|
|
|
static Log::FatalErrorCallbackPtr fatal_error_callback;
|
|
|
|
|
|
|
|
static void fatal_error_callback_wrapper(CSlice message) {
|
|
|
|
CHECK(fatal_error_callback != nullptr);
|
|
|
|
fatal_error_callback(message.c_str());
|
|
|
|
}
|
2018-01-09 12:40:56 +03:00
|
|
|
|
2018-01-28 19:38:59 +03:00
|
|
|
bool Log::set_file_path(string file_path) {
|
2018-09-01 22:44:20 +03:00
|
|
|
std::lock_guard<std::mutex> lock(log_mutex);
|
2018-01-09 12:40:56 +03:00
|
|
|
if (file_path.empty()) {
|
2018-12-31 22:04:05 +03:00
|
|
|
log_interface = default_log_interface;
|
2018-01-28 19:38:59 +03:00
|
|
|
return true;
|
2018-12-31 22:04:05 +03:00
|
|
|
}
|
|
|
|
|
2018-01-28 17:48:11 +03:00
|
|
|
if (file_log.init(file_path, max_log_file_size)) {
|
|
|
|
log_interface = &ts_log;
|
2018-01-28 19:38:59 +03:00
|
|
|
return true;
|
2018-01-28 17:48:11 +03:00
|
|
|
}
|
2018-01-28 19:38:59 +03:00
|
|
|
|
|
|
|
return false;
|
2018-12-31 22:04:05 +03:00
|
|
|
}
|
|
|
|
|
2018-01-09 12:40:56 +03:00
|
|
|
void Log::set_max_file_size(int64 max_file_size) {
|
2018-09-01 22:44:20 +03:00
|
|
|
std::lock_guard<std::mutex> lock(log_mutex);
|
2018-02-12 13:37:54 +03:00
|
|
|
max_log_file_size = max(max_file_size, static_cast<int64>(0));
|
2018-01-09 12:40:56 +03:00
|
|
|
file_log.set_rotate_threshold(max_log_file_size);
|
|
|
|
}
|
|
|
|
|
2018-12-31 22:04:05 +03:00
|
|
|
void Log::set_verbosity_level(int new_verbosity_level) {
|
2018-09-01 22:44:20 +03:00
|
|
|
std::lock_guard<std::mutex> lock(log_mutex);
|
2018-08-25 03:08:10 +03:00
|
|
|
if (0 <= new_verbosity_level && new_verbosity_level <= 1024) {
|
|
|
|
SET_VERBOSITY_LEVEL(VERBOSITY_NAME(FATAL) + new_verbosity_level);
|
|
|
|
}
|
2018-12-31 22:04:05 +03:00
|
|
|
}
|
2018-01-09 12:40:56 +03:00
|
|
|
|
2018-01-24 18:45:57 +03:00
|
|
|
void Log::set_fatal_error_callback(FatalErrorCallbackPtr callback) {
|
2018-09-01 22:44:20 +03:00
|
|
|
std::lock_guard<std::mutex> lock(log_mutex);
|
2018-01-24 18:45:57 +03:00
|
|
|
if (callback == nullptr) {
|
|
|
|
fatal_error_callback = nullptr;
|
|
|
|
set_log_fatal_error_callback(nullptr);
|
|
|
|
} else {
|
|
|
|
fatal_error_callback = callback;
|
|
|
|
set_log_fatal_error_callback(fatal_error_callback_wrapper);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-12-31 22:04:05 +03:00
|
|
|
} // namespace td
|