use quote::quote_spanned;
use super::{
FloType, OperatorCategory, OperatorConstraints, OperatorWriteOutput, RANGE_0, RANGE_1,
WriteContextArgs,
};
pub const REPEAT_N: OperatorConstraints = OperatorConstraints {
name: "repeat_n",
categories: &[OperatorCategory::Windowing],
hard_range_inn: RANGE_1,
soft_range_inn: RANGE_1,
hard_range_out: RANGE_1,
soft_range_out: RANGE_1,
num_args: 1,
persistence_args: RANGE_0,
type_args: RANGE_0,
is_external_input: false,
has_singleton_output: true,
flo_type: Some(FloType::Windowing),
ports_inn: None,
ports_out: None,
input_delaytype_fn: |_| None,
write_fn: |wc @ &WriteContextArgs {
root,
context,
df_ident,
op_span,
work_fn_async,
arguments,
ident,
is_pull,
inputs,
singleton_output_ident,
..
},
_diagnostics| {
assert!(is_pull);
let write_prologue = quote_spanned! {op_span=>
#[allow(clippy::redundant_closure_call)]
let #singleton_output_ident = #df_ident.add_state(
::std::cell::RefCell::new(::std::vec::Vec::new())
);
};
let vec_ident = wc.make_ident("vec");
let input = &inputs[0];
let write_iterator = quote_spanned! {op_span=>
let mut #vec_ident = unsafe {
#context.state_ref_unchecked(#singleton_output_ident)
}.borrow_mut();
if 0 == #context.loop_iter_count() {
*#vec_ident = #work_fn_async(
#root::dfir_pipes::pull::Pull::collect::<::std::vec::Vec<_>>(#input),
).await;
}
let #ident = #root::dfir_pipes::pull::iter(::std::clone::Clone::clone(&*#vec_ident));
};
let count_arg = &arguments[0];
let write_iterator_after = quote_spanned! {op_span=>
{
if #context.loop_iter_count() + 1 < #count_arg {
#context.reschedule_loop_block();
}
}
};
Ok(OperatorWriteOutput {
write_prologue,
write_iterator,
write_iterator_after,
..Default::default()
})
},
};