Files
adler32
backtrace
backtrace_sys
base64
bigtable
bitflags
byteorder
bytes
cfg_if
cookie
cookie_store
crc32fast
crossbeam_deque
crossbeam_epoch
crossbeam_queue
crossbeam_utils
curl
curl_sys
dtoa
either
encoding_rs
error_chain
failure
failure_derive
flate2
deflate
ffi
gz
zlib
fnv
foreign_types
foreign_types_shared
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
futures_cpupool
goauth
h2
codec
frame
hpack
proto
http
http_body
httparse
hyper
body
client
common
proto
server
service
hyper_tls
idna
indexmap
iovec
itoa
lazy_static
libc
unix
libz_sys
lock_api
log
matches
maybe_uninit
memoffset
mime
mime_guess
miniz_oxide
mio
deprecated
net
sys
native_tls
net2
num_cpus
num_traits
openssl
openssl_probe
openssl_sys
parking_lot
parking_lot_core
percent_encoding
proc_macro2
protobuf
codegen
reflect
well_known_types
protobuf_json
publicsuffix
quote
rand
distributions
prng
rngs
seq
rand_chacha
rand_core
rand_hc
rand_isaac
rand_jitter
rand_os
rand_pcg
rand_xorshift
regex
literal
regex_syntax
ast
hir
unicode_tables
reqwest
rustc_demangle
rustc_serialize
ryu
scopeguard
serde
de
private
ser
serde_codegen_internals
serde_derive
serde_json
serde_urlencoded
slab
smallvec
smpl_jwt
socket2
string
syn
attr.rsbigint.rsbuffer.rscustom_keyword.rscustom_punctuation.rsdata.rsderive.rsdiscouraged.rserror.rsexport.rsexpr.rsext.rsgenerics.rsgroup.rsident.rslib.rslifetime.rslit.rslookahead.rsmac.rsmacros.rsop.rsparse.rsparse_macro_input.rsparse_quote.rspath.rsprint.rspunctuated.rssealed.rsspan.rsspanned.rsthread.rstoken.rstt.rsty.rs
synom
synstructure
time
tokio
executor
reactor
runtime
util
tokio_buf
tokio_current_thread
tokio_executor
tokio_io
_tokio_codec
codec
io
tokio_reactor
tokio_sync
tokio_tcp
tokio_threadpool
blocking
park
pool
task
worker
tokio_timer
clock
timer
wheel
try_from
try_lock
unicase
unicode_bidi
unicode_normalization
unicode_xid
url
uuid
want
>
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 {Poll, Async, Future, AsyncSink}; use sink::Sink; /// Future for the `Sink::send` combinator, which sends a value to a sink and /// then waits until the sink has fully flushed. #[derive(Debug)] #[must_use = "futures do nothing unless polled"] pub struct Send<S: Sink> { sink: Option<S>, item: Option<S::SinkItem>, } pub fn new<S: Sink>(sink: S, item: S::SinkItem) -> Send<S> { Send { sink: Some(sink), item: Some(item), } } impl<S: Sink> Send<S> { /// Get a shared reference to the inner sink. pub fn get_ref(&self) -> &S { self.sink.as_ref().take().expect("Attempted Send::get_ref after completion") } /// Get a mutable reference to the inner sink. pub fn get_mut(&mut self) -> &mut S { self.sink.as_mut().take().expect("Attempted Send::get_mut after completion") } fn sink_mut(&mut self) -> &mut S { self.sink.as_mut().take().expect("Attempted to poll Send after completion") } fn take_sink(&mut self) -> S { self.sink.take().expect("Attempted to poll Send after completion") } } impl<S: Sink> Future for Send<S> { type Item = S; type Error = S::SinkError; fn poll(&mut self) -> Poll<S, S::SinkError> { if let Some(item) = self.item.take() { if let AsyncSink::NotReady(item) = self.sink_mut().start_send(item)? { self.item = Some(item); return Ok(Async::NotReady); } } // we're done sending the item, but want to block on flushing the // sink try_ready!(self.sink_mut().poll_complete()); // now everything's emptied, so return the sink for further use Ok(Async::Ready(self.take_sink())) } }