aboutsummaryrefslogtreecommitdiffstats
path: root/components/script/dom/element.rs
diff options
context:
space:
mode:
authorbors-servo <lbergstrom+bors@mozilla.com>2017-05-17 05:40:14 -0500
committerGitHub <noreply@github.com>2017-05-17 05:40:14 -0500
commitd8b7013fcddff79a9c879077e1a564d83201359c (patch)
tree88a16d0317249297479192f769217f69a8b39895 /components/script/dom/element.rs
parenta7b77306f985b79d3b8b4d9b2cb51fa38f45bd39 (diff)
parent522f8489d6fca474e6aad1d341ee84a99c130738 (diff)
downloadservo-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.rs20
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()
}