diff options
author | bors-servo <lbergstrom+bors@mozilla.com> | 2017-05-17 05:40:14 -0500 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-05-17 05:40:14 -0500 |
commit | d8b7013fcddff79a9c879077e1a564d83201359c (patch) | |
tree | 88a16d0317249297479192f769217f69a8b39895 /components/script/dom/element.rs | |
parent | a7b77306f985b79d3b8b4d9b2cb51fa38f45bd39 (diff) | |
parent | 522f8489d6fca474e6aad1d341ee84a99c130738 (diff) | |
download | servo-d8b7013fcddff79a9c879077e1a564d83201359c.tar.gz servo-d8b7013fcddff79a9c879077e1a564d83201359c.zip |
Auto merge of #16900 - emilio:pseudos, r=bholley
Bug 1364850: Move PseudoElement to be just another combinator in selectors. r=bholley
On top of https://github.com/servo/servo/pull/16890.
<!-- Reviewable:start -->
---
This change is [<img src="https://reviewable.io/review_button.svg" height="34" align="absmiddle" alt="Reviewable"/>](https://reviewable.io/reviews/servo/servo/16900)
<!-- Reviewable:end -->
Diffstat (limited to 'components/script/dom/element.rs')
-rw-r--r-- | components/script/dom/element.rs | 20 |
1 files changed, 15 insertions, 5 deletions
diff --git a/components/script/dom/element.rs b/components/script/dom/element.rs index 011b87aabf1..6b844dd83a2 100644 --- a/components/script/dom/element.rs +++ b/components/script/dom/element.rs @@ -86,7 +86,7 @@ use net_traits::request::CorsSettings; use ref_filter_map::ref_filter_map; use script_layout_interface::message::ReflowQueryType; use script_thread::Runnable; -use selectors::matching::{ElementSelectorFlags, MatchingContext, matches_selector_list}; +use selectors::matching::{ElementSelectorFlags, MatchingContext, MatchingMode, matches_selector_list}; use selectors::matching::{HAS_EDGE_CHILD_SELECTOR, HAS_SLOW_SELECTOR, HAS_SLOW_SELECTOR_LATER_SIBLINGS}; use selectors::parser::{AttrSelector, NamespaceConstraint}; use servo_atoms::Atom; @@ -104,7 +104,7 @@ use style::properties::{Importance, PropertyDeclaration, PropertyDeclarationBloc use style::properties::longhands::{self, background_image, border_spacing, font_family, font_size, overflow_x}; use style::restyle_hints::RESTYLE_SELF; use style::rule_tree::CascadeLevel; -use style::selector_parser::{NonTSPseudoClass, RestyleDamage, SelectorImpl, SelectorParser}; +use style::selector_parser::{NonTSPseudoClass, PseudoElement, RestyleDamage, SelectorImpl, SelectorParser}; use style::shared_lock::{SharedRwLock, Locked}; use style::sink::Push; use style::stylearc::Arc; @@ -2058,7 +2058,8 @@ impl ElementMethods for Element { match SelectorParser::parse_author_origin_no_namespace(&selectors) { Err(()) => Err(Error::Syntax), Ok(selectors) => { - Ok(matches_selector_list(&selectors.0, &Root::from_ref(self), None)) + let mut ctx = MatchingContext::new(MatchingMode::Normal, None); + Ok(matches_selector_list(&selectors.0, &Root::from_ref(self), &mut ctx)) } } } @@ -2076,8 +2077,8 @@ impl ElementMethods for Element { let root = self.upcast::<Node>(); for element in root.inclusive_ancestors() { if let Some(element) = Root::downcast::<Element>(element) { - if matches_selector_list(&selectors.0, &element, None) - { + let mut ctx = MatchingContext::new(MatchingMode::Normal, None); + if matches_selector_list(&selectors.0, &element, &mut ctx) { return Ok(Some(element)); } } @@ -2386,6 +2387,15 @@ impl<'a> ::selectors::Element for Root<Element> { self.upcast::<Node>().GetParentElement() } + fn match_pseudo_element(&self, + _pseudo: &PseudoElement, + _context: &mut MatchingContext) + -> bool + { + false + } + + fn first_child_element(&self) -> Option<Root<Element>> { self.node.child_elements().next() } |