OnixS C++ SGX Titan OUCH Trading Handler  1.2.0
API documentation
OrderRejected.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 
26 
27  /// This message is used to reject Enter Order
28  /// messages, Cancel Order messages and Replace Order
29  /// messages.
30  struct ONIXS_SGXTITAN_OUCH_API OrderRejected : public IncomingMessage
31  {
32  /// UNIX Time
34  {
35  return ordinary<DateTime>(1);
36  }
37 
38  /// Order Token
40  ONIXS_SGX_OUCH_NOTHROW
41  {
42  return fixedStr<14>(9);
43  }
44 
45  /// Error Code
47  ONIXS_SGX_OUCH_NOTHROW
48  {
49  return ordinary<SignedBinary4>(23);
50  }
51 
52  /// Total message size.
53  static ONIXS_SGX_OUCH_CONST_OR_CONSTEXPR MessageSize messageSize_ = 27;
54 
55  /// Check the given size.
56  static void validateSize(MessageSize size)
57  {
58  if(size < messageSize_)
59  throwIncorrectSize("OrderRejected", size, messageSize_);
60  }
61 
62  /// Initializes instance over given memory block.
63  OrderRejected(const void* data, MessageSize size)
64  ONIXS_SGX_OUCH_NOTHROW
65  : IncomingMessage(data, size)
66  {
67  }
68  };
69 
70  /// Serializes object into string.
71  ONIXS_SGXTITAN_OUCH_API void toStr(std::string&, const OrderRejected&);
72 
73  /// Serializes object into string.
74  inline std::string toStr(const OrderRejected& msg)
75  {
76  std::string str;
77  toStr(str, msg);
78  return str;
79  }
80 
81  ///
82  inline std::ostream& operator<<(std::ostream& stream, const OrderRejected& msg)
83  {
84  stream << toStr(msg);
85  return stream;
86  }
87 
IncomingMessage(const void *data, MessageSize size)
Binary2 MessageSize
Aliases message length type.
Definition: Defines.h:47
OrderRejected(const void *data, MessageSize size)
Initializes instance over given memory block.
Definition: OrderRejected.h:63
DateTime timestamp() const
UNIX Time.
Definition: OrderRejected.h:33
ONIXS_SGXTITAN_OUCH_API void throwIncorrectSize(const std::string &messageName, MessageSize receivedSize, MessageSize expectedSize)
ONIXS_SGXTITAN_OUCH_API std::ostream & operator<<(std::ostream &stream, HandlerState::Enum value)
static void validateSize(MessageSize size)
Check the given size.
Definition: OrderRejected.h:56
Provides efficient way of accessing text-based FIX field values.
Definition: String.h:41
#define ONIXS_SGXTITAN_OUCH_NAMESPACE_END
Definition: Bootstrap.h:31
#define ONIXS_SGXTITAN_OUCH_NAMESPACE_BEGIN
Definition: Bootstrap.h:27
ONIXS_SGXTITAN_OUCH_API void toStr(std::string &, OutboundMessageTypes::Enum)
Appends string presentation of object.
StrRef orderToken() const
Order Token.
Definition: OrderRejected.h:39
SignedBinary4 rejectCode() const
Error Code.
Definition: OrderRejected.h:46