[INFO] updating cached repository https://github.com/ghl3/hermes
[INFO] running `"git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "-c" "remote.origin.fetch=refs/heads/*:refs/heads/*" "fetch" "origin" "--force" "--prune"`
[INFO] running `"git" "rev-parse" "HEAD"`
[INFO] [stdout] 79fa0bec5bd14fb3ef317a56d7ef25d75860ef5f
[INFO] checking ghl3/hermes against master#bf1f2eedda4fa02b7c9347dd849ed73ddd43dedc for pr-70917
[INFO] running `"git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fghl3%2Fhermes" "/workspace/builds/worker-6/source"`
[INFO] [stderr] Cloning into '/workspace/builds/worker-6/source'...
[INFO] [stderr] done.
[INFO] validating manifest of git repo https://github.com/ghl3/hermes on toolchain bf1f2eedda4fa02b7c9347dd849ed73ddd43dedc
[INFO] running `"/workspace/cargo-home/bin/cargo" "+bf1f2eedda4fa02b7c9347dd849ed73ddd43dedc" "read-manifest" "--manifest-path" "Cargo.toml"`
[INFO] started tweaking git repo https://github.com/ghl3/hermes
[INFO] finished tweaking git repo https://github.com/ghl3/hermes
[INFO] tweaked toml for git repo https://github.com/ghl3/hermes written to /workspace/builds/worker-6/source/Cargo.toml
[INFO] crate git repo https://github.com/ghl3/hermes already has a lockfile, it will not be regenerated
[INFO] running `"/workspace/cargo-home/bin/cargo" "+bf1f2eedda4fa02b7c9347dd849ed73ddd43dedc" "fetch" "--locked" "--manifest-path" "Cargo.toml"`
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr] error: the lock file /workspace/builds/worker-6/source/Cargo.lock needs to be updated but --locked was passed to prevent this
[INFO] [stderr] If you want to try to generate the lock file without accessing the network, use the --offline flag.
[INFO] the lockfile is outdated, regenerating it
[INFO] running `"/workspace/cargo-home/bin/cargo" "+bf1f2eedda4fa02b7c9347dd849ed73ddd43dedc" "generate-lockfile" "--manifest-path" "Cargo.toml" "-Zno-index-update"`
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] running `"/workspace/cargo-home/bin/cargo" "+bf1f2eedda4fa02b7c9347dd849ed73ddd43dedc" "fetch" "--locked" "--manifest-path" "Cargo.toml"`
[INFO] running `"docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "MAP_USER_ID=0" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--network" "none" "rustops/crates-build-env" "/opt/rustwide/cargo-home/bin/cargo" "+bf1f2eedda4fa02b7c9347dd849ed73ddd43dedc" "check" "--frozen" "--all" "--all-targets"`
[INFO] [stdout] bb64eb0cd8327d3f1abbe70861dac0845bdad524b11c49045092a8d669eb8b32
[INFO] [stderr] WARNING: Your kernel does not support swap limit capabilities or the cgroup is not mounted. Memory limited without swap.
[INFO] running `"docker" "start" "-a" "bb64eb0cd8327d3f1abbe70861dac0845bdad524b11c49045092a8d669eb8b32"`
[INFO] [stderr]     Checking strsim v0.5.2
[INFO] [stderr]     Checking chunked_transfer v0.3.1
[INFO] [stderr]     Checking ascii v0.7.1
[INFO] [stderr]     Checking memchr v0.1.11
[INFO] [stderr]     Checking uuid v0.1.18
[INFO] [stderr]     Checking url v0.5.10
[INFO] [stderr]     Checking num v0.1.42
[INFO] [stderr]     Checking thread-id v2.0.0
[INFO] [stderr]     Checking thread_local v0.2.7
[INFO] [stderr]     Checking chrono v0.2.25
[INFO] [stderr]     Checking aho-corasick v0.5.3
[INFO] [stderr]     Checking url v0.2.38
[INFO] [stderr]     Checking regex v0.1.80
[INFO] [stderr]     Checking tiny_http v0.5.9
[INFO] [stderr]     Checking docopt v0.6.86
[INFO] [stderr]     Checking hermes v0.1.0 (/opt/rustwide/workdir)
[INFO] [stderr] warning: use of deprecated item 'try': use the `?` operator instead
[INFO] [stderr]   --> src/router.rs:71:15
[INFO] [stderr]    |
[INFO] [stderr] 71 |     let url = try!(get_url(request));
[INFO] [stderr]    |               ^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(deprecated)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated item 'try': use the `?` operator instead
[INFO] [stderr]   --> src/router.rs:80:24
[INFO] [stderr]    |
[INFO] [stderr] 80 |             let json = try!(get_body_as_json(&mut request));
[INFO] [stderr]    |                        ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated item 'try': use the `?` operator instead
[INFO] [stderr]    --> src/router.rs:164:5
[INFO] [stderr]     |
[INFO] [stderr] 164 |     try!(request.as_reader().read_to_string(&mut content));
[INFO] [stderr]     |     ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated item 'try': use the `?` operator instead
[INFO] [stderr]    --> src/router.rs:165:22
[INFO] [stderr]     |
[INFO] [stderr] 165 |     let json: Json = try!(Json::from_str(&content));
[INFO] [stderr]     |                      ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated item 'try': use the `?` operator instead
[INFO] [stderr]    --> src/router.rs:171:8
[INFO] [stderr]     |
[INFO] [stderr] 171 |     Ok(try!(url_parser::parse_url_resource(request.url())))
[INFO] [stderr]     |        ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated item 'try': use the `?` operator instead
[INFO] [stderr]   --> src/table.rs:48:21
[INFO] [stderr]    |
[INFO] [stderr] 48 |         let table = try!(self.get_mut_table(table));
[INFO] [stderr]    |                     ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated item 'try': use the `?` operator instead
[INFO] [stderr]   --> src/table.rs:60:21
[INFO] [stderr]    |
[INFO] [stderr] 60 |         let table = try!(self.get_table(table));
[INFO] [stderr]    |                     ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated item 'try': use the `?` operator instead
[INFO] [stderr]   --> src/table.rs:70:21
[INFO] [stderr]    |
[INFO] [stderr] 70 |         let table = try!(self.get_mut_table(table));
[INFO] [stderr]    |                     ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `ok`
[INFO] [stderr]   --> src/router.rs:22:12
[INFO] [stderr]    |
[INFO] [stderr] 22 | use http::{ok, http_response};
[INFO] [stderr]    |            ^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_imports)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `if` condition
[INFO] [stderr]   --> src/url_parser.rs:51:12
[INFO] [stderr]    |
[INFO] [stderr] 51 |         if (location.len() == 0) {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^^^^^^^ help: remove these parentheses
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_parens)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `if` condition
[INFO] [stderr]   --> src/url_parser.rs:53:19
[INFO] [stderr]    |
[INFO] [stderr] 53 |         } else if (location.chars().nth(0).unwrap() != '/') {
[INFO] [stderr]    |                   ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: remove these parentheses
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `if` condition
[INFO] [stderr]   --> src/url_parser.rs:61:12
[INFO] [stderr]    |
[INFO] [stderr] 61 |         if (query == "") {
[INFO] [stderr]    |            ^^^^^^^^^^^^^ help: remove these parentheses
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `if` condition
[INFO] [stderr]   --> src/url_parser.rs:71:20
[INFO] [stderr]    |
[INFO] [stderr] 71 |                 if (param_pair_split.len() != 2) {
[INFO] [stderr]    |                    ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: remove these parentheses
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `rustc_serialize::json`
[INFO] [stderr]  --> src/api.rs:4:5
[INFO] [stderr]   |
[INFO] [stderr] 4 | use rustc_serialize::json;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `if` condition
[INFO] [stderr]   --> src/table.rs:24:12
[INFO] [stderr]    |
[INFO] [stderr] 24 |         if (self.data.contains_key(table)) {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: remove these parentheses
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `if` condition
[INFO] [stderr]   --> src/table.rs:50:12
[INFO] [stderr]    |
[INFO] [stderr] 50 |         if (table.contains_key(key)) {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^^^^^^^^^^^ help: remove these parentheses
[INFO] [stderr] 
[INFO] [stderr] error[E0433]: failed to resolve: use of undeclared type or module `http`
[INFO] [stderr]   --> src/router.rs:96:13
[INFO] [stderr]    |
[INFO] [stderr] 96 |     assert!(http::response_string(response) == http::response_string(ok("foobar")));
[INFO] [stderr]    |             ^^^^ use of undeclared type or module `http`
[INFO] [stderr] 
[INFO] [stderr] error[E0433]: failed to resolve: use of undeclared type or module `http`
[INFO] [stderr]   --> src/router.rs:96:48
[INFO] [stderr]    |
[INFO] [stderr] 96 |     assert!(http::response_string(response) == http::response_string(ok("foobar")));
[INFO] [stderr]    |                                                ^^^^ use of undeclared type or module `http`
[INFO] [stderr] 
[INFO] [stderr] error[E0425]: cannot find function `request_router` in this scope
[INFO] [stderr]   --> src/router.rs:95:20
[INFO] [stderr]    |
[INFO] [stderr] 95 |     let response = request_router(&Method::Post, UrlResource::from_resource("/foo").unwrap());
[INFO] [stderr]    |                    ^^^^^^^^^^^^^^ not found in this scope
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated item 'try': use the `?` operator instead
[INFO] [stderr]   --> src/router.rs:71:15
[INFO] [stderr]    |
[INFO] [stderr] 71 |     let url = try!(get_url(request));
[INFO] [stderr]    |               ^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(deprecated)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated item 'try': use the `?` operator instead
[INFO] [stderr]   --> src/router.rs:80:24
[INFO] [stderr]    |
[INFO] [stderr] 80 |             let json = try!(get_body_as_json(&mut request));
[INFO] [stderr]    |                        ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated item 'try': use the `?` operator instead
[INFO] [stderr]    --> src/router.rs:164:5
[INFO] [stderr]     |
[INFO] [stderr] 164 |     try!(request.as_reader().read_to_string(&mut content));
[INFO] [stderr]     |     ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated item 'try': use the `?` operator instead
[INFO] [stderr]    --> src/router.rs:165:22
[INFO] [stderr]     |
[INFO] [stderr] 165 |     let json: Json = try!(Json::from_str(&content));
[INFO] [stderr]     |                      ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated item 'try': use the `?` operator instead
[INFO] [stderr]    --> src/router.rs:171:8
[INFO] [stderr]     |
[INFO] [stderr] 171 |     Ok(try!(url_parser::parse_url_resource(request.url())))
[INFO] [stderr]     |        ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated item 'try': use the `?` operator instead
[INFO] [stderr]   --> src/table.rs:48:21
[INFO] [stderr]    |
[INFO] [stderr] 48 |         let table = try!(self.get_mut_table(table));
[INFO] [stderr]    |                     ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated item 'try': use the `?` operator instead
[INFO] [stderr]   --> src/table.rs:60:21
[INFO] [stderr]    |
[INFO] [stderr] 60 |         let table = try!(self.get_table(table));
[INFO] [stderr]    |                     ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated item 'try': use the `?` operator instead
[INFO] [stderr]   --> src/table.rs:70:21
[INFO] [stderr]    |
[INFO] [stderr] 70 |         let table = try!(self.get_mut_table(table));
[INFO] [stderr]    |                     ^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `if` condition
[INFO] [stderr]   --> src/url_parser.rs:51:12
[INFO] [stderr]    |
[INFO] [stderr] 51 |         if (location.len() == 0) {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^^^^^^^ help: remove these parentheses
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_parens)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `if` condition
[INFO] [stderr]   --> src/url_parser.rs:53:19
[INFO] [stderr]    |
[INFO] [stderr] 53 |         } else if (location.chars().nth(0).unwrap() != '/') {
[INFO] [stderr]    |                   ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: remove these parentheses
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `if` condition
[INFO] [stderr]   --> src/url_parser.rs:61:12
[INFO] [stderr]    |
[INFO] [stderr] 61 |         if (query == "") {
[INFO] [stderr]    |            ^^^^^^^^^^^^^ help: remove these parentheses
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `if` condition
[INFO] [stderr]   --> src/url_parser.rs:71:20
[INFO] [stderr]    |
[INFO] [stderr] 71 |                 if (param_pair_split.len() != 2) {
[INFO] [stderr]    |                    ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: remove these parentheses
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `rustc_serialize::json`
[INFO] [stderr]  --> src/api.rs:4:5
[INFO] [stderr]   |
[INFO] [stderr] 4 | use rustc_serialize::json;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `if` condition
[INFO] [stderr]   --> src/table.rs:24:12
[INFO] [stderr]    |
[INFO] [stderr] 24 |         if (self.data.contains_key(table)) {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: remove these parentheses
[INFO] [stderr] 
[INFO] [stderr] warning: unnecessary parentheses around `if` condition
[INFO] [stderr]   --> src/table.rs:50:12
[INFO] [stderr]    |
[INFO] [stderr] 50 |         if (table.contains_key(key)) {
[INFO] [stderr]    |            ^^^^^^^^^^^^^^^^^^^^^^^^^ help: remove these parentheses
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated item 'std::error::Error::description': use the Display impl or to_string()
[INFO] [stderr]    --> src/router.rs:136:53
[INFO] [stderr]     |
[INFO] [stderr] 136 |             RequestError::ReadError(ref err) => err.description(),
[INFO] [stderr]     |                                                     ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated item 'std::error::Error::description': use the Display impl or to_string()
[INFO] [stderr]    --> src/router.rs:137:58
[INFO] [stderr]     |
[INFO] [stderr] 137 |             RequestError::JsonParseError(ref err) => err.description(),
[INFO] [stderr]     |                                                          ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated item 'std::error::Error::description': use the Display impl or to_string()
[INFO] [stderr]    --> src/router.rs:138:57
[INFO] [stderr]     |
[INFO] [stderr] 138 |             RequestError::UrlParseError(ref err) => err.description(),
[INFO] [stderr]     |                                                         ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::fmt::Display`
[INFO] [stderr]  --> src/router.rs:5:5
[INFO] [stderr]   |
[INFO] [stderr] 5 | use std::fmt::Display;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::io::Read`
[INFO] [stderr]  --> src/router.rs:6:5
[INFO] [stderr]   |
[INFO] [stderr] 6 | use std::io::Read;
[INFO] [stderr]   |     ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `method`
[INFO] [stderr]   --> src/router.rs:88:10
[INFO] [stderr]    |
[INFO] [stderr] 88 |         (method, location) => Err(RequestError::UnknownResource),
[INFO] [stderr]    |          ^^^^^^ help: if this is intentional, prefix it with an underscore: `_method`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_variables)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused variable: `location`
[INFO] [stderr]   --> src/router.rs:88:18
[INFO] [stderr]    |
[INFO] [stderr] 88 |         (method, location) => Err(RequestError::UnknownResource),
[INFO] [stderr]    |                  ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_location`
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]   --> src/main.rs:68:9
[INFO] [stderr]    |
[INFO] [stderr] 68 |     let mut tables = table::Tables::new();
[INFO] [stderr]    |         ----^^^^^^
[INFO] [stderr]    |         |
[INFO] [stderr]    |         help: remove this `mut`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(unused_mut)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: variable does not need to be mutable
[INFO] [stderr]   --> src/router.rs:31:46
[INFO] [stderr]    |
[INFO] [stderr] 31 | pub fn handle_request(context: &mut Context, mut request: &mut Request) -> Response<Cursor<Vec<u8>>> {
[INFO] [stderr]    |                                              ----^^^^^^^
[INFO] [stderr]    |                                              |
[INFO] [stderr]    |                                              help: remove this `mut`
[INFO] [stderr] 
[INFO] [stderr] warning: variant is never constructed: `UnsupportedMethod`
[INFO] [stderr]    --> src/router.rs:120:5
[INFO] [stderr]     |
[INFO] [stderr] 120 |     UnsupportedMethod
[INFO] [stderr]     |     ^^^^^^^^^^^^^^^^^
[INFO] [stderr]     |
[INFO] [stderr]     = note: `#[warn(dead_code)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: variant is never constructed: `InvalidQuery`
[INFO] [stderr]   --> src/url_parser.rs:25:5
[INFO] [stderr]    |
[INFO] [stderr] 25 |     InvalidQuery
[INFO] [stderr]    |     ^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: the feature `slice_patterns` has been stable since 1.42.0 and no longer requires an attribute to enable
[INFO] [stderr]  --> src/main.rs:4:12
[INFO] [stderr]   |
[INFO] [stderr] 4 | #![feature(slice_patterns)]
[INFO] [stderr]   |            ^^^^^^^^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(stable_features)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated item 'std::error::Error::description': use the Display impl or to_string()
[INFO] [stderr]    --> src/router.rs:136:53
[INFO] [stderr]     |
[INFO] [stderr] 136 |             RequestError::ReadError(ref err) => err.description(),
[INFO] [stderr]     |                                                     ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: function `okJson` should have a snake case name
[INFO] [stderr]   --> src/http.rs:11:8
[INFO] [stderr]    |
[INFO] [stderr] 11 | pub fn okJson(data: Json) -> Response<Cursor<Vec<u8>>> {
[INFO] [stderr]    |        ^^^^^^ help: convert the identifier to snake case: `ok_json`
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(non_snake_case)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated item 'std::error::Error::description': use the Display impl or to_string()
[INFO] [stderr]    --> src/router.rs:137:58
[INFO] [stderr]     |
[INFO] [stderr] 137 |             RequestError::JsonParseError(ref err) => err.description(),
[INFO] [stderr]     |                                                          ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: use of deprecated item 'std::error::Error::description': use the Display impl or to_string()
[INFO] [stderr]    --> src/router.rs:138:57
[INFO] [stderr]     |
[INFO] [stderr] 138 |             RequestError::UrlParseError(ref err) => err.description(),
[INFO] [stderr]     |                                                         ^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::fmt::Display`
[INFO] [stderr]  --> src/router.rs:5:5
[INFO] [stderr]   |
[INFO] [stderr] 5 | use std::fmt::Display;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `std::io::Read`
[INFO] [stderr]  --> src/router.rs:6:5
[INFO] [stderr]   |
[INFO] [stderr] 6 | use std::io::Read;
[INFO] [stderr]   |     ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] error: aborting due to 3 previous errors
[INFO] [stderr] 
[INFO] [stderr] Some errors have detailed explanations: E0425, E0433.
[INFO] [stderr] For more information about an error, try `rustc --explain E0425`.
[INFO] [stderr] error: could not compile `hermes`.
[INFO] [stderr] 
[INFO] [stderr] To learn more, run the command again with --verbose.
[INFO] [stderr] warning: build failed, waiting for other jobs to finish...
[INFO] [stderr] error: build failed
[INFO] running `"docker" "inspect" "bb64eb0cd8327d3f1abbe70861dac0845bdad524b11c49045092a8d669eb8b32"`
[INFO] running `"docker" "rm" "-f" "bb64eb0cd8327d3f1abbe70861dac0845bdad524b11c49045092a8d669eb8b32"`
[INFO] [stdout] bb64eb0cd8327d3f1abbe70861dac0845bdad524b11c49045092a8d669eb8b32
