Struct substrate::io::layout::PortGeometry
source · pub struct PortGeometry {
pub primary: IoShape,
pub unnamed_shapes: Vec<IoShape>,
pub named_shapes: HashMap<ArcStr, IoShape>,
}
Expand description
A layout port with a generic set of associated geometry.
Fields§
§primary: IoShape
The primary shape of the port.
Not contained in named_shapes
or unnamed_shapes
.
unnamed_shapes: Vec<IoShape>
A set of unnamed shapes contained by the port.
named_shapes: HashMap<ArcStr, IoShape>
A set of named shapes contained by the port.
Implementations§
source§impl PortGeometry
impl PortGeometry
sourcepub fn shapes(&self) -> impl Iterator<Item = &IoShape>
pub fn shapes(&self) -> impl Iterator<Item = &IoShape>
Returns an iterator over all shapes in a PortGeometry
.
Trait Implementations§
source§impl Bbox for PortGeometry
impl Bbox for PortGeometry
source§impl BundleBuilder<PortGeometry> for PortGeometryBuilder
impl BundleBuilder<PortGeometry> for PortGeometryBuilder
source§fn build(self) -> Result<PortGeometry>
fn build(self) -> Result<PortGeometry>
Builds an instance of bundle
T
.source§impl Clone for PortGeometry
impl Clone for PortGeometry
source§fn clone(&self) -> PortGeometry
fn clone(&self) -> PortGeometry
Returns a copy of the value. Read more
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source
. Read moresource§impl Debug for PortGeometry
impl Debug for PortGeometry
source§impl FlatLen for PortGeometry
impl FlatLen for PortGeometry
source§impl Flatten<PortGeometry> for ()
impl Flatten<PortGeometry> for ()
source§impl<T: Flatten<PortGeometry>> Flatten<PortGeometry> for ArrayData<T>
impl<T: Flatten<PortGeometry>> Flatten<PortGeometry> for ArrayData<T>
source§impl Flatten<PortGeometry> for DiffPairLayout
impl Flatten<PortGeometry> for DiffPairLayout
source§impl Flatten<PortGeometry> for IoShape
impl Flatten<PortGeometry> for IoShape
source§impl Flatten<PortGeometry> for MosIoLayout
impl Flatten<PortGeometry> for MosIoLayout
source§impl Flatten<PortGeometry> for PortGeometry
impl Flatten<PortGeometry> for PortGeometry
source§impl Flatten<PortGeometry> for PowerIoLayout
impl Flatten<PortGeometry> for PowerIoLayout
source§impl Flatten<PortGeometry> for TestbenchIoLayout
impl Flatten<PortGeometry> for TestbenchIoLayout
source§impl Flatten<PortGeometry> for TwoTerminalIoLayout
impl Flatten<PortGeometry> for TwoTerminalIoLayout
source§impl HasTransformedView for PortGeometry
impl HasTransformedView for PortGeometry
§type TransformedView = PortGeometry
type TransformedView = PortGeometry
An object storing a transformed view of
Self
.source§fn transformed_view(&self, trans: Transformation) -> Self::TransformedView
fn transformed_view(&self, trans: Transformation) -> Self::TransformedView
Produces a transformed view of
self
.source§impl PartialEq for PortGeometry
impl PartialEq for PortGeometry
source§fn eq(&self, other: &PortGeometry) -> bool
fn eq(&self, other: &PortGeometry) -> bool
This method tests for
self
and other
values to be equal, and is used
by ==
.impl Eq for PortGeometry
impl StructuralPartialEq for PortGeometry
Auto Trait Implementations§
impl RefUnwindSafe for PortGeometry
impl Send for PortGeometry
impl Sync for PortGeometry
impl Unpin for PortGeometry
impl UnwindSafe for PortGeometry
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
Mutably borrows from an owned value. Read more
source§impl<T, U> CustomHardwareType<Flipped<T>> for Uwhere
U: CustomHardwareType<T>,
T: HardwareType,
impl<T, U> CustomHardwareType<Flipped<T>> for Uwhere
U: CustomHardwareType<T>,
T: HardwareType,
source§fn from_layout_type(other: &Flipped<T>) -> U
fn from_layout_type(other: &Flipped<T>) -> U
Creates this layout type from another layout type.
source§impl<T, U> CustomHardwareType<InOut<T>> for Uwhere
U: CustomHardwareType<T>,
T: HardwareType,
impl<T, U> CustomHardwareType<InOut<T>> for Uwhere
U: CustomHardwareType<T>,
T: HardwareType,
source§fn from_layout_type(other: &InOut<T>) -> U
fn from_layout_type(other: &InOut<T>) -> U
Creates this layout type from another layout type.
source§impl<T, U> CustomHardwareType<Input<T>> for Uwhere
U: CustomHardwareType<T>,
T: HardwareType,
impl<T, U> CustomHardwareType<Input<T>> for Uwhere
U: CustomHardwareType<T>,
T: HardwareType,
source§fn from_layout_type(other: &Input<T>) -> U
fn from_layout_type(other: &Input<T>) -> U
Creates this layout type from another layout type.
source§impl<T, U> CustomHardwareType<Output<T>> for Uwhere
U: CustomHardwareType<T>,
T: HardwareType,
impl<T, U> CustomHardwareType<Output<T>> for Uwhere
U: CustomHardwareType<T>,
T: HardwareType,
source§fn from_layout_type(other: &Output<T>) -> U
fn from_layout_type(other: &Output<T>) -> U
Creates this layout type from another layout type.
§impl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere
T: Any,
§fn into_any(self: Box<T>) -> Box<dyn 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>
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)
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)
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
impl<T> DowncastSync for T
source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Compare self to
key
and return true
if they are equal.§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Checks if this value is equivalent to the given key. Read more
§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Compare self to
key
and return true
if they are equal.§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
source§impl<T> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
source§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
Wrap the input message
T
in a tonic::Request