From 05d67e404d05c751fd14476fdfa1de03b6da154e Mon Sep 17 00:00:00 2001 From: ConnorSkees <39542938+ConnorSkees@users.noreply.github.com> Date: Sun, 5 Jan 2020 12:25:03 -0500 Subject: [PATCH] implement zip method to combine super selectors --- src/selector.rs | 16 ++++++++++++++++ 1 file changed, 16 insertions(+) diff --git a/src/selector.rs b/src/selector.rs index 161ba5c..e57481f 100644 --- a/src/selector.rs +++ b/src/selector.rs @@ -32,6 +32,8 @@ pub enum Selector { Attribute(Attribute), /// Pseudo selector: `:hover` Pseudo(String), + /// Used to signify no selector (when there is no super_selector of a rule) + None, } impl Display for Selector { @@ -49,6 +51,7 @@ impl Display for Selector { Selector::Preceding(lhs, rhs) => write!(f, "{} ~ {}", lhs, rhs), Selector::Attribute(attr) => write!(f, "{}", attr), Selector::Pseudo(s) => write!(f, ":{}", s), + Selector::None => write!(f, ""), } } } @@ -183,6 +186,19 @@ impl Selector { pub fn from_tokens(tokens: Peekable>) -> Selector { SelectorParser::new(tokens).all_selectors() } + + pub fn zip(self, other: Selector) -> Selector { + if let Selector::Multiple(lhs, rhs) = other { + return Selector::Multiple(Box::new(self.clone().zip(*lhs)), Box::new(self.zip(*rhs))); + } + match self { + Selector::Multiple(lhs, rhs) => { + Selector::Multiple(Box::new(lhs.zip(other.clone())), Box::new(rhs.zip(other))) + } + Selector::None => other, + _ => Selector::Descendant(Box::new(self), Box::new(other)), + } + } } #[derive(Clone, Debug, Eq, PartialEq)]