Skip to main content

crabka_protocol/opt/rustwide/workdir/generated/
AddOffsetsToTxnResponse.borrowed.rs

1// AUTO-GENERATED by crabka-protocol-codegen against a9ce3221537b8653448750697915607dc7936cf3. Do not edit.
2use crate::primitives::fixed::{get_i16, get_i32, put_i16, put_i32};
3use crate::tagged_fields::{WriteTaggedFields, read_tagged_fields, tagged_fields_len};
4use crate::{DecodeBorrow, Encode, ProtocolError, UnknownTaggedFields};
5use bytes::BufMut;
6pub const API_KEY: i16 = 25;
7pub const MIN_VERSION: i16 = 0;
8pub const MAX_VERSION: i16 = 4;
9pub const FLEXIBLE_MIN: i16 = 3;
10#[inline]
11fn is_flexible(version: i16) -> bool {
12    version >= FLEXIBLE_MIN
13}
14#[derive(Debug, Clone, PartialEq, Eq, Default)]
15pub struct AddOffsetsToTxnResponse {
16    pub throttle_time_ms: i32,
17    pub error_code: i16,
18    pub unknown_tagged_fields: UnknownTaggedFields,
19}
20impl AddOffsetsToTxnResponse {
21    pub fn to_owned(&self) -> crate::owned::add_offsets_to_txn_response::AddOffsetsToTxnResponse {
22        crate::owned::add_offsets_to_txn_response::AddOffsetsToTxnResponse {
23            throttle_time_ms: (self.throttle_time_ms),
24            error_code: (self.error_code),
25            unknown_tagged_fields: self.unknown_tagged_fields.clone(),
26        }
27    }
28}
29impl Encode for AddOffsetsToTxnResponse {
30    fn encode<B: BufMut>(&self, buf: &mut B, version: i16) -> Result<(), ProtocolError> {
31        if !(MIN_VERSION..=MAX_VERSION).contains(&version) {
32            return Err(ProtocolError::UnsupportedVersion {
33                api_key: API_KEY,
34                version,
35            });
36        }
37        let flex = is_flexible(version);
38        if version >= 0 {
39            put_i32(buf, self.throttle_time_ms);
40        }
41        if version >= 0 {
42            put_i16(buf, self.error_code);
43        }
44        if flex {
45            let tagged = WriteTaggedFields::new();
46            tagged.write(buf, &self.unknown_tagged_fields);
47        }
48        Ok(())
49    }
50    fn encoded_len(&self, version: i16) -> usize {
51        let flex = is_flexible(version);
52        let mut n: usize = 0;
53        if version >= 0 {
54            n += 4;
55        }
56        if version >= 0 {
57            n += 2;
58        }
59        if flex {
60            let known_pairs: Vec<(u32, usize)> = Vec::new();
61            n += tagged_fields_len(&known_pairs, &self.unknown_tagged_fields);
62        }
63        n
64    }
65}
66impl<'de> DecodeBorrow<'de> for AddOffsetsToTxnResponse {
67    fn decode_borrow(buf: &mut &'de [u8], version: i16) -> Result<Self, ProtocolError> {
68        if !(MIN_VERSION..=MAX_VERSION).contains(&version) {
69            return Err(ProtocolError::UnsupportedVersion {
70                api_key: API_KEY,
71                version,
72            });
73        }
74        let flex = is_flexible(version);
75        let mut out = Self::default();
76        if version >= 0 {
77            out.throttle_time_ms = get_i32(buf)?;
78        }
79        if version >= 0 {
80            out.error_code = get_i16(buf)?;
81        }
82        if flex {
83            out.unknown_tagged_fields = read_tagged_fields(buf, |_tag, _payload| Ok(false))?;
84        }
85        Ok(out)
86    }
87}
88#[cfg(test)]
89impl AddOffsetsToTxnResponse {
90    #[must_use]
91    pub fn populated(version: i16) -> Self {
92        let mut m = Self::default();
93        if version >= 0 {
94            m.throttle_time_ms = 1i32;
95        }
96        if version >= 0 {
97            m.error_code = 1i16;
98        }
99        m
100    }
101}