substrate::layout

Struct CellBuilder

Source
pub struct CellBuilder<S: Schema> {
    pub ctx: Context,
    /* private fields */
}
Expand description

A layout cell builder.

Constructed once for each invocation of Layout::layout.

Fields§

§ctx: Context

The current global context.

Implementations§

Source§

impl<S: Schema> CellBuilder<S>

Source

pub fn new(ctx: Context) -> Self

Creates a new layout builder.

Source

pub fn generate<I: Layout>(&mut self, block: I) -> Instance<I>

Generate an instance of block.

Returns immediately, allowing generation to complete in the background. Attempting to access the generated instance’s cell will block until generation is complete.

Source

pub fn generate_blocking<I: Layout>(&mut self, block: I) -> Result<Instance<I>>

Generate an instance of block.

Blocks on generation, returning only once the instance’s cell is populated. Useful for handling errors thrown by the generation of a cell immediately.

Source

pub fn draw(&mut self, obj: impl Draw<S>) -> Result<()>

Draw layout object obj.

For instances, a new thread is spawned to add the instance once the underlying cell has been generated. If generation fails, the spawned thread may panic after this function has been called.

For error recovery, instance generation results should be checked using Instance::try_cell before calling draw.

§Panics

May cause a panic if generation of an underlying instance fails.

Source

pub fn ctx(&self) -> &Context

Gets the global context.

Trait Implementations§

Source§

impl<S: Schema> Bbox for CellBuilder<S>

Source§

fn bbox(&self) -> Option<Rect>

Computes the axis-aligned rectangular bounding box. Read more
Source§

fn bbox_rect(&self) -> Rect

Computes the axis-aligned rectangular bounding box, panicking if it is empty.
Source§

impl<S: Schema> LayerBbox<<S as Schema>::Layer> for CellBuilder<S>

Source§

fn layer_bbox(&self, layer: &S::Layer) -> Option<Rect>

Compute the bounding box considering only objects occupying the given layer.

Auto Trait Implementations§

§

impl<S> Freeze for CellBuilder<S>

§

impl<S> !RefUnwindSafe for CellBuilder<S>

§

impl<S> Send for CellBuilder<S>
where S: Send,

§

impl<S> Sync for CellBuilder<S>
where S: Sync,

§

impl<S> Unpin for CellBuilder<S>
where S: Unpin, <S as Schema>::Layer: Unpin,

§

impl<S> !UnwindSafe for CellBuilder<S>

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
§

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

§

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

Converts Box<dyn Trait> (where Trait: Downcast) to Box<dyn Any>, which can then be downcast into Box<dyn ConcreteType> where ConcreteType implements Trait.
§

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

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

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

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

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

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

impl<T> DowncastSend for T
where T: Any + Send,

§

fn into_any_send(self: Box<T>) -> Box<dyn Any + Send>

Converts Box<Trait> (where Trait: DowncastSend) to Box<dyn Any + Send>, which can then be downcast into Box<ConcreteType> where ConcreteType implements Trait.
§

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

§

fn into_any_sync(self: Box<T>) -> Box<dyn Any + Sync + Send>

Converts Box<Trait> (where Trait: DowncastSync) to Box<dyn Any + Send + Sync>, which can then be downcast into Box<ConcreteType> where ConcreteType implements Trait.
§

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

Converts Arc<Trait> (where Trait: DowncastSync) to Arc<Any>, which can then be 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.

§

impl<T> Instrument for T

§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided [Span], returning an Instrumented wrapper. Read more
§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
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> IntoRequest<T> for T

Source§

fn into_request(self) -> Request<T>

Wrap the input message T in a tonic::Request
Source§

impl<T> Same for T

Source§

type Output = T

Should always be Self
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.
§

impl<V, T> VZip<V> for T
where V: MultiLane<T>,

§

fn vzip(self) -> V

§

impl<T> WithSubscriber for T

§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a [WithDispatch] wrapper. Read more
§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a [WithDispatch] wrapper. Read more
Source§

impl<T> Primitive for T