2022-10-09 13:04:57 +03:00
|
|
|
//
|
|
|
|
// 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 {
|
|
|
|
|
2022-11-09 14:48:14 +03:00
|
|
|
#if !TD_THREAD_UNSUPPORTED
|
|
|
|
|
2022-10-09 13:04:57 +03:00
|
|
|
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();
|
|
|
|
|
2022-10-15 10:17:42 +03:00
|
|
|
Status init(string path, int64 rotate_threshold, bool redirect_stderr = true);
|
2022-10-09 13:04:57 +03:00
|
|
|
|
|
|
|
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;
|
|
|
|
};
|
|
|
|
|
2022-11-09 14:48:14 +03:00
|
|
|
#endif
|
|
|
|
|
2022-10-09 13:04:57 +03:00
|
|
|
} // namespace td
|