aboutsummaryrefslogtreecommitdiffstats
path: root/contrib/libs/poco/Foundation/include/Poco/ConsoleChannel.h
diff options
context:
space:
mode:
authorDevtools Arcadia <arcadia-devtools@yandex-team.ru>2022-02-07 18:08:42 +0300
committerDevtools Arcadia <arcadia-devtools@mous.vla.yp-c.yandex.net>2022-02-07 18:08:42 +0300
commit1110808a9d39d4b808aef724c861a2e1a38d2a69 (patch)
treee26c9fed0de5d9873cce7e00bc214573dc2195b7 /contrib/libs/poco/Foundation/include/Poco/ConsoleChannel.h
downloadydb-1110808a9d39d4b808aef724c861a2e1a38d2a69.tar.gz
intermediate changes
ref:cde9a383711a11544ce7e107a78147fb96cc4029
Diffstat (limited to 'contrib/libs/poco/Foundation/include/Poco/ConsoleChannel.h')
-rw-r--r--contrib/libs/poco/Foundation/include/Poco/ConsoleChannel.h187
1 files changed, 187 insertions, 0 deletions
diff --git a/contrib/libs/poco/Foundation/include/Poco/ConsoleChannel.h b/contrib/libs/poco/Foundation/include/Poco/ConsoleChannel.h
new file mode 100644
index 0000000000..28aab6e3ef
--- /dev/null
+++ b/contrib/libs/poco/Foundation/include/Poco/ConsoleChannel.h
@@ -0,0 +1,187 @@
+//
+// ConsoleChannel.h
+//
+// Library: Foundation
+// Package: Logging
+// Module: ConsoleChannel
+//
+// Definition of the ConsoleChannel class.
+//
+// Copyright (c) 2004-2006, Applied Informatics Software Engineering GmbH.
+// and Contributors.
+//
+// SPDX-License-Identifier: BSL-1.0
+//
+
+
+#ifndef Foundation_ConsoleChannel_INCLUDED
+#define Foundation_ConsoleChannel_INCLUDED
+
+
+#include "Poco/Foundation.h"
+#include "Poco/Channel.h"
+#include "Poco/Mutex.h"
+#include <ostream>
+
+
+namespace Poco {
+
+
+class Foundation_API ConsoleChannel: public Channel
+ /// A channel that writes to an ostream.
+ ///
+ /// Only the message's text is written, followed
+ /// by a newline.
+ ///
+ /// Chain this channel to a FormattingChannel with an
+ /// appropriate Formatter to control what is contained
+ /// in the text.
+ ///
+ /// Similar to StreamChannel, except that a static
+ /// mutex is used to protect against multiple
+ /// console channels concurrently writing to the
+ /// same stream.
+{
+public:
+ ConsoleChannel();
+ /// Creates the channel and attaches std::clog.
+
+ ConsoleChannel(std::ostream& str);
+ /// Creates the channel using the given stream.
+
+ void log(const Message& msg);
+ /// Logs the given message to the channel's stream.
+
+protected:
+ ~ConsoleChannel();
+
+private:
+ std::ostream& _str;
+ static FastMutex _mutex;
+};
+
+
+class Foundation_API ColorConsoleChannel: public Channel
+ /// A channel that writes to an ostream.
+ ///
+ /// Only the message's text is written, followed
+ /// by a newline.
+ ///
+ /// Messages can be colored depending on priority.
+ /// The console device must support ANSI escape codes
+ /// in order to display colored messages.
+ ///
+ /// To enable message coloring, set the "enableColors"
+ /// property to true (default). Furthermore, colors can be
+ /// configured by setting the following properties
+ /// (default values are given in parenthesis):
+ ///
+ /// * traceColor (gray)
+ /// * debugColor (gray)
+ /// * informationColor (default)
+ /// * noticeColor (default)
+ /// * warningColor (yellow)
+ /// * errorColor (lightRed)
+ /// * criticalColor (lightRed)
+ /// * fatalColor (lightRed)
+ ///
+ /// The following color values are supported:
+ ///
+ /// * default
+ /// * black
+ /// * red
+ /// * green
+ /// * brown
+ /// * blue
+ /// * magenta
+ /// * cyan
+ /// * gray
+ /// * darkgray
+ /// * lightRed
+ /// * lightGreen
+ /// * yellow
+ /// * lightBlue
+ /// * lightMagenta
+ /// * lightCyan
+ /// * white
+ ///
+ /// Chain this channel to a FormattingChannel with an
+ /// appropriate Formatter to control what is contained
+ /// in the text.
+ ///
+ /// Similar to StreamChannel, except that a static
+ /// mutex is used to protect against multiple
+ /// console channels concurrently writing to the
+ /// same stream.
+{
+public:
+ ColorConsoleChannel();
+ /// Creates the channel and attaches std::clog.
+
+ ColorConsoleChannel(std::ostream& str);
+ /// Creates the channel using the given stream.
+
+ void log(const Message& msg);
+ /// Logs the given message to the channel's stream.
+
+ void setProperty(const std::string& name, const std::string& value);
+ /// Sets the property with the given name.
+ ///
+ /// The following properties are supported:
+ /// * enableColors: Enable or disable colors.
+ /// * traceColor: Specify color for trace messages.
+ /// * debugColor: Specify color for debug messages.
+ /// * informationColor: Specify color for information messages.
+ /// * noticeColor: Specify color for notice messages.
+ /// * warningColor: Specify color for warning messages.
+ /// * errorColor: Specify color for error messages.
+ /// * criticalColor: Specify color for critical messages.
+ /// * fatalColor: Specify color for fatal messages.
+ ///
+ /// See the class documentation for a list of supported color values.
+
+ std::string getProperty(const std::string& name) const;
+ /// Returns the value of the property with the given name.
+ /// See setProperty() for a description of the supported
+ /// properties.
+
+protected:
+ enum Color
+ {
+ CC_DEFAULT = 0x0027,
+ CC_BLACK = 0x001e,
+ CC_RED = 0x001f,
+ CC_GREEN = 0x0020,
+ CC_BROWN = 0x0021,
+ CC_BLUE = 0x0022,
+ CC_MAGENTA = 0x0023,
+ CC_CYAN = 0x0024,
+ CC_GRAY = 0x0025,
+ CC_DARKGRAY = 0x011e,
+ CC_LIGHTRED = 0x011f,
+ CC_LIGHTGREEN = 0x0120,
+ CC_YELLOW = 0x0121,
+ CC_LIGHTBLUE = 0x0122,
+ CC_LIGHTMAGENTA = 0x0123,
+ CC_LIGHTCYAN = 0x0124,
+ CC_WHITE = 0x0125
+ };
+
+ ~ColorConsoleChannel();
+ Color parseColor(const std::string& color) const;
+ std::string formatColor(Color color) const;
+ void initColors();
+
+private:
+ std::ostream& _str;
+ bool _enableColors;
+ Color _colors[9];
+ static FastMutex _mutex;
+ static const std::string CSI;
+};
+
+
+} // namespace Poco
+
+
+#endif // Foundation_ConsoleChannel_INCLUDED