OnixS Eurex ETI Handler C++ library  9.22.0
API documentation
LogSettings.h
Go to the documentation of this file.
1 /*
2  * Copyright Onix Solutions Limited [OnixS]. All rights reserved.
3  *
4  * This software owned by Onix Solutions Limited [OnixS] and is protected by copyright law
5  * and international copyright treaties.
6  *
7  * Access to and use of the software is governed by the terms of the applicable ONIXS Software
8  * Services Agreement (the Agreement) and Customer end user license agreements granting
9  * a non-assignable, non-transferable and non-exclusive license to use the software
10  * for it's own data processing purposes under the terms defined in the Agreement.
11  *
12  * Except as otherwise granted within the terms of the Agreement, copying or reproduction of any
13  * part of this source code or associated reference material to any other location for further
14  * reproduction or redistribution, and any amendments to this copyright notice, are expressly
15  * prohibited.
16  *
17  * Any reproduction or redistribution for sale or hiring of the Software not in accordance with
18  * the terms of the Agreement is a violation of copyright law.
19  */
20 
21 #pragma once
22 
23 #include "OnixS/Eurex/Trading/Export.h"
24 
25 #include <string>
26 
27 namespace OnixS { namespace Eurex { namespace Trading {
28 
29 /// Log level.
30 struct ONIXS_EUREX_ETI_EXPORT LogLevel
31 {
32  enum Enum
33  {
34  Fatal, ///< Fatal error, cannot continue.
35  Error, ///< System error, but we can go on.
36  Warning, ///< User or logic error, just say about it.
37  Info, ///< Information message.
38  Trace, ///< Used for tracing, usually including functions' names and args.
39  Debug, ///< Used for debugging.
40  };
41 };
42 
43 /// Returns string representation.
44 ONIXS_EUREX_ETI_EXPORT std::string enumToString(LogLevel::Enum);
45 
46 /// Make it printable using C++ I/O streams.
47 ONIXS_EUREX_ETI_EXPORT std::ostream& operator<<(std::ostream&, LogLevel::Enum);
48 
49 /// Logging options.
50 struct ONIXS_EUREX_ETI_EXPORT LogSettings
51 {
52  enum Enum
53  {
54  /// Disable all tracing.
55  NoTrace = 0x00,
56 
57  /// Trace to the log file.
58  TraceToFile = 0x01,
59 
60  /// Trace to the console.
61  ///
62  /// \note Messages with LogLevel::Trace and LogLevel::Debug are not duplicated to console.
63  TraceToConsole = 0x02,
64 
65  /// Enable asynchronous logging.
66  ///
67  /// \note Instead of direct output to file or console, handler put log message into
68  /// interthread queue, that will be processed by auxiliary thread.
69  Async = 0x04,
70 
71  /// Default log settings.
72  Default = TraceToFile | TraceToConsole
73  };
74 };
75 
76 /// Typed logical operator helper.
78 {
79  return LogSettings::Enum((int) a | (int) b);
80 }
81 
82 /// Returns string representation.
83 ONIXS_EUREX_ETI_EXPORT std::string enumToString(LogSettings::Enum);
84 
85 /// Returns string representation.
86 ONIXS_EUREX_ETI_EXPORT std::string bitsToString(LogSettings::Enum);
87 
88 /// Make it printable using C++ I/O streams.
89 ONIXS_EUREX_ETI_EXPORT std::ostream& operator<<(std::ostream&, LogSettings::Enum);
90 
91 }}}
User or logic error, just say about it.
Definition: LogSettings.h:36
std::string bitsToString(LogSettings::Enum)
Returns string representation.
System error, but we can go on.
Definition: LogSettings.h:35
std::ostream & operator<<(std::ostream &, ConnectionState::Enum)
Make it printable using C++ I/O streams.
std::string enumToString(ConnectionState::Enum)
Returns string representation of ConnectionState value.
LogSettings::Enum operator|(LogSettings::Enum a, LogSettings::Enum b)
Typed logical operator helper.
Definition: LogSettings.h:77
Used for tracing, usually including functions&#39; names and args.
Definition: LogSettings.h:38
Fatal error, cannot continue.
Definition: LogSettings.h:34