use super::{
Arc,
ArcConditionalFunction,
BoxFunction,
BoxFunctionOnce,
Function,
Predicate,
RcFunction,
impl_arc_conversions,
impl_closure_trait,
impl_function_clone,
impl_function_common_methods,
impl_function_constant_method,
impl_function_debug_display,
impl_function_identity_method,
impl_shared_function_methods,
};
pub struct ArcFunction<T, R> {
pub(super) function: Arc<dyn Fn(&T) -> R + Send + Sync>,
pub(super) name: Option<String>,
}
impl<T, R> ArcFunction<T, R> {
impl_function_common_methods!(
ArcFunction<T, R>,
(Fn(&T) -> R + Send + Sync + 'static),
|f| Arc::new(f)
);
impl_shared_function_methods!(
ArcFunction<T, R>,
ArcConditionalFunction,
into_arc,
Function,
Send + Sync + 'static
);
}
impl_function_constant_method!(ArcFunction<T, R>, Send + Sync + 'static);
impl_function_identity_method!(ArcFunction<T, T>);
impl_function_clone!(ArcFunction<T, R>);
impl_function_debug_display!(ArcFunction<T, R>);
impl<T, R> Function<T, R> for ArcFunction<T, R> {
fn apply(&self, t: &T) -> R {
(self.function)(t)
}
impl_arc_conversions!(
ArcFunction<T, R>,
BoxFunction,
RcFunction,
BoxFunctionOnce,
Fn(t: &T) -> R
);
}
impl_closure_trait!(
Function<T, R>,
apply,
BoxFunctionOnce,
Fn(input: &T) -> R
);