Skip to main content

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

1// AUTO-GENERATED by crabka-protocol-codegen against a9ce3221537b8653448750697915607dc7936cf3. Do not edit.
2
3use bytes::BufMut;
4
5use crate::primitives::fixed::{
6    get_i8, get_i16, get_i32, get_i64, put_i8, put_i16, put_i32, put_i64,
7};
8use crate::primitives::string_bytes::{
9    compact_nullable_string_len, nullable_string_len, put_compact_nullable_string,
10    put_nullable_string,
11};
12use crate::primitives::string_bytes_borrowed::{
13    get_compact_nullable_string_borrowed, get_nullable_string_borrowed,
14};
15use crate::tagged_fields::{WriteTaggedFields, read_tagged_fields, tagged_fields_len};
16use crate::{DecodeBorrow, Encode, ProtocolError, UnknownTaggedFields};
17
18pub const API_KEY: i16 = 84;
19pub const MIN_VERSION: i16 = 0;
20pub const MAX_VERSION: i16 = 0;
21pub const FLEXIBLE_MIN: i16 = 0;
22
23#[inline]
24fn is_flexible(version: i16) -> bool {
25    version >= FLEXIBLE_MIN
26}
27
28#[derive(Debug, Clone, PartialEq, Eq, Default)]
29pub struct ReadShareGroupStateResponse<'a> {
30    pub results: Vec<ReadStateResult<'a>>,
31    pub unknown_tagged_fields: UnknownTaggedFields,
32}
33impl ReadShareGroupStateResponse<'_> {
34    pub fn to_owned(
35        &self,
36    ) -> crate::owned::read_share_group_state_response::ReadShareGroupStateResponse {
37        crate::owned::read_share_group_state_response::ReadShareGroupStateResponse {
38            results: (self.results)
39                .iter()
40                .map(ReadStateResult::to_owned)
41                .collect(),
42            unknown_tagged_fields: self.unknown_tagged_fields.clone(),
43        }
44    }
45}
46impl Encode for ReadShareGroupStateResponse<'_> {
47    fn encode<B: BufMut>(&self, buf: &mut B, version: i16) -> Result<(), ProtocolError> {
48        if !(MIN_VERSION..=MAX_VERSION).contains(&version) {
49            return Err(ProtocolError::UnsupportedVersion {
50                api_key: API_KEY,
51                version,
52            });
53        }
54        let flex = is_flexible(version);
55        if version >= 0 {
56            {
57                crate::primitives::array::put_array_len(buf, (self.results).len(), flex);
58                for it in &self.results {
59                    it.encode(buf, version)?;
60                }
61            }
62        }
63        if flex {
64            let tagged = WriteTaggedFields::new();
65            tagged.write(buf, &self.unknown_tagged_fields);
66        }
67        Ok(())
68    }
69    fn encoded_len(&self, version: i16) -> usize {
70        let flex = is_flexible(version);
71        let mut n: usize = 0;
72        if version >= 0 {
73            n += {
74                let prefix =
75                    crate::primitives::array::array_len_prefix_len((self.results).len(), flex);
76                let body: usize = (self.results)
77                    .iter()
78                    .map(|it| it.encoded_len(version))
79                    .sum();
80                prefix + body
81            };
82        }
83        if flex {
84            let known_pairs: Vec<(u32, usize)> = Vec::new();
85            n += tagged_fields_len(&known_pairs, &self.unknown_tagged_fields);
86        }
87        n
88    }
89}
90impl<'de> DecodeBorrow<'de> for ReadShareGroupStateResponse<'de> {
91    fn decode_borrow(buf: &mut &'de [u8], version: i16) -> Result<Self, ProtocolError> {
92        if !(MIN_VERSION..=MAX_VERSION).contains(&version) {
93            return Err(ProtocolError::UnsupportedVersion {
94                api_key: API_KEY,
95                version,
96            });
97        }
98        let flex = is_flexible(version);
99        let mut out = Self::default();
100        if version >= 0 {
101            out.results = {
102                let n = crate::primitives::array::get_array_len(buf, flex)?;
103                let mut v = Vec::with_capacity(n);
104                for _ in 0..n {
105                    v.push(ReadStateResult::decode_borrow(buf, version)?);
106                }
107                v
108            };
109        }
110        if flex {
111            out.unknown_tagged_fields = read_tagged_fields(buf, |_tag, _payload| Ok(false))?;
112        }
113        Ok(out)
114    }
115}
116#[cfg(test)]
117impl ReadShareGroupStateResponse<'_> {
118    #[must_use]
119    pub fn populated(version: i16) -> Self {
120        let mut m = Self::default();
121        if version >= 0 {
122            m.results = vec![ReadStateResult::populated(version)];
123        }
124        m
125    }
126}
127#[derive(Debug, Clone, PartialEq, Eq, Default)]
128pub struct ReadStateResult<'a> {
129    pub topic_id: crate::primitives::uuid::Uuid,
130    pub partitions: Vec<PartitionResult<'a>>,
131    pub unknown_tagged_fields: UnknownTaggedFields,
132}
133impl ReadStateResult<'_> {
134    pub fn to_owned(&self) -> crate::owned::read_share_group_state_response::ReadStateResult {
135        crate::owned::read_share_group_state_response::ReadStateResult {
136            topic_id: (self.topic_id),
137            partitions: (self.partitions)
138                .iter()
139                .map(PartitionResult::to_owned)
140                .collect(),
141            unknown_tagged_fields: self.unknown_tagged_fields.clone(),
142        }
143    }
144}
145impl Encode for ReadStateResult<'_> {
146    fn encode<B: BufMut>(&self, buf: &mut B, version: i16) -> Result<(), ProtocolError> {
147        let flex = version >= 0;
148        if version >= 0 {
149            crate::primitives::uuid::put_uuid(buf, self.topic_id);
150        }
151        if version >= 0 {
152            {
153                crate::primitives::array::put_array_len(buf, (self.partitions).len(), flex);
154                for it in &self.partitions {
155                    it.encode(buf, version)?;
156                }
157            }
158        }
159        if flex {
160            let tagged = WriteTaggedFields::new();
161            tagged.write(buf, &self.unknown_tagged_fields);
162        }
163        Ok(())
164    }
165    fn encoded_len(&self, version: i16) -> usize {
166        let flex = version >= 0;
167        let mut n: usize = 0;
168        if version >= 0 {
169            n += 16;
170        }
171        if version >= 0 {
172            n += {
173                let prefix =
174                    crate::primitives::array::array_len_prefix_len((self.partitions).len(), flex);
175                let body: usize = (self.partitions)
176                    .iter()
177                    .map(|it| it.encoded_len(version))
178                    .sum();
179                prefix + body
180            };
181        }
182        if flex {
183            let known_pairs: Vec<(u32, usize)> = Vec::new();
184            n += tagged_fields_len(&known_pairs, &self.unknown_tagged_fields);
185        }
186        n
187    }
188}
189impl<'de> DecodeBorrow<'de> for ReadStateResult<'de> {
190    fn decode_borrow(buf: &mut &'de [u8], version: i16) -> Result<Self, ProtocolError> {
191        let flex = version >= 0;
192        let mut out = Self::default();
193        if version >= 0 {
194            out.topic_id = crate::primitives::uuid::get_uuid(buf)?;
195        }
196        if version >= 0 {
197            out.partitions = {
198                let n = crate::primitives::array::get_array_len(buf, flex)?;
199                let mut v = Vec::with_capacity(n);
200                for _ in 0..n {
201                    v.push(PartitionResult::decode_borrow(buf, version)?);
202                }
203                v
204            };
205        }
206        if flex {
207            out.unknown_tagged_fields = read_tagged_fields(buf, |_tag, _payload| Ok(false))?;
208        }
209        Ok(out)
210    }
211}
212#[cfg(test)]
213impl ReadStateResult<'_> {
214    #[must_use]
215    pub fn populated(version: i16) -> Self {
216        let mut m = Self::default();
217        if version >= 0 {
218            m.topic_id = crate::primitives::uuid::Uuid([1u8; 16]);
219        }
220        if version >= 0 {
221            m.partitions = vec![PartitionResult::populated(version)];
222        }
223        m
224    }
225}
226#[derive(Debug, Clone, PartialEq, Eq, Default)]
227pub struct PartitionResult<'a> {
228    pub partition: i32,
229    pub error_code: i16,
230    pub error_message: Option<&'a str>,
231    pub state_epoch: i32,
232    pub start_offset: i64,
233    pub state_batches: Vec<StateBatch>,
234    pub unknown_tagged_fields: UnknownTaggedFields,
235}
236impl PartitionResult<'_> {
237    pub fn to_owned(&self) -> crate::owned::read_share_group_state_response::PartitionResult {
238        crate::owned::read_share_group_state_response::PartitionResult {
239            partition: (self.partition),
240            error_code: (self.error_code),
241            error_message: (self.error_message).map(std::string::ToString::to_string),
242            state_epoch: (self.state_epoch),
243            start_offset: (self.start_offset),
244            state_batches: (self.state_batches)
245                .iter()
246                .map(StateBatch::to_owned)
247                .collect(),
248            unknown_tagged_fields: self.unknown_tagged_fields.clone(),
249        }
250    }
251}
252impl Encode for PartitionResult<'_> {
253    fn encode<B: BufMut>(&self, buf: &mut B, version: i16) -> Result<(), ProtocolError> {
254        let flex = version >= 0;
255        if version >= 0 {
256            put_i32(buf, self.partition);
257        }
258        if version >= 0 {
259            put_i16(buf, self.error_code);
260        }
261        if version >= 0 {
262            if flex {
263                put_compact_nullable_string(buf, self.error_message);
264            } else {
265                put_nullable_string(buf, self.error_message);
266            }
267        }
268        if version >= 0 {
269            put_i32(buf, self.state_epoch);
270        }
271        if version >= 0 {
272            put_i64(buf, self.start_offset);
273        }
274        if version >= 0 {
275            {
276                crate::primitives::array::put_array_len(buf, (self.state_batches).len(), flex);
277                for it in &self.state_batches {
278                    it.encode(buf, version)?;
279                }
280            }
281        }
282        if flex {
283            let tagged = WriteTaggedFields::new();
284            tagged.write(buf, &self.unknown_tagged_fields);
285        }
286        Ok(())
287    }
288    fn encoded_len(&self, version: i16) -> usize {
289        let flex = version >= 0;
290        let mut n: usize = 0;
291        if version >= 0 {
292            n += 4;
293        }
294        if version >= 0 {
295            n += 2;
296        }
297        if version >= 0 {
298            n += if flex {
299                compact_nullable_string_len(self.error_message)
300            } else {
301                nullable_string_len(self.error_message)
302            };
303        }
304        if version >= 0 {
305            n += 4;
306        }
307        if version >= 0 {
308            n += 8;
309        }
310        if version >= 0 {
311            n += {
312                let prefix = crate::primitives::array::array_len_prefix_len(
313                    (self.state_batches).len(),
314                    flex,
315                );
316                let body: usize = (self.state_batches)
317                    .iter()
318                    .map(|it| it.encoded_len(version))
319                    .sum();
320                prefix + body
321            };
322        }
323        if flex {
324            let known_pairs: Vec<(u32, usize)> = Vec::new();
325            n += tagged_fields_len(&known_pairs, &self.unknown_tagged_fields);
326        }
327        n
328    }
329}
330impl<'de> DecodeBorrow<'de> for PartitionResult<'de> {
331    fn decode_borrow(buf: &mut &'de [u8], version: i16) -> Result<Self, ProtocolError> {
332        let flex = version >= 0;
333        let mut out = Self::default();
334        if version >= 0 {
335            out.partition = get_i32(buf)?;
336        }
337        if version >= 0 {
338            out.error_code = get_i16(buf)?;
339        }
340        if version >= 0 {
341            out.error_message = if flex {
342                get_compact_nullable_string_borrowed(buf)?
343            } else {
344                get_nullable_string_borrowed(buf)?
345            };
346        }
347        if version >= 0 {
348            out.state_epoch = get_i32(buf)?;
349        }
350        if version >= 0 {
351            out.start_offset = get_i64(buf)?;
352        }
353        if version >= 0 {
354            out.state_batches = {
355                let n = crate::primitives::array::get_array_len(buf, flex)?;
356                let mut v = Vec::with_capacity(n);
357                for _ in 0..n {
358                    v.push(StateBatch::decode_borrow(buf, version)?);
359                }
360                v
361            };
362        }
363        if flex {
364            out.unknown_tagged_fields = read_tagged_fields(buf, |_tag, _payload| Ok(false))?;
365        }
366        Ok(out)
367    }
368}
369#[cfg(test)]
370impl PartitionResult<'_> {
371    #[must_use]
372    pub fn populated(version: i16) -> Self {
373        let mut m = Self::default();
374        if version >= 0 {
375            m.partition = 1i32;
376        }
377        if version >= 0 {
378            m.error_code = 1i16;
379        }
380        if version >= 0 {
381            m.error_message = Some("x");
382        }
383        if version >= 0 {
384            m.state_epoch = 1i32;
385        }
386        if version >= 0 {
387            m.start_offset = 1i64;
388        }
389        if version >= 0 {
390            m.state_batches = vec![StateBatch::populated(version)];
391        }
392        m
393    }
394}
395#[derive(Debug, Clone, PartialEq, Eq, Default)]
396pub struct StateBatch {
397    pub first_offset: i64,
398    pub last_offset: i64,
399    pub delivery_state: i8,
400    pub delivery_count: i16,
401    pub unknown_tagged_fields: UnknownTaggedFields,
402}
403impl StateBatch {
404    pub fn to_owned(&self) -> crate::owned::read_share_group_state_response::StateBatch {
405        crate::owned::read_share_group_state_response::StateBatch {
406            first_offset: (self.first_offset),
407            last_offset: (self.last_offset),
408            delivery_state: (self.delivery_state),
409            delivery_count: (self.delivery_count),
410            unknown_tagged_fields: self.unknown_tagged_fields.clone(),
411        }
412    }
413}
414impl Encode for StateBatch {
415    fn encode<B: BufMut>(&self, buf: &mut B, version: i16) -> Result<(), ProtocolError> {
416        let flex = version >= 0;
417        if version >= 0 {
418            put_i64(buf, self.first_offset);
419        }
420        if version >= 0 {
421            put_i64(buf, self.last_offset);
422        }
423        if version >= 0 {
424            put_i8(buf, self.delivery_state);
425        }
426        if version >= 0 {
427            put_i16(buf, self.delivery_count);
428        }
429        if flex {
430            let tagged = WriteTaggedFields::new();
431            tagged.write(buf, &self.unknown_tagged_fields);
432        }
433        Ok(())
434    }
435    fn encoded_len(&self, version: i16) -> usize {
436        let flex = version >= 0;
437        let mut n: usize = 0;
438        if version >= 0 {
439            n += 8;
440        }
441        if version >= 0 {
442            n += 8;
443        }
444        if version >= 0 {
445            n += 1;
446        }
447        if version >= 0 {
448            n += 2;
449        }
450        if flex {
451            let known_pairs: Vec<(u32, usize)> = Vec::new();
452            n += tagged_fields_len(&known_pairs, &self.unknown_tagged_fields);
453        }
454        n
455    }
456}
457impl<'de> DecodeBorrow<'de> for StateBatch {
458    fn decode_borrow(buf: &mut &'de [u8], version: i16) -> Result<Self, ProtocolError> {
459        let flex = version >= 0;
460        let mut out = Self::default();
461        if version >= 0 {
462            out.first_offset = get_i64(buf)?;
463        }
464        if version >= 0 {
465            out.last_offset = get_i64(buf)?;
466        }
467        if version >= 0 {
468            out.delivery_state = get_i8(buf)?;
469        }
470        if version >= 0 {
471            out.delivery_count = get_i16(buf)?;
472        }
473        if flex {
474            out.unknown_tagged_fields = read_tagged_fields(buf, |_tag, _payload| Ok(false))?;
475        }
476        Ok(out)
477    }
478}
479#[cfg(test)]
480impl StateBatch {
481    #[must_use]
482    pub fn populated(version: i16) -> Self {
483        let mut m = Self::default();
484        if version >= 0 {
485            m.first_offset = 1i64;
486        }
487        if version >= 0 {
488            m.last_offset = 1i64;
489        }
490        if version >= 0 {
491            m.delivery_state = 1i8;
492        }
493        if version >= 0 {
494            m.delivery_count = 1i16;
495        }
496        m
497    }
498}