OnixS C++ Cboe CFE Multicast PITCH Market Data Handler  1.12.1
API documentation
TradingStatus.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 CboeCFE {
32 namespace MarketData {
33 namespace Pitch {
34 
35  /// The Trading Status message is used to indicate the current trading status of a Futures contract.
37  {
38  /// Nanosecond offset from last unit timestamp.
41  {
42  return ordinary<Binary4>(2);
43  }
44 
45  /// Symbol right padded with spaces.
46  StrRef symbol() const
48  {
49  return fixedStr<6>(6);
50  }
51 
52  /// Trading Status
55  {
56  return enumeration<TradingStatus>(14);
57  }
58 
59  /// Total message size.
61 
62  /// Check the given size.
63  static void validateSize(MessageSize size)
64  {
65  if (ONIXS_BATS_PITCH_CHECK_EXPECT((size < messageSize_), false))
66  throwIncorrectSize("TradingStatus", size, messageSize_);
67  }
68 
69  /// Initializes instance over given memory block.
70  TradingStatusMsg(const void* data, MessageSize size)
72  : BinaryMessage(data, size)
73  {
74  }
75  };
76 
77  /// Serializes object into string.
78  ONIXS_CBOECFE_PITCH_API void toStr(std::string&, const TradingStatusMsg&);
79 
80  /// Serializes object into string.
81  inline std::string toStr(const TradingStatusMsg& msg)
82  {
83  std::string str;
84  toStr(str, msg);
85  return str;
86  }
87 
88 }
89 }
90 }
91 }
StrRef symbol() const ONIXS_BATS_PITCH_NOTHROW
Symbol right padded with spaces.
Definition: TradingStatus.h:46
ONIXS_CBOECFE_PITCH_API ONIXS_BATS_PITCH_COLDPATH ONIXS_BATS_PITCH_NORETURN void throwIncorrectSize(const std::string &messageName, MessageSize receivedSize, MessageSize expectedSize)
static void validateSize(MessageSize size)
Check the given size.
Definition: TradingStatus.h:63
TradingStatus::Enum tradingStatus() const ONIXS_BATS_PITCH_NOTHROW
Trading Status.
Definition: TradingStatus.h:53
#define ONIXS_BATS_PITCH_CONST_OR_CONSTEXPR
Definition: Compiler.h:110
Provides efficient way of accessing text-based FIX field values.
Definition: String.h:45
TradingStatusMsg(const void *data, MessageSize size) ONIXS_BATS_PITCH_NOTHROW
Initializes instance over given memory block.
Definition: TradingStatus.h:70
Encapsulates services for manipulating little endian encoded messages.
BinaryMessage() ONIXS_BATS_PITCH_NOTHROW
Initializes blank instance referencing to nothing.
Binary2 MessageSize
Aliases message length type.
Definition: Defines.h:90
Binary4 timeOffset() const ONIXS_BATS_PITCH_NOTHROW
Nanosecond offset from last unit timestamp.
Definition: TradingStatus.h:39
The Trading Status message is used to indicate the current trading status of a Futures contract...
Definition: TradingStatus.h:36
static ONIXS_BATS_PITCH_CONST_OR_CONSTEXPR MessageSize messageSize_
Total message size.
Definition: TradingStatus.h:60
#define ONIXS_BATS_PITCH_NOTHROW
Definition: Compiler.h:107
ONIXS_CBOECFE_PITCH_API void toStr(std::string &, SideIndicator::Enum)
Appends string presentation of object.