Skip to main content

Library

Struct Library 

Source
pub struct Library { /* private fields */ }

Implementations§

Source§

impl Library

Source

pub fn new(name: impl Into<SmolStr>, dbu: i64) -> Self

Create a new library. dbu is database units per micron (e.g. 1000 for a 1 nm grid). grid is the manufacturing grid in DBU; coordinates not on this grid are rejected by the (future) grid-check pass.

Source

pub fn name(&self) -> &str

Source

pub fn dbu(&self) -> i64

Source

pub fn grid(&self) -> i64

Source

pub fn set_grid(&mut self, grid: i64)

Source

pub fn layer(&self, info: LayerInfo) -> LayerIndex

Source

pub fn layer_info(&self, idx: LayerIndex) -> LayerInfo

Source

pub fn layer_by_gds(&self, layer: u16, datatype: u16) -> Option<LayerIndex>

Source

pub fn layer_by_name(&self, name: &str) -> Option<LayerIndex>

Source

pub fn insert(&self, builder: CellBuilder) -> CellId

Freeze a builder and insert into the library, returning a CellId. If a cell with the same ContentHash already exists, the existing CellId is returned and the builder is discarded.

Source

pub fn get(&self, id: CellId) -> Arc<Cell>

Source

pub fn try_get(&self, id: CellId) -> Option<Arc<Cell>>

Source

pub fn by_name(&self, name: &str) -> Option<CellId>

Source

pub fn by_content(&self, hash: ContentHash) -> Option<CellId>

Source

pub fn cell_count(&self) -> usize

Source

pub fn build<C: Component>(&self, c: &C) -> CellId

Source

pub fn top_cells(&self) -> Vec<CellId>

Cells with no parents in this library. Walks all cells and subtracts any referenced as instance children.

Source

pub fn all_cells(&self) -> Vec<(CellId, Arc<Cell>)>

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