[INFO] cloning repository https://github.com/smrt28/gpt-game [INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/smrt28/gpt-game" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fsmrt28%2Fgpt-game", kill_on_drop: false }` [INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fsmrt28%2Fgpt-game'... [INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }` [INFO] [stdout] b203bbbedd70fa4fec46feb65fc63ce00e6b35e6 [INFO] linting smrt28/gpt-game against nightly for clippy-nonminimal_bool-denied [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fsmrt28%2Fgpt-game" "/workspace/builds/worker-7-tc1/source", kill_on_drop: false }` [INFO] [stderr] Cloning into '/workspace/builds/worker-7-tc1/source'... [INFO] [stderr] done. [INFO] started tweaking git repo https://github.com/smrt28/gpt-game [INFO] finished tweaking git repo https://github.com/smrt28/gpt-game [INFO] tweaked toml for git repo https://github.com/smrt28/gpt-game written to /workspace/builds/worker-7-tc1/source/Cargo.toml [INFO] validating manifest of git repo https://github.com/smrt28/gpt-game on toolchain nightly [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+nightly" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }` [INFO] crate git repo https://github.com/smrt28/gpt-game already has a lockfile, it will not be regenerated [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+nightly" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] [stderr] Updating crates.io index [INFO] [stderr] Downloading crates ... [INFO] [stderr] Downloaded yew-router-macro v0.18.0 [INFO] [stderr] Downloaded yew-router v0.18.0 [INFO] [stderr] Downloaded serde_with_macros v3.14.0 [INFO] [stderr] Downloaded time-core v0.1.5 [INFO] [stderr] Downloaded value-bag v1.11.1 [INFO] [stderr] Downloaded component v0.1.1 [INFO] [stderr] Downloaded time-macros v0.2.23 [INFO] [stderr] Downloaded dashmap v7.0.0-rc2 [INFO] [stderr] Downloaded clap v4.5.46 [INFO] [stderr] Downloaded polling v3.10.0 [INFO] [stderr] Downloaded async-io v2.5.0 [INFO] [stderr] Downloaded gloo-net v0.5.0 [INFO] [stderr] Downloaded time v0.3.42 [INFO] [stderr] Downloaded gloo-worker v0.5.0 [INFO] [stderr] Downloaded clap_builder v4.5.46 [INFO] [stderr] Downloaded serde_with v3.14.0 [INFO] [stderr] Downloaded gloo v0.11.0 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+nightly" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] f283edcd92f636f7c2ba2167ff58704b1cae544cdd333d7e65706e322e6ebce8 [INFO] running `Command { std: "docker" "start" "-a" "f283edcd92f636f7c2ba2167ff58704b1cae544cdd333d7e65706e322e6ebce8", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "f283edcd92f636f7c2ba2167ff58704b1cae544cdd333d7e65706e322e6ebce8", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "f283edcd92f636f7c2ba2167ff58704b1cae544cdd333d7e65706e322e6ebce8", kill_on_drop: false }` [INFO] [stdout] f283edcd92f636f7c2ba2167ff58704b1cae544cdd333d7e65706e322e6ebce8 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-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=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+nightly" "clippy" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 6f7ef0c8a9d2f25dfdbc98fda4960f24a9dbe5d82d2fdecfb364e75b236b45c1 [INFO] running `Command { std: "docker" "start" "-a" "6f7ef0c8a9d2f25dfdbc98fda4960f24a9dbe5d82d2fdecfb364e75b236b45c1", kill_on_drop: false }` [INFO] [stderr] Checking futures-io v0.3.31 [INFO] [stderr] Checking value-bag v1.11.1 [INFO] [stderr] Compiling bumpalo v3.19.0 [INFO] [stderr] Compiling log v0.4.27 [INFO] [stderr] Compiling find-msvc-tools v0.1.0 [INFO] [stderr] Compiling proc-macro2 v1.0.101 [INFO] [stderr] Compiling serde_json v1.0.143 [INFO] [stderr] Checking hashbrown v0.15.5 [INFO] [stderr] Checking mio v1.0.4 [INFO] [stderr] Checking bitflags v2.9.4 [INFO] [stderr] Checking http v0.2.12 [INFO] [stderr] Compiling openssl v0.10.73 [INFO] [stderr] Compiling indexmap v2.11.0 [INFO] [stderr] Checking event-listener v5.4.1 [INFO] [stderr] Compiling anyhow v1.0.99 [INFO] [stderr] Checking rustls-pki-types v1.12.0 [INFO] [stderr] Checking getrandom v0.2.16 [INFO] [stderr] Compiling cc v1.2.35 [INFO] [stderr] Compiling rustix v1.0.8 [INFO] [stderr] Compiling syn v1.0.109 [INFO] [stderr] Checking event-listener-strategy v0.5.4 [INFO] [stderr] Compiling thiserror v2.0.16 [INFO] [stderr] Checking futures-lite v2.6.1 [INFO] [stderr] Compiling rustls v0.23.31 [INFO] [stderr] Checking time-core v0.1.5 [INFO] [stderr] Checking iana-time-zone v0.1.63 [INFO] [stderr] Compiling zerocopy v0.8.26 [INFO] [stderr] Checking linux-raw-sys v0.9.4 [INFO] [stderr] Compiling prettyplease v0.2.37 [INFO] [stderr] Checking scopeguard v1.2.0 [INFO] [stderr] Checking getrandom v0.3.3 [INFO] [stderr] Checking async-lock v3.4.1 [INFO] [stderr] Checking async-channel v2.5.0 [INFO] [stderr] Checking piper v0.2.4 [INFO] [stderr] Compiling quote v1.0.40 [INFO] [stderr] Compiling lock_api v0.4.13 [INFO] [stderr] Checking socket2 v0.5.10 [INFO] [stderr] Checking num_cpus v1.17.0 [INFO] [stderr] Checking regex-syntax v0.8.6 [INFO] [stderr] Compiling boolinator v2.4.0 [INFO] [stderr] Checking rand_core v0.9.3 [INFO] [stderr] Checking webpki-roots v1.0.2 [INFO] [stderr] Checking clap_builder v4.5.46 [INFO] [stderr] Checking async-channel v1.9.0 [INFO] [stderr] Compiling syn v2.0.106 [INFO] [stderr] Compiling toml_edit v0.19.15 [INFO] [stderr] Checking http-body v0.4.6 [INFO] [stderr] Checking toml_parser v1.0.2 [INFO] [stderr] Checking parking_lot_core v0.9.11 [INFO] [stderr] Checking tracing-log v0.2.0 [INFO] [stderr] Compiling proc-macro-error-attr v1.0.4 [INFO] [stderr] Checking kv-log-macro v1.0.7 [INFO] [stderr] Checking toml_writer v1.0.2 [INFO] [stderr] Checking route-recognizer v0.3.1 [INFO] [stderr] Checking component v0.1.1 [INFO] [stderr] Checking linked-hash-map v0.5.6 [INFO] [stderr] Checking dashmap v7.0.0-rc2 [INFO] [stderr] Compiling proc-macro-error v1.0.4 [INFO] [stderr] Compiling openssl-src v300.5.2+3.5.2 [INFO] [stderr] Checking blocking v1.6.2 [INFO] [stderr] Checking async-executor v1.13.3 [INFO] [stderr] Compiling ring v0.17.14 [INFO] [stderr] Compiling openssl-sys v0.9.109 [INFO] [stderr] Checking regex-automata v0.4.10 [INFO] [stderr] Compiling proc-macro-crate v1.3.1 [INFO] [stderr] Checking ppv-lite86 v0.2.21 [INFO] [stderr] Checking matchers v0.2.0 [INFO] [stderr] Checking rand_chacha v0.9.0 [INFO] [stderr] Checking rand v0.9.2 [INFO] [stderr] Checking polling v3.10.0 [INFO] [stderr] Checking async-io v2.5.0 [INFO] [stderr] Checking async-global-executor v2.4.1 [INFO] [stderr] Checking async-std v1.13.2 [INFO] [stderr] Checking rustls-webpki v0.103.4 [INFO] [stderr] Compiling wasm-bindgen-backend v0.2.100 [INFO] [stderr] Compiling synstructure v0.13.2 [INFO] [stderr] Compiling darling_core v0.20.11 [INFO] [stderr] Compiling serde_derive v1.0.219 [INFO] [stderr] Compiling futures-macro v0.3.31 [INFO] [stderr] Compiling tokio-macros v2.5.0 [INFO] [stderr] Compiling tracing-attributes v0.1.30 [INFO] [stderr] Compiling zerofrom-derive v0.1.6 [INFO] [stderr] Compiling yoke-derive v0.8.0 [INFO] [stderr] Compiling zerovec-derive v0.11.1 [INFO] [stderr] Compiling thiserror-impl v1.0.69 [INFO] [stderr] Compiling displaydoc v0.2.5 [INFO] [stderr] Compiling pin-project-internal v1.1.10 [INFO] [stderr] Compiling openssl-macros v0.1.1 [INFO] [stderr] Compiling gloo-worker-macros v0.1.0 [INFO] [stderr] Compiling thiserror-impl v2.0.16 [INFO] [stderr] Checking tokio v1.47.1 [INFO] [stderr] Compiling implicit-clone-derive v0.1.2 [INFO] [stderr] Compiling yew-macro v0.21.0 [INFO] [stderr] Compiling yew-router-macro v0.18.0 [INFO] [stderr] Checking implicit-clone v0.4.9 [INFO] [stderr] Checking futures-util v0.3.31 [INFO] [stderr] Compiling wasm-bindgen-macro-support v0.2.100 [INFO] [stderr] Checking thiserror v1.0.69 [INFO] [stderr] Compiling clap_derive v4.5.45 [INFO] [stderr] Checking tracing v0.1.41 [INFO] [stderr] Checking zerofrom v0.1.6 [INFO] [stderr] Checking yoke v0.8.0 [INFO] [stderr] Checking zerotrie v0.2.2 [INFO] [stderr] Checking pin-project v1.1.10 [INFO] [stderr] Checking axum-core v0.5.2 [INFO] [stderr] Checking zerovec v0.11.4 [INFO] [stderr] Checking tracing-subscriber v0.3.20 [INFO] [stderr] Compiling darling_macro v0.20.11 [INFO] [stderr] Compiling wasm-bindgen-macro v0.2.100 [INFO] [stderr] Compiling darling v0.20.11 [INFO] [stderr] Checking tinystr v0.8.1 [INFO] [stderr] Checking potential_utf v0.1.3 [INFO] [stderr] Compiling serde_with_macros v3.14.0 [INFO] [stderr] Checking wasm-bindgen v0.2.100 [INFO] [stderr] Checking icu_collections v2.0.0 [INFO] [stderr] Checking icu_locale_core v2.0.0 [INFO] [stderr] Checking serde v1.0.219 [INFO] [stderr] Checking icu_provider v2.0.0 [INFO] [stderr] Checking icu_normalizer v2.0.0 [INFO] [stderr] Checking icu_properties v2.0.1 [INFO] [stderr] Checking clap v4.5.46 [INFO] [stderr] Checking js-sys v0.3.77 [INFO] [stderr] Checking console_error_panic_hook v0.1.7 [INFO] [stderr] Checking futures v0.3.31 [INFO] [stderr] Checking pinned v0.1.0 [INFO] [stderr] Checking idna_adapter v1.2.1 [INFO] [stderr] Checking idna v1.1.0 [INFO] [stderr] Checking serde_urlencoded v0.7.1 [INFO] [stderr] Checking bincode v1.3.3 [INFO] [stderr] Checking deranged v0.5.3 [INFO] [stderr] Checking chrono v0.4.41 [INFO] [stderr] Checking url v2.5.7 [INFO] [stderr] Checking serde_with v3.14.0 [INFO] [stderr] Checking serde_spanned v1.0.0 [INFO] [stderr] Checking serde_path_to_error v0.1.17 [INFO] [stderr] Checking toml_datetime v0.7.0 [INFO] [stderr] Checking toml v0.9.5 [INFO] [stderr] Checking tokio-util v0.7.16 [INFO] [stderr] Checking tokio-stream v0.1.17 [INFO] [stderr] Checking tower v0.5.2 [INFO] [stderr] Checking tokio-rustls v0.26.2 [INFO] [stderr] Checking prokio v0.1.0 [INFO] [stderr] Checking h2 v0.4.12 [INFO] [stderr] Checking h2 v0.3.27 [INFO] [stderr] Checking tower-http v0.6.6 [INFO] [stderr] Checking web-sys v0.3.77 [INFO] [stderr] Checking wasm-bindgen-futures v0.4.50 [INFO] [stderr] Checking serde-wasm-bindgen v0.6.5 [INFO] [stderr] Checking gloo-timers v0.3.0 [INFO] [stderr] Checking time v0.3.42 [INFO] [stderr] Checking shared v0.1.0 (/opt/rustwide/workdir/shared) [INFO] [stdout] warning: unneeded `return` statement [INFO] [stdout] --> shared/src/messages.rs:78:9 [INFO] [stdout] | [INFO] [stdout] 78 | return GameTemplateStatus::Ok; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#needless_return [INFO] [stdout] = note: `#[warn(clippy::needless_return)]` on by default [INFO] [stdout] help: remove `return` [INFO] [stdout] | [INFO] [stdout] 78 - return GameTemplateStatus::Ok; [INFO] [stdout] 78 + GameTemplateStatus::Ok [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: you should consider adding a `Default` implementation for `Answer` [INFO] [stdout] --> shared/src/messages.rs:196:5 [INFO] [stdout] | [INFO] [stdout] 196 | / pub fn new() -> Self { [INFO] [stdout] 197 | | Self { [INFO] [stdout] 198 | | verdict: None, [INFO] [stdout] 199 | | comment: None, [INFO] [stdout] ... | [INFO] [stdout] 202 | | } [INFO] [stdout] | |_____^ [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#new_without_default [INFO] [stdout] = note: `#[warn(clippy::new_without_default)]` on by default [INFO] [stdout] help: try adding this [INFO] [stdout] | [INFO] [stdout] 195 + impl Default for Answer { [INFO] [stdout] 196 + fn default() -> Self { [INFO] [stdout] 197 + Self::new() [INFO] [stdout] 198 + } [INFO] [stdout] 199 + } [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: useless use of `format!` [INFO] [stdout] --> shared/src/messages.rs:215:27 [INFO] [stdout] | [INFO] [stdout] 215 | comment: Some(format!("{}", result)), [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ help: consider using `.to_string()`: `result.to_string()` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#useless_format [INFO] [stdout] = note: `#[warn(clippy::useless_format)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: casting a character literal to `u8` truncates [INFO] [stdout] --> shared/src/token.rs:17:34 [INFO] [stdout] | [INFO] [stdout] 17 | TokenType::Answer => 'a' as u8, [INFO] [stdout] | ^^^^^^^^^ help: use a byte literal instead: `b'a'` [INFO] [stdout] | [INFO] [stdout] = note: `char` is four bytes wide, but `u8` is a single byte [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#char_lit_as_u8 [INFO] [stdout] = note: `#[warn(clippy::char_lit_as_u8)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: casting a character literal to `u8` truncates [INFO] [stdout] --> shared/src/token.rs:18:32 [INFO] [stdout] | [INFO] [stdout] 18 | TokenType::Game => 'g' as u8, [INFO] [stdout] | ^^^^^^^^^ help: use a byte literal instead: `b'g'` [INFO] [stdout] | [INFO] [stdout] = note: `char` is four bytes wide, but `u8` is a single byte [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#char_lit_as_u8 [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: casting a character literal to `u8` truncates [INFO] [stdout] --> shared/src/token.rs:19:40 [INFO] [stdout] | [INFO] [stdout] 19 | TokenType::GameTemplate => 't' as u8, [INFO] [stdout] | ^^^^^^^^^ help: use a byte literal instead: `b't'` [INFO] [stdout] | [INFO] [stdout] = note: `char` is four bytes wide, but `u8` is a single byte [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#char_lit_as_u8 [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: implementation of inherent method `to_string(&self) -> String` for type `token::Token` [INFO] [stdout] --> shared/src/token.rs:56:5 [INFO] [stdout] | [INFO] [stdout] 56 | / pub fn to_string(&self) -> String { [INFO] [stdout] 57 | | String::from_utf8_lossy(&self.token).to_string() [INFO] [stdout] 58 | | } [INFO] [stdout] | |_____^ [INFO] [stdout] | [INFO] [stdout] = help: implement trait `Display` for type `token::Token` instead [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#inherent_to_string [INFO] [stdout] = note: `#[warn(clippy::inherent_to_string)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `from_str` can be confused for the standard trait method `std::str::FromStr::from_str` [INFO] [stdout] --> shared/src/locale.rs:13:5 [INFO] [stdout] | [INFO] [stdout] 13 | / pub fn from_str(s: &str) -> Option { [INFO] [stdout] 14 | | match s.to_lowercase().as_str() { [INFO] [stdout] 15 | | "en" | "english" => Some(Language::English), [INFO] [stdout] 16 | | "cs" | "czech" | "česky" | "cesky" => Some(Language::Czech), [INFO] [stdout] ... | [INFO] [stdout] 19 | | } [INFO] [stdout] | |_____^ [INFO] [stdout] | [INFO] [stdout] = help: consider implementing the trait `std::str::FromStr` or choosing a less ambiguous method name [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#should_implement_trait [INFO] [stdout] = note: `#[warn(clippy::should_implement_trait)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: this `impl` can be derived [INFO] [stdout] --> shared/src/locale.rs:43:1 [INFO] [stdout] | [INFO] [stdout] 43 | / impl Default for Language { [INFO] [stdout] 44 | | fn default() -> Self { [INFO] [stdout] 45 | | Language::English [INFO] [stdout] 46 | | } [INFO] [stdout] 47 | | } [INFO] [stdout] | |_^ [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#derivable_impls [INFO] [stdout] = note: `#[warn(clippy::derivable_impls)]` on by default [INFO] [stdout] help: replace the manual implementation with a derive attribute and mark the default variant [INFO] [stdout] | [INFO] [stdout] 5 + #[derive(Default)] [INFO] [stdout] 6 | pub enum Language { [INFO] [stdout] 7 | #[serde(rename = "en")] [INFO] [stdout] 8 ~ #[default] [INFO] [stdout] 9 ~ English, [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: you should consider adding a `Default` implementation for `Translations` [INFO] [stdout] --> shared/src/locale.rs:56:5 [INFO] [stdout] | [INFO] [stdout] 56 | / pub fn new() -> Self { [INFO] [stdout] 57 | | Self { [INFO] [stdout] 58 | | translations: HashMap::new(), [INFO] [stdout] 59 | | } [INFO] [stdout] 60 | | } [INFO] [stdout] | |_____^ [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#new_without_default [INFO] [stdout] help: try adding this [INFO] [stdout] | [INFO] [stdout] 55 + impl Default for Translations { [INFO] [stdout] 56 + fn default() -> Self { [INFO] [stdout] 57 + Self::new() [INFO] [stdout] 58 + } [INFO] [stdout] 59 + } [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: useless conversion to the same type: `anyhow::Error` [INFO] [stdout] --> shared/src/gpt.rs:5:20 [INFO] [stdout] | [INFO] [stdout] 5 | return Err(anyhow::anyhow!("Too long question").into()); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: consider removing `.into()`: `anyhow::anyhow!("Too long question")` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#useless_conversion [INFO] [stdout] = note: `#[warn(clippy::useless_conversion)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: useless conversion to the same type: `anyhow::Error` [INFO] [stdout] --> shared/src/gpt.rs:9:20 [INFO] [stdout] | [INFO] [stdout] 9 | return Err(anyhow::anyhow!("Is it even a question?").into()); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: consider removing `.into()`: `anyhow::anyhow!("Is it even a question?")` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#useless_conversion [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unneeded `return` statement [INFO] [stdout] --> shared/src/messages.rs:78:9 [INFO] [stdout] | [INFO] [stdout] 78 | return GameTemplateStatus::Ok; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#needless_return [INFO] [stdout] = note: `#[warn(clippy::needless_return)]` on by default [INFO] [stdout] help: remove `return` [INFO] [stdout] | [INFO] [stdout] 78 - return GameTemplateStatus::Ok; [INFO] [stdout] 78 + GameTemplateStatus::Ok [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: you should consider adding a `Default` implementation for `Answer` [INFO] [stdout] --> shared/src/messages.rs:196:5 [INFO] [stdout] | [INFO] [stdout] 196 | / pub fn new() -> Self { [INFO] [stdout] 197 | | Self { [INFO] [stdout] 198 | | verdict: None, [INFO] [stdout] 199 | | comment: None, [INFO] [stdout] ... | [INFO] [stdout] 202 | | } [INFO] [stdout] | |_____^ [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#new_without_default [INFO] [stdout] = note: `#[warn(clippy::new_without_default)]` on by default [INFO] [stdout] help: try adding this [INFO] [stdout] | [INFO] [stdout] 195 + impl Default for Answer { [INFO] [stdout] 196 + fn default() -> Self { [INFO] [stdout] 197 + Self::new() [INFO] [stdout] 198 + } [INFO] [stdout] 199 + } [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: useless use of `format!` [INFO] [stdout] --> shared/src/messages.rs:215:27 [INFO] [stdout] | [INFO] [stdout] 215 | comment: Some(format!("{}", result)), [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ help: consider using `.to_string()`: `result.to_string()` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#useless_format [INFO] [stdout] = note: `#[warn(clippy::useless_format)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: casting a character literal to `u8` truncates [INFO] [stdout] --> shared/src/token.rs:17:34 [INFO] [stdout] | [INFO] [stdout] 17 | TokenType::Answer => 'a' as u8, [INFO] [stdout] | ^^^^^^^^^ help: use a byte literal instead: `b'a'` [INFO] [stdout] | [INFO] [stdout] = note: `char` is four bytes wide, but `u8` is a single byte [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#char_lit_as_u8 [INFO] [stdout] = note: `#[warn(clippy::char_lit_as_u8)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: casting a character literal to `u8` truncates [INFO] [stdout] --> shared/src/token.rs:18:32 [INFO] [stdout] | [INFO] [stdout] 18 | TokenType::Game => 'g' as u8, [INFO] [stdout] | ^^^^^^^^^ help: use a byte literal instead: `b'g'` [INFO] [stdout] | [INFO] [stdout] = note: `char` is four bytes wide, but `u8` is a single byte [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#char_lit_as_u8 [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: casting a character literal to `u8` truncates [INFO] [stdout] --> shared/src/token.rs:19:40 [INFO] [stdout] | [INFO] [stdout] 19 | TokenType::GameTemplate => 't' as u8, [INFO] [stdout] | ^^^^^^^^^ help: use a byte literal instead: `b't'` [INFO] [stdout] | [INFO] [stdout] = note: `char` is four bytes wide, but `u8` is a single byte [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#char_lit_as_u8 [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: implementation of inherent method `to_string(&self) -> String` for type `token::Token` [INFO] [stdout] --> shared/src/token.rs:56:5 [INFO] [stdout] | [INFO] [stdout] 56 | / pub fn to_string(&self) -> String { [INFO] [stdout] 57 | | String::from_utf8_lossy(&self.token).to_string() [INFO] [stdout] 58 | | } [INFO] [stdout] | |_____^ [INFO] [stdout] | [INFO] [stdout] = help: implement trait `Display` for type `token::Token` instead [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#inherent_to_string [INFO] [stdout] = note: `#[warn(clippy::inherent_to_string)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `from_str` can be confused for the standard trait method `std::str::FromStr::from_str` [INFO] [stdout] --> shared/src/locale.rs:13:5 [INFO] [stdout] | [INFO] [stdout] 13 | / pub fn from_str(s: &str) -> Option { [INFO] [stdout] 14 | | match s.to_lowercase().as_str() { [INFO] [stdout] 15 | | "en" | "english" => Some(Language::English), [INFO] [stdout] 16 | | "cs" | "czech" | "česky" | "cesky" => Some(Language::Czech), [INFO] [stdout] ... | [INFO] [stdout] 19 | | } [INFO] [stdout] | |_____^ [INFO] [stdout] | [INFO] [stdout] = help: consider implementing the trait `std::str::FromStr` or choosing a less ambiguous method name [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#should_implement_trait [INFO] [stdout] = note: `#[warn(clippy::should_implement_trait)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: this `impl` can be derived [INFO] [stdout] --> shared/src/locale.rs:43:1 [INFO] [stdout] | [INFO] [stdout] 43 | / impl Default for Language { [INFO] [stdout] 44 | | fn default() -> Self { [INFO] [stdout] 45 | | Language::English [INFO] [stdout] 46 | | } [INFO] [stdout] 47 | | } [INFO] [stdout] | |_^ [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#derivable_impls [INFO] [stdout] = note: `#[warn(clippy::derivable_impls)]` on by default [INFO] [stdout] help: replace the manual implementation with a derive attribute and mark the default variant [INFO] [stdout] | [INFO] [stdout] 5 + #[derive(Default)] [INFO] [stdout] 6 | pub enum Language { [INFO] [stdout] 7 | #[serde(rename = "en")] [INFO] [stdout] 8 ~ #[default] [INFO] [stdout] 9 ~ English, [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: you should consider adding a `Default` implementation for `Translations` [INFO] [stdout] --> shared/src/locale.rs:56:5 [INFO] [stdout] | [INFO] [stdout] 56 | / pub fn new() -> Self { [INFO] [stdout] 57 | | Self { [INFO] [stdout] 58 | | translations: HashMap::new(), [INFO] [stdout] 59 | | } [INFO] [stdout] 60 | | } [INFO] [stdout] | |_____^ [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#new_without_default [INFO] [stdout] help: try adding this [INFO] [stdout] | [INFO] [stdout] 55 + impl Default for Translations { [INFO] [stdout] 56 + fn default() -> Self { [INFO] [stdout] 57 + Self::new() [INFO] [stdout] 58 + } [INFO] [stdout] 59 + } [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: useless conversion to the same type: `anyhow::Error` [INFO] [stdout] --> shared/src/gpt.rs:5:20 [INFO] [stdout] | [INFO] [stdout] 5 | return Err(anyhow::anyhow!("Too long question").into()); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: consider removing `.into()`: `anyhow::anyhow!("Too long question")` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#useless_conversion [INFO] [stdout] = note: `#[warn(clippy::useless_conversion)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: useless conversion to the same type: `anyhow::Error` [INFO] [stdout] --> shared/src/gpt.rs:9:20 [INFO] [stdout] | [INFO] [stdout] 9 | return Err(anyhow::anyhow!("Is it even a question?").into()); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: consider removing `.into()`: `anyhow::anyhow!("Is it even a question?")` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#useless_conversion [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Checking hyper v0.14.32 [INFO] [stderr] Checking hyper v1.7.0 [INFO] [stderr] Checking hyper-util v0.1.16 [INFO] [stderr] Checking hyper-rustls v0.27.7 [INFO] [stderr] Checking axum v0.8.4 [INFO] [stderr] Checking gloo-utils v0.2.0 [INFO] [stderr] Checking gloo-events v0.2.0 [INFO] [stderr] Checking gloo-dialogs v0.2.0 [INFO] [stderr] Checking gloo-render v0.2.0 [INFO] [stderr] Checking wasm-logger v0.2.0 [INFO] [stderr] Checking gloo-file v0.3.0 [INFO] [stderr] Checking gloo-console v0.3.0 [INFO] [stderr] Checking gloo-history v0.2.2 [INFO] [stderr] Checking gloo-storage v0.3.0 [INFO] [stderr] Checking gloo-net v0.4.0 [INFO] [stderr] Checking gloo-worker v0.4.0 [INFO] [stderr] Checking gloo-net v0.5.0 [INFO] [stderr] Checking gloo-worker v0.5.0 [INFO] [stderr] Checking gloo-net v0.6.0 [INFO] [stderr] Checking gloo v0.11.0 [INFO] [stderr] Checking gloo v0.10.0 [INFO] [stderr] Checking yew v0.21.0 [INFO] [stderr] Checking yew-router v0.18.0 [INFO] [stderr] Compiling native-tls v0.2.14 [INFO] [stderr] Checking tokio-native-tls v0.3.1 [INFO] [stderr] Checking hyper-tls v0.5.0 [INFO] [stderr] Checking hyper-tls v0.6.0 [INFO] [stderr] Checking reqwest v0.11.27 [INFO] [stderr] Checking reqwest v0.12.23 [INFO] [stderr] Checking wwweb v0.1.0 (/opt/rustwide/workdir/frontend) [INFO] [stderr] Checking gggame v0.1.0 (/opt/rustwide/workdir/server) [INFO] [stdout] warning: this expression creates a reference which is immediately dereferenced by the compiler [INFO] [stdout] --> frontend/src/board_component.rs:79:20 [INFO] [stdout] | [INFO] [stdout] 79 | state: &game_board [INFO] [stdout] | ^^^^^^^^^^^ help: change this to: `game_board` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#needless_borrow [INFO] [stdout] = note: `#[warn(clippy::needless_borrow)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: this expression creates a reference which is immediately dereferenced by the compiler [INFO] [stdout] --> frontend/src/board_component.rs:79:20 [INFO] [stdout] | [INFO] [stdout] 79 | state: &game_board [INFO] [stdout] | ^^^^^^^^^^^ help: change this to: `game_board` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#needless_borrow [INFO] [stdout] = note: `#[warn(clippy::needless_borrow)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: redundant closure [INFO] [stdout] --> frontend/src/custom_game_design_component.rs:18:29 [INFO] [stdout] | [INFO] [stdout] 18 | let comment = use_state(|| String::new()); [INFO] [stdout] | ^^^^^^^^^^^^^^^^ help: replace the closure with the associated function itself: `String::new` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#redundant_closure [INFO] [stdout] = note: `#[warn(clippy::redundant_closure)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: redundant closure [INFO] [stdout] --> frontend/src/custom_game_design_component.rs:18:29 [INFO] [stdout] | [INFO] [stdout] 18 | let comment = use_state(|| String::new()); [INFO] [stdout] | ^^^^^^^^^^^^^^^^ help: replace the closure with the associated function itself: `String::new` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#redundant_closure [INFO] [stdout] = note: `#[warn(clippy::redundant_closure)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: this boolean expression can be simplified [INFO] [stdout] --> frontend/src/game_component.rs:41:16 [INFO] [stdout] | [INFO] [stdout] 41 | if !check_question(&text).is_ok() { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: try: `check_question(&text).is_err()` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#nonminimal_bool [INFO] [stdout] = note: `#[warn(clippy::nonminimal_bool)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: this boolean expression can be simplified [INFO] [stdout] --> frontend/src/game_component.rs:41:16 [INFO] [stdout] | [INFO] [stdout] 41 | if !check_question(&text).is_ok() { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: try: `check_question(&text).is_err()` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#nonminimal_bool [INFO] [stdout] = note: `#[warn(clippy::nonminimal_bool)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: this let-binding has unit value [INFO] [stdout] --> frontend/src/language_selector_component.rs:70:25 [INFO] [stdout] | [INFO] [stdout] 70 | let _ = LocalStorage::delete("token"); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#let_unit_value [INFO] [stdout] = note: `#[warn(clippy::let_unit_value)]` on by default [INFO] [stdout] help: omit the `let` binding [INFO] [stdout] | [INFO] [stdout] 70 - let _ = LocalStorage::delete("token"); [INFO] [stdout] 70 + LocalStorage::delete("token"); [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: module has the same name as its containing module [INFO] [stdout] --> frontend/src/locale/mod.rs:3:1 [INFO] [stdout] | [INFO] [stdout] 3 | mod locale; [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#module_inception [INFO] [stdout] = note: `#[warn(clippy::module_inception)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: this let-binding has unit value [INFO] [stdout] --> frontend/src/language_selector_component.rs:70:25 [INFO] [stdout] | [INFO] [stdout] 70 | let _ = LocalStorage::delete("token"); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#let_unit_value [INFO] [stdout] = note: `#[warn(clippy::let_unit_value)]` on by default [INFO] [stdout] help: omit the `let` binding [INFO] [stdout] | [INFO] [stdout] 70 - let _ = LocalStorage::delete("token"); [INFO] [stdout] 70 + LocalStorage::delete("token"); [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: this `if let` can be collapsed into the outer `if let` [INFO] [stdout] --> frontend/src/locale/locale.rs:30:13 [INFO] [stdout] | [INFO] [stdout] 30 | / if let Ok(Some(lang_str)) = storage_result { [INFO] [stdout] 31 | | if let Some(lang) = Language::from_str(&lang_str) { [INFO] [stdout] 32 | | manager.current_language = lang; [INFO] [stdout] 33 | | } [INFO] [stdout] 34 | | } [INFO] [stdout] | |_____________^ [INFO] [stdout] | [INFO] [stdout] help: the outer pattern can be modified to include the inner pattern [INFO] [stdout] --> frontend/src/locale/locale.rs:26:21 [INFO] [stdout] | [INFO] [stdout] 26 | if let Some(storage_result) = web_sys::window() [INFO] [stdout] | ^^^^^^^^^^^^^^ replace this binding [INFO] [stdout] ... [INFO] [stdout] 30 | if let Ok(Some(lang_str)) = storage_result { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ with this pattern [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#collapsible_match [INFO] [stdout] = note: `#[warn(clippy::collapsible_match)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: module has the same name as its containing module [INFO] [stdout] --> frontend/src/locale/mod.rs:3:1 [INFO] [stdout] | [INFO] [stdout] 3 | mod locale; [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#module_inception [INFO] [stdout] = note: `#[warn(clippy::module_inception)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: this `if let` can be collapsed into the outer `if let` [INFO] [stdout] --> frontend/src/locale/locale.rs:30:13 [INFO] [stdout] | [INFO] [stdout] 30 | / if let Ok(Some(lang_str)) = storage_result { [INFO] [stdout] 31 | | if let Some(lang) = Language::from_str(&lang_str) { [INFO] [stdout] 32 | | manager.current_language = lang; [INFO] [stdout] 33 | | } [INFO] [stdout] 34 | | } [INFO] [stdout] | |_____________^ [INFO] [stdout] | [INFO] [stdout] help: the outer pattern can be modified to include the inner pattern [INFO] [stdout] --> frontend/src/locale/locale.rs:26:21 [INFO] [stdout] | [INFO] [stdout] 26 | if let Some(storage_result) = web_sys::window() [INFO] [stdout] | ^^^^^^^^^^^^^^ replace this binding [INFO] [stdout] ... [INFO] [stdout] 30 | if let Ok(Some(lang_str)) = storage_result { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ with this pattern [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#collapsible_match [INFO] [stdout] = note: `#[warn(clippy::collapsible_match)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary use of `to_string` [INFO] [stdout] --> frontend/src/to_html.rs:59:57 [INFO] [stdout] | [INFO] [stdout] 59 | { self.comment.as_deref().unwrap_or(&"".to_string()) } [INFO] [stdout] | ^^^^^^^^^^^^^^^ help: use: `""` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unnecessary_to_owned [INFO] [stdout] = note: `#[warn(clippy::unnecessary_to_owned)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: this expression creates a reference which is immediately dereferenced by the compiler [INFO] [stdout] --> frontend/src/to_html.rs:114:56 [INFO] [stdout] | [INFO] [stdout] 114 | create_pending_question_record(&pendig_question) [INFO] [stdout] | ^^^^^^^^^^^^^^^^ help: change this to: `pendig_question` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#needless_borrow [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: this import is redundant [INFO] [stdout] --> server/src/game_manager.rs:7:1 [INFO] [stdout] | [INFO] [stdout] 7 | use serde_json; [INFO] [stdout] | ^^^^^^^^^^^^^^^ help: remove it entirely [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#single_component_path_imports [INFO] [stdout] = note: `#[warn(clippy::single_component_path_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: this import is redundant [INFO] [stdout] --> server/src/game_manager.rs:7:1 [INFO] [stdout] | [INFO] [stdout] 7 | use serde_json; [INFO] [stdout] | ^^^^^^^^^^^^^^^ help: remove it entirely [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#single_component_path_imports [INFO] [stdout] = note: `#[warn(clippy::single_component_path_imports)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary use of `to_string` [INFO] [stdout] --> frontend/src/to_html.rs:59:57 [INFO] [stdout] | [INFO] [stdout] 59 | { self.comment.as_deref().unwrap_or(&"".to_string()) } [INFO] [stdout] | ^^^^^^^^^^^^^^^ help: use: `""` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unnecessary_to_owned [INFO] [stdout] = note: `#[warn(clippy::unnecessary_to_owned)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: this expression creates a reference which is immediately dereferenced by the compiler [INFO] [stdout] --> frontend/src/to_html.rs:114:56 [INFO] [stdout] | [INFO] [stdout] 114 | create_pending_question_record(&pendig_question) [INFO] [stdout] | ^^^^^^^^^^^^^^^^ help: change this to: `pendig_question` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#needless_borrow [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `game_template` [INFO] [stdout] --> server/src/server.rs:459:12 [INFO] [stdout] | [INFO] [stdout] 459 | let Ok(game_template) = state.game_manager.get_game_template(&token) else { [INFO] [stdout] | ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_game_template` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `game_template` [INFO] [stdout] --> server/src/server.rs:459:12 [INFO] [stdout] | [INFO] [stdout] 459 | let Ok(game_template) = state.game_manager.get_game_template(&token) else { [INFO] [stdout] | ^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_game_template` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary closure used to substitute value for `Option::None` [INFO] [stdout] --> server/src/server.rs:69:17 [INFO] [stdout] | [INFO] [stdout] 69 | / Language::from_str(&lang).unwrap_or_else(|| [INFO] [stdout] 70 | | Language::English) [INFO] [stdout] | |______________________________________^ [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unnecessary_lazy_evaluations [INFO] [stdout] = note: `#[warn(clippy::unnecessary_lazy_evaluations)]` on by default [INFO] [stdout] help: use `unwrap_or` instead [INFO] [stdout] | [INFO] [stdout] 69 - Language::from_str(&lang).unwrap_or_else(|| [INFO] [stdout] 70 - Language::English) [INFO] [stdout] 69 + Language::from_str(&lang).unwrap_or(Language::English) [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: this expression creates a reference which is immediately dereferenced by the compiler [INFO] [stdout] --> server/src/server.rs:69:36 [INFO] [stdout] | [INFO] [stdout] 69 | Language::from_str(&lang).unwrap_or_else(|| [INFO] [stdout] | ^^^^^ help: change this to: `lang` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#needless_borrow [INFO] [stdout] = note: `#[warn(clippy::needless_borrow)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: the borrowed expression implements the required traits [INFO] [stdout] --> server/src/server.rs:199:27 [INFO] [stdout] | [INFO] [stdout] 199 | ServeDir::new(&config.dirs.get_path(DirType::Www)) [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: change this to: `config.dirs.get_path(DirType::Www)` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#needless_borrows_for_generic_args [INFO] [stdout] = note: `#[warn(clippy::needless_borrows_for_generic_args)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: the borrowed expression implements the required traits [INFO] [stdout] --> server/src/server.rs:209:27 [INFO] [stdout] | [INFO] [stdout] 209 | ServeDir::new(&config.dirs.get_path(DirType::Dist)) [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: change this to: `config.dirs.get_path(DirType::Dist)` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#needless_borrows_for_generic_args [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: the borrowed expression implements the required traits [INFO] [stdout] --> server/src/server.rs:214:27 [INFO] [stdout] | [INFO] [stdout] 214 | .join(&config.dirs.get_path(DirType::Dist)).join("index.html"))) [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: change this to: `config.dirs.get_path(DirType::Dist)` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#needless_borrows_for_generic_args [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: called `unwrap_err` on `res` after checking its variant with `is_err` [INFO] [stdout] --> server/src/server.rs:269:66 [INFO] [stdout] | [INFO] [stdout] 268 | if res.is_err() { [INFO] [stdout] | --------------- help: try: `if let Err() = &res` [INFO] [stdout] 269 | info!("answer not ready for {}, reason={}", real_ip, res.as_ref().unwrap_err()); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unnecessary_unwrap [INFO] [stdout] = note: `#[warn(clippy::unnecessary_unwrap)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary use of `to_string` [INFO] [stdout] --> server/src/server.rs:320:44 [INFO] [stdout] | [INFO] [stdout] 320 | let Some(question) = sanitize_question(&String::from_utf8_lossy(&body).to_string()) else { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use: `String::from_utf8_lossy(&body).as_ref()` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unnecessary_to_owned [INFO] [stdout] = note: `#[warn(clippy::unnecessary_to_owned)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary closure used to substitute value for `Option::None` [INFO] [stdout] --> server/src/server.rs:69:17 [INFO] [stdout] | [INFO] [stdout] 69 | / Language::from_str(&lang).unwrap_or_else(|| [INFO] [stdout] 70 | | Language::English) [INFO] [stdout] | |______________________________________^ [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unnecessary_lazy_evaluations [INFO] [stdout] = note: `#[warn(clippy::unnecessary_lazy_evaluations)]` on by default [INFO] [stdout] help: use `unwrap_or` instead [INFO] [stdout] | [INFO] [stdout] 69 - Language::from_str(&lang).unwrap_or_else(|| [INFO] [stdout] 70 - Language::English) [INFO] [stdout] 69 + Language::from_str(&lang).unwrap_or(Language::English) [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: this expression creates a reference which is immediately dereferenced by the compiler [INFO] [stdout] --> server/src/server.rs:69:36 [INFO] [stdout] | [INFO] [stdout] 69 | Language::from_str(&lang).unwrap_or_else(|| [INFO] [stdout] | ^^^^^ help: change this to: `lang` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#needless_borrow [INFO] [stdout] = note: `#[warn(clippy::needless_borrow)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: this let-binding has unit value [INFO] [stdout] --> server/src/game_manager.rs:66:9 [INFO] [stdout] | [INFO] [stdout] 66 | / let result = time::timeout(timeout, self.get_notifier(token)?.notified()).await [INFO] [stdout] 67 | | .map_err(|_| AppError::Timeout)?; [INFO] [stdout] | |_____________________________________________^ [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#let_unit_value [INFO] [stdout] = note: `#[warn(clippy::let_unit_value)]` on by default [INFO] [stdout] help: omit the `let` binding and replace variable usages with `()` [INFO] [stdout] | [INFO] [stdout] 66 ~ time::timeout(timeout, self.get_notifier(token)?.notified()).await [INFO] [stdout] 67 | .map_err(|_| AppError::Timeout)?; [INFO] [stdout] 68 | info!("Waiting for answer END"); [INFO] [stdout] 69 ~ Ok(()) [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: the borrowed expression implements the required traits [INFO] [stdout] --> server/src/server.rs:199:27 [INFO] [stdout] | [INFO] [stdout] 199 | ServeDir::new(&config.dirs.get_path(DirType::Www)) [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: change this to: `config.dirs.get_path(DirType::Www)` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#needless_borrows_for_generic_args [INFO] [stdout] = note: `#[warn(clippy::needless_borrows_for_generic_args)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: the borrowed expression implements the required traits [INFO] [stdout] --> server/src/server.rs:209:27 [INFO] [stdout] | [INFO] [stdout] 209 | ServeDir::new(&config.dirs.get_path(DirType::Dist)) [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: change this to: `config.dirs.get_path(DirType::Dist)` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#needless_borrows_for_generic_args [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: the borrowed expression implements the required traits [INFO] [stdout] --> server/src/server.rs:214:27 [INFO] [stdout] | [INFO] [stdout] 214 | .join(&config.dirs.get_path(DirType::Dist)).join("index.html"))) [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: change this to: `config.dirs.get_path(DirType::Dist)` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#needless_borrows_for_generic_args [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field assignment outside of initializer for an instance created with Default::default() [INFO] [stdout] --> server/src/game_manager.rs:101:9 [INFO] [stdout] | [INFO] [stdout] 101 | game.lang = lang.clone(); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] note: consider initializing the variable with `shared::messages::GameState { lang: lang.clone(), identity: Some(identity.to_string()), ..Default::default() }` and removing relevant reassignments [INFO] [stdout] --> server/src/game_manager.rs:100:9 [INFO] [stdout] | [INFO] [stdout] 100 | let mut game = GameState::default(); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#field_reassign_with_default [INFO] [stdout] = note: `#[warn(clippy::field_reassign_with_default)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: called `unwrap_err` on `res` after checking its variant with `is_err` [INFO] [stdout] --> server/src/server.rs:269:66 [INFO] [stdout] | [INFO] [stdout] 268 | if res.is_err() { [INFO] [stdout] | --------------- help: try: `if let Err() = &res` [INFO] [stdout] 269 | info!("answer not ready for {}, reason={}", real_ip, res.as_ref().unwrap_err()); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unnecessary_unwrap [INFO] [stdout] = note: `#[warn(clippy::unnecessary_unwrap)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: match expression looks like `matches!` macro [INFO] [stdout] --> server/src/app_error.rs:47:29 [INFO] [stdout] | [INFO] [stdout] 47 | let invalid_token = match self { [INFO] [stdout] | _____________________________^ [INFO] [stdout] 48 | | AppError::InvalidToken => true, [INFO] [stdout] 49 | | AppError::GameNotFound => true, [INFO] [stdout] 50 | | _ => false [INFO] [stdout] 51 | | }; [INFO] [stdout] | |_________^ [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#match_like_matches_macro [INFO] [stdout] = note: `#[warn(clippy::match_like_matches_macro)]` on by default [INFO] [stdout] help: use `matches!` directly [INFO] [stdout] | [INFO] [stdout] 47 - let invalid_token = match self { [INFO] [stdout] 48 - AppError::InvalidToken => true, [INFO] [stdout] 49 - AppError::GameNotFound => true, [INFO] [stdout] 50 - _ => false [INFO] [stdout] 51 - }; [INFO] [stdout] 47 + let invalid_token = matches!(self, AppError::InvalidToken | AppError::GameNotFound); [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: this expression creates a reference which is immediately dereferenced by the compiler [INFO] [stdout] --> server/src/game_prompt.rs:25:38 [INFO] [stdout] | [INFO] [stdout] 25 | .replace("{target}", &target.as_str()) [INFO] [stdout] | ^^^^^^^^^^^^^^^^ help: change this to: `target.as_str()` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#needless_borrow [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary use of `to_string` [INFO] [stdout] --> server/src/game_prompt.rs:53:55 [INFO] [stdout] | [INFO] [stdout] 53 | if let Ok(q) = shared::gpt::sanitize_question(&question.to_string()) { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ help: use: `question` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unnecessary_to_owned [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary use of `to_string` [INFO] [stdout] --> server/src/server.rs:320:44 [INFO] [stdout] | [INFO] [stdout] 320 | let Some(question) = sanitize_question(&String::from_utf8_lossy(&body).to_string()) else { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: use: `String::from_utf8_lossy(&body).as_ref()` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unnecessary_to_owned [INFO] [stdout] = note: `#[warn(clippy::unnecessary_to_owned)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unneeded `return` statement [INFO] [stdout] --> server/src/config.rs:113:24 [INFO] [stdout] | [INFO] [stdout] 113 | Ok(res) => return Ok(res), [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#needless_return [INFO] [stdout] = note: `#[warn(clippy::needless_return)]` on by default [INFO] [stdout] help: remove `return` [INFO] [stdout] | [INFO] [stdout] 113 - Ok(res) => return Ok(res), [INFO] [stdout] 113 + Ok(res) => Ok(res), [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unneeded `return` statement [INFO] [stdout] --> server/src/config.rs:116:17 [INFO] [stdout] | [INFO] [stdout] 116 | return Err(err.into()); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#needless_return [INFO] [stdout] help: remove `return` [INFO] [stdout] | [INFO] [stdout] 116 - return Err(err.into()); [INFO] [stdout] 116 + Err(err.into()) [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: this let-binding has unit value [INFO] [stdout] --> server/src/game_manager.rs:66:9 [INFO] [stdout] | [INFO] [stdout] 66 | / let result = time::timeout(timeout, self.get_notifier(token)?.notified()).await [INFO] [stdout] 67 | | .map_err(|_| AppError::Timeout)?; [INFO] [stdout] | |_____________________________________________^ [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#let_unit_value [INFO] [stdout] = note: `#[warn(clippy::let_unit_value)]` on by default [INFO] [stdout] help: omit the `let` binding and replace variable usages with `()` [INFO] [stdout] | [INFO] [stdout] 66 ~ time::timeout(timeout, self.get_notifier(token)?.notified()).await [INFO] [stdout] 67 | .map_err(|_| AppError::Timeout)?; [INFO] [stdout] 68 | info!("Waiting for answer END"); [INFO] [stdout] 69 ~ Ok(()) [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field assignment outside of initializer for an instance created with Default::default() [INFO] [stdout] --> server/src/game_manager.rs:101:9 [INFO] [stdout] | [INFO] [stdout] 101 | game.lang = lang.clone(); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] note: consider initializing the variable with `shared::messages::GameState { lang: lang.clone(), identity: Some(identity.to_string()), ..Default::default() }` and removing relevant reassignments [INFO] [stdout] --> server/src/game_manager.rs:100:9 [INFO] [stdout] | [INFO] [stdout] 100 | let mut game = GameState::default(); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#field_reassign_with_default [INFO] [stdout] = note: `#[warn(clippy::field_reassign_with_default)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: match expression looks like `matches!` macro [INFO] [stdout] --> server/src/app_error.rs:47:29 [INFO] [stdout] | [INFO] [stdout] 47 | let invalid_token = match self { [INFO] [stdout] | _____________________________^ [INFO] [stdout] 48 | | AppError::InvalidToken => true, [INFO] [stdout] 49 | | AppError::GameNotFound => true, [INFO] [stdout] 50 | | _ => false [INFO] [stdout] 51 | | }; [INFO] [stdout] | |_________^ [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#match_like_matches_macro [INFO] [stdout] = note: `#[warn(clippy::match_like_matches_macro)]` on by default [INFO] [stdout] help: use `matches!` directly [INFO] [stdout] | [INFO] [stdout] 47 - let invalid_token = match self { [INFO] [stdout] 48 - AppError::InvalidToken => true, [INFO] [stdout] 49 - AppError::GameNotFound => true, [INFO] [stdout] 50 - _ => false [INFO] [stdout] 51 - }; [INFO] [stdout] 47 + let invalid_token = matches!(self, AppError::InvalidToken | AppError::GameNotFound); [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: this expression creates a reference which is immediately dereferenced by the compiler [INFO] [stdout] --> server/src/game_prompt.rs:25:38 [INFO] [stdout] | [INFO] [stdout] 25 | .replace("{target}", &target.as_str()) [INFO] [stdout] | ^^^^^^^^^^^^^^^^ help: change this to: `target.as_str()` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#needless_borrow [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unnecessary use of `to_string` [INFO] [stdout] --> server/src/game_prompt.rs:53:55 [INFO] [stdout] | [INFO] [stdout] 53 | if let Ok(q) = shared::gpt::sanitize_question(&question.to_string()) { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ help: use: `question` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unnecessary_to_owned [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unneeded `return` statement [INFO] [stdout] --> server/src/config.rs:113:24 [INFO] [stdout] | [INFO] [stdout] 113 | Ok(res) => return Ok(res), [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#needless_return [INFO] [stdout] = note: `#[warn(clippy::needless_return)]` on by default [INFO] [stdout] help: remove `return` [INFO] [stdout] | [INFO] [stdout] 113 - Ok(res) => return Ok(res), [INFO] [stdout] 113 + Ok(res) => Ok(res), [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unneeded `return` statement [INFO] [stdout] --> server/src/config.rs:116:17 [INFO] [stdout] | [INFO] [stdout] 116 | return Err(err.into()); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#needless_return [INFO] [stdout] help: remove `return` [INFO] [stdout] | [INFO] [stdout] 116 - return Err(err.into()); [INFO] [stdout] 116 + Err(err.into()) [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished `dev` profile [unoptimized + debuginfo] target(s) in 3m 06s [INFO] running `Command { std: "docker" "inspect" "6f7ef0c8a9d2f25dfdbc98fda4960f24a9dbe5d82d2fdecfb364e75b236b45c1", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "6f7ef0c8a9d2f25dfdbc98fda4960f24a9dbe5d82d2fdecfb364e75b236b45c1", kill_on_drop: false }` [INFO] [stdout] 6f7ef0c8a9d2f25dfdbc98fda4960f24a9dbe5d82d2fdecfb364e75b236b45c1