aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorbors-servo <lbergstrom+bors@mozilla.com>2017-05-02 18:15:05 -0500
committerGitHub <noreply@github.com>2017-05-02 18:15:05 -0500
commit536d63c67028c7368dff780945626283d2c48f1c (patch)
treec4064581f70b3cbc1871a4039c9a8e50dee03efb
parent32f4273e38f362787bcc348577a3fce074447035 (diff)
parent2b6c494f858772dd539e4a06c18572cbd87189f5 (diff)
downloadservo-536d63c67028c7368dff780945626283d2c48f1c.tar.gz
servo-536d63c67028c7368dff780945626283d2c48f1c.zip
Auto merge of #16698 - bradwerth:cloneRight, r=heycam
Change StyleSet to track stylesheets by unique ID. MozReview-Commit-ID: Ky3P53o4Euw https://bugzilla.mozilla.org/show_bug.cgi?id=1348481 https://reviewboard.mozilla.org/r/128850/ --- <!-- Thank you for contributing to Servo! Please replace each `[ ]` by `[X]` when the step is complete, and replace `__` with appropriate data: --> - [X] `./mach build -d` does not report any errors - [X] `./mach test-tidy` does not report any errors - [ ] These changes fix #__ (github issue number if applicable). <!-- Either: --> - [X] There are tests for these changes OR - [ ] These changes do not require tests because _____ <!-- Also, please make sure that "Allow edits from maintainers" checkbox is checked, so that we can help you if you get stuck somewhere along the way.--> <!-- Pull requests that do not address these steps are welcome, but they will require additional verification as part of the review process. --> <!-- 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/16698) <!-- Reviewable:end -->
-rw-r--r--components/style/gecko/data.rs7
-rw-r--r--components/style/gecko_bindings/bindings.rs8
-rw-r--r--components/style/stylesheet_set.rs67
-rw-r--r--ports/geckolib/glue.rs17
4 files changed, 62 insertions, 37 deletions
diff --git a/components/style/gecko/data.rs b/components/style/gecko/data.rs
index 7efad2a9fbe..942aaf4f7b5 100644
--- a/components/style/gecko/data.rs
+++ b/components/style/gecko/data.rs
@@ -18,7 +18,7 @@ use std::collections::HashMap;
use std::sync::Arc;
use std::sync::mpsc::{Receiver, Sender, channel};
use stylesheet_set::StylesheetSet;
-use stylesheets::{FontFaceRule, Origin};
+use stylesheets::{FontFaceRule, Origin, Stylesheet};
use stylist::{ExtraStyleData, Stylist};
/// The container for data that a Servo-backed Gecko document needs to style
@@ -106,8 +106,9 @@ impl PerDocumentStyleDataImpl {
};
let author_style_disabled = self.stylesheets.author_style_disabled();
- let stylesheets = self.stylesheets.flush();
- stylist.update(stylesheets,
+ let mut stylesheets = Vec::<Arc<Stylesheet>>::new();
+ self.stylesheets.flush(&mut stylesheets);
+ stylist.update(stylesheets.as_slice(),
&StylesheetGuards::same(guard),
/* ua_sheets = */ None,
/* stylesheets_changed = */ true,
diff --git a/components/style/gecko_bindings/bindings.rs b/components/style/gecko_bindings/bindings.rs
index 36075707b5b..1b3560dc849 100644
--- a/components/style/gecko_bindings/bindings.rs
+++ b/components/style/gecko_bindings/bindings.rs
@@ -1574,16 +1574,18 @@ extern "C" {
extern "C" {
pub fn Servo_StyleSet_AppendStyleSheet(set: RawServoStyleSetBorrowed,
sheet: RawServoStyleSheetBorrowed,
+ unique_id: u32,
flush: bool);
}
extern "C" {
pub fn Servo_StyleSet_PrependStyleSheet(set: RawServoStyleSetBorrowed,
sheet: RawServoStyleSheetBorrowed,
+ unique_id: u32,
flush: bool);
}
extern "C" {
pub fn Servo_StyleSet_RemoveStyleSheet(set: RawServoStyleSetBorrowed,
- sheet: RawServoStyleSheetBorrowed,
+ unique_id: u32,
flush: bool);
}
extern "C" {
@@ -1591,8 +1593,8 @@ extern "C" {
RawServoStyleSetBorrowed,
sheet:
RawServoStyleSheetBorrowed,
- reference:
- RawServoStyleSheetBorrowed,
+ unique_id: u32,
+ before_unique_id: u32,
flush: bool);
}
extern "C" {
diff --git a/components/style/stylesheet_set.rs b/components/style/stylesheet_set.rs
index e1f782bbbbf..78e0c9cd558 100644
--- a/components/style/stylesheet_set.rs
+++ b/components/style/stylesheet_set.rs
@@ -4,19 +4,26 @@
//! A centralized set of stylesheets for a document.
-use arc_ptr_eq;
use std::sync::Arc;
use stylesheets::Stylesheet;
+/// Entry for a StylesheetSet. We don't bother creating a constructor, because
+/// there's no sensible defaults for the member variables.
+pub struct StylesheetSetEntry {
+ unique_id: u32,
+ sheet: Arc<Stylesheet>,
+}
+
/// The set of stylesheets effective for a given document.
pub struct StylesheetSet {
- /// The actual list of all the stylesheets that apply to the given document.
+ /// The actual list of all the stylesheets that apply to the given document,
+ /// each stylesheet associated with a unique ID.
///
/// This is only a list of top-level stylesheets, and as such it doesn't
/// include recursive `@import` rules.
- stylesheets: Vec<Arc<Stylesheet>>,
+ entries: Vec<StylesheetSetEntry>,
- /// Whether the stylesheets list above has changed since the last restyle.
+ /// Whether the entries list above has changed since the last restyle.
dirty: bool,
/// Has author style been disabled?
@@ -27,7 +34,7 @@ impl StylesheetSet {
/// Create a new empty StylesheetSet.
pub fn new() -> Self {
StylesheetSet {
- stylesheets: vec![],
+ entries: vec![],
dirty: false,
author_style_disabled: false,
}
@@ -39,39 +46,51 @@ impl StylesheetSet {
self.author_style_disabled
}
- fn remove_stylesheet_if_present(&mut self, sheet: &Arc<Stylesheet>) {
- self.stylesheets.retain(|x| !arc_ptr_eq(x, sheet));
+ fn remove_stylesheet_if_present(&mut self, unique_id: u32) {
+ self.entries.retain(|x| x.unique_id != unique_id);
}
/// Appends a new stylesheet to the current set.
- pub fn append_stylesheet(&mut self, sheet: &Arc<Stylesheet>) {
- self.remove_stylesheet_if_present(sheet);
- self.stylesheets.push(sheet.clone());
+ pub fn append_stylesheet(&mut self, sheet: &Arc<Stylesheet>,
+ unique_id: u32) {
+ self.remove_stylesheet_if_present(unique_id);
+ self.entries.push(StylesheetSetEntry {
+ unique_id: unique_id,
+ sheet: sheet.clone(),
+ });
self.dirty = true;
}
/// Prepend a new stylesheet to the current set.
- pub fn prepend_stylesheet(&mut self, sheet: &Arc<Stylesheet>) {
- self.remove_stylesheet_if_present(sheet);
- self.stylesheets.insert(0, sheet.clone());
+ pub fn prepend_stylesheet(&mut self, sheet: &Arc<Stylesheet>,
+ unique_id: u32) {
+ self.remove_stylesheet_if_present(unique_id);
+ self.entries.insert(0, StylesheetSetEntry {
+ unique_id: unique_id,
+ sheet: sheet.clone(),
+ });
self.dirty = true;
}
/// Insert a given stylesheet before another stylesheet in the document.
pub fn insert_stylesheet_before(&mut self,
sheet: &Arc<Stylesheet>,
- before: &Arc<Stylesheet>) {
- self.remove_stylesheet_if_present(sheet);
- let index = self.stylesheets.iter().position(|x| {
- arc_ptr_eq(x, before)
- }).expect("`before` stylesheet not found");
- self.stylesheets.insert(index, sheet.clone());
+ unique_id: u32,
+ before_unique_id: u32) {
+ self.remove_stylesheet_if_present(unique_id);
+ let index = self.entries.iter().position(|x| {
+ x.unique_id == before_unique_id
+ }).expect("`before_unique_id` stylesheet not found");
+ self.entries.insert(index, StylesheetSetEntry {
+ unique_id: unique_id,
+ sheet: sheet.clone(),
+ });
self.dirty = true;
}
/// Remove a given stylesheet from the set.
- pub fn remove_stylesheet(&mut self, sheet: &Arc<Stylesheet>) {
- self.remove_stylesheet_if_present(sheet);
+ pub fn remove_stylesheet(&mut self, unique_id: u32) {
+ self.remove_stylesheet_if_present(unique_id);
self.dirty = true;
}
@@ -90,9 +109,11 @@ impl StylesheetSet {
}
/// Flush the current set, unmarking it as dirty.
- pub fn flush(&mut self) -> &[Arc<Stylesheet>] {
+ pub fn flush(&mut self, sheets: &mut Vec<Arc<Stylesheet>>) {
self.dirty = false;
- &self.stylesheets
+ for entry in &self.entries {
+ sheets.push(entry.sheet.clone())
+ }
}
/// Mark the stylesheets as dirty, because something external may have
diff --git a/ports/geckolib/glue.rs b/ports/geckolib/glue.rs
index 25790188460..dff56ce8b0f 100644
--- a/ports/geckolib/glue.rs
+++ b/ports/geckolib/glue.rs
@@ -593,12 +593,13 @@ pub extern "C" fn Servo_StyleSheet_ClearAndUpdate(stylesheet: RawServoStyleSheet
#[no_mangle]
pub extern "C" fn Servo_StyleSet_AppendStyleSheet(raw_data: RawServoStyleSetBorrowed,
raw_sheet: RawServoStyleSheetBorrowed,
+ unique_id: u32,
flush: bool) {
let global_style_data = &*GLOBAL_STYLE_DATA;
let guard = global_style_data.shared_lock.read();
let mut data = PerDocumentStyleData::from_ffi(raw_data).borrow_mut();
let sheet = HasArcFFI::as_arc(&raw_sheet);
- data.stylesheets.append_stylesheet(sheet);
+ data.stylesheets.append_stylesheet(sheet, unique_id);
if flush {
data.flush_stylesheets(&guard);
}
@@ -607,12 +608,13 @@ pub extern "C" fn Servo_StyleSet_AppendStyleSheet(raw_data: RawServoStyleSetBorr
#[no_mangle]
pub extern "C" fn Servo_StyleSet_PrependStyleSheet(raw_data: RawServoStyleSetBorrowed,
raw_sheet: RawServoStyleSheetBorrowed,
+ unique_id: u32,
flush: bool) {
let global_style_data = &*GLOBAL_STYLE_DATA;
let guard = global_style_data.shared_lock.read();
let mut data = PerDocumentStyleData::from_ffi(raw_data).borrow_mut();
let sheet = HasArcFFI::as_arc(&raw_sheet);
- data.stylesheets.prepend_stylesheet(sheet);
+ data.stylesheets.prepend_stylesheet(sheet, unique_id);
if flush {
data.flush_stylesheets(&guard);
}
@@ -621,14 +623,14 @@ pub extern "C" fn Servo_StyleSet_PrependStyleSheet(raw_data: RawServoStyleSetBor
#[no_mangle]
pub extern "C" fn Servo_StyleSet_InsertStyleSheetBefore(raw_data: RawServoStyleSetBorrowed,
raw_sheet: RawServoStyleSheetBorrowed,
- raw_reference: RawServoStyleSheetBorrowed,
+ unique_id: u32,
+ before_unique_id: u32,
flush: bool) {
let global_style_data = &*GLOBAL_STYLE_DATA;
let guard = global_style_data.shared_lock.read();
let mut data = PerDocumentStyleData::from_ffi(raw_data).borrow_mut();
let sheet = HasArcFFI::as_arc(&raw_sheet);
- let reference = HasArcFFI::as_arc(&raw_reference);
- data.stylesheets.insert_stylesheet_before(sheet, reference);
+ data.stylesheets.insert_stylesheet_before(sheet, unique_id, before_unique_id);
if flush {
data.flush_stylesheets(&guard);
}
@@ -636,13 +638,12 @@ pub extern "C" fn Servo_StyleSet_InsertStyleSheetBefore(raw_data: RawServoStyleS
#[no_mangle]
pub extern "C" fn Servo_StyleSet_RemoveStyleSheet(raw_data: RawServoStyleSetBorrowed,
- raw_sheet: RawServoStyleSheetBorrowed,
+ unique_id: u32,
flush: bool) {
let global_style_data = &*GLOBAL_STYLE_DATA;
let guard = global_style_data.shared_lock.read();
let mut data = PerDocumentStyleData::from_ffi(raw_data).borrow_mut();
- let sheet = HasArcFFI::as_arc(&raw_sheet);
- data.stylesheets.remove_stylesheet(sheet);
+ data.stylesheets.remove_stylesheet(unique_id);
if flush {
data.flush_stylesheets(&guard);
}