use super::{
BoxFunction,
BoxFunctionOnce,
Function,
Predicate,
Rc,
RcConditionalFunction,
impl_function_clone,
impl_function_common_methods,
impl_function_constant_method,
impl_function_debug_display,
impl_function_identity_method,
impl_rc_conversions,
impl_shared_function_methods,
};
pub struct RcFunction<T, R> {
pub(super) function: Rc<dyn Fn(&T) -> R>,
pub(super) name: Option<String>,
}
impl<T, R> RcFunction<T, R> {
impl_function_common_methods!(
RcFunction<T, R>,
(Fn(&T) -> R + 'static),
|f| Rc::new(f)
);
impl_shared_function_methods!(
RcFunction<T, R>,
RcConditionalFunction,
into_rc,
Function,
'static
);
}
impl_function_constant_method!(RcFunction<T, R>, 'static);
impl_function_identity_method!(RcFunction<T, T>);
impl_function_clone!(RcFunction<T, R>);
impl_function_debug_display!(RcFunction<T, R>);
impl<T, R> Function<T, R> for RcFunction<T, R> {
fn apply(&self, t: &T) -> R {
(self.function)(t)
}
impl_rc_conversions!(
RcFunction<T, R>,
BoxFunction,
BoxFunctionOnce,
Fn(t: &T) -> R
);
}