lokinet/llarp/util/logging/file_logger.hpp

72 lines
1.4 KiB
C++
Raw Normal View History

#pragma once
#include "logstream.hpp"
2019-09-01 12:10:49 +00:00
#include <llarp/util/thread/queue.hpp>
#include <llarp/util/time.hpp>
#include <deque>
namespace llarp
{
/// flushable file based log stream
struct FileLogStream : public ILogStream
{
using Work_t = std::function<void(void)>;
FileLogStream(
std::function<void(Work_t)> io, FILE* f, llarp_time_t flushInterval, bool closefile = true);
2019-07-30 23:42:13 +00:00
~FileLogStream() override;
void
PreLog(
std::stringstream& out,
LogLevel lvl,
const char* fname,
int lineno,
const std::string& nodename) const override;
void
Print(LogLevel, const char*, const std::string& msg) override;
void
Tick(llarp_time_t now) override;
void
2019-11-15 21:16:46 +00:00
PostLog(std::stringstream&) const override{};
void
AppendLog(
LogLevel lvl,
const char* fname,
int lineno,
const std::string& nodename,
const std::string msg) override;
virtual void
ImmediateFlush() override;
using Lines_t = thread::Queue<std::string>;
2019-11-15 21:10:51 +00:00
2019-06-13 13:26:34 +00:00
protected:
2019-11-15 21:10:51 +00:00
Lines_t m_Lines;
2019-06-13 13:26:34 +00:00
private:
2019-11-15 21:16:46 +00:00
static void
Flush(Lines_t* const, FILE* const);
bool
ShouldFlush(llarp_time_t now) const;
void
FlushLinesToDisk(llarp_time_t now);
const std::function<void(Work_t)> m_Disk;
2019-06-13 13:26:34 +00:00
FILE* const m_File;
const llarp_time_t m_FlushInterval;
2020-02-24 19:40:45 +00:00
llarp_time_t m_LastFlush = 0s;
2019-06-13 13:26:34 +00:00
const bool m_Close;
};
} // namespace llarp