css_ast 0.0.25

CSS Abstract Syntax Trees with visitable nodes and style value types.
Documentation
use super::prelude::*;
use crate::{CssAtomSet, types::Image};

/// <https://drafts.csswg.org/css-counter-styles-3/#funcdef-symbols>
///
/// ```text,ignore
/// symbols() = symbols( <symbols-type>? [ <string> | <image> ]+ )
/// ```
#[derive(Parse, Peek, ToCursors, ToSpan, SemanticEq, Debug, 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)]
pub struct SymbolsFunction<'a> {
	#[atom(CssAtomSet::Symbols)]
	pub name: T![Function],
	pub params: SymbolsFunctionParams<'a>,
	pub close: T![')'],
}

#[derive(Parse, Peek, ToCursors, ToSpan, SemanticEq, Debug, 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)]
pub struct SymbolsFunctionParams<'a> {
	pub symbols_type: Option<SymbolsType>,
	pub symbols: Vec<'a, Symbol<'a>>,
}

/// <https://drafts.csswg.org/css-counter-styles-3/#typedef-symbols-type>
///
/// ```text,ignore
/// <symbols-type> = cyclic | numeric | alphabetic | symbolic | fixed
/// ```
#[derive(Parse, Peek, ToCursors, ToSpan, SemanticEq, Debug, Clone, PartialEq, Eq, PartialOrd, Ord, Hash)]
#[cfg_attr(feature = "serde", derive(serde::Serialize), serde())]
#[cfg_attr(feature = "visitable", derive(csskit_derives::Visitable), visit(skip))]
#[derive(csskit_derives::NodeWithMetadata)]
pub enum SymbolsType {
	#[atom(CssAtomSet::Cyclic)]
	Cyclic(T![Ident]),
	#[atom(CssAtomSet::Numeric)]
	Numeric(T![Ident]),
	#[atom(CssAtomSet::Alphabetic)]
	Alphabetic(T![Ident]),
	#[atom(CssAtomSet::Symbolic)]
	Symbolic(T![Ident]),
	#[atom(CssAtomSet::Fixed)]
	Fixed(T![Ident]),
}

/// <https://drafts.csswg.org/css-counter-styles-3/#funcdef-symbols>
///
/// A single Symbol from the `<symbols()>` syntax
///
/// ```text,ignore
/// <string> | <image>
/// ```
#[derive(Parse, Peek, ToCursors, ToSpan, SemanticEq, Debug, Clone, PartialEq, Eq, PartialOrd, Ord, Hash)]
#[cfg_attr(feature = "serde", derive(serde::Serialize), serde())]
#[cfg_attr(feature = "visitable", derive(csskit_derives::Visitable), visit(children))]
#[derive(csskit_derives::NodeWithMetadata)]
pub enum Symbol<'a> {
	#[cfg_attr(feature = "visitable", visit(skip))]
	String(T![String]),
	Image(Image<'a>),
}

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

	#[test]
	fn size_test() {
		assert_eq!(std::mem::size_of::<SymbolsFunction>(), 72);
		assert_eq!(std::mem::size_of::<Symbol>(), 40);
		assert_eq!(std::mem::size_of::<SymbolsType>(), 16);
	}

	#[test]
	fn test_writes() {
		assert_parse!(CssAtomSet::ATOMS, SymbolsFunction, "symbols(symbolic'+')");
		assert_parse!(CssAtomSet::ATOMS, SymbolsFunction, "symbols(symbolic'*''†''‡')");
	}
}