You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
73 lines
1.6 KiB
73 lines
1.6 KiB
/*
|
|
* Copyright (c) 2016-present, Facebook, Inc.
|
|
* All rights reserved.
|
|
*
|
|
* This source code is licensed under both the BSD-style license (found in the
|
|
* LICENSE file in the root directory of this source tree) and the GPLv2 (found
|
|
* in the COPYING file in the root directory of this source tree).
|
|
*/
|
|
#pragma once
|
|
|
|
#include <cstdio>
|
|
#include <mutex>
|
|
|
|
namespace pzstd {
|
|
|
|
constexpr int kLogError = 1;
|
|
constexpr int kLogInfo = 2;
|
|
constexpr int kLogDebug = 3;
|
|
constexpr int kLogVerbose = 4;
|
|
|
|
class Logger {
|
|
std::mutex mutex_;
|
|
FILE* out_;
|
|
const int level_;
|
|
|
|
using Clock = std::chrono::system_clock;
|
|
Clock::time_point lastUpdate_;
|
|
std::chrono::milliseconds refreshRate_;
|
|
|
|
public:
|
|
explicit Logger(int level, FILE* out = stderr)
|
|
: out_(out), level_(level), lastUpdate_(Clock::now()),
|
|
refreshRate_(150) {}
|
|
|
|
|
|
bool logsAt(int level) {
|
|
return level <= level_;
|
|
}
|
|
|
|
template <typename... Args>
|
|
void operator()(int level, const char *fmt, Args... args) {
|
|
if (level > level_) {
|
|
return;
|
|
}
|
|
std::lock_guard<std::mutex> lock(mutex_);
|
|
std::fprintf(out_, fmt, args...);
|
|
}
|
|
|
|
template <typename... Args>
|
|
void update(int level, const char *fmt, Args... args) {
|
|
if (level > level_) {
|
|
return;
|
|
}
|
|
std::lock_guard<std::mutex> lock(mutex_);
|
|
auto now = Clock::now();
|
|
if (now - lastUpdate_ > refreshRate_) {
|
|
lastUpdate_ = now;
|
|
std::fprintf(out_, "\r");
|
|
std::fprintf(out_, fmt, args...);
|
|
}
|
|
}
|
|
|
|
void clear(int level) {
|
|
if (level > level_) {
|
|
return;
|
|
}
|
|
std::lock_guard<std::mutex> lock(mutex_);
|
|
std::fprintf(out_, "\r%79s\r", "");
|
|
}
|
|
};
|
|
|
|
}
|