mirror of
https://github.com/servo/servo.git
synced 2025-06-14 11:24:33 +00:00
flows when mousing over the document. This exposes more "jumpiness" on sites like Hacker News, but the bug that causes it was pre-existing.
65 lines
2.5 KiB
Rust
65 lines
2.5 KiB
Rust
/* This Source Code Form is subject to the terms of the Mozilla Public
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
|
|
|
//! Style retrieval from DOM elements.
|
|
|
|
use data::LayoutDataWrapper;
|
|
use wrapper::{PseudoElementType, ThreadSafeLayoutNode};
|
|
|
|
use std::mem;
|
|
use style::properties::ComputedValues;
|
|
use std::sync::Arc;
|
|
|
|
/// Node mixin providing `style` method that returns a `NodeStyle`
|
|
pub trait StyledNode {
|
|
fn get_style<'a>(&'a self, layout_data_ref: &'a LayoutDataWrapper) -> &'a Arc<ComputedValues>;
|
|
/// Returns the style results for the given node. If CSS selector matching has not yet been
|
|
/// performed, fails.
|
|
fn style<'a>(&'a self) -> &'a Arc<ComputedValues>;
|
|
/// Does this node have a computed style yet?
|
|
fn has_style(&self) -> bool;
|
|
/// Removes the style from this node.
|
|
fn unstyle(self);
|
|
}
|
|
|
|
impl<'ln> StyledNode for ThreadSafeLayoutNode<'ln> {
|
|
#[inline]
|
|
fn get_style<'a>(&self, layout_data_ref: &'a LayoutDataWrapper) -> &'a Arc<ComputedValues> {
|
|
match self.get_pseudo_element_type() {
|
|
PseudoElementType::Before(_) => layout_data_ref.data.before_style.as_ref().unwrap(),
|
|
PseudoElementType::After(_) => layout_data_ref.data.after_style.as_ref().unwrap(),
|
|
PseudoElementType::Normal => layout_data_ref.shared_data.style.as_ref().unwrap(),
|
|
}
|
|
}
|
|
|
|
#[inline]
|
|
#[allow(unsafe_code)]
|
|
fn style<'a>(&'a self) -> &'a Arc<ComputedValues> {
|
|
unsafe {
|
|
let layout_data_ref = self.borrow_layout_data();
|
|
let layout_data = layout_data_ref.as_ref().expect("no layout data");
|
|
mem::transmute::<&Arc<ComputedValues>,
|
|
&'a Arc<ComputedValues>>(self.get_style(&layout_data))
|
|
}
|
|
}
|
|
|
|
fn has_style(&self) -> bool {
|
|
let layout_data_ref = self.borrow_layout_data();
|
|
layout_data_ref.as_ref().unwrap().shared_data.style.is_some()
|
|
}
|
|
|
|
fn unstyle(self) {
|
|
let mut layout_data_ref = self.mutate_layout_data();
|
|
let layout_data = layout_data_ref.as_mut().expect("no layout data");
|
|
|
|
let style =
|
|
match self.get_pseudo_element_type() {
|
|
PseudoElementType::Before(_) => &mut layout_data.data.before_style,
|
|
PseudoElementType::After (_) => &mut layout_data.data.after_style,
|
|
PseudoElementType::Normal => &mut layout_data.shared_data.style,
|
|
};
|
|
|
|
*style = None;
|
|
}
|
|
}
|