crabka_protocol/opt/rustwide/workdir/generated/
UpdateRaftVoterResponse.borrowed.rs1use bytes::BufMut;
4
5use crate::primitives::fixed::{get_i16, get_i32, put_i16, put_i32};
6use crate::primitives::string_bytes::{
7 compact_string_len, put_compact_string, put_string, string_len,
8};
9use crate::primitives::string_bytes_borrowed::{
10 get_compact_string_borrowed, get_string_borrowed,
11};
12use crate::tagged_fields::{encode_to_bytes, read_tagged_fields, tagged_fields_len, WriteTaggedFields};
13use crate::{Decode, DecodeBorrow, Encode, ProtocolError, UnknownTaggedFields};
14
15pub const API_KEY: i16 = 82;
16pub const MIN_VERSION: i16 = 0;
17pub const MAX_VERSION: i16 = 0;
18pub const FLEXIBLE_MIN: i16 = 0;
19
20#[inline]
21fn is_flexible(version: i16) -> bool { version >= FLEXIBLE_MIN }
22
23#[derive(Debug, Clone, PartialEq, Eq)]
24pub struct UpdateRaftVoterResponse {
25 pub throttle_time_ms: i32,
26 pub error_code: i16,
27 pub current_leader: crate::owned::update_raft_voter_response::CurrentLeader,
28 pub unknown_tagged_fields: UnknownTaggedFields,
29}
30
31impl Default for UpdateRaftVoterResponse {
32 fn default() -> Self {
33 Self {
34 throttle_time_ms: 0i32,
35 error_code: 0i16,
36 current_leader: Default::default(),
37 unknown_tagged_fields: Default::default(),
38 }
39 }
40}
41
42impl UpdateRaftVoterResponse {
43 pub fn to_owned(&self) -> crate::owned::update_raft_voter_response::UpdateRaftVoterResponse {
44 crate::owned::update_raft_voter_response::UpdateRaftVoterResponse {
45 throttle_time_ms: (self.throttle_time_ms),
46 error_code: (self.error_code),
47 current_leader: self.current_leader.clone(),
48 unknown_tagged_fields: self.unknown_tagged_fields.clone(),
49 }
50 }
51}
52
53impl Encode for UpdateRaftVoterResponse {
54 fn encode<B: BufMut>(&self, buf: &mut B, version: i16) -> Result<(), ProtocolError> {
55 if !(MIN_VERSION..=MAX_VERSION).contains(&version) {
56 return Err(ProtocolError::UnsupportedVersion { api_key: API_KEY, version });
57 }
58 let flex = is_flexible(version);
59 if version >= 0 { put_i32(buf, self.throttle_time_ms) }
60 if version >= 0 { put_i16(buf, self.error_code) }
61 if flex {
62 let mut tagged = WriteTaggedFields::new();
63 if !(crate::codegen_helpers::is_default(&self.current_leader)) {
64 let payload = encode_to_bytes(self.current_leader.encoded_len(version), |b| { self.current_leader.encode(b, version)?; Ok(()) });
65 tagged.add(0, payload);
66 }
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 { n += 4; }
75 if version >= 0 { n += 2; }
76 if flex {
77 let mut known_pairs: Vec<(u32, usize)> = Vec::new();
78 if !(crate::codegen_helpers::is_default(&self.current_leader)) {
79 known_pairs.push((0, self.current_leader.encoded_len(version)));
80 }
81 n += tagged_fields_len(&known_pairs, &self.unknown_tagged_fields);
82 }
83 n
84 }
85}
86
87impl<'de> DecodeBorrow<'de> for UpdateRaftVoterResponse {
88 fn decode_borrow(buf: &mut &'de [u8], version: i16) -> Result<Self, ProtocolError> {
89 if !(MIN_VERSION..=MAX_VERSION).contains(&version) {
90 return Err(ProtocolError::UnsupportedVersion { api_key: API_KEY, version });
91 }
92 let flex = is_flexible(version);
93 let mut out = Self::default();
94 if version >= 0 { out.throttle_time_ms = get_i32(buf)?; }
95 if version >= 0 { out.error_code = get_i16(buf)?; }
96 if flex {
97 let mut tag_current_leader = None;
99 out.unknown_tagged_fields = read_tagged_fields(buf, |tag, payload| {
100 match tag {
101 0 => { tag_current_leader = Some({ let b: &mut &[u8] = payload; crate::owned::update_raft_voter_response::CurrentLeader::decode(b, version)? }); Ok(true) }
102 _ => Ok(false),
103 }
104 })?;
105 if let Some(v) = tag_current_leader { out.current_leader = v; }
106 }
107 Ok(out)
108 }
109}
110
111#[derive(Debug, Clone, PartialEq, Eq)]
112pub struct CurrentLeader<'a> {
113 pub leader_id: i32,
114 pub leader_epoch: i32,
115 pub host: &'a str,
116 pub port: i32,
117 pub unknown_tagged_fields: UnknownTaggedFields,
118}
119
120impl<'a> Default for CurrentLeader<'a> {
121 fn default() -> Self {
122 Self {
123 leader_id: -1i32,
124 leader_epoch: -1i32,
125 host: "",
126 port: 0i32,
127 unknown_tagged_fields: Default::default(),
128 }
129 }
130}
131
132impl<'a> CurrentLeader<'a> {
133 pub fn to_owned(&self) -> crate::owned::update_raft_voter_response::CurrentLeader {
134 crate::owned::update_raft_voter_response::CurrentLeader {
135 leader_id: (self.leader_id),
136 leader_epoch: (self.leader_epoch),
137 host: (self.host).to_string(),
138 port: (self.port),
139 unknown_tagged_fields: self.unknown_tagged_fields.clone(),
140 }
141 }
142}
143
144impl<'a> Encode for CurrentLeader<'a> {
145 fn encode<B: BufMut>(&self, buf: &mut B, version: i16) -> Result<(), ProtocolError> {
146 let flex = version >= 0;
147 if version >= 0 { put_i32(buf, self.leader_id) }
148 if version >= 0 { put_i32(buf, self.leader_epoch) }
149 if version >= 0 { if flex { put_compact_string(buf, self.host) } else { put_string(buf, self.host) } }
150 if version >= 0 { put_i32(buf, self.port) }
151 if flex {
152 let tagged = WriteTaggedFields::new();
153 tagged.write(buf, &self.unknown_tagged_fields);
154 }
155 Ok(())
156 }
157 fn encoded_len(&self, version: i16) -> usize {
158 let flex = version >= 0;
159 let mut n: usize = 0;
160 if version >= 0 { n += 4; }
161 if version >= 0 { n += 4; }
162 if version >= 0 { n += if flex { compact_string_len(self.host) } else { string_len(self.host) }; }
163 if version >= 0 { n += 4; }
164 if flex {
165 let known_pairs: Vec<(u32, usize)> = Vec::new();
166 n += tagged_fields_len(&known_pairs, &self.unknown_tagged_fields);
167 }
168 n
169 }
170}
171
172impl<'de> DecodeBorrow<'de> for CurrentLeader<'de> {
173 fn decode_borrow(buf: &mut &'de [u8], version: i16) -> Result<Self, ProtocolError> {
174 let flex = version >= 0;
175 let mut out = Self::default();
176 if version >= 0 { out.leader_id = get_i32(buf)?; }
177 if version >= 0 { out.leader_epoch = get_i32(buf)?; }
178 if version >= 0 { out.host = if flex { get_compact_string_borrowed(buf)? } else { get_string_borrowed(buf)? }; }
179 if version >= 0 { out.port = get_i32(buf)?; }
180 if flex {
181 out.unknown_tagged_fields = read_tagged_fields(buf, |_tag, _payload| {
182 Ok(false)
183 })?;
184 }
185 Ok(out)
186 }
187}