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}