pub struct CellBuilder<PDK: Pdk + ?Sized> {
    pub ctx: PdkContext<PDK>,
    /* private fields */
}
Expand description

A layout cell builder.

Constructed once for each invocation of Layout::layout.

Fields§

§ctx: PdkContext<PDK>

The current global context.

Implementations§

source§

impl<PDK: Pdk> CellBuilder<PDK>

source

pub fn new(ctx: PdkContext<PDK>) -> Self

Creates a new layout builder.

source

pub fn generate<I: Layout<PDK>>(&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.

§Examples
    impl Layout<ExamplePdk> for Buffer {
        fn layout(

            // ...

        ) -> substrate::error::Result<Self::LayoutData> {
            let inv1 = cell.generate(Inverter::new(self.strength));
            let inv2 = inv1.clone().align_bbox(AlignMode::ToTheRight, &inv1, 10);

            cell.draw(inv1.clone())?;
            cell.draw(inv2.clone())?;

            io.vdd.merge(inv1.io().vdd);
            io.vdd.merge(inv2.io().vdd);
            io.vss.merge(inv1.io().vss);
            io.vss.merge(inv2.io().vss);
            io.din.merge(inv1.io().din);
            io.dout.merge(inv2.io().dout);

            Ok(BufferData { inv1, inv2 })
        }
    }
source

pub fn generate_blocking<I: Layout<PDK>>( &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_blockage(&mut self, shape: Shape)

Draw a blockage.

source

pub fn draw(&mut self, obj: impl Draw<PDK>) -> 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) -> &PdkContext<PDK>

Gets the global context.

Trait Implementations§

source§

impl<PDK: Pdk> Bbox for CellBuilder<PDK>

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<PDK: Pdk> LayerBbox for CellBuilder<PDK>

source§

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

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

Auto Trait Implementations§

§

impl<PDK> !RefUnwindSafe for CellBuilder<PDK>

§

impl<PDK: ?Sized> Send for CellBuilder<PDK>

§

impl<PDK: ?Sized> Sync for CellBuilder<PDK>

§

impl<PDK: ?Sized> Unpin for CellBuilder<PDK>
where PDK: Unpin,

§

impl<PDK> !UnwindSafe for CellBuilder<PDK>

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<T, U> CustomHardwareType<Flipped<T>> for U

source§

fn from_layout_type(other: &Flipped<T>) -> U

Creates this layout type from another layout type.
source§

impl<T, U> CustomHardwareType<InOut<T>> for U

source§

fn from_layout_type(other: &InOut<T>) -> U

Creates this layout type from another layout type.
source§

impl<T, U> CustomHardwareType<Input<T>> for U

source§

fn from_layout_type(other: &Input<T>) -> U

Creates this layout type from another layout type.
source§

impl<T, U> CustomHardwareType<Output<T>> for U

source§

fn from_layout_type(other: &Output<T>) -> U

Creates this layout type from another layout type.
§

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

§

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.
§

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.
§

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.
§

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.
§

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

§

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.

§

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

§

type Output = T

Should always be Self
source§

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

§

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>,

§

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> Connect<&T> for T

source§

impl<T> Connect<T> for T

source§

impl<T> Primitive for T