OnixS ICE iMpact Multicast Price Feed Handler C++ library  8.18.0
API documentation
AddModifyOrder.h
Go to the documentation of this file.
1 /**
2  * \file
3  * \brief Declare `OnixS::ICE::iMpact::MarketData::AddModifyOrder` message structure
4  */
5 /*
6  * Copyright (c) Onix Solutions Limited. All rights reserved.
7  *
8  * This software owned by Onix Solutions Limited and is protected by copyright law
9  * and international copyright treaties.
10  *
11  * Access to and use of the software is governed by the terms of the applicable ONIXS Software
12  * Services Agreement (the Agreement) and Customer end user license agreements granting
13  * a non-assignable, non-transferable and non-exclusive license to use the software
14  * for it's own data processing purposes under the terms defined in the Agreement.
15  *
16  * Except as otherwise granted within the terms of the Agreement, copying or reproduction of any part
17  * of this source code or associated reference material to any other location for further reproduction
18  * or redistribution, and any amendments to this copyright notice, are expressly prohibited.
19  *
20  * Any reproduction or redistribution for sale or hiring of the Software not in accordance with
21  * the terms of the Agreement is a violation of copyright law.
22  */
23 
24 #pragma once
25 
26 #include "../Enumerations.h"
27 #include "../Export.h"
28 #include "../Types.h"
29 
30 #include <iosfwd>
31 #include <string>
32 
33 namespace OnixS { namespace ICE { namespace iMpact { namespace MarketData {
34 
35 /// This class represents the Add/Modify Order Message.
36 struct ONIXS_ICEMDH_EXPORT AddModifyOrder
37 {
38  /// Message type constant
39  enum
40  {
41  messageType = 'E'
42  };
43 
44  /// Unique identifier of the market.
46 
47  /// Unique identifier of the order.
49 
50  /// Sequence ID of the order. When an order is modified, this will be
51  /// incremented while OrderID remains the same. It is for legacy reason
52  /// and can be ignored.
54 
55  /// Tells whether order represents bid or offer.
57 
58  /// Price of the bid/offer. OrderPriceDenominator for the market should be
59  /// applied to get the real price.
61 
62  /// Quantity.
63  int quantity;
64 
65  /// Indicate if this is an implied order or not.
66  bool isImplied;
67 
68  /// Indicate whether it is just an RFQ or not. Client should filter the
69  /// order if it doesn't care about RFQ.
70  bool isRFQ;
71 
72  /// Order entry date time. Milliseconds since Jan 1st, 1970, 00:00:00 GMT.
74 
75  /// Least Significant Bit (Bit 0): IsModifyOrder - indicate this is to
76  /// Modify existing order if set to 1. Bit 1 through 7: Reserved for
77  /// future use. For backward compatibility, client should always look at
78  /// each individual bit for the corresponding flag. Otherwise problems
79  /// might occur when bits 1 through 7 start to be utilized.
81 
82  /// Can be used in conjunction with `OrderEntryDateTime` field for
83  /// priority of orders within same milliseconds time.
85 
86  /// This field can be used to get the order modification time. The format
87  /// is nanoseconds since Jan 1st, 1970, 00:00:00 GMT. The nanosecond part
88  /// is currently 000 and might be supported later.
90 
91  /// This field can be used to get the time the trading engine received the
92  /// request that triggers this message. The format is nanoseconds since
93  /// Jan 1st, 1970, 00:00:00 GMT. The nanosecond part is currently 000 and
94  /// might be supported later. Note: This field could be set to different
95  /// values or `0` for some scenarios. Please refer to the FAQs for more
96  /// details.
98 
99  /// Default constructor.
100  AddModifyOrder();
101 
102  /// Initialize from raw message data.
103  AddModifyOrder(const char* data, std::size_t dataSize);
104 
105  /// Deserialize from raw data.
106  void deserialize(const char* data, std::size_t dataSize);
107 
108  /// Reset all fields to default values.
109  void reset();
110 
111  /// Returns string representation.
112  std::string toString() const;
113 };
114 
115 /// Make it printable using C++ I/O streams.
116 ONIXS_ICEMDH_EXPORT std::ostream& operator<<(std::ostream&, const AddModifyOrder&);
117 
118 }}}} // namespace OnixS::ICE::iMpact::MarketData
bool isImplied
Indicate if this is an implied order or not.
This class represents the Add/Modify Order Message.
AddModifyOrderExtraFlags::Enum extraFlags
long long Price
Alias for order identifiers type.
Definition: Types.h:54
Enum
Extra flags for Add/Modify Order message.
Definition: Enumerations.h:361
DateTime orderEntryDateTime
Order entry date time. Milliseconds since Jan 1st, 1970, 00:00:00 GMT.
int MarketId
Alias for market identifiers type.
Definition: Types.h:39
std::ostream & operator<<(std::ostream &, const Error &)
Make it printable to formatted C++ I/O streams.
MarketId marketId
Unique identifier of the market.
OrderId orderId
Unique identifier of the order.
Side::Enum side
Tells whether order represents bid or offer.
long long OrderId
Alias for order identifiers type.
Definition: Types.h:42
long long DateTime
Represents the number of nanoseconds since Jan 1st, 1970, 00:00:00 GMT.
Definition: Types.h:57
Enum
Trading side constants.
Definition: Enumerations.h:38