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