use std::fmt::{self, Display, Formatter, Write};
use validators::{Validated, ValidatedWrapper};
use super::{
super::{
parameters::{
alternative_id::AlternativeID, any::Any, geo::Geo, label::Label, language::Language,
preference::Preference, property_id::PropertyID, time_zone::TimeZone, typ::Type,
Parameter,
},
values::{address_value::AddressValue, Value},
Set,
},
*,
};
#[derive(Clone, Debug, PartialEq, Eq, Hash)]
pub struct Address {
pub label: Option<Label>,
pub language: Option<Language>,
pub geo: Option<Geo>,
pub time_zone: Option<TimeZone>,
pub typ: Option<Type>,
pub property_id: Option<PropertyID>,
pub preference: Option<Preference>,
pub alternative_id: Option<AlternativeID>,
pub any: Option<Set<Any>>,
pub value: AddressValue,
}
impl Address {
pub fn from_address_value(address_value: AddressValue) -> Address {
Address {
label: None,
language: None,
geo: None,
time_zone: None,
typ: None,
property_id: None,
preference: None,
alternative_id: None,
any: None,
value: address_value,
}
}
pub fn is_empty(&self) -> bool {
self.value.is_empty()
}
}
impl Property for Address {
fn fmt(&self, f: &mut Formatter) -> Result<(), fmt::Error> {
if self.is_empty() {
return Ok(());
}
f.write_str("ADR")?;
macro_rules! fmt {
($c:tt, $p:ident) => {
fmt_g!($c, Parameter, self, $p, f);
};
}
fmt!(0, label);
fmt!(0, language);
fmt!(0, geo);
fmt!(0, time_zone);
fmt!(0, typ);
fmt!(0, property_id);
fmt!(0, preference);
fmt!(0, alternative_id);
fmt!(2, any);
f.write_char(':')?;
Value::fmt(&self.value, f)?;
f.write_str("\r\n")?;
Ok(())
}
}
impl Display for Address {
fn fmt(&self, f: &mut Formatter) -> Result<(), fmt::Error> {
Property::fmt(self, f)
}
}
impl Validated for Address {}
impl ValidatedWrapper for Address {
type Error = &'static str;
fn from_string(_from_string_input: String) -> Result<Self, Self::Error> {
unimplemented!();
}
fn from_str(_from_str_input: &str) -> Result<Self, Self::Error> {
unimplemented!();
}
}