Skip to main content

stellar_xdr/generated/
bucket_metadata.rs

1#[allow(unused_imports, clippy::wildcard_imports)]
2use super::*;
3
4/// BucketMetadata is an XDR Struct defined as:
5///
6/// ```text
7/// struct BucketMetadata
8/// {
9///     // Indicates the protocol version used to create / merge this bucket.
10///     uint32 ledgerVersion;
11///
12///     // reserved for future use
13///     union switch (int v)
14///     {
15///     case 0:
16///         void;
17///     case 1:
18///         BucketListType bucketListType;
19///     }
20///     ext;
21/// };
22/// ```
23///
24#[cfg_attr(feature = "alloc", derive(Default))]
25#[derive(Clone, Debug, Hash, PartialEq, Eq, PartialOrd, Ord)]
26#[cfg_attr(feature = "serde", cfg_eval::cfg_eval)]
27#[cfg_attr(feature = "arbitrary", derive(Arbitrary))]
28#[cfg_attr(
29    all(feature = "serde", feature = "alloc"),
30    serde_with::serde_as,
31    derive(serde::Serialize, serde::Deserialize),
32    serde(rename_all = "snake_case")
33)]
34#[cfg_attr(feature = "schemars", derive(schemars::JsonSchema))]
35pub struct BucketMetadata {
36    pub ledger_version: u32,
37    pub ext: BucketMetadataExt,
38}
39
40impl ReadXdr for BucketMetadata {
41    #[cfg(feature = "std")]
42    fn read_xdr<R: Read>(r: &mut Limited<R>) -> Result<Self, Error> {
43        r.with_limited_depth(|r| {
44            Ok(Self {
45                ledger_version: u32::read_xdr(r)?,
46                ext: BucketMetadataExt::read_xdr(r)?,
47            })
48        })
49    }
50}
51
52impl WriteXdr for BucketMetadata {
53    #[cfg(feature = "std")]
54    fn write_xdr<W: Write>(&self, w: &mut Limited<W>) -> Result<(), Error> {
55        w.with_limited_depth(|w| {
56            self.ledger_version.write_xdr(w)?;
57            self.ext.write_xdr(w)?;
58            Ok(())
59        })
60    }
61}