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 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76
use BufStream; use bytes::Buf; use futures::Poll; /// Limits the stream to a maximum amount of data. #[derive(Debug)] pub struct Limit<T> { stream: T, remaining: u64, } /// Errors returned from `Limit`. #[derive(Debug)] pub struct LimitError<T> { /// When `None`, limit was reached inner: Option<T>, } impl<T> Limit<T> { pub(crate) fn new(stream: T, amount: u64) -> Limit<T> { Limit { stream, remaining: amount, } } } impl<T> BufStream for Limit<T> where T: BufStream, { type Item = T::Item; type Error = LimitError<T::Error>; fn poll_buf(&mut self) -> Poll<Option<Self::Item>, Self::Error> { use futures::Async::Ready; if self.stream.size_hint().lower() > self.remaining { return Err(LimitError { inner: None }); } let res = self .stream .poll_buf() .map_err(|err| LimitError { inner: Some(err) }); match res { Ok(Ready(Some(ref buf))) => { if buf.remaining() as u64 > self.remaining { self.remaining = 0; return Err(LimitError { inner: None }); } self.remaining -= buf.remaining() as u64; } _ => {} } res } } // ===== impl LimitError ===== impl<T> LimitError<T> { /// Returns `true` if the error was caused by polling the stream. pub fn is_stream_err(&self) -> bool { self.inner.is_some() } /// Returns `true` if the stream reached its limit. pub fn is_limit_err(&self) -> bool { self.inner.is_none() } }