crabka_protocol/opt/rustwide/workdir/generated/common/owned/
ReplicaState.owned.rs1use 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}