OnixS C++ Fenics UST BIMP Market Data Handler  1.1.0
API documentation
InstrumentTradingAction.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  /// Instrument Trading Action
37  {
38  /// Instrument locate code identifying the instrument.
41  {
42  return ordinary<Integer4>(1);
43  }
44 
45  /// Timestamp for this message. Expressed as the number of nanoseconds since Unix Epoch (00:00:00 UTC on
46  /// 1 January 1970).
49  {
50  return ordinary<Integer8>(5);
51  }
52 
53  /// The unique numeric instrument identification number, used as the primary identifier for order
54  /// management via the BOP protocol.
57  {
58  return ordinary<Integer8>(13);
59  }
60 
61  /// Current trading state.
64  {
65  return enumeration<TradingState>(21);
66  }
67 
68  /// Total message size.
70 
71  /// Check the given size.
72  static void validateSize(MessageSize size)
73  {
74  if (ONIXS_FENICSUST_BIMP_CHECK_EXPECT((size < messageSize_), false))
75  throwIncorrectSize("InstrumentTradingAction", size, messageSize_);
76  }
77 
78  /// Initializes instance over given memory block.
79  InstrumentTradingActionMsg(const void* data, MessageSize size)
81  : BinaryMessage(data, size)
82  {
83  }
84  };
85 
86  /// Serializes object into string.
87  ONIXS_FENICSUST_BIMP_API void toStr(std::string&, const InstrumentTradingActionMsg&);
88 
89  /// Serializes object into string.
90  inline std::string toStr(const InstrumentTradingActionMsg& msg)
91  {
92  std::string str;
93  toStr(str, msg);
94  return str;
95  }
96 
97 }
98 }
99 }
100 }
ONIXS_FENICSUST_BIMP_API ONIXS_FENICSUST_BIMP_COLD_PATH ONIXS_FENICSUST_BIMP_NORETURN void throwIncorrectSize(const std::string &messageName, MessageSize receivedSize, MessageSize expectedSize)
static void validateSize(MessageSize size)
Check the given size.
BinaryMessage() ONIXS_FENICSUST_BIMP_NOTHROW
Initializes blank instance referencing to nothing.
Integer4 instrumentLocate() const ONIXS_FENICSUST_BIMP_NOTHROW
Instrument locate code identifying the instrument.
#define ONIXS_FENICSUST_BIMP_CHECK_EXPECT(exp, c)
Definition: Compiler.h:52
#define ONIXS_FENICSUST_BIMP_CONST_OR_CONSTEXPR
Definition: Compiler.h:46
#define ONIXS_FENICSUST_BIMP_NOTHROW
Definition: Compiler.h:27
Encapsulates services for manipulating little endian encoded messages.
ONIXS_FENICSUST_BIMP_API void toStr(std::string &, EventCode::Enum)
Appends string presentation of object.
InstrumentTradingActionMsg(const void *data, MessageSize size) ONIXS_FENICSUST_BIMP_NOTHROW
Initializes instance over given memory block.
Integer2 MessageSize
Aliases message length type.
Definition: Defines.h:100
Integer8 instrumentId() const ONIXS_FENICSUST_BIMP_NOTHROW
static ONIXS_FENICSUST_BIMP_CONST_OR_CONSTEXPR MessageSize messageSize_
Total message size.
TradingState::Enum tradingState() const ONIXS_FENICSUST_BIMP_NOTHROW
Current trading state.