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
use std::marker::PhantomData;
use async_codec::{AsyncDecode, PollDec};
use async_codec::PollDec::{Done, Progress, Pending, Errored};
use futures_core::task::Context;
use futures_io::AsyncRead;
pub struct Map<R, D, F> {
dec: D,
f: F,
_r: PhantomData<R>,
}
impl<R, D, F> Map<R, D, F> {
pub fn new(dec: D, f: F) -> Map<R, D, F> {
Map {
dec,
f,
_r: PhantomData,
}
}
}
impl<R, D, F, U> AsyncDecode<R> for Map<R, D, F>
where R: AsyncRead,
D: AsyncDecode<R>,
F: FnOnce(D::Item) -> U
{
type Item = U;
type Error = D::Error;
fn poll_decode(mut self,
cx: &mut Context,
reader: &mut R)
-> PollDec<Self::Item, Self, Self::Error> {
match self.dec.poll_decode(cx, reader) {
Done(item, read) => Done((self.f)(item), read),
Progress(dec, read) => {
self.dec = dec;
Progress(self, read)
}
Pending(dec) => {
self.dec = dec;
Pending(self)
}
Errored(err) => Errored(err),
}
}
}