iridis_api/io/
raw_input.rs1use crate::prelude::*;
2use thirdparty::arrow_data::ArrayData;
3
4#[derive(Debug)]
6pub struct RawInput {
7 pub rx: MessageReceiver,
9
10 pub source: NodeLayout,
12 pub layout: InputLayout,
14}
15
16impl RawInput {
17 pub fn new(rx: MessageReceiver, source: NodeLayout, layout: InputLayout) -> Self {
19 Self { rx, source, layout }
20 }
21
22 pub async fn recv(&mut self) -> Result<(Header, ArrayData)> {
24 let DataflowMessage { header, data } = self
25 .rx
26 .recv()
27 .await
28 .ok_or_eyre(report_error_receiving(&self.source, &self.layout))?;
29
30 Ok((header, data))
31 }
32}