Skip to main content

crabka_protocol/opt/rustwide/workdir/generated/common/owned/
ReplicaState.owned.rs

1// AUTO-GENERATED by crabka-protocol-codegen against a9ce3221537b8653448750697915607dc7936cf3. Do not edit.
2
3use bytes::{Buf, BufMut};
4
5use crate::primitives::fixed::{get_i32, get_i64, put_i32, put_i64};
6use crate::tagged_fields::{read_tagged_fields, tagged_fields_len, WriteTaggedFields};
7use crate::{Decode, Encode, ProtocolError, UnknownTaggedFields};
8
9#[derive(Debug, Clone, PartialEq, Eq)]
10pub struct ReplicaState {
11    pub replica_id: i32,
12    pub replica_directory_id: crate::primitives::uuid::Uuid,
13    pub log_end_offset: i64,
14    pub last_fetch_timestamp: i64,
15    pub last_caught_up_timestamp: i64,
16    pub unknown_tagged_fields: UnknownTaggedFields,
17}
18
19impl Default for ReplicaState {
20    fn default() -> Self {
21        Self {
22            replica_id: 0i32,
23            replica_directory_id: Default::default(),
24            log_end_offset: 0i64,
25            last_fetch_timestamp: -1i64,
26            last_caught_up_timestamp: -1i64,
27            unknown_tagged_fields: Default::default(),
28        }
29    }
30}
31
32impl Encode for ReplicaState {
33    fn encode<B: BufMut>(&self, buf: &mut B, version: i16) -> Result<(), ProtocolError> {
34        let flex = version >= 0;
35        if version >= 0 { put_i32(buf, self.replica_id) }
36        if version >= 2 { crate::primitives::uuid::put_uuid(buf, self.replica_directory_id) }
37        if version >= 0 { put_i64(buf, self.log_end_offset) }
38        if version >= 1 { put_i64(buf, self.last_fetch_timestamp) }
39        if version >= 1 { put_i64(buf, self.last_caught_up_timestamp) }
40        if flex {
41            let tagged = WriteTaggedFields::new();
42            tagged.write(buf, &self.unknown_tagged_fields);
43        }
44        Ok(())
45    }
46    fn encoded_len(&self, version: i16) -> usize {
47        let flex = version >= 0;
48        let mut n: usize = 0;
49        if version >= 0 { n += 4; }
50        if version >= 2 { n += 16; }
51        if version >= 0 { n += 8; }
52        if version >= 1 { n += 8; }
53        if version >= 1 { n += 8; }
54        if flex {
55            let known_pairs: Vec<(u32, usize)> = Vec::new();
56            n += tagged_fields_len(&known_pairs, &self.unknown_tagged_fields);
57        }
58        n
59    }
60}
61
62impl<'de> Decode<'de> for ReplicaState {
63    fn decode<B: Buf>(buf: &mut B, version: i16) -> Result<Self, ProtocolError> {
64        let flex = version >= 0;
65        let mut out = Self::default();
66        if version >= 0 { out.replica_id = get_i32(buf)?; }
67        if version >= 2 { out.replica_directory_id = crate::primitives::uuid::get_uuid(buf)?; }
68        if version >= 0 { out.log_end_offset = get_i64(buf)?; }
69        if version >= 1 { out.last_fetch_timestamp = get_i64(buf)?; }
70        if version >= 1 { out.last_caught_up_timestamp = get_i64(buf)?; }
71        if flex {
72            out.unknown_tagged_fields = read_tagged_fields(buf, |_tag, _payload| {
73                Ok(false)
74            })?;
75        }
76        Ok(out)
77    }
78}