mirror of
https://github.com/mozilla/gecko-dev.git
synced 2024-10-20 16:55:40 +00:00
62e95664e4
Gecko Bug: https://bugzilla.mozilla.org/show_bug.cgi?id=131701 (Don't review yet, will flag on the gecko bug when the time comes) Source-Repo: https://github.com/servo/servo Source-Revision: d98abaec20e624aa89a3abddf4cf2a6399951ef1
105 lines
3.4 KiB
Rust
105 lines
3.4 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/. */
|
|
|
|
//! The context within which style is calculated.
|
|
|
|
use animation::Animation;
|
|
use app_units::Au;
|
|
use dom::OpaqueNode;
|
|
use error_reporting::ParseErrorReporter;
|
|
use euclid::Size2D;
|
|
use matching::StyleSharingCandidateCache;
|
|
use parking_lot::RwLock;
|
|
use std::cell::RefCell;
|
|
use std::collections::HashMap;
|
|
use std::sync::{Arc, Mutex};
|
|
use std::sync::mpsc::Sender;
|
|
use stylist::Stylist;
|
|
use timer::Timer;
|
|
|
|
/// This structure is used to create a local style context from a shared one.
|
|
pub struct LocalStyleContextCreationInfo {
|
|
new_animations_sender: Sender<Animation>,
|
|
}
|
|
|
|
impl LocalStyleContextCreationInfo {
|
|
pub fn new(animations_sender: Sender<Animation>) -> Self {
|
|
LocalStyleContextCreationInfo {
|
|
new_animations_sender: animations_sender,
|
|
}
|
|
}
|
|
}
|
|
|
|
pub struct SharedStyleContext {
|
|
/// The current viewport size.
|
|
pub viewport_size: Size2D<Au>,
|
|
|
|
/// Screen sized changed?
|
|
pub screen_size_changed: bool,
|
|
|
|
/// Skip the root during traversal?
|
|
///
|
|
/// This is used in Gecko to style newly-appended children without restyling
|
|
/// the parent. It would be cleaner to add an API to allow us to enqueue the
|
|
/// children directly from glue.rs.
|
|
#[cfg(feature = "gecko")]
|
|
pub skip_root: bool,
|
|
|
|
/// The CSS selector stylist.
|
|
pub stylist: Arc<Stylist>,
|
|
|
|
/// Starts at zero, and increased by one every time a layout completes.
|
|
/// This can be used to easily check for invalid stale data.
|
|
pub generation: u32,
|
|
|
|
/// Why is this reflow occurring
|
|
pub goal: ReflowGoal,
|
|
|
|
/// The animations that are currently running.
|
|
pub running_animations: Arc<RwLock<HashMap<OpaqueNode, Vec<Animation>>>>,
|
|
|
|
/// The list of animations that have expired since the last style recalculation.
|
|
pub expired_animations: Arc<RwLock<HashMap<OpaqueNode, Vec<Animation>>>>,
|
|
|
|
///The CSS error reporter for all CSS loaded in this layout thread
|
|
pub error_reporter: Box<ParseErrorReporter + Sync>,
|
|
|
|
/// Data needed to create the local style context from the shared one.
|
|
pub local_context_creation_data: Mutex<LocalStyleContextCreationInfo>,
|
|
|
|
/// The current timer for transitions and animations. This is needed to test
|
|
/// them.
|
|
pub timer: Timer,
|
|
}
|
|
|
|
pub struct LocalStyleContext {
|
|
pub style_sharing_candidate_cache: RefCell<StyleSharingCandidateCache>,
|
|
/// A channel on which new animations that have been triggered by style
|
|
/// recalculation can be sent.
|
|
pub new_animations_sender: Sender<Animation>,
|
|
}
|
|
|
|
impl LocalStyleContext {
|
|
pub fn new(local_context_creation_data: &LocalStyleContextCreationInfo) -> Self {
|
|
LocalStyleContext {
|
|
style_sharing_candidate_cache: RefCell::new(StyleSharingCandidateCache::new()),
|
|
new_animations_sender: local_context_creation_data.new_animations_sender.clone(),
|
|
}
|
|
}
|
|
}
|
|
|
|
pub trait StyleContext<'a> {
|
|
fn shared_context(&self) -> &'a SharedStyleContext;
|
|
fn local_context(&self) -> &LocalStyleContext;
|
|
}
|
|
|
|
/// Why we're doing reflow.
|
|
#[derive(PartialEq, Copy, Clone, Debug)]
|
|
pub enum ReflowGoal {
|
|
/// We're reflowing in order to send a display list to the screen.
|
|
ForDisplay,
|
|
/// We're reflowing in order to satisfy a script query. No display list will be created.
|
|
ForScriptQuery,
|
|
}
|