pub(crate) struct CSSRuleListParser;
pub(crate) struct CSSDeclarationListParser;
pub(crate) type Name<'i> = cssparser::CowRcStr<'i>;
pub(crate) type Declaration<'i> = (Name<'i>, &'i str);
pub(crate) type QualifiedRule<'i> = (&'i str, Vec<Declaration<'i>>);
fn exhaust<'i>(input: &mut cssparser::Parser<'i, '_>) -> &'i str {
let start = input.position();
while input.next().is_ok() {}
input.slice_from(start)
}
impl<'i> cssparser::QualifiedRuleParser<'i> for CSSRuleListParser {
type Prelude = &'i str;
type QualifiedRule = QualifiedRule<'i>;
type Error = ();
fn parse_prelude<'t>(
&mut self,
input: &mut cssparser::Parser<'i, 't>,
) -> Result<Self::Prelude, cssparser::ParseError<'i, Self::Error>> {
Ok(exhaust(input))
}
fn parse_block<'t>(
&mut self,
prelude: Self::Prelude,
_: &cssparser::ParserState,
input: &mut cssparser::Parser<'i, 't>,
) -> Result<Self::QualifiedRule, cssparser::ParseError<'i, Self::Error>> {
let parser = cssparser::DeclarationListParser::new(input, CSSDeclarationListParser);
let declarations: Vec<_> = parser.flatten().collect();
Ok((prelude, declarations))
}
}
impl<'i> cssparser::DeclarationParser<'i> for CSSDeclarationListParser {
type Declaration = Declaration<'i>;
type Error = ();
fn parse_value<'t>(
&mut self,
name: Name<'i>,
input: &mut cssparser::Parser<'i, 't>,
) -> Result<Self::Declaration, cssparser::ParseError<'i, Self::Error>> {
Ok((name, exhaust(input)))
}
}
impl<'i> cssparser::AtRuleParser<'i> for CSSRuleListParser {
type Prelude = &'i str;
type AtRule = QualifiedRule<'i>;
type Error = ();
}
impl<'i> cssparser::AtRuleParser<'i> for CSSDeclarationListParser {
type Prelude = String;
type AtRule = Declaration<'i>;
type Error = ();
}