pub use decoder::ExchangeInfoResponseDecoder;
pub use encoder::ExchangeInfoResponseEncoder;
use super::*;
pub use super::{SBE_SCHEMA_ID, SBE_SCHEMA_VERSION, SBE_SEMANTIC_VERSION};
pub const SBE_BLOCK_LENGTH: u16 = 0;
pub const SBE_TEMPLATE_ID: u16 = 103;
pub mod encoder {
use message_header_codec::*;
use super::*;
#[derive(Debug, Default)]
pub struct ExchangeInfoResponseEncoder<'a> {
buf: WriteBuf<'a>,
initial_offset: usize,
offset: usize,
limit: usize,
}
impl<'a> Writer<'a> for ExchangeInfoResponseEncoder<'a> {
#[inline]
fn get_buf_mut(&mut self) -> &mut WriteBuf<'a> {
&mut self.buf
}
}
impl<'a> Encoder<'a> for ExchangeInfoResponseEncoder<'a> {
#[inline]
fn get_limit(&self) -> usize {
self.limit
}
#[inline]
fn set_limit(&mut self, limit: usize) {
self.limit = limit;
}
}
impl<'a> ExchangeInfoResponseEncoder<'a> {
pub fn wrap(mut self, buf: WriteBuf<'a>, offset: usize) -> Self {
let limit = offset + SBE_BLOCK_LENGTH as usize;
self.buf = buf;
self.initial_offset = offset;
self.offset = offset;
self.limit = limit;
self
}
#[inline]
pub fn encoded_length(&self) -> usize {
self.limit - self.offset
}
pub fn header(self, offset: usize) -> MessageHeaderEncoder<Self> {
let mut header = MessageHeaderEncoder::default().wrap(self, offset);
header.block_length(SBE_BLOCK_LENGTH);
header.template_id(SBE_TEMPLATE_ID);
header.schema_id(SBE_SCHEMA_ID);
header.version(SBE_SCHEMA_VERSION);
header
}
#[inline]
pub fn rate_limits_encoder(
self,
count: u32,
rate_limits_encoder: RateLimitsEncoder<Self>,
) -> RateLimitsEncoder<Self> {
rate_limits_encoder.wrap(self, count)
}
#[inline]
pub fn exchange_filters_encoder(
self,
count: u32,
exchange_filters_encoder: ExchangeFiltersEncoder<Self>,
) -> ExchangeFiltersEncoder<Self> {
exchange_filters_encoder.wrap(self, count)
}
#[inline]
pub fn symbols_encoder(
self,
count: u32,
symbols_encoder: SymbolsEncoder<Self>,
) -> SymbolsEncoder<Self> {
symbols_encoder.wrap(self, count)
}
#[inline]
pub fn sors_encoder(
self,
count: u32,
sors_encoder: SorsEncoder<Self>,
) -> SorsEncoder<Self> {
sors_encoder.wrap(self, count)
}
}
#[derive(Debug, Default)]
pub struct RateLimitsEncoder<P> {
parent: Option<P>,
count: u32,
index: usize,
offset: usize,
initial_limit: usize,
}
impl<'a, P> Writer<'a> for RateLimitsEncoder<P>
where
P: Writer<'a> + Default,
{
#[inline]
fn get_buf_mut(&mut self) -> &mut WriteBuf<'a> {
if let Some(parent) = self.parent.as_mut() {
parent.get_buf_mut()
} else {
panic!("parent was None")
}
}
}
impl<'a, P> Encoder<'a> for RateLimitsEncoder<P>
where
P: Encoder<'a> + Default,
{
#[inline]
fn get_limit(&self) -> usize {
self.parent.as_ref().expect("parent missing").get_limit()
}
#[inline]
fn set_limit(&mut self, limit: usize) {
self.parent
.as_mut()
.expect("parent missing")
.set_limit(limit);
}
}
impl<'a, P> RateLimitsEncoder<P>
where
P: Encoder<'a> + Default,
{
#[inline]
pub fn wrap(mut self, mut parent: P, count: u32) -> Self {
let initial_limit = parent.get_limit();
parent.set_limit(initial_limit + 6);
parent
.get_buf_mut()
.put_u16_at(initial_limit, Self::block_length());
parent.get_buf_mut().put_u32_at(initial_limit + 2, count);
self.parent = Some(parent);
self.count = count;
self.index = usize::MAX;
self.offset = usize::MAX;
self.initial_limit = initial_limit;
self
}
#[inline]
pub fn block_length() -> u16 {
11
}
#[inline]
pub fn parent(&mut self) -> SbeResult<P> {
self.parent.take().ok_or(SbeErr::ParentNotSet)
}
#[inline]
pub fn advance(&mut self) -> SbeResult<Option<usize>> {
let index = self.index.wrapping_add(1);
if index >= self.count as usize {
return Ok(None);
}
if let Some(parent) = self.parent.as_mut() {
self.offset = parent.get_limit();
parent.set_limit(self.offset + Self::block_length() as usize);
self.index = index;
Ok(Some(index))
} else {
Err(SbeErr::ParentNotSet)
}
}
#[inline]
pub fn rate_limit_type(&mut self, value: rate_limit_type::RateLimitType) {
let offset = self.offset;
self.get_buf_mut().put_u8_at(offset, value as u8)
}
#[inline]
pub fn interval(&mut self, value: rate_limit_interval::RateLimitInterval) {
let offset = self.offset + 1;
self.get_buf_mut().put_u8_at(offset, value as u8)
}
#[inline]
pub fn interval_num(&mut self, value: u8) {
let offset = self.offset + 2;
self.get_buf_mut().put_u8_at(offset, value);
}
#[inline]
pub fn rate_limit(&mut self, value: i64) {
let offset = self.offset + 3;
self.get_buf_mut().put_i64_at(offset, value);
}
}
#[derive(Debug, Default)]
pub struct ExchangeFiltersEncoder<P> {
parent: Option<P>,
count: u32,
index: usize,
offset: usize,
initial_limit: usize,
}
impl<'a, P> Writer<'a> for ExchangeFiltersEncoder<P>
where
P: Writer<'a> + Default,
{
#[inline]
fn get_buf_mut(&mut self) -> &mut WriteBuf<'a> {
if let Some(parent) = self.parent.as_mut() {
parent.get_buf_mut()
} else {
panic!("parent was None")
}
}
}
impl<'a, P> Encoder<'a> for ExchangeFiltersEncoder<P>
where
P: Encoder<'a> + Default,
{
#[inline]
fn get_limit(&self) -> usize {
self.parent.as_ref().expect("parent missing").get_limit()
}
#[inline]
fn set_limit(&mut self, limit: usize) {
self.parent
.as_mut()
.expect("parent missing")
.set_limit(limit);
}
}
impl<'a, P> ExchangeFiltersEncoder<P>
where
P: Encoder<'a> + Default,
{
#[inline]
pub fn wrap(mut self, mut parent: P, count: u32) -> Self {
let initial_limit = parent.get_limit();
parent.set_limit(initial_limit + 6);
parent
.get_buf_mut()
.put_u16_at(initial_limit, Self::block_length());
parent.get_buf_mut().put_u32_at(initial_limit + 2, count);
self.parent = Some(parent);
self.count = count;
self.index = usize::MAX;
self.offset = usize::MAX;
self.initial_limit = initial_limit;
self
}
#[inline]
pub fn block_length() -> u16 {
0
}
#[inline]
pub fn parent(&mut self) -> SbeResult<P> {
self.parent.take().ok_or(SbeErr::ParentNotSet)
}
#[inline]
pub fn advance(&mut self) -> SbeResult<Option<usize>> {
let index = self.index.wrapping_add(1);
if index >= self.count as usize {
return Ok(None);
}
if let Some(parent) = self.parent.as_mut() {
self.offset = parent.get_limit();
parent.set_limit(self.offset + Self::block_length() as usize);
self.index = index;
Ok(Some(index))
} else {
Err(SbeErr::ParentNotSet)
}
}
#[inline]
pub fn filter(&mut self, value: &[u8]) {
let limit = self.get_limit();
let data_length = value.len();
self.set_limit(limit + 1 + data_length);
self.get_buf_mut().put_u8_at(limit, data_length as u8);
self.get_buf_mut().put_slice_at(limit + 1, value);
}
}
#[derive(Debug, Default)]
pub struct SymbolsEncoder<P> {
parent: Option<P>,
count: u32,
index: usize,
offset: usize,
initial_limit: usize,
}
impl<'a, P> Writer<'a> for SymbolsEncoder<P>
where
P: Writer<'a> + Default,
{
#[inline]
fn get_buf_mut(&mut self) -> &mut WriteBuf<'a> {
if let Some(parent) = self.parent.as_mut() {
parent.get_buf_mut()
} else {
panic!("parent was None")
}
}
}
impl<'a, P> Encoder<'a> for SymbolsEncoder<P>
where
P: Encoder<'a> + Default,
{
#[inline]
fn get_limit(&self) -> usize {
self.parent.as_ref().expect("parent missing").get_limit()
}
#[inline]
fn set_limit(&mut self, limit: usize) {
self.parent
.as_mut()
.expect("parent missing")
.set_limit(limit);
}
}
impl<'a, P> SymbolsEncoder<P>
where
P: Encoder<'a> + Default,
{
#[inline]
pub fn wrap(mut self, mut parent: P, count: u32) -> Self {
let initial_limit = parent.get_limit();
parent.set_limit(initial_limit + 6);
parent
.get_buf_mut()
.put_u16_at(initial_limit, Self::block_length());
parent.get_buf_mut().put_u32_at(initial_limit + 2, count);
self.parent = Some(parent);
self.count = count;
self.index = usize::MAX;
self.offset = usize::MAX;
self.initial_limit = initial_limit;
self
}
#[inline]
pub fn block_length() -> u16 {
19
}
#[inline]
pub fn parent(&mut self) -> SbeResult<P> {
self.parent.take().ok_or(SbeErr::ParentNotSet)
}
#[inline]
pub fn advance(&mut self) -> SbeResult<Option<usize>> {
let index = self.index.wrapping_add(1);
if index >= self.count as usize {
return Ok(None);
}
if let Some(parent) = self.parent.as_mut() {
self.offset = parent.get_limit();
parent.set_limit(self.offset + Self::block_length() as usize);
self.index = index;
Ok(Some(index))
} else {
Err(SbeErr::ParentNotSet)
}
}
#[inline]
pub fn status(&mut self, value: symbol_status::SymbolStatus) {
let offset = self.offset;
self.get_buf_mut().put_u8_at(offset, value as u8)
}
#[inline]
pub fn base_asset_precision(&mut self, value: u8) {
let offset = self.offset + 1;
self.get_buf_mut().put_u8_at(offset, value);
}
#[inline]
pub fn quote_asset_precision(&mut self, value: u8) {
let offset = self.offset + 2;
self.get_buf_mut().put_u8_at(offset, value);
}
#[inline]
pub fn base_commission_precision(&mut self, value: u8) {
let offset = self.offset + 3;
self.get_buf_mut().put_u8_at(offset, value);
}
#[inline]
pub fn quote_commission_precision(&mut self, value: u8) {
let offset = self.offset + 4;
self.get_buf_mut().put_u8_at(offset, value);
}
#[inline]
pub fn order_types(&mut self, value: order_types::OrderTypes) {
let offset = self.offset + 5;
self.get_buf_mut().put_u16_at(offset, value.0)
}
#[inline]
pub fn iceberg_allowed(&mut self, value: bool_enum::BoolEnum) {
let offset = self.offset + 7;
self.get_buf_mut().put_u8_at(offset, value as u8)
}
#[inline]
pub fn oco_allowed(&mut self, value: bool_enum::BoolEnum) {
let offset = self.offset + 8;
self.get_buf_mut().put_u8_at(offset, value as u8)
}
#[inline]
pub fn oto_allowed(&mut self, value: bool_enum::BoolEnum) {
let offset = self.offset + 9;
self.get_buf_mut().put_u8_at(offset, value as u8)
}
#[inline]
pub fn quote_order_qty_market_allowed(&mut self, value: bool_enum::BoolEnum) {
let offset = self.offset + 10;
self.get_buf_mut().put_u8_at(offset, value as u8)
}
#[inline]
pub fn allow_trailing_stop(&mut self, value: bool_enum::BoolEnum) {
let offset = self.offset + 11;
self.get_buf_mut().put_u8_at(offset, value as u8)
}
#[inline]
pub fn cancel_replace_allowed(&mut self, value: bool_enum::BoolEnum) {
let offset = self.offset + 12;
self.get_buf_mut().put_u8_at(offset, value as u8)
}
#[inline]
pub fn amend_allowed(&mut self, value: bool_enum::BoolEnum) {
let offset = self.offset + 13;
self.get_buf_mut().put_u8_at(offset, value as u8)
}
#[inline]
pub fn is_spot_trading_allowed(&mut self, value: bool_enum::BoolEnum) {
let offset = self.offset + 14;
self.get_buf_mut().put_u8_at(offset, value as u8)
}
#[inline]
pub fn is_margin_trading_allowed(&mut self, value: bool_enum::BoolEnum) {
let offset = self.offset + 15;
self.get_buf_mut().put_u8_at(offset, value as u8)
}
#[inline]
pub fn default_self_trade_prevention_mode(
&mut self,
value: self_trade_prevention_mode::SelfTradePreventionMode,
) {
let offset = self.offset + 16;
self.get_buf_mut().put_u8_at(offset, value as u8)
}
#[inline]
pub fn allowed_self_trade_prevention_modes(
&mut self,
value: allowed_self_trade_prevention_modes::AllowedSelfTradePreventionModes,
) {
let offset = self.offset + 17;
self.get_buf_mut().put_u8_at(offset, value.0)
}
#[inline]
pub fn peg_instructions_allowed(&mut self, value: bool_enum::BoolEnum) {
let offset = self.offset + 18;
self.get_buf_mut().put_u8_at(offset, value as u8)
}
#[inline]
pub fn filters_encoder(
self,
count: u32,
filters_encoder: FiltersEncoder<Self>,
) -> FiltersEncoder<Self> {
filters_encoder.wrap(self, count)
}
#[inline]
pub fn permission_sets_encoder(
self,
count: u32,
permission_sets_encoder: PermissionSetsEncoder<Self>,
) -> PermissionSetsEncoder<Self> {
permission_sets_encoder.wrap(self, count)
}
#[inline]
pub fn symbol(&mut self, value: &str) {
let limit = self.get_limit();
let data_length = value.len();
self.set_limit(limit + 1 + data_length);
self.get_buf_mut().put_u8_at(limit, data_length as u8);
self.get_buf_mut().put_slice_at(limit + 1, value.as_bytes());
}
#[inline]
pub fn base_asset(&mut self, value: &str) {
let limit = self.get_limit();
let data_length = value.len();
self.set_limit(limit + 1 + data_length);
self.get_buf_mut().put_u8_at(limit, data_length as u8);
self.get_buf_mut().put_slice_at(limit + 1, value.as_bytes());
}
#[inline]
pub fn quote_asset(&mut self, value: &str) {
let limit = self.get_limit();
let data_length = value.len();
self.set_limit(limit + 1 + data_length);
self.get_buf_mut().put_u8_at(limit, data_length as u8);
self.get_buf_mut().put_slice_at(limit + 1, value.as_bytes());
}
}
#[derive(Debug, Default)]
pub struct FiltersEncoder<P> {
parent: Option<P>,
count: u32,
index: usize,
offset: usize,
initial_limit: usize,
}
impl<'a, P> Writer<'a> for FiltersEncoder<P>
where
P: Writer<'a> + Default,
{
#[inline]
fn get_buf_mut(&mut self) -> &mut WriteBuf<'a> {
if let Some(parent) = self.parent.as_mut() {
parent.get_buf_mut()
} else {
panic!("parent was None")
}
}
}
impl<'a, P> Encoder<'a> for FiltersEncoder<P>
where
P: Encoder<'a> + Default,
{
#[inline]
fn get_limit(&self) -> usize {
self.parent.as_ref().expect("parent missing").get_limit()
}
#[inline]
fn set_limit(&mut self, limit: usize) {
self.parent
.as_mut()
.expect("parent missing")
.set_limit(limit);
}
}
impl<'a, P> FiltersEncoder<P>
where
P: Encoder<'a> + Default,
{
#[inline]
pub fn wrap(mut self, mut parent: P, count: u32) -> Self {
let initial_limit = parent.get_limit();
parent.set_limit(initial_limit + 6);
parent
.get_buf_mut()
.put_u16_at(initial_limit, Self::block_length());
parent.get_buf_mut().put_u32_at(initial_limit + 2, count);
self.parent = Some(parent);
self.count = count;
self.index = usize::MAX;
self.offset = usize::MAX;
self.initial_limit = initial_limit;
self
}
#[inline]
pub fn block_length() -> u16 {
0
}
#[inline]
pub fn parent(&mut self) -> SbeResult<P> {
self.parent.take().ok_or(SbeErr::ParentNotSet)
}
#[inline]
pub fn advance(&mut self) -> SbeResult<Option<usize>> {
let index = self.index.wrapping_add(1);
if index >= self.count as usize {
return Ok(None);
}
if let Some(parent) = self.parent.as_mut() {
self.offset = parent.get_limit();
parent.set_limit(self.offset + Self::block_length() as usize);
self.index = index;
Ok(Some(index))
} else {
Err(SbeErr::ParentNotSet)
}
}
#[inline]
pub fn filter(&mut self, value: &[u8]) {
let limit = self.get_limit();
let data_length = value.len();
self.set_limit(limit + 1 + data_length);
self.get_buf_mut().put_u8_at(limit, data_length as u8);
self.get_buf_mut().put_slice_at(limit + 1, value);
}
}
#[derive(Debug, Default)]
pub struct PermissionSetsEncoder<P> {
parent: Option<P>,
count: u32,
index: usize,
offset: usize,
initial_limit: usize,
}
impl<'a, P> Writer<'a> for PermissionSetsEncoder<P>
where
P: Writer<'a> + Default,
{
#[inline]
fn get_buf_mut(&mut self) -> &mut WriteBuf<'a> {
if let Some(parent) = self.parent.as_mut() {
parent.get_buf_mut()
} else {
panic!("parent was None")
}
}
}
impl<'a, P> Encoder<'a> for PermissionSetsEncoder<P>
where
P: Encoder<'a> + Default,
{
#[inline]
fn get_limit(&self) -> usize {
self.parent.as_ref().expect("parent missing").get_limit()
}
#[inline]
fn set_limit(&mut self, limit: usize) {
self.parent
.as_mut()
.expect("parent missing")
.set_limit(limit);
}
}
impl<'a, P> PermissionSetsEncoder<P>
where
P: Encoder<'a> + Default,
{
#[inline]
pub fn wrap(mut self, mut parent: P, count: u32) -> Self {
let initial_limit = parent.get_limit();
parent.set_limit(initial_limit + 6);
parent
.get_buf_mut()
.put_u16_at(initial_limit, Self::block_length());
parent.get_buf_mut().put_u32_at(initial_limit + 2, count);
self.parent = Some(parent);
self.count = count;
self.index = usize::MAX;
self.offset = usize::MAX;
self.initial_limit = initial_limit;
self
}
#[inline]
pub fn block_length() -> u16 {
0
}
#[inline]
pub fn parent(&mut self) -> SbeResult<P> {
self.parent.take().ok_or(SbeErr::ParentNotSet)
}
#[inline]
pub fn advance(&mut self) -> SbeResult<Option<usize>> {
let index = self.index.wrapping_add(1);
if index >= self.count as usize {
return Ok(None);
}
if let Some(parent) = self.parent.as_mut() {
self.offset = parent.get_limit();
parent.set_limit(self.offset + Self::block_length() as usize);
self.index = index;
Ok(Some(index))
} else {
Err(SbeErr::ParentNotSet)
}
}
#[inline]
pub fn permissions_encoder(
self,
count: u32,
permissions_encoder: PermissionsEncoder<Self>,
) -> PermissionsEncoder<Self> {
permissions_encoder.wrap(self, count)
}
}
#[derive(Debug, Default)]
pub struct PermissionsEncoder<P> {
parent: Option<P>,
count: u32,
index: usize,
offset: usize,
initial_limit: usize,
}
impl<'a, P> Writer<'a> for PermissionsEncoder<P>
where
P: Writer<'a> + Default,
{
#[inline]
fn get_buf_mut(&mut self) -> &mut WriteBuf<'a> {
if let Some(parent) = self.parent.as_mut() {
parent.get_buf_mut()
} else {
panic!("parent was None")
}
}
}
impl<'a, P> Encoder<'a> for PermissionsEncoder<P>
where
P: Encoder<'a> + Default,
{
#[inline]
fn get_limit(&self) -> usize {
self.parent.as_ref().expect("parent missing").get_limit()
}
#[inline]
fn set_limit(&mut self, limit: usize) {
self.parent
.as_mut()
.expect("parent missing")
.set_limit(limit);
}
}
impl<'a, P> PermissionsEncoder<P>
where
P: Encoder<'a> + Default,
{
#[inline]
pub fn wrap(mut self, mut parent: P, count: u32) -> Self {
let initial_limit = parent.get_limit();
parent.set_limit(initial_limit + 6);
parent
.get_buf_mut()
.put_u16_at(initial_limit, Self::block_length());
parent.get_buf_mut().put_u32_at(initial_limit + 2, count);
self.parent = Some(parent);
self.count = count;
self.index = usize::MAX;
self.offset = usize::MAX;
self.initial_limit = initial_limit;
self
}
#[inline]
pub fn block_length() -> u16 {
0
}
#[inline]
pub fn parent(&mut self) -> SbeResult<P> {
self.parent.take().ok_or(SbeErr::ParentNotSet)
}
#[inline]
pub fn advance(&mut self) -> SbeResult<Option<usize>> {
let index = self.index.wrapping_add(1);
if index >= self.count as usize {
return Ok(None);
}
if let Some(parent) = self.parent.as_mut() {
self.offset = parent.get_limit();
parent.set_limit(self.offset + Self::block_length() as usize);
self.index = index;
Ok(Some(index))
} else {
Err(SbeErr::ParentNotSet)
}
}
#[inline]
pub fn permission(&mut self, value: &str) {
let limit = self.get_limit();
let data_length = value.len();
self.set_limit(limit + 1 + data_length);
self.get_buf_mut().put_u8_at(limit, data_length as u8);
self.get_buf_mut().put_slice_at(limit + 1, value.as_bytes());
}
}
#[derive(Debug, Default)]
pub struct SorsEncoder<P> {
parent: Option<P>,
count: u32,
index: usize,
offset: usize,
initial_limit: usize,
}
impl<'a, P> Writer<'a> for SorsEncoder<P>
where
P: Writer<'a> + Default,
{
#[inline]
fn get_buf_mut(&mut self) -> &mut WriteBuf<'a> {
if let Some(parent) = self.parent.as_mut() {
parent.get_buf_mut()
} else {
panic!("parent was None")
}
}
}
impl<'a, P> Encoder<'a> for SorsEncoder<P>
where
P: Encoder<'a> + Default,
{
#[inline]
fn get_limit(&self) -> usize {
self.parent.as_ref().expect("parent missing").get_limit()
}
#[inline]
fn set_limit(&mut self, limit: usize) {
self.parent
.as_mut()
.expect("parent missing")
.set_limit(limit);
}
}
impl<'a, P> SorsEncoder<P>
where
P: Encoder<'a> + Default,
{
#[inline]
pub fn wrap(mut self, mut parent: P, count: u32) -> Self {
let initial_limit = parent.get_limit();
parent.set_limit(initial_limit + 6);
parent
.get_buf_mut()
.put_u16_at(initial_limit, Self::block_length());
parent.get_buf_mut().put_u32_at(initial_limit + 2, count);
self.parent = Some(parent);
self.count = count;
self.index = usize::MAX;
self.offset = usize::MAX;
self.initial_limit = initial_limit;
self
}
#[inline]
pub fn block_length() -> u16 {
0
}
#[inline]
pub fn parent(&mut self) -> SbeResult<P> {
self.parent.take().ok_or(SbeErr::ParentNotSet)
}
#[inline]
pub fn advance(&mut self) -> SbeResult<Option<usize>> {
let index = self.index.wrapping_add(1);
if index >= self.count as usize {
return Ok(None);
}
if let Some(parent) = self.parent.as_mut() {
self.offset = parent.get_limit();
parent.set_limit(self.offset + Self::block_length() as usize);
self.index = index;
Ok(Some(index))
} else {
Err(SbeErr::ParentNotSet)
}
}
#[inline]
pub fn sor_symbols_encoder(
self,
count: u32,
sor_symbols_encoder: SorSymbolsEncoder<Self>,
) -> SorSymbolsEncoder<Self> {
sor_symbols_encoder.wrap(self, count)
}
#[inline]
pub fn base_asset(&mut self, value: &str) {
let limit = self.get_limit();
let data_length = value.len();
self.set_limit(limit + 1 + data_length);
self.get_buf_mut().put_u8_at(limit, data_length as u8);
self.get_buf_mut().put_slice_at(limit + 1, value.as_bytes());
}
}
#[derive(Debug, Default)]
pub struct SorSymbolsEncoder<P> {
parent: Option<P>,
count: u32,
index: usize,
offset: usize,
initial_limit: usize,
}
impl<'a, P> Writer<'a> for SorSymbolsEncoder<P>
where
P: Writer<'a> + Default,
{
#[inline]
fn get_buf_mut(&mut self) -> &mut WriteBuf<'a> {
if let Some(parent) = self.parent.as_mut() {
parent.get_buf_mut()
} else {
panic!("parent was None")
}
}
}
impl<'a, P> Encoder<'a> for SorSymbolsEncoder<P>
where
P: Encoder<'a> + Default,
{
#[inline]
fn get_limit(&self) -> usize {
self.parent.as_ref().expect("parent missing").get_limit()
}
#[inline]
fn set_limit(&mut self, limit: usize) {
self.parent
.as_mut()
.expect("parent missing")
.set_limit(limit);
}
}
impl<'a, P> SorSymbolsEncoder<P>
where
P: Encoder<'a> + Default,
{
#[inline]
pub fn wrap(mut self, mut parent: P, count: u32) -> Self {
let initial_limit = parent.get_limit();
parent.set_limit(initial_limit + 6);
parent
.get_buf_mut()
.put_u16_at(initial_limit, Self::block_length());
parent.get_buf_mut().put_u32_at(initial_limit + 2, count);
self.parent = Some(parent);
self.count = count;
self.index = usize::MAX;
self.offset = usize::MAX;
self.initial_limit = initial_limit;
self
}
#[inline]
pub fn block_length() -> u16 {
0
}
#[inline]
pub fn parent(&mut self) -> SbeResult<P> {
self.parent.take().ok_or(SbeErr::ParentNotSet)
}
#[inline]
pub fn advance(&mut self) -> SbeResult<Option<usize>> {
let index = self.index.wrapping_add(1);
if index >= self.count as usize {
return Ok(None);
}
if let Some(parent) = self.parent.as_mut() {
self.offset = parent.get_limit();
parent.set_limit(self.offset + Self::block_length() as usize);
self.index = index;
Ok(Some(index))
} else {
Err(SbeErr::ParentNotSet)
}
}
#[inline]
pub fn symbol(&mut self, value: &str) {
let limit = self.get_limit();
let data_length = value.len();
self.set_limit(limit + 1 + data_length);
self.get_buf_mut().put_u8_at(limit, data_length as u8);
self.get_buf_mut().put_slice_at(limit + 1, value.as_bytes());
}
}
}
pub mod decoder {
use message_header_codec::*;
use super::*;
#[derive(Clone, Copy, Debug, Default)]
pub struct ExchangeInfoResponseDecoder<'a> {
buf: ReadBuf<'a>,
initial_offset: usize,
offset: usize,
limit: usize,
pub acting_block_length: u16,
pub acting_version: u16,
}
impl ActingVersion for ExchangeInfoResponseDecoder<'_> {
#[inline]
fn acting_version(&self) -> u16 {
self.acting_version
}
}
impl<'a> Reader<'a> for ExchangeInfoResponseDecoder<'a> {
#[inline]
fn get_buf(&self) -> &ReadBuf<'a> {
&self.buf
}
}
impl<'a> Decoder<'a> for ExchangeInfoResponseDecoder<'a> {
#[inline]
fn get_limit(&self) -> usize {
self.limit
}
#[inline]
fn set_limit(&mut self, limit: usize) {
self.limit = limit;
}
}
impl<'a> ExchangeInfoResponseDecoder<'a> {
pub fn wrap(
mut self,
buf: ReadBuf<'a>,
offset: usize,
acting_block_length: u16,
acting_version: u16,
) -> Self {
let limit = offset + acting_block_length as usize;
self.buf = buf;
self.initial_offset = offset;
self.offset = offset;
self.limit = limit;
self.acting_block_length = acting_block_length;
self.acting_version = acting_version;
self
}
#[inline]
pub fn encoded_length(&self) -> usize {
self.limit - self.offset
}
pub fn header(self, mut header: MessageHeaderDecoder<ReadBuf<'a>>, offset: usize) -> Self {
debug_assert_eq!(SBE_TEMPLATE_ID, header.template_id());
let acting_block_length = header.block_length();
let acting_version = header.version();
self.wrap(
header.parent().unwrap(),
offset + message_header_codec::ENCODED_LENGTH,
acting_block_length,
acting_version,
)
}
#[inline]
pub fn rate_limits_decoder(self) -> RateLimitsDecoder<Self> {
RateLimitsDecoder::default().wrap(self)
}
#[inline]
pub fn exchange_filters_decoder(self) -> ExchangeFiltersDecoder<Self> {
ExchangeFiltersDecoder::default().wrap(self)
}
#[inline]
pub fn symbols_decoder(self) -> SymbolsDecoder<Self> {
SymbolsDecoder::default().wrap(self)
}
#[inline]
pub fn sors_decoder(self) -> SorsDecoder<Self> {
SorsDecoder::default().wrap(self)
}
}
#[derive(Debug, Default)]
pub struct RateLimitsDecoder<P> {
parent: Option<P>,
block_length: u16,
count: u32,
index: usize,
offset: usize,
}
impl<'a, P> ActingVersion for RateLimitsDecoder<P>
where
P: Reader<'a> + ActingVersion + Default,
{
#[inline]
fn acting_version(&self) -> u16 {
self.parent.as_ref().unwrap().acting_version()
}
}
impl<'a, P> Reader<'a> for RateLimitsDecoder<P>
where
P: Reader<'a> + Default,
{
#[inline]
fn get_buf(&self) -> &ReadBuf<'a> {
self.parent.as_ref().expect("parent missing").get_buf()
}
}
impl<'a, P> Decoder<'a> for RateLimitsDecoder<P>
where
P: Decoder<'a> + ActingVersion + Default,
{
#[inline]
fn get_limit(&self) -> usize {
self.parent.as_ref().expect("parent missing").get_limit()
}
#[inline]
fn set_limit(&mut self, limit: usize) {
self.parent
.as_mut()
.expect("parent missing")
.set_limit(limit);
}
}
impl<'a, P> RateLimitsDecoder<P>
where
P: Decoder<'a> + ActingVersion + Default,
{
pub fn wrap(mut self, mut parent: P) -> Self {
let initial_offset = parent.get_limit();
let block_length = parent.get_buf().get_u16_at(initial_offset);
let count = parent.get_buf().get_u32_at(initial_offset + 2);
parent.set_limit(initial_offset + 6);
self.parent = Some(parent);
self.block_length = block_length;
self.count = count;
self.index = usize::MAX;
self.offset = 0;
self
}
#[inline]
pub fn parent(&mut self) -> SbeResult<P> {
self.parent.take().ok_or(SbeErr::ParentNotSet)
}
#[inline]
pub fn acting_version(&mut self) -> u16 {
self.parent.as_ref().unwrap().acting_version()
}
#[inline]
pub fn count(&self) -> u32 {
self.count
}
pub fn advance(&mut self) -> SbeResult<Option<usize>> {
let index = self.index.wrapping_add(1);
if index >= self.count as usize {
return Ok(None);
}
if let Some(parent) = self.parent.as_mut() {
self.offset = parent.get_limit();
parent.set_limit(self.offset + self.block_length as usize);
self.index = index;
Ok(Some(index))
} else {
Err(SbeErr::ParentNotSet)
}
}
#[inline]
pub fn rate_limit_type(&self) -> rate_limit_type::RateLimitType {
self.get_buf().get_u8_at(self.offset).into()
}
#[inline]
pub fn interval(&self) -> rate_limit_interval::RateLimitInterval {
self.get_buf().get_u8_at(self.offset + 1).into()
}
#[inline]
pub fn interval_num(&self) -> u8 {
self.get_buf().get_u8_at(self.offset + 2)
}
#[inline]
pub fn rate_limit(&self) -> i64 {
self.get_buf().get_i64_at(self.offset + 3)
}
}
#[derive(Debug, Default)]
pub struct ExchangeFiltersDecoder<P> {
parent: Option<P>,
block_length: u16,
count: u32,
index: usize,
offset: usize,
}
impl<'a, P> ActingVersion for ExchangeFiltersDecoder<P>
where
P: Reader<'a> + ActingVersion + Default,
{
#[inline]
fn acting_version(&self) -> u16 {
self.parent.as_ref().unwrap().acting_version()
}
}
impl<'a, P> Reader<'a> for ExchangeFiltersDecoder<P>
where
P: Reader<'a> + Default,
{
#[inline]
fn get_buf(&self) -> &ReadBuf<'a> {
self.parent.as_ref().expect("parent missing").get_buf()
}
}
impl<'a, P> Decoder<'a> for ExchangeFiltersDecoder<P>
where
P: Decoder<'a> + ActingVersion + Default,
{
#[inline]
fn get_limit(&self) -> usize {
self.parent.as_ref().expect("parent missing").get_limit()
}
#[inline]
fn set_limit(&mut self, limit: usize) {
self.parent
.as_mut()
.expect("parent missing")
.set_limit(limit);
}
}
impl<'a, P> ExchangeFiltersDecoder<P>
where
P: Decoder<'a> + ActingVersion + Default,
{
pub fn wrap(mut self, mut parent: P) -> Self {
let initial_offset = parent.get_limit();
let block_length = parent.get_buf().get_u16_at(initial_offset);
let count = parent.get_buf().get_u32_at(initial_offset + 2);
parent.set_limit(initial_offset + 6);
self.parent = Some(parent);
self.block_length = block_length;
self.count = count;
self.index = usize::MAX;
self.offset = 0;
self
}
#[inline]
pub fn parent(&mut self) -> SbeResult<P> {
self.parent.take().ok_or(SbeErr::ParentNotSet)
}
#[inline]
pub fn acting_version(&mut self) -> u16 {
self.parent.as_ref().unwrap().acting_version()
}
#[inline]
pub fn count(&self) -> u32 {
self.count
}
pub fn advance(&mut self) -> SbeResult<Option<usize>> {
let index = self.index.wrapping_add(1);
if index >= self.count as usize {
return Ok(None);
}
if let Some(parent) = self.parent.as_mut() {
self.offset = parent.get_limit();
parent.set_limit(self.offset + self.block_length as usize);
self.index = index;
Ok(Some(index))
} else {
Err(SbeErr::ParentNotSet)
}
}
#[inline]
pub fn filter_decoder(&mut self) -> (usize, usize) {
let offset = self.parent.as_ref().expect("parent missing").get_limit();
let data_length = self.get_buf().get_u8_at(offset) as usize;
self.parent
.as_mut()
.unwrap()
.set_limit(offset + 1 + data_length);
(offset + 1, data_length)
}
#[inline]
pub fn filter_slice(&'a self, coordinates: (usize, usize)) -> &'a [u8] {
debug_assert!(self.get_limit() >= coordinates.0 + coordinates.1);
self.get_buf().get_slice_at(coordinates.0, coordinates.1)
}
}
#[derive(Debug, Default)]
pub struct SymbolsDecoder<P> {
parent: Option<P>,
block_length: u16,
count: u32,
index: usize,
offset: usize,
}
impl<'a, P> ActingVersion for SymbolsDecoder<P>
where
P: Reader<'a> + ActingVersion + Default,
{
#[inline]
fn acting_version(&self) -> u16 {
self.parent.as_ref().unwrap().acting_version()
}
}
impl<'a, P> Reader<'a> for SymbolsDecoder<P>
where
P: Reader<'a> + Default,
{
#[inline]
fn get_buf(&self) -> &ReadBuf<'a> {
self.parent.as_ref().expect("parent missing").get_buf()
}
}
impl<'a, P> Decoder<'a> for SymbolsDecoder<P>
where
P: Decoder<'a> + ActingVersion + Default,
{
#[inline]
fn get_limit(&self) -> usize {
self.parent.as_ref().expect("parent missing").get_limit()
}
#[inline]
fn set_limit(&mut self, limit: usize) {
self.parent
.as_mut()
.expect("parent missing")
.set_limit(limit);
}
}
impl<'a, P> SymbolsDecoder<P>
where
P: Decoder<'a> + ActingVersion + Default,
{
pub fn wrap(mut self, mut parent: P) -> Self {
let initial_offset = parent.get_limit();
let block_length = parent.get_buf().get_u16_at(initial_offset);
let count = parent.get_buf().get_u32_at(initial_offset + 2);
parent.set_limit(initial_offset + 6);
self.parent = Some(parent);
self.block_length = block_length;
self.count = count;
self.index = usize::MAX;
self.offset = 0;
self
}
#[inline]
pub fn parent(&mut self) -> SbeResult<P> {
self.parent.take().ok_or(SbeErr::ParentNotSet)
}
#[inline]
pub fn acting_version(&mut self) -> u16 {
self.parent.as_ref().unwrap().acting_version()
}
#[inline]
pub fn count(&self) -> u32 {
self.count
}
pub fn advance(&mut self) -> SbeResult<Option<usize>> {
let index = self.index.wrapping_add(1);
if index >= self.count as usize {
return Ok(None);
}
if let Some(parent) = self.parent.as_mut() {
self.offset = parent.get_limit();
parent.set_limit(self.offset + self.block_length as usize);
self.index = index;
Ok(Some(index))
} else {
Err(SbeErr::ParentNotSet)
}
}
#[inline]
pub fn status(&self) -> symbol_status::SymbolStatus {
self.get_buf().get_u8_at(self.offset).into()
}
#[inline]
pub fn base_asset_precision(&self) -> u8 {
self.get_buf().get_u8_at(self.offset + 1)
}
#[inline]
pub fn quote_asset_precision(&self) -> u8 {
self.get_buf().get_u8_at(self.offset + 2)
}
#[inline]
pub fn base_commission_precision(&self) -> u8 {
self.get_buf().get_u8_at(self.offset + 3)
}
#[inline]
pub fn quote_commission_precision(&self) -> u8 {
self.get_buf().get_u8_at(self.offset + 4)
}
#[inline]
pub fn order_types(&self) -> order_types::OrderTypes {
order_types::OrderTypes::new(self.get_buf().get_u16_at(self.offset + 5))
}
#[inline]
pub fn iceberg_allowed(&self) -> bool_enum::BoolEnum {
self.get_buf().get_u8_at(self.offset + 7).into()
}
#[inline]
pub fn oco_allowed(&self) -> bool_enum::BoolEnum {
self.get_buf().get_u8_at(self.offset + 8).into()
}
#[inline]
pub fn oto_allowed(&self) -> bool_enum::BoolEnum {
self.get_buf().get_u8_at(self.offset + 9).into()
}
#[inline]
pub fn quote_order_qty_market_allowed(&self) -> bool_enum::BoolEnum {
self.get_buf().get_u8_at(self.offset + 10).into()
}
#[inline]
pub fn allow_trailing_stop(&self) -> bool_enum::BoolEnum {
self.get_buf().get_u8_at(self.offset + 11).into()
}
#[inline]
pub fn cancel_replace_allowed(&self) -> bool_enum::BoolEnum {
self.get_buf().get_u8_at(self.offset + 12).into()
}
#[inline]
pub fn amend_allowed(&self) -> bool_enum::BoolEnum {
self.get_buf().get_u8_at(self.offset + 13).into()
}
#[inline]
pub fn is_spot_trading_allowed(&self) -> bool_enum::BoolEnum {
self.get_buf().get_u8_at(self.offset + 14).into()
}
#[inline]
pub fn is_margin_trading_allowed(&self) -> bool_enum::BoolEnum {
self.get_buf().get_u8_at(self.offset + 15).into()
}
#[inline]
pub fn default_self_trade_prevention_mode(
&self,
) -> self_trade_prevention_mode::SelfTradePreventionMode {
self.get_buf().get_u8_at(self.offset + 16).into()
}
#[inline]
pub fn allowed_self_trade_prevention_modes(
&self,
) -> allowed_self_trade_prevention_modes::AllowedSelfTradePreventionModes {
allowed_self_trade_prevention_modes::AllowedSelfTradePreventionModes::new(
self.get_buf().get_u8_at(self.offset + 17),
)
}
#[inline]
pub fn peg_instructions_allowed(&self) -> bool_enum::BoolEnum {
if self.acting_version() < 1 {
return bool_enum::BoolEnum::default();
}
self.get_buf().get_u8_at(self.offset + 18).into()
}
#[inline]
pub fn filters_decoder(self) -> FiltersDecoder<Self> {
FiltersDecoder::default().wrap(self)
}
#[inline]
pub fn permission_sets_decoder(self) -> PermissionSetsDecoder<Self> {
PermissionSetsDecoder::default().wrap(self)
}
#[inline]
pub fn symbol_decoder(&mut self) -> (usize, usize) {
let offset = self.parent.as_ref().expect("parent missing").get_limit();
let data_length = self.get_buf().get_u8_at(offset) as usize;
self.parent
.as_mut()
.unwrap()
.set_limit(offset + 1 + data_length);
(offset + 1, data_length)
}
#[inline]
pub fn symbol_slice(&'a self, coordinates: (usize, usize)) -> &'a [u8] {
debug_assert!(self.get_limit() >= coordinates.0 + coordinates.1);
self.get_buf().get_slice_at(coordinates.0, coordinates.1)
}
#[inline]
pub fn base_asset_decoder(&mut self) -> (usize, usize) {
let offset = self.parent.as_ref().expect("parent missing").get_limit();
let data_length = self.get_buf().get_u8_at(offset) as usize;
self.parent
.as_mut()
.unwrap()
.set_limit(offset + 1 + data_length);
(offset + 1, data_length)
}
#[inline]
pub fn base_asset_slice(&'a self, coordinates: (usize, usize)) -> &'a [u8] {
debug_assert!(self.get_limit() >= coordinates.0 + coordinates.1);
self.get_buf().get_slice_at(coordinates.0, coordinates.1)
}
#[inline]
pub fn quote_asset_decoder(&mut self) -> (usize, usize) {
let offset = self.parent.as_ref().expect("parent missing").get_limit();
let data_length = self.get_buf().get_u8_at(offset) as usize;
self.parent
.as_mut()
.unwrap()
.set_limit(offset + 1 + data_length);
(offset + 1, data_length)
}
#[inline]
pub fn quote_asset_slice(&'a self, coordinates: (usize, usize)) -> &'a [u8] {
debug_assert!(self.get_limit() >= coordinates.0 + coordinates.1);
self.get_buf().get_slice_at(coordinates.0, coordinates.1)
}
}
#[derive(Debug, Default)]
pub struct FiltersDecoder<P> {
parent: Option<P>,
block_length: u16,
count: u32,
index: usize,
offset: usize,
}
impl<'a, P> ActingVersion for FiltersDecoder<P>
where
P: Reader<'a> + ActingVersion + Default,
{
#[inline]
fn acting_version(&self) -> u16 {
self.parent.as_ref().unwrap().acting_version()
}
}
impl<'a, P> Reader<'a> for FiltersDecoder<P>
where
P: Reader<'a> + Default,
{
#[inline]
fn get_buf(&self) -> &ReadBuf<'a> {
self.parent.as_ref().expect("parent missing").get_buf()
}
}
impl<'a, P> Decoder<'a> for FiltersDecoder<P>
where
P: Decoder<'a> + ActingVersion + Default,
{
#[inline]
fn get_limit(&self) -> usize {
self.parent.as_ref().expect("parent missing").get_limit()
}
#[inline]
fn set_limit(&mut self, limit: usize) {
self.parent
.as_mut()
.expect("parent missing")
.set_limit(limit);
}
}
impl<'a, P> FiltersDecoder<P>
where
P: Decoder<'a> + ActingVersion + Default,
{
pub fn wrap(mut self, mut parent: P) -> Self {
let initial_offset = parent.get_limit();
let block_length = parent.get_buf().get_u16_at(initial_offset);
let count = parent.get_buf().get_u32_at(initial_offset + 2);
parent.set_limit(initial_offset + 6);
self.parent = Some(parent);
self.block_length = block_length;
self.count = count;
self.index = usize::MAX;
self.offset = 0;
self
}
#[inline]
pub fn parent(&mut self) -> SbeResult<P> {
self.parent.take().ok_or(SbeErr::ParentNotSet)
}
#[inline]
pub fn acting_version(&mut self) -> u16 {
self.parent.as_ref().unwrap().acting_version()
}
#[inline]
pub fn count(&self) -> u32 {
self.count
}
pub fn advance(&mut self) -> SbeResult<Option<usize>> {
let index = self.index.wrapping_add(1);
if index >= self.count as usize {
return Ok(None);
}
if let Some(parent) = self.parent.as_mut() {
self.offset = parent.get_limit();
parent.set_limit(self.offset + self.block_length as usize);
self.index = index;
Ok(Some(index))
} else {
Err(SbeErr::ParentNotSet)
}
}
#[inline]
pub fn filter_decoder(&mut self) -> (usize, usize) {
let offset = self.parent.as_ref().expect("parent missing").get_limit();
let data_length = self.get_buf().get_u8_at(offset) as usize;
self.parent
.as_mut()
.unwrap()
.set_limit(offset + 1 + data_length);
(offset + 1, data_length)
}
#[inline]
pub fn filter_slice(&'a self, coordinates: (usize, usize)) -> &'a [u8] {
debug_assert!(self.get_limit() >= coordinates.0 + coordinates.1);
self.get_buf().get_slice_at(coordinates.0, coordinates.1)
}
}
#[derive(Debug, Default)]
pub struct PermissionSetsDecoder<P> {
parent: Option<P>,
block_length: u16,
count: u32,
index: usize,
offset: usize,
}
impl<'a, P> ActingVersion for PermissionSetsDecoder<P>
where
P: Reader<'a> + ActingVersion + Default,
{
#[inline]
fn acting_version(&self) -> u16 {
self.parent.as_ref().unwrap().acting_version()
}
}
impl<'a, P> Reader<'a> for PermissionSetsDecoder<P>
where
P: Reader<'a> + Default,
{
#[inline]
fn get_buf(&self) -> &ReadBuf<'a> {
self.parent.as_ref().expect("parent missing").get_buf()
}
}
impl<'a, P> Decoder<'a> for PermissionSetsDecoder<P>
where
P: Decoder<'a> + ActingVersion + Default,
{
#[inline]
fn get_limit(&self) -> usize {
self.parent.as_ref().expect("parent missing").get_limit()
}
#[inline]
fn set_limit(&mut self, limit: usize) {
self.parent
.as_mut()
.expect("parent missing")
.set_limit(limit);
}
}
impl<'a, P> PermissionSetsDecoder<P>
where
P: Decoder<'a> + ActingVersion + Default,
{
pub fn wrap(mut self, mut parent: P) -> Self {
let initial_offset = parent.get_limit();
let block_length = parent.get_buf().get_u16_at(initial_offset);
let count = parent.get_buf().get_u32_at(initial_offset + 2);
parent.set_limit(initial_offset + 6);
self.parent = Some(parent);
self.block_length = block_length;
self.count = count;
self.index = usize::MAX;
self.offset = 0;
self
}
#[inline]
pub fn parent(&mut self) -> SbeResult<P> {
self.parent.take().ok_or(SbeErr::ParentNotSet)
}
#[inline]
pub fn acting_version(&mut self) -> u16 {
self.parent.as_ref().unwrap().acting_version()
}
#[inline]
pub fn count(&self) -> u32 {
self.count
}
pub fn advance(&mut self) -> SbeResult<Option<usize>> {
let index = self.index.wrapping_add(1);
if index >= self.count as usize {
return Ok(None);
}
if let Some(parent) = self.parent.as_mut() {
self.offset = parent.get_limit();
parent.set_limit(self.offset + self.block_length as usize);
self.index = index;
Ok(Some(index))
} else {
Err(SbeErr::ParentNotSet)
}
}
#[inline]
pub fn permissions_decoder(self) -> PermissionsDecoder<Self> {
PermissionsDecoder::default().wrap(self)
}
}
#[derive(Debug, Default)]
pub struct PermissionsDecoder<P> {
parent: Option<P>,
block_length: u16,
count: u32,
index: usize,
offset: usize,
}
impl<'a, P> ActingVersion for PermissionsDecoder<P>
where
P: Reader<'a> + ActingVersion + Default,
{
#[inline]
fn acting_version(&self) -> u16 {
self.parent.as_ref().unwrap().acting_version()
}
}
impl<'a, P> Reader<'a> for PermissionsDecoder<P>
where
P: Reader<'a> + Default,
{
#[inline]
fn get_buf(&self) -> &ReadBuf<'a> {
self.parent.as_ref().expect("parent missing").get_buf()
}
}
impl<'a, P> Decoder<'a> for PermissionsDecoder<P>
where
P: Decoder<'a> + ActingVersion + Default,
{
#[inline]
fn get_limit(&self) -> usize {
self.parent.as_ref().expect("parent missing").get_limit()
}
#[inline]
fn set_limit(&mut self, limit: usize) {
self.parent
.as_mut()
.expect("parent missing")
.set_limit(limit);
}
}
impl<'a, P> PermissionsDecoder<P>
where
P: Decoder<'a> + ActingVersion + Default,
{
pub fn wrap(mut self, mut parent: P) -> Self {
let initial_offset = parent.get_limit();
let block_length = parent.get_buf().get_u16_at(initial_offset);
let count = parent.get_buf().get_u32_at(initial_offset + 2);
parent.set_limit(initial_offset + 6);
self.parent = Some(parent);
self.block_length = block_length;
self.count = count;
self.index = usize::MAX;
self.offset = 0;
self
}
#[inline]
pub fn parent(&mut self) -> SbeResult<P> {
self.parent.take().ok_or(SbeErr::ParentNotSet)
}
#[inline]
pub fn acting_version(&mut self) -> u16 {
self.parent.as_ref().unwrap().acting_version()
}
#[inline]
pub fn count(&self) -> u32 {
self.count
}
pub fn advance(&mut self) -> SbeResult<Option<usize>> {
let index = self.index.wrapping_add(1);
if index >= self.count as usize {
return Ok(None);
}
if let Some(parent) = self.parent.as_mut() {
self.offset = parent.get_limit();
parent.set_limit(self.offset + self.block_length as usize);
self.index = index;
Ok(Some(index))
} else {
Err(SbeErr::ParentNotSet)
}
}
#[inline]
pub fn permission_decoder(&mut self) -> (usize, usize) {
let offset = self.parent.as_ref().expect("parent missing").get_limit();
let data_length = self.get_buf().get_u8_at(offset) as usize;
self.parent
.as_mut()
.unwrap()
.set_limit(offset + 1 + data_length);
(offset + 1, data_length)
}
#[inline]
pub fn permission_slice(&'a self, coordinates: (usize, usize)) -> &'a [u8] {
debug_assert!(self.get_limit() >= coordinates.0 + coordinates.1);
self.get_buf().get_slice_at(coordinates.0, coordinates.1)
}
}
#[derive(Debug, Default)]
pub struct SorsDecoder<P> {
parent: Option<P>,
block_length: u16,
count: u32,
index: usize,
offset: usize,
}
impl<'a, P> ActingVersion for SorsDecoder<P>
where
P: Reader<'a> + ActingVersion + Default,
{
#[inline]
fn acting_version(&self) -> u16 {
self.parent.as_ref().unwrap().acting_version()
}
}
impl<'a, P> Reader<'a> for SorsDecoder<P>
where
P: Reader<'a> + Default,
{
#[inline]
fn get_buf(&self) -> &ReadBuf<'a> {
self.parent.as_ref().expect("parent missing").get_buf()
}
}
impl<'a, P> Decoder<'a> for SorsDecoder<P>
where
P: Decoder<'a> + ActingVersion + Default,
{
#[inline]
fn get_limit(&self) -> usize {
self.parent.as_ref().expect("parent missing").get_limit()
}
#[inline]
fn set_limit(&mut self, limit: usize) {
self.parent
.as_mut()
.expect("parent missing")
.set_limit(limit);
}
}
impl<'a, P> SorsDecoder<P>
where
P: Decoder<'a> + ActingVersion + Default,
{
pub fn wrap(mut self, mut parent: P) -> Self {
let initial_offset = parent.get_limit();
let block_length = parent.get_buf().get_u16_at(initial_offset);
let count = parent.get_buf().get_u32_at(initial_offset + 2);
parent.set_limit(initial_offset + 6);
self.parent = Some(parent);
self.block_length = block_length;
self.count = count;
self.index = usize::MAX;
self.offset = 0;
self
}
#[inline]
pub fn parent(&mut self) -> SbeResult<P> {
self.parent.take().ok_or(SbeErr::ParentNotSet)
}
#[inline]
pub fn acting_version(&mut self) -> u16 {
self.parent.as_ref().unwrap().acting_version()
}
#[inline]
pub fn count(&self) -> u32 {
self.count
}
pub fn advance(&mut self) -> SbeResult<Option<usize>> {
let index = self.index.wrapping_add(1);
if index >= self.count as usize {
return Ok(None);
}
if let Some(parent) = self.parent.as_mut() {
self.offset = parent.get_limit();
parent.set_limit(self.offset + self.block_length as usize);
self.index = index;
Ok(Some(index))
} else {
Err(SbeErr::ParentNotSet)
}
}
#[inline]
pub fn sor_symbols_decoder(self) -> SorSymbolsDecoder<Self> {
SorSymbolsDecoder::default().wrap(self)
}
#[inline]
pub fn base_asset_decoder(&mut self) -> (usize, usize) {
let offset = self.parent.as_ref().expect("parent missing").get_limit();
let data_length = self.get_buf().get_u8_at(offset) as usize;
self.parent
.as_mut()
.unwrap()
.set_limit(offset + 1 + data_length);
(offset + 1, data_length)
}
#[inline]
pub fn base_asset_slice(&'a self, coordinates: (usize, usize)) -> &'a [u8] {
debug_assert!(self.get_limit() >= coordinates.0 + coordinates.1);
self.get_buf().get_slice_at(coordinates.0, coordinates.1)
}
}
#[derive(Debug, Default)]
pub struct SorSymbolsDecoder<P> {
parent: Option<P>,
block_length: u16,
count: u32,
index: usize,
offset: usize,
}
impl<'a, P> ActingVersion for SorSymbolsDecoder<P>
where
P: Reader<'a> + ActingVersion + Default,
{
#[inline]
fn acting_version(&self) -> u16 {
self.parent.as_ref().unwrap().acting_version()
}
}
impl<'a, P> Reader<'a> for SorSymbolsDecoder<P>
where
P: Reader<'a> + Default,
{
#[inline]
fn get_buf(&self) -> &ReadBuf<'a> {
self.parent.as_ref().expect("parent missing").get_buf()
}
}
impl<'a, P> Decoder<'a> for SorSymbolsDecoder<P>
where
P: Decoder<'a> + ActingVersion + Default,
{
#[inline]
fn get_limit(&self) -> usize {
self.parent.as_ref().expect("parent missing").get_limit()
}
#[inline]
fn set_limit(&mut self, limit: usize) {
self.parent
.as_mut()
.expect("parent missing")
.set_limit(limit);
}
}
impl<'a, P> SorSymbolsDecoder<P>
where
P: Decoder<'a> + ActingVersion + Default,
{
pub fn wrap(mut self, mut parent: P) -> Self {
let initial_offset = parent.get_limit();
let block_length = parent.get_buf().get_u16_at(initial_offset);
let count = parent.get_buf().get_u32_at(initial_offset + 2);
parent.set_limit(initial_offset + 6);
self.parent = Some(parent);
self.block_length = block_length;
self.count = count;
self.index = usize::MAX;
self.offset = 0;
self
}
#[inline]
pub fn parent(&mut self) -> SbeResult<P> {
self.parent.take().ok_or(SbeErr::ParentNotSet)
}
#[inline]
pub fn acting_version(&mut self) -> u16 {
self.parent.as_ref().unwrap().acting_version()
}
#[inline]
pub fn count(&self) -> u32 {
self.count
}
pub fn advance(&mut self) -> SbeResult<Option<usize>> {
let index = self.index.wrapping_add(1);
if index >= self.count as usize {
return Ok(None);
}
if let Some(parent) = self.parent.as_mut() {
self.offset = parent.get_limit();
parent.set_limit(self.offset + self.block_length as usize);
self.index = index;
Ok(Some(index))
} else {
Err(SbeErr::ParentNotSet)
}
}
#[inline]
pub fn symbol_decoder(&mut self) -> (usize, usize) {
let offset = self.parent.as_ref().expect("parent missing").get_limit();
let data_length = self.get_buf().get_u8_at(offset) as usize;
self.parent
.as_mut()
.unwrap()
.set_limit(offset + 1 + data_length);
(offset + 1, data_length)
}
#[inline]
pub fn symbol_slice(&'a self, coordinates: (usize, usize)) -> &'a [u8] {
debug_assert!(self.get_limit() >= coordinates.0 + coordinates.1);
self.get_buf().get_slice_at(coordinates.0, coordinates.1)
}
}
}