use super::prelude::*;
#[derive(ToSpan, ToCursors, SemanticEq, Debug, Default, 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))]
#[cfg_attr(feature = "css_feature_data", derive(::csskit_derives::ToCSSFeature), css_feature("css.at-rules.charset"))]
#[derive(csskit_derives::NodeWithMetadata)]
#[metadata(node_kinds = AtRule, used_at_rules = Charset)]
pub struct CharsetRule {
at_keyword: T![AtKeyword],
space: T![' '],
string: T![String],
semicolon: Option<T![;]>,
}
impl<'a> Parse<'a> for CharsetRule {
fn parse<I>(p: &mut Parser<'a, I>) -> ParserResult<Self>
where
I: Iterator<Item = Cursor> + Clone,
{
let at_keyword = p.parse::<T![AtKeyword]>()?;
let c: Cursor = at_keyword.into();
if !p.equals_atom(c, &CssAtomSet::Charset) {
Err(Diagnostic::new(c, Diagnostic::unexpected))?;
}
let space = p.parse::<T![' ']>()?;
let string = p.parse::<T![String]>()?;
let semicolon = p.parse::<T![;]>().ok();
Ok(Self { at_keyword, space, string, semicolon })
}
}
#[cfg(test)]
mod tests {
use super::*;
use crate::CssAtomSet;
use css_parse::assert_parse;
#[test]
fn size_test() {
assert_eq!(std::mem::size_of::<CharsetRule>(), 52);
}
#[test]
fn test_writes() {
assert_parse!(CssAtomSet::ATOMS, CharsetRule, "@charset \"utf-8\";");
assert_parse!(CssAtomSet::ATOMS, CharsetRule, "@charset \"UTF-8\";");
}
}