OnixS C++ SGX Titan ITCH Market Data Handler  1.2.2
API documentation
TickSizeTableEntryMsg.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 
25 
26 ONIXS_SGXTITAN_ITCH_NAMESPACE_BEGIN
27 
28  /// This message contains information on a tick size
29  /// for a price range.
30  struct ONIXS_SGXTITAN_ITCH_API TickSizeTableEntryMsg : public IncomingMessage
31  {
32  /// Nanoseconds portion of the timestamp
33  UInt32 nanoseconds() const
34  {
35  return ordinary<UInt32>(1);
36  }
37 
38  /// The Order Book this entry belongs to
40  {
41  return ordinary<UInt32>(5);
42  }
43 
44  /// Tick Size for the given price range
45  UInt64 tickSize() const
46  {
47  return ordinary<UInt64>(9);
48  }
49 
50  /// Start of price range for this entry
51  Price priceFrom() const
52  {
53  return Price(ordinary<Int32>(17));
54  }
55 
56  /// End of price range for this entry, zero (0) means
57  /// infinity
58  Price priceTo() const
59  {
60  return Price(ordinary<Int32>(21));
61  }
62 
63  /// Total message size.
65 
66  /// Check the given size.
67  static void validateSize(MessageSize size)
68  {
69  if(size < messageSize_)
70  throwIncorrectSize("TickSizeTableEntryMsg", size, messageSize_);
71  }
72 
73  /// Initializes instance over given memory block.
74  TickSizeTableEntryMsg(const void* data, MessageSize size)
76  : IncomingMessage(data, size)
77  {
78  }
79  };
80 
81  /// Serializes object into string.
82  ONIXS_SGXTITAN_ITCH_API void toStr(std::string&, const TickSizeTableEntryMsg&);
83 
84  /// Serializes object into string.
85  inline std::string toStr(const TickSizeTableEntryMsg& msg)
86  {
87  std::string str;
88  toStr(str, msg);
89  return str;
90  }
91 
92  ///
93  inline std::ostream& operator<<(std::ostream& stream, const TickSizeTableEntryMsg& msg)
94  {
95  stream << toStr(msg);
96  return stream;
97  }
98 
99 ONIXS_SGXTITAN_ITCH_NAMESPACE_END
#define ONIXS_SGXTITAN_ITCH_CONST_OR_CONSTEXPR
Definition: Compiler.h:46
UInt32 nanoseconds() const
Nanoseconds portion of the timestamp.
static void validateSize(MessageSize size)
Check the given size.
#define ONIXS_SGXTITAN_ITCH_NOTHROW
Definition: Compiler.h:27
Price priceFrom() const
Start of price range for this entry.
UInt32 OrderBookId
Alias for Security Id type.
Definition: Defines.h:43
IncomingMessage(const void *data, MessageSize size)
UInt16 MessageSize
Aliases message length type.
Definition: Defines.h:34
ONIXS_SGXTITAN_ITCH_API void toStr(std::string &, MessageType::Enum)
Appends string presentation of object.
ONIXS_SGXTITAN_ITCH_API std::ostream & operator<<(std::ostream &stream, const ServiceDescriptor &descriptor)
ONIXS_SGXTITAN_ITCH_API void throwIncorrectSize(const std::string &messageName, MessageSize receivedSize, MessageSize expectedSize)
UInt64 tickSize() const
Tick Size for the given price range.
TickSizeTableEntryMsg(const void *data, MessageSize size)
Initializes instance over given memory block.
OrderBookId orderBookId() const
The Order Book this entry belongs to.