From ca861d488b67dd20e6300a452d8c712eeeb3abbf Mon Sep 17 00:00:00 2001 From: Connor Skees Date: Sat, 4 Jul 2020 12:11:01 -0400 Subject: [PATCH] optimize common case of previously seen simple selectors --- src/selector/extend/mod.rs | 15 +++++++++++---- 1 file changed, 11 insertions(+), 4 deletions(-) diff --git a/src/selector/extend/mod.rs b/src/selector/extend/mod.rs index cbeb37e..f9404cb 100644 --- a/src/selector/extend/mod.rs +++ b/src/selector/extend/mod.rs @@ -912,10 +912,17 @@ impl Extender { for component in complex.components { if let ComplexSelectorComponent::Compound(component) = component { for simple in component.components { - self.selectors - .entry(simple.clone()) - .or_insert_with(SelectorHashSet::new) - .insert(selector.clone()); + // PERF: we compute the hash twice, which isn't great, but we avoid a superfluous + // clone in cases where we have already seen a simple selector (common in + // scenarios in which there is a lot of nesting) + if let Some(entry) = self.selectors.get_mut(&simple) { + entry.insert(selector.clone()) + } else { + self.selectors + .entry(simple.clone()) + .or_insert_with(SelectorHashSet::new) + .insert(selector.clone()); + } if let SimpleSelector::Pseudo(Pseudo { selector: Some(simple_selector),