OnixS ICE iMpact Multicast Price Feed Handler C++ library  8.18.0
API documentation
MarkerIndexPrices.h
Go to the documentation of this file.
1 /**
2  * \file
3  * \brief Declare `OnixS::ICE::iMpact::MarketData::MarkerIndexPrices` 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 Marker/Index Prices Message.
36 struct ONIXS_ICEMDH_EXPORT MarkerIndexPrices
37 {
38  /// Message type constant
39  enum
40  {
41  messageType = 'z'
42  };
43 
44  /// The market ID of the underlying market of the Marker/Index.
46 
47  /// Price. `IndexPriceDenominator` for the market should be applied to get
48  /// the real price.
50 
51  /// The short name date of the Marker/Index. For example `Morn5Min`.
52  std::string shortName;
53 
54  /// The date and time the marker was put into. Milliseconds since Jan 1st,
55  /// 1970, 00:00:00 GMT.
57 
58  /// The date this price is effective for, in the format of YYYY-MM-DD.
59  std::string valuationDate;
60 
61  /// For Endex Spot markets, the possible values are Current (`C`), Default
62  /// (`D`), Final (`F`). For non-Endex Spot markets this field will be set
63  /// to `' '`.
65 
66  /// The market id of the marker market, or 0 if none is set.
68 
69  /// This field should be applied to the `Price` field to get the number of
70  /// decimals for the `Marker/Index`.
72 
73  /// Default constructor.
75 
76  /// Initialize from raw message data.
77  MarkerIndexPrices(const char* data, std::size_t dataSize);
78 
79  /// Deserialize from raw data.
80  void deserialize(const char* data, std::size_t dataSize);
81 
82  /// Reset all fields to default values.
83  void reset();
84 
85  /// Returns string representation.
86  std::string toString() const;
87 };
88 
89 /// Make it printable using C++ I/O streams.
90 ONIXS_ICEMDH_EXPORT std::ostream& operator<<(std::ostream&, const MarkerIndexPrices&);
91 
92 }}}} // namespace OnixS::ICE::iMpact::MarketData
long long Price
Alias for order identifiers type.
Definition: Types.h:54
MarketId altMarketId
The market id of the marker market, or 0 if none is set.
std::string shortName
The short name date of the Marker/Index. For example Morn5Min.
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.
This class represents the Marker/Index Prices Message.
std::string valuationDate
The date this price is effective for, in the format of YYYY-MM-DD.
MarketId marketId
The market ID of the underlying market of the Marker/Index.
long long DateTime
Represents the number of nanoseconds since Jan 1st, 1970, 00:00:00 GMT.
Definition: Types.h:57