1
2
Fork 0
mirror of https://github.com/mat-1/azalea.git synced 2025-08-02 14:26:04 +00:00

simplify ServerAddress serde implementations

This commit is contained in:
mat 2023-11-29 19:51:34 -06:00
parent 87c2bc2e5d
commit af818b3b58

View file

@ -76,30 +76,26 @@ impl Display for ServerAddress {
}
}
///
/// Serde Deserialization for ServerAddress
/// This is necessary for config file usage
/// We are not using TryFrom because we want to use the serde error system
///
/// Serde deserialization for ServerAddress. This is useful for config file
/// usage.
impl<'de> serde::Deserialize<'de> for ServerAddress {
fn deserialize<D>(deserializer: D) -> Result<Self, D::Error> where D: serde::Deserializer<'de> {
fn deserialize<D>(deserializer: D) -> Result<Self, D::Error>
where
D: serde::Deserializer<'de>,
{
let string = String::deserialize(deserializer)?;
let mut parts = string.split(':');
let host = parts.next().ok_or(serde::de::Error::custom("No host specified"))?.to_string();
// default the port to 25565
let port = parts.next().unwrap_or("25565");
let port = u16::from_str(port).map_err(|_| serde::de::Error::custom("Invalid port specified"))?;
Ok(ServerAddress { host, port })
ServerAddress::try_from(string.as_str()).map_err(serde::de::Error::custom)
}
}
///
/// Serde Serialization for ServerAddress
/// Pretty much like impl Display
///
/// Serde serialization for ServerAddress. This uses the Display impl, so it
/// will serialize to a string.
impl serde::Serialize for ServerAddress {
fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error> where S: serde::Serializer {
serializer.serialize_str(&format!("{}:{}", self.host, self.port))
fn serialize<S>(&self, serializer: S) -> Result<S::Ok, S::Error>
where
S: serde::Serializer,
{
serializer.serialize_str(&self.to_string())
}
}