mirror of
https://github.com/servo/servo.git
synced 2025-08-14 09:55:35 +01:00
Bug 1357583: style: Make effective_rules return an iterator, stop refcounting the Device. r=heycam
This makes the code cleaner, and also documents the fact that effective_rules recurses into imports. No we're not adding the imported stylesheets twice, and we share code with the invalidation analysis. MozReview-Commit-ID: DOF2AViTlmR
This commit is contained in:
parent
ebd6f47be3
commit
ac5872b48c
6 changed files with 446 additions and 308 deletions
|
@ -13,7 +13,7 @@ use style::media_queries::*;
|
|||
use style::servo::media_queries::*;
|
||||
use style::shared_lock::{SharedRwLock, SharedRwLockReadGuard};
|
||||
use style::stylearc::Arc;
|
||||
use style::stylesheets::{Stylesheet, Origin, CssRule, NestedRulesResult};
|
||||
use style::stylesheets::{AllRules, Stylesheet, Origin, CssRule};
|
||||
use style::values::specified;
|
||||
use style_traits::ToCss;
|
||||
|
||||
|
@ -39,31 +39,16 @@ fn test_media_rule<F>(css: &str, callback: F)
|
|||
let stylesheet = Stylesheet::from_str(
|
||||
css, url, Origin::Author, media_list, lock,
|
||||
None, &CSSErrorReporterTest, QuirksMode::NoQuirks, 0u64);
|
||||
let dummy = Device::new(MediaType::Screen, TypedSize2D::new(200.0, 100.0));
|
||||
let mut rule_count = 0;
|
||||
let guard = stylesheet.shared_lock.read();
|
||||
media_queries(&guard, &stylesheet.rules.read_with(&guard).0, &mut |mq| {
|
||||
rule_count += 1;
|
||||
callback(mq, css);
|
||||
});
|
||||
assert!(rule_count > 0, css_str);
|
||||
}
|
||||
|
||||
fn media_queries<F>(guard: &SharedRwLockReadGuard, rules: &[CssRule], f: &mut F)
|
||||
where F: FnMut(&MediaList),
|
||||
{
|
||||
for rule in rules {
|
||||
rule.with_nested_rules_mq_and_doc_rule(guard, |result| {
|
||||
match result {
|
||||
NestedRulesResult::Rules(rules) |
|
||||
NestedRulesResult::RulesWithDocument(rules, _) => {
|
||||
media_queries(guard, rules, f)
|
||||
},
|
||||
NestedRulesResult::RulesWithMediaQueries(_, mq) => {
|
||||
f(mq)
|
||||
}
|
||||
}
|
||||
})
|
||||
for rule in stylesheet.iter_rules::<AllRules>(&dummy, &guard) {
|
||||
if let CssRule::Media(ref lock) = *rule {
|
||||
rule_count += 1;
|
||||
callback(&lock.read_with(&guard).media_queries.read_with(&guard), css);
|
||||
}
|
||||
}
|
||||
assert!(rule_count > 0, css_str);
|
||||
}
|
||||
|
||||
fn media_query_test(device: &Device, css: &str, expected_rule_count: usize) {
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue