ClickHouse/libs/libdaemon/include/daemon/OwnFormattingChannel.h
2018-06-28 23:04:13 +03:00

56 lines
1.3 KiB
C++

#pragma once
#include <daemon/ExtendedLogChannel.h>
#include <Poco/AutoPtr.h>
#include <Poco/Channel.h>
#include <Poco/FormattingChannel.h>
class OwnPatternFormatter;
namespace DB
{
// Like Poco::FormattingChannel but supports the extended logging interface and log level filter
class OwnFormattingChannel : public Poco::Channel, public ExtendedLogChannel
{
public:
explicit OwnFormattingChannel(Poco::AutoPtr<OwnPatternFormatter> pFormatter_ = nullptr, Poco::AutoPtr<Poco::Channel> pChannel_ = nullptr)
: pFormatter(std::move(pFormatter_)), pChannel(std::move(pChannel_)) {}
void setChannel(Poco::AutoPtr<Poco::Channel> pChannel_)
{
pChannel = std::move(pChannel_);
}
void setLevel(Poco::Message::Priority priority_)
{
priority = priority_;
}
void open() override
{
if (pChannel)
pChannel->open();
}
void close() override
{
if (pChannel)
pChannel->close();
}
void log(const Poco::Message & msg) override;
void logExtended(const ExtendedLogMessage & msg) override;
~OwnFormattingChannel() override;
private:
Poco::AutoPtr<OwnPatternFormatter> pFormatter;
Poco::AutoPtr<Poco::Channel> pChannel;
Poco::Message::Priority priority = Poco::Message::PRIO_TRACE;
};
}