OnixS C++ EuroTLX GTP Market Data Handler  1.4.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 part
13 * of this source code or associated reference material to any other location for further reproduction
14 * or redistribution, and any amendments to this copyright notice, are expressly prohibited.
15 *
16 * Any reproduction or redistribution for sale or hiring of the Software not in accordance with
17 * the terms of the Agreement is a violation of copyright law.
18 */
19 
20 #pragma once
21 
23 
24 #include <string>
25 
26 namespace OnixS
27 {
28  namespace EuroTLX
29  {
30  namespace MarketData
31  {
32  namespace GTP
33  {
34 
35  /// Log level.
36  struct ONIXS_EUROTLX_GTP_API LogLevel
37  {
38  enum Enum
39  {
40  Fatal, ///< Fatal error, cannot continue.
41  Error, ///< System error, but we can go on.
42  Warning, ///< User or logic error, just say about it.
43  Info, ///< Information message.
44  Trace, ///< Used for tracing, usually including functions' names and args.
45  Debug, ///< Used for debugging.
46  };
47  };
48 
49  /// Returns string representation of ErrorCode value.
50  ONIXS_EUROTLX_GTP_API std::string enumToString (LogLevel::Enum);
51 
52  /// Logging options.
53  struct ONIXS_EUROTLX_GTP_API LogSettings
54  {
55  enum Enum
56  {
57  /// Trace to the log file.
58  TraceToFile = 0x01,
59 
60  /// Duplicate log messages to console.
61  /// @note Messages with LogLevel::Trace and LogLevel::Debug are not duplicated to console.
62  TraceToConsole = 0x02,
63 
64  /// Use asynchronous logging
65  Async = 0x4,
66 
67  /// if TraceToConsole is set, then direct output to stderr
68  ConsoleErr = 0x8,
69 
70  /// if TraceToConsole is set, then set up colored output mode
71  ConsoleColored = 0x10,
72 
73  /// if TraceToConsole is set, then append prefix to output
74  ConsoleShowPrefix = 0x20,
75 
76  /// Log binary data of received packets, applied only for Info log level and below.
77  LogPackets = 0x40,
78 
79  /// Default log settings.
80  Default = TraceToFile | LogPackets
81  };
82  };
83 
84  /// Typed logical operator helper.
86  {
87  return LogSettings::Enum ( (int) a | (int) b);
88  }
89 
90 
91  /// Log file read permissions.
92  struct ONIXS_EUROTLX_GTP_API LogFilePermission
93  {
94  enum Enum
95  {
96  /// read access only for owner of process
97  ReadOwnerOnly = 0x01,
98 
99  /// read access for all
100  ReadAll = 0x02,
101 
102  /// write access only for owner of process
103  WriteOwnerOnly = 0x04,
104 
105  /// write access for all
106  WriteAll = 0x08,
107 
108  /// Default value
109  Default = ReadAll | WriteOwnerOnly
110  };
111  };
112 
113  /// Typed logical operator helper.
115  {
116  return static_cast<LogFilePermission::Enum> (static_cast<int> (a) | static_cast<int> (b) );
117  }
118  }
119  }
120  }
121 }
122 
123 
124 
125 
126 
127 
128 
User or logic error, just say about it.
Definition: LogSettings.h:42
LogSettings::Enum operator|(LogSettings::Enum a, LogSettings::Enum b)
Typed logical operator helper.
Definition: LogSettings.h:85
System error, but we can go on.
Definition: LogSettings.h:41
Used for tracing, usually including functions&#39; names and args.
Definition: LogSettings.h:44
ONIXS_EUROTLX_GTP_API std::string enumToString(LogLevel::Enum)
Returns string representation of ErrorCode value.