Make loop server iteration count more flexible than a chain

This commit is contained in:
Tangent 128 2018-03-30 02:54:02 -04:00
parent 00fc1fcb2a
commit f385371bb9

View file

@ -3,6 +3,7 @@ extern crate hyper;
extern crate lab_ebml; extern crate lab_ebml;
use futures::future::FutureResult; use futures::future::FutureResult;
use futures::stream::repeat;
use futures::stream::Stream; use futures::stream::Stream;
use lab_ebml::chunk::{Chunk, WebmStream, ChunkingError}; use lab_ebml::chunk::{Chunk, WebmStream, ChunkingError};
use lab_ebml::timecode_fixer::ChunkStream; use lab_ebml::timecode_fixer::ChunkStream;
@ -29,8 +30,10 @@ impl Service for WebmServer {
let response = match (req.method(), req.path()) { let response = match (req.method(), req.path()) {
(&Get, "/loop") => { (&Get, "/loop") => {
let stream: BodyStream<Vec<u8>> = Box::new( let stream: BodyStream<Vec<u8>> = Box::new(
parse_webm(SRC_FILE).into_iter().chunk_webm() repeat(()).take(10)
.chain(parse_webm(SRC_FILE).into_iter().chunk_webm()) .map(|()|
parse_webm(SRC_FILE).into_iter().chunk_webm()
).flatten()
.fix_timecodes() .fix_timecodes()
.map_err(|err| match err { .map_err(|err| match err {
ChunkingError::IoError(io_err) => hyper::Error::Io(io_err), ChunkingError::IoError(io_err) => hyper::Error::Io(io_err),