aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorbors-servo <lbergstrom+bors@mozilla.com>2017-06-12 11:37:47 -0700
committerGitHub <noreply@github.com>2017-06-12 11:37:47 -0700
commitdfffc726919c9f8f553ed02f825d20635dadbadb (patch)
treef108ce8b092997d315dadd9f293811e092911c71
parent8085a3717822e70185a7deb50e3250a3a86ab857 (diff)
parentf8755d6cf07f8d34dfadbe6f9716e5b455efd872 (diff)
downloadservo-dfffc726919c9f8f553ed02f825d20635dadbadb.tar.gz
servo-dfffc726919c9f8f553ed02f825d20635dadbadb.zip
Auto merge of #17279 - emilio:no-viewport, r=bholley
style: Don't try to compute @viewport unnecessarily. If the viewport rule is not enabled, there's just no point in computing it. Bug: 1372058
-rw-r--r--components/style/stylesheets/rule_parser.rs14
-rw-r--r--components/style/stylesheets/viewport_rule.rs13
-rw-r--r--components/style/stylist.rs30
3 files changed, 38 insertions, 19 deletions
diff --git a/components/style/stylesheets/rule_parser.rs b/components/style/stylesheets/rule_parser.rs
index f8f536b4a06..dd39070c977 100644
--- a/components/style/stylesheets/rule_parser.rs
+++ b/components/style/stylesheets/rule_parser.rs
@@ -30,6 +30,7 @@ use stylesheets::keyframes_rule::parse_keyframe_list;
use stylesheets::loader::NoOpLoader;
use stylesheets::stylesheet::{Namespaces, Stylesheet};
use stylesheets::supports_rule::SupportsCondition;
+use stylesheets::viewport_rule;
use values::CustomIdent;
use values::KeyframesName;
use values::specified::url::SpecifiedUrl;
@@ -325,17 +326,6 @@ impl<'a, 'b> NestedRuleParser<'a, 'b> {
}
}
-#[cfg(feature = "servo")]
-fn is_viewport_enabled() -> bool {
- use servo_config::prefs::PREFS;
- PREFS.get("layout.viewport.enabled").as_boolean().unwrap_or(false)
-}
-
-#[cfg(not(feature = "servo"))]
-fn is_viewport_enabled() -> bool {
- false // Gecko doesn't support @viewport.
-}
-
impl<'a, 'b, 'i> AtRuleParser<'i> for NestedRuleParser<'a, 'b> {
type Prelude = AtRulePrelude;
type AtRule = CssRule;
@@ -380,7 +370,7 @@ impl<'a, 'b, 'i> AtRuleParser<'i> for NestedRuleParser<'a, 'b> {
Ok(AtRuleType::WithBlock(AtRulePrelude::CounterStyle(name)))
},
"viewport" => {
- if is_viewport_enabled() {
+ if viewport_rule::enabled() {
Ok(AtRuleType::WithBlock(AtRulePrelude::Viewport))
} else {
Err(StyleParseError::UnsupportedAtRule(name.clone()).into())
diff --git a/components/style/stylesheets/viewport_rule.rs b/components/style/stylesheets/viewport_rule.rs
index e9af7a74673..fdd8623a390 100644
--- a/components/style/stylesheets/viewport_rule.rs
+++ b/components/style/stylesheets/viewport_rule.rs
@@ -31,6 +31,19 @@ use stylesheets::{Stylesheet, Origin};
use values::computed::{Context, ToComputedValue};
use values::specified::{NoCalcLength, LengthOrPercentageOrAuto, ViewportPercentageLength};
+/// Whether parsing and processing of `@viewport` rules is enabled.
+#[cfg(feature = "servo")]
+pub fn enabled() -> bool {
+ use servo_config::prefs::PREFS;
+ PREFS.get("layout.viewport.enabled").as_boolean().unwrap_or(false)
+}
+
+/// Whether parsing and processing of `@viewport` rules is enabled.
+#[cfg(not(feature = "servo"))]
+pub fn enabled() -> bool {
+ false // Gecko doesn't support @viewport.
+}
+
macro_rules! declare_viewport_descriptor {
( $( $variant_name: expr => $variant: ident($data: ident), )+ ) => {
declare_viewport_descriptor_inner!([] [ $( $variant_name => $variant($data), )+ ] 0);
diff --git a/components/style/stylist.rs b/components/style/stylist.rs
index 497b51732d7..89edcf0e86a 100644
--- a/components/style/stylist.rs
+++ b/components/style/stylist.rs
@@ -368,14 +368,30 @@ impl Stylist {
self.num_rebuilds += 1;
- let cascaded_rule = ViewportRule {
- declarations: viewport_rule::Cascade::from_stylesheets(
- doc_stylesheets.clone(), guards.author, &self.device
- ).finish(),
- };
+ self.viewport_constraints = None;
- self.viewport_constraints =
- ViewportConstraints::maybe_new(&self.device, &cascaded_rule, self.quirks_mode);
+ if viewport_rule::enabled() {
+ // TODO(emilio): This doesn't look so efficient.
+ //
+ // Presumably when we properly implement this we can at least have a
+ // bit on the stylesheet that says whether it contains viewport
+ // rules to skip it entirely?
+ //
+ // Processing it with the rest of rules seems tricky since it
+ // overrides the viewport size which may change the evaluation of
+ // media queries (or may not? how are viewport units in media
+ // queries defined?)
+ let cascaded_rule = ViewportRule {
+ declarations: viewport_rule::Cascade::from_stylesheets(
+ doc_stylesheets.clone(), guards.author, &self.device
+ ).finish()
+ };
+
+ self.viewport_constraints =
+ ViewportConstraints::maybe_new(&self.device,
+ &cascaded_rule,
+ self.quirks_mode)
+ }
if let Some(ref constraints) = self.viewport_constraints {
self.device.account_for_viewport_rule(constraints);