OnixS Eurex ETI Handler C++ library  9.22.0
API documentation
WarningListener.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 /// Known (selected) warning codes.
30 struct ONIXS_EUREX_ETI_EXPORT WarningCode
31 {
32  /// \copydoc WarningCode
33  enum Enum
34  {
35  General, ///< Generic issues.
36  ReceiverInactivity, ///< Receiver inactivity issue.
37  ExceptionInEventHandler, ///< Indicates failure in the user-space code.
38  };
39 };
40 
41 /// Returns string representation of WarningCode value.
42 ONIXS_EUREX_ETI_EXPORT std::string enumToString(WarningCode::Enum);
43 
44 /// Make it printable using C++ I/O streams.
45 ONIXS_EUREX_ETI_EXPORT std::ostream& operator<<(std::ostream&, WarningCode::Enum);
46 
47 /// Defines an interface through which the Handler notifies subscribers
48 /// about warnings occurred while processing messages.
50 {
51 public:
52  /// Implement this member to get notified about warnings.
53  /// \param description supplies notes on occurred error.
54  /// \note Deprecated, use onWarning(WarningCode::Enum, const std::string&) instead.
55  virtual void onWarning(const std::string& description) = 0;
56 
57  /// Implement this member to get notified about warnings.
58  /// \param code identifies warning occurred while processing messages.
59  /// \param description supplies notes on occurred error.
60  virtual void onWarning(WarningCode::Enum code, const std::string& description)
61  {
62  (void) code;
63  (void) description;
64  }
65 
66 protected:
67  /// Class provides an interface for handling trading system events.
68  /// It doesn't provide an interface for instance deletion. However,
69  /// since C++ doesn't have pure interface concept, destructor will be
70  /// generated anyway. We can only control proper use of it. For this
71  /// reason we hide from public use and make it available for descendants.
72  virtual ~WarningListener() {}
73 };
74 
75 }}}
Known (selected) warning codes.
virtual void onWarning(WarningCode::Enum code, const std::string &description)
std::ostream & operator<<(std::ostream &, ConnectionState::Enum)
Make it printable using C++ I/O streams.
Enum
Known (selected) warning codes.
std::string enumToString(ConnectionState::Enum)
Returns string representation of ConnectionState value.
Indicates failure in the user-space code.