aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorbors-servo <lbergstrom+bors@mozilla.com>2016-12-25 18:13:30 -0800
committerGitHub <noreply@github.com>2016-12-25 18:13:30 -0800
commit42ec8a89747ba1e25769fffae083f62fe9576987 (patch)
treecf84db766a8a9ae95a15c44c0183f28758e7856a
parent4cd7321531a95ca2d9a1b4d5e04e3fdb35b03f56 (diff)
parentcda445cba5768303e3ed60538a03fd396a19367e (diff)
downloadservo-42ec8a89747ba1e25769fffae083f62fe9576987.tar.gz
servo-42ec8a89747ba1e25769fffae083f62fe9576987.zip
Auto merge of #14731 - heycam:flushing_and_pseudos, r=heycam
stylo: Coordinate stylist flushing with gecko, and clean up pseudo-element resolution
-rw-r--r--components/style/gecko_bindings/bindings.rs33
-rw-r--r--ports/geckolib/glue.rs116
2 files changed, 82 insertions, 67 deletions
diff --git a/components/style/gecko_bindings/bindings.rs b/components/style/gecko_bindings/bindings.rs
index efc3b66b69c..b9dc050143b 100644
--- a/components/style/gecko_bindings/bindings.rs
+++ b/components/style/gecko_bindings/bindings.rs
@@ -991,16 +991,18 @@ extern "C" {
}
extern "C" {
pub fn Servo_StyleSet_AppendStyleSheet(set: RawServoStyleSetBorrowed,
- sheet: RawServoStyleSheetBorrowed);
+ sheet: RawServoStyleSheetBorrowed,
+ flush: bool);
}
extern "C" {
pub fn Servo_StyleSet_PrependStyleSheet(set: RawServoStyleSetBorrowed,
- sheet:
- RawServoStyleSheetBorrowed);
+ sheet: RawServoStyleSheetBorrowed,
+ flush: bool);
}
extern "C" {
pub fn Servo_StyleSet_RemoveStyleSheet(set: RawServoStyleSetBorrowed,
- sheet: RawServoStyleSheetBorrowed);
+ sheet: RawServoStyleSheetBorrowed,
+ flush: bool);
}
extern "C" {
pub fn Servo_StyleSet_InsertStyleSheetBefore(set:
@@ -1008,7 +1010,11 @@ extern "C" {
sheet:
RawServoStyleSheetBorrowed,
reference:
- RawServoStyleSheetBorrowed);
+ RawServoStyleSheetBorrowed,
+ flush: bool);
+}
+extern "C" {
+ pub fn Servo_StyleSet_FlushStyleSheets(set: RawServoStyleSetBorrowed);
}
extern "C" {
pub fn Servo_StyleSet_NoteStyleSheetsChanged(set:
@@ -1178,17 +1184,6 @@ extern "C" {
-> ServoComputedValuesStrong;
}
extern "C" {
- pub fn Servo_ComputedValues_GetForPseudoElement(parent_style:
- ServoComputedValuesBorrowed,
- match_element:
- RawGeckoElementBorrowed,
- pseudo_tag: *mut nsIAtom,
- set:
- RawServoStyleSetBorrowed,
- is_probe: bool)
- -> ServoComputedValuesStrong;
-}
-extern "C" {
pub fn Servo_ComputedValues_Inherit(parent_style:
ServoComputedValuesBorrowedOrNull)
-> ServoComputedValuesStrong;
@@ -1220,6 +1215,12 @@ extern "C" {
-> ServoComputedValuesStrong;
}
extern "C" {
+ pub fn Servo_ResolvePseudoStyle(element: RawGeckoElementBorrowed,
+ pseudo_tag: *mut nsIAtom, is_probe: bool,
+ set: RawServoStyleSetBorrowed)
+ -> ServoComputedValuesStrong;
+}
+extern "C" {
pub fn Servo_TraverseSubtree(root: RawGeckoElementBorrowed,
set: RawServoStyleSetBorrowed,
root_behavior: TraversalRootBehavior);
diff --git a/ports/geckolib/glue.rs b/ports/geckolib/glue.rs
index b028065f48a..e59013a931d 100644
--- a/ports/geckolib/glue.rs
+++ b/ports/geckolib/glue.rs
@@ -19,7 +19,7 @@ use style::arc_ptr_eq;
use style::atomic_refcell::AtomicRefMut;
use style::context::{QuirksMode, ReflowGoal, SharedStyleContext, StyleContext};
use style::context::{ThreadLocalStyleContext, ThreadLocalStyleContextCreationInfo};
-use style::data::{ElementData, RestyleData};
+use style::data::{ElementData, ElementStyles, RestyleData};
use style::dom::{ShowSubtreeData, TElement, TNode};
use style::error_reporting::StdoutErrorReporter;
use style::gecko::data::{NUM_THREADS, PerDocumentStyleData, PerDocumentStyleDataImpl};
@@ -90,10 +90,7 @@ pub extern "C" fn Servo_Shutdown() -> () {
unsafe { ComputedValues::shutdown(); }
}
-fn create_shared_context(mut per_doc_data: &mut AtomicRefMut<PerDocumentStyleDataImpl>) -> SharedStyleContext {
- // The stylist consumes stylesheets lazily.
- per_doc_data.flush_stylesheets();
-
+fn create_shared_context(per_doc_data: &PerDocumentStyleDataImpl) -> SharedStyleContext {
let local_context_data =
ThreadLocalStyleContextCreationInfo::new(per_doc_data.new_animations_sender.clone());
@@ -144,7 +141,7 @@ fn traverse_subtree(element: GeckoElement, raw_data: RawServoStyleSetBorrowed,
debug!("Traversing subtree:");
debug!("{:?}", ShowSubtreeData(element.as_node()));
- let shared_style_context = create_shared_context(&mut per_doc_data);
+ let shared_style_context = create_shared_context(&per_doc_data);
let traversal = RecalcStyleOnly::new(shared_style_context);
let known_depth = None;
@@ -271,28 +268,37 @@ pub extern "C" fn Servo_StyleSheet_FromUTF8Bytes(data: *const nsACString,
#[no_mangle]
pub extern "C" fn Servo_StyleSet_AppendStyleSheet(raw_data: RawServoStyleSetBorrowed,
- raw_sheet: RawServoStyleSheetBorrowed) {
+ raw_sheet: RawServoStyleSheetBorrowed,
+ flush: bool) {
let mut data = PerDocumentStyleData::from_ffi(raw_data).borrow_mut();
let sheet = HasArcFFI::as_arc(&raw_sheet);
data.stylesheets.retain(|x| !arc_ptr_eq(x, sheet));
data.stylesheets.push(sheet.clone());
data.stylesheets_changed = true;
+ if flush {
+ data.flush_stylesheets();
+ }
}
#[no_mangle]
pub extern "C" fn Servo_StyleSet_PrependStyleSheet(raw_data: RawServoStyleSetBorrowed,
- raw_sheet: RawServoStyleSheetBorrowed) {
+ raw_sheet: RawServoStyleSheetBorrowed,
+ flush: bool) {
let mut data = PerDocumentStyleData::from_ffi(raw_data).borrow_mut();
let sheet = HasArcFFI::as_arc(&raw_sheet);
data.stylesheets.retain(|x| !arc_ptr_eq(x, sheet));
data.stylesheets.insert(0, sheet.clone());
data.stylesheets_changed = true;
+ if flush {
+ data.flush_stylesheets();
+ }
}
#[no_mangle]
pub extern "C" fn Servo_StyleSet_InsertStyleSheetBefore(raw_data: RawServoStyleSetBorrowed,
raw_sheet: RawServoStyleSheetBorrowed,
- raw_reference: RawServoStyleSheetBorrowed) {
+ raw_reference: RawServoStyleSheetBorrowed,
+ flush: bool) {
let mut data = PerDocumentStyleData::from_ffi(raw_data).borrow_mut();
let sheet = HasArcFFI::as_arc(&raw_sheet);
let reference = HasArcFFI::as_arc(&raw_reference);
@@ -300,15 +306,28 @@ pub extern "C" fn Servo_StyleSet_InsertStyleSheetBefore(raw_data: RawServoStyleS
let index = data.stylesheets.iter().position(|x| arc_ptr_eq(x, reference)).unwrap();
data.stylesheets.insert(index, sheet.clone());
data.stylesheets_changed = true;
+ if flush {
+ data.flush_stylesheets();
+ }
}
#[no_mangle]
pub extern "C" fn Servo_StyleSet_RemoveStyleSheet(raw_data: RawServoStyleSetBorrowed,
- raw_sheet: RawServoStyleSheetBorrowed) {
+ raw_sheet: RawServoStyleSheetBorrowed,
+ flush: bool) {
let mut data = PerDocumentStyleData::from_ffi(raw_data).borrow_mut();
let sheet = HasArcFFI::as_arc(&raw_sheet);
data.stylesheets.retain(|x| !arc_ptr_eq(x, sheet));
data.stylesheets_changed = true;
+ if flush {
+ data.flush_stylesheets();
+ }
+}
+
+#[no_mangle]
+pub extern "C" fn Servo_StyleSet_FlushStyleSheets(raw_data: RawServoStyleSetBorrowed) {
+ let mut data = PerDocumentStyleData::from_ffi(raw_data).borrow_mut();
+ data.flush_stylesheets();
}
#[no_mangle]
@@ -443,10 +462,7 @@ pub extern "C" fn Servo_ComputedValues_GetForAnonymousBox(parent_style_or_null:
pseudo_tag: *mut nsIAtom,
raw_data: RawServoStyleSetBorrowed)
-> ServoComputedValuesStrong {
- // The stylist consumes stylesheets lazily.
- let mut data = PerDocumentStyleData::from_ffi(raw_data).borrow_mut();
- data.flush_stylesheets();
-
+ let data = PerDocumentStyleData::from_ffi(raw_data).borrow_mut();
let atom = Atom::from(pseudo_tag);
let pseudo = PseudoElement::from_atom_unchecked(atom, /* anon_box = */ true);
@@ -458,48 +474,46 @@ pub extern "C" fn Servo_ComputedValues_GetForAnonymousBox(parent_style_or_null:
}
#[no_mangle]
-pub extern "C" fn Servo_ComputedValues_GetForPseudoElement(parent_style: ServoComputedValuesBorrowed,
- match_element: RawGeckoElementBorrowed,
- pseudo_tag: *mut nsIAtom,
- raw_data: RawServoStyleSetBorrowed,
- is_probe: bool)
- -> ServoComputedValuesStrong {
- debug_assert!(!(match_element as *const _).is_null());
+pub extern "C" fn Servo_ResolvePseudoStyle(element: RawGeckoElementBorrowed,
+ pseudo_tag: *mut nsIAtom, is_probe: bool,
+ raw_data: RawServoStyleSetBorrowed)
+ -> ServoComputedValuesStrong
+{
+ let element = GeckoElement(element);
+ let data = unsafe { element.ensure_data() }.borrow_mut();
- let parent_or_null = || {
- if is_probe {
+ // FIXME(bholley): Assert against this.
+ if data.get_styles().is_none() {
+ error!("Calling Servo_ResolvePseudoStyle on unstyled element");
+ return if is_probe {
Strong::null()
} else {
- ComputedValues::as_arc(&parent_style).clone().into_strong()
- }
- };
-
- let atom = Atom::from(pseudo_tag);
- let pseudo = PseudoElement::from_atom_unchecked(atom, /* anon_box = */ false);
-
- // The stylist consumes stylesheets lazily.
- let mut data = PerDocumentStyleData::from_ffi(raw_data).borrow_mut();
- data.flush_stylesheets();
-
- let element = GeckoElement(match_element);
+ Arc::new(ComputedValues::initial_values().clone()).into_strong()
+ };
+ }
+ let doc_data = PerDocumentStyleData::from_ffi(raw_data);
+ match get_pseudo_style(element, pseudo_tag, data.styles(), doc_data) {
+ Some(values) => values.into_strong(),
+ None if !is_probe => data.styles().primary.values.clone().into_strong(),
+ None => Strong::null(),
+ }
+}
+fn get_pseudo_style(element: GeckoElement, pseudo_tag: *mut nsIAtom,
+ styles: &ElementStyles, doc_data: &PerDocumentStyleData)
+ -> Option<Arc<ComputedValues>>
+{
+ let pseudo = PseudoElement::from_atom_unchecked(Atom::from(pseudo_tag), false);
match SelectorImpl::pseudo_element_cascade_type(&pseudo) {
- PseudoElementCascadeType::Eager => {
- let maybe_computed = element.get_pseudo_style(&pseudo);
- maybe_computed.map_or_else(parent_or_null, FFIArcHelpers::into_strong)
- }
+ PseudoElementCascadeType::Eager => styles.pseudos.get(&pseudo).map(|s| s.values.clone()),
+ PseudoElementCascadeType::Precomputed => unreachable!("No anonymous boxes"),
PseudoElementCascadeType::Lazy => {
- let parent = ComputedValues::as_arc(&parent_style);
- data.stylist
- .lazily_compute_pseudo_element_style(&element, &pseudo, parent)
- .map(|styles| styles.values)
- .map_or_else(parent_or_null, FFIArcHelpers::into_strong)
- }
- PseudoElementCascadeType::Precomputed => {
- unreachable!("Anonymous pseudo found in \
- Servo_GetComputedValuesForPseudoElement");
- }
+ let d = doc_data.borrow_mut();
+ let base = &styles.primary.values;
+ d.stylist.lazily_compute_pseudo_element_style(&element, &pseudo, base)
+ .map(|s| s.values.clone())
+ },
}
}
@@ -865,8 +879,8 @@ pub extern "C" fn Servo_ResolveStyle(element: RawGeckoElementBorrowed,
}
}
- let mut per_doc_data = PerDocumentStyleData::from_ffi(raw_data).borrow_mut();
- let shared_style_context = create_shared_context(&mut per_doc_data);
+ let per_doc_data = PerDocumentStyleData::from_ffi(raw_data).borrow_mut();
+ let shared_style_context = create_shared_context(&per_doc_data);
let traversal = RecalcStyleOnly::new(shared_style_context);
let mut traversal_data = PerLevelTraversalData {