[INFO] fetching crate multipart-async 0.0.2...
[INFO] testing multipart-async-0.0.2 against 1.91.0 for beta-1.92-2
[INFO] extracting crate multipart-async 0.0.2 into /workspace/builds/worker-1-tc1/source
[INFO] started tweaking crates.io crate multipart-async 0.0.2
[INFO] finished tweaking crates.io crate multipart-async 0.0.2
[INFO] tweaked toml for crates.io crate multipart-async 0.0.2 written to /workspace/builds/worker-1-tc1/source/Cargo.toml
[INFO] validating manifest of crates.io crate multipart-async 0.0.2 on toolchain 1.91.0
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1.91.0" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1.91.0" "generate-lockfile" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]      Locking 99 packages to latest compatible versions
[INFO] [stderr]       Adding display_bytes v0.1.0 (available: v0.2.1)
[INFO] [stderr]       Adding env_logger v0.3.5 (available: v0.11.8)
[INFO] [stderr]       Adding futures v0.1.31 (available: v0.3.31)
[INFO] [stderr]       Adding hyper v0.11.27 (available: v1.7.0)
[INFO] [stderr]       Adding log v0.3.9 (available: v0.4.28)
[INFO] [stderr]       Adding rand v0.3.23 (available: v0.9.2)
[INFO] [stderr]       Adding twoway v0.1.8 (available: v0.2.2)
[INFO] [stderr]       Adding wasi v0.10.0+wasi-snapshot-preview1 (available: v0.10.2+wasi-snapshot-preview1)
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1.91.0" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr] warning: no edition set: defaulting to the 2015 edition while the latest is 2024
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded want v0.0.4
[INFO] [stderr]   Downloaded cfg-if v0.1.10
[INFO] [stderr]   Downloaded semver-parser v0.7.0
[INFO] [stderr]   Downloaded mime_guess v2.0.5
[INFO] [stderr]   Downloaded rand v0.3.23
[INFO] [stderr]   Downloaded relay v0.1.1
[INFO] [stderr]   Downloaded memoffset v0.5.6
[INFO] [stderr]   Downloaded winapi-build v0.1.1
[INFO] [stderr]   Downloaded tokio-proto v0.1.1
[INFO] [stderr]   Downloaded language-tags v0.2.2
[INFO] [stderr]   Downloaded twoway v0.1.8
[INFO] [stderr]   Downloaded httparse v1.10.1
[INFO] [stderr]   Downloaded kernel32-sys v0.2.2
[INFO] [stderr]   Downloaded tempdir v0.3.7
[INFO] [stderr]   Downloaded miow v0.2.2
[INFO] [stderr]   Downloaded parking_lot v0.9.0
[INFO] [stderr]   Downloaded time v0.1.45
[INFO] [stderr]   Downloaded winapi v0.2.8
[INFO] [stderr]   Downloaded unchecked-index v0.2.2
[INFO] [stderr]   Downloaded rand v0.4.6
[INFO] [stderr]   Downloaded crossbeam-queue v0.2.3
[INFO] [stderr]   Downloaded redox_syscall v0.1.57
[INFO] [stderr]   Downloaded tokio-fs v0.1.7
[INFO] [stderr]   Downloaded lazy_static v1.5.0
[INFO] [stderr]   Downloaded winapi v0.3.9
[INFO] [stderr]   Downloaded memchr v0.1.11
[INFO] [stderr]   Downloaded thread-id v2.0.0
[INFO] [stderr]   Downloaded tokio-current-thread v0.1.7
[INFO] [stderr]   Downloaded wasi v0.10.0+wasi-snapshot-preview1
[INFO] [stderr]   Downloaded regex-syntax v0.3.9
[INFO] [stderr]   Downloaded env_logger v0.3.5
[INFO] [stderr]   Downloaded aho-corasick v0.5.3
[INFO] [stderr]   Downloaded scoped-tls v0.1.2
[INFO] [stderr]   Downloaded tokio v0.1.22
[INFO] [stderr]   Downloaded regex v0.1.80
[INFO] [stderr]   Downloaded cloudabi v0.0.3
[INFO] [stderr]   Downloaded thread_local v0.2.7
[INFO] [stderr]   Downloaded display_bytes v0.1.0
[INFO] [stderr]   Downloaded utf8-ranges v0.1.3
[INFO] [stderr]   Downloaded slab v0.3.0
[INFO] [stderr]   Downloaded net2 v0.2.39
[INFO] [stderr]   Downloaded rand_core v0.3.1
[INFO] [stderr]   Downloaded base64 v0.9.3
[INFO] [stderr]   Downloaded take v0.1.0
[INFO] [stderr]   Downloaded mio v0.6.23
[INFO] [stderr]   Downloaded scopeguard v1.2.0
[INFO] [stderr]   Downloaded crossbeam-utils v0.7.2
[INFO] [stderr]   Downloaded log v0.4.28
[INFO] [stderr]   Downloaded unicase v2.8.1
[INFO] [stderr]   Downloaded libc v0.2.177
[INFO] [stderr]   Downloaded hyper v0.11.27
[INFO] [stderr]   Downloaded rand_core v0.4.2
[INFO] [stderr]   Downloaded crossbeam-deque v0.7.4
[INFO] [stderr]   Downloaded tokio-uds v0.2.7
[INFO] [stderr]   Downloaded rustc_version v0.2.3
[INFO] [stderr]   Downloaded slab v0.4.11
[INFO] [stderr]   Downloaded autocfg v1.5.0
[INFO] [stderr]   Downloaded byteorder v1.5.0
[INFO] [stderr]   Downloaded winapi-i686-pc-windows-gnu v0.4.0
[INFO] [stderr]   Downloaded tokio-reactor v0.1.12
[INFO] [stderr]   Downloaded futures v0.1.31
[INFO] [stderr]   Downloaded log v0.3.9
[INFO] [stderr]   Downloaded smallvec v0.2.1
[INFO] [stderr]   Downloaded tokio-codec v0.1.2
[INFO] [stderr]   Downloaded winapi-x86_64-pc-windows-gnu v0.4.0
[INFO] [stderr]   Downloaded tokio-threadpool v0.1.18
[INFO] [stderr]   Downloaded rdrand v0.4.0
[INFO] [stderr]   Downloaded tokio-udp v0.1.6
[INFO] [stderr]   Downloaded lock_api v0.3.4
[INFO] [stderr]   Downloaded tokio-io v0.1.13
[INFO] [stderr]   Downloaded tokio-service v0.1.0
[INFO] [stderr]   Downloaded safemem v0.3.3
[INFO] [stderr]   Downloaded mio-uds v0.6.8
[INFO] [stderr]   Downloaded num_cpus v1.17.0
[INFO] [stderr]   Downloaded maybe-uninit v2.0.0
[INFO] [stderr]   Downloaded semver v0.9.0
[INFO] [stderr]   Downloaded tokio-sync v0.1.8
[INFO] [stderr]   Downloaded tokio-timer v0.2.13
[INFO] [stderr]   Downloaded bytes v0.4.12
[INFO] [stderr]   Downloaded mime v0.3.17
[INFO] [stderr]   Downloaded fuchsia-cprng v0.1.1
[INFO] [stderr]   Downloaded futures-cpupool v0.1.8
[INFO] [stderr]   Downloaded percent-encoding v1.0.1
[INFO] [stderr]   Downloaded tokio-tcp v0.1.4
[INFO] [stderr]   Downloaded crossbeam-epoch v0.8.2
[INFO] [stderr]   Downloaded fuchsia-zircon v0.3.3
[INFO] [stderr]   Downloaded fuchsia-zircon-sys v0.3.3
[INFO] [stderr]   Downloaded hermit-abi v0.5.2
[INFO] [stderr]   Downloaded fnv v1.0.7
[INFO] [stderr]   Downloaded try-lock v0.1.0
[INFO] [stderr]   Downloaded remove_dir_all v0.5.3
[INFO] [stderr]   Downloaded smallvec v0.6.14
[INFO] [stderr]   Downloaded tokio-executor v0.1.10
[INFO] [stderr]   Downloaded tokio-core v0.1.18
[INFO] [stderr]   Downloaded memchr v2.7.6
[INFO] [stderr]   Downloaded parking_lot_core v0.6.3
[INFO] [stderr]   Downloaded ws2_32-sys v0.2.1
[INFO] [stderr]   Downloaded iovec v0.1.4
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/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" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+1.91.0" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 8446ffed349ea442550ca9652c534b53bbd9a389c677c59aad476d2fab405704
[INFO] running `Command { std: "docker" "start" "-a" "8446ffed349ea442550ca9652c534b53bbd9a389c677c59aad476d2fab405704", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "8446ffed349ea442550ca9652c534b53bbd9a389c677c59aad476d2fab405704", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "8446ffed349ea442550ca9652c534b53bbd9a389c677c59aad476d2fab405704", kill_on_drop: false }`
[INFO] [stdout] 8446ffed349ea442550ca9652c534b53bbd9a389c677c59aad476d2fab405704
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/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" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+1.91.0" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 7f3a24162e493775702b15de13bd91f0da4bb9197addf73676c85dd53990fb08
[INFO] running `Command { std: "docker" "start" "-a" "7f3a24162e493775702b15de13bd91f0da4bb9197addf73676c85dd53990fb08", kill_on_drop: false }`
[INFO] [stderr] warning: no edition set: defaulting to the 2015 edition while the latest is 2024
[INFO] [stderr]    Compiling libc v0.2.177
[INFO] [stderr]    Compiling autocfg v1.5.0
[INFO] [stderr]    Compiling cfg-if v0.1.10
[INFO] [stderr]    Compiling futures v0.1.31
[INFO] [stderr]    Compiling maybe-uninit v2.0.0
[INFO] [stderr]    Compiling lazy_static v1.5.0
[INFO] [stderr]    Compiling log v0.4.28
[INFO] [stderr]    Compiling semver-parser v0.7.0
[INFO] [stderr]    Compiling scopeguard v1.2.0
[INFO] [stderr]    Compiling slab v0.4.11
[INFO] [stderr]    Compiling byteorder v1.5.0
[INFO] [stderr]    Compiling fnv v1.0.7
[INFO] [stderr]    Compiling winapi-build v0.1.1
[INFO] [stderr]    Compiling winapi v0.2.8
[INFO] [stderr]    Compiling unicase v2.8.1
[INFO] [stderr]    Compiling scoped-tls v0.1.2
[INFO] [stderr]    Compiling lock_api v0.3.4
[INFO] [stderr]    Compiling httparse v1.10.1
[INFO] [stderr]    Compiling utf8-ranges v0.1.3
[INFO] [stderr]    Compiling smallvec v0.2.1
[INFO] [stderr]    Compiling kernel32-sys v0.2.2
[INFO] [stderr]    Compiling slab v0.3.0
[INFO] [stderr]    Compiling regex-syntax v0.3.9
[INFO] [stderr]    Compiling mime_guess v2.0.5
[INFO] [stderr]    Compiling mime v0.3.17
[INFO] [stderr]    Compiling semver v0.9.0
[INFO] [stderr]    Compiling try-lock v0.1.0
[INFO] [stderr]    Compiling safemem v0.3.3
[INFO] [stderr]    Compiling take v0.1.0
[INFO] [stderr]    Compiling smallvec v0.6.14
[INFO] [stderr]    Compiling log v0.3.9
[INFO] [stderr]    Compiling base64 v0.9.3
[INFO] [stderr]    Compiling remove_dir_all v0.5.3
[INFO] [stderr]    Compiling memchr v2.7.6
[INFO] [stderr]    Compiling percent-encoding v1.0.1
[INFO] [stderr]    Compiling language-tags v0.2.2
[INFO] [stderr]    Compiling display_bytes v0.1.0
[INFO] [stderr]    Compiling rustc_version v0.2.3
[INFO] [stderr]    Compiling crossbeam-utils v0.7.2
[INFO] [stderr]    Compiling memoffset v0.5.6
[INFO] [stderr]    Compiling crossbeam-epoch v0.8.2
[INFO] [stderr]    Compiling parking_lot_core v0.6.3
[INFO] [stderr]    Compiling parking_lot v0.9.0
[INFO] [stderr]    Compiling twoway v0.1.8
[INFO] [stderr]    Compiling crossbeam-queue v0.2.3
[INFO] [stderr]    Compiling tokio-executor v0.1.10
[INFO] [stderr]    Compiling tokio-sync v0.1.8
[INFO] [stderr]    Compiling tokio-service v0.1.0
[INFO] [stderr]    Compiling want v0.0.4
[INFO] [stderr]    Compiling relay v0.1.1
[INFO] [stderr]    Compiling tokio-timer v0.2.13
[INFO] [stderr]    Compiling tokio-current-thread v0.1.7
[INFO] [stderr]    Compiling crossbeam-deque v0.7.4
[INFO] [stderr]    Compiling iovec v0.1.4
[INFO] [stderr]    Compiling num_cpus v1.17.0
[INFO] [stderr]    Compiling net2 v0.2.39
[INFO] [stderr]    Compiling rand v0.4.6
[INFO] [stderr]    Compiling thread-id v2.0.0
[INFO] [stderr]    Compiling memchr v0.1.11
[INFO] [stderr]    Compiling time v0.1.45
[INFO] [stderr]    Compiling thread_local v0.2.7
[INFO] [stderr]    Compiling bytes v0.4.12
[INFO] [stderr]    Compiling aho-corasick v0.5.3
[INFO] [stderr]    Compiling tokio-threadpool v0.1.18
[INFO] [stderr]    Compiling futures-cpupool v0.1.8
[INFO] [stderr]    Compiling mio v0.6.23
[INFO] [stderr]    Compiling regex v0.1.80
[INFO] [stderr]    Compiling tokio-io v0.1.13
[INFO] [stderr]    Compiling rand v0.3.23
[INFO] [stderr]    Compiling tempdir v0.3.7
[INFO] [stderr]    Compiling tokio-codec v0.1.2
[INFO] [stderr]    Compiling tokio-fs v0.1.7
[INFO] [stderr]    Compiling tokio-reactor v0.1.12
[INFO] [stderr]    Compiling mio-uds v0.6.8
[INFO] [stderr]    Compiling env_logger v0.3.5
[INFO] [stderr]    Compiling tokio-uds v0.2.7
[INFO] [stderr]    Compiling tokio-tcp v0.1.4
[INFO] [stderr]    Compiling tokio-udp v0.1.6
[INFO] [stderr]    Compiling tokio v0.1.22
[INFO] [stderr]    Compiling tokio-core v0.1.18
[INFO] [stderr]    Compiling tokio-proto v0.1.1
[INFO] [stderr]    Compiling hyper v0.11.27
[INFO] [stderr]    Compiling multipart-async v0.0.2 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `std::rc::Rc`
[INFO] [stdout]   --> src/lib.rs:41:5
[INFO] [stdout]    |
[INFO] [stdout] 41 | use std::rc::Rc;
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::sync::Arc`
[INFO] [stdout]   --> src/lib.rs:42:5
[INFO] [stdout]    |
[INFO] [stdout] 42 | use std::sync::Arc;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `mime::Mime`
[INFO] [stdout]   --> src/server/mod.rs:20:5
[INFO] [stdout]    |
[INFO] [stdout] 20 | use mime::Mime;
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `tempdir::TempDir`
[INFO] [stdout]   --> src/server/mod.rs:22:5
[INFO] [stdout]    |
[INFO] [stdout] 22 | use tempdir::TempDir;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::borrow::Borrow`
[INFO] [stdout]   --> src/server/mod.rs:24:5
[INFO] [stdout]    |
[INFO] [stdout] 24 | use std::borrow::Borrow;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::VecDeque`
[INFO] [stdout]   --> src/server/mod.rs:26:5
[INFO] [stdout]    |
[INFO] [stdout] 26 | use std::collections::VecDeque;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `File` and `self`
[INFO] [stdout]   --> src/server/mod.rs:27:15
[INFO] [stdout]    |
[INFO] [stdout] 27 | use std::fs::{self, File};
[INFO] [stdout]    |               ^^^^  ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `PathBuf` and `Path`
[INFO] [stdout]   --> src/server/mod.rs:29:17
[INFO] [stdout]    |
[INFO] [stdout] 29 | use std::path::{Path, PathBuf};
[INFO] [stdout]    |                 ^^^^  ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `fmt`, `mem`, and `ptr`
[INFO] [stdout]   --> src/server/mod.rs:32:11
[INFO] [stdout]    |
[INFO] [stdout] 32 | use std::{fmt, io, mem, ptr};
[INFO] [stdout]    |           ^^^      ^^^  ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::cmp`
[INFO] [stdout]   --> src/server/boundary.rs:11:5
[INFO] [stdout]    |
[INFO] [stdout] 11 | use std::cmp;
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Borrow` and `Cow`
[INFO] [stdout]   --> src/server/boundary.rs:12:19
[INFO] [stdout]    |
[INFO] [stdout] 12 | use std::borrow::{Borrow, Cow};
[INFO] [stdout]    |                   ^^^^^^  ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::error::Error`
[INFO] [stdout]   --> src/server/boundary.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 13 | use std::error::Error;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::io`
[INFO] [stdout]   --> src/server/boundary.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 15 | use std::io;
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Async` and `Future`
[INFO] [stdout]  --> src/server/field/mod.rs:7:15
[INFO] [stdout]   |
[INFO] [stdout] 7 | use futures::{Future, Stream, Async, Poll};
[INFO] [stdout]   |               ^^^^^^          ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `futures::Async::*`
[INFO] [stdout]  --> src/server/field/mod.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use futures::Async::*;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Mime` and `self`
[INFO] [stdout]   --> src/server/field/mod.rs:10:12
[INFO] [stdout]    |
[INFO] [stdout] 10 | use mime::{self, Mime};
[INFO] [stdout]    |            ^^^^  ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `io`, `mem`, and `str`
[INFO] [stdout]   --> src/server/field/mod.rs:13:11
[INFO] [stdout]    |
[INFO] [stdout] 13 | use std::{io, mem, str};
[INFO] [stdout]    |           ^^  ^^^  ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `helpers::*`
[INFO] [stdout]   --> src/server/field/mod.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 18 | use helpers::*;
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `self::httparse::EMPTY_HEADER`
[INFO] [stdout]   --> src/server/field/mod.rs:21:5
[INFO] [stdout]    |
[INFO] [stdout] 21 | use self::httparse::EMPTY_HEADER;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `futures::Async::*`
[INFO] [stdout]  --> src/server/field/collect.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use futures::Async::*;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `server::boundary::BoundaryFinder`
[INFO] [stdout]  --> src/server/field/collect.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 | use server::boundary::BoundaryFinder;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Internal`
[INFO] [stdout]   --> src/server/field/collect.rs:10:14
[INFO] [stdout]    |
[INFO] [stdout] 10 | use server::{Internal, BodyChunk, StreamError};
[INFO] [stdout]    |              ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trailing semicolon in macro used in expression position
[INFO] [stdout]    --> src/server/mod.rs:47:41
[INFO] [stdout]     |
[INFO] [stdout]  47 |         return ::helpers::error($string);
[INFO] [stdout]     |                                         ^
[INFO] [stdout]     |
[INFO] [stdout]    ::: src/server/field/collect.rs:159:25
[INFO] [stdout]     |
[INFO] [stdout] 159 |                 None => ret_err!("unexpected end of stream while decoding a UTF-8 sequence"),
[INFO] [stdout]     |                         -------------------------------------------------------------------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
[INFO] [stdout]     = note: for more information, see issue #79813 <https://github.com/rust-lang/rust/issues/79813>
[INFO] [stdout]     = note: `#[warn(semicolon_in_expressions_from_macros)]` (part of `#[warn(future_incompatible)]`) on by default
[INFO] [stdout]     = note: this warning originates in the macro `ret_err` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Poll`
[INFO] [stdout]  --> src/server/field/headers.rs:1:15
[INFO] [stdout]   |
[INFO] [stdout] 1 | use futures::{Poll, Stream};
[INFO] [stdout]   |               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `io`
[INFO] [stdout]  --> src/server/field/headers.rs:5:11
[INFO] [stdout]   |
[INFO] [stdout] 5 | use std::{io, str};
[INFO] [stdout]   |           ^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Multipart`
[INFO] [stdout]  --> src/server/field/headers.rs:7:14
[INFO] [stdout]   |
[INFO] [stdout] 7 | use server::{Multipart, BodyChunk, StreamError, httparse, twoway};
[INFO] [stdout]   |              ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trailing semicolon in macro used in expression position
[INFO] [stdout]    --> src/server/mod.rs:50:61
[INFO] [stdout]     |
[INFO] [stdout]  50 |         return ::helpers::error(format!($string, $($args)*));
[INFO] [stdout]     |                                                             ^
[INFO] [stdout]     |
[INFO] [stdout]    ::: src/server/field/headers.rs:139:32
[INFO] [stdout]     |
[INFO] [stdout] 139 |         Ok(Status::Partial) => ret_err!("field headers incomplete: {}", show_bytes(bytes)),
[INFO] [stdout]     |                                ----------------------------------------------------------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
[INFO] [stdout]     = note: for more information, see issue #79813 <https://github.com/rust-lang/rust/issues/79813>
[INFO] [stdout]     = note: this warning originates in the macro `ret_err` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trailing semicolon in macro used in expression position
[INFO] [stdout]    --> src/server/mod.rs:50:61
[INFO] [stdout]     |
[INFO] [stdout]  50 |         return ::helpers::error(format!($string, $($args)*));
[INFO] [stdout]     |                                                             ^
[INFO] [stdout]     |
[INFO] [stdout]    ::: src/server/field/headers.rs:140:19
[INFO] [stdout]     |
[INFO] [stdout] 140 |         Err(e) => ret_err!("error parsing headers: {}; from buffer: {}", e, show_bytes(bytes)),
[INFO] [stdout]     |                   ---------------------------------------------------------------------------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
[INFO] [stdout]     = note: for more information, see issue #79813 <https://github.com/rust-lang/rust/issues/79813>
[INFO] [stdout]     = note: this warning originates in the macro `ret_err` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trailing semicolon in macro used in expression position
[INFO] [stdout]    --> src/server/mod.rs:50:61
[INFO] [stdout]     |
[INFO] [stdout]  50 |         return ::helpers::error(format!($string, $($args)*));
[INFO] [stdout]     |                                                             ^
[INFO] [stdout]     |
[INFO] [stdout]    ::: src/server/field/headers.rs:153:31
[INFO] [stdout]     |
[INFO] [stdout] 153 |                  .or_else(|_| ret_err!("could not parse MIME type from {:?}", str_val))?),
[INFO] [stdout]     |                               -------------------------------------------------------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
[INFO] [stdout]     = note: for more information, see issue #79813 <https://github.com/rust-lang/rust/issues/79813>
[INFO] [stdout]     = note: this warning originates in the macro `ret_err` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trailing semicolon in macro used in expression position
[INFO] [stdout]    --> src/server/mod.rs:50:61
[INFO] [stdout]     |
[INFO] [stdout]  50 |         return ::helpers::error(format!($string, $($args)*));
[INFO] [stdout]     |                                                             ^
[INFO] [stdout]     |
[INFO] [stdout]    ::: src/server/field/headers.rs:167:24
[INFO] [stdout]     |
[INFO] [stdout] 167 |         Some(other) => ret_err!("unexpected multipart field Content-Disposition: {}", other),
[INFO] [stdout]     |                        --------------------------------------------------------------------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
[INFO] [stdout]     = note: for more information, see issue #79813 <https://github.com/rust-lang/rust/issues/79813>
[INFO] [stdout]     = note: this warning originates in the macro `ret_err` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Stream`
[INFO] [stdout]  --> src/helpers.rs:7:22
[INFO] [stdout]   |
[INFO] [stdout] 7 | use futures::{Async, Stream};
[INFO] [stdout]   |                      ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::error::Error`
[INFO] [stdout]   --> src/helpers.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | use std::error::Error;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::io`
[INFO] [stdout]   --> src/helpers.rs:11:5
[INFO] [stdout]    |
[INFO] [stdout] 11 | use std::io;
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `core::str::<impl str>::trim_left_matches`: superseded by `trim_start_matches`
[INFO] [stdout]    --> src/server/field/headers.rs:198:28
[INFO] [stdout]     |
[INFO] [stdout] 198 |     let mut splits = input.trim_left_matches(&[' ', ';'][..]).splitn(1, '=');
[INFO] [stdout]     |                            ^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] help: replace the use of the deprecated method
[INFO] [stdout]     |
[INFO] [stdout] 198 -     let mut splits = input.trim_left_matches(&[' ', ';'][..]).splitn(1, '=');
[INFO] [stdout] 198 +     let mut splits = input.trim_start_matches(&[' ', ';'][..]).splitn(1, '=');
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::io::prelude`
[INFO] [stdout]   --> src/server/mod.rs:28:5
[INFO] [stdout]    |
[INFO] [stdout] 28 | use std::io::prelude::*;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::fmt::Write`
[INFO] [stdout]    --> src/server/boundary.rs:395:13
[INFO] [stdout]     |
[INFO] [stdout] 395 |         use std::fmt::Write;
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `len`
[INFO] [stdout]    --> src/server/boundary.rs:313:13
[INFO] [stdout]     |
[INFO] [stdout] 313 |         let len = boundary.len();
[INFO] [stdout]     |             ^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]     |
[INFO] [stdout] 313 |         let _len = boundary.len();
[INFO] [stdout]     |             +
[INFO] [stdout] help: you might have meant to pattern match on the similarly named constant `MAX_HEADERS`
[INFO] [stdout]     |
[INFO] [stdout] 313 -         let len = boundary.len();
[INFO] [stdout] 313 +         let server::field::headers::MAX_HEADERS = boundary.len();
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/server/field/collect.rs:122:17
[INFO] [stdout]     |
[INFO] [stdout] 122 |             let mut stream = data.stream_mut();
[INFO] [stdout]     |                 ----^^^^^^
[INFO] [stdout]     |                 |
[INFO] [stdout]     |                 help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `random_alphanumeric` is never used
[INFO] [stdout]   --> src/lib.rs:56:4
[INFO] [stdout]    |
[INFO] [stdout] 56 | fn random_alphanumeric(len: usize) -> String {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `maybe_boundary`, `check_boundary`, `consume_boundary`, `confirm_boundary`, and `confirm_boundary_split` are never used
[INFO] [stdout]    --> src/server/boundary.rs:261:8
[INFO] [stdout]     |
[INFO] [stdout]  98 | impl<S: Stream> BoundaryFinder<S> where S::Item: BodyChunk, S::Error: StreamError {
[INFO] [stdout]     | --------------------------------------------------------------------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 261 |     fn maybe_boundary(&self, bytes: &[u8]) -> bool {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 266 |     fn check_boundary(&self, bytes: &[u8]) -> bool {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 278 |     pub fn consume_boundary(&mut self) -> Poll<bool, S::Error> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 290 |     fn confirm_boundary(&mut self, boundary: S::Item) -> Poll<bool, S::Error> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 324 |     fn confirm_boundary_split(&mut self, first: S::Item, second: S::Item) -> Poll<bool, S::Error> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `End` is never constructed
[INFO] [stdout]    --> src/server/boundary.rs:390:5
[INFO] [stdout]     |
[INFO] [stdout] 381 | enum State<B> {
[INFO] [stdout]     |      ----- variant in this enum
[INFO] [stdout] ...
[INFO] [stdout] 390 |     End,
[INFO] [stdout]     |     ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `check_last_two` is never used
[INFO] [stdout]    --> src/server/boundary.rs:438:4
[INFO] [stdout]     |
[INFO] [stdout] 438 | fn check_last_two(boundary: &[u8]) -> bool {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/server/field/headers.rs:56:20
[INFO] [stdout]    |
[INFO] [stdout] 56 |     pub fn charset(&self) -> Option<Name> {
[INFO] [stdout]    |                    ^^^^^            ^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                    |
[INFO] [stdout]    |                    the lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]    = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]    |
[INFO] [stdout] 56 |     pub fn charset(&self) -> Option<Name<'_>> {
[INFO] [stdout]    |                                         ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 9.34s
[INFO] [stderr] warning: the following packages contain code that will be rejected by a future version of Rust: multipart-async v0.0.2 (/opt/rustwide/workdir)
[INFO] [stderr] note: to see what the problems were, use the option `--future-incompat-report`, or run `cargo report future-incompatibilities --id 1`
[INFO] running `Command { std: "docker" "inspect" "7f3a24162e493775702b15de13bd91f0da4bb9197addf73676c85dd53990fb08", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "7f3a24162e493775702b15de13bd91f0da4bb9197addf73676c85dd53990fb08", kill_on_drop: false }`
[INFO] [stdout] 7f3a24162e493775702b15de13bd91f0da4bb9197addf73676c85dd53990fb08
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/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" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+1.91.0" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 2547ac752d7635624a0d510e852aeec7b294d90ca871f5c9e1e227ca59b9088d
[INFO] running `Command { std: "docker" "start" "-a" "2547ac752d7635624a0d510e852aeec7b294d90ca871f5c9e1e227ca59b9088d", kill_on_drop: false }`
[INFO] [stderr] warning: no edition set: defaulting to the 2015 edition while the latest is 2024
[INFO] [stdout] warning: unused import: `std::rc::Rc`
[INFO] [stdout]   --> src/lib.rs:41:5
[INFO] [stdout]    |
[INFO] [stdout] 41 | use std::rc::Rc;
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::sync::Arc`
[INFO] [stdout]   --> src/lib.rs:42:5
[INFO] [stdout]    |
[INFO] [stdout] 42 | use std::sync::Arc;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `mime::Mime`
[INFO] [stdout]   --> src/server/mod.rs:20:5
[INFO] [stdout]    |
[INFO] [stdout] 20 | use mime::Mime;
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `tempdir::TempDir`
[INFO] [stdout]   --> src/server/mod.rs:22:5
[INFO] [stdout]    |
[INFO] [stdout] 22 | use tempdir::TempDir;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::borrow::Borrow`
[INFO] [stdout]   --> src/server/mod.rs:24:5
[INFO] [stdout]    |
[INFO] [stdout] 24 | use std::borrow::Borrow;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::VecDeque`
[INFO] [stdout]   --> src/server/mod.rs:26:5
[INFO] [stdout]    |
[INFO] [stdout] 26 | use std::collections::VecDeque;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `File` and `self`
[INFO] [stdout]   --> src/server/mod.rs:27:15
[INFO] [stdout]    |
[INFO] [stdout] 27 | use std::fs::{self, File};
[INFO] [stdout]    |               ^^^^  ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `PathBuf` and `Path`
[INFO] [stdout]   --> src/server/mod.rs:29:17
[INFO] [stdout]    |
[INFO] [stdout] 29 | use std::path::{Path, PathBuf};
[INFO] [stdout]    |                 ^^^^  ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `fmt`, `mem`, and `ptr`
[INFO] [stdout]   --> src/server/mod.rs:32:11
[INFO] [stdout]    |
[INFO] [stdout] 32 | use std::{fmt, io, mem, ptr};
[INFO] [stdout]    |           ^^^      ^^^  ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::cmp`
[INFO] [stdout]   --> src/server/boundary.rs:11:5
[INFO] [stdout]    |
[INFO] [stdout] 11 | use std::cmp;
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Borrow` and `Cow`
[INFO] [stdout]   --> src/server/boundary.rs:12:19
[INFO] [stdout]    |
[INFO] [stdout] 12 | use std::borrow::{Borrow, Cow};
[INFO] [stdout]    |                   ^^^^^^  ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::error::Error`
[INFO] [stdout]   --> src/server/boundary.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 13 | use std::error::Error;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::io`
[INFO] [stdout]   --> src/server/boundary.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 15 | use std::io;
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Async` and `Future`
[INFO] [stdout]  --> src/server/field/mod.rs:7:15
[INFO] [stdout]   |
[INFO] [stdout] 7 | use futures::{Future, Stream, Async, Poll};
[INFO] [stdout]   |               ^^^^^^          ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `futures::Async::*`
[INFO] [stdout]  --> src/server/field/mod.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use futures::Async::*;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Mime` and `self`
[INFO] [stdout]   --> src/server/field/mod.rs:10:12
[INFO] [stdout]    |
[INFO] [stdout] 10 | use mime::{self, Mime};
[INFO] [stdout]    |            ^^^^  ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `io`, `mem`, and `str`
[INFO] [stdout]   --> src/server/field/mod.rs:13:11
[INFO] [stdout]    |
[INFO] [stdout] 13 | use std::{io, mem, str};
[INFO] [stdout]    |           ^^  ^^^  ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `helpers::*`
[INFO] [stdout]   --> src/server/field/mod.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 18 | use helpers::*;
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `self::httparse::EMPTY_HEADER`
[INFO] [stdout]   --> src/server/field/mod.rs:21:5
[INFO] [stdout]    |
[INFO] [stdout] 21 | use self::httparse::EMPTY_HEADER;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `futures::Async::*`
[INFO] [stdout]  --> src/server/field/collect.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use futures::Async::*;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `server::boundary::BoundaryFinder`
[INFO] [stdout]  --> src/server/field/collect.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 | use server::boundary::BoundaryFinder;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Internal`
[INFO] [stdout]   --> src/server/field/collect.rs:10:14
[INFO] [stdout]    |
[INFO] [stdout] 10 | use server::{Internal, BodyChunk, StreamError};
[INFO] [stdout]    |              ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trailing semicolon in macro used in expression position
[INFO] [stdout]    --> src/server/mod.rs:47:41
[INFO] [stdout]     |
[INFO] [stdout]  47 |         return ::helpers::error($string);
[INFO] [stdout]     |                                         ^
[INFO] [stdout]     |
[INFO] [stdout]    ::: src/server/field/collect.rs:159:25
[INFO] [stdout]     |
[INFO] [stdout] 159 |                 None => ret_err!("unexpected end of stream while decoding a UTF-8 sequence"),
[INFO] [stdout]     |                         -------------------------------------------------------------------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
[INFO] [stdout]     = note: for more information, see issue #79813 <https://github.com/rust-lang/rust/issues/79813>
[INFO] [stdout]     = note: `#[warn(semicolon_in_expressions_from_macros)]` (part of `#[warn(future_incompatible)]`) on by default
[INFO] [stdout]     = note: this warning originates in the macro `ret_err` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Poll`
[INFO] [stdout]  --> src/server/field/headers.rs:1:15
[INFO] [stdout]   |
[INFO] [stdout] 1 | use futures::{Poll, Stream};
[INFO] [stdout]   |               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `io`
[INFO] [stdout]  --> src/server/field/headers.rs:5:11
[INFO] [stdout]   |
[INFO] [stdout] 5 | use std::{io, str};
[INFO] [stdout]   |           ^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Multipart`
[INFO] [stdout]  --> src/server/field/headers.rs:7:14
[INFO] [stdout]   |
[INFO] [stdout] 7 | use server::{Multipart, BodyChunk, StreamError, httparse, twoway};
[INFO] [stdout]   |              ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trailing semicolon in macro used in expression position
[INFO] [stdout]    --> src/server/mod.rs:50:61
[INFO] [stdout]     |
[INFO] [stdout]  50 |         return ::helpers::error(format!($string, $($args)*));
[INFO] [stdout]     |                                                             ^
[INFO] [stdout]     |
[INFO] [stdout]    ::: src/server/field/headers.rs:139:32
[INFO] [stdout]     |
[INFO] [stdout] 139 |         Ok(Status::Partial) => ret_err!("field headers incomplete: {}", show_bytes(bytes)),
[INFO] [stdout]     |                                ----------------------------------------------------------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
[INFO] [stdout]     = note: for more information, see issue #79813 <https://github.com/rust-lang/rust/issues/79813>
[INFO] [stdout]     = note: this warning originates in the macro `ret_err` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trailing semicolon in macro used in expression position
[INFO] [stdout]    --> src/server/mod.rs:50:61
[INFO] [stdout]     |
[INFO] [stdout]  50 |         return ::helpers::error(format!($string, $($args)*));
[INFO] [stdout]     |                                                             ^
[INFO] [stdout]     |
[INFO] [stdout]    ::: src/server/field/headers.rs:140:19
[INFO] [stdout]     |
[INFO] [stdout] 140 |         Err(e) => ret_err!("error parsing headers: {}; from buffer: {}", e, show_bytes(bytes)),
[INFO] [stdout]     |                   ---------------------------------------------------------------------------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
[INFO] [stdout]     = note: for more information, see issue #79813 <https://github.com/rust-lang/rust/issues/79813>
[INFO] [stdout]     = note: this warning originates in the macro `ret_err` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trailing semicolon in macro used in expression position
[INFO] [stdout]    --> src/server/mod.rs:50:61
[INFO] [stdout]     |
[INFO] [stdout]  50 |         return ::helpers::error(format!($string, $($args)*));
[INFO] [stdout]     |                                                             ^
[INFO] [stdout]     |
[INFO] [stdout]    ::: src/server/field/headers.rs:153:31
[INFO] [stdout]     |
[INFO] [stdout] 153 |                  .or_else(|_| ret_err!("could not parse MIME type from {:?}", str_val))?),
[INFO] [stdout]     |                               -------------------------------------------------------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
[INFO] [stdout]     = note: for more information, see issue #79813 <https://github.com/rust-lang/rust/issues/79813>
[INFO] [stdout]     = note: this warning originates in the macro `ret_err` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trailing semicolon in macro used in expression position
[INFO] [stdout]    --> src/server/mod.rs:50:61
[INFO] [stdout]     |
[INFO] [stdout]  50 |         return ::helpers::error(format!($string, $($args)*));
[INFO] [stdout]     |                                                             ^
[INFO] [stdout]     |
[INFO] [stdout]    ::: src/server/field/headers.rs:167:24
[INFO] [stdout]     |
[INFO] [stdout] 167 |         Some(other) => ret_err!("unexpected multipart field Content-Disposition: {}", other),
[INFO] [stdout]     |                        --------------------------------------------------------------------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
[INFO] [stdout]     = note: for more information, see issue #79813 <https://github.com/rust-lang/rust/issues/79813>
[INFO] [stdout]     = note: this warning originates in the macro `ret_err` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Stream`
[INFO] [stdout]  --> src/helpers.rs:7:22
[INFO] [stdout]   |
[INFO] [stdout] 7 | use futures::{Async, Stream};
[INFO] [stdout]   |                      ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::error::Error`
[INFO] [stdout]   --> src/helpers.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | use std::error::Error;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::io`
[INFO] [stdout]   --> src/helpers.rs:11:5
[INFO] [stdout]    |
[INFO] [stdout] 11 | use std::io;
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `core::str::<impl str>::trim_left_matches`: superseded by `trim_start_matches`
[INFO] [stdout]    --> src/server/field/headers.rs:198:28
[INFO] [stdout]     |
[INFO] [stdout] 198 |     let mut splits = input.trim_left_matches(&[' ', ';'][..]).splitn(1, '=');
[INFO] [stdout]     |                            ^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] help: replace the use of the deprecated method
[INFO] [stdout]     |
[INFO] [stdout] 198 -     let mut splits = input.trim_left_matches(&[' ', ';'][..]).splitn(1, '=');
[INFO] [stdout] 198 +     let mut splits = input.trim_start_matches(&[' ', ';'][..]).splitn(1, '=');
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::io::prelude`
[INFO] [stdout]   --> src/server/mod.rs:28:5
[INFO] [stdout]    |
[INFO] [stdout] 28 | use std::io::prelude::*;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::fmt::Write`
[INFO] [stdout]    --> src/server/boundary.rs:395:13
[INFO] [stdout]     |
[INFO] [stdout] 395 |         use std::fmt::Write;
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `len`
[INFO] [stdout]    --> src/server/boundary.rs:313:13
[INFO] [stdout]     |
[INFO] [stdout] 313 |         let len = boundary.len();
[INFO] [stdout]     |             ^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]     |
[INFO] [stdout] 313 |         let _len = boundary.len();
[INFO] [stdout]     |             +
[INFO] [stdout] help: you might have meant to pattern match on the similarly named constant `MAX_HEADERS`
[INFO] [stdout]     |
[INFO] [stdout] 313 -         let len = boundary.len();
[INFO] [stdout] 313 +         let server::field::headers::MAX_HEADERS = boundary.len();
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/server/field/collect.rs:122:17
[INFO] [stdout]     |
[INFO] [stdout] 122 |             let mut stream = data.stream_mut();
[INFO] [stdout]     |                 ----^^^^^^
[INFO] [stdout]     |                 |
[INFO] [stdout]     |                 help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `random_alphanumeric` is never used
[INFO] [stdout]   --> src/lib.rs:56:4
[INFO] [stdout]    |
[INFO] [stdout] 56 | fn random_alphanumeric(len: usize) -> String {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `maybe_boundary`, `check_boundary`, `consume_boundary`, `confirm_boundary`, and `confirm_boundary_split` are never used
[INFO] [stdout]    --> src/server/boundary.rs:261:8
[INFO] [stdout]     |
[INFO] [stdout]  98 | impl<S: Stream> BoundaryFinder<S> where S::Item: BodyChunk, S::Error: StreamError {
[INFO] [stdout]     | --------------------------------------------------------------------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 261 |     fn maybe_boundary(&self, bytes: &[u8]) -> bool {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 266 |     fn check_boundary(&self, bytes: &[u8]) -> bool {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 278 |     pub fn consume_boundary(&mut self) -> Poll<bool, S::Error> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 290 |     fn confirm_boundary(&mut self, boundary: S::Item) -> Poll<bool, S::Error> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 324 |     fn confirm_boundary_split(&mut self, first: S::Item, second: S::Item) -> Poll<bool, S::Error> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `End` is never constructed
[INFO] [stdout]    --> src/server/boundary.rs:390:5
[INFO] [stdout]     |
[INFO] [stdout] 381 | enum State<B> {
[INFO] [stdout]     |      ----- variant in this enum
[INFO] [stdout] ...
[INFO] [stdout] 390 |     End,
[INFO] [stdout]     |     ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `check_last_two` is never used
[INFO] [stdout]    --> src/server/boundary.rs:438:4
[INFO] [stdout]     |
[INFO] [stdout] 438 | fn check_last_two(boundary: &[u8]) -> bool {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/server/field/headers.rs:56:20
[INFO] [stdout]    |
[INFO] [stdout] 56 |     pub fn charset(&self) -> Option<Name> {
[INFO] [stdout]    |                    ^^^^^            ^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                    |
[INFO] [stdout]    |                    the lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]    = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]    |
[INFO] [stdout] 56 |     pub fn charset(&self) -> Option<Name<'_>> {
[INFO] [stdout]    |                                         ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]    Compiling multipart-async v0.0.2 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `std::rc::Rc`
[INFO] [stdout]   --> src/lib.rs:41:5
[INFO] [stdout]    |
[INFO] [stdout] 41 | use std::rc::Rc;
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::sync::Arc`
[INFO] [stdout]   --> src/lib.rs:42:5
[INFO] [stdout]    |
[INFO] [stdout] 42 | use std::sync::Arc;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `mime::Mime`
[INFO] [stdout]   --> src/server/mod.rs:20:5
[INFO] [stdout]    |
[INFO] [stdout] 20 | use mime::Mime;
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `tempdir::TempDir`
[INFO] [stdout]   --> src/server/mod.rs:22:5
[INFO] [stdout]    |
[INFO] [stdout] 22 | use tempdir::TempDir;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::borrow::Borrow`
[INFO] [stdout]   --> src/server/mod.rs:24:5
[INFO] [stdout]    |
[INFO] [stdout] 24 | use std::borrow::Borrow;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::VecDeque`
[INFO] [stdout]   --> src/server/mod.rs:26:5
[INFO] [stdout]    |
[INFO] [stdout] 26 | use std::collections::VecDeque;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `File` and `self`
[INFO] [stdout]   --> src/server/mod.rs:27:15
[INFO] [stdout]    |
[INFO] [stdout] 27 | use std::fs::{self, File};
[INFO] [stdout]    |               ^^^^  ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `PathBuf` and `Path`
[INFO] [stdout]   --> src/server/mod.rs:29:17
[INFO] [stdout]    |
[INFO] [stdout] 29 | use std::path::{Path, PathBuf};
[INFO] [stdout]    |                 ^^^^  ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `fmt`, `mem`, and `ptr`
[INFO] [stdout]   --> src/server/mod.rs:32:11
[INFO] [stdout]    |
[INFO] [stdout] 32 | use std::{fmt, io, mem, ptr};
[INFO] [stdout]    |           ^^^      ^^^  ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::cmp`
[INFO] [stdout]   --> src/server/boundary.rs:11:5
[INFO] [stdout]    |
[INFO] [stdout] 11 | use std::cmp;
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Borrow` and `Cow`
[INFO] [stdout]   --> src/server/boundary.rs:12:19
[INFO] [stdout]    |
[INFO] [stdout] 12 | use std::borrow::{Borrow, Cow};
[INFO] [stdout]    |                   ^^^^^^  ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::error::Error`
[INFO] [stdout]   --> src/server/boundary.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 13 | use std::error::Error;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::io`
[INFO] [stdout]   --> src/server/boundary.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 15 | use std::io;
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::fmt::Debug`
[INFO] [stdout]    --> src/server/boundary.rs:479:9
[INFO] [stdout]     |
[INFO] [stdout] 479 |     use std::fmt::Debug;
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::io::prelude::*`
[INFO] [stdout]    --> src/server/boundary.rs:481:9
[INFO] [stdout]     |
[INFO] [stdout] 481 |     use std::io::prelude::*;
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Async` and `Future`
[INFO] [stdout]  --> src/server/field/mod.rs:7:15
[INFO] [stdout]   |
[INFO] [stdout] 7 | use futures::{Future, Stream, Async, Poll};
[INFO] [stdout]   |               ^^^^^^          ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `futures::Async::*`
[INFO] [stdout]  --> src/server/field/mod.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use futures::Async::*;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Mime` and `self`
[INFO] [stdout]   --> src/server/field/mod.rs:10:12
[INFO] [stdout]    |
[INFO] [stdout] 10 | use mime::{self, Mime};
[INFO] [stdout]    |            ^^^^  ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `io`, `mem`, and `str`
[INFO] [stdout]   --> src/server/field/mod.rs:13:11
[INFO] [stdout]    |
[INFO] [stdout] 13 | use std::{io, mem, str};
[INFO] [stdout]    |           ^^  ^^^  ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `helpers::*`
[INFO] [stdout]   --> src/server/field/mod.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 18 | use helpers::*;
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `self::httparse::EMPTY_HEADER`
[INFO] [stdout]   --> src/server/field/mod.rs:21:5
[INFO] [stdout]    |
[INFO] [stdout] 21 | use self::httparse::EMPTY_HEADER;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `futures::Async::*`
[INFO] [stdout]  --> src/server/field/collect.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use futures::Async::*;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `server::boundary::BoundaryFinder`
[INFO] [stdout]  --> src/server/field/collect.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 | use server::boundary::BoundaryFinder;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Internal`
[INFO] [stdout]   --> src/server/field/collect.rs:10:14
[INFO] [stdout]    |
[INFO] [stdout] 10 | use server::{Internal, BodyChunk, StreamError};
[INFO] [stdout]    |              ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trailing semicolon in macro used in expression position
[INFO] [stdout]    --> src/server/mod.rs:47:41
[INFO] [stdout]     |
[INFO] [stdout]  47 |         return ::helpers::error($string);
[INFO] [stdout]     |                                         ^
[INFO] [stdout]     |
[INFO] [stdout]    ::: src/server/field/collect.rs:159:25
[INFO] [stdout]     |
[INFO] [stdout] 159 |                 None => ret_err!("unexpected end of stream while decoding a UTF-8 sequence"),
[INFO] [stdout]     |                         -------------------------------------------------------------------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
[INFO] [stdout]     = note: for more information, see issue #79813 <https://github.com/rust-lang/rust/issues/79813>
[INFO] [stdout]     = note: `#[warn(semicolon_in_expressions_from_macros)]` (part of `#[warn(future_incompatible)]`) on by default
[INFO] [stdout]     = note: this warning originates in the macro `ret_err` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Poll`
[INFO] [stdout]  --> src/server/field/headers.rs:1:15
[INFO] [stdout]   |
[INFO] [stdout] 1 | use futures::{Poll, Stream};
[INFO] [stdout]   |               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `io`
[INFO] [stdout]  --> src/server/field/headers.rs:5:11
[INFO] [stdout]   |
[INFO] [stdout] 5 | use std::{io, str};
[INFO] [stdout]   |           ^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Multipart`
[INFO] [stdout]  --> src/server/field/headers.rs:7:14
[INFO] [stdout]   |
[INFO] [stdout] 7 | use server::{Multipart, BodyChunk, StreamError, httparse, twoway};
[INFO] [stdout]   |              ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trailing semicolon in macro used in expression position
[INFO] [stdout]    --> src/server/mod.rs:50:61
[INFO] [stdout]     |
[INFO] [stdout]  50 |         return ::helpers::error(format!($string, $($args)*));
[INFO] [stdout]     |                                                             ^
[INFO] [stdout]     |
[INFO] [stdout]    ::: src/server/field/headers.rs:139:32
[INFO] [stdout]     |
[INFO] [stdout] 139 |         Ok(Status::Partial) => ret_err!("field headers incomplete: {}", show_bytes(bytes)),
[INFO] [stdout]     |                                ----------------------------------------------------------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
[INFO] [stdout]     = note: for more information, see issue #79813 <https://github.com/rust-lang/rust/issues/79813>
[INFO] [stdout]     = note: this warning originates in the macro `ret_err` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trailing semicolon in macro used in expression position
[INFO] [stdout]    --> src/server/mod.rs:50:61
[INFO] [stdout]     |
[INFO] [stdout]  50 |         return ::helpers::error(format!($string, $($args)*));
[INFO] [stdout]     |                                                             ^
[INFO] [stdout]     |
[INFO] [stdout]    ::: src/server/field/headers.rs:140:19
[INFO] [stdout]     |
[INFO] [stdout] 140 |         Err(e) => ret_err!("error parsing headers: {}; from buffer: {}", e, show_bytes(bytes)),
[INFO] [stdout]     |                   ---------------------------------------------------------------------------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
[INFO] [stdout]     = note: for more information, see issue #79813 <https://github.com/rust-lang/rust/issues/79813>
[INFO] [stdout]     = note: this warning originates in the macro `ret_err` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trailing semicolon in macro used in expression position
[INFO] [stdout]    --> src/server/mod.rs:50:61
[INFO] [stdout]     |
[INFO] [stdout]  50 |         return ::helpers::error(format!($string, $($args)*));
[INFO] [stdout]     |                                                             ^
[INFO] [stdout]     |
[INFO] [stdout]    ::: src/server/field/headers.rs:153:31
[INFO] [stdout]     |
[INFO] [stdout] 153 |                  .or_else(|_| ret_err!("could not parse MIME type from {:?}", str_val))?),
[INFO] [stdout]     |                               -------------------------------------------------------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
[INFO] [stdout]     = note: for more information, see issue #79813 <https://github.com/rust-lang/rust/issues/79813>
[INFO] [stdout]     = note: this warning originates in the macro `ret_err` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trailing semicolon in macro used in expression position
[INFO] [stdout]    --> src/server/mod.rs:50:61
[INFO] [stdout]     |
[INFO] [stdout]  50 |         return ::helpers::error(format!($string, $($args)*));
[INFO] [stdout]     |                                                             ^
[INFO] [stdout]     |
[INFO] [stdout]    ::: src/server/field/headers.rs:167:24
[INFO] [stdout]     |
[INFO] [stdout] 167 |         Some(other) => ret_err!("unexpected multipart field Content-Disposition: {}", other),
[INFO] [stdout]     |                        --------------------------------------------------------------------- in this macro invocation
[INFO] [stdout]     |
[INFO] [stdout]     = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
[INFO] [stdout]     = note: for more information, see issue #79813 <https://github.com/rust-lang/rust/issues/79813>
[INFO] [stdout]     = note: this warning originates in the macro `ret_err` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Stream`
[INFO] [stdout]  --> src/helpers.rs:7:22
[INFO] [stdout]   |
[INFO] [stdout] 7 | use futures::{Async, Stream};
[INFO] [stdout]   |                      ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::error::Error`
[INFO] [stdout]   --> src/helpers.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | use std::error::Error;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::io`
[INFO] [stdout]   --> src/helpers.rs:11:5
[INFO] [stdout]    |
[INFO] [stdout] 11 | use std::io;
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated method `core::str::<impl str>::trim_left_matches`: superseded by `trim_start_matches`
[INFO] [stdout]    --> src/server/field/headers.rs:198:28
[INFO] [stdout]     |
[INFO] [stdout] 198 |     let mut splits = input.trim_left_matches(&[' ', ';'][..]).splitn(1, '=');
[INFO] [stdout]     |                            ^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] help: replace the use of the deprecated method
[INFO] [stdout]     |
[INFO] [stdout] 198 -     let mut splits = input.trim_left_matches(&[' ', ';'][..]).splitn(1, '=');
[INFO] [stdout] 198 +     let mut splits = input.trim_start_matches(&[' ', ';'][..]).splitn(1, '=');
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::io::prelude`
[INFO] [stdout]   --> src/server/mod.rs:28:5
[INFO] [stdout]    |
[INFO] [stdout] 28 | use std::io::prelude::*;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::fmt::Write`
[INFO] [stdout]    --> src/server/boundary.rs:395:13
[INFO] [stdout]     |
[INFO] [stdout] 395 |         use std::fmt::Write;
[INFO] [stdout]     |             ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Future`
[INFO] [stdout]    --> src/server/boundary.rs:476:19
[INFO] [stdout]     |
[INFO] [stdout] 476 |     use futures::{Future, Stream, Poll};
[INFO] [stdout]     |                   ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `len`
[INFO] [stdout]    --> src/server/boundary.rs:313:13
[INFO] [stdout]     |
[INFO] [stdout] 313 |         let len = boundary.len();
[INFO] [stdout]     |             ^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: if this is intentional, prefix it with an underscore
[INFO] [stdout]     |
[INFO] [stdout] 313 |         let _len = boundary.len();
[INFO] [stdout]     |             +
[INFO] [stdout] help: you might have meant to pattern match on the similarly named constant `MAX_HEADERS`
[INFO] [stdout]     |
[INFO] [stdout] 313 -         let len = boundary.len();
[INFO] [stdout] 313 +         let server::field::headers::MAX_HEADERS = boundary.len();
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/server/field/collect.rs:122:17
[INFO] [stdout]     |
[INFO] [stdout] 122 |             let mut stream = data.stream_mut();
[INFO] [stdout]     |                 ----^^^^^^
[INFO] [stdout]     |                 |
[INFO] [stdout]     |                 help: remove this `mut`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `random_alphanumeric` is never used
[INFO] [stdout]   --> src/lib.rs:56:4
[INFO] [stdout]    |
[INFO] [stdout] 56 | fn random_alphanumeric(len: usize) -> String {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `maybe_boundary` is never used
[INFO] [stdout]    --> src/server/boundary.rs:261:8
[INFO] [stdout]     |
[INFO] [stdout]  98 | impl<S: Stream> BoundaryFinder<S> where S::Item: BodyChunk, S::Error: StreamError {
[INFO] [stdout]     | --------------------------------------------------------------------------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 261 |     fn maybe_boundary(&self, bytes: &[u8]) -> bool {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]   --> src/server/field/headers.rs:56:20
[INFO] [stdout]    |
[INFO] [stdout] 56 |     pub fn charset(&self) -> Option<Name> {
[INFO] [stdout]    |                    ^^^^^            ^^^^ the same lifetime is hidden here
[INFO] [stdout]    |                    |
[INFO] [stdout]    |                    the lifetime is elided here
[INFO] [stdout]    |
[INFO] [stdout]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]    = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]    |
[INFO] [stdout] 56 |     pub fn charset(&self) -> Option<Name<'_>> {
[INFO] [stdout]    |                                         ++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.93s
[INFO] [stderr] warning: the following packages contain code that will be rejected by a future version of Rust: multipart-async v0.0.2 (/opt/rustwide/workdir)
[INFO] [stderr] note: to see what the problems were, use the option `--future-incompat-report`, or run `cargo report future-incompatibilities --id 2`
[INFO] running `Command { std: "docker" "inspect" "2547ac752d7635624a0d510e852aeec7b294d90ca871f5c9e1e227ca59b9088d", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "2547ac752d7635624a0d510e852aeec7b294d90ca871f5c9e1e227ca59b9088d", kill_on_drop: false }`
[INFO] [stdout] 2547ac752d7635624a0d510e852aeec7b294d90ca871f5c9e1e227ca59b9088d
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/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" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:4848fb76d95f26979359cc7e45710b1dbc8f3acb7aeedee7c460d7702230f228" "/opt/rustwide/cargo-home/bin/cargo" "+1.91.0" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] 8c3da729fb2b882974f5b840155f2f6679e31127a663e40383a4e7787f74ab9d
[INFO] running `Command { std: "docker" "start" "-a" "8c3da729fb2b882974f5b840155f2f6679e31127a663e40383a4e7787f74ab9d", kill_on_drop: false }`
[INFO] [stderr] warning: no edition set: defaulting to the 2015 edition while the latest is 2024
[INFO] [stderr] warning: unused import: `std::rc::Rc`
[INFO] [stderr]   --> src/lib.rs:41:5
[INFO] [stderr]    |
[INFO] [stderr] 41 | use std::rc::Rc;
[INFO] [stderr]    |     ^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::sync::Arc`
[INFO] [stderr]   --> src/lib.rs:42:5
[INFO] [stderr]    |
[INFO] [stderr] 42 | use std::sync::Arc;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `mime::Mime`
[INFO] [stderr]   --> src/server/mod.rs:20:5
[INFO] [stderr]    |
[INFO] [stderr] 20 | use mime::Mime;
[INFO] [stderr]    |     ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `tempdir::TempDir`
[INFO] [stderr]   --> src/server/mod.rs:22:5
[INFO] [stderr]    |
[INFO] [stderr] 22 | use tempdir::TempDir;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::borrow::Borrow`
[INFO] [stderr]   --> src/server/mod.rs:24:5
[INFO] [stderr]    |
[INFO] [stderr] 24 | use std::borrow::Borrow;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::collections::VecDeque`
[INFO] [stderr]   --> src/server/mod.rs:26:5
[INFO] [stderr]    |
[INFO] [stderr] 26 | use std::collections::VecDeque;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `File` and `self`
[INFO] [stderr]   --> src/server/mod.rs:27:15
[INFO] [stderr]    |
[INFO] [stderr] 27 | use std::fs::{self, File};
[INFO] [stderr]    |               ^^^^  ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `PathBuf` and `Path`
[INFO] [stderr]   --> src/server/mod.rs:29:17
[INFO] [stderr]    |
[INFO] [stderr] 29 | use std::path::{Path, PathBuf};
[INFO] [stderr]    |                 ^^^^  ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `fmt`, `mem`, and `ptr`
[INFO] [stderr]   --> src/server/mod.rs:32:11
[INFO] [stderr]    |
[INFO] [stderr] 32 | use std::{fmt, io, mem, ptr};
[INFO] [stderr]    |           ^^^      ^^^  ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::cmp`
[INFO] [stderr]   --> src/server/boundary.rs:11:5
[INFO] [stderr]    |
[INFO] [stderr] 11 | use std::cmp;
[INFO] [stderr]    |     ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `Borrow` and `Cow`
[INFO] [stderr]   --> src/server/boundary.rs:12:19
[INFO] [stderr]    |
[INFO] [stderr] 12 | use std::borrow::{Borrow, Cow};
[INFO] [stderr]    |                   ^^^^^^  ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::error::Error`
[INFO] [stderr]   --> src/server/boundary.rs:13:5
[INFO] [stderr]    |
[INFO] [stderr] 13 | use std::error::Error;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::io`
[INFO] [stderr]   --> src/server/boundary.rs:15:5
[INFO] [stderr]    |
[INFO] [stderr] 15 | use std::io;
[INFO] [stderr]    |     ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `Async` and `Future`
[INFO] [stderr]  --> src/server/field/mod.rs:7:15
[INFO] [stderr]   |
[INFO] [stderr] 7 | use futures::{Future, Stream, Async, Poll};
[INFO] [stderr]   |               ^^^^^^          ^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `futures::Async::*`
[INFO] [stderr]  --> src/server/field/mod.rs:8:5
[INFO] [stderr]   |
[INFO] [stderr] 8 | use futures::Async::*;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `Mime` and `self`
[INFO] [stderr]   --> src/server/field/mod.rs:10:12
[INFO] [stderr]    |
[INFO] [stderr] 10 | use mime::{self, Mime};
[INFO] [stderr]    |            ^^^^  ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused imports: `io`, `mem`, and `str`
[INFO] [stderr]   --> src/server/field/mod.rs:13:11
[INFO] [stderr]    |
[INFO] [stderr] 13 | use std::{io, mem, str};
[INFO] [stderr]    |           ^^  ^^^  ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `helpers::*`
[INFO] [stderr]   --> src/server/field/mod.rs:18:5
[INFO] [stderr]    |
[INFO] [stderr] 18 | use helpers::*;
[INFO] [stderr]    |     ^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `self::httparse::EMPTY_HEADER`
[INFO] [stderr]   --> src/server/field/mod.rs:21:5
[INFO] [stderr]    |
[INFO] [stderr] 21 | use self::httparse::EMPTY_HEADER;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `futures::Async::*`
[INFO] [stderr]  --> src/server/field/collect.rs:2:5
[INFO] [stderr]   |
[INFO] [stderr] 2 | use futures::Async::*;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `server::boundary::BoundaryFinder`
[INFO] [stderr]  --> src/server/field/collect.rs:9:5
[INFO] [stderr]   |
[INFO] [stderr] 9 | use server::boundary::BoundaryFinder;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Internal`
[INFO] [stderr]   --> src/server/field/collect.rs:10:14
[INFO] [stderr]    |
[INFO] [stderr] 10 | use server::{Internal, BodyChunk, StreamError};
[INFO] [stderr]    |              ^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: trailing semicolon in macro used in expression position
[INFO] [stderr]    --> src/server/mod.rs:47:41
[INFO] [stderr]     |
[INFO] [stderr]  47 |         return ::helpers::error($string);
[INFO] [stderr]     |                                         ^
[INFO] [stderr]     |
[INFO] [stderr]    ::: src/server/field/collect.rs:159:25
[INFO] [stderr]     |
[INFO] [stderr] 159 |                 None => ret_err!("unexpected end of stream while decoding a UTF-8 sequence"),
[INFO] [stderr]     |                         -------------------------------------------------------------------- in this macro invocation
[INFO] [stderr]     |
[INFO] [stderr]     = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
[INFO] [stderr]     = note: for more information, see issue #79813 <https://github.com/rust-lang/rust/issues/79813>
[INFO] [stderr]     = note: `#[warn(semicolon_in_expressions_from_macros)]` (part of `#[warn(future_incompatible)]`) on by default
[INFO] [stderr]     = note: this warning originates in the macro `ret_err` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Poll`
[INFO] [stderr]  --> src/server/field/headers.rs:1:15
[INFO] [stderr]   |
[INFO] [stderr] 1 | use futures::{Poll, Stream};
[INFO] [stderr]   |               ^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `io`
[INFO] [stderr]  --> src/server/field/headers.rs:5:11
[INFO] [stderr]   |
[INFO] [stderr] 5 | use std::{io, str};
[INFO] [stderr]   |           ^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Multipart`
[INFO] [stderr]  --> src/server/field/headers.rs:7:14
[INFO] [stderr]   |
[INFO] [stderr] 7 | use server::{Multipart, BodyChunk, StreamError, httparse, twoway};
[INFO] [stderr]   |              ^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: trailing semicolon in macro used in expression position
[INFO] [stderr]    --> src/server/mod.rs:50:61
[INFO] [stderr]     |
[INFO] [stderr]  50 |         return ::helpers::error(format!($string, $($args)*));
[INFO] [stderr]     |                                                             ^
[INFO] [stderr]     |
[INFO] [stderr]    ::: src/server/field/headers.rs:139:32
[INFO] [stderr]     |
[INFO] [stderr] 139 |         Ok(Status::Partial) => ret_err!("field headers incomplete: {}", show_bytes(bytes)),
[INFO] [stderr]     |                                ----------------------------------------------------------- in this macro invocation
[INFO] [stderr]     |
[INFO] [stderr]     = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
[INFO] [stderr]     = note: for more information, see issue #79813 <https://github.com/rust-lang/rust/issues/79813>
[INFO] [stderr]     = note: this warning originates in the macro `ret_err` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] 
[INFO] [stderr] warning: trailing semicolon in macro used in expression position
[INFO] [stderr]    --> src/server/mod.rs:50:61
[INFO] [stderr]     |
[INFO] [stderr]  50 |         return ::helpers::error(format!($string, $($args)*));
[INFO] [stderr]     |                                                             ^
[INFO] [stderr]     |
[INFO] [stderr]    ::: src/server/field/headers.rs:140:19
[INFO] [stderr]     |
[INFO] [stderr] 140 |         Err(e) => ret_err!("error parsing headers: {}; from buffer: {}", e, show_bytes(bytes)),
[INFO] [stderr]     |                   ---------------------------------------------------------------------------- in this macro invocation
[INFO] [stderr]     |
[INFO] [stderr]     = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
[INFO] [stderr]     = note: for more information, see issue #79813 <https://github.com/rust-lang/rust/issues/79813>
[INFO] [stderr]     = note: this warning originates in the macro `ret_err` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] 
[INFO] [stderr] warning: trailing semicolon in macro used in expression position
[INFO] [stderr]    --> src/server/mod.rs:50:61
[INFO] [stderr]     |
[INFO] [stderr]  50 |         return ::helpers::error(format!($string, $($args)*));
[INFO] [stderr]     |                                                             ^
[INFO] [stderr]     |
[INFO] [stderr]    ::: src/server/field/headers.rs:153:31
[INFO] [stderr]     |
[INFO] [stderr] 153 |                  .or_else(|_| ret_err!("could not parse MIME type from {:?}", str_val))?),
[INFO] [stderr]     |                               -------------------------------------------------------- in this macro invocation
[INFO] [stderr]     |
[INFO] [stderr]     = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
[INFO] [stderr]     = note: for more information, see issue #79813 <https://github.com/rust-lang/rust/issues/79813>
[INFO] [stderr]     = note: this warning originates in the macro `ret_err` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] 
[INFO] [stderr] warning: trailing semicolon in macro used in expression position
[INFO] [stderr]    --> src/server/mod.rs:50:61
[INFO] [stderr]     |
[INFO] [stderr]  50 |         return ::helpers::error(format!($string, $($args)*));
[INFO] [stderr]     |                                                             ^
[INFO] [stderr]     |
[INFO] [stderr]    ::: src/server/field/headers.rs:167:24
[INFO] [stderr]     |
[INFO] [stderr] 167 |         Some(other) => ret_err!("unexpected multipart field Content-Disposition: {}", other),
[INFO] [stderr]     |                        --------------------------------------------------------------------- in this macro invocation
[INFO] [stderr]     |
[INFO] [stderr]     = warning: this was previously accepted by the compiler but is being phased out; it will become a hard error in a future release!
[INFO] [stderr]     = note: for more information, see issue #79813 <https://github.com/rust-lang/rust/issues/79813>
[INFO] [stderr]     = note: this warning originates in the macro `ret_err` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Stream`
[INFO] [stderr]  --> src/helpers.rs:7:22
[INFO] [stderr]   |
[INFO] [stderr] 7 | use futures::{Async, Stream};
[INFO] [stderr]   |                      ^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::error::Error`
[INFO] [stderr]   --> src/helpers.rs:10:5
[INFO] [stderr]    |
[INFO] [stderr] 10 | use std::error::Error;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::io`
[INFO] [stderr]   --> src/helpers.rs:11:5
[INFO] [stderr]    |
[INFO] [stderr] 11 | use std::io;
[INFO] [stderr]    |     ^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated method `core::str::<impl str>::trim_left_matches`: superseded by `trim_start_matches`
[INFO] [stderr]    --> src/server/field/headers.rs:198:28
[INFO] [stderr]     |
[INFO] [stderr] 198 |     let mut splits = input.trim_left_matches(&[' ', ';'][..]).splitn(1, '=');
[INFO] [stderr]     |                            ^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(deprecated)]` on by default
[INFO] [stderr] help: replace the use of the deprecated method
[INFO] [stderr]     |
[INFO] [stderr] 198 -     let mut splits = input.trim_left_matches(&[' ', ';'][..]).splitn(1, '=');
[INFO] [stderr] 198 +     let mut splits = input.trim_start_matches(&[' ', ';'][..]).splitn(1, '=');
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::io::prelude`
[INFO] [stderr]   --> src/server/mod.rs:28:5
[INFO] [stderr]    |
[INFO] [stderr] 28 | use std::io::prelude::*;
[INFO] [stderr]    |     ^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::fmt::Write`
[INFO] [stderr]    --> src/server/boundary.rs:395:13
[INFO] [stderr]     |
[INFO] [stderr] 395 |         use std::fmt::Write;
[INFO] [stderr]     |             ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `len`
[INFO] [stderr]    --> src/server/boundary.rs:313:13
[INFO] [stderr]     |
[INFO] [stderr] 313 |         let len = boundary.len();
[INFO] [stderr]     |             ^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] help: if this is intentional, prefix it with an underscore
[INFO] [stderr]     |
[INFO] [stderr] 313 |         let _len = boundary.len();
[INFO] [stderr]     |             +
[INFO] [stderr] help: you might have meant to pattern match on the similarly named constant `MAX_HEADERS`
[INFO] [stderr]     |
[INFO] [stderr] 313 -         let len = boundary.len();
[INFO] [stderr] 313 +         let server::field::headers::MAX_HEADERS = boundary.len();
[INFO] [stderr]     |
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]    --> src/server/field/collect.rs:122:17
[INFO] [stderr]     |
[INFO] [stderr] 122 |             let mut stream = data.stream_mut();
[INFO] [stderr]     |                 ----^^^^^^
[INFO] [stderr]     |                 |
[INFO] [stderr]     |                 help: remove this `mut`
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: function `random_alphanumeric` is never used
[INFO] [stderr]   --> src/lib.rs:56:4
[INFO] [stderr]    |
[INFO] [stderr] 56 | fn random_alphanumeric(len: usize) -> String {
[INFO] [stderr]    |    ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stderr] 
[INFO] [stderr] warning: methods `maybe_boundary`, `check_boundary`, `consume_boundary`, `confirm_boundary`, and `confirm_boundary_split` are never used
[INFO] [stderr]    --> src/server/boundary.rs:261:8
[INFO] [stderr]     |
[INFO] [stderr]  98 | impl<S: Stream> BoundaryFinder<S> where S::Item: BodyChunk, S::Error: StreamError {
[INFO] [stderr]     | --------------------------------------------------------------------------------- methods in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 261 |     fn maybe_boundary(&self, bytes: &[u8]) -> bool {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 266 |     fn check_boundary(&self, bytes: &[u8]) -> bool {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 278 |     pub fn consume_boundary(&mut self) -> Poll<bool, S::Error> {
[INFO] [stderr]     |            ^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 290 |     fn confirm_boundary(&mut self, boundary: S::Item) -> Poll<bool, S::Error> {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^^
[INFO] [stderr] ...
[INFO] [stderr] 324 |     fn confirm_boundary_split(&mut self, first: S::Item, second: S::Item) -> Poll<bool, S::Error> {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: variant `End` is never constructed
[INFO] [stderr]    --> src/server/boundary.rs:390:5
[INFO] [stderr]     |
[INFO] [stderr] 381 | enum State<B> {
[INFO] [stderr]     |      ----- variant in this enum
[INFO] [stderr] ...
[INFO] [stderr] 390 |     End,
[INFO] [stderr]     |     ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `check_last_two` is never used
[INFO] [stderr]    --> src/server/boundary.rs:438:4
[INFO] [stderr]     |
[INFO] [stderr] 438 | fn check_last_two(boundary: &[u8]) -> bool {
[INFO] [stderr]     |    ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stderr]   --> src/server/field/headers.rs:56:20
[INFO] [stderr]    |
[INFO] [stderr] 56 |     pub fn charset(&self) -> Option<Name> {
[INFO] [stderr]    |                    ^^^^^            ^^^^ the same lifetime is hidden here
[INFO] [stderr]    |                    |
[INFO] [stderr]    |                    the lifetime is elided here
[INFO] [stderr]    |
[INFO] [stderr]    = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stderr]    = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stderr] help: use `'_` for type paths
[INFO] [stderr]    |
[INFO] [stderr] 56 |     pub fn charset(&self) -> Option<Name<'_>> {
[INFO] [stderr]    |                                         ++++
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::fmt::Debug`
[INFO] [stderr]    --> src/server/boundary.rs:479:9
[INFO] [stderr]     |
[INFO] [stderr] 479 |     use std::fmt::Debug;
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::io::prelude::*`
[INFO] [stderr]    --> src/server/boundary.rs:481:9
[INFO] [stderr]     |
[INFO] [stderr] 481 |     use std::io::prelude::*;
[INFO] [stderr]     |         ^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `Future`
[INFO] [stderr]    --> src/server/boundary.rs:476:19
[INFO] [stderr]     |
[INFO] [stderr] 476 |     use futures::{Future, Stream, Poll};
[INFO] [stderr]     |                   ^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: method `maybe_boundary` is never used
[INFO] [stderr]    --> src/server/boundary.rs:261:8
[INFO] [stderr]     |
[INFO] [stderr]  98 | impl<S: Stream> BoundaryFinder<S> where S::Item: BodyChunk, S::Error: StreamError {
[INFO] [stderr]     | --------------------------------------------------------------------------------- method in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 261 |     fn maybe_boundary(&self, bytes: &[u8]) -> bool {
[INFO] [stderr]     |        ^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: `multipart-async` (lib) generated 43 warnings (run `cargo fix --lib -p multipart-async` to apply 32 suggestions)
[INFO] [stderr] warning: `multipart-async` (lib test) generated 44 warnings (40 duplicates) (run `cargo fix --lib -p multipart-async --tests` to apply 2 suggestions)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.13s
[INFO] [stderr] warning: the following packages contain code that will be rejected by a future version of Rust: multipart-async v0.0.2 (/opt/rustwide/workdir)
[INFO] [stderr] note: to see what the problems were, use the option `--future-incompat-report`, or run `cargo report future-incompatibilities --id 2`
[INFO] [stderr]      Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/multipart_async-e41f5b9414c2f609)
[INFO] [stdout] 
[INFO] [stdout] running 5 tests
[INFO] [stdout] test server::boundary::test::split_mid_bnd ... ok
[INFO] [stdout] test server::boundary::test::two_parts ... ok
[INFO] [stdout] test server::boundary::test::simple ... ok
[INFO] [stdout] test server::boundary::test::split_repeat_once ... ok
[INFO] [stdout] test server::field::headers::test_header_end_split ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 5 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.01s
[INFO] [stdout] 
[INFO] [stderr]    Doc-tests multipart_async
[INFO] [stdout] 
[INFO] [stdout] running 0 tests
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 0 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s
[INFO] [stdout] 
[INFO] running `Command { std: "docker" "inspect" "8c3da729fb2b882974f5b840155f2f6679e31127a663e40383a4e7787f74ab9d", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "8c3da729fb2b882974f5b840155f2f6679e31127a663e40383a4e7787f74ab9d", kill_on_drop: false }`
[INFO] [stdout] 8c3da729fb2b882974f5b840155f2f6679e31127a663e40383a4e7787f74ab9d
