Skip to main content

LayoutCache

Struct LayoutCache 

Source
pub struct LayoutCache {
    pub safe_area: SafeArea,
    pub delta_time: f32,
    pub scale_factor: f32,
    pub viewport: Option<Rect>,
    pub layout_time_budget: Duration,
    pub layout_start_time: Option<Instant>,
    pub parent_map: HashMap<u64, u64>,
    pub engine: Option<Box<dyn Any + Send + Sync>>,
    pub animators: Option<Box<dyn Any + Send + Sync>>,
    pub previous_rects: HashMap<u64, Rect>,
    pub eviction_generation: u64,
    pub previous_rects_generation: HashMap<u64, u64>,
    /* private fields */
}

Fields§

§safe_area: SafeArea§delta_time: f32§scale_factor: f32

Device scale factor for HiDPI / retina snapping. Defaults to 1.0.

§viewport: Option<Rect>

The visible viewport bounds in logical pixels. If Some, layout execution can cull offscreen subtrees.

§layout_time_budget: Duration

Time budget for the layout pass. Defaults to 4.0ms.

§layout_start_time: Option<Instant>

Start of the layout pass, captured at the beginning of the frame/layout run.

§parent_map: HashMap<u64, u64>

Map tracking child-to-parent view hash relationships for bottom-up invalidation.

§engine: Option<Box<dyn Any + Send + Sync>>

Opaque pointer to the active layout engine (e.g. Taffy)

§animators: Option<Box<dyn Any + Send + Sync>>

Opaque pointer to the active animation orchestrator

§previous_rects: HashMap<u64, Rect>

Cached previous rects for view transitions

§eviction_generation: u64

Generation counter for cache eviction. Incremented each frame; entries not touched for N frames are evicted.

§previous_rects_generation: HashMap<u64, u64>

Tracks which generation each previous_rects entry was last touched in.

Implementations§

Source§

impl LayoutCache

Source

pub fn new() -> Self

Source

pub fn generation(&self) -> u64

Returns the current generation counter.

Source

pub fn evict_stale_entries(&mut self)

Evict entries from previous_rects that haven’t been touched for N generations.

Source

pub fn is_over_budget(&self) -> bool

Checks if the layout pass is currently running over its allocated time budget.

Source

pub fn set_layout_budget_deadline(deadline: Option<Instant>)

Set a process-local deadline for layout cache consumers. When this deadline is exceeded, caches should reuse previous rects instead of recomputing expensive layout work.

Source

pub fn clear_layout_budget_deadline()

Clear any process-local layout budget deadline.

Source

pub fn invalidate(&mut self)

Bump the generation counter, logically invalidating all cached entries without eagerly clearing them. Subsequent lookups with the old generation will miss until re-populated.

Source

pub fn is_valid(&self, key: LayoutKey, current_gen: u64) -> bool

Check whether a cached entry for the given key is still valid against the current generation.

Source

pub fn clear(&mut self)

Source

pub fn get_size(&self, view_hash: u64, proposal: SizeProposal) -> Option<Size>

Source

pub fn set_size(&mut self, view_hash: u64, proposal: SizeProposal, size: Size)

Source

pub fn register_parent(&mut self, child_hash: u64, parent_hash: u64)

Register a child-to-parent layout relationship for bottom-up invalidation propagation.

Source

pub fn invalidate_view(&mut self, view_hash: u64)

Remove all cached size entries for a specific view hash and propagate the invalidation bottom-up to all its layout ancestors to ensure consistent layout updates.

Trait Implementations§

Source§

impl Default for LayoutCache

Source§

fn default() -> Self

Returns the “default value” for a type. Read more

Auto Trait Implementations§

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<ST, DT> CastableFrom<ST, Initialized, Initialized> for DT
where ST: ?Sized, DT: ?Sized,

Source§

impl<ST, DT> CastableFrom<ST, Uninit, Uninit> for DT
where ST: ?Sized, DT: ?Sized,

Source§

impl<T> Downcast for T
where T: Any,

Source§

fn into_any(self: Box<T>) -> Box<dyn Any>

Convert Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>. Box<dyn Any> can then be further downcast into Box<ConcreteType> where ConcreteType implements Trait.
Source§

fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>

Convert Rc<Trait> (where Trait: Downcast) to Rc<Any>. Rc<Any> can then be further downcast into Rc<ConcreteType> where ConcreteType implements Trait.
Source§

fn as_any(&self) -> &(dyn Any + 'static)

Convert &Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &Any’s vtable from &Trait’s.
Source§

fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)

Convert &mut Trait (where Trait: Downcast) to &Any. This is needed since Rust cannot generate &mut Any’s vtable from &mut Trait’s.
Source§

impl<T> DowncastSync for T
where T: Any + Send + Sync,

Source§

fn into_any_arc(self: Arc<T>) -> Arc<dyn Any + Send + Sync>

Convert Arc<Trait> (where Trait: Downcast) to Arc<Any>. Arc<Any> can then be further downcast into Arc<ConcreteType> where ConcreteType implements Trait.
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> Read<Exclusive, BecauseExclusive> for T
where T: ?Sized,

Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.