48 lines
1.2 KiB
C
48 lines
1.2 KiB
C
|
//
|
||
|
// Copyright Aliaksei Levin (levlam@telegram.org), Arseny Smirnov (arseny30@gmail.com) 2014-2022
|
||
|
//
|
||
|
// 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)
|
||
|
//
|
||
|
#pragma once
|
||
|
|
||
|
#include "td/utils/common.h"
|
||
|
#include "td/utils/logging.h"
|
||
|
#include "td/utils/MpscPollableQueue.h"
|
||
|
#include "td/utils/port/thread.h"
|
||
|
#include "td/utils/Slice.h"
|
||
|
#include "td/utils/Status.h"
|
||
|
|
||
|
namespace td {
|
||
|
|
||
|
class AsyncFileLog final : public LogInterface {
|
||
|
public:
|
||
|
AsyncFileLog() = default;
|
||
|
AsyncFileLog(const AsyncFileLog &) = delete;
|
||
|
AsyncFileLog &operator=(const AsyncFileLog &) = delete;
|
||
|
AsyncFileLog(AsyncFileLog &&) = delete;
|
||
|
AsyncFileLog &operator=(AsyncFileLog &&) = delete;
|
||
|
~AsyncFileLog();
|
||
|
|
||
|
Status init(string path, int64 rotate_threshold);
|
||
|
|
||
|
private:
|
||
|
struct Query {
|
||
|
enum class Type : int32 { Log, AfterRotation, Close };
|
||
|
Type type_ = Type::Log;
|
||
|
string data_;
|
||
|
};
|
||
|
|
||
|
string path_;
|
||
|
unique_ptr<MpscPollableQueue<Query>> queue_;
|
||
|
thread logging_thread_;
|
||
|
|
||
|
vector<string> get_file_paths() final;
|
||
|
|
||
|
void after_rotation() final;
|
||
|
|
||
|
void do_append(int log_level, CSlice slice) final;
|
||
|
};
|
||
|
|
||
|
} // namespace td
|