OnixS C++ Fenics UST BIMP Market Data Handler  1.1.0
API documentation
OrderExecuted.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 FenicsUST {
32 namespace MarketData {
33 namespace Bimp {
34 
35  /// This message is sent when an order is partially or completely executed.
37  {
38  /// Instrument locate code identifying the instrument.
41  {
42  return ordinary<Integer4>(1);
43  }
44 
45  /// Fenics USTreasuries internal tracking/sequence number.
48  {
49  return ordinary<Integer8>(5);
50  }
51 
52  /// Timestamp for this message. Expressed as the number of nanoseconds since Unix Epoch (00:00:00 UTC on
53  /// 1 January 1970).
56  {
57  return ordinary<Integer8>(13);
58  }
59 
60  /// The Fenics USTreasuries generated identifier for this order.
63  {
64  return ordinary<Integer8>(21);
65  }
66 
67  /// Total quantity of the order that matched within this execution.
70  {
71  return ordinary<Integer8>(29);
72  }
73 
74  /// Assigned by Fenics USTreasuries to each execution that occurs.
77  {
78  return ordinary<Integer8>(37);
79  }
80 
81  /// Price at which this execution occurred.
84  {
85  return ordinary<SignedInteger8>(45);
86  }
87 
88  /// A bitmap with each bit carrying a specific meaning.
89  bool orderFlags(Integer1& value) const
91  {
92  if (binarySize() < 53 + sizeof(Integer1))
93  return false;
94 
95  value = ordinary<Integer1>(53);
96  return true;
97  }
98 
99 
100  /// Total message size.
102 
103  /// Min message size.
105 
106  /// Check the given size.
107  static void validateSize(MessageSize size)
108  {
109  if (ONIXS_FENICSUST_BIMP_CHECK_EXPECT((size < minMessageSize_), false))
110  throwIncorrectSize("OrderExecuted", size, minMessageSize_);
111  }
112 
113  /// Initializes instance over given memory block.
114  OrderExecutedMsg(const void* data, MessageSize size)
116  : BinaryMessage(data, size)
117  {
118  }
119  };
120 
121  /// Serializes object into string.
122  ONIXS_FENICSUST_BIMP_API void toStr(std::string&, const OrderExecutedMsg&);
123 
124  /// Serializes object into string.
125  inline std::string toStr(const OrderExecutedMsg& msg)
126  {
127  std::string str;
128  toStr(str, msg);
129  return str;
130  }
131 
132 }
133 }
134 }
135 }
Integer8 orderReferenceNumber() const ONIXS_FENICSUST_BIMP_NOTHROW
The Fenics USTreasuries generated identifier for this order.
Definition: OrderExecuted.h:61
Integer4 instrumentLocate() const ONIXS_FENICSUST_BIMP_NOTHROW
Instrument locate code identifying the instrument.
Definition: OrderExecuted.h:39
Integer8 executedQuantity() const ONIXS_FENICSUST_BIMP_NOTHROW
Total quantity of the order that matched within this execution.
Definition: OrderExecuted.h:68
static ONIXS_FENICSUST_BIMP_CONST_OR_CONSTEXPR MessageSize minMessageSize_
Min message size.
ONIXS_FENICSUST_BIMP_API ONIXS_FENICSUST_BIMP_COLD_PATH ONIXS_FENICSUST_BIMP_NORETURN void throwIncorrectSize(const std::string &messageName, MessageSize receivedSize, MessageSize expectedSize)
static ONIXS_FENICSUST_BIMP_CONST_OR_CONSTEXPR MessageSize messageSize_
Total message size.
BinaryMessage() ONIXS_FENICSUST_BIMP_NOTHROW
Initializes blank instance referencing to nothing.
Integer8 timestamp() const ONIXS_FENICSUST_BIMP_NOTHROW
Definition: OrderExecuted.h:54
#define ONIXS_FENICSUST_BIMP_CHECK_EXPECT(exp, c)
Definition: Compiler.h:52
OrderExecutedMsg(const void *data, MessageSize size) ONIXS_FENICSUST_BIMP_NOTHROW
Initializes instance over given memory block.
#define ONIXS_FENICSUST_BIMP_CONST_OR_CONSTEXPR
Definition: Compiler.h:46
MessageSize binarySize() const ONIXS_FENICSUST_BIMP_NOTHROW
Size of message.
Integer8 trackingNumber() const ONIXS_FENICSUST_BIMP_NOTHROW
Fenics USTreasuries internal tracking/sequence number.
Definition: OrderExecuted.h:46
This message is sent when an order is partially or completely executed.
Definition: OrderExecuted.h:36
SignedInteger8 executionPrice() const ONIXS_FENICSUST_BIMP_NOTHROW
Price at which this execution occurred.
Definition: OrderExecuted.h:82
#define ONIXS_FENICSUST_BIMP_NOTHROW
Definition: Compiler.h:27
Encapsulates services for manipulating little endian encoded messages.
static void validateSize(MessageSize size)
Check the given size.
bool orderFlags(Integer1 &value) const ONIXS_FENICSUST_BIMP_NOTHROW
A bitmap with each bit carrying a specific meaning.
Definition: OrderExecuted.h:89
Integer8 tradeIdentifier() const ONIXS_FENICSUST_BIMP_NOTHROW
Assigned by Fenics USTreasuries to each execution that occurs.
Definition: OrderExecuted.h:75
ONIXS_FENICSUST_BIMP_API void toStr(std::string &, EventCode::Enum)
Appends string presentation of object.
Integer2 MessageSize
Aliases message length type.
Definition: Defines.h:100