stellar_xdr/generated/
peer_address.rs1#[allow(unused_imports, clippy::wildcard_imports)]
2use super::*;
3
4#[cfg_attr(feature = "alloc", derive(Default))]
23#[derive(Clone, Debug, Hash, PartialEq, Eq, PartialOrd, Ord)]
24#[cfg_attr(feature = "serde", cfg_eval::cfg_eval)]
25#[cfg_attr(feature = "arbitrary", derive(Arbitrary))]
26#[cfg_attr(
27 all(feature = "serde", feature = "alloc"),
28 serde_with::serde_as,
29 derive(serde::Serialize, serde::Deserialize),
30 serde(rename_all = "snake_case")
31)]
32#[cfg_attr(feature = "schemars", derive(schemars::JsonSchema))]
33pub struct PeerAddress {
34 pub ip: PeerAddressIp,
35 pub port: u32,
36 pub num_failures: u32,
37}
38
39impl ReadXdr for PeerAddress {
40 #[cfg(feature = "std")]
41 fn read_xdr<R: Read>(r: &mut Limited<R>) -> Result<Self, Error> {
42 r.with_limited_depth(|r| {
43 Ok(Self {
44 ip: PeerAddressIp::read_xdr(r)?,
45 port: u32::read_xdr(r)?,
46 num_failures: u32::read_xdr(r)?,
47 })
48 })
49 }
50}
51
52impl WriteXdr for PeerAddress {
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.ip.write_xdr(w)?;
57 self.port.write_xdr(w)?;
58 self.num_failures.write_xdr(w)?;
59 Ok(())
60 })
61 }
62}