use super::super::parameters::alternative_id::AlternativeID;
use super::super::parameters::any::Any;
use super::super::parameters::media_type::MediaType;
use super::super::parameters::preference::Preference;
use super::super::parameters::property_id::PropertyID;
use super::super::parameters::typ::Type;
use super::super::parameters::Parameter;
use super::super::values::time_zone_value::TimeZoneValue;
use super::super::values::Value;
use super::super::Set;
use super::*;
use std::fmt::{self, Display, Formatter, Write};
use validators::{Validated, ValidatedWrapper};
#[derive(Clone, Debug, PartialEq, Eq, Hash)]
pub struct TimeZone {
pub typ: Option<Type>,
pub media_type: Option<MediaType>,
pub property_id: Option<PropertyID>,
pub preference: Option<Preference>,
pub alternative_id: Option<AlternativeID>,
pub any: Option<Set<Any>>,
pub value: TimeZoneValue,
}
impl TimeZone {
pub fn from_time_zone_value(time_zone_value: TimeZoneValue) -> TimeZone {
TimeZone {
typ: None,
media_type: None,
property_id: None,
preference: None,
alternative_id: None,
any: None,
value: time_zone_value,
}
}
}
impl Property for TimeZone {
fn fmt(&self, f: &mut Formatter) -> Result<(), fmt::Error> {
f.write_str("TZ")?;
macro_rules! fmt {
($c:tt, $p:ident) => {
fmt_g!($c, Parameter, self, $p, f);
};
}
fmt!(0, typ);
fmt!(0, media_type);
fmt!(0, property_id);
fmt!(0, preference);
fmt!(0, alternative_id);
fmt!(2, any);
if let TimeZoneValue::URI(_) = self.value {
f.write_str(";VALUE=uri:")?;
} else {
f.write_char(':')?;
}
Value::fmt(&self.value, f)?;
f.write_str("\r\n")?;
Ok(())
}
}
impl Display for TimeZone {
fn fmt(&self, f: &mut Formatter) -> Result<(), fmt::Error> {
Property::fmt(self, f)
}
}
impl Validated for TimeZone {}
impl ValidatedWrapper for TimeZone {
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!();
}
}