2019-02-06 20:44:15 +01:00
|
|
|
#![allow(dead_code, unused_imports)]
|
|
|
|
|
2019-02-02 05:18:44 +01:00
|
|
|
use std::fmt;
|
|
|
|
|
2019-02-06 20:44:15 +01:00
|
|
|
use bytes::Bytes;
|
|
|
|
use futures::{Async, Poll, Stream};
|
|
|
|
use h2::RecvStream;
|
|
|
|
|
|
|
|
mod dispatcher;
|
2019-02-02 05:18:44 +01:00
|
|
|
mod service;
|
|
|
|
|
2019-03-07 07:56:34 +01:00
|
|
|
pub use self::dispatcher::Dispatcher;
|
2019-02-06 20:44:15 +01:00
|
|
|
pub use self::service::H2Service;
|
|
|
|
use crate::error::PayloadError;
|
|
|
|
|
|
|
|
/// H2 receive stream
|
|
|
|
pub struct Payload {
|
|
|
|
pl: RecvStream,
|
|
|
|
}
|
|
|
|
|
|
|
|
impl Payload {
|
|
|
|
pub(crate) fn new(pl: RecvStream) -> Self {
|
|
|
|
Self { pl }
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl Stream for Payload {
|
|
|
|
type Item = Bytes;
|
|
|
|
type Error = PayloadError;
|
|
|
|
|
|
|
|
fn poll(&mut self) -> Poll<Option<Self::Item>, Self::Error> {
|
|
|
|
match self.pl.poll() {
|
|
|
|
Ok(Async::Ready(Some(chunk))) => {
|
|
|
|
let len = chunk.len();
|
|
|
|
if let Err(err) = self.pl.release_capacity().release_capacity(len) {
|
|
|
|
Err(err.into())
|
|
|
|
} else {
|
|
|
|
Ok(Async::Ready(Some(chunk)))
|
|
|
|
}
|
|
|
|
}
|
|
|
|
Ok(Async::Ready(None)) => Ok(Async::Ready(None)),
|
|
|
|
Ok(Async::NotReady) => Ok(Async::NotReady),
|
2019-03-12 00:42:33 +01:00
|
|
|
Err(err) => {
|
|
|
|
println!("======== {:?}", err);
|
|
|
|
Err(err.into())
|
|
|
|
}
|
2019-02-06 20:44:15 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|