Skip to main content

stellar_xdr/generated/
peer_address_ip.rs

1#[allow(unused_imports, clippy::wildcard_imports)]
2use super::*;
3
4/// PeerAddressIp is an XDR NestedUnion defined as:
5///
6/// ```text
7/// union switch (IPAddrType type)
8///     {
9///     case IPv4:
10///         opaque ipv4[4];
11///     case IPv6:
12///         opaque ipv6[16];
13///     }
14/// ```
15///
16// union with discriminant IpAddrType
17#[cfg_attr(feature = "serde", cfg_eval::cfg_eval)]
18#[derive(Clone, Debug, Hash, PartialEq, Eq, PartialOrd, Ord)]
19#[cfg_attr(feature = "arbitrary", derive(Arbitrary))]
20#[cfg_attr(
21    all(feature = "serde", feature = "alloc"),
22    serde_with::serde_as,
23    derive(serde::Serialize, serde::Deserialize),
24    serde(rename_all = "snake_case")
25)]
26#[cfg_attr(feature = "schemars", derive(schemars::JsonSchema))]
27#[allow(clippy::large_enum_variant)]
28pub enum PeerAddressIp {
29    IPv4([u8; 4]),
30    IPv6([u8; 16]),
31}
32
33#[cfg(feature = "alloc")]
34impl Default for PeerAddressIp {
35    fn default() -> Self {
36        Self::IPv4(<[u8; 4]>::default())
37    }
38}
39
40impl PeerAddressIp {
41    const _VARIANTS: &[IpAddrType] = &[IpAddrType::IPv4, IpAddrType::IPv6];
42    pub const VARIANTS: [IpAddrType; Self::_VARIANTS.len()] = {
43        let mut arr = [Self::_VARIANTS[0]; Self::_VARIANTS.len()];
44        let mut i = 1;
45        while i < Self::_VARIANTS.len() {
46            arr[i] = Self::_VARIANTS[i];
47            i += 1;
48        }
49        arr
50    };
51    const _VARIANTS_STR: &[&str] = &["IPv4", "IPv6"];
52    pub const VARIANTS_STR: [&'static str; Self::_VARIANTS_STR.len()] = {
53        let mut arr = [Self::_VARIANTS_STR[0]; Self::_VARIANTS_STR.len()];
54        let mut i = 1;
55        while i < Self::_VARIANTS_STR.len() {
56            arr[i] = Self::_VARIANTS_STR[i];
57            i += 1;
58        }
59        arr
60    };
61
62    #[must_use]
63    pub const fn name(&self) -> &'static str {
64        match self {
65            Self::IPv4(_) => "IPv4",
66            Self::IPv6(_) => "IPv6",
67        }
68    }
69
70    #[must_use]
71    pub const fn discriminant(&self) -> IpAddrType {
72        #[allow(clippy::match_same_arms)]
73        match self {
74            Self::IPv4(_) => IpAddrType::IPv4,
75            Self::IPv6(_) => IpAddrType::IPv6,
76        }
77    }
78
79    #[must_use]
80    pub const fn variants() -> [IpAddrType; Self::_VARIANTS.len()] {
81        Self::VARIANTS
82    }
83}
84
85impl Name for PeerAddressIp {
86    #[must_use]
87    fn name(&self) -> &'static str {
88        Self::name(self)
89    }
90}
91
92impl Discriminant<IpAddrType> for PeerAddressIp {
93    #[must_use]
94    fn discriminant(&self) -> IpAddrType {
95        Self::discriminant(self)
96    }
97}
98
99impl Variants<IpAddrType> for PeerAddressIp {
100    fn variants() -> slice::Iter<'static, IpAddrType> {
101        Self::VARIANTS.iter()
102    }
103}
104
105impl Union<IpAddrType> for PeerAddressIp {}
106
107impl ReadXdr for PeerAddressIp {
108    #[cfg(feature = "std")]
109    fn read_xdr<R: Read>(r: &mut Limited<R>) -> Result<Self, Error> {
110        r.with_limited_depth(|r| {
111            let dv: IpAddrType = <IpAddrType as ReadXdr>::read_xdr(r)?;
112            #[allow(clippy::match_same_arms, clippy::match_wildcard_for_single_variants)]
113            let v = match dv {
114                IpAddrType::IPv4 => Self::IPv4(<[u8; 4]>::read_xdr(r)?),
115                IpAddrType::IPv6 => Self::IPv6(<[u8; 16]>::read_xdr(r)?),
116                #[allow(unreachable_patterns)]
117                _ => return Err(Error::Invalid),
118            };
119            Ok(v)
120        })
121    }
122}
123
124impl WriteXdr for PeerAddressIp {
125    #[cfg(feature = "std")]
126    fn write_xdr<W: Write>(&self, w: &mut Limited<W>) -> Result<(), Error> {
127        w.with_limited_depth(|w| {
128            self.discriminant().write_xdr(w)?;
129            #[allow(clippy::match_same_arms)]
130            match self {
131                Self::IPv4(v) => v.write_xdr(w)?,
132                Self::IPv6(v) => v.write_xdr(w)?,
133            };
134            Ok(())
135        })
136    }
137}