mirror of
https://github.com/servo/servo.git
synced 2025-07-24 07:40:27 +01:00
Replace more RwLock<MediaList> with shared_lock::Locked<MediaList>
This commit is contained in:
parent
fe4e70c5f8
commit
600152bd00
8 changed files with 79 additions and 38 deletions
|
@ -99,7 +99,7 @@ use style::keyframes::Keyframe;
|
||||||
use style::media_queries::MediaList;
|
use style::media_queries::MediaList;
|
||||||
use style::properties::PropertyDeclarationBlock;
|
use style::properties::PropertyDeclarationBlock;
|
||||||
use style::selector_parser::{PseudoElement, Snapshot};
|
use style::selector_parser::{PseudoElement, Snapshot};
|
||||||
use style::shared_lock::SharedRwLock as StyleSharedRwLock;
|
use style::shared_lock::{SharedRwLock as StyleSharedRwLock, Locked as StyleLocked};
|
||||||
use style::stylesheets::{CssRules, KeyframesRule, MediaRule, NamespaceRule, StyleRule, ImportRule};
|
use style::stylesheets::{CssRules, KeyframesRule, MediaRule, NamespaceRule, StyleRule, ImportRule};
|
||||||
use style::stylesheets::SupportsRule;
|
use style::stylesheets::SupportsRule;
|
||||||
use style::values::specified::Length;
|
use style::values::specified::Length;
|
||||||
|
@ -574,7 +574,7 @@ unsafe impl JSTraceable for RwLock<SharedRt> {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
unsafe impl JSTraceable for RwLock<MediaList> {
|
unsafe impl JSTraceable for StyleLocked<MediaList> {
|
||||||
unsafe fn trace(&self, _trc: *mut JSTracer) {
|
unsafe fn trace(&self, _trc: *mut JSTracer) {
|
||||||
// Do nothing.
|
// Do nothing.
|
||||||
}
|
}
|
||||||
|
|
|
@ -28,6 +28,10 @@ impl CSSConditionRule {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn parent_stylesheet(&self) -> &CSSStyleSheet {
|
||||||
|
self.cssgroupingrule.parent_stylesheet()
|
||||||
|
}
|
||||||
|
|
||||||
pub fn shared_lock(&self) -> &SharedRwLock {
|
pub fn shared_lock(&self) -> &SharedRwLock {
|
||||||
self.cssgroupingrule.shared_lock()
|
self.cssgroupingrule.shared_lock()
|
||||||
}
|
}
|
||||||
|
|
|
@ -42,6 +42,10 @@ impl CSSGroupingRule {
|
||||||
RulesSource::Rules(self.rules.clone())))
|
RulesSource::Rules(self.rules.clone())))
|
||||||
}
|
}
|
||||||
|
|
||||||
|
pub fn parent_stylesheet(&self) -> &CSSStyleSheet {
|
||||||
|
self.cssrule.parent_stylesheet()
|
||||||
|
}
|
||||||
|
|
||||||
pub fn shared_lock(&self) -> &SharedRwLock {
|
pub fn shared_lock(&self) -> &SharedRwLock {
|
||||||
self.cssrule.shared_lock()
|
self.cssrule.shared_lock()
|
||||||
}
|
}
|
||||||
|
|
|
@ -50,22 +50,25 @@ impl CSSMediaRule {
|
||||||
|
|
||||||
fn medialist(&self) -> Root<MediaList> {
|
fn medialist(&self) -> Root<MediaList> {
|
||||||
self.medialist.or_init(|| MediaList::new(self.global().as_window(),
|
self.medialist.or_init(|| MediaList::new(self.global().as_window(),
|
||||||
|
self.cssconditionrule.parent_stylesheet(),
|
||||||
self.mediarule.read().media_queries.clone()))
|
self.mediarule.read().media_queries.clone()))
|
||||||
}
|
}
|
||||||
|
|
||||||
/// https://drafts.csswg.org/css-conditional-3/#the-cssmediarule-interface
|
/// https://drafts.csswg.org/css-conditional-3/#the-cssmediarule-interface
|
||||||
pub fn get_condition_text(&self) -> DOMString {
|
pub fn get_condition_text(&self) -> DOMString {
|
||||||
|
let guard = self.cssconditionrule.shared_lock().read();
|
||||||
let rule = self.mediarule.read();
|
let rule = self.mediarule.read();
|
||||||
let list = rule.media_queries.read();
|
let list = rule.media_queries.read_with(&guard);
|
||||||
list.to_css_string().into()
|
list.to_css_string().into()
|
||||||
}
|
}
|
||||||
|
|
||||||
/// https://drafts.csswg.org/css-conditional-3/#the-cssmediarule-interface
|
/// https://drafts.csswg.org/css-conditional-3/#the-cssmediarule-interface
|
||||||
pub fn set_condition_text(&self, text: DOMString) {
|
pub fn set_condition_text(&self, text: DOMString) {
|
||||||
|
let mut guard = self.cssconditionrule.shared_lock().write();
|
||||||
let mut input = Parser::new(&text);
|
let mut input = Parser::new(&text);
|
||||||
let new_medialist = parse_media_query_list(&mut input);
|
let new_medialist = parse_media_query_list(&mut input);
|
||||||
let rule = self.mediarule.read();
|
let rule = self.mediarule.read();
|
||||||
let mut list = rule.media_queries.write();
|
let mut list = rule.media_queries.write_with(&mut guard);
|
||||||
*list = new_medialist;
|
*list = new_medialist;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -6,13 +6,14 @@ use core::default::Default;
|
||||||
use cssparser::Parser;
|
use cssparser::Parser;
|
||||||
use dom::bindings::codegen::Bindings::MediaListBinding;
|
use dom::bindings::codegen::Bindings::MediaListBinding;
|
||||||
use dom::bindings::codegen::Bindings::MediaListBinding::MediaListMethods;
|
use dom::bindings::codegen::Bindings::MediaListBinding::MediaListMethods;
|
||||||
use dom::bindings::js::Root;
|
use dom::bindings::js::{JS, Root};
|
||||||
use dom::bindings::reflector::{Reflector, reflect_dom_object};
|
use dom::bindings::reflector::{Reflector, reflect_dom_object};
|
||||||
use dom::bindings::str::DOMString;
|
use dom::bindings::str::DOMString;
|
||||||
|
use dom::cssstylesheet::CSSStyleSheet;
|
||||||
use dom::window::Window;
|
use dom::window::Window;
|
||||||
use dom_struct::dom_struct;
|
use dom_struct::dom_struct;
|
||||||
use parking_lot::RwLock;
|
|
||||||
use std::sync::Arc;
|
use std::sync::Arc;
|
||||||
|
use style::shared_lock::{SharedRwLock, Locked};
|
||||||
use style::media_queries::{MediaQuery, parse_media_query_list};
|
use style::media_queries::{MediaQuery, parse_media_query_list};
|
||||||
use style::media_queries::MediaList as StyleMediaList;
|
use style::media_queries::MediaList as StyleMediaList;
|
||||||
use style_traits::ToCss;
|
use style_traits::ToCss;
|
||||||
|
@ -20,38 +21,47 @@ use style_traits::ToCss;
|
||||||
#[dom_struct]
|
#[dom_struct]
|
||||||
pub struct MediaList {
|
pub struct MediaList {
|
||||||
reflector_: Reflector,
|
reflector_: Reflector,
|
||||||
|
parent_stylesheet: JS<CSSStyleSheet>,
|
||||||
#[ignore_heap_size_of = "Arc"]
|
#[ignore_heap_size_of = "Arc"]
|
||||||
media_queries: Arc<RwLock<StyleMediaList>>,
|
media_queries: Arc<Locked<StyleMediaList>>,
|
||||||
}
|
}
|
||||||
|
|
||||||
impl MediaList {
|
impl MediaList {
|
||||||
#[allow(unrooted_must_root)]
|
#[allow(unrooted_must_root)]
|
||||||
pub fn new_inherited(media_queries: Arc<RwLock<StyleMediaList>>) -> MediaList {
|
pub fn new_inherited(parent_stylesheet: &CSSStyleSheet,
|
||||||
|
media_queries: Arc<Locked<StyleMediaList>>) -> MediaList {
|
||||||
MediaList {
|
MediaList {
|
||||||
|
parent_stylesheet: JS::from_ref(parent_stylesheet),
|
||||||
reflector_: Reflector::new(),
|
reflector_: Reflector::new(),
|
||||||
media_queries: media_queries,
|
media_queries: media_queries,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
#[allow(unrooted_must_root)]
|
#[allow(unrooted_must_root)]
|
||||||
pub fn new(window: &Window, media_queries: Arc<RwLock<StyleMediaList>>)
|
pub fn new(window: &Window, parent_stylesheet: &CSSStyleSheet,
|
||||||
|
media_queries: Arc<Locked<StyleMediaList>>)
|
||||||
-> Root<MediaList> {
|
-> Root<MediaList> {
|
||||||
reflect_dom_object(box MediaList::new_inherited(media_queries),
|
reflect_dom_object(box MediaList::new_inherited(parent_stylesheet, media_queries),
|
||||||
window,
|
window,
|
||||||
MediaListBinding::Wrap)
|
MediaListBinding::Wrap)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
fn shared_lock(&self) -> &SharedRwLock {
|
||||||
|
&self.parent_stylesheet.style_stylesheet().shared_lock
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl MediaListMethods for MediaList {
|
impl MediaListMethods for MediaList {
|
||||||
// https://drafts.csswg.org/cssom/#dom-medialist-mediatext
|
// https://drafts.csswg.org/cssom/#dom-medialist-mediatext
|
||||||
fn MediaText(&self) -> DOMString {
|
fn MediaText(&self) -> DOMString {
|
||||||
DOMString::from(self.media_queries.read().to_css_string())
|
let guard = self.shared_lock().read();
|
||||||
|
DOMString::from(self.media_queries.read_with(&guard).to_css_string())
|
||||||
}
|
}
|
||||||
|
|
||||||
// https://drafts.csswg.org/cssom/#dom-medialist-mediatext
|
// https://drafts.csswg.org/cssom/#dom-medialist-mediatext
|
||||||
fn SetMediaText(&self, value: DOMString) {
|
fn SetMediaText(&self, value: DOMString) {
|
||||||
let mut media_queries = self.media_queries.write();
|
let mut guard = self.shared_lock().write();
|
||||||
|
let mut media_queries = self.media_queries.write_with(&mut guard);
|
||||||
// Step 2
|
// Step 2
|
||||||
if value.is_empty() {
|
if value.is_empty() {
|
||||||
// Step 1
|
// Step 1
|
||||||
|
@ -65,13 +75,15 @@ impl MediaListMethods for MediaList {
|
||||||
|
|
||||||
// https://drafts.csswg.org/cssom/#dom-medialist-length
|
// https://drafts.csswg.org/cssom/#dom-medialist-length
|
||||||
fn Length(&self) -> u32 {
|
fn Length(&self) -> u32 {
|
||||||
self.media_queries.read().media_queries.len() as u32
|
let guard = self.shared_lock().read();
|
||||||
|
self.media_queries.read_with(&guard).media_queries.len() as u32
|
||||||
}
|
}
|
||||||
|
|
||||||
// https://drafts.csswg.org/cssom/#dom-medialist-item
|
// https://drafts.csswg.org/cssom/#dom-medialist-item
|
||||||
fn Item(&self, index: u32) -> Option<DOMString> {
|
fn Item(&self, index: u32) -> Option<DOMString> {
|
||||||
self.media_queries.read().media_queries.get(index as usize)
|
let guard = self.shared_lock().read();
|
||||||
.and_then(|query| {
|
self.media_queries.read_with(&guard).media_queries
|
||||||
|
.get(index as usize).and_then(|query| {
|
||||||
let mut s = String::new();
|
let mut s = String::new();
|
||||||
query.to_css(&mut s).unwrap();
|
query.to_css(&mut s).unwrap();
|
||||||
Some(DOMString::from_string(s))
|
Some(DOMString::from_string(s))
|
||||||
|
@ -94,13 +106,14 @@ impl MediaListMethods for MediaList {
|
||||||
}
|
}
|
||||||
// Step 3
|
// Step 3
|
||||||
let m_serialized = m.clone().unwrap().to_css_string();
|
let m_serialized = m.clone().unwrap().to_css_string();
|
||||||
let any = self.media_queries.read().media_queries.iter()
|
let mut guard = self.shared_lock().write();
|
||||||
.any(|q| m_serialized == q.to_css_string());
|
let mq = self.media_queries.write_with(&mut guard);
|
||||||
|
let any = mq.media_queries.iter().any(|q| m_serialized == q.to_css_string());
|
||||||
if any {
|
if any {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
// Step 4
|
// Step 4
|
||||||
self.media_queries.write().media_queries.push(m.unwrap());
|
mq.media_queries.push(m.unwrap());
|
||||||
}
|
}
|
||||||
|
|
||||||
// https://drafts.csswg.org/cssom/#dom-medialist-deletemedium
|
// https://drafts.csswg.org/cssom/#dom-medialist-deletemedium
|
||||||
|
@ -114,7 +127,8 @@ impl MediaListMethods for MediaList {
|
||||||
}
|
}
|
||||||
// Step 3
|
// Step 3
|
||||||
let m_serialized = m.unwrap().to_css_string();
|
let m_serialized = m.unwrap().to_css_string();
|
||||||
let mut media_list = self.media_queries.write();
|
let mut guard = self.shared_lock().write();
|
||||||
|
let mut media_list = self.media_queries.write_with(&mut guard);
|
||||||
let new_vec = media_list.media_queries.drain(..)
|
let new_vec = media_list.media_queries.drain(..)
|
||||||
.filter(|q| m_serialized != q.to_css_string())
|
.filter(|q| m_serialized != q.to_css_string())
|
||||||
.collect();
|
.collect();
|
||||||
|
|
|
@ -17,6 +17,7 @@ use media_queries::MediaList;
|
||||||
use parking_lot::RwLock;
|
use parking_lot::RwLock;
|
||||||
use properties::{ComputedValues, PropertyDeclarationBlock};
|
use properties::{ComputedValues, PropertyDeclarationBlock};
|
||||||
use properties::animated_properties::{AnimationValue, AnimationValueMap};
|
use properties::animated_properties::{AnimationValue, AnimationValueMap};
|
||||||
|
use shared_lock::Locked;
|
||||||
use stylesheets::{CssRules, Stylesheet, StyleRule, ImportRule, MediaRule, NamespaceRule};
|
use stylesheets::{CssRules, Stylesheet, StyleRule, ImportRule, MediaRule, NamespaceRule};
|
||||||
|
|
||||||
macro_rules! impl_arc_ffi {
|
macro_rules! impl_arc_ffi {
|
||||||
|
@ -62,7 +63,7 @@ impl_arc_ffi!(AnimationValue => RawServoAnimationValue
|
||||||
impl_arc_ffi!(RwLock<AnimationValueMap> => RawServoAnimationValueMap
|
impl_arc_ffi!(RwLock<AnimationValueMap> => RawServoAnimationValueMap
|
||||||
[Servo_AnimationValueMap_AddRef, Servo_AnimationValueMap_Release]);
|
[Servo_AnimationValueMap_AddRef, Servo_AnimationValueMap_Release]);
|
||||||
|
|
||||||
impl_arc_ffi!(RwLock<MediaList> => RawServoMediaList
|
impl_arc_ffi!(Locked<MediaList> => RawServoMediaList
|
||||||
[Servo_MediaList_AddRef, Servo_MediaList_Release]);
|
[Servo_MediaList_AddRef, Servo_MediaList_Release]);
|
||||||
|
|
||||||
impl_arc_ffi!(RwLock<MediaRule> => RawServoMediaRule
|
impl_arc_ffi!(RwLock<MediaRule> => RawServoMediaRule
|
||||||
|
|
|
@ -316,7 +316,7 @@ impl CssRule {
|
||||||
}
|
}
|
||||||
CssRule::Media(ref lock) => {
|
CssRule::Media(ref lock) => {
|
||||||
let media_rule = lock.read();
|
let media_rule = lock.read();
|
||||||
let mq = media_rule.media_queries.read();
|
let mq = media_rule.media_queries.read_with(guard);
|
||||||
let rules = &media_rule.rules.read().0;
|
let rules = &media_rule.rules.read().0;
|
||||||
f(rules, Some(&mq))
|
f(rules, Some(&mq))
|
||||||
}
|
}
|
||||||
|
@ -477,7 +477,7 @@ impl ToCssWithGuard for KeyframesRule {
|
||||||
#[allow(missing_docs)]
|
#[allow(missing_docs)]
|
||||||
#[derive(Debug)]
|
#[derive(Debug)]
|
||||||
pub struct MediaRule {
|
pub struct MediaRule {
|
||||||
pub media_queries: Arc<RwLock<MediaList>>,
|
pub media_queries: Arc<Locked<MediaList>>,
|
||||||
pub rules: Arc<RwLock<CssRules>>,
|
pub rules: Arc<RwLock<CssRules>>,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -487,7 +487,7 @@ impl ToCssWithGuard for MediaRule {
|
||||||
fn to_css<W>(&self, guard: &SharedRwLockReadGuard, dest: &mut W) -> fmt::Result
|
fn to_css<W>(&self, guard: &SharedRwLockReadGuard, dest: &mut W) -> fmt::Result
|
||||||
where W: fmt::Write {
|
where W: fmt::Write {
|
||||||
try!(dest.write_str("@media "));
|
try!(dest.write_str("@media "));
|
||||||
try!(self.media_queries.read().to_css(dest));
|
try!(self.media_queries.read_with(guard).to_css(dest));
|
||||||
try!(dest.write_str(" {"));
|
try!(dest.write_str(" {"));
|
||||||
for rule in self.rules.read().0.iter() {
|
for rule in self.rules.read().0.iter() {
|
||||||
try!(dest.write_str(" "));
|
try!(dest.write_str(" "));
|
||||||
|
@ -753,6 +753,7 @@ impl<'b> TopLevelRuleParser<'b> {
|
||||||
fn nested<'a: 'b>(&'a self) -> NestedRuleParser<'a, 'b> {
|
fn nested<'a: 'b>(&'a self) -> NestedRuleParser<'a, 'b> {
|
||||||
NestedRuleParser {
|
NestedRuleParser {
|
||||||
stylesheet_origin: self.stylesheet_origin,
|
stylesheet_origin: self.stylesheet_origin,
|
||||||
|
shared_lock: self.shared_lock,
|
||||||
context: &self.context,
|
context: &self.context,
|
||||||
namespaces: self.namespaces,
|
namespaces: self.namespaces,
|
||||||
}
|
}
|
||||||
|
@ -774,7 +775,7 @@ enum AtRulePrelude {
|
||||||
/// A @font-face rule prelude.
|
/// A @font-face rule prelude.
|
||||||
FontFace,
|
FontFace,
|
||||||
/// A @media rule prelude, with its media queries.
|
/// A @media rule prelude, with its media queries.
|
||||||
Media(Arc<RwLock<MediaList>>),
|
Media(Arc<Locked<MediaList>>),
|
||||||
/// An @supports rule, with its conditional
|
/// An @supports rule, with its conditional
|
||||||
Supports(SupportsCondition),
|
Supports(SupportsCondition),
|
||||||
/// A @viewport rule prelude.
|
/// A @viewport rule prelude.
|
||||||
|
@ -900,6 +901,7 @@ impl<'a> QualifiedRuleParser for TopLevelRuleParser<'a> {
|
||||||
#[derive(Clone)] // shallow, relatively cheap .clone
|
#[derive(Clone)] // shallow, relatively cheap .clone
|
||||||
struct NestedRuleParser<'a, 'b: 'a> {
|
struct NestedRuleParser<'a, 'b: 'a> {
|
||||||
stylesheet_origin: Origin,
|
stylesheet_origin: Origin,
|
||||||
|
shared_lock: &'a SharedRwLock,
|
||||||
context: &'a ParserContext<'b>,
|
context: &'a ParserContext<'b>,
|
||||||
namespaces: &'b Namespaces,
|
namespaces: &'b Namespaces,
|
||||||
}
|
}
|
||||||
|
@ -931,7 +933,8 @@ impl<'a, 'b> AtRuleParser for NestedRuleParser<'a, 'b> {
|
||||||
match_ignore_ascii_case! { name,
|
match_ignore_ascii_case! { name,
|
||||||
"media" => {
|
"media" => {
|
||||||
let media_queries = parse_media_query_list(input);
|
let media_queries = parse_media_query_list(input);
|
||||||
Ok(AtRuleType::WithBlock(AtRulePrelude::Media(Arc::new(RwLock::new(media_queries)))))
|
let arc = Arc::new(self.shared_lock.wrap(media_queries));
|
||||||
|
Ok(AtRuleType::WithBlock(AtRulePrelude::Media(arc)))
|
||||||
},
|
},
|
||||||
"supports" => {
|
"supports" => {
|
||||||
let cond = SupportsCondition::parse(input)?;
|
let cond = SupportsCondition::parse(input)?;
|
||||||
|
|
|
@ -76,7 +76,7 @@ use style::properties::parse_one_declaration;
|
||||||
use style::restyle_hints::{self, RestyleHint};
|
use style::restyle_hints::{self, RestyleHint};
|
||||||
use style::selector_parser::PseudoElementCascadeType;
|
use style::selector_parser::PseudoElementCascadeType;
|
||||||
use style::sequential;
|
use style::sequential;
|
||||||
use style::shared_lock::{SharedRwLock, ToCssWithGuard};
|
use style::shared_lock::{SharedRwLock, ToCssWithGuard, Locked};
|
||||||
use style::string_cache::Atom;
|
use style::string_cache::Atom;
|
||||||
use style::stylesheets::{CssRule, CssRules, ImportRule, MediaRule, NamespaceRule};
|
use style::stylesheets::{CssRule, CssRules, ImportRule, MediaRule, NamespaceRule};
|
||||||
use style::stylesheets::{Origin, Stylesheet, StyleRule};
|
use style::stylesheets::{Origin, Stylesheet, StyleRule};
|
||||||
|
@ -964,29 +964,37 @@ pub extern "C" fn Servo_DeclarationBlock_RemovePropertyById(declarations: RawSer
|
||||||
|
|
||||||
#[no_mangle]
|
#[no_mangle]
|
||||||
pub extern "C" fn Servo_MediaList_GetText(list: RawServoMediaListBorrowed, result: *mut nsAString) {
|
pub extern "C" fn Servo_MediaList_GetText(list: RawServoMediaListBorrowed, result: *mut nsAString) {
|
||||||
let list = RwLock::<MediaList>::as_arc(&list);
|
let global_style_data = &*GLOBAL_STYLE_DATA;
|
||||||
list.read().to_css(unsafe { result.as_mut().unwrap() }).unwrap();
|
let guard = global_style_data.shared_lock.read();
|
||||||
|
let list = Locked::<MediaList>::as_arc(&list);
|
||||||
|
list.read_with(&guard).to_css(unsafe { result.as_mut().unwrap() }).unwrap();
|
||||||
}
|
}
|
||||||
|
|
||||||
#[no_mangle]
|
#[no_mangle]
|
||||||
pub extern "C" fn Servo_MediaList_SetText(list: RawServoMediaListBorrowed, text: *const nsACString) {
|
pub extern "C" fn Servo_MediaList_SetText(list: RawServoMediaListBorrowed, text: *const nsACString) {
|
||||||
let list = RwLock::<MediaList>::as_arc(&list);
|
let global_style_data = &*GLOBAL_STYLE_DATA;
|
||||||
|
let mut guard = global_style_data.shared_lock.write();
|
||||||
|
let list = Locked::<MediaList>::as_arc(&list);
|
||||||
let text = unsafe { text.as_ref().unwrap().as_str_unchecked() };
|
let text = unsafe { text.as_ref().unwrap().as_str_unchecked() };
|
||||||
let mut parser = Parser::new(&text);
|
let mut parser = Parser::new(&text);
|
||||||
*list.write() = parse_media_query_list(&mut parser);
|
*list.write_with(&mut guard) = parse_media_query_list(&mut parser);
|
||||||
}
|
}
|
||||||
|
|
||||||
#[no_mangle]
|
#[no_mangle]
|
||||||
pub extern "C" fn Servo_MediaList_GetLength(list: RawServoMediaListBorrowed) -> u32 {
|
pub extern "C" fn Servo_MediaList_GetLength(list: RawServoMediaListBorrowed) -> u32 {
|
||||||
let list = RwLock::<MediaList>::as_arc(&list);
|
let global_style_data = &*GLOBAL_STYLE_DATA;
|
||||||
list.read().media_queries.len() as u32
|
let guard = global_style_data.shared_lock.read();
|
||||||
|
let list = Locked::<MediaList>::as_arc(&list);
|
||||||
|
list.read_with(&guard).media_queries.len() as u32
|
||||||
}
|
}
|
||||||
|
|
||||||
#[no_mangle]
|
#[no_mangle]
|
||||||
pub extern "C" fn Servo_MediaList_GetMediumAt(list: RawServoMediaListBorrowed, index: u32,
|
pub extern "C" fn Servo_MediaList_GetMediumAt(list: RawServoMediaListBorrowed, index: u32,
|
||||||
result: *mut nsAString) -> bool {
|
result: *mut nsAString) -> bool {
|
||||||
let list = RwLock::<MediaList>::as_arc(&list);
|
let global_style_data = &*GLOBAL_STYLE_DATA;
|
||||||
if let Some(media_query) = list.read().media_queries.get(index as usize) {
|
let guard = global_style_data.shared_lock.read();
|
||||||
|
let list = Locked::<MediaList>::as_arc(&list);
|
||||||
|
if let Some(media_query) = list.read_with(&guard).media_queries.get(index as usize) {
|
||||||
media_query.to_css(unsafe { result.as_mut().unwrap() }).unwrap();
|
media_query.to_css(unsafe { result.as_mut().unwrap() }).unwrap();
|
||||||
true
|
true
|
||||||
} else {
|
} else {
|
||||||
|
@ -997,17 +1005,21 @@ pub extern "C" fn Servo_MediaList_GetMediumAt(list: RawServoMediaListBorrowed, i
|
||||||
#[no_mangle]
|
#[no_mangle]
|
||||||
pub extern "C" fn Servo_MediaList_AppendMedium(list: RawServoMediaListBorrowed,
|
pub extern "C" fn Servo_MediaList_AppendMedium(list: RawServoMediaListBorrowed,
|
||||||
new_medium: *const nsACString) {
|
new_medium: *const nsACString) {
|
||||||
let list = RwLock::<MediaList>::as_arc(&list);
|
let global_style_data = &*GLOBAL_STYLE_DATA;
|
||||||
|
let mut guard = global_style_data.shared_lock.write();
|
||||||
|
let list = Locked::<MediaList>::as_arc(&list);
|
||||||
let new_medium = unsafe { new_medium.as_ref().unwrap().as_str_unchecked() };
|
let new_medium = unsafe { new_medium.as_ref().unwrap().as_str_unchecked() };
|
||||||
list.write().append_medium(new_medium);
|
list.write_with(&mut guard).append_medium(new_medium);
|
||||||
}
|
}
|
||||||
|
|
||||||
#[no_mangle]
|
#[no_mangle]
|
||||||
pub extern "C" fn Servo_MediaList_DeleteMedium(list: RawServoMediaListBorrowed,
|
pub extern "C" fn Servo_MediaList_DeleteMedium(list: RawServoMediaListBorrowed,
|
||||||
old_medium: *const nsACString) -> bool {
|
old_medium: *const nsACString) -> bool {
|
||||||
let list = RwLock::<MediaList>::as_arc(&list);
|
let global_style_data = &*GLOBAL_STYLE_DATA;
|
||||||
|
let mut guard = global_style_data.shared_lock.write();
|
||||||
|
let list = Locked::<MediaList>::as_arc(&list);
|
||||||
let old_medium = unsafe { old_medium.as_ref().unwrap().as_str_unchecked() };
|
let old_medium = unsafe { old_medium.as_ref().unwrap().as_str_unchecked() };
|
||||||
list.write().delete_medium(old_medium)
|
list.write_with(&mut guard).delete_medium(old_medium)
|
||||||
}
|
}
|
||||||
|
|
||||||
macro_rules! get_longhand_from_id {
|
macro_rules! get_longhand_from_id {
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue