crabka_protocol/opt/rustwide/workdir/generated/
EndTxnResponse.borrowed.rs1use crate::primitives::fixed::{get_i16, get_i32, get_i64, put_i16, put_i32, put_i64};
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 = 26;
7pub const MIN_VERSION: i16 = 0;
8pub const MAX_VERSION: i16 = 5;
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)]
15pub struct EndTxnResponse {
16 pub throttle_time_ms: i32,
17 pub error_code: i16,
18 pub producer_id: i64,
19 pub producer_epoch: i16,
20 pub unknown_tagged_fields: UnknownTaggedFields,
21}
22impl Default for EndTxnResponse {
23 fn default() -> Self {
24 Self {
25 throttle_time_ms: 0i32,
26 error_code: 0i16,
27 producer_id: -1i64,
28 producer_epoch: -1i16,
29 unknown_tagged_fields: Default::default(),
30 }
31 }
32}
33impl EndTxnResponse {
34 pub fn to_owned(&self) -> crate::owned::end_txn_response::EndTxnResponse {
35 crate::owned::end_txn_response::EndTxnResponse {
36 throttle_time_ms: (self.throttle_time_ms),
37 error_code: (self.error_code),
38 producer_id: (self.producer_id),
39 producer_epoch: (self.producer_epoch),
40 unknown_tagged_fields: self.unknown_tagged_fields.clone(),
41 }
42 }
43}
44impl Encode for EndTxnResponse {
45 fn encode<B: BufMut>(&self, buf: &mut B, version: i16) -> Result<(), ProtocolError> {
46 if !(MIN_VERSION..=MAX_VERSION).contains(&version) {
47 return Err(ProtocolError::UnsupportedVersion {
48 api_key: API_KEY,
49 version,
50 });
51 }
52 let flex = is_flexible(version);
53 if version >= 0 {
54 put_i32(buf, self.throttle_time_ms);
55 }
56 if version >= 0 {
57 put_i16(buf, self.error_code);
58 }
59 if version >= 5 {
60 put_i64(buf, self.producer_id);
61 }
62 if version >= 5 {
63 put_i16(buf, self.producer_epoch);
64 }
65 if flex {
66 let tagged = WriteTaggedFields::new();
67 tagged.write(buf, &self.unknown_tagged_fields);
68 }
69 Ok(())
70 }
71 fn encoded_len(&self, version: i16) -> usize {
72 let flex = is_flexible(version);
73 let mut n: usize = 0;
74 if version >= 0 {
75 n += 4;
76 }
77 if version >= 0 {
78 n += 2;
79 }
80 if version >= 5 {
81 n += 8;
82 }
83 if version >= 5 {
84 n += 2;
85 }
86 if flex {
87 let known_pairs: Vec<(u32, usize)> = Vec::new();
88 n += tagged_fields_len(&known_pairs, &self.unknown_tagged_fields);
89 }
90 n
91 }
92}
93impl<'de> DecodeBorrow<'de> for EndTxnResponse {
94 fn decode_borrow(buf: &mut &'de [u8], version: i16) -> Result<Self, ProtocolError> {
95 if !(MIN_VERSION..=MAX_VERSION).contains(&version) {
96 return Err(ProtocolError::UnsupportedVersion {
97 api_key: API_KEY,
98 version,
99 });
100 }
101 let flex = is_flexible(version);
102 let mut out = Self::default();
103 if version >= 0 {
104 out.throttle_time_ms = get_i32(buf)?;
105 }
106 if version >= 0 {
107 out.error_code = get_i16(buf)?;
108 }
109 if version >= 5 {
110 out.producer_id = get_i64(buf)?;
111 }
112 if version >= 5 {
113 out.producer_epoch = get_i16(buf)?;
114 }
115 if flex {
116 out.unknown_tagged_fields = read_tagged_fields(buf, |_tag, _payload| Ok(false))?;
117 }
118 Ok(out)
119 }
120}
121#[cfg(test)]
122impl EndTxnResponse {
123 #[must_use]
124 pub fn populated(version: i16) -> Self {
125 let mut m = Self::default();
126 if version >= 0 {
127 m.throttle_time_ms = 1i32;
128 }
129 if version >= 0 {
130 m.error_code = 1i16;
131 }
132 if version >= 5 {
133 m.producer_id = 1i64;
134 }
135 if version >= 5 {
136 m.producer_epoch = 1i16;
137 }
138 m
139 }
140}