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
use async_codec::{AsyncEncode, AsyncEncodeLen};
use futures_core::{Future, Poll};
use futures_core::Async::{Ready, Pending};
use futures_core::task::Context;
use futures_io::{AsyncWrite, Error as FutIoErr};
pub struct Encoder<W, C> {
writer: Option<W>,
co: C,
written: usize,
}
impl<W, C> Encoder<W, C> {
pub fn new(writer: W, co: C) -> Encoder<W, C> {
Encoder {
writer: Some(writer),
co,
written: 0,
}
}
}
impl<W, C> Encoder<W, C>
where W: AsyncWrite,
C: AsyncEncodeLen<W>
{
pub fn remaining_bytes(&self) -> usize {
self.co.remaining_bytes()
}
}
impl<W, C> Future for Encoder<W, C>
where W: AsyncWrite,
C: AsyncEncode<W>
{
type Item = (W, usize);
type Error = (W, FutIoErr);
fn poll(&mut self, cx: &mut Context) -> Poll<Self::Item, Self::Error> {
let mut writer = self.writer
.take()
.expect("Polled future after completion");
match self.co.poll_encode(cx, &mut writer) {
Ok(Ready(0)) => Ok(Ready((writer, self.written))),
Ok(Ready(written)) => {
self.written += written;
self.writer = Some(writer);
self.poll(cx)
}
Ok(Pending) => {
self.writer = Some(writer);
Ok(Pending)
}
Err(err) => Err((writer, err)),
}
}
}