protoflow_blocks/blocks/io/
encode_hex.rsuse crate::{
prelude::{format, Bytes, String},
IoBlocks, StdioConfig, StdioError, StdioSystem, System,
};
use protoflow_core::{Block, BlockResult, BlockRuntime, InputPort, OutputPort};
use protoflow_derive::Block;
use simple_mermaid::mermaid;
#[doc = mermaid!("../../../doc/io/encode_hex.mmd")]
#[doc = mermaid!("../../../doc/io/encode_hex.seq.mmd" framed)]
#[derive(Block, Clone)]
pub struct EncodeHex {
#[input]
pub input: InputPort<Bytes>,
#[output]
pub output: OutputPort<Bytes>,
}
impl EncodeHex {
pub fn new(input: InputPort<Bytes>, output: OutputPort<Bytes>) -> Self {
Self { input, output }
}
pub fn with_system(system: &System) -> Self {
use crate::SystemBuilding;
Self::new(system.input(), system.output())
}
}
impl Block for EncodeHex {
fn execute(&mut self, runtime: &dyn BlockRuntime) -> BlockResult {
runtime.wait_for(&self.input)?;
while let Some(message) = self.input.recv()? {
let mut buffer = String::with_capacity(message.len() * 2);
for byte in message.iter() {
buffer.push_str(format!("{:02x}", byte).as_str()); }
let message = Bytes::from(buffer);
self.output.send(&message)?;
}
Ok(())
}
}
#[cfg(feature = "std")]
impl StdioSystem for EncodeHex {
fn build_system(config: StdioConfig) -> Result<System, StdioError> {
use crate::SystemBuilding;
config.reject_any()?;
Ok(System::build(|s| {
let stdin = config.read_stdin(s);
let hex_encoder = s.encode_hex();
let stdout = config.write_stdout(s);
s.connect(&stdin.output, &hex_encoder.input);
s.connect(&hex_encoder.output, &stdout.input);
}))
}
}
#[cfg(test)]
mod tests {
use super::EncodeHex;
use crate::{System, SystemBuilding};
#[test]
fn instantiate_block() {
let _ = System::build(|s| {
let _ = s.block(EncodeHex::new(s.input(), s.output()));
});
}
}