css_ast 0.0.25

CSS Abstract Syntax Trees with visitable nodes and style value types.
Documentation
use super::prelude::*;

/// <https://drafts.csswg.org/css-values/#time>
///
/// ```text,ignore
/// <time> = <dimension-token>
/// ```
#[derive(
	IntoCursor, ToSpan, SemanticEq, Parse, Peek, ToCursors, Debug, Copy, Clone, PartialEq, Eq, PartialOrd, Ord, Hash,
)]
#[cfg_attr(feature = "serde", derive(serde::Serialize), serde())]
#[cfg_attr(feature = "visitable", derive(csskit_derives::Visitable), visit(self))]
#[derive(csskit_derives::NodeWithMetadata)]
#[metadata(node_kinds = Dimension)]
pub enum Time {
	#[atom(CssAtomSet::Ms)]
	Ms(T![Dimension]),
	#[atom(CssAtomSet::S)]
	S(T![Dimension]),
}

impl Time {
	pub fn as_seconds(&self) -> f32 {
		match self {
			Self::Ms(f) => Into::<f32>::into(*f) / 1000.0,
			Self::S(f) => (*f).into(),
		}
	}
}

impl From<Time> for f32 {
	fn from(val: Time) -> Self {
		match val {
			Time::Ms(f) => f.into(),
			Time::S(f) => f.into(),
		}
	}
}

impl ToNumberValue for Time {
	fn to_number_value(&self) -> Option<f32> {
		Some((*self).into())
	}
}

#[cfg(test)]
mod tests {
	use super::*;
	use crate::CssAtomSet;
	use css_parse::{assert_parse, assert_parse_error};

	#[test]
	fn size_test() {
		assert_eq!(std::mem::size_of::<Time>(), 16);
	}

	#[test]
	fn test_writes() {
		assert_parse!(CssAtomSet::ATOMS, Time, "0s");
		assert_parse!(CssAtomSet::ATOMS, Time, "0ms");
		assert_parse!(CssAtomSet::ATOMS, Time, "1s");
		assert_parse!(CssAtomSet::ATOMS, Time, "100ms");
	}

	#[test]
	fn test_errors() {
		assert_parse_error!(CssAtomSet::ATOMS, Time, "0");
		assert_parse_error!(CssAtomSet::ATOMS, Time, "1");
		assert_parse_error!(CssAtomSet::ATOMS, Time, "foo");
	}
}