1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
use core::marker::PhantomData;
use super::IOLike;
use crate::prelude::*;
#[must_use = "IO is not evaluated until `IOLike.exec` invoked"]
pub struct Bind<F, A, B, IOA>(F, IOA, PhantomData<(A, B)>);
impl<F, A, B, IOA> Bind<F, A, B, IOA> {
pub fn new(f: F, ioa: IOA) -> Self {
Self(f, ioa, PhantomData)
}
}
impl<F, A, B, IOA> core::fmt::Debug for Bind<F, A, B, IOA>
where F: core::fmt::Debug,
IOA: core::fmt::Debug
{
fn fmt(&self, f: &mut core::fmt::Formatter<'_>) -> core::fmt::Result {
f.debug_tuple("Bind")
.field(&self.0)
.field(&self.1)
.field(&"PhantomData")
.finish()
}
}
impl<F, A, B, IOA> Clone for Bind<F, A, B, IOA>
where F: Clone,
IOA: Clone
{
fn clone(&self) -> Self {
Self(self.0.clone(), self.1.clone(), PhantomData)
}
}
impl<F, A, B, IOA> Copy for Bind<F, A, B, IOA>
where F: Copy,
IOA: Copy
{
}
impl<F, A, B, IOA> Equiv for Bind<F, A, B, IOA>
where F: F1Once<A>,
F::Ret: Equiv<To = IO<B>>,
IOA: Equiv<To = IO<A>>
{
type To = IO<B>;
}
impl<F, A, B, IOA> IOLike<B> for Bind<F, A, B, IOA>
where F: F1Once<A>,
F::Ret: Equiv<To = IO<B>> + IOLike<B>,
IOA: IOLike<A>
{
fn exec(self) -> B {
self.0.call1(self.1.exec()).exec()
}
}