diff --git a/azalea-protocol/src/lib.rs b/azalea-protocol/src/lib.rs index aac449c9..973564eb 100644 --- a/azalea-protocol/src/lib.rs +++ b/azalea-protocol/src/lib.rs @@ -76,6 +76,33 @@ 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 +/// +impl<'de> serde::Deserialize<'de> for ServerAddress { + fn deserialize(deserializer: D) -> Result 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 }) + } +} + +/// +/// Serde Serialization for ServerAddress +/// Pretty much like impl Display +/// +impl serde::Serialize for ServerAddress { + fn serialize(&self, serializer: S) -> Result where S: serde::Serializer { + serializer.serialize_str(&format!("{}:{}", self.host, self.port)) + } +} + #[cfg(test)] mod tests { use std::io::Cursor;