pub struct InverterIoKindwhere
InOut<Signal>: HasBundleKind,
Input<Signal>: HasBundleKind,
Output<Signal>: HasBundleKind,{
pub vdd: <InOut<Signal> as HasBundleKind>::BundleKind,
pub vss: <InOut<Signal> as HasBundleKind>::BundleKind,
pub din: <Input<Signal> as HasBundleKind>::BundleKind,
pub dout: <Output<Signal> as HasBundleKind>::BundleKind,
}Fields§
§vdd: <InOut<Signal> as HasBundleKind>::BundleKind§vss: <InOut<Signal> as HasBundleKind>::BundleKind§din: <Input<Signal> as HasBundleKind>::BundleKind§dout: <Output<Signal> as HasBundleKind>::BundleKindTrait Implementations§
Source§impl Clone for InverterIoKind
impl Clone for InverterIoKind
Source§impl Debug for InverterIoKind
impl Debug for InverterIoKind
Source§impl FlatLen for InverterIoKindwhere
InOut<Signal>: HasBundleKind,
Input<Signal>: HasBundleKind,
Output<Signal>: HasBundleKind,
<InOut<Signal> as HasBundleKind>::BundleKind: FlatLen,
<Input<Signal> as HasBundleKind>::BundleKind: FlatLen,
<Output<Signal> as HasBundleKind>::BundleKind: FlatLen,
impl FlatLen for InverterIoKindwhere
InOut<Signal>: HasBundleKind,
Input<Signal>: HasBundleKind,
Output<Signal>: HasBundleKind,
<InOut<Signal> as HasBundleKind>::BundleKind: FlatLen,
<Input<Signal> as HasBundleKind>::BundleKind: FlatLen,
<Output<Signal> as HasBundleKind>::BundleKind: FlatLen,
Source§impl HasBundleKind for InverterIoKindwhere
InOut<Signal>: HasBundleKind,
Input<Signal>: HasBundleKind,
Output<Signal>: HasBundleKind,
<InOut<Signal> as HasBundleKind>::BundleKind: HasBundleKind,
<Input<Signal> as HasBundleKind>::BundleKind: HasBundleKind,
<Output<Signal> as HasBundleKind>::BundleKind: HasBundleKind,
impl HasBundleKind for InverterIoKindwhere
InOut<Signal>: HasBundleKind,
Input<Signal>: HasBundleKind,
Output<Signal>: HasBundleKind,
<InOut<Signal> as HasBundleKind>::BundleKind: HasBundleKind,
<Input<Signal> as HasBundleKind>::BundleKind: HasBundleKind,
<Output<Signal> as HasBundleKind>::BundleKind: HasBundleKind,
Source§type BundleKind = InverterIoKind
type BundleKind = InverterIoKind
The Rust type of the [
BundleKind] associated with this bundle.Source§impl HasDefaultLayoutBundle for InverterIoKindwhere
InOut<Signal>: HasBundleKind + HasDefaultLayoutBundle,
Input<Signal>: HasBundleKind + HasDefaultLayoutBundle,
Output<Signal>: HasBundleKind + HasDefaultLayoutBundle,
impl HasDefaultLayoutBundle for InverterIoKindwhere
InOut<Signal>: HasBundleKind + HasDefaultLayoutBundle,
Input<Signal>: HasBundleKind + HasDefaultLayoutBundle,
Output<Signal>: HasBundleKind + HasDefaultLayoutBundle,
type Bundle<__substrate_L: Schema> = InverterIoView<PortGeometryBundle<__substrate_L>>
Source§impl HasNameTree for InverterIoKindwhere
InOut<Signal>: HasBundleKind,
Input<Signal>: HasBundleKind,
Output<Signal>: HasBundleKind,
<InOut<Signal> as HasBundleKind>::BundleKind: HasBundleKind,
<Input<Signal> as HasBundleKind>::BundleKind: HasBundleKind,
<Output<Signal> as HasBundleKind>::BundleKind: HasBundleKind,
impl HasNameTree for InverterIoKindwhere
InOut<Signal>: HasBundleKind,
Input<Signal>: HasBundleKind,
Output<Signal>: HasBundleKind,
<InOut<Signal> as HasBundleKind>::BundleKind: HasBundleKind,
<Input<Signal> as HasBundleKind>::BundleKind: HasBundleKind,
<Output<Signal> as HasBundleKind>::BundleKind: HasBundleKind,
Source§impl HasNodeBundle for InverterIoKindwhere
InOut<Signal>: HasBundleKind + HasSchematicBundleKindViews,
Input<Signal>: HasBundleKind + HasSchematicBundleKindViews,
Output<Signal>: HasBundleKind + HasSchematicBundleKindViews,
<InOut<Signal> as HasBundleKind>::BundleKind: HasNodeBundle,
<Input<Signal> as HasBundleKind>::BundleKind: HasNodeBundle,
<Output<Signal> as HasBundleKind>::BundleKind: HasNodeBundle,
impl HasNodeBundle for InverterIoKindwhere
InOut<Signal>: HasBundleKind + HasSchematicBundleKindViews,
Input<Signal>: HasBundleKind + HasSchematicBundleKindViews,
Output<Signal>: HasBundleKind + HasSchematicBundleKindViews,
<InOut<Signal> as HasBundleKind>::BundleKind: HasNodeBundle,
<Input<Signal> as HasBundleKind>::BundleKind: HasNodeBundle,
<Output<Signal> as HasBundleKind>::BundleKind: HasNodeBundle,
Source§type NodeBundle = InverterIoView<NodeBundle>
type NodeBundle = InverterIoView<NodeBundle>
The associated node bundle.
Source§impl HasTerminalBundle for InverterIoKindwhere
InOut<Signal>: HasBundleKind + HasSchematicBundleKindViews,
Input<Signal>: HasBundleKind + HasSchematicBundleKindViews,
Output<Signal>: HasBundleKind + HasSchematicBundleKindViews,
<InOut<Signal> as HasBundleKind>::BundleKind: HasTerminalBundle,
<Input<Signal> as HasBundleKind>::BundleKind: HasTerminalBundle,
<Output<Signal> as HasBundleKind>::BundleKind: HasTerminalBundle,
impl HasTerminalBundle for InverterIoKindwhere
InOut<Signal>: HasBundleKind + HasSchematicBundleKindViews,
Input<Signal>: HasBundleKind + HasSchematicBundleKindViews,
Output<Signal>: HasBundleKind + HasSchematicBundleKindViews,
<InOut<Signal> as HasBundleKind>::BundleKind: HasTerminalBundle,
<Input<Signal> as HasBundleKind>::BundleKind: HasTerminalBundle,
<Output<Signal> as HasBundleKind>::BundleKind: HasTerminalBundle,
Source§type TerminalBundle = InverterIoView<TerminalBundle>
type TerminalBundle = InverterIoView<TerminalBundle>
The associated terminal bundle.
Source§impl PartialEq for InverterIoKind
impl PartialEq for InverterIoKind
Source§impl SchematicBundleKind for InverterIoKindwhere
InOut<Signal>: HasBundleKind + HasSchematicBundleKindViews,
Input<Signal>: HasBundleKind + HasSchematicBundleKindViews,
Output<Signal>: HasBundleKind + HasSchematicBundleKindViews,
impl SchematicBundleKind for InverterIoKindwhere
InOut<Signal>: HasBundleKind + HasSchematicBundleKindViews,
Input<Signal>: HasBundleKind + HasSchematicBundleKindViews,
Output<Signal>: HasBundleKind + HasSchematicBundleKindViews,
Source§fn terminal_view(
cell: CellId,
cell_io: &NodeBundle<Self>,
instance: InstanceId,
instance_io: &NodeBundle<Self>,
) -> TerminalBundle<Self>
fn terminal_view( cell: CellId, cell_io: &NodeBundle<Self>, instance: InstanceId, instance_io: &NodeBundle<Self>, ) -> TerminalBundle<Self>
Creates a terminal view of the object given a parent node, the cell IO, and the instance IO.
Source§impl<SubstrateV, SubstrateS> Unflatten<InverterIoKind, SubstrateS> for InverterIoView<SubstrateV>where
InOut<Signal>: HasView<SubstrateV> + HasBundleKind,
Input<Signal>: HasView<SubstrateV> + HasBundleKind,
Output<Signal>: HasView<SubstrateV> + HasBundleKind,
<InOut<Signal> as HasView<SubstrateV>>::View: Unflatten<<InOut<Signal> as HasBundleKind>::BundleKind, SubstrateS>,
<Input<Signal> as HasView<SubstrateV>>::View: Unflatten<<Input<Signal> as HasBundleKind>::BundleKind, SubstrateS>,
<Output<Signal> as HasView<SubstrateV>>::View: Unflatten<<Output<Signal> as HasBundleKind>::BundleKind, SubstrateS>,
impl<SubstrateV, SubstrateS> Unflatten<InverterIoKind, SubstrateS> for InverterIoView<SubstrateV>where
InOut<Signal>: HasView<SubstrateV> + HasBundleKind,
Input<Signal>: HasView<SubstrateV> + HasBundleKind,
Output<Signal>: HasView<SubstrateV> + HasBundleKind,
<InOut<Signal> as HasView<SubstrateV>>::View: Unflatten<<InOut<Signal> as HasBundleKind>::BundleKind, SubstrateS>,
<Input<Signal> as HasView<SubstrateV>>::View: Unflatten<<Input<Signal> as HasBundleKind>::BundleKind, SubstrateS>,
<Output<Signal> as HasView<SubstrateV>>::View: Unflatten<<Output<Signal> as HasBundleKind>::BundleKind, SubstrateS>,
Source§fn unflatten<SubstrateI>(
__substrate_data: &InverterIoKind,
__substrate_source: &mut SubstrateI,
) -> Option<Self>where
SubstrateI: Iterator<Item = SubstrateS>,
fn unflatten<SubstrateI>(
__substrate_data: &InverterIoKind,
__substrate_source: &mut SubstrateI,
) -> Option<Self>where
SubstrateI: Iterator<Item = SubstrateS>,
Unflatten a structure from an iterator. Read more
impl Eq for InverterIoKind
Auto Trait Implementations§
impl Freeze for InverterIoKind
impl RefUnwindSafe for InverterIoKind
impl Send for InverterIoKind
impl Sync for InverterIoKind
impl Unpin for InverterIoKind
impl UnwindSafe for InverterIoKind
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> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
§impl<T> DataView<Array<Signal>> for Twhere
T: SchematicBundleKind,
impl<T> DataView<Array<Signal>> for Twhere
T: SchematicBundleKind,
§fn view_nodes_as(
nodes: &<<T as HasBundleKind>::BundleKind as HasNodeBundle>::NodeBundle,
) -> <<Array<Signal> as HasBundleKind>::BundleKind as HasNodeBundle>::NodeBundle
fn view_nodes_as( nodes: &<<T as HasBundleKind>::BundleKind as HasNodeBundle>::NodeBundle, ) -> <<Array<Signal> as HasBundleKind>::BundleKind as HasNodeBundle>::NodeBundle
Views a node bundle as a node bundle of a different kind.
§fn view_terminals_as(
terminals: &<Self::BundleKind as HasTerminalBundle>::TerminalBundle,
) -> <<T as HasBundleKind>::BundleKind as HasTerminalBundle>::TerminalBundle
fn view_terminals_as( terminals: &<Self::BundleKind as HasTerminalBundle>::TerminalBundle, ) -> <<T as HasBundleKind>::BundleKind as HasTerminalBundle>::TerminalBundle
Views a terminal bundle as a terminal bundle of a different kind.
§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>
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>
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)
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)
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
impl<T> DowncastSend for T
§impl<T> DowncastSync for T
impl<T> DowncastSync for T
§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<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<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>
§impl<T> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
Wrap the input message
T in a tonic::Request§impl<L> LayerExt<L> for L
impl<L> LayerExt<L> for L
§fn named_layer<S>(&self, service: S) -> Layered<<L as Layer<S>>::Service, S>where
L: Layer<S>,
fn named_layer<S>(&self, service: S) -> Layered<<L as Layer<S>>::Service, S>where
L: Layer<S>,
Applies the layer to a service and wraps it in [
Layered].