[INFO] cloning repository https://github.com/ElXreno/teledump [INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/ElXreno/teledump" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FElXreno%2Fteledump", kill_on_drop: false }` [INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FElXreno%2Fteledump'... [INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }` [INFO] [stdout] a6f1146d0cc27c91a4f04241f44be2e36ab0c2d3 [INFO] linting ElXreno/teledump against nightly for clippy-nonminimal_bool-denied [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FElXreno%2Fteledump" "/workspace/builds/worker-3-tc1/source", kill_on_drop: false }` [INFO] [stderr] Cloning into '/workspace/builds/worker-3-tc1/source'... [INFO] [stderr] done. [INFO] removed /workspace/builds/worker-3-tc1/source/rust-toolchain.toml [INFO] started tweaking git repo https://github.com/ElXreno/teledump [INFO] finished tweaking git repo https://github.com/ElXreno/teledump [INFO] tweaked toml for git repo https://github.com/ElXreno/teledump written to /workspace/builds/worker-3-tc1/source/Cargo.toml [INFO] validating manifest of git repo https://github.com/ElXreno/teledump 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/ElXreno/teledump 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 git repository `https://github.com/Lonami/grammers` [INFO] [stderr] Updating crates.io index [INFO] [stderr] Blocking waiting for file lock on package cache [INFO] [stderr] Downloading crates ... [INFO] [stderr] Downloaded sea-orm-migration v0.12.15 [INFO] [stderr] Downloaded rkyv_derive v0.7.44 [INFO] [stderr] Downloaded locate-locale v0.2.0 [INFO] [stderr] Downloaded ouroboros v0.17.2 [INFO] [stderr] Downloaded sea-schema-derive v0.2.0 [INFO] [stderr] Downloaded async-stream-impl v0.3.5 [INFO] [stderr] Downloaded sea-query-derive v0.4.1 [INFO] [stderr] Downloaded is-terminal v0.4.12 [INFO] [stderr] Downloaded async-attributes v1.1.2 [INFO] [stderr] Downloaded async-stream v0.3.5 [INFO] [stderr] Downloaded os_info v3.8.2 [INFO] [stderr] Downloaded glass_pumpkin v1.7.0 [INFO] [stderr] Downloaded polling v3.7.2 [INFO] [stderr] Downloaded async-io v2.3.3 [INFO] [stderr] Downloaded cc v1.1.2 [INFO] [stderr] Downloaded raw-cpuid v11.0.2 [INFO] [stderr] Downloaded rust_decimal v1.35.0 [INFO] [stderr] Downloaded bytes v1.6.1 [INFO] [stderr] Downloaded sea-query v0.30.7 [INFO] [stderr] Downloaded rkyv v0.7.44 [INFO] [stderr] Downloaded simdutf8 v0.1.4 [INFO] [stderr] Downloaded ouroboros_macro v0.17.2 [INFO] [stderr] Downloaded sea-orm-cli v0.12.15 [INFO] [stderr] Downloaded bigdecimal v0.3.1 [INFO] [stderr] Downloaded syn v2.0.71 [INFO] [stderr] Downloaded triomphe v0.1.11 [INFO] [stderr] Downloaded moka v0.12.8 [INFO] [stderr] Downloaded sea-orm-macros v0.12.15 [INFO] [stderr] Downloaded sea-bae v0.2.0 [INFO] [stderr] Downloaded sea-query-binder v0.5.0 [INFO] [stderr] Downloaded inherent v1.0.11 [INFO] [stderr] Downloaded sea-orm v0.12.15 [INFO] [stderr] Downloaded sea-schema v0.14.2 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-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] 1b32109b4fbabdd648436ba4a89ad602caf4c4aa68075d61606731b5af7e0383 [INFO] running `Command { std: "docker" "start" "-a" "1b32109b4fbabdd648436ba4a89ad602caf4c4aa68075d61606731b5af7e0383", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "1b32109b4fbabdd648436ba4a89ad602caf4c4aa68075d61606731b5af7e0383", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "1b32109b4fbabdd648436ba4a89ad602caf4c4aa68075d61606731b5af7e0383", kill_on_drop: false }` [INFO] [stdout] 1b32109b4fbabdd648436ba4a89ad602caf4c4aa68075d61606731b5af7e0383 [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-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] e23db4117d5c6d6d3be8bdd9e2a15c44064563800edb19d9cb0be4bad62813d2 [INFO] running `Command { std: "docker" "start" "-a" "e23db4117d5c6d6d3be8bdd9e2a15c44064563800edb19d9cb0be4bad62813d2", kill_on_drop: false }` [INFO] [stderr] Compiling syn v2.0.71 [INFO] [stderr] Checking value-bag v1.9.0 [INFO] [stderr] Compiling serde v1.0.204 [INFO] [stderr] Checking getrandom v0.2.15 [INFO] [stderr] Compiling num-traits v0.2.19 [INFO] [stderr] Compiling generic-array v0.14.7 [INFO] [stderr] Compiling syn v1.0.109 [INFO] [stderr] Compiling cc v1.1.2 [INFO] [stderr] Checking bitflags v2.6.0 [INFO] [stderr] Compiling pkg-config v0.3.30 [INFO] [stderr] Checking futures-sink v0.3.30 [INFO] [stderr] Checking parking_lot_core v0.9.10 [INFO] [stderr] Compiling thiserror v1.0.62 [INFO] [stderr] Checking bytes v1.6.1 [INFO] [stderr] Checking mio v0.8.11 [INFO] [stderr] Checking num_cpus v1.16.0 [INFO] [stderr] Checking futures-channel v0.3.30 [INFO] [stderr] Checking parking_lot v0.12.3 [INFO] [stderr] Checking rand_core v0.6.4 [INFO] [stderr] Compiling ahash v0.8.11 [INFO] [stderr] Compiling serde_json v1.0.120 [INFO] [stderr] Checking log v0.4.22 [INFO] [stderr] Checking iana-time-zone v0.1.60 [INFO] [stderr] Compiling rust_decimal v1.35.0 [INFO] [stderr] Checking rand v0.8.5 [INFO] [stderr] Compiling time-macros v0.2.18 [INFO] [stderr] Checking concurrent-queue v2.5.0 [INFO] [stderr] Checking arrayvec v0.7.4 [INFO] [stderr] Checking event-listener v2.5.3 [INFO] [stderr] Checking zerocopy v0.7.35 [INFO] [stderr] Checking unicode-normalization v0.1.23 [INFO] [stderr] Checking unicode-bidi v0.3.15 [INFO] [stderr] Compiling openssl v0.10.66 [INFO] [stderr] Compiling proc-macro-error-attr v1.0.4 [INFO] [stderr] Checking futures-intrusive v0.5.0 [INFO] [stderr] Checking event-listener v5.3.1 [INFO] [stderr] Checking spin v0.9.8 [INFO] [stderr] Checking crossbeam-queue v0.3.11 [INFO] [stderr] Compiling crc32fast v1.4.2 [INFO] [stderr] Checking urlencoding v2.1.3 [INFO] [stderr] Checking num-integer v0.1.46 [INFO] [stderr] Checking ordered-float v3.9.2 [INFO] [stderr] Checking atoi v2.0.0 [INFO] [stderr] Checking fastrand v2.1.0 [INFO] [stderr] Checking event-listener-strategy v0.5.2 [INFO] [stderr] Checking flume v0.11.0 [INFO] [stderr] Checking crypto-common v0.1.6 [INFO] [stderr] Checking block-buffer v0.10.4 [INFO] [stderr] Compiling grammers-tl-parser v1.1.1 (https://github.com/Lonami/grammers#345a3f89) [INFO] [stderr] Compiling rustix v0.38.34 [INFO] [stderr] Checking idna v0.5.0 [INFO] [stderr] Checking regex-syntax v0.8.4 [INFO] [stderr] Checking anstyle-parse v0.2.4 [INFO] [stderr] Checking hashbrown v0.14.5 [INFO] [stderr] Checking futures-lite v2.3.0 [INFO] [stderr] Checking digest v0.10.7 [INFO] [stderr] Checking is_terminal_polyfill v1.70.0 [INFO] [stderr] Checking aliasable v0.1.3 [INFO] [stderr] Checking anstyle v1.0.7 [INFO] [stderr] Checking regex-syntax v0.6.29 [INFO] [stderr] Checking num-bigint v0.4.6 [INFO] [stderr] Compiling io-lifetimes v1.0.11 [INFO] [stderr] Checking colorchoice v1.0.1 [INFO] [stderr] Compiling grammers-tl-gen v0.6.0 (https://github.com/Lonami/grammers#345a3f89) [INFO] [stderr] Checking linux-raw-sys v0.4.14 [INFO] [stderr] Checking anstyle-query v1.1.0 [INFO] [stderr] Checking sha2 v0.10.8 [INFO] [stderr] Checking anstream v0.6.14 [INFO] [stderr] Checking async-lock v3.4.0 [INFO] [stderr] Compiling polling v2.8.0 [INFO] [stderr] Compiling rustix v0.37.27 [INFO] [stderr] Checking strum v0.25.0 [INFO] [stderr] Checking clap_lex v0.7.1 [INFO] [stderr] Checking piper v0.2.3 [INFO] [stderr] Checking url v2.5.2 [INFO] [stderr] Checking async-channel v2.3.1 [INFO] [stderr] Checking bigdecimal v0.3.1 [INFO] [stderr] Checking inout v0.1.3 [INFO] [stderr] Checking clap_builder v4.5.9 [INFO] [stderr] Checking indexmap v2.2.6 [INFO] [stderr] Checking hashlink v0.8.4 [INFO] [stderr] Compiling async-io v1.13.0 [INFO] [stderr] Checking thread_local v1.1.8 [INFO] [stderr] Compiling unicase v2.7.0 [INFO] [stderr] Checking fastrand v1.9.0 [INFO] [stderr] Checking waker-fn v1.2.0 [INFO] [stderr] Checking linux-raw-sys v0.3.8 [INFO] [stderr] Checking cipher v0.4.4 [INFO] [stderr] Compiling grammers-tl-types v0.6.0 (https://github.com/Lonami/grammers#345a3f89) [INFO] [stderr] Checking futures-lite v1.13.0 [INFO] [stderr] Checking hmac v0.12.1 [INFO] [stderr] Checking async-lock v2.8.0 [INFO] [stderr] Checking core2 v0.4.0 [INFO] [stderr] Checking socket2 v0.4.10 [INFO] [stderr] Checking blocking v1.6.1 [INFO] [stderr] Compiling openssl-sys v0.9.103 [INFO] [stderr] Compiling libsqlite3-sys v0.27.0 [INFO] [stderr] Checking async-executor v1.12.0 [INFO] [stderr] Checking glob v0.3.1 [INFO] [stderr] Checking pbkdf2 v0.12.2 [INFO] [stderr] Checking aes v0.8.4 [INFO] [stderr] Checking glass_pumpkin v1.7.0 [INFO] [stderr] Checking sha1 v0.10.6 [INFO] [stderr] Checking regex-automata v0.4.7 [INFO] [stderr] Checking async-channel v1.9.0 [INFO] [stderr] Checking kv-log-macro v1.0.7 [INFO] [stderr] Checking miniz_oxide v0.7.4 [INFO] [stderr] Compiling grammers-session v0.5.2 (https://github.com/Lonami/grammers#345a3f89) [INFO] [stderr] Checking dirs-sys v0.4.1 [INFO] [stderr] Compiling native-tls v0.2.12 [INFO] [stderr] Checking raw-cpuid v11.0.2 [INFO] [stderr] Compiling mime_guess v2.0.5 [INFO] [stderr] Compiling moka v0.12.8 [INFO] [stderr] Checking flate2 v1.0.30 [INFO] [stderr] Checking regex-automata v0.1.10 [INFO] [stderr] Compiling anyhow v1.0.86 [INFO] [stderr] Checking dirs v5.0.1 [INFO] [stderr] Checking os_info v3.8.2 [INFO] [stderr] Checking grammers-crypto v0.6.1 (https://github.com/Lonami/grammers#345a3f89) [INFO] [stderr] Checking crossbeam-epoch v0.9.18 [INFO] [stderr] Checking crossbeam-channel v0.5.13 [INFO] [stderr] Checking is-terminal v0.4.12 [INFO] [stderr] Checking triomphe v0.1.11 [INFO] [stderr] Checking md5 v0.7.0 [INFO] [stderr] Checking locate-locale v0.2.0 [INFO] [stderr] Checking humantime v2.1.0 [INFO] [stderr] Checking shellexpand v3.1.0 [INFO] [stderr] Checking quanta v0.12.3 [INFO] [stderr] Checking matchers v0.1.0 [INFO] [stderr] Checking regex v1.10.5 [INFO] [stderr] Compiling serde_derive v1.0.204 [INFO] [stderr] Compiling futures-macro v0.3.30 [INFO] [stderr] Compiling thiserror-impl v1.0.62 [INFO] [stderr] Compiling tracing-attributes v0.1.27 [INFO] [stderr] Compiling tokio-macros v2.3.0 [INFO] [stderr] Compiling openssl-macros v0.1.1 [INFO] [stderr] Compiling inherent v1.0.11 [INFO] [stderr] Compiling async-stream-impl v0.3.5 [INFO] [stderr] Compiling async-trait v0.1.81 [INFO] [stderr] Compiling clap_derive v4.5.8 [INFO] [stderr] Checking env_logger v0.10.2 [INFO] [stderr] Checking async-stream v0.3.5 [INFO] [stderr] Compiling proc-macro-error v1.0.4 [INFO] [stderr] Checking futures-util v0.3.30 [INFO] [stderr] Checking tokio v1.38.0 [INFO] [stderr] Compiling sea-query-derive v0.4.1 [INFO] [stderr] Checking tracing v0.1.40 [INFO] [stderr] Checking polling v3.7.2 [INFO] [stderr] Checking tracing-subscriber v0.3.18 [INFO] [stderr] Compiling derivative v2.2.0 [INFO] [stderr] Compiling ouroboros_macro v0.17.2 [INFO] [stderr] Compiling sea-bae v0.2.0 [INFO] [stderr] Compiling sea-schema-derive v0.2.0 [INFO] [stderr] Compiling async-attributes v1.1.2 [INFO] [stderr] Checking clap v4.5.9 [INFO] [stderr] Compiling sea-orm-macros v0.12.15 [INFO] [stderr] Checking async-io v2.3.3 [INFO] [stderr] Checking ouroboros v0.17.2 [INFO] [stderr] Checking futures-executor v0.3.30 [INFO] [stderr] Checking futures v0.3.30 [INFO] [stderr] Checking tokio-stream v0.1.15 [INFO] [stderr] Checking async-global-executor v2.4.1 [INFO] [stderr] Checking async-std v1.12.0 [INFO] [stderr] Checking deranged v0.3.11 [INFO] [stderr] Checking chrono v0.4.38 [INFO] [stderr] Checking uuid v1.10.0 [INFO] [stderr] Checking either v1.13.0 [INFO] [stderr] Checking time v0.3.36 [INFO] [stderr] Checking sea-query v0.30.7 [INFO] [stderr] Checking sqlx-core v0.7.4 [INFO] [stderr] Checking sea-schema v0.14.2 [INFO] [stderr] Checking sqlx-sqlite v0.7.4 [INFO] [stderr] Checking sea-orm-cli v0.12.15 [INFO] [stderr] Checking sqlx v0.7.4 [INFO] [stderr] Checking sea-query-binder v0.5.0 [INFO] [stderr] Checking sea-orm v0.12.15 [INFO] [stderr] Checking grammers-mtproto v0.6.0 (https://github.com/Lonami/grammers#345a3f89) [INFO] [stderr] Checking grammers-mtsender v0.5.1 (https://github.com/Lonami/grammers#345a3f89) [INFO] [stderr] Checking grammers-client v0.6.0 (https://github.com/Lonami/grammers#345a3f89) [INFO] [stderr] Checking sea-orm-migration v0.12.15 [INFO] [stderr] Checking entity v0.1.0 (/opt/rustwide/workdir/entity) [INFO] [stderr] Checking migration v0.1.0 (/opt/rustwide/workdir/migration) [INFO] [stderr] Checking teledump v0.1.0 (/opt/rustwide/workdir) [INFO] [stdout] warning: field `download_semaphore` is never read [INFO] [stdout] --> src/bot.rs:35:5 [INFO] [stdout] | [INFO] [stdout] 27 | pub struct Bot { [INFO] [stdout] | --- field in this struct [INFO] [stdout] ... [INFO] [stdout] 35 | download_semaphore: Arc, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `Bot` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis [INFO] [stdout] = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `store_path` is never read [INFO] [stdout] --> src/config.rs:12:9 [INFO] [stdout] | [INFO] [stdout] 9 | pub struct Config { [INFO] [stdout] | ------ field in this struct [INFO] [stdout] ... [INFO] [stdout] 12 | pub store_path: String, [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `get_message_count_by_chat` is never used [INFO] [stdout] --> src/db.rs:164:18 [INFO] [stdout] | [INFO] [stdout] 18 | impl Db { [INFO] [stdout] | ------- method in this implementation [INFO] [stdout] ... [INFO] [stdout] 164 | pub async fn get_message_count_by_chat(&self, chat_id: i64) -> anyhow::Result { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `download_semaphore` is never read [INFO] [stdout] --> src/bot.rs:35:5 [INFO] [stdout] | [INFO] [stdout] 27 | pub struct Bot { [INFO] [stdout] | --- field in this struct [INFO] [stdout] ... [INFO] [stdout] 35 | download_semaphore: Arc, [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^ [INFO] [stdout] | [INFO] [stdout] = note: `Bot` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis [INFO] [stdout] = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: field `store_path` is never read [INFO] [stdout] --> src/config.rs:12:9 [INFO] [stdout] | [INFO] [stdout] 9 | pub struct Config { [INFO] [stdout] | ------ field in this struct [INFO] [stdout] ... [INFO] [stdout] 12 | pub store_path: String, [INFO] [stdout] | ^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: method `get_message_count_by_chat` is never used [INFO] [stdout] --> src/db.rs:164:18 [INFO] [stdout] | [INFO] [stdout] 18 | impl Db { [INFO] [stdout] | ------- method in this implementation [INFO] [stdout] ... [INFO] [stdout] 164 | pub async fn get_message_count_by_chat(&self, chat_id: i64) -> anyhow::Result { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: redundant pattern matching, consider using `is_err()` [INFO] [stdout] --> src/bot.rs:108:19 [INFO] [stdout] | [INFO] [stdout] 108 | while let Err(_) = self.save_user_private_chats().await { [INFO] [stdout] | ----------^^^^^^--------------------------------------- help: try: `while self.save_user_private_chats().await.is_err()` [INFO] [stdout] | [INFO] [stdout] = note: this will change drop order of the result, as well as all temporaries [INFO] [stdout] = note: add `#[allow(clippy::redundant_pattern_matching)]` if this is important [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: redundant pattern matching, consider using `is_err()` [INFO] [stdout] --> src/bot.rs:108:19 [INFO] [stdout] | [INFO] [stdout] 108 | while let Err(_) = self.save_user_private_chats().await { [INFO] [stdout] | ----------^^^^^^--------------------------------------- help: try: `while self.save_user_private_chats().await.is_err()` [INFO] [stdout] | [INFO] [stdout] = note: this will change drop order of the result, as well as all temporaries [INFO] [stdout] = note: add `#[allow(clippy::redundant_pattern_matching)]` if this is important [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: this expression creates a reference which is immediately dereferenced by the compiler [INFO] [stdout] --> src/bot.rs:198:47 [INFO] [stdout] | [INFO] [stdout] 198 | match self.handle_message(&message).await { [INFO] [stdout] | ^^^^^^^^ help: change this to: `message` [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] --> src/bot.rs:198:47 [INFO] [stdout] | [INFO] [stdout] 198 | match self.handle_message(&message).await { [INFO] [stdout] | ^^^^^^^^ help: change this to: `message` [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: you seem to be trying to use `match` for destructuring a single pattern. Consider using `if let` [INFO] [stdout] --> src/bot.rs:204:21 [INFO] [stdout] | [INFO] [stdout] 204 | / match self.save_message(message).await { [INFO] [stdout] 205 | | Ok(_) => {} [INFO] [stdout] 206 | | Err(_) => {} [INFO] [stdout] 207 | | } [INFO] [stdout] | |_____________________^ help: try: `if let Ok(_) = self.save_message(message).await {}` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#single_match [INFO] [stdout] = note: `#[warn(clippy::single_match)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: you seem to be trying to use `match` for destructuring a single pattern. Consider using `if let` [INFO] [stdout] --> src/bot.rs:204:21 [INFO] [stdout] | [INFO] [stdout] 204 | / match self.save_message(message).await { [INFO] [stdout] 205 | | Ok(_) => {} [INFO] [stdout] 206 | | Err(_) => {} [INFO] [stdout] 207 | | } [INFO] [stdout] | |_____________________^ help: try: `if let Ok(_) = self.save_message(message).await {}` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#single_match [INFO] [stdout] = note: `#[warn(clippy::single_match)]` 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/bot.rs:252:45 [INFO] [stdout] | [INFO] [stdout] 252 | if self.db.is_message_already_saved(&message).await { [INFO] [stdout] | ^^^^^^^^ help: change this to: `message` [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 expression creates a reference which is immediately dereferenced by the compiler [INFO] [stdout] --> src/bot.rs:252:45 [INFO] [stdout] | [INFO] [stdout] 252 | if self.db.is_message_already_saved(&message).await { [INFO] [stdout] | ^^^^^^^^ help: change this to: `message` [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: redundant pattern matching, consider using `is_some()` [INFO] [stdout] --> src/bot.rs:270:21 [INFO] [stdout] | [INFO] [stdout] 270 | / match message.media() { [INFO] [stdout] 271 | | None => false, [INFO] [stdout] 272 | | Some(_) => true, [INFO] [stdout] 273 | | } [INFO] [stdout] | |_____________________^ help: try: `message.media().is_some()` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#redundant_pattern_matching [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: redundant pattern matching, consider using `is_some()` [INFO] [stdout] --> src/bot.rs:270:21 [INFO] [stdout] | [INFO] [stdout] 270 | / match message.media() { [INFO] [stdout] 271 | | None => false, [INFO] [stdout] 272 | | Some(_) => true, [INFO] [stdout] 273 | | } [INFO] [stdout] | |_____________________^ help: try: `message.media().is_some()` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#redundant_pattern_matching [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `to_string` applied to a type that implements `Display` in `format!` args [INFO] [stdout] --> src/bot.rs:339:49 [INFO] [stdout] | [INFO] [stdout] 339 | ... message.id().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 `format!` args [INFO] [stdout] --> src/bot.rs:339:49 [INFO] [stdout] | [INFO] [stdout] 339 | ... message.id().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: unneeded `return` statement [INFO] [stdout] --> src/bot.rs:434:13 [INFO] [stdout] | [INFO] [stdout] 434 | / return if mime_type.is_none() || mime_type.unwrap().is_empty() { [INFO] [stdout] 435 | | format!( [INFO] [stdout] 436 | | ".{}", [INFO] [stdout] 437 | | Path::new(document.name()) [INFO] [stdout] ... | [INFO] [stdout] 443 | | get_mime_extension(document.mime_type()).unwrap() [INFO] [stdout] 444 | | }; [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] 434 ~ if mime_type.is_none() || mime_type.unwrap().is_empty() { [INFO] [stdout] 435 + format!( [INFO] [stdout] 436 + ".{}", [INFO] [stdout] 437 + Path::new(document.name()) [INFO] [stdout] 438 + .extension() [INFO] [stdout] 439 + .and_then(OsStr::to_str) [INFO] [stdout] 440 + .unwrap_or_default() [INFO] [stdout] 441 + ) [INFO] [stdout] 442 + } else { [INFO] [stdout] 443 + get_mime_extension(document.mime_type()).unwrap() [INFO] [stdout] 444 ~ } [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unneeded `return` statement [INFO] [stdout] --> src/bot.rs:434:13 [INFO] [stdout] | [INFO] [stdout] 434 | / return if mime_type.is_none() || mime_type.unwrap().is_empty() { [INFO] [stdout] 435 | | format!( [INFO] [stdout] 436 | | ".{}", [INFO] [stdout] 437 | | Path::new(document.name()) [INFO] [stdout] ... | [INFO] [stdout] 443 | | get_mime_extension(document.mime_type()).unwrap() [INFO] [stdout] 444 | | }; [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] 434 ~ if mime_type.is_none() || mime_type.unwrap().is_empty() { [INFO] [stdout] 435 + format!( [INFO] [stdout] 436 + ".{}", [INFO] [stdout] 437 + Path::new(document.name()) [INFO] [stdout] 438 + .extension() [INFO] [stdout] 439 + .and_then(OsStr::to_str) [INFO] [stdout] 440 + .unwrap_or_default() [INFO] [stdout] 441 + ) [INFO] [stdout] 442 + } else { [INFO] [stdout] 443 + get_mime_extension(document.mime_type()).unwrap() [INFO] [stdout] 444 ~ } [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unneeded `return` statement [INFO] [stdout] --> src/bot.rs:452:5 [INFO] [stdout] | [INFO] [stdout] 452 | / return mime_type.map(|m| { [INFO] [stdout] 453 | | let mime: Mime = m.parse().unwrap(); [INFO] [stdout] 454 | | format!(".{}", mime.subtype().to_string()) [INFO] [stdout] 455 | | }); [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] 452 ~ mime_type.map(|m| { [INFO] [stdout] 453 + let mime: Mime = m.parse().unwrap(); [INFO] [stdout] 454 + format!(".{}", mime.subtype().to_string()) [INFO] [stdout] 455 ~ }) [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `to_string` applied to a type that implements `Display` in `format!` args [INFO] [stdout] --> src/bot.rs:454:38 [INFO] [stdout] | [INFO] [stdout] 454 | format!(".{}", mime.subtype().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: unneeded `return` statement [INFO] [stdout] --> src/bot.rs:452:5 [INFO] [stdout] | [INFO] [stdout] 452 | / return mime_type.map(|m| { [INFO] [stdout] 453 | | let mime: Mime = m.parse().unwrap(); [INFO] [stdout] 454 | | format!(".{}", mime.subtype().to_string()) [INFO] [stdout] 455 | | }); [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] 452 ~ mime_type.map(|m| { [INFO] [stdout] 453 + let mime: Mime = m.parse().unwrap(); [INFO] [stdout] 454 + format!(".{}", mime.subtype().to_string()) [INFO] [stdout] 455 ~ }) [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function call inside of `expect` [INFO] [stdout] --> src/config.rs:23:14 [INFO] [stdout] | [INFO] [stdout] 23 | .expect(&format!("Failed to parse {API_ID}")); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: try: `unwrap_or_else(|_| panic!("Failed to parse {API_ID}"))` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#expect_fun_call [INFO] [stdout] = note: `#[warn(clippy::expect_fun_call)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: `to_string` applied to a type that implements `Display` in `format!` args [INFO] [stdout] --> src/bot.rs:454:38 [INFO] [stdout] | [INFO] [stdout] 454 | format!(".{}", mime.subtype().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 call inside of `expect` [INFO] [stdout] --> src/config.rs:21:14 [INFO] [stdout] | [INFO] [stdout] 21 | .expect(&format!("{API_ID} must be set!")) [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: try: `unwrap_or_else(|_| panic!("{API_ID} must be set!"))` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#expect_fun_call [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function call inside of `expect` [INFO] [stdout] --> src/config.rs:24:43 [INFO] [stdout] | [INFO] [stdout] 24 | let api_hash = env::var(API_HASH).expect(&format!("{API_HASH} must be set!")); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: try: `unwrap_or_else(|_| panic!("{API_HASH} must be set!"))` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#expect_fun_call [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function call inside of `expect` [INFO] [stdout] --> src/config.rs:23:14 [INFO] [stdout] | [INFO] [stdout] 23 | .expect(&format!("Failed to parse {API_ID}")); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: try: `unwrap_or_else(|_| panic!("Failed to parse {API_ID}"))` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#expect_fun_call [INFO] [stdout] = note: `#[warn(clippy::expect_fun_call)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function call inside of `expect` [INFO] [stdout] --> src/config.rs:26:51 [INFO] [stdout] | [INFO] [stdout] 26 | let store_path = env::var(STORE_PATH).expect(&format!("{STORE_PATH} must be set!")); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: try: `unwrap_or_else(|_| panic!("{STORE_PATH} must be set!"))` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#expect_fun_call [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function call inside of `expect` [INFO] [stdout] --> src/config.rs:21:14 [INFO] [stdout] | [INFO] [stdout] 21 | .expect(&format!("{API_ID} must be set!")) [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: try: `unwrap_or_else(|_| panic!("{API_ID} must be set!"))` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#expect_fun_call [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function call inside of `expect` [INFO] [stdout] --> src/config.rs:24:43 [INFO] [stdout] | [INFO] [stdout] 24 | let api_hash = env::var(API_HASH).expect(&format!("{API_HASH} must be set!")); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: try: `unwrap_or_else(|_| panic!("{API_HASH} must be set!"))` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#expect_fun_call [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: function call inside of `expect` [INFO] [stdout] --> src/config.rs:26:51 [INFO] [stdout] | [INFO] [stdout] 26 | let store_path = env::var(STORE_PATH).expect(&format!("{STORE_PATH} must be set!")); [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ help: try: `unwrap_or_else(|_| panic!("{STORE_PATH} must be set!"))` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#expect_fun_call [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unneeded `return` statement [INFO] [stdout] --> src/db.rs:47:9 [INFO] [stdout] | [INFO] [stdout] 47 | return if let Some(_) = msg { true } else { false }; [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] 47 - return if let Some(_) = msg { true } else { false }; [INFO] [stdout] 47 + if let Some(_) = msg { true } else { false } [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: redundant pattern matching, consider using `is_some()` [INFO] [stdout] --> src/db.rs:47:23 [INFO] [stdout] | [INFO] [stdout] 47 | return if let Some(_) = msg { true } else { false }; [INFO] [stdout] | -------^^^^^^^------ help: try: `if msg.is_some()` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#redundant_pattern_matching [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unneeded `return` statement [INFO] [stdout] --> src/db.rs:47:9 [INFO] [stdout] | [INFO] [stdout] 47 | return if let Some(_) = msg { true } else { false }; [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] 47 - return if let Some(_) = msg { true } else { false }; [INFO] [stdout] 47 + if let Some(_) = msg { true } else { false } [INFO] [stdout] | [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: redundant pattern matching, consider using `is_some()` [INFO] [stdout] --> src/db.rs:47:23 [INFO] [stdout] | [INFO] [stdout] 47 | return if let Some(_) = msg { true } else { false }; [INFO] [stdout] | -------^^^^^^^------ help: try: `if msg.is_some()` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#redundant_pattern_matching [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: if let can be simplified with `.unwrap_or_default()` [INFO] [stdout] --> src/db.rs:138:9 [INFO] [stdout] | [INFO] [stdout] 138 | / if let Ok(msg) = message { [INFO] [stdout] 139 | | msg [INFO] [stdout] 140 | | } else { [INFO] [stdout] 141 | | None [INFO] [stdout] 142 | | } [INFO] [stdout] | |_________^ help: ascribe the type std::option::Option and replace your expression with: `message.unwrap_or_default()` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#manual_unwrap_or_default [INFO] [stdout] = note: `#[warn(clippy::manual_unwrap_or_default)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: if let can be simplified with `.unwrap_or_default()` [INFO] [stdout] --> src/db.rs:138:9 [INFO] [stdout] | [INFO] [stdout] 138 | / if let Ok(msg) = message { [INFO] [stdout] 139 | | msg [INFO] [stdout] 140 | | } else { [INFO] [stdout] 141 | | None [INFO] [stdout] 142 | | } [INFO] [stdout] | |_________^ help: ascribe the type std::option::Option and replace your expression with: `message.unwrap_or_default()` [INFO] [stdout] | [INFO] [stdout] = help: for further information visit https://rust-lang.github.io/rust-clippy/master/index.html#manual_unwrap_or_default [INFO] [stdout] = note: `#[warn(clippy::manual_unwrap_or_default)]` on by default [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: useless use of `vec!` [INFO] [stdout] --> src/bot.rs:303:47 [INFO] [stdout] | [INFO] [stdout] 303 | .get_messages_by_id(chat, &vec![message_model.id]) [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ help: you can use a slice directly: `&[message_model.id]` [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] [INFO] [stdout] [INFO] [stdout] warning: useless use of `vec!` [INFO] [stdout] --> src/bot.rs:303:47 [INFO] [stdout] | [INFO] [stdout] 303 | .get_messages_by_id(chat, &vec![message_model.id]) [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^^ help: you can use a slice directly: `&[message_model.id]` [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] [INFO] [stdout] [INFO] [stderr] Finished `dev` profile [unoptimized + debuginfo] target(s) in 53.09s [INFO] running `Command { std: "docker" "inspect" "e23db4117d5c6d6d3be8bdd9e2a15c44064563800edb19d9cb0be4bad62813d2", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "e23db4117d5c6d6d3be8bdd9e2a15c44064563800edb19d9cb0be4bad62813d2", kill_on_drop: false }` [INFO] [stdout] e23db4117d5c6d6d3be8bdd9e2a15c44064563800edb19d9cb0be4bad62813d2