OnixS C++ EuroTLX GTP Market Data Handler  1.4.0
API documentation
AddOrderMBO.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 
22 #include <vector>
23 
28 
29 
30 namespace OnixS {
31 namespace EuroTLX {
32 namespace MarketData {
33 namespace GTP {
34 
35  ///
36  struct AddOrderMBOMsg : public BinaryMessage
37  {
38  /// Time the message was generated.
39  UDT timestamp() const
41  {
42  return ordinary<UDT>(3);
43  }
44 
45  /// Unique identifier of the order.
46  UInt64 orderID() const
48  {
49  return ordinary<UInt64>(11);
50  }
51 
52  ///
53  Side::Enum side() const
55  {
56  return enumeration<Side>(19);
57  }
58 
59  /// Displayed size of the order.
60  Size size() const
62  {
63  return Size(ordinary<UInt64>(20));
64  }
65 
66  /// GTP Instrument identifier.
67  UInt64 instrument() const
69  {
70  return ordinary<UInt64>(28);
71  }
72 
73  /// Limit price of the order. Implied price if instrument trades in yield.
74  Price price() const
76  {
77  return Price(ordinary<UInt64>(36));
78  }
79 
80  /// Yield, if the instrument trades in yield.
81  Price yield() const
83  {
84  return Price(ordinary<UInt64>(44));
85  }
86 
87  /// Venue from which market data is received for the instrument.
90  {
91  return enumeration<SourceVenue>(52);
92  }
93 
94  ///
97  {
98  return enumeration<OrderBookType>(54);
99  }
100 
101  /// Identity of trading participant that submitted the order.
104  {
105  return fixedStr<11>(55);
106  }
107 
108  /// Total number of orders disseminated including this one, on this side of the book as indicated by
109  /// Side field.
110  UInt8 depth() const
112  {
113  return ordinaryRef<UInt8>(66);
114  }
115 
116  /// Total message size.
118 
119  /// Check the given size.
121  {
122  if(size < messageSize_)
123  throwIncorrectSize("AddOrderMBO", size, messageSize_);
124  }
125 
126  /// Initializes instance over given memory block.
127  AddOrderMBOMsg(const void* data, MessageSize size)
129  : BinaryMessage(data, size)
130  {
131  }
132  };
133 
134  /// Serializes object into string.
135  ONIXS_EUROTLX_GTP_API void toStr(std::string&, const AddOrderMBOMsg&);
136 
137  /// Serializes object into string.
138  inline std::string toStr(const AddOrderMBOMsg& msg)
139  {
140  std::string str;
141  toStr(str, msg);
142  return str;
143  }
144 
145 }
146 }
147 }
148 }
#define ONIXS_EUROTLX_GTP_CONST_OR_CONSTEXPR
Definition: Compiler.h:46
Alpha participant() const ONIXS_EUROTLX_GTP_NOTHROW
Identity of trading participant that submitted the order.
Definition: AddOrderMBO.h:102
BinaryMessage() ONIXS_EUROTLX_GTP_NOTHROW
Initializes blank instance referencing to nothing.
#define ONIXS_EUROTLX_GTP_NOTHROW
Definition: Compiler.h:27
Side::Enum side() const ONIXS_EUROTLX_GTP_NOTHROW
Definition: AddOrderMBO.h:53
static void validateSize(MessageSize size)
Check the given size.
Definition: AddOrderMBO.h:120
Price yield() const ONIXS_EUROTLX_GTP_NOTHROW
Yield, if the instrument trades in yield.
Definition: AddOrderMBO.h:81
static ONIXS_EUROTLX_GTP_CONST_OR_CONSTEXPR MessageSize messageSize_
Total message size.
Definition: AddOrderMBO.h:117
FixedPointDecimal< Int64, IntegralConstant< Int8,-8 > > Price
Signed Little-Endian encoded 64bit integer field with eight implied decimal places.
Definition: Defines.h:102
UInt16 MessageSize
Aliases message length type.
Definition: Defines.h:141
Price price() const ONIXS_EUROTLX_GTP_NOTHROW
Limit price of the order. Implied price if instrument trades in yield.
Definition: AddOrderMBO.h:74
ONIXS_EUROTLX_GTP_API void throwIncorrectSize(const std::string &messageName, MessageSize receivedSize, MessageSize expectedSize)
FixedPointDecimal< UInt64, IntegralConstant< Int8,-8 > > Size
Little-Endian encoded 64 bit unsigned integer with eight implied decimal places.
Definition: Defines.h:111
UDT timestamp() const ONIXS_EUROTLX_GTP_NOTHROW
Time the message was generated.
Definition: AddOrderMBO.h:39
OrderBookType::Enum orderBookType() const ONIXS_EUROTLX_GTP_NOTHROW
Definition: AddOrderMBO.h:95
AddOrderMBOMsg(const void *data, MessageSize size) ONIXS_EUROTLX_GTP_NOTHROW
Initializes instance over given memory block.
Definition: AddOrderMBO.h:127
UInt64 instrument() const ONIXS_EUROTLX_GTP_NOTHROW
GTP Instrument identifier.
Definition: AddOrderMBO.h:67
UInt8 depth() const ONIXS_EUROTLX_GTP_NOTHROW
Definition: AddOrderMBO.h:110
Encapsulates services for manipulating little endian encoded messages.
Provides efficient way of accessing text-based FIX field values.
Definition: String.h:45
UInt64 UDT
time stamp (in UTC) = (date time per second resolution in unix time format) * 1,000,000,000 + (nanoseconds component)
Definition: Defines.h:94
Size size() const ONIXS_EUROTLX_GTP_NOTHROW
Displayed size of the order.
Definition: AddOrderMBO.h:60
SourceVenue::Enum sourceVenue() const ONIXS_EUROTLX_GTP_NOTHROW
Venue from which market data is received for the instrument.
Definition: AddOrderMBO.h:88
UInt64 orderID() const ONIXS_EUROTLX_GTP_NOTHROW
Unique identifier of the order.
Definition: AddOrderMBO.h:46
ONIXS_EUROTLX_GTP_API void toStr(std::string &, EventCode::Enum)
Appends string presentation of object.