select_of_equal_is_same
All checks were successful
buildbot/cargo fmt (1.72) Build done.
buildbot/cargo doc (1.72) Build done.
buildbot/cargo clippy (1.72) Build done.
buildbot/cargo test (1.65) Build done.
buildbot/cargo clippy (1.65) Build done.

This commit is contained in:
AF 2023-10-15 16:07:59 +00:00
parent d6f2c7a7fa
commit 4d668876eb
2 changed files with 20 additions and 0 deletions

View File

@ -57,6 +57,9 @@ pub fn applicative_follows_laws<'a, T: Applicative<'a> + FunctorTestSuite<'a>>()
res += tuple_can_be_expressed_via_la2::<T, _, _>(|| pa(2), || pb(2));
})
});
T::sample(|pa| {
res += select_of_equal_is_same::<T, _>(|| pa(2));
});
res
}

View File

@ -3,6 +3,7 @@ use std::{
ops::{Add, AddAssign},
};
use applicative_select::Selected;
use controlflow::IterativeWrapped;
use super::*;
@ -400,3 +401,19 @@ pub fn iterate_can_be_expressed_via_bind<
T::bind(fa0(), f0()),
)
}
pub fn select_of_equal_is_same<
'a,
T: Applicative<'a> + Eqr<'a>,
A: 'a + Send + Debug + PartialEq,
>(
fa0: impl 'a + Fn() -> T::F<A>,
) -> R {
T::eqr(
"select of equal",
T::fmap(T::select(fa0(), fa0()), |selected| match selected {
Selected::A(a, _) | Selected::B(_, a) => a,
}),
fa0(),
)
}