mirror of
https://github.com/servo/servo.git
synced 2025-08-03 20:50:07 +01:00
style: Don't share style with an element that has a different proto binding than us.
See the lengthy comment about why... XBL sucks. MozReview-Commit-ID: 8UgeJAVkj6a
This commit is contained in:
parent
c338745b17
commit
9364cd21b8
3 changed files with 31 additions and 6 deletions
|
@ -681,15 +681,29 @@ impl<E: TElement> StyleSharingCache<E> {
|
|||
|
||||
// If two elements belong to different shadow trees, different rules may
|
||||
// apply to them, from the respective trees.
|
||||
//
|
||||
// Note that we don't need the same for XBL case, since two elements
|
||||
// with different XBL bindings need to necessarily have different style
|
||||
// (and thus children of them would never pass the parent check).
|
||||
if target.element.containing_shadow() != candidate.element.containing_shadow() {
|
||||
trace!("Miss: Different containing shadow roots");
|
||||
return None;
|
||||
}
|
||||
|
||||
// Note that in theory we shouldn't need this XBL check. However, XBL is
|
||||
// absolutely broken in all sorts of ways.
|
||||
//
|
||||
// A style change that changes which XBL binding applies to an element
|
||||
// arrives there, with the element still having the old prototype
|
||||
// binding attached. And thus we try to match revalidation selectors
|
||||
// with the old XBL binding, because we can't look at the new ones of
|
||||
// course. And that causes us to revalidate with the wrong selectors and
|
||||
// hit assertions.
|
||||
//
|
||||
// Other than this, we don't need anything else like the containing XBL
|
||||
// binding parent or what not, since two elements with different XBL
|
||||
// bindings will necessarily end up with different style.
|
||||
if !target.element.has_same_xbl_proto_binding_as(candidate.element) {
|
||||
trace!("Miss: Different proto bindings");
|
||||
return None;
|
||||
}
|
||||
|
||||
// If the elements are not assigned to the same slot they could match
|
||||
// different ::slotted() rules in the slot scope.
|
||||
//
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue