OnixS C++ eSpeed ITCH Market Data Handler  1.7.3
API documentation
BrokenTradeMsg.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 
24 
26 
27  /// The Broken Trade Message is sent when NFI
28  /// determines an execution is broken pursuant to
29  /// NFI's Error Trade Policy.
30  struct ONIXS_ESPEED_ITCH_API BrokenTradeMsg : public IncomingMessage
31  {
32  /// Timestamp
33  UInt64 timestamp() const
34  {
35  return ordinary<UInt64>(1);
36  }
37 
38  /// Unique Order book identifier
40  {
41  return ordinary<UInt32>(9);
42  }
43 
44  /// Transaction ID corresponding to the transaction ID
45  /// in the response message. Value is set to 0 for
46  /// delayed updates
47  UInt32 transactionId() const
48  {
49  return ordinary<UInt32>(13);
50  }
51 
52  /// The quantity executed.
54  {
55  return ordinary<UInt32>(17);
56  }
57 
58  /// The day unique Match Number of this execution.
59  /// This field will be set to blanks if trade message
60  /// specifies the incremental quantity traded for some
61  /// period of time instead of reporting every non-
62  /// displayable execution.
63  StrRef matchId() const
65  {
66  return fixedStr<14>(21);
67  }
68 
69  /// The execution price or average execution price.
70  /// Value is set to 0 for delayed updates.
72  {
73  return ordinary<Int64>(35);
74  }
75 
76  /// Total message size.
78 
79  /// Check the given size.
80  static void validateSize(MessageSize size)
81  {
82  if (ONIXS_ESPEED_ITCH_CHECK_EXPECT((size < messageSize_), false))
83  throwIncorrectSize("BrokenTradeMsg", size, messageSize_);
84  }
85 
86  /// Initializes instance over given memory block.
87  BrokenTradeMsg(const void* data, MessageSize size)
89  : IncomingMessage(data, size)
90  {
91  }
92  };
93 
94  /// Serializes object into string.
95  ONIXS_ESPEED_ITCH_API void toStr(std::string&, const BrokenTradeMsg&);
96 
97  /// Serializes object into string.
98  inline std::string toStr(const BrokenTradeMsg& msg)
99  {
100  std::string str;
101  toStr(str, msg);
102  return str;
103  }
104 
105  ///
106  inline std::ostream& operator<<(std::ostream& stream, const BrokenTradeMsg& msg)
107  {
108  stream << toStr(msg);
109  return stream;
110  }
111 
#define ONIXS_ESPEED_ITCH_NAMESPACE_END
Definition: Bootstrap.h:31
#define ONIXS_ESPEED_ITCH_NAMESPACE_BEGIN
Definition: Bootstrap.h:27
Price8 tradePrice() const
ONIXS_ESPEED_ITCH_API void throwIncorrectSize(const std::string &messageName, MessageSize receivedSize, MessageSize expectedSize)
OrderBookId orderBookId() const
Unique Order book identifier.
ONIXS_ESPEED_ITCH_API void toStr(std::string &, const BrokenTradeMsg &)
Serializes object into string.
std::ostream & operator<<(std::ostream &stream, const BrokenTradeMsg &msg)
#define ONIXS_ESPEED_ITCH_CHECK_EXPECT(exp, c)
Definition: Compiler.h:52
UInt32 Quantity
Alias for Quantity type.
Definition: Defines.h:46
BrokenTradeMsg(const void *data, MessageSize size) ONIXS_ESPEED_ITCH_NOTHROW
Initializes instance over given memory block.
ONIXS_ESPEED_ITCH_NAMESPACE_BEGIN typedef UInt16 MessageSize
Aliases message length type.
Definition: Defines.h:34
UInt32 transactionId() const
#define ONIXS_ESPEED_ITCH_CONST_OR_CONSTEXPR
Definition: Compiler.h:46
UInt64 timestamp() const
Timestamp.
Int64 Price8
Alias for Price type (8 bytes).
Definition: Defines.h:52
StrRef matchId() const ONIXS_ESPEED_ITCH_NOTHROW
static void validateSize(MessageSize size)
Check the given size.
Provides efficient way of accessing text-based FIX field values.
Definition: String.h:40
#define ONIXS_ESPEED_ITCH_NOTHROW
Definition: Compiler.h:27
Quantity executedQuantity() const
The quantity executed.
IncomingMessage(const void *data, MessageSize size) ONIXS_ESPEED_ITCH_NOTHROW
UInt32 OrderBookId
Alias for Security Id type.
Definition: Defines.h:43