pub(crate) struct LayoutBoxBase {
pub base_fragment_info: BaseFragmentInfo,
pub style: Arc<ComputedValues>,
pub cached_inline_content_size: AtomicRefCell<Option<Box<(SizeConstraint, InlineContentSizesResult)>>>,
pub outer_inline_content_sizes_depend_on_content: AtomicBool,
cached_layout_result: AtomicRefCell<Option<LayoutResultAndInputs>>,
cached_layout_result_dirty: AtomicBool,
pub fragments: AtomicRefCell<Vec<Fragment>>,
pub parent_box: Option<WeakLayoutBox>,
only_descendants_changed: AtomicBool,
}Expand description
A box tree node that handles containing information about style and the original DOM node or pseudo-element that it is based on. This also handles caching of layout values such as the inline content sizes to avoid recalculating these values during layout passes.
In the future, this will hold layout results to support incremental layout.
Fields§
§base_fragment_info: BaseFragmentInfo§style: Arc<ComputedValues>§cached_inline_content_size: AtomicRefCell<Option<Box<(SizeConstraint, InlineContentSizesResult)>>>§outer_inline_content_sizes_depend_on_content: AtomicBool§cached_layout_result: AtomicRefCell<Option<LayoutResultAndInputs>>The cached layout results for this LayoutBoxBase. These are either cached
independent formatting context results or a cached block layout for use within
a block flow.
cached_layout_result_dirty: AtomicBoolWhether or not the cached layout result for this LayoutBoxBase is dirty.
This flag is used to preserve the cache when it can be used to do a faster
layout, but cannot be reused directly.
fragments: AtomicRefCell<Vec<Fragment>>§parent_box: Option<WeakLayoutBox>§only_descendants_changed: AtomicBoolImplementations§
Source§impl LayoutBoxBase
impl LayoutBoxBase
pub(crate) fn new( base_fragment_info: BaseFragmentInfo, style: ServoArc<ComputedValues>, ) -> Self
Sourcepub(crate) fn inline_content_sizes(
&self,
layout_context: &LayoutContext<'_>,
constraint_space: &ConstraintSpace<'_>,
layout_box: &impl ComputeInlineContentSizes,
) -> InlineContentSizesResult
pub(crate) fn inline_content_sizes( &self, layout_context: &LayoutContext<'_>, constraint_space: &ConstraintSpace<'_>, layout_box: &impl ComputeInlineContentSizes, ) -> InlineContentSizesResult
Get the inline content sizes of a box tree node that extends this LayoutBoxBase, fetch
the result from a cache when possible.
pub(crate) fn fragments(&self) -> Vec<Fragment>
pub(crate) fn add_fragment(&self, fragment: Fragment)
pub(crate) fn set_fragment(&self, fragment: Fragment)
pub(crate) fn clear_fragments(&self)
Sourcepub(crate) fn clear_fragments_and_dirty_fragment_cache(&self)
pub(crate) fn clear_fragments_and_dirty_fragment_cache(&self)
Clear all resulting fragments and dirty and fragment caches. Resulting fragments are used for layout queries and fragment caches are used for incremental layout.
pub(crate) fn repair_style(&mut self, new_style: &ServoArc<ComputedValues>)
pub(crate) fn parent_box(&self) -> Option<LayoutBox>
pub(crate) fn add_damage( &self, element_damage: LayoutDamage, damage_from_children: LayoutDamage, damage_from_parent: RestyleDamage, ) -> LayoutDamage
pub(crate) fn cached_independent_formatting_context_layout_if_applicable( &self, positioning_context: &mut PositioningContext, containing_block_for_children: &ContainingBlock<'_>, ) -> Option<IndependentFormattingContextLayoutResult>
pub(crate) fn cache_independent_formatting_context_layout( &self, containing_block_for_children: &ContainingBlock<'_>, child_positioning_context: &PositioningContext, result: &IndependentFormattingContextLayoutResult, )
pub(crate) fn cached_same_formatting_context_block_if_applicable( &self, containing_block: &ContainingBlock<'_>, collapsible_with_parent_start_margin: Option<CollapsibleWithParentStartMargin>, ignore_block_margins_for_stretch: LogicalSides1D<bool>, has_inline_parent: bool, ) -> Option<Arc<BoxFragment>>
pub(crate) fn cache_same_formatting_context_block_layout( &self, containing_block: &ContainingBlock<'_>, collapsible_with_parent_start_margin: Option<CollapsibleWithParentStartMargin>, ignore_block_margins_for_stretch: LogicalSides1D<bool>, has_inline_parent: bool, fragment: Arc<BoxFragment>, )
pub(crate) fn clear_scrollable_overflow_all_on_fragments(&self)
Trait Implementations§
Source§impl Debug for LayoutBoxBase
impl Debug for LayoutBoxBase
Source§impl MallocSizeOf for LayoutBoxBase
impl MallocSizeOf for LayoutBoxBase
Source§fn size_of(&self, ops: &mut MallocSizeOfOps) -> usize
fn size_of(&self, ops: &mut MallocSizeOfOps) -> usize
Auto Trait Implementations§
impl !Freeze for LayoutBoxBase
impl !RefUnwindSafe for LayoutBoxBase
impl Send for LayoutBoxBase
impl Sync for LayoutBoxBase
impl Unpin for LayoutBoxBase
impl UnsafeUnpin for LayoutBoxBase
impl !UnwindSafe for LayoutBoxBase
Blanket Implementations§
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> Filterable for T
impl<T> Filterable for T
Source§fn filterable(
self,
filter_name: &'static str,
) -> RequestFilterDataProvider<T, fn(DataRequest<'_>) -> bool>
fn filterable( self, filter_name: &'static str, ) -> RequestFilterDataProvider<T, fn(DataRequest<'_>) -> bool>
Source§impl<T> Instrument for T
impl<T> Instrument for T
Source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
Source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read more