Files
aho_corasick
ansi_term
arrayvec
atty
backtrace
backtrace_sys
base64
bincode
bitflags
byteorder
bytes
c2_chacha
capnp
capnp_futures
capnp_rpc
cfg_if
chrono
format
naive
offset
clap
app
args
completions
crossbeam_deque
crossbeam_epoch
crossbeam_queue
crossbeam_utils
ctrlc
daemon
failure
failure_derive
flexi_logger
fnv
futures
future
sink
stream
and_then.rsbuffer_unordered.rsbuffered.rscatch_unwind.rschain.rschannel.rschunks.rscollect.rsconcat.rsempty.rsfilter.rsfilter_map.rsflatten.rsfold.rsfor_each.rsforward.rsfrom_err.rsfuse.rsfuture.rsfutures_ordered.rsfutures_unordered.rsinspect.rsinspect_err.rsiter.rsiter_ok.rsiter_result.rsmap.rsmap_err.rsmerge.rsmod.rsonce.rsor_else.rspeek.rspoll_fn.rsrepeat.rsselect.rsskip.rsskip_while.rssplit.rstake.rstake_while.rsthen.rsunfold.rswait.rszip.rs
sync
task_impl
unsync
getrandom
glob
hid_io
api
device
module
protocol
hidapi
install_service
iovec
lazy_static
libc
unix
lock_api
log
memchr
memoffset
mio
deprecated
net
sys
mio_uds
nanoid
net2
nix
net
sys
nodrop
num_cpus
num_integer
num_traits
open
parking_lot
parking_lot_core
pem
ppv_lite86
proc_macro2
quote
rand
distributions
weighted
rngs
seq
rand_chacha
rand_core
rand_hc
rand_isaac
rand_jitter
rand_os
rand_pcg
rand_xorshift
rcgen
regex
regex_syntax
ast
hir
unicode_tables
remove_dir_all
ring
aead
arithmetic
digest
ec
curve25519
suite_b
io
polyfill
rsa
rustc_demangle
rustls
client
msgs
server
scoped_tls
scopeguard
sct
serde
de
private
ser
slab
smallvec
spin
stream_cancel
strsim
syn
attr.rsbigint.rsbuffer.rscustom_keyword.rscustom_punctuation.rsdata.rsderive.rsdiscouraged.rserror.rsexport.rsexpr.rsext.rsfile.rsgenerics.rsgroup.rsident.rsitem.rslib.rslifetime.rslit.rslookahead.rsmac.rsmacros.rsop.rsparse.rsparse_macro_input.rsparse_quote.rspat.rspath.rsprint.rspunctuated.rssealed.rsspan.rsspanned.rsstmt.rsthread.rstoken.rstt.rsty.rs
synstructure
tempfile
textwrap
thread_local
time
tokio
codec
executor
reactor
runtime
util
tokio_codec
tokio_core
io
net
reactor
tokio_current_thread
tokio_executor
tokio_fs
tokio_io
_tokio_codec
codec
io
tokio_reactor
tokio_rustls
tokio_sync
tokio_tcp
tokio_threadpool
park
pool
task
worker
tokio_timer
clock
timer
wheel
tokio_udp
tokio_uds
unicode_width
unicode_xid
untrusted
vec_map
void
webpki
windows_service
x11
xcb
xkbcommon
yasna
>
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
use {Async, Poll}; use stream::{Stream, Fuse}; /// An adapter for merging the output of two streams. /// /// The merged stream produces items from one or both of the underlying /// streams as they become available. Errors, however, are not merged: you #[derive(Debug)] /// get at most one error at a time. #[must_use = "streams do nothing unless polled"] pub struct Zip<S1: Stream, S2: Stream> { stream1: Fuse<S1>, stream2: Fuse<S2>, queued1: Option<S1::Item>, queued2: Option<S2::Item>, } pub fn new<S1, S2>(stream1: S1, stream2: S2) -> Zip<S1, S2> where S1: Stream, S2: Stream<Error = S1::Error> { Zip { stream1: stream1.fuse(), stream2: stream2.fuse(), queued1: None, queued2: None, } } impl<S1, S2> Stream for Zip<S1, S2> where S1: Stream, S2: Stream<Error = S1::Error> { type Item = (S1::Item, S2::Item); type Error = S1::Error; fn poll(&mut self) -> Poll<Option<Self::Item>, Self::Error> { if self.queued1.is_none() { match self.stream1.poll()? { Async::Ready(Some(item1)) => self.queued1 = Some(item1), Async::Ready(None) | Async::NotReady => {} } } if self.queued2.is_none() { match self.stream2.poll()? { Async::Ready(Some(item2)) => self.queued2 = Some(item2), Async::Ready(None) | Async::NotReady => {} } } if self.queued1.is_some() && self.queued2.is_some() { let pair = (self.queued1.take().unwrap(), self.queued2.take().unwrap()); Ok(Async::Ready(Some(pair))) } else if self.stream1.is_done() || self.stream2.is_done() { Ok(Async::Ready(None)) } else { Ok(Async::NotReady) } } }