use super::prelude::*;
#[derive(Parse, Peek, ToSpan, ToCursors, 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)]
#[derive(csskit_derives::NodeWithMetadata)]
#[metadata(node_kinds = AtRule | Deprecated, used_at_rules = Document)]
pub struct DocumentRule<'a> {
#[cfg_attr(feature = "visitable", visit(skip))]
#[atom(CssAtomSet::Document)]
pub name: T![AtKeyword],
pub prelude: DocumentMatcherList<'a>,
#[metadata(delegate)]
pub block: DocumentRuleBlock<'a>,
}
#[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))]
pub struct DocumentMatcherList<'a>(pub CommaSeparated<'a, DocumentMatcher>);
#[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 enum DocumentMatcher {
Url(T![Url]),
#[atom(CssAtomSet::Url)]
UrlFunction(T![Function], T![String], T![')']),
#[atom(CssAtomSet::UrlPrefix)]
UrlPrefix(T![Function], T![String], T![')']),
#[atom(CssAtomSet::Domain)]
Domain(T![Function], T![String], T![')']),
#[atom(CssAtomSet::MediaDocument)]
MediaDocument(T![Function], T![String], T![')']),
#[atom(CssAtomSet::Regexp)]
Regexp(T![Function], T![String], T![')']),
}
#[derive(Parse, Peek, ToSpan, ToCursors, SemanticEq, Debug, Clone, PartialEq, Eq, PartialOrd, Ord, Hash)]
#[cfg_attr(feature = "serde", derive(serde::Serialize), serde())]
#[cfg_attr(feature = "visitable", derive(csskit_derives::Visitable))]
#[derive(csskit_derives::NodeWithMetadata)]
pub struct DocumentRuleBlock<'a>(#[metadata(delegate)] pub RuleList<'a, Rule<'a>, CssMetadata>);
#[cfg(test)]
mod tests {
use super::*;
use crate::CssAtomSet;
use css_parse::assert_parse;
#[test]
fn size_test() {
assert_eq!(std::mem::size_of::<DocumentRule>(), 144);
assert_eq!(std::mem::size_of::<DocumentMatcher>(), 40);
assert_eq!(std::mem::size_of::<DocumentRuleBlock>(), 96);
}
#[test]
fn test_writes() {
assert_parse!(CssAtomSet::ATOMS, DocumentRule, r#"@document url("http://www.w3.org"){}"#);
assert_parse!(CssAtomSet::ATOMS, DocumentRule, r#"@document domain("mozilla.org"){}"#);
assert_parse!(CssAtomSet::ATOMS, DocumentRule, r#"@document url-prefix("http://www.w3.org/Style/"){}"#);
assert_parse!(CssAtomSet::ATOMS, DocumentRule, r#"@document media-document("video"){}"#);
assert_parse!(CssAtomSet::ATOMS, DocumentRule, r#"@document regexp("https:.*"){}"#);
assert_parse!(
CssAtomSet::ATOMS,
DocumentRule,
r#"@document url(http://www.w3.org),url-prefix("http://www.w3.org/Style/"),domain("mozilla.org"){}"#
);
assert_parse!(
CssAtomSet::ATOMS,
DocumentRule,
r#"@document url(http://www.w3.org),url-prefix("http://www.w3.org/Style/"),domain("mozilla.org"){body{color:black}}"#
);
}
}