[INFO] crate swindon 0.7.8 is already in cache
[INFO] checking swindon-0.7.8 against master#bf1f2eedda4fa02b7c9347dd849ed73ddd43dedc for pr-70917
[INFO] extracting crate swindon 0.7.8 into /workspace/builds/worker-9/source
[INFO] validating manifest of crates.io crate swindon 0.7.8 on toolchain bf1f2eedda4fa02b7c9347dd849ed73ddd43dedc
[INFO] running `"/workspace/cargo-home/bin/cargo" "+bf1f2eedda4fa02b7c9347dd849ed73ddd43dedc" "read-manifest" "--manifest-path" "Cargo.toml"`
[INFO] started tweaking crates.io crate swindon 0.7.8
[INFO] finished tweaking crates.io crate swindon 0.7.8
[INFO] tweaked toml for crates.io crate swindon 0.7.8 written to /workspace/builds/worker-9/source/Cargo.toml
[INFO] running `"/workspace/cargo-home/bin/cargo" "+bf1f2eedda4fa02b7c9347dd849ed73ddd43dedc" "generate-lockfile" "--manifest-path" "Cargo.toml" "-Zno-index-update"`
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] running `"/workspace/cargo-home/bin/cargo" "+bf1f2eedda4fa02b7c9347dd849ed73ddd43dedc" "fetch" "--locked" "--manifest-path" "Cargo.toml"`
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] running `"docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-9/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-9/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "MAP_USER_ID=0" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--network" "none" "rustops/crates-build-env" "/opt/rustwide/cargo-home/bin/cargo" "+bf1f2eedda4fa02b7c9347dd849ed73ddd43dedc" "check" "--frozen" "--all" "--all-targets"`
[INFO] [stderr] WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap.
[INFO] [stdout] 18798c8185ada1f27a68cb8c2a9de505de67da0f081f87f1f94d83190cd52c90
[INFO] running `"docker" "start" "-a" "18798c8185ada1f27a68cb8c2a9de505de67da0f081f87f1f94d83190cd52c90"`
[INFO] [stderr]     Checking netbuf v0.4.1
[INFO] [stderr]     Checking sha1 v0.4.0
[INFO] [stderr]     Checking atomic v0.3.4
[INFO] [stderr]     Checking string-intern v0.1.7
[INFO] [stderr]     Checking serde_json v1.0.51
[INFO] [stderr]     Checking humannum v0.1.0
[INFO] [stderr]     Checking self-meter v0.6.0
[INFO] [stderr]     Checking digest-writer v0.3.1
[INFO] [stderr]     Checking blake2 v0.7.1
[INFO] [stderr]     Checking tk-listen v0.1.1
[INFO] [stderr]     Checking ns-router v0.1.6
[INFO] [stderr]     Checking tk-pool v0.5.3
[INFO] [stderr]     Checking tk-bufstream v0.3.0
[INFO] [stderr]     Checking http-file-headers v0.1.8
[INFO] [stderr]     Checking quire v0.3.1
[INFO] [stderr]     Checking tk-http v0.3.9
[INFO] [stderr]     Checking libcantal v0.3.2
[INFO] [stderr]     Checking trimmer v0.3.6
[INFO] [stderr]     Checking httpbin v0.3.3
[INFO] [stderr]     Checking self-meter-http v0.4.1
[INFO] [stderr]     Checking swindon v0.7.8 (/opt/rustwide/workdir)
[INFO] [stderr] warning: unnecessary parentheses around function argument
[INFO] [stderr]    --> src/chat/backend.rs:310:12
[INFO] [stderr]     |
[INFO] [stderr] 310 |         Ok((Async::Ready(data.len())))
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^ help: remove these parentheses
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_parens)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around function argument
[INFO] [stderr]    --> src/chat/backend.rs:412:12
[INFO] [stderr]     |
[INFO] [stderr] 412 |         Ok((Async::Ready(data.len())))
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^ help: remove these parentheses
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around function argument
[INFO] [stderr]    --> src/chat/backend.rs:450:12
[INFO] [stderr]     |
[INFO] [stderr] 450 |         Ok((Async::Ready(data.len())))
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^ help: remove these parentheses
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around function argument
[INFO] [stderr]    --> src/chat/backend.rs:310:12
[INFO] [stderr]     |
[INFO] [stderr] 310 |         Ok((Async::Ready(data.len())))
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^ help: remove these parentheses
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_parens)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around function argument
[INFO] [stderr]    --> src/chat/backend.rs:412:12
[INFO] [stderr]     |
[INFO] [stderr] 412 |         Ok((Async::Ready(data.len())))
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^ help: remove these parentheses
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around function argument
[INFO] [stderr]    --> src/chat/backend.rs:450:12
[INFO] [stderr]     |
[INFO] [stderr] 450 |         Ok((Async::Ready(data.len())))
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^ help: remove these parentheses
[INFO] [stderr] 
[INFO] [stderr] warning: `...` range patterns are deprecated
[INFO] [stderr]   --> src/handlers/files/decode.rs:24:13
[INFO] [stderr]    |
[INFO] [stderr] 24 |         b'0'...b'9' => Ok(b & 0x0f),
[INFO] [stderr]    |             ^^^ help: use `..=` for an inclusive range
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(ellipsis_inclusive_range_patterns)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: `...` range patterns are deprecated
[INFO] [stderr]   --> src/handlers/files/decode.rs:25:13
[INFO] [stderr]    |
[INFO] [stderr] 25 |         b'a'...b'f' | b'A'...b'F' => Ok((b & 0x0f) + 9),
[INFO] [stderr]    |             ^^^ help: use `..=` for an inclusive range
[INFO] [stderr] 
[INFO] [stderr] warning: `...` range patterns are deprecated
[INFO] [stderr]   --> src/handlers/files/decode.rs:25:27
[INFO] [stderr]    |
[INFO] [stderr] 25 |         b'a'...b'f' | b'A'...b'F' => Ok((b & 0x0f) + 9),
[INFO] [stderr]    |                           ^^^ help: use `..=` for an inclusive range
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/handlers/self_status.rs:29:39
[INFO] [stderr]    |
[INFO] [stderr] 29 |             metrics: Json<'a, Vec<Box<Collection>>>,
[INFO] [stderr]    |                                       ^^^^^^^^^^ help: use `dyn`: `dyn Collection`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(bare_trait_objects)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: `...` range patterns are deprecated
[INFO] [stderr]   --> src/handlers/files/decode.rs:24:13
[INFO] [stderr]    |
[INFO] [stderr] 24 |         b'0'...b'9' => Ok(b & 0x0f),
[INFO] [stderr]    |             ^^^ help: use `..=` for an inclusive range
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(ellipsis_inclusive_range_patterns)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/http_pools.rs:51:9
[INFO] [stderr]    |
[INFO] [stderr] 51 |     Box<Codec<TcpStream, Future=HttpFuture<TcpStream>>+Send>,
[INFO] [stderr]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Codec<TcpStream, Future=HttpFuture<TcpStream>>+Send`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> src/http_pools.rs:127:36
[INFO] [stderr]     |
[INFO] [stderr] 127 |     fn visit<'x>(&'x self, v: &mut Visitor<'x>) {
[INFO] [stderr]     |                                    ^^^^^^^^^^^ help: use `dyn`: `dyn Visitor<'x>`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/incoming/mod.rs:15:27
[INFO] [stderr]    |
[INFO] [stderr] 15 | pub type Request<S> = Box<Codec<S, ResponseFuture=Reply<S>>>;
[INFO] [stderr]    |                           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Codec<S, ResponseFuture=Reply<S>>`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/incoming/mod.rs:16:25
[INFO] [stderr]    |
[INFO] [stderr] 16 | pub type Reply<S> = Box<Future<Item=EncoderDone<S>, Error=Error>>;
[INFO] [stderr]    |                         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future<Item=EncoderDone<S>, Error=Error>`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/metrics.rs:10:48
[INFO] [stderr]    |
[INFO] [stderr] 10 | pub type List = Vec<(Metric<'static>, &'static Value)>;
[INFO] [stderr]    |                                                ^^^^^ help: use `dyn`: `dyn Value`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/metrics.rs:17:54
[INFO] [stderr]    |
[INFO] [stderr] 17 | pub struct ActiveCollection(OwningHandle<Box<Vec<Box<Collection>>>, Wrapper>);
[INFO] [stderr]    |                                                      ^^^^^^^^^^ help: use `dyn`: `dyn Collection`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/metrics.rs:27:29
[INFO] [stderr]    |
[INFO] [stderr] 27 |     fn visit(&self, s: &mut NameVisitor) {
[INFO] [stderr]    |                             ^^^^^^^^^^^ help: use `dyn`: `dyn NameVisitor`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/metrics.rs:38:51
[INFO] [stderr]    |
[INFO] [stderr] 38 | pub fn all(runtime: &Arc<Runtime>) -> Box<Vec<Box<Collection>>> {
[INFO] [stderr]    |                                                   ^^^^^^^^^^ help: use `dyn`: `dyn Collection`
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around function argument
[INFO] [stderr]   --> src/proxy/backend.rs:75:12
[INFO] [stderr]    |
[INFO] [stderr] 75 |         Ok((Async::Ready(data.len())))
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^^^^^^^^^^^^ help: remove these parentheses
[INFO] [stderr] 
[INFO] [stderr] warning: `...` range patterns are deprecated
[INFO] [stderr]   --> src/handlers/files/decode.rs:25:13
[INFO] [stderr]    |
[INFO] [stderr] 25 |         b'a'...b'f' | b'A'...b'F' => Ok((b & 0x0f) + 9),
[INFO] [stderr]    |             ^^^ help: use `..=` for an inclusive range
[INFO] [stderr] 
[INFO] [stderr] warning: `...` range patterns are deprecated
[INFO] [stderr]   --> src/handlers/files/decode.rs:25:27
[INFO] [stderr]    |
[INFO] [stderr] 25 |         b'a'...b'f' | b'A'...b'F' => Ok((b & 0x0f) + 9),
[INFO] [stderr]    |                           ^^^ help: use `..=` for an inclusive range
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/handlers/self_status.rs:29:39
[INFO] [stderr]    |
[INFO] [stderr] 29 |             metrics: Json<'a, Vec<Box<Collection>>>,
[INFO] [stderr]    |                                       ^^^^^^^^^^ help: use `dyn`: `dyn Collection`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(bare_trait_objects)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/http_pools.rs:51:9
[INFO] [stderr]    |
[INFO] [stderr] 51 |     Box<Codec<TcpStream, Future=HttpFuture<TcpStream>>+Send>,
[INFO] [stderr]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Codec<TcpStream, Future=HttpFuture<TcpStream>>+Send`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> src/http_pools.rs:127:36
[INFO] [stderr]     |
[INFO] [stderr] 127 |     fn visit<'x>(&'x self, v: &mut Visitor<'x>) {
[INFO] [stderr]     |                                    ^^^^^^^^^^^ help: use `dyn`: `dyn Visitor<'x>`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/incoming/mod.rs:15:27
[INFO] [stderr]    |
[INFO] [stderr] 15 | pub type Request<S> = Box<Codec<S, ResponseFuture=Reply<S>>>;
[INFO] [stderr]    |                           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Codec<S, ResponseFuture=Reply<S>>`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/incoming/mod.rs:16:25
[INFO] [stderr]    |
[INFO] [stderr] 16 | pub type Reply<S> = Box<Future<Item=EncoderDone<S>, Error=Error>>;
[INFO] [stderr]    |                         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future<Item=EncoderDone<S>, Error=Error>`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/metrics.rs:10:48
[INFO] [stderr]    |
[INFO] [stderr] 10 | pub type List = Vec<(Metric<'static>, &'static Value)>;
[INFO] [stderr]    |                                                ^^^^^ help: use `dyn`: `dyn Value`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/metrics.rs:17:54
[INFO] [stderr]    |
[INFO] [stderr] 17 | pub struct ActiveCollection(OwningHandle<Box<Vec<Box<Collection>>>, Wrapper>);
[INFO] [stderr]    |                                                      ^^^^^^^^^^ help: use `dyn`: `dyn Collection`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/metrics.rs:27:29
[INFO] [stderr]    |
[INFO] [stderr] 27 |     fn visit(&self, s: &mut NameVisitor) {
[INFO] [stderr]    |                             ^^^^^^^^^^^ help: use `dyn`: `dyn NameVisitor`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/metrics.rs:38:51
[INFO] [stderr]    |
[INFO] [stderr] 38 | pub fn all(runtime: &Arc<Runtime>) -> Box<Vec<Box<Collection>>> {
[INFO] [stderr]    |                                                   ^^^^^^^^^^ help: use `dyn`: `dyn Collection`
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around function argument
[INFO] [stderr]   --> src/proxy/backend.rs:75:12
[INFO] [stderr]    |
[INFO] [stderr] 75 |         Ok((Async::Ready(data.len())))
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^^^^^^^^^^^^ help: remove these parentheses
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated item 'std::sync::atomic::ATOMIC_USIZE_INIT': the `new` function is now preferred
[INFO] [stderr]   --> src/chat/cid.rs:20:46
[INFO] [stderr]    |
[INFO] [stderr] 20 |         use std::sync::atomic::{AtomicUsize, ATOMIC_USIZE_INIT, Ordering};
[INFO] [stderr]    |                                              ^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(deprecated)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated item 'std::sync::atomic::ATOMIC_USIZE_INIT': the `new` function is now preferred
[INFO] [stderr]   --> src/chat/cid.rs:21:39
[INFO] [stderr]    |
[INFO] [stderr] 21 |         static COUNTER: AtomicUsize = ATOMIC_USIZE_INIT;
[INFO] [stderr]    |                                       ^^^^^^^^^^^^^^^^^ help: replace the use of the deprecated item: `AtomicUsize::new(0)`
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated item 'std::sync::atomic::ATOMIC_USIZE_INIT': the `new` function is now preferred
[INFO] [stderr]   --> src/chat/cid.rs:20:46
[INFO] [stderr]    |
[INFO] [stderr] 20 |         use std::sync::atomic::{AtomicUsize, ATOMIC_USIZE_INIT, Ordering};
[INFO] [stderr]    |                                              ^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(deprecated)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated item 'std::sync::atomic::ATOMIC_USIZE_INIT': the `new` function is now preferred
[INFO] [stderr]   --> src/chat/cid.rs:21:39
[INFO] [stderr]    |
[INFO] [stderr] 21 |         static COUNTER: AtomicUsize = ATOMIC_USIZE_INIT;
[INFO] [stderr]    |                                       ^^^^^^^^^^^^^^^^^ help: replace the use of the deprecated item: `AtomicUsize::new(0)`
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around function argument
[INFO] [stderr]    --> src/chat/backend.rs:310:12
[INFO] [stderr]     |
[INFO] [stderr] 310 |         Ok((Async::Ready(data.len())))
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^ help: remove these parentheses
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_parens)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around function argument
[INFO] [stderr]    --> src/chat/backend.rs:412:12
[INFO] [stderr]     |
[INFO] [stderr] 412 |         Ok((Async::Ready(data.len())))
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^ help: remove these parentheses
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around function argument
[INFO] [stderr]    --> src/chat/backend.rs:450:12
[INFO] [stderr]     |
[INFO] [stderr] 450 |         Ok((Async::Ready(data.len())))
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^ help: remove these parentheses
[INFO] [stderr] 
[INFO] [stderr] warning: `...` range patterns are deprecated
[INFO] [stderr]   --> src/handlers/files/decode.rs:24:13
[INFO] [stderr]    |
[INFO] [stderr] 24 |         b'0'...b'9' => Ok(b & 0x0f),
[INFO] [stderr]    |             ^^^ help: use `..=` for an inclusive range
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(ellipsis_inclusive_range_patterns)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: `...` range patterns are deprecated
[INFO] [stderr]   --> src/handlers/files/decode.rs:25:13
[INFO] [stderr]    |
[INFO] [stderr] 25 |         b'a'...b'f' | b'A'...b'F' => Ok((b & 0x0f) + 9),
[INFO] [stderr]    |             ^^^ help: use `..=` for an inclusive range
[INFO] [stderr] 
[INFO] [stderr] warning: `...` range patterns are deprecated
[INFO] [stderr]   --> src/handlers/files/decode.rs:25:27
[INFO] [stderr]    |
[INFO] [stderr] 25 |         b'a'...b'f' | b'A'...b'F' => Ok((b & 0x0f) + 9),
[INFO] [stderr]    |                           ^^^ help: use `..=` for an inclusive range
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/handlers/self_status.rs:29:39
[INFO] [stderr]    |
[INFO] [stderr] 29 |             metrics: Json<'a, Vec<Box<Collection>>>,
[INFO] [stderr]    |                                       ^^^^^^^^^^ help: use `dyn`: `dyn Collection`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(bare_trait_objects)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/http_pools.rs:51:9
[INFO] [stderr]    |
[INFO] [stderr] 51 |     Box<Codec<TcpStream, Future=HttpFuture<TcpStream>>+Send>,
[INFO] [stderr]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Codec<TcpStream, Future=HttpFuture<TcpStream>>+Send`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> src/http_pools.rs:127:36
[INFO] [stderr]     |
[INFO] [stderr] 127 |     fn visit<'x>(&'x self, v: &mut Visitor<'x>) {
[INFO] [stderr]     |                                    ^^^^^^^^^^^ help: use `dyn`: `dyn Visitor<'x>`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/incoming/mod.rs:15:27
[INFO] [stderr]    |
[INFO] [stderr] 15 | pub type Request<S> = Box<Codec<S, ResponseFuture=Reply<S>>>;
[INFO] [stderr]    |                           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Codec<S, ResponseFuture=Reply<S>>`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/incoming/mod.rs:16:25
[INFO] [stderr]    |
[INFO] [stderr] 16 | pub type Reply<S> = Box<Future<Item=EncoderDone<S>, Error=Error>>;
[INFO] [stderr]    |                         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future<Item=EncoderDone<S>, Error=Error>`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/metrics.rs:10:48
[INFO] [stderr]    |
[INFO] [stderr] 10 | pub type List = Vec<(Metric<'static>, &'static Value)>;
[INFO] [stderr]    |                                                ^^^^^ help: use `dyn`: `dyn Value`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/metrics.rs:17:54
[INFO] [stderr]    |
[INFO] [stderr] 17 | pub struct ActiveCollection(OwningHandle<Box<Vec<Box<Collection>>>, Wrapper>);
[INFO] [stderr]    |                                                      ^^^^^^^^^^ help: use `dyn`: `dyn Collection`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/metrics.rs:27:29
[INFO] [stderr]    |
[INFO] [stderr] 27 |     fn visit(&self, s: &mut NameVisitor) {
[INFO] [stderr]    |                             ^^^^^^^^^^^ help: use `dyn`: `dyn NameVisitor`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/metrics.rs:38:51
[INFO] [stderr]    |
[INFO] [stderr] 38 | pub fn all(runtime: &Arc<Runtime>) -> Box<Vec<Box<Collection>>> {
[INFO] [stderr]    |                                                   ^^^^^^^^^^ help: use `dyn`: `dyn Collection`
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around function argument
[INFO] [stderr]   --> src/proxy/backend.rs:75:12
[INFO] [stderr]    |
[INFO] [stderr] 75 |         Ok((Async::Ready(data.len())))
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^^^^^^^^^^^^ help: remove these parentheses
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around function argument
[INFO] [stderr]    --> src/chat/backend.rs:310:12
[INFO] [stderr]     |
[INFO] [stderr] 310 |         Ok((Async::Ready(data.len())))
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^ help: remove these parentheses
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_parens)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around function argument
[INFO] [stderr]    --> src/chat/backend.rs:412:12
[INFO] [stderr]     |
[INFO] [stderr] 412 |         Ok((Async::Ready(data.len())))
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^ help: remove these parentheses
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around function argument
[INFO] [stderr]    --> src/chat/backend.rs:450:12
[INFO] [stderr]     |
[INFO] [stderr] 450 |         Ok((Async::Ready(data.len())))
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^ help: remove these parentheses
[INFO] [stderr] 
[INFO] [stderr] warning: `...` range patterns are deprecated
[INFO] [stderr]   --> src/handlers/files/decode.rs:24:13
[INFO] [stderr]    |
[INFO] [stderr] 24 |         b'0'...b'9' => Ok(b & 0x0f),
[INFO] [stderr]    |             ^^^ help: use `..=` for an inclusive range
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(ellipsis_inclusive_range_patterns)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: `...` range patterns are deprecated
[INFO] [stderr]   --> src/handlers/files/decode.rs:25:13
[INFO] [stderr]    |
[INFO] [stderr] 25 |         b'a'...b'f' | b'A'...b'F' => Ok((b & 0x0f) + 9),
[INFO] [stderr]    |             ^^^ help: use `..=` for an inclusive range
[INFO] [stderr] 
[INFO] [stderr] warning: `...` range patterns are deprecated
[INFO] [stderr]   --> src/handlers/files/decode.rs:25:27
[INFO] [stderr]    |
[INFO] [stderr] 25 |         b'a'...b'f' | b'A'...b'F' => Ok((b & 0x0f) + 9),
[INFO] [stderr]    |                           ^^^ help: use `..=` for an inclusive range
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/handlers/self_status.rs:29:39
[INFO] [stderr]    |
[INFO] [stderr] 29 |             metrics: Json<'a, Vec<Box<Collection>>>,
[INFO] [stderr]    |                                       ^^^^^^^^^^ help: use `dyn`: `dyn Collection`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(bare_trait_objects)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/http_pools.rs:51:9
[INFO] [stderr]    |
[INFO] [stderr] 51 |     Box<Codec<TcpStream, Future=HttpFuture<TcpStream>>+Send>,
[INFO] [stderr]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Codec<TcpStream, Future=HttpFuture<TcpStream>>+Send`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]    --> src/http_pools.rs:127:36
[INFO] [stderr]     |
[INFO] [stderr] 127 |     fn visit<'x>(&'x self, v: &mut Visitor<'x>) {
[INFO] [stderr]     |                                    ^^^^^^^^^^^ help: use `dyn`: `dyn Visitor<'x>`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/incoming/mod.rs:15:27
[INFO] [stderr]    |
[INFO] [stderr] 15 | pub type Request<S> = Box<Codec<S, ResponseFuture=Reply<S>>>;
[INFO] [stderr]    |                           ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Codec<S, ResponseFuture=Reply<S>>`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/incoming/mod.rs:16:25
[INFO] [stderr]    |
[INFO] [stderr] 16 | pub type Reply<S> = Box<Future<Item=EncoderDone<S>, Error=Error>>;
[INFO] [stderr]    |                         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use `dyn`: `dyn Future<Item=EncoderDone<S>, Error=Error>`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/metrics.rs:10:48
[INFO] [stderr]    |
[INFO] [stderr] 10 | pub type List = Vec<(Metric<'static>, &'static Value)>;
[INFO] [stderr]    |                                                ^^^^^ help: use `dyn`: `dyn Value`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/metrics.rs:17:54
[INFO] [stderr]    |
[INFO] [stderr] 17 | pub struct ActiveCollection(OwningHandle<Box<Vec<Box<Collection>>>, Wrapper>);
[INFO] [stderr]    |                                                      ^^^^^^^^^^ help: use `dyn`: `dyn Collection`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/metrics.rs:27:29
[INFO] [stderr]    |
[INFO] [stderr] 27 |     fn visit(&self, s: &mut NameVisitor) {
[INFO] [stderr]    |                             ^^^^^^^^^^^ help: use `dyn`: `dyn NameVisitor`
[INFO] [stderr] 
[INFO] [stderr] warning: trait objects without an explicit `dyn` are deprecated
[INFO] [stderr]   --> src/metrics.rs:38:51
[INFO] [stderr]    |
[INFO] [stderr] 38 | pub fn all(runtime: &Arc<Runtime>) -> Box<Vec<Box<Collection>>> {
[INFO] [stderr]    |                                                   ^^^^^^^^^^ help: use `dyn`: `dyn Collection`
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around function argument
[INFO] [stderr]   --> src/proxy/backend.rs:75:12
[INFO] [stderr]    |
[INFO] [stderr] 75 |         Ok((Async::Ready(data.len())))
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^^^^^^^^^^^^ help: remove these parentheses
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated item 'std::sync::atomic::ATOMIC_USIZE_INIT': the `new` function is now preferred
[INFO] [stderr]   --> src/chat/cid.rs:20:46
[INFO] [stderr]    |
[INFO] [stderr] 20 |         use std::sync::atomic::{AtomicUsize, ATOMIC_USIZE_INIT, Ordering};
[INFO] [stderr]    |                                              ^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(deprecated)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated item 'std::sync::atomic::ATOMIC_USIZE_INIT': the `new` function is now preferred
[INFO] [stderr]   --> src/chat/cid.rs:21:39
[INFO] [stderr]    |
[INFO] [stderr] 21 |         static COUNTER: AtomicUsize = ATOMIC_USIZE_INIT;
[INFO] [stderr]    |                                       ^^^^^^^^^^^^^^^^^ help: replace the use of the deprecated item: `AtomicUsize::new(0)`
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated item 'std::sync::atomic::ATOMIC_USIZE_INIT': the `new` function is now preferred
[INFO] [stderr]   --> src/chat/cid.rs:20:46
[INFO] [stderr]    |
[INFO] [stderr] 20 |         use std::sync::atomic::{AtomicUsize, ATOMIC_USIZE_INIT, Ordering};
[INFO] [stderr]    |                                              ^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(deprecated)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated item 'std::sync::atomic::ATOMIC_USIZE_INIT': the `new` function is now preferred
[INFO] [stderr]   --> src/chat/cid.rs:21:39
[INFO] [stderr]    |
[INFO] [stderr] 21 |         static COUNTER: AtomicUsize = ATOMIC_USIZE_INIT;
[INFO] [stderr]    |                                       ^^^^^^^^^^^^^^^^^ help: replace the use of the deprecated item: `AtomicUsize::new(0)`
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated item 'core::str::<impl str>::trim_right_matches': superseded by `trim_end_matches`
[INFO] [stderr]   --> src/handlers/files/index.rs:63:30
[INFO] [stderr]    |
[INFO] [stderr] 63 |     let vpath = virtual_path.trim_right_matches('/');
[INFO] [stderr]    |                              ^^^^^^^^^^^^^^^^^^ help: replace the use of the deprecated item: `trim_end_matches`
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated item 'core::str::<impl str>::trim_right_matches': superseded by `trim_end_matches`
[INFO] [stderr]   --> src/handlers/files/index.rs:63:30
[INFO] [stderr]    |
[INFO] [stderr] 63 |     let vpath = virtual_path.trim_right_matches('/');
[INFO] [stderr]    |                              ^^^^^^^^^^^^^^^^^^ help: replace the use of the deprecated item: `trim_end_matches`
[INFO] [stderr] 
[INFO] [stderr] error[E0382]: assign to part of moved value: `session`
[INFO] [stderr]    --> src/chat/processor/pool.rs:180:13
[INFO] [stderr]     |
[INFO] [stderr] 175 |             let mut session = Session::new();
[INFO] [stderr]     |                 ----------- move occurs because `session` has type `chat::processor::session::Session`, which does not implement the `Copy` trait
[INFO] [stderr] ...
[INFO] [stderr] 179 |             self.sessions.active.insert(session_id.clone(), expire, session);
[INFO] [stderr]     |                                                                     ------- value moved here
[INFO] [stderr] 180 |             session.status_timestamp = now;
[INFO] [stderr]     |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ value partially assigned here after move
[INFO] [stderr] 
[INFO] [stderr] error[E0382]: assign to part of moved value: `sess`
[INFO] [stderr]    --> src/chat/processor/pool.rs:295:17
[INFO] [stderr]     |
[INFO] [stderr] 292 |                 let mut sess = Session::new();
[INFO] [stderr]     |                     -------- move occurs because `sess` has type `chat::processor::session::Session`, which does not implement the `Copy` trait
[INFO] [stderr] 293 |                 self.sessions.active.insert(
[INFO] [stderr] 294 |                     sess_id.clone(), activity_ts, sess);
[INFO] [stderr]     |                                                   ---- value moved here
[INFO] [stderr] 295 |                 sess.status_timestamp = now;
[INFO] [stderr]     |                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^ value partially assigned here after move
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated item 'core::str::<impl str>::trim_right_matches': superseded by `trim_end_matches`
[INFO] [stderr]   --> src/handlers/files/index.rs:63:30
[INFO] [stderr]    |
[INFO] [stderr] 63 |     let vpath = virtual_path.trim_right_matches('/');
[INFO] [stderr]    |                              ^^^^^^^^^^^^^^^^^^ help: replace the use of the deprecated item: `trim_end_matches`
[INFO] [stderr] 
[INFO] [stderr] error[E0382]: assign to part of moved value: `session`
[INFO] [stderr]    --> src/chat/processor/pool.rs:180:13
[INFO] [stderr]     |
[INFO] [stderr] 175 |             let mut session = Session::new();
[INFO] [stderr]     |                 ----------- move occurs because `session` has type `chat::processor::session::Session`, which does not implement the `Copy` trait
[INFO] [stderr] ...
[INFO] [stderr] 179 |             self.sessions.active.insert(session_id.clone(), expire, session);
[INFO] [stderr]     |                                                                     ------- value moved here
[INFO] [stderr] 180 |             session.status_timestamp = now;
[INFO] [stderr]     |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ value partially assigned here after move
[INFO] [stderr] 
[INFO] [stderr] error[E0382]: assign to part of moved value: `sess`
[INFO] [stderr]    --> src/chat/processor/pool.rs:295:17
[INFO] [stderr]     |
[INFO] [stderr] 292 |                 let mut sess = Session::new();
[INFO] [stderr]     |                     -------- move occurs because `sess` has type `chat::processor::session::Session`, which does not implement the `Copy` trait
[INFO] [stderr] 293 |                 self.sessions.active.insert(
[INFO] [stderr] 294 |                     sess_id.clone(), activity_ts, sess);
[INFO] [stderr]     |                                                   ---- value moved here
[INFO] [stderr] 295 |                 sess.status_timestamp = now;
[INFO] [stderr]     |                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^ value partially assigned here after move
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated item 'core::str::<impl str>::trim_right_matches': superseded by `trim_end_matches`
[INFO] [stderr]   --> src/handlers/files/index.rs:63:30
[INFO] [stderr]    |
[INFO] [stderr] 63 |     let vpath = virtual_path.trim_right_matches('/');
[INFO] [stderr]    |                              ^^^^^^^^^^^^^^^^^^ help: replace the use of the deprecated item: `trim_end_matches`
[INFO] [stderr] 
[INFO] [stderr] error: aborting due to 2 previous errors
[INFO] [stderr] 
[INFO] [stderr] For more information about this error, try `rustc --explain E0382`.
[INFO] [stderr] error: could not compile `swindon`.
[INFO] [stderr] 
[INFO] [stderr] To learn more, run the command again with --verbose.
[INFO] [stderr] warning: build failed, waiting for other jobs to finish...
[INFO] [stderr] error[E0382]: assign to part of moved value: `session`
[INFO] [stderr]    --> src/chat/processor/pool.rs:180:13
[INFO] [stderr]     |
[INFO] [stderr] 175 |             let mut session = Session::new();
[INFO] [stderr]     |                 ----------- move occurs because `session` has type `chat::processor::session::Session`, which does not implement the `Copy` trait
[INFO] [stderr] ...
[INFO] [stderr] 179 |             self.sessions.active.insert(session_id.clone(), expire, session);
[INFO] [stderr]     |                                                                     ------- value moved here
[INFO] [stderr] 180 |             session.status_timestamp = now;
[INFO] [stderr]     |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ value partially assigned here after move
[INFO] [stderr] 
[INFO] [stderr] error[E0382]: assign to part of moved value: `sess`
[INFO] [stderr]    --> src/chat/processor/pool.rs:295:17
[INFO] [stderr]     |
[INFO] [stderr] 292 |                 let mut sess = Session::new();
[INFO] [stderr]     |                     -------- move occurs because `sess` has type `chat::processor::session::Session`, which does not implement the `Copy` trait
[INFO] [stderr] 293 |                 self.sessions.active.insert(
[INFO] [stderr] 294 |                     sess_id.clone(), activity_ts, sess);
[INFO] [stderr]     |                                                   ---- value moved here
[INFO] [stderr] 295 |                 sess.status_timestamp = now;
[INFO] [stderr]     |                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^ value partially assigned here after move
[INFO] [stderr] 
[INFO] [stderr] error[E0382]: assign to part of moved value: `session`
[INFO] [stderr]    --> src/chat/processor/pool.rs:180:13
[INFO] [stderr]     |
[INFO] [stderr] 175 |             let mut session = Session::new();
[INFO] [stderr]     |                 ----------- move occurs because `session` has type `chat::processor::session::Session`, which does not implement the `Copy` trait
[INFO] [stderr] ...
[INFO] [stderr] 179 |             self.sessions.active.insert(session_id.clone(), expire, session);
[INFO] [stderr]     |                                                                     ------- value moved here
[INFO] [stderr] 180 |             session.status_timestamp = now;
[INFO] [stderr]     |             ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ value partially assigned here after move
[INFO] [stderr] 
[INFO] [stderr] error[E0382]: assign to part of moved value: `sess`
[INFO] [stderr]    --> src/chat/processor/pool.rs:295:17
[INFO] [stderr]     |
[INFO] [stderr] 292 |                 let mut sess = Session::new();
[INFO] [stderr]     |                     -------- move occurs because `sess` has type `chat::processor::session::Session`, which does not implement the `Copy` trait
[INFO] [stderr] 293 |                 self.sessions.active.insert(
[INFO] [stderr] 294 |                     sess_id.clone(), activity_ts, sess);
[INFO] [stderr]     |                                                   ---- value moved here
[INFO] [stderr] 295 |                 sess.status_timestamp = now;
[INFO] [stderr]     |                 ^^^^^^^^^^^^^^^^^^^^^^^^^^^ value partially assigned here after move
[INFO] [stderr] 
[INFO] [stderr] error: aborting due to 2 previous errors
[INFO] [stderr] 
[INFO] [stderr] For more information about this error, try `rustc --explain E0382`.
[INFO] [stderr] error: could not compile `swindon`.
[INFO] [stderr] 
[INFO] [stderr] To learn more, run the command again with --verbose.
[INFO] [stderr] warning: build failed, waiting for other jobs to finish...
[INFO] [stderr] error: aborting due to 2 previous errors
[INFO] [stderr] 
[INFO] [stderr] For more information about this error, try `rustc --explain E0382`.
[INFO] [stderr] error: could not compile `swindon`.
[INFO] [stderr] 
[INFO] [stderr] To learn more, run the command again with --verbose.
[INFO] [stderr] warning: build failed, waiting for other jobs to finish...
[INFO] [stderr] error: aborting due to 2 previous errors
[INFO] [stderr] 
[INFO] [stderr] For more information about this error, try `rustc --explain E0382`.
[INFO] [stderr] error: could not compile `swindon`.
[INFO] [stderr] 
[INFO] [stderr] To learn more, run the command again with --verbose.
[INFO] running `"docker" "inspect" "18798c8185ada1f27a68cb8c2a9de505de67da0f081f87f1f94d83190cd52c90"`
[INFO] running `"docker" "rm" "-f" "18798c8185ada1f27a68cb8c2a9de505de67da0f081f87f1f94d83190cd52c90"`
[INFO] [stdout] 18798c8185ada1f27a68cb8c2a9de505de67da0f081f87f1f94d83190cd52c90
