[INFO] cloning repository https://github.com/KoalaLoveTree/wow_guilds_claude [INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/KoalaLoveTree/wow_guilds_claude" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FKoalaLoveTree%2Fwow_guilds_claude", kill_on_drop: false }` [INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FKoalaLoveTree%2Fwow_guilds_claude'... [INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }` [INFO] [stdout] 9a6b9b18bc91dad4b7c70f5b18bc803010578f73 [INFO] linting KoalaLoveTree/wow_guilds_claude against nightly for clippy-nonminimal_bool-denied [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FKoalaLoveTree%2Fwow_guilds_claude" "/workspace/builds/worker-1-tc1/source", kill_on_drop: false }` [INFO] [stderr] Cloning into '/workspace/builds/worker-1-tc1/source'... [INFO] [stderr] done. [INFO] started tweaking git repo https://github.com/KoalaLoveTree/wow_guilds_claude [INFO] finished tweaking git repo https://github.com/KoalaLoveTree/wow_guilds_claude [INFO] tweaked toml for git repo https://github.com/KoalaLoveTree/wow_guilds_claude written to /workspace/builds/worker-1-tc1/source/Cargo.toml [INFO] validating manifest of git repo https://github.com/KoalaLoveTree/wow_guilds_claude 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/KoalaLoveTree/wow_guilds_claude 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] Blocking waiting for file lock on package cache [INFO] [stderr] Downloading crates ... [INFO] [stderr] Downloaded sqlx-macros v0.8.6 [INFO] [stderr] Downloaded base64ct v1.8.0 [INFO] [stderr] Downloaded json5 v0.4.1 [INFO] [stderr] Downloaded sqlx-macros-core v0.8.6 [INFO] [stderr] Downloaded rust-ini v0.20.0 [INFO] [stderr] Downloaded dlv-list v0.5.2 [INFO] [stderr] Downloaded sqlx-sqlite v0.8.6 [INFO] [stderr] Downloaded config v0.14.1 [INFO] [stderr] Downloaded rsa v0.9.8 [INFO] [stderr] Downloaded sqlx-postgres v0.8.6 [INFO] [stderr] Downloaded sqlx-core v0.8.6 [INFO] [stderr] Downloaded sqlx-mysql v0.8.6 [INFO] [stderr] Downloaded reqwest v0.12.22 [INFO] [stderr] Downloaded sqlx v0.8.6 [INFO] [stderr] Downloaded ordered-multimap v0.7.3 [INFO] [stderr] Downloaded arraydeque v0.5.1 [INFO] [stderr] Downloaded yaml-rust2 v0.8.1 [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:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+nightly" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] a8ae5b05a53c83b5b956c93e64f6a71c024475b58fda5b3e351abe94305abe6e [INFO] running `Command { std: "docker" "start" "-a" "a8ae5b05a53c83b5b956c93e64f6a71c024475b58fda5b3e351abe94305abe6e", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "a8ae5b05a53c83b5b956c93e64f6a71c024475b58fda5b3e351abe94305abe6e", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "a8ae5b05a53c83b5b956c93e64f6a71c024475b58fda5b3e351abe94305abe6e", kill_on_drop: false }` [INFO] [stdout] a8ae5b05a53c83b5b956c93e64f6a71c024475b58fda5b3e351abe94305abe6e [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=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] 8f0704dedfe61857132d466c502aad03e81841999fc585ec83086490234d9e84 [INFO] running `Command { std: "docker" "start" "-a" "8f0704dedfe61857132d466c502aad03e81841999fc585ec83086490234d9e84", kill_on_drop: false }` [INFO] [stderr] Compiling libc v0.2.174 [INFO] [stderr] Checking cfg-if v1.0.1 [INFO] [stderr] Compiling serde v1.0.219 [INFO] [stderr] Checking memchr v2.7.5 [INFO] [stderr] Compiling cc v1.2.32 [INFO] [stderr] Checking allocator-api2 v0.2.21 [INFO] [stderr] Compiling lock_api v0.4.13 [INFO] [stderr] Compiling stable_deref_trait v1.2.0 [INFO] [stderr] Checking slab v0.4.11 [INFO] [stderr] Compiling syn v2.0.104 [INFO] [stderr] Checking futures-io v0.3.31 [INFO] [stderr] Compiling crossbeam-utils v0.8.21 [INFO] [stderr] Compiling num-traits v0.2.19 [INFO] [stderr] Checking tracing-core v0.1.34 [INFO] [stderr] Compiling serde_json v1.0.142 [INFO] [stderr] Compiling zerocopy v0.8.26 [INFO] [stderr] Checking foldhash v0.1.5 [INFO] [stderr] Compiling parking_lot_core v0.9.11 [INFO] [stderr] Compiling rustls v0.23.31 [INFO] [stderr] Compiling writeable v0.6.1 [INFO] [stderr] Compiling litemap v0.8.0 [INFO] [stderr] Compiling smallvec v1.15.1 [INFO] [stderr] Compiling pin-project-lite v0.2.16 [INFO] [stderr] Checking hashbrown v0.15.5 [INFO] [stderr] Compiling futures-core v0.3.31 [INFO] [stderr] Compiling typenum v1.18.0 [INFO] [stderr] Compiling scopeguard v1.2.0 [INFO] [stderr] Compiling zeroize v1.8.1 [INFO] [stderr] Compiling icu_normalizer_data v2.0.0 [INFO] [stderr] Compiling icu_properties_data v2.0.1 [INFO] [stderr] Compiling rustls-pki-types v1.12.0 [INFO] [stderr] Compiling futures-sink v0.3.31 [INFO] [stderr] Compiling vcpkg v0.2.15 [INFO] [stderr] Compiling crunchy v0.2.4 [INFO] [stderr] Checking http v0.2.12 [INFO] [stderr] Compiling percent-encoding v2.3.1 [INFO] [stderr] Checking indexmap v2.10.0 [INFO] [stderr] Compiling untrusted v0.9.0 [INFO] [stderr] Compiling tiny-keccak v2.0.2 [INFO] [stderr] Checking getrandom v0.2.16 [INFO] [stderr] Checking mio v1.0.4 [INFO] [stderr] Checking socket2 v0.6.0 [INFO] [stderr] Compiling form_urlencoded v1.2.1 [INFO] [stderr] Compiling generic-array v0.14.7 [INFO] [stderr] Compiling pin-utils v0.1.0 [INFO] [stderr] Compiling utf8_iter v1.0.4 [INFO] [stderr] Compiling futures-task v0.3.31 [INFO] [stderr] Compiling parking_lot v0.12.4 [INFO] [stderr] Compiling concurrent-queue v2.5.0 [INFO] [stderr] Compiling webpki-roots v1.0.2 [INFO] [stderr] Compiling futures-util v0.3.31 [INFO] [stderr] Compiling tokio v1.47.1 [INFO] [stderr] Compiling crc-catalog v2.4.0 [INFO] [stderr] Checking untrusted v0.7.1 [INFO] [stderr] Compiling subtle v2.6.1 [INFO] [stderr] Checking spin v0.5.2 [INFO] [stderr] Compiling iana-time-zone v0.1.63 [INFO] [stderr] Compiling ring v0.17.14 [INFO] [stderr] Compiling ring v0.16.20 [INFO] [stderr] Compiling libsqlite3-sys v0.30.1 [INFO] [stderr] Compiling parking v2.2.1 [INFO] [stderr] Compiling crypto-common v0.1.6 [INFO] [stderr] Compiling block-buffer v0.10.4 [INFO] [stderr] Compiling ucd-trie v0.1.7 [INFO] [stderr] Compiling rustls v0.20.9 [INFO] [stderr] Compiling rustls v0.21.12 [INFO] [stderr] Compiling event-listener v5.4.1 [INFO] [stderr] Compiling hashlink v0.10.0 [INFO] [stderr] Compiling digest v0.10.7 [INFO] [stderr] Compiling futures-intrusive v0.5.0 [INFO] [stderr] Compiling crc v3.3.0 [INFO] [stderr] Compiling const-random-macro v0.1.16 [INFO] [stderr] Compiling chrono v0.4.41 [INFO] [stderr] Compiling sha2 v0.10.9 [INFO] [stderr] Compiling getrandom v0.3.3 [INFO] [stderr] Checking ahash v0.8.12 [INFO] [stderr] Checking ppv-lite86 v0.2.21 [INFO] [stderr] Compiling webpki-roots v0.26.11 [INFO] [stderr] Checking rand_core v0.6.4 [INFO] [stderr] Compiling crossbeam-queue v0.3.12 [INFO] [stderr] Compiling spin v0.9.8 [INFO] [stderr] Checking hashbrown v0.14.5 [INFO] [stderr] Compiling base64 v0.22.1 [INFO] [stderr] Compiling uuid v1.17.0 [INFO] [stderr] Checking const-random v0.1.18 [INFO] [stderr] Compiling flume v0.11.1 [INFO] [stderr] Compiling atoi v2.0.0 [INFO] [stderr] Checking http-body v0.4.6 [INFO] [stderr] Checking rand_chacha v0.3.1 [INFO] [stderr] Checking socket2 v0.5.10 [INFO] [stderr] Compiling futures-channel v0.3.31 [INFO] [stderr] Checking aho-corasick v1.1.3 [INFO] [stderr] Checking encoding_rs v0.8.35 [INFO] [stderr] Checking regex-syntax v0.6.29 [INFO] [stderr] Checking rand v0.8.5 [INFO] [stderr] Checking dlv-list v0.5.2 [INFO] [stderr] Compiling mime_guess v2.0.5 [INFO] [stderr] Checking sha-1 v0.10.1 [INFO] [stderr] Checking unicase v2.8.1 [INFO] [stderr] Compiling dotenvy v0.15.7 [INFO] [stderr] Compiling synstructure v0.13.2 [INFO] [stderr] Checking regex-automata v0.4.9 [INFO] [stderr] Checking toml_write v0.1.2 [INFO] [stderr] Checking base64 v0.13.1 [INFO] [stderr] Checking winnow v0.7.12 [INFO] [stderr] Checking miniz_oxide v0.8.9 [INFO] [stderr] Compiling futures-executor v0.3.31 [INFO] [stderr] Checking ordered-multimap v0.7.3 [INFO] [stderr] Checking hashlink v0.8.4 [INFO] [stderr] Checking crc32fast v1.5.0 [INFO] [stderr] Checking rustls-pemfile v1.0.4 [INFO] [stderr] Checking ordered-float v2.10.1 [INFO] [stderr] Checking tracing-log v0.2.0 [INFO] [stderr] Checking thread_local v1.1.9 [INFO] [stderr] Checking iri-string v0.7.8 [INFO] [stderr] Checking sync_wrapper v0.1.2 [INFO] [stderr] Checking arraydeque v0.5.1 [INFO] [stderr] Checking webpki-roots v0.25.4 [INFO] [stderr] Compiling serenity v0.11.7 [INFO] [stderr] Checking convert_case v0.6.0 [INFO] [stderr] Checking nom v7.1.3 [INFO] [stderr] Checking rust-ini v0.20.0 [INFO] [stderr] Checking flate2 v1.1.2 [INFO] [stderr] Checking crossbeam-channel v0.5.15 [INFO] [stderr] Checking typemap_rev v0.1.5 [INFO] [stderr] Checking pathdiff v0.2.3 [INFO] [stderr] Checking urlencoding v2.1.3 [INFO] [stderr] Checking regex-automata v0.1.10 [INFO] [stderr] Checking yaml-rust2 v0.8.1 [INFO] [stderr] Compiling zerofrom-derive v0.1.6 [INFO] [stderr] Compiling yoke-derive v0.8.0 [INFO] [stderr] Compiling serde_derive v1.0.219 [INFO] [stderr] Compiling zerovec-derive v0.11.1 [INFO] [stderr] Compiling displaydoc v0.2.5 [INFO] [stderr] Compiling tokio-macros v2.5.0 [INFO] [stderr] Compiling tracing-attributes v0.1.30 [INFO] [stderr] Compiling futures-macro v0.3.31 [INFO] [stderr] Compiling thiserror-impl v2.0.12 [INFO] [stderr] Compiling thiserror-impl v1.0.69 [INFO] [stderr] Compiling tokio-stream v0.1.17 [INFO] [stderr] Checking matchers v0.1.0 [INFO] [stderr] Compiling async-trait v0.1.88 [INFO] [stderr] Checking thiserror v1.0.69 [INFO] [stderr] Checking zerofrom v0.1.6 [INFO] [stderr] Checking yoke v0.8.0 [INFO] [stderr] Checking tracing v0.1.41 [INFO] [stderr] Compiling thiserror v2.0.12 [INFO] [stderr] Compiling pest v2.8.1 [INFO] [stderr] Checking regex v1.11.1 [INFO] [stderr] Checking zerovec v0.11.4 [INFO] [stderr] Checking zerotrie v0.2.2 [INFO] [stderr] Checking sct v0.7.1 [INFO] [stderr] Checking rustls-webpki v0.103.4 [INFO] [stderr] Checking webpki v0.22.4 [INFO] [stderr] Checking rustls-webpki v0.101.7 [INFO] [stderr] Checking webpki-roots v0.22.6 [INFO] [stderr] Checking tinystr v0.8.1 [INFO] [stderr] Checking potential_utf v0.1.2 [INFO] [stderr] Checking icu_locale_core v2.0.0 [INFO] [stderr] Checking icu_collections v2.0.0 [INFO] [stderr] Checking icu_provider v2.0.0 [INFO] [stderr] Compiling pest_meta v2.8.1 [INFO] [stderr] Checking icu_properties v2.0.1 [INFO] [stderr] Checking icu_normalizer v2.0.0 [INFO] [stderr] Checking futures v0.3.31 [INFO] [stderr] Compiling pest_generator v2.8.1 [INFO] [stderr] Checking idna_adapter v1.2.1 [INFO] [stderr] Compiling pest_derive v2.8.1 [INFO] [stderr] Checking idna v1.0.3 [INFO] [stderr] Checking tokio-util v0.7.16 [INFO] [stderr] Checking tokio-rustls v0.24.1 [INFO] [stderr] Checking hyper v1.6.0 [INFO] [stderr] Checking tokio-rustls v0.23.4 [INFO] [stderr] Checking tower v0.5.2 [INFO] [stderr] Checking url v2.5.4 [INFO] [stderr] Checking serde_urlencoded v0.7.1 [INFO] [stderr] Checking bitflags v2.9.1 [INFO] [stderr] Checking serde_spanned v0.6.9 [INFO] [stderr] Checking deranged v0.4.0 [INFO] [stderr] Checking either v1.15.0 [INFO] [stderr] Checking toml_datetime v0.6.11 [INFO] [stderr] Checking tracing-serde v0.2.0 [INFO] [stderr] Checking toml_edit v0.22.27 [INFO] [stderr] Checking tokio-rustls v0.26.2 [INFO] [stderr] Checking tungstenite v0.17.3 [INFO] [stderr] Checking hyper-util v0.1.16 [INFO] [stderr] Checking tower-http v0.6.6 [INFO] [stderr] Checking ron v0.8.1 [INFO] [stderr] Checking serde-value v0.7.0 [INFO] [stderr] Checking json5 v0.4.1 [INFO] [stderr] Checking h2 v0.3.27 [INFO] [stderr] Checking time v0.3.41 [INFO] [stderr] Checking async-tungstenite v0.17.2 [INFO] [stderr] Checking tracing-subscriber v0.3.19 [INFO] [stderr] Checking sqlx-core v0.8.6 [INFO] [stderr] Checking toml v0.8.23 [INFO] [stderr] Checking hyper-rustls v0.27.7 [INFO] [stderr] Checking reqwest v0.12.22 [INFO] [stderr] Checking config v0.14.1 [INFO] [stderr] Checking tracing-appender v0.2.3 [INFO] [stderr] Checking sqlx-sqlite v0.8.6 [INFO] [stderr] Checking hyper v0.14.32 [INFO] [stderr] Compiling sqlx-macros-core v0.8.6 [INFO] [stderr] Checking hyper-rustls v0.24.2 [INFO] [stderr] Checking reqwest v0.11.27 [INFO] [stderr] Compiling sqlx-macros v0.8.6 [INFO] [stderr] Checking sqlx v0.8.6 [INFO] [stderr] Checking wow_guild_bot v0.1.0 (/opt/rustwide/workdir) [INFO] [stdout] warning: unused import: `PlayerName` [INFO] [stdout] --> src/database.rs:4:52 [INFO] [stdout] | [INFO] [stdout] 4 | use crate::types::{GuildUrl, GuildName, RealmName, PlayerName}; [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: `PlayerName` [INFO] [stdout] --> src/database.rs:4:52 [INFO] [stdout] | [INFO] [stdout] 4 | use crate::types::{GuildUrl, GuildName, RealmName, PlayerName}; [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 imports: `error` and `warn` [INFO] [stdout] --> src/logging.rs:4:15 [INFO] [stdout] | [INFO] [stdout] 4 | use tracing::{error, info, warn, Level}; [INFO] [stdout] | ^^^^^ ^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: this import is redundant [INFO] [stdout] --> src/parser.rs:6:1 [INFO] [stdout] | [INFO] [stdout] 6 | 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: unused imports: `error` and `warn` [INFO] [stdout] --> src/logging.rs:4:15 [INFO] [stdout] | [INFO] [stdout] 4 | use tracing::{error, info, warn, Level}; [INFO] [stdout] | ^^^^^ ^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: this import is redundant [INFO] [stdout] --> src/parser.rs:6:1 [INFO] [stdout] | [INFO] [stdout] 6 | 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: unused macro definition: `log_api_request` [INFO] [stdout] --> src/main.rs:29:14 [INFO] [stdout] | [INFO] [stdout] 29 | macro_rules! log_api_request { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_macros)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused macro definition: `log_discord_command` [INFO] [stdout] --> src/main.rs:41:14 [INFO] [stdout] | [INFO] [stdout] 41 | macro_rules! log_discord_command { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused macro definition: `log_api_request` [INFO] [stdout] --> src/main.rs:29:14 [INFO] [stdout] | [INFO] [stdout] 29 | macro_rules! log_api_request { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_macros)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused macro definition: `log_discord_command` [INFO] [stdout] --> src/main.rs:41:14 [INFO] [stdout] | [INFO] [stdout] 41 | macro_rules! log_discord_command { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/guild_data.rs:421:13 [INFO] [stdout] | [INFO] [stdout] 421 | let mut guilds = vec![ [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: variable does not need to be mutable [INFO] [stdout] --> src/guild_data.rs:450:13 [INFO] [stdout] | [INFO] [stdout] 450 | let mut guilds = vec![ [INFO] [stdout] | ----^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/guild_data.rs:480:13 [INFO] [stdout] | [INFO] [stdout] 480 | let mut guilds = vec![ [INFO] [stdout] | ----^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/guild_data.rs:530:13 [INFO] [stdout] | [INFO] [stdout] 530 | let mut guilds = vec![ [INFO] [stdout] | ----^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/guild_data.rs:564:13 [INFO] [stdout] | [INFO] [stdout] 564 | let mut guilds = vec![ [INFO] [stdout] | ----^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/guild_data.rs:653:13 [INFO] [stdout] | [INFO] [stdout] 653 | let mut guilds = vec![ [INFO] [stdout] | ----^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/guild_data.rs:698:13 [INFO] [stdout] | [INFO] [stdout] 698 | let mut guilds = vec![ [INFO] [stdout] | ----^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/guild_data.rs:740:13 [INFO] [stdout] | [INFO] [stdout] 740 | let mut guilds = vec![ [INFO] [stdout] | ----^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/guild_data.rs:797:13 [INFO] [stdout] | [INFO] [stdout] 797 | let mut guilds = vec![ [INFO] [stdout] | ----^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/guild_data.rs:838:13 [INFO] [stdout] | [INFO] [stdout] 838 | let mut guilds = vec![ [INFO] [stdout] | ----^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variable does not need to be mutable [INFO] [stdout] --> src/guild_data.rs:885:13 [INFO] [stdout] | [INFO] [stdout] 885 | let mut guilds = vec![ [INFO] [stdout] | ----^^^^^^ [INFO] [stdout] | | [INFO] [stdout] | help: remove this `mut` [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `client` [INFO] [stdout] --> src/parser.rs:333:30 [INFO] [stdout] | [INFO] [stdout] 333 | async fn fetch_guild_members(client: &RaiderIOClient, guild_url: &str) -> Result { [INFO] [stdout] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_client` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `client` [INFO] [stdout] --> src/parser.rs:333:30 [INFO] [stdout] | [INFO] [stdout] 333 | async fn fetch_guild_members(client: &RaiderIOClient, guild_url: &str) -> Result { [INFO] [stdout] | ^^^^^^ help: if this is intentional, prefix it with an underscore: `_client` [INFO] [stdout] | [INFO] [stdout] = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `handle_rank_command` is never used [INFO] [stdout] --> src/commands.rs:123:14 [INFO] [stdout] | [INFO] [stdout] 123 | pub async fn handle_rank_command(command: &ApplicationCommandInteraction, database: &Database) -> 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 `has_api_key` and `api_key` are never used [INFO] [stdout] --> src/config.rs:283:12 [INFO] [stdout] | [INFO] [stdout] 183 | impl AppConfig { [INFO] [stdout] | -------------- methods in this implementation [INFO] [stdout] ... [INFO] [stdout] 283 | pub fn has_api_key(&self) -> bool { [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 288 | pub fn api_key(&self) -> &str { [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `DbGuild` is never constructed [INFO] [stdout] --> src/database.rs:16:12 [INFO] [stdout] | [INFO] [stdout] 16 | pub struct DbGuild { [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: methods `import_guild_data_from_file`, `parse_guild_url`, and `insert_guild` are never used [INFO] [stdout] --> src/database.rs:348:18 [INFO] [stdout] | [INFO] [stdout] 48 | impl Database { [INFO] [stdout] | ------------- methods in this implementation [INFO] [stdout] ... [INFO] [stdout] 348 | pub async fn import_guild_data_from_file(&self, file_path: &str) -> Result { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 385 | fn parse_guild_url(&self, url_str: &str) -> Option { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 406 | async fn insert_guild(&self, guild_url: &GuildUrl) -> Result { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variants `Parse`, `GuildNotFound`, and `PlayerNotFound` are never constructed [INFO] [stdout] --> src/error.rs:42:5 [INFO] [stdout] | [INFO] [stdout] 6 | pub enum BotError { [INFO] [stdout] | -------- variants in this enum [INFO] [stdout] ... [INFO] [stdout] 42 | Parse(String), [INFO] [stdout] | ^^^^^ [INFO] [stdout] ... [INFO] [stdout] 46 | GuildNotFound { guild_name: String, realm: String }, [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 50 | PlayerNotFound { player_name: String, realm: String }, [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `BotError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated items `parse`, `guild_not_found`, `player_not_found`, `is_rate_limit`, `is_server_error`, and `is_client_error` are never used [INFO] [stdout] --> src/error.rs:81:12 [INFO] [stdout] | [INFO] [stdout] 64 | impl BotError { [INFO] [stdout] | ------------- associated items in this implementation [INFO] [stdout] ... [INFO] [stdout] 81 | pub fn parse>(message: S) -> Self { [INFO] [stdout] | ^^^^^ [INFO] [stdout] ... [INFO] [stdout] 86 | pub fn guild_not_found(guild_name: impl Into, realm: impl Into) -> Self { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 94 | pub fn player_not_found(player_name: impl Into, realm: impl Into) -> Self { [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 112 | pub fn is_rate_limit(&self) -> bool { [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 117 | pub fn is_server_error(&self) -> bool { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 125 | pub fn is_client_error(&self) -> bool { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `read_guild_data` is never used [INFO] [stdout] --> src/guild_data.rs:14:8 [INFO] [stdout] | [INFO] [stdout] 14 | pub fn read_guild_data(file_path: &str) -> Result> { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `read_additional_characters` is never used [INFO] [stdout] --> src/guild_data.rs:65:8 [INFO] [stdout] | [INFO] [stdout] 65 | pub fn read_additional_characters(file_path: &str) -> Result> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `compare_progression` is never used [INFO] [stdout] --> src/guild_data.rs:218:4 [INFO] [stdout] | [INFO] [stdout] 218 | fn compare_progression(progress_a: &str, progress_b: &str) -> std::cmp::Ordering { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: fields `name` and `realm` are never read [INFO] [stdout] --> src/raider_io.rs:48:5 [INFO] [stdout] | [INFO] [stdout] 47 | struct RaiderIOGuildResponse { [INFO] [stdout] | --------------------- fields in this struct [INFO] [stdout] 48 | name: String, [INFO] [stdout] | ^^^^ [INFO] [stdout] 49 | realm: String, [INFO] [stdout] | ^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `RaiderIOGuildResponse` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `duration_ms` is never read [INFO] [stdout] --> src/raider_io.rs:86:5 [INFO] [stdout] | [INFO] [stdout] 82 | struct KillInfo { [INFO] [stdout] | -------- field in this struct [INFO] [stdout] ... [INFO] [stdout] 86 | duration_ms: Option, [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `KillInfo` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `WowClass` is never constructed [INFO] [stdout] --> src/types.rs:21:12 [INFO] [stdout] | [INFO] [stdout] 21 | pub struct WowClass(String); [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `SpecName` is never constructed [INFO] [stdout] --> src/types.rs:25:12 [INFO] [stdout] | [INFO] [stdout] 25 | pub struct SpecName(String); [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: enum `RaidDifficulty` is never used [INFO] [stdout] --> src/types.rs:60:10 [INFO] [stdout] | [INFO] [stdout] 60 | pub enum RaidDifficulty { [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: enum `Role` is never used [INFO] [stdout] --> src/types.rs:69:10 [INFO] [stdout] | [INFO] [stdout] 69 | pub enum Role { [INFO] [stdout] | ^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `as_str` is never used [INFO] [stdout] --> src/types.rs:85:12 [INFO] [stdout] | [INFO] [stdout] 77 | impl GuildName { [INFO] [stdout] | -------------- method in this implementation [INFO] [stdout] ... [INFO] [stdout] 85 | pub fn as_str(&self) -> &str { [INFO] [stdout] | ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated items `as_str`, `current`, and `previous` are never used [INFO] [stdout] --> src/types.rs:278:12 [INFO] [stdout] | [INFO] [stdout] 273 | impl Season { [INFO] [stdout] | ----------- associated items in this implementation [INFO] [stdout] ... [INFO] [stdout] 278 | pub fn as_str(&self) -> &str { [INFO] [stdout] | ^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 282 | pub fn current() -> Self { [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 286 | pub fn previous() -> Self { [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated functions `nerubar_palace`, `liberation_of_undermine`, and `manaforge_omega` are never used [INFO] [stdout] --> src/types.rs:416:12 [INFO] [stdout] | [INFO] [stdout] 407 | impl RaidTier { [INFO] [stdout] | ------------- associated functions in this implementation [INFO] [stdout] ... [INFO] [stdout] 416 | pub fn nerubar_palace() -> Self { [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 420 | pub fn liberation_of_undermine() -> Self { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 424 | pub fn manaforge_omega() -> Self { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: this expression creates a reference which is immediately dereferenced by the compiler [INFO] [stdout] --> src/commands.rs:317:55 [INFO] [stdout] | [INFO] [stdout] 317 | let guild_name = truncate_and_pad(&player.guild.as_deref().unwrap_or("No Guild"), 34); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: change this to: `player.guild.as_deref().unwrap_or("No Guild")` [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 `impl` can be derived [INFO] [stdout] --> src/config.rs:104:1 [INFO] [stdout] | [INFO] [stdout] 104 | / impl Default for AppConfig { [INFO] [stdout] 105 | | fn default() -> Self { [INFO] [stdout] 106 | | Self { [INFO] [stdout] 107 | | discord: DiscordConfig::default(), [INFO] [stdout] ... | [INFO] [stdout] 115 | | } [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 [INFO] [stdout] | [INFO] [stdout] 9 + #[derive(Default)] [INFO] [stdout] 10 | pub struct AppConfig { [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: the `Err`-variant returned from this function is very large [INFO] [stdout] --> src/config.rs:185:22 [INFO] [stdout] | [INFO] [stdout] 185 | pub fn load() -> Result { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] ::: src/error.rs:22:5 [INFO] [stdout] | [INFO] [stdout] 22 | Discord(#[from] serenity::Error), [INFO] [stdout] | -------------------------------- the largest variant contains at least 136 bytes [INFO] [stdout] | [INFO] [stdout] = help: try reducing the size of `error::BotError`, for example by boxing large elements or replacing it with `Box` [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#result_large_err [INFO] [stdout] = note: `#[warn(clippy::result_large_err)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: the `Err`-variant returned from this function is very large [INFO] [stdout] --> src/config.rs:255:27 [INFO] [stdout] | [INFO] [stdout] 255 | fn validate(&self) -> Result<()> { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] ::: src/error.rs:22:5 [INFO] [stdout] | [INFO] [stdout] 22 | Discord(#[from] serenity::Error), [INFO] [stdout] | -------------------------------- the largest variant contains at least 136 bytes [INFO] [stdout] | [INFO] [stdout] = help: try reducing the size of `error::BotError`, for example by boxing large elements or replacing it with `Box` [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#result_large_err [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: redundant closure [INFO] [stdout] --> src/database.rs:355:22 [INFO] [stdout] | [INFO] [stdout] 355 | .map_err(|e| BotError::Io(e))?; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ help: replace the closure with the tuple variant itself: `BotError::Io` [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: the `Err`-variant returned from this function is very large [INFO] [stdout] --> src/guild_data.rs:14:44 [INFO] [stdout] | [INFO] [stdout] 14 | pub fn read_guild_data(file_path: &str) -> Result> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] ::: src/error.rs:22:5 [INFO] [stdout] | [INFO] [stdout] 22 | Discord(#[from] serenity::Error), [INFO] [stdout] | -------------------------------- the largest variant contains at least 136 bytes [INFO] [stdout] | [INFO] [stdout] = help: try reducing the size of `error::BotError`, for example by boxing large elements or replacing it with `Box` [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#result_large_err [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: the `Err`-variant returned from this function is very large [INFO] [stdout] --> src/guild_data.rs:65:55 [INFO] [stdout] | [INFO] [stdout] 65 | pub fn read_additional_characters(file_path: &str) -> Result> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] ::: src/error.rs:22:5 [INFO] [stdout] | [INFO] [stdout] 22 | Discord(#[from] serenity::Error), [INFO] [stdout] | -------------------------------- the largest variant contains at least 136 bytes [INFO] [stdout] | [INFO] [stdout] = help: try reducing the size of `error::BotError`, for example by boxing large elements or replacing it with `Box` [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#result_large_err [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: found call to `str::trim` before `str::split_whitespace` [INFO] [stdout] --> src/guild_data.rs:75:37 [INFO] [stdout] | [INFO] [stdout] 75 | let parts: Vec<&str> = line.trim().split_whitespace().collect(); [INFO] [stdout] | ^^^^^^^ help: remove `trim()` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#trim_split_whitespace [INFO] [stdout] = note: `#[warn(clippy::trim_split_whitespace)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: manual implementation of `.is_multiple_of()` [INFO] [stdout] --> src/guild_data.rs:126:24 [INFO] [stdout] | [INFO] [stdout] 126 | if current % 10 == 0 || current == total_guilds { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ help: replace with: `current.is_multiple_of(10)` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#manual_is_multiple_of [INFO] [stdout] = note: `#[warn(clippy::manual_is_multiple_of)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `to_string` applied to a type that implements `Display` in `println!` args [INFO] [stdout] --> src/guild_data.rs:726:27 [INFO] [stdout] | [INFO] [stdout] 726 | guild.name.to_string(), [INFO] [stdout] | ^^^^^^^^^^^^ help: remove this [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#to_string_in_format_args [INFO] [stdout] = note: `#[warn(clippy::to_string_in_format_args)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `to_string` applied to a type that implements `Display` in `println!` args [INFO] [stdout] --> src/guild_data.rs:776:27 [INFO] [stdout] | [INFO] [stdout] 776 | guild.name.to_string(), [INFO] [stdout] | ^^^^^^^^^^^^ help: remove this [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#to_string_in_format_args [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `to_string` applied to a type that implements `Display` in `println!` args [INFO] [stdout] --> src/guild_data.rs:824:27 [INFO] [stdout] | [INFO] [stdout] 824 | guild.name.to_string(), [INFO] [stdout] | ^^^^^^^^^^^^ help: remove this [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#to_string_in_format_args [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `to_string` applied to a type that implements `Display` in `println!` args [INFO] [stdout] --> src/guild_data.rs:865:27 [INFO] [stdout] | [INFO] [stdout] 865 | guild.name.to_string(), [INFO] [stdout] | ^^^^^^^^^^^^ help: remove this [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#to_string_in_format_args [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `handle_rank_command` is never used [INFO] [stdout] --> src/commands.rs:123:14 [INFO] [stdout] | [INFO] [stdout] 123 | pub async fn handle_rank_command(command: &ApplicationCommandInteraction, database: &Database) -> 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 `request_delay_ms`, `has_api_key`, and `api_key` are never used [INFO] [stdout] --> src/config.rs:278:12 [INFO] [stdout] | [INFO] [stdout] 183 | impl AppConfig { [INFO] [stdout] | -------------- methods in this implementation [INFO] [stdout] ... [INFO] [stdout] 278 | pub fn request_delay_ms(&self) -> u64 { [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 283 | pub fn has_api_key(&self) -> bool { [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 288 | pub fn api_key(&self) -> &str { [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `DbGuild` is never constructed [INFO] [stdout] --> src/database.rs:16:12 [INFO] [stdout] | [INFO] [stdout] 16 | pub struct DbGuild { [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: methods `import_guild_data_from_file`, `parse_guild_url`, and `insert_guild` are never used [INFO] [stdout] --> src/database.rs:348:18 [INFO] [stdout] | [INFO] [stdout] 48 | impl Database { [INFO] [stdout] | ------------- methods in this implementation [INFO] [stdout] ... [INFO] [stdout] 348 | pub async fn import_guild_data_from_file(&self, file_path: &str) -> Result { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 385 | fn parse_guild_url(&self, url_str: &str) -> Option { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 406 | async fn insert_guild(&self, guild_url: &GuildUrl) -> Result { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: variants `Parse`, `GuildNotFound`, and `PlayerNotFound` are never constructed [INFO] [stdout] --> src/error.rs:42:5 [INFO] [stdout] | [INFO] [stdout] 6 | pub enum BotError { [INFO] [stdout] | -------- variants in this enum [INFO] [stdout] ... [INFO] [stdout] 42 | Parse(String), [INFO] [stdout] | ^^^^^ [INFO] [stdout] ... [INFO] [stdout] 46 | GuildNotFound { guild_name: String, realm: String }, [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 50 | PlayerNotFound { player_name: String, realm: String }, [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `BotError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated items `parse`, `guild_not_found`, `player_not_found`, `is_rate_limit`, `is_server_error`, and `is_client_error` are never used [INFO] [stdout] --> src/error.rs:81:12 [INFO] [stdout] | [INFO] [stdout] 64 | impl BotError { [INFO] [stdout] | ------------- associated items in this implementation [INFO] [stdout] ... [INFO] [stdout] 81 | pub fn parse>(message: S) -> Self { [INFO] [stdout] | ^^^^^ [INFO] [stdout] ... [INFO] [stdout] 86 | pub fn guild_not_found(guild_name: impl Into, realm: impl Into) -> Self { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 94 | pub fn player_not_found(player_name: impl Into, realm: impl Into) -> Self { [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 112 | pub fn is_rate_limit(&self) -> bool { [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 117 | pub fn is_server_error(&self) -> bool { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 125 | pub fn is_client_error(&self) -> bool { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `read_guild_data` is never used [INFO] [stdout] --> src/guild_data.rs:14:8 [INFO] [stdout] | [INFO] [stdout] 14 | pub fn read_guild_data(file_path: &str) -> Result> { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `parse_guild_url` is never used [INFO] [stdout] --> src/guild_data.rs:42:4 [INFO] [stdout] | [INFO] [stdout] 42 | fn parse_guild_url(url_str: &str) -> Option { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `read_additional_characters` is never used [INFO] [stdout] --> src/guild_data.rs:65:8 [INFO] [stdout] | [INFO] [stdout] 65 | pub fn read_additional_characters(file_path: &str) -> Result> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function `compare_progression` is never used [INFO] [stdout] --> src/guild_data.rs:218:4 [INFO] [stdout] | [INFO] [stdout] 218 | fn compare_progression(progress_a: &str, progress_b: &str) -> std::cmp::Ordering { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: fields `name` and `realm` are never read [INFO] [stdout] --> src/raider_io.rs:48:5 [INFO] [stdout] | [INFO] [stdout] 47 | struct RaiderIOGuildResponse { [INFO] [stdout] | --------------------- fields in this struct [INFO] [stdout] 48 | name: String, [INFO] [stdout] | ^^^^ [INFO] [stdout] 49 | realm: String, [INFO] [stdout] | ^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `RaiderIOGuildResponse` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `duration_ms` is never read [INFO] [stdout] --> src/raider_io.rs:86:5 [INFO] [stdout] | [INFO] [stdout] 82 | struct KillInfo { [INFO] [stdout] | -------- field in this struct [INFO] [stdout] ... [INFO] [stdout] 86 | duration_ms: Option, [INFO] [stdout] | ^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `KillInfo` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `WowClass` is never constructed [INFO] [stdout] --> src/types.rs:21:12 [INFO] [stdout] | [INFO] [stdout] 21 | pub struct WowClass(String); [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `SpecName` is never constructed [INFO] [stdout] --> src/types.rs:25:12 [INFO] [stdout] | [INFO] [stdout] 25 | pub struct SpecName(String); [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: struct `PlayerId` is never constructed [INFO] [stdout] --> src/types.rs:52:12 [INFO] [stdout] | [INFO] [stdout] 52 | pub struct PlayerId { [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: enum `RaidDifficulty` is never used [INFO] [stdout] --> src/types.rs:60:10 [INFO] [stdout] | [INFO] [stdout] 60 | pub enum RaidDifficulty { [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: enum `Role` is never used [INFO] [stdout] --> src/types.rs:69:10 [INFO] [stdout] | [INFO] [stdout] 69 | pub enum Role { [INFO] [stdout] | ^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `as_str` is never used [INFO] [stdout] --> src/types.rs:85:12 [INFO] [stdout] | [INFO] [stdout] 77 | impl GuildName { [INFO] [stdout] | -------------- method in this implementation [INFO] [stdout] ... [INFO] [stdout] 85 | pub fn as_str(&self) -> &str { [INFO] [stdout] | ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `as_str` is never used [INFO] [stdout] --> src/types.rs:142:12 [INFO] [stdout] | [INFO] [stdout] 133 | impl RealmName { [INFO] [stdout] | -------------- method in this implementation [INFO] [stdout] ... [INFO] [stdout] 142 | pub fn as_str(&self) -> &str { [INFO] [stdout] | ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `as_str` is never used [INFO] [stdout] --> src/types.rs:214:12 [INFO] [stdout] | [INFO] [stdout] 205 | impl PlayerName { [INFO] [stdout] | --------------- method in this implementation [INFO] [stdout] ... [INFO] [stdout] 214 | pub fn as_str(&self) -> &str { [INFO] [stdout] | ^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated items `as_str`, `current`, and `previous` are never used [INFO] [stdout] --> src/types.rs:278:12 [INFO] [stdout] | [INFO] [stdout] 273 | impl Season { [INFO] [stdout] | ----------- associated items in this implementation [INFO] [stdout] ... [INFO] [stdout] 278 | pub fn as_str(&self) -> &str { [INFO] [stdout] | ^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 282 | pub fn current() -> Self { [INFO] [stdout] | ^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 286 | pub fn previous() -> Self { [INFO] [stdout] | ^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated functions `nerubar_palace`, `liberation_of_undermine`, and `manaforge_omega` are never used [INFO] [stdout] --> src/types.rs:416:12 [INFO] [stdout] | [INFO] [stdout] 407 | impl RaidTier { [INFO] [stdout] | ------------- associated functions in this implementation [INFO] [stdout] ... [INFO] [stdout] 416 | pub fn nerubar_palace() -> Self { [INFO] [stdout] | ^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 420 | pub fn liberation_of_undermine() -> Self { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] ... [INFO] [stdout] 424 | pub fn manaforge_omega() -> Self { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `new` is never used [INFO] [stdout] --> src/types.rs:443:12 [INFO] [stdout] | [INFO] [stdout] 442 | impl PlayerId { [INFO] [stdout] | ------------- associated function in this implementation [INFO] [stdout] 443 | pub fn new(realm: impl Into, name: impl Into) -> Self { [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `to_string` applied to a type that implements `Display` in `println!` args [INFO] [stdout] --> src/guild_data.rs:921:27 [INFO] [stdout] | [INFO] [stdout] 921 | guild.name.to_string(), [INFO] [stdout] | ^^^^^^^^^^^^ help: remove this [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#to_string_in_format_args [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: associated function `new` is never used [INFO] [stdout] --> src/types.rs:459:12 [INFO] [stdout] | [INFO] [stdout] 458 | impl GuildUrl { [INFO] [stdout] | ------------- associated function in this implementation [INFO] [stdout] 459 | pub fn new(realm: impl Into, name: impl Into) -> Self { [INFO] [stdout] | ^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `to_string` applied to a type that implements `Display` in `println!` args [INFO] [stdout] --> src/guild_data.rs:1003:27 [INFO] [stdout] | [INFO] [stdout] 1003 | guild.name.to_string(), [INFO] [stdout] | ^^^^^^^^^^^^ help: remove this [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#to_string_in_format_args [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: the `Err`-variant returned from this function is very large [INFO] [stdout] --> src/logging.rs:17:48 [INFO] [stdout] | [INFO] [stdout] 17 | pub fn init_logging(config: &LoggingConfig) -> Result<()> { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] ::: src/error.rs:22:5 [INFO] [stdout] | [INFO] [stdout] 22 | Discord(#[from] serenity::Error), [INFO] [stdout] | -------------------------------- the largest variant contains at least 136 bytes [INFO] [stdout] | [INFO] [stdout] = help: try reducing the size of `error::BotError`, for example by boxing large elements or replacing it with `Box` [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#result_large_err [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: called `.as_ref().map(|p| p.as_str())` on an `Option` value [INFO] [stdout] --> src/logging.rs:33:25 [INFO] [stdout] | [INFO] [stdout] 33 | let file_path = config.file_path.as_ref() [INFO] [stdout] | _________________________^ [INFO] [stdout] 34 | | .map(|p| p.as_str()) [INFO] [stdout] | |________________________________^ help: consider using as_deref: `config.file_path.as_deref()` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#option_as_ref_deref [INFO] [stdout] = note: `#[warn(clippy::option_as_ref_deref)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: this expression creates a reference which is immediately dereferenced by the compiler [INFO] [stdout] --> src/commands.rs:317:55 [INFO] [stdout] | [INFO] [stdout] 317 | let guild_name = truncate_and_pad(&player.guild.as_deref().unwrap_or("No Guild"), 34); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: change this to: `player.guild.as_deref().unwrap_or("No Guild")` [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 `Err`-variant returned from this function is very large [INFO] [stdout] --> src/logging.rs:116:36 [INFO] [stdout] | [INFO] [stdout] 116 | fn parse_log_level(level: &str) -> Result { [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] ::: src/error.rs:22:5 [INFO] [stdout] | [INFO] [stdout] 22 | Discord(#[from] serenity::Error), [INFO] [stdout] | -------------------------------- the largest variant contains at least 136 bytes [INFO] [stdout] | [INFO] [stdout] = help: try reducing the size of `error::BotError`, for example by boxing large elements or replacing it with `Box` [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#result_large_err [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: this expression creates a reference which is immediately dereferenced by the compiler [INFO] [stdout] --> src/parser.rs:42:62 [INFO] [stdout] | [INFO] [stdout] 42 | if let Ok(guild_data) = fetch_guild_members(&client, &url).await { [INFO] [stdout] | ^^^^ help: change this to: `url` [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 `if` statement can be collapsed [INFO] [stdout] --> src/parser.rs:162:25 [INFO] [stdout] | [INFO] [stdout] 162 | / if error_msg.contains("429") || error_msg.contains("rate") || error_msg.contains("limit") { [INFO] [stdout] 163 | | if attempts < max_attempts { [INFO] [stdout] 164 | | warn!( [INFO] [stdout] 165 | | player = %name, [INFO] [stdout] ... | [INFO] [stdout] 184 | | } [INFO] [stdout] | |_________________________^ [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#collapsible_if [INFO] [stdout] = note: `#[warn(clippy::collapsible_if)]` on by default [INFO] [stdout] help: collapse nested if block [INFO] [stdout] | [INFO] [stdout] 162 ~ if (error_msg.contains("429") || error_msg.contains("rate") || error_msg.contains("limit")) { [INFO] [stdout] 163 ~ && attempts < max_attempts { [INFO] [stdout] 164 | warn!( [INFO] [stdout] ... [INFO] [stdout] 182 | continue; [INFO] [stdout] 183 ~ } [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: this `impl` can be derived [INFO] [stdout] --> src/config.rs:104:1 [INFO] [stdout] | [INFO] [stdout] 104 | / impl Default for AppConfig { [INFO] [stdout] 105 | | fn default() -> Self { [INFO] [stdout] 106 | | Self { [INFO] [stdout] 107 | | discord: DiscordConfig::default(), [INFO] [stdout] ... | [INFO] [stdout] 115 | | } [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 [INFO] [stdout] | [INFO] [stdout] 9 + #[derive(Default)] [INFO] [stdout] 10 | pub struct AppConfig { [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: the `Err`-variant returned from this function is very large [INFO] [stdout] --> src/config.rs:185:22 [INFO] [stdout] | [INFO] [stdout] 185 | pub fn load() -> Result { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] ::: src/error.rs:22:5 [INFO] [stdout] | [INFO] [stdout] 22 | Discord(#[from] serenity::Error), [INFO] [stdout] | -------------------------------- the largest variant contains at least 136 bytes [INFO] [stdout] | [INFO] [stdout] = help: try reducing the size of `error::BotError`, for example by boxing large elements or replacing it with `Box` [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#result_large_err [INFO] [stdout] = note: `#[warn(clippy::result_large_err)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: this `if` statement can be collapsed [INFO] [stdout] --> src/parser.rs:187:25 [INFO] [stdout] | [INFO] [stdout] 187 | / if error_msg.contains("500") || error_msg.contains("502") || error_msg.contains("503") { [INFO] [stdout] 188 | | if attempts < max_attempts { [INFO] [stdout] 189 | | warn!( [INFO] [stdout] 190 | | player = %name, [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#collapsible_if [INFO] [stdout] help: collapse nested if block [INFO] [stdout] | [INFO] [stdout] 187 ~ if (error_msg.contains("500") || error_msg.contains("502") || error_msg.contains("503")) { [INFO] [stdout] 188 ~ && attempts < max_attempts { [INFO] [stdout] 189 | warn!( [INFO] [stdout] ... [INFO] [stdout] 200 | continue; [INFO] [stdout] 201 ~ } [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: the `Err`-variant returned from this function is very large [INFO] [stdout] --> src/config.rs:255:27 [INFO] [stdout] | [INFO] [stdout] 255 | fn validate(&self) -> Result<()> { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] ::: src/error.rs:22:5 [INFO] [stdout] | [INFO] [stdout] 22 | Discord(#[from] serenity::Error), [INFO] [stdout] | -------------------------------- the largest variant contains at least 136 bytes [INFO] [stdout] | [INFO] [stdout] = help: try reducing the size of `error::BotError`, for example by boxing large elements or replacing it with `Box` [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#result_large_err [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: casting to the same type is unnecessary (`f64` -> `f64`) [INFO] [stdout] --> src/parser.rs:269:41 [INFO] [stdout] | [INFO] [stdout] 269 | rio_score: Some(player.rio_all.value() as f64), // Legacy field - kept for compatibility [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: try: `player.rio_all.value()` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unnecessary_cast [INFO] [stdout] = note: `#[warn(clippy::unnecessary_cast)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: casting to the same type is unnecessary (`f64` -> `f64`) [INFO] [stdout] --> src/parser.rs:272:34 [INFO] [stdout] | [INFO] [stdout] 272 | rio_all: player.rio_all.value() as f64, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: try: `player.rio_all.value()` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unnecessary_cast [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: casting to the same type is unnecessary (`f64` -> `f64`) [INFO] [stdout] --> src/parser.rs:273:34 [INFO] [stdout] | [INFO] [stdout] 273 | rio_dps: player.rio_dps.value() as f64, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: try: `player.rio_dps.value()` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unnecessary_cast [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: casting to the same type is unnecessary (`f64` -> `f64`) [INFO] [stdout] --> src/parser.rs:274:37 [INFO] [stdout] | [INFO] [stdout] 274 | rio_healer: player.rio_healer.value() as f64, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: try: `player.rio_healer.value()` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unnecessary_cast [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: casting to the same type is unnecessary (`f64` -> `f64`) [INFO] [stdout] --> src/parser.rs:275:35 [INFO] [stdout] | [INFO] [stdout] 275 | rio_tank: player.rio_tank.value() as f64, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: try: `player.rio_tank.value()` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unnecessary_cast [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: casting to the same type is unnecessary (`f64` -> `f64`) [INFO] [stdout] --> src/parser.rs:276:33 [INFO] [stdout] | [INFO] [stdout] 276 | spec_0: player.spec_0.value() as f64, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: try: `player.spec_0.value()` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unnecessary_cast [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: casting to the same type is unnecessary (`f64` -> `f64`) [INFO] [stdout] --> src/parser.rs:277:33 [INFO] [stdout] | [INFO] [stdout] 277 | spec_1: player.spec_1.value() as f64, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: try: `player.spec_1.value()` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unnecessary_cast [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: casting to the same type is unnecessary (`f64` -> `f64`) [INFO] [stdout] --> src/parser.rs:278:33 [INFO] [stdout] | [INFO] [stdout] 278 | spec_2: player.spec_2.value() as f64, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: try: `player.spec_2.value()` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unnecessary_cast [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: casting to the same type is unnecessary (`f64` -> `f64`) [INFO] [stdout] --> src/parser.rs:279:33 [INFO] [stdout] | [INFO] [stdout] 279 | spec_3: player.spec_3.value() as f64, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: try: `player.spec_3.value()` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unnecessary_cast [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: redundant closure [INFO] [stdout] --> src/database.rs:355:22 [INFO] [stdout] | [INFO] [stdout] 355 | .map_err(|e| BotError::Io(e))?; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^ help: replace the closure with the tuple variant itself: `BotError::Io` [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: the `Err`-variant returned from this function is very large [INFO] [stdout] --> src/guild_data.rs:14:44 [INFO] [stdout] | [INFO] [stdout] 14 | pub fn read_guild_data(file_path: &str) -> Result> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] ::: src/error.rs:22:5 [INFO] [stdout] | [INFO] [stdout] 22 | Discord(#[from] serenity::Error), [INFO] [stdout] | -------------------------------- the largest variant contains at least 136 bytes [INFO] [stdout] | [INFO] [stdout] = help: try reducing the size of `error::BotError`, for example by boxing large elements or replacing it with `Box` [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#result_large_err [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: the `Err`-variant returned from this function is very large [INFO] [stdout] --> src/guild_data.rs:65:55 [INFO] [stdout] | [INFO] [stdout] 65 | pub fn read_additional_characters(file_path: &str) -> Result> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] ::: src/error.rs:22:5 [INFO] [stdout] | [INFO] [stdout] 22 | Discord(#[from] serenity::Error), [INFO] [stdout] | -------------------------------- the largest variant contains at least 136 bytes [INFO] [stdout] | [INFO] [stdout] = help: try reducing the size of `error::BotError`, for example by boxing large elements or replacing it with `Box` [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#result_large_err [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: found call to `str::trim` before `str::split_whitespace` [INFO] [stdout] --> src/guild_data.rs:75:37 [INFO] [stdout] | [INFO] [stdout] 75 | let parts: Vec<&str> = line.trim().split_whitespace().collect(); [INFO] [stdout] | ^^^^^^^ help: remove `trim()` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#trim_split_whitespace [INFO] [stdout] = note: `#[warn(clippy::trim_split_whitespace)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: the `Err`-variant returned from this function is very large [INFO] [stdout] --> src/raider_io.rs:156:47 [INFO] [stdout] | [INFO] [stdout] 156 | pub fn from_config(config: &AppConfig) -> Result { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] ::: src/error.rs:22:5 [INFO] [stdout] | [INFO] [stdout] 22 | Discord(#[from] serenity::Error), [INFO] [stdout] | -------------------------------- the largest variant contains at least 136 bytes [INFO] [stdout] | [INFO] [stdout] = help: try reducing the size of `error::BotError`, for example by boxing large elements or replacing it with `Box` [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#result_large_err [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: redundant closure [INFO] [stdout] --> src/raider_io.rs:161:22 [INFO] [stdout] | [INFO] [stdout] 161 | .map_err(|e| BotError::Http(e))?; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ help: replace the closure with the tuple variant itself: `BotError::Http` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#redundant_closure [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: the `Err`-variant returned from this function is very large [INFO] [stdout] --> src/raider_io.rs:192:41 [INFO] [stdout] | [INFO] [stdout] 192 | fn get_raid_name(tier: RaidTier) -> Result<&'static str> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] ::: src/error.rs:22:5 [INFO] [stdout] | [INFO] [stdout] 22 | Discord(#[from] serenity::Error), [INFO] [stdout] | -------------------------------- the largest variant contains at least 136 bytes [INFO] [stdout] | [INFO] [stdout] = help: try reducing the size of `error::BotError`, for example by boxing large elements or replacing it with `Box` [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#result_large_err [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: redundant pattern matching, consider using `is_err()` [INFO] [stdout] --> src/raider_io.rs:235:16 [INFO] [stdout] | [INFO] [stdout] 235 | if let Err(_) = fs::create_dir_all(error_dir) { [INFO] [stdout] | -------^^^^^^-------------------------------- help: try: `if fs::create_dir_all(error_dir).is_err()` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#redundant_pattern_matching [INFO] [stdout] = note: `#[warn(clippy::redundant_pattern_matching)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: manual implementation of `.is_multiple_of()` [INFO] [stdout] --> src/guild_data.rs:126:24 [INFO] [stdout] | [INFO] [stdout] 126 | if current % 10 == 0 || current == total_guilds { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ help: replace with: `current.is_multiple_of(10)` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#manual_is_multiple_of [INFO] [stdout] = note: `#[warn(clippy::manual_is_multiple_of)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: the `Err`-variant returned from this function is very large [INFO] [stdout] --> src/logging.rs:17:48 [INFO] [stdout] | [INFO] [stdout] 17 | pub fn init_logging(config: &LoggingConfig) -> Result<()> { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] ::: src/error.rs:22:5 [INFO] [stdout] | [INFO] [stdout] 22 | Discord(#[from] serenity::Error), [INFO] [stdout] | -------------------------------- the largest variant contains at least 136 bytes [INFO] [stdout] | [INFO] [stdout] = help: try reducing the size of `error::BotError`, for example by boxing large elements or replacing it with `Box` [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#result_large_err [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: called `.as_ref().map(|p| p.as_str())` on an `Option` value [INFO] [stdout] --> src/logging.rs:33:25 [INFO] [stdout] | [INFO] [stdout] 33 | let file_path = config.file_path.as_ref() [INFO] [stdout] | _________________________^ [INFO] [stdout] 34 | | .map(|p| p.as_str()) [INFO] [stdout] | |________________________________^ help: consider using as_deref: `config.file_path.as_deref()` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#option_as_ref_deref [INFO] [stdout] = note: `#[warn(clippy::option_as_ref_deref)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: the `Err`-variant returned from this function is very large [INFO] [stdout] --> src/logging.rs:116:36 [INFO] [stdout] | [INFO] [stdout] 116 | fn parse_log_level(level: &str) -> Result { [INFO] [stdout] | ^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] ::: src/error.rs:22:5 [INFO] [stdout] | [INFO] [stdout] 22 | Discord(#[from] serenity::Error), [INFO] [stdout] | -------------------------------- the largest variant contains at least 136 bytes [INFO] [stdout] | [INFO] [stdout] = help: try reducing the size of `error::BotError`, for example by boxing large elements or replacing it with `Box` [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#result_large_err [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: this expression creates a reference which is immediately dereferenced by the compiler [INFO] [stdout] --> src/parser.rs:42:62 [INFO] [stdout] | [INFO] [stdout] 42 | if let Ok(guild_data) = fetch_guild_members(&client, &url).await { [INFO] [stdout] | ^^^^ help: change this to: `url` [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 `if` statement can be collapsed [INFO] [stdout] --> src/parser.rs:162:25 [INFO] [stdout] | [INFO] [stdout] 162 | / if error_msg.contains("429") || error_msg.contains("rate") || error_msg.contains("limit") { [INFO] [stdout] 163 | | if attempts < max_attempts { [INFO] [stdout] 164 | | warn!( [INFO] [stdout] 165 | | player = %name, [INFO] [stdout] ... | [INFO] [stdout] 184 | | } [INFO] [stdout] | |_________________________^ [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#collapsible_if [INFO] [stdout] = note: `#[warn(clippy::collapsible_if)]` on by default [INFO] [stdout] help: collapse nested if block [INFO] [stdout] | [INFO] [stdout] 162 ~ if (error_msg.contains("429") || error_msg.contains("rate") || error_msg.contains("limit")) { [INFO] [stdout] 163 ~ && attempts < max_attempts { [INFO] [stdout] 164 | warn!( [INFO] [stdout] ... [INFO] [stdout] 182 | continue; [INFO] [stdout] 183 ~ } [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: this `if` statement can be collapsed [INFO] [stdout] --> src/parser.rs:187:25 [INFO] [stdout] | [INFO] [stdout] 187 | / if error_msg.contains("500") || error_msg.contains("502") || error_msg.contains("503") { [INFO] [stdout] 188 | | if attempts < max_attempts { [INFO] [stdout] 189 | | warn!( [INFO] [stdout] 190 | | player = %name, [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#collapsible_if [INFO] [stdout] help: collapse nested if block [INFO] [stdout] | [INFO] [stdout] 187 ~ if (error_msg.contains("500") || error_msg.contains("502") || error_msg.contains("503")) { [INFO] [stdout] 188 ~ && attempts < max_attempts { [INFO] [stdout] 189 | warn!( [INFO] [stdout] ... [INFO] [stdout] 200 | continue; [INFO] [stdout] 201 ~ } [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: casting to the same type is unnecessary (`f64` -> `f64`) [INFO] [stdout] --> src/parser.rs:269:41 [INFO] [stdout] | [INFO] [stdout] 269 | rio_score: Some(player.rio_all.value() as f64), // Legacy field - kept for compatibility [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: try: `player.rio_all.value()` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unnecessary_cast [INFO] [stdout] = note: `#[warn(clippy::unnecessary_cast)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: casting to the same type is unnecessary (`f64` -> `f64`) [INFO] [stdout] --> src/parser.rs:272:34 [INFO] [stdout] | [INFO] [stdout] 272 | rio_all: player.rio_all.value() as f64, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: try: `player.rio_all.value()` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unnecessary_cast [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: casting to the same type is unnecessary (`f64` -> `f64`) [INFO] [stdout] --> src/parser.rs:273:34 [INFO] [stdout] | [INFO] [stdout] 273 | rio_dps: player.rio_dps.value() as f64, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: try: `player.rio_dps.value()` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unnecessary_cast [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: casting to the same type is unnecessary (`f64` -> `f64`) [INFO] [stdout] --> src/parser.rs:274:37 [INFO] [stdout] | [INFO] [stdout] 274 | rio_healer: player.rio_healer.value() as f64, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: try: `player.rio_healer.value()` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unnecessary_cast [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: casting to the same type is unnecessary (`f64` -> `f64`) [INFO] [stdout] --> src/parser.rs:275:35 [INFO] [stdout] | [INFO] [stdout] 275 | rio_tank: player.rio_tank.value() as f64, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: try: `player.rio_tank.value()` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unnecessary_cast [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: casting to the same type is unnecessary (`f64` -> `f64`) [INFO] [stdout] --> src/parser.rs:276:33 [INFO] [stdout] | [INFO] [stdout] 276 | spec_0: player.spec_0.value() as f64, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: try: `player.spec_0.value()` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unnecessary_cast [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: casting to the same type is unnecessary (`f64` -> `f64`) [INFO] [stdout] --> src/parser.rs:277:33 [INFO] [stdout] | [INFO] [stdout] 277 | spec_1: player.spec_1.value() as f64, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: try: `player.spec_1.value()` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unnecessary_cast [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: casting to the same type is unnecessary (`f64` -> `f64`) [INFO] [stdout] --> src/parser.rs:278:33 [INFO] [stdout] | [INFO] [stdout] 278 | spec_2: player.spec_2.value() as f64, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: try: `player.spec_2.value()` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unnecessary_cast [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: casting to the same type is unnecessary (`f64` -> `f64`) [INFO] [stdout] --> src/parser.rs:279:33 [INFO] [stdout] | [INFO] [stdout] 279 | spec_3: player.spec_3.value() as f64, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: try: `player.spec_3.value()` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#unnecessary_cast [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: the `Err`-variant returned from this function is very large [INFO] [stdout] --> src/raider_io.rs:156:47 [INFO] [stdout] | [INFO] [stdout] 156 | pub fn from_config(config: &AppConfig) -> Result { [INFO] [stdout] | ^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] ::: src/error.rs:22:5 [INFO] [stdout] | [INFO] [stdout] 22 | Discord(#[from] serenity::Error), [INFO] [stdout] | -------------------------------- the largest variant contains at least 136 bytes [INFO] [stdout] | [INFO] [stdout] = help: try reducing the size of `error::BotError`, for example by boxing large elements or replacing it with `Box` [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#result_large_err [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: redundant closure [INFO] [stdout] --> src/raider_io.rs:161:22 [INFO] [stdout] | [INFO] [stdout] 161 | .map_err(|e| BotError::Http(e))?; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^ help: replace the closure with the tuple variant itself: `BotError::Http` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#redundant_closure [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: the `Err`-variant returned from this function is very large [INFO] [stdout] --> src/raider_io.rs:192:41 [INFO] [stdout] | [INFO] [stdout] 192 | fn get_raid_name(tier: RaidTier) -> Result<&'static str> { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] ::: src/error.rs:22:5 [INFO] [stdout] | [INFO] [stdout] 22 | Discord(#[from] serenity::Error), [INFO] [stdout] | -------------------------------- the largest variant contains at least 136 bytes [INFO] [stdout] | [INFO] [stdout] = help: try reducing the size of `error::BotError`, for example by boxing large elements or replacing it with `Box` [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#result_large_err [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: redundant pattern matching, consider using `is_err()` [INFO] [stdout] --> src/raider_io.rs:235:16 [INFO] [stdout] | [INFO] [stdout] 235 | if let Err(_) = fs::create_dir_all(error_dir) { [INFO] [stdout] | -------^^^^^^-------------------------------- help: try: `if fs::create_dir_all(error_dir).is_err()` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#redundant_pattern_matching [INFO] [stdout] = note: `#[warn(clippy::redundant_pattern_matching)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: the `Err`-variant returned from this function is very large [INFO] [stdout] --> src/main.rs:268:20 [INFO] [stdout] | [INFO] [stdout] 268 | async fn main() -> Result<()> { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] ::: src/error.rs:22:5 [INFO] [stdout] | [INFO] [stdout] 22 | Discord(#[from] serenity::Error), [INFO] [stdout] | -------------------------------- the largest variant contains at least 136 bytes [INFO] [stdout] | [INFO] [stdout] = help: try reducing the size of `error::BotError`, for example by boxing large elements or replacing it with `Box` [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#result_large_err [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: useless conversion to the same type: `error::BotError` [INFO] [stdout] --> src/main.rs:292:21 [INFO] [stdout] | [INFO] [stdout] 292 | Err(BotError::from(e)) [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ help: consider removing `BotError::from()`: `e` [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: redundant closure [INFO] [stdout] --> src/main.rs:346:18 [INFO] [stdout] | [INFO] [stdout] 346 | .map_err(|e| BotError::Discord(e))?; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ help: replace the closure with the tuple variant itself: `BotError::Discord` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#redundant_closure [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: useless use of `vec!` [INFO] [stdout] --> src/database.rs:283:32 [INFO] [stdout] | [INFO] [stdout] 283 | let alter_statements = vec![ [INFO] [stdout] | ________________________________^ [INFO] [stdout] 284 | | "ALTER TABLE members ADD COLUMN rio_all REAL DEFAULT 0", [INFO] [stdout] 285 | | "ALTER TABLE members ADD COLUMN rio_dps REAL DEFAULT 0", [INFO] [stdout] 286 | | "ALTER TABLE members ADD COLUMN rio_healer REAL DEFAULT 0", [INFO] [stdout] ... | [INFO] [stdout] 291 | | "ALTER TABLE members ADD COLUMN spec_3 REAL DEFAULT 0", [INFO] [stdout] 292 | | ]; [INFO] [stdout] | |_________^ [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#useless_vec [INFO] [stdout] = note: `#[warn(clippy::useless_vec)]` on by default [INFO] [stdout] help: you can use an array directly [INFO] [stdout] | [INFO] [stdout] 283 ~ let alter_statements = ["ALTER TABLE members ADD COLUMN rio_all REAL DEFAULT 0", [INFO] [stdout] 284 + "ALTER TABLE members ADD COLUMN rio_dps REAL DEFAULT 0", [INFO] [stdout] 285 + "ALTER TABLE members ADD COLUMN rio_healer REAL DEFAULT 0", [INFO] [stdout] 286 + "ALTER TABLE members ADD COLUMN rio_tank REAL DEFAULT 0", [INFO] [stdout] 287 + "ALTER TABLE members ADD COLUMN spec_0 REAL DEFAULT 0", [INFO] [stdout] 288 + "ALTER TABLE members ADD COLUMN spec_1 REAL DEFAULT 0", [INFO] [stdout] 289 + "ALTER TABLE members ADD COLUMN spec_2 REAL DEFAULT 0", [INFO] [stdout] 290 ~ "ALTER TABLE members ADD COLUMN spec_3 REAL DEFAULT 0"]; [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: useless use of `vec!` [INFO] [stdout] --> src/database.rs:302:36 [INFO] [stdout] | [INFO] [stdout] 302 | let alter_tmp_statements = vec![ [INFO] [stdout] | ____________________________________^ [INFO] [stdout] 303 | | "ALTER TABLE members_tmp ADD COLUMN rio_all REAL DEFAULT 0", [INFO] [stdout] 304 | | "ALTER TABLE members_tmp ADD COLUMN rio_dps REAL DEFAULT 0", [INFO] [stdout] 305 | | "ALTER TABLE members_tmp ADD COLUMN rio_healer REAL DEFAULT 0", [INFO] [stdout] ... | [INFO] [stdout] 310 | | "ALTER TABLE members_tmp ADD COLUMN spec_3 REAL DEFAULT 0", [INFO] [stdout] 311 | | ]; [INFO] [stdout] | |_________^ [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#useless_vec [INFO] [stdout] help: you can use an array directly [INFO] [stdout] | [INFO] [stdout] 302 ~ let alter_tmp_statements = ["ALTER TABLE members_tmp ADD COLUMN rio_all REAL DEFAULT 0", [INFO] [stdout] 303 + "ALTER TABLE members_tmp ADD COLUMN rio_dps REAL DEFAULT 0", [INFO] [stdout] 304 + "ALTER TABLE members_tmp ADD COLUMN rio_healer REAL DEFAULT 0", [INFO] [stdout] 305 + "ALTER TABLE members_tmp ADD COLUMN rio_tank REAL DEFAULT 0", [INFO] [stdout] 306 + "ALTER TABLE members_tmp ADD COLUMN spec_0 REAL DEFAULT 0", [INFO] [stdout] 307 + "ALTER TABLE members_tmp ADD COLUMN spec_1 REAL DEFAULT 0", [INFO] [stdout] 308 + "ALTER TABLE members_tmp ADD COLUMN spec_2 REAL DEFAULT 0", [INFO] [stdout] 309 ~ "ALTER TABLE members_tmp ADD COLUMN spec_3 REAL DEFAULT 0"]; [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: the `Err`-variant returned from this function is very large [INFO] [stdout] --> src/main.rs:268:20 [INFO] [stdout] | [INFO] [stdout] 268 | async fn main() -> Result<()> { [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] ::: src/error.rs:22:5 [INFO] [stdout] | [INFO] [stdout] 22 | Discord(#[from] serenity::Error), [INFO] [stdout] | -------------------------------- the largest variant contains at least 136 bytes [INFO] [stdout] | [INFO] [stdout] = help: try reducing the size of `error::BotError`, for example by boxing large elements or replacing it with `Box` [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#result_large_err [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: useless conversion to the same type: `error::BotError` [INFO] [stdout] --> src/main.rs:292:21 [INFO] [stdout] | [INFO] [stdout] 292 | Err(BotError::from(e)) [INFO] [stdout] | ^^^^^^^^^^^^^^^^^ help: consider removing `BotError::from()`: `e` [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: redundant closure [INFO] [stdout] --> src/main.rs:346:18 [INFO] [stdout] | [INFO] [stdout] 346 | .map_err(|e| BotError::Discord(e))?; [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^ help: replace the closure with the tuple variant itself: `BotError::Discord` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#redundant_closure [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: useless use of `vec!` [INFO] [stdout] --> src/database.rs:283:32 [INFO] [stdout] | [INFO] [stdout] 283 | let alter_statements = vec![ [INFO] [stdout] | ________________________________^ [INFO] [stdout] 284 | | "ALTER TABLE members ADD COLUMN rio_all REAL DEFAULT 0", [INFO] [stdout] 285 | | "ALTER TABLE members ADD COLUMN rio_dps REAL DEFAULT 0", [INFO] [stdout] 286 | | "ALTER TABLE members ADD COLUMN rio_healer REAL DEFAULT 0", [INFO] [stdout] ... | [INFO] [stdout] 291 | | "ALTER TABLE members ADD COLUMN spec_3 REAL DEFAULT 0", [INFO] [stdout] 292 | | ]; [INFO] [stdout] | |_________^ [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#useless_vec [INFO] [stdout] = note: `#[warn(clippy::useless_vec)]` on by default [INFO] [stdout] help: you can use an array directly [INFO] [stdout] | [INFO] [stdout] 283 ~ let alter_statements = ["ALTER TABLE members ADD COLUMN rio_all REAL DEFAULT 0", [INFO] [stdout] 284 + "ALTER TABLE members ADD COLUMN rio_dps REAL DEFAULT 0", [INFO] [stdout] 285 + "ALTER TABLE members ADD COLUMN rio_healer REAL DEFAULT 0", [INFO] [stdout] 286 + "ALTER TABLE members ADD COLUMN rio_tank REAL DEFAULT 0", [INFO] [stdout] 287 + "ALTER TABLE members ADD COLUMN spec_0 REAL DEFAULT 0", [INFO] [stdout] 288 + "ALTER TABLE members ADD COLUMN spec_1 REAL DEFAULT 0", [INFO] [stdout] 289 + "ALTER TABLE members ADD COLUMN spec_2 REAL DEFAULT 0", [INFO] [stdout] 290 ~ "ALTER TABLE members ADD COLUMN spec_3 REAL DEFAULT 0"]; [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: useless use of `vec!` [INFO] [stdout] --> src/database.rs:302:36 [INFO] [stdout] | [INFO] [stdout] 302 | let alter_tmp_statements = vec![ [INFO] [stdout] | ____________________________________^ [INFO] [stdout] 303 | | "ALTER TABLE members_tmp ADD COLUMN rio_all REAL DEFAULT 0", [INFO] [stdout] 304 | | "ALTER TABLE members_tmp ADD COLUMN rio_dps REAL DEFAULT 0", [INFO] [stdout] 305 | | "ALTER TABLE members_tmp ADD COLUMN rio_healer REAL DEFAULT 0", [INFO] [stdout] ... | [INFO] [stdout] 310 | | "ALTER TABLE members_tmp ADD COLUMN spec_3 REAL DEFAULT 0", [INFO] [stdout] 311 | | ]; [INFO] [stdout] | |_________^ [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#useless_vec [INFO] [stdout] help: you can use an array directly [INFO] [stdout] | [INFO] [stdout] 302 ~ let alter_tmp_statements = ["ALTER TABLE members_tmp ADD COLUMN rio_all REAL DEFAULT 0", [INFO] [stdout] 303 + "ALTER TABLE members_tmp ADD COLUMN rio_dps REAL DEFAULT 0", [INFO] [stdout] 304 + "ALTER TABLE members_tmp ADD COLUMN rio_healer REAL DEFAULT 0", [INFO] [stdout] 305 + "ALTER TABLE members_tmp ADD COLUMN rio_tank REAL DEFAULT 0", [INFO] [stdout] 306 + "ALTER TABLE members_tmp ADD COLUMN spec_0 REAL DEFAULT 0", [INFO] [stdout] 307 + "ALTER TABLE members_tmp ADD COLUMN spec_1 REAL DEFAULT 0", [INFO] [stdout] 308 + "ALTER TABLE members_tmp ADD COLUMN spec_2 REAL DEFAULT 0", [INFO] [stdout] 309 ~ "ALTER TABLE members_tmp ADD COLUMN spec_3 REAL DEFAULT 0"]; [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished `dev` profile [unoptimized + debuginfo] target(s) in 1m 25s [INFO] running `Command { std: "docker" "inspect" "8f0704dedfe61857132d466c502aad03e81841999fc585ec83086490234d9e84", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "8f0704dedfe61857132d466c502aad03e81841999fc585ec83086490234d9e84", kill_on_drop: false }` [INFO] [stdout] 8f0704dedfe61857132d466c502aad03e81841999fc585ec83086490234d9e84