pub enum ConstantOpIO<T>{
None,
Output0(T),
}
Variants§
Implementations§
Trait Implementations§
Source§impl<T> Clone for ConstantOpIO<T>
impl<T> Clone for ConstantOpIO<T>
Source§fn clone(&self) -> ConstantOpIO<T>
fn clone(&self) -> ConstantOpIO<T>
Returns a duplicate 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<T> Debug for ConstantOpIO<T>
impl<T> Debug for ConstantOpIO<T>
Source§impl<T> Default for ConstantOpIO<T>
impl<T> Default for ConstantOpIO<T>
Source§impl<T> Operator<ConstantOpIO<T>> for ConstantOp<T>
impl<T> Operator<ConstantOpIO<T>> for ConstantOp<T>
Source§fn output_port_connection_required(&self, port: usize) -> bool
fn output_port_connection_required(&self, port: usize) -> bool
NOTE: typically, we do not require that outputs from any given operator be connected. perhaps this design choice may be changed in the future
Source§fn opcode(&self) -> Arc<dyn OpCode>
fn opcode(&self) -> Arc<dyn OpCode>
Returns the operation code, which can be used to inform
specialized handling or diagnostics.
Source§fn input_count(&self) -> usize
fn input_count(&self) -> usize
How many actual inputs does this operator need?
Source§fn output_count(&self) -> usize
fn output_count(&self) -> usize
How many outputs does this operator produce?
Source§fn input_port_type_str(&self, port: usize) -> Option<&'static str>
fn input_port_type_str(&self, port: usize) -> Option<&'static str>
used by the network! dag compiler to verify that the input port of one operator is
compatible with the data flowing into it from the output port of another operator
Source§fn output_port_type_str(&self, port: usize) -> Option<&'static str>
fn output_port_type_str(&self, port: usize) -> Option<&'static str>
used by the network! dag compiler to verify that the output port of one operator is
compatible with the data required by the input port of its downstream operator
Source§fn input_port_connection_required(&self, port: usize) -> bool
fn input_port_connection_required(&self, port: usize) -> bool
used by the network! dag compiler to verify that this input port needs an output connection
Source§fn execute<'life0, 'life1, 'life2, 'async_trait>(
&'life0 self,
execute_inputs: [Option<&'life1 ConstantOpIO<T>>; 4],
execute_outputs: &'life2 mut [Option<ConstantOpIO<T>>; 4],
) -> Pin<Box<dyn Future<Output = NetResult<()>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
'life2: 'async_trait,
fn execute<'life0, 'life1, 'life2, 'async_trait>(
&'life0 self,
execute_inputs: [Option<&'life1 ConstantOpIO<T>>; 4],
execute_outputs: &'life2 mut [Option<ConstantOpIO<T>>; 4],
) -> Pin<Box<dyn Future<Output = NetResult<()>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
'life2: 'async_trait,
The big 4×4 method:
You receive up to 4 inputs and must fill up to 4 outputs.
Source§impl<T> PartialEq for ConstantOpIO<T>
impl<T> PartialEq for ConstantOpIO<T>
Source§impl<T> PortTryFrom0<()> for ConstantOpIO<T>
impl<T> PortTryFrom0<()> for ConstantOpIO<T>
type Error = NetworkError
fn port_try_from0(src: ()) -> Result<Self, Self::Error>
Source§impl<T> PortTryFrom1<()> for ConstantOpIO<T>
impl<T> PortTryFrom1<()> for ConstantOpIO<T>
type Error = NetworkError
fn port_try_from1(src: ()) -> Result<Self, Self::Error>
Source§impl<T> PortTryFrom2<()> for ConstantOpIO<T>
impl<T> PortTryFrom2<()> for ConstantOpIO<T>
type Error = NetworkError
fn port_try_from2(src: ()) -> Result<Self, Self::Error>
Source§impl<T> PortTryFrom3<()> for ConstantOpIO<T>
impl<T> PortTryFrom3<()> for ConstantOpIO<T>
type Error = NetworkError
fn port_try_from3(src: ()) -> Result<Self, Self::Error>
Source§impl<T> PortTryInto0<T> for ConstantOpIO<T>
impl<T> PortTryInto0<T> for ConstantOpIO<T>
type Error = NetworkError
Source§fn port_try_into0(self) -> Result<T, Self::Error>
fn port_try_into0(self) -> Result<T, Self::Error>
Convert
self
into a T
, using port
as needed.Source§impl<'a, T> PortTryInto0Any for ConstantOpIO<T>
impl<'a, T> PortTryInto0Any for ConstantOpIO<T>
type Error = NetworkError
fn port_try_into0_any(self) -> Result<Erased, Self::Error>
Source§impl<T> PortTryInto1<()> for ConstantOpIO<T>
impl<T> PortTryInto1<()> for ConstantOpIO<T>
type Error = NetworkError
Source§impl<'a, T> PortTryInto1Any for ConstantOpIO<T>
impl<'a, T> PortTryInto1Any for ConstantOpIO<T>
type Error = NetworkError
fn port_try_into1_any(self) -> Result<Erased, Self::Error>
Source§impl<T> PortTryInto2<()> for ConstantOpIO<T>
impl<T> PortTryInto2<()> for ConstantOpIO<T>
type Error = NetworkError
Source§impl<'a, T> PortTryInto2Any for ConstantOpIO<T>
impl<'a, T> PortTryInto2Any for ConstantOpIO<T>
type Error = NetworkError
fn port_try_into2_any(self) -> Result<Erased, Self::Error>
Source§impl<T> PortTryInto3<()> for ConstantOpIO<T>
impl<T> PortTryInto3<()> for ConstantOpIO<T>
type Error = NetworkError
Source§impl<'a, T> PortTryInto3Any for ConstantOpIO<T>
impl<'a, T> PortTryInto3Any for ConstantOpIO<T>
type Error = NetworkError
fn port_try_into3_any(self) -> Result<Erased, Self::Error>
impl<T> Eq for ConstantOpIO<T>
impl<T> StructuralPartialEq for ConstantOpIO<T>
Auto Trait Implementations§
impl<T> Freeze for ConstantOpIO<T>where
T: Freeze,
impl<T> RefUnwindSafe for ConstantOpIO<T>where
T: RefUnwindSafe,
impl<T> Send for ConstantOpIO<T>
impl<T> Sync for ConstantOpIO<T>
impl<T> Unpin for ConstantOpIO<T>where
T: Unpin,
impl<T> UnwindSafe for ConstantOpIO<T>where
T: UnwindSafe,
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