[INFO] fetching crate rmg 0.5.11...
[INFO] checking rmg-0.5.11 against 1.95.0 for pr-155915
[INFO] extracting crate rmg 0.5.11 into /workspace/builds/worker-7-tc1/source
[INFO] started tweaking crates.io crate rmg 0.5.11
[INFO] finished tweaking crates.io crate rmg 0.5.11
[INFO] tweaked toml for crates.io crate rmg 0.5.11 written to /workspace/builds/worker-7-tc1/source/Cargo.toml
[INFO] validating manifest of crates.io crate rmg 0.5.11 on toolchain 1.95.0
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1.95.0" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate crates.io crate rmg 0.5.11 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" "+1.95.0" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr] warning: unused manifest key: bench.0.plugin
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded usvg-text-layout v0.32.0
[INFO] [stderr]   Downloaded strict-num v0.1.0
[INFO] [stderr]   Downloaded usvg-tree v0.32.0
[INFO] [stderr]   Downloaded usvg v0.32.0
[INFO] [stderr]   Downloaded imagesize v0.11.0
[INFO] [stderr]   Downloaded kurbo v0.9.4
[INFO] [stderr]   Downloaded nohash v0.2.0
[INFO] [stderr]   Downloaded enumn v0.1.8
[INFO] [stderr]   Downloaded four-cc v0.2.0
[INFO] [stderr]   Downloaded svgtypes v0.11.0
[INFO] [stderr]   Downloaded gif-dispose v4.0.0
[INFO] [stderr]   Downloaded xmlparser v0.13.5
[INFO] [stderr]   Downloaded infer v0.13.0
[INFO] [stderr]   Downloaded lexopt v0.3.0
[INFO] [stderr]   Downloaded cmake v0.1.50
[INFO] [stderr]   Downloaded fontdb v0.13.1
[INFO] [stderr]   Downloaded rosvgtree v0.3.0
[INFO] [stderr]   Downloaded fontconfig-parser v0.5.2
[INFO] [stderr]   Downloaded asefile v0.3.5
[INFO] [stderr]   Downloaded usvg-parser v0.32.0
[INFO] [stderr]   Downloaded roxmltree v0.18.0
[INFO] [stderr]   Downloaded imgref v1.9.4
[INFO] [stderr]   Downloaded tracing v0.1.38
[INFO] [stderr]   Downloaded zune-inflate v0.2.53
[INFO] [stderr]   Downloaded bumpalo v3.12.1
[INFO] [stderr]   Downloaded resvg v0.32.0
[INFO] [stderr]   Downloaded fast_image_resize v2.7.0
[INFO] [stderr]   Downloaded minifb v0.24.0
[INFO] [stderr]   Downloaded uuid v1.3.1
[INFO] [stderr]   Downloaded ttf-parser v0.18.1
[INFO] [stderr]   Downloaded sysinfo v0.28.4
[INFO] [stderr]   Downloaded tiny-skia-path v0.9.0
[INFO] [stderr]   Downloaded unicode-script v0.5.5
[INFO] [stderr]   Downloaded tiny-skia v0.9.0
[INFO] [stderr]   Downloaded rustybuzz v0.7.0
[INFO] [stderr]   Downloaded image v0.24.6
[INFO] [stderr]   Downloaded rustix v0.37.14
[INFO] [stderr]   Downloaded gif v0.12.0
[INFO] [stderr]   Downloaded linux-raw-sys v0.3.4
[INFO] [stderr]   Downloaded orbclient v0.3.44
[INFO] [stderr]   Downloaded libheif-rs v0.19.2
[INFO] [stderr]   Downloaded libheif-sys v1.14.2
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+1.95.0" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] a2090f6fedb0eda8b3476c927b43dd285ac6505cbb3c6e4eef45596ca99288ab
[INFO] running `Command { std: "docker" "start" "-a" "a2090f6fedb0eda8b3476c927b43dd285ac6505cbb3c6e4eef45596ca99288ab", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "a2090f6fedb0eda8b3476c927b43dd285ac6505cbb3c6e4eef45596ca99288ab", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "a2090f6fedb0eda8b3476c927b43dd285ac6505cbb3c6e4eef45596ca99288ab", kill_on_drop: false }`
[INFO] [stdout] a2090f6fedb0eda8b3476c927b43dd285ac6505cbb3c6e4eef45596ca99288ab
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+1.95.0" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 7f67871a3c791a931402f1648f0d74fb8d359cbc0ebe325539ebc644b5787ea2
[INFO] running `Command { std: "docker" "start" "-a" "7f67871a3c791a931402f1648f0d74fb8d359cbc0ebe325539ebc644b5787ea2", kill_on_drop: false }`
[INFO] [stderr] warning: unused manifest key: bench.0.plugin
[INFO] [stderr]    Compiling pkg-config v0.3.26
[INFO] [stderr]    Compiling num-traits v0.2.15
[INFO] [stderr]    Compiling syn v2.0.15
[INFO] [stderr]     Checking num_cpus v1.15.0
[INFO] [stderr]    Compiling syn v1.0.109
[INFO] [stderr]     Checking subtle v2.4.1
[INFO] [stderr]    Compiling crc32fast v1.3.2
[INFO] [stderr]     Checking miniz_oxide v0.6.2
[INFO] [stderr]     Checking rayon-core v1.11.0
[INFO] [stderr]    Compiling lock_api v0.4.9
[INFO] [stderr]     Checking digest v0.10.6
[INFO] [stderr]    Compiling futures-core v0.3.28
[INFO] [stderr]     Checking flate2 v1.0.25
[INFO] [stderr]     Checking getrandom v0.2.9
[INFO] [stderr]    Compiling bzip2-sys v0.1.11+1.0.8
[INFO] [stderr]    Compiling num-integer v0.1.45
[INFO] [stderr]     Checking weezl v0.1.7
[INFO] [stderr]     Checking rayon v1.7.0
[INFO] [stderr]     Checking byteorder v1.4.3
[INFO] [stderr]     Checking bytemuck v1.13.1
[INFO] [stderr]     Checking nanorand v0.7.0
[INFO] [stderr]    Compiling x11-dl v2.21.0
[INFO] [stderr]     Checking spin v0.9.8
[INFO] [stderr]     Checking tracing-core v0.1.30
[INFO] [stderr]    Compiling num-rational v0.4.1
[INFO] [stderr]     Checking simd-adler32 v0.3.5
[INFO] [stderr]     Checking futures-sink v0.3.28
[INFO] [stderr]     Checking smallvec v1.10.0
[INFO] [stderr]     Checking color_quant v1.1.0
[INFO] [stderr]     Checking base64ct v1.6.0
[INFO] [stderr]    Compiling proc-macro2 v1.0.56
[INFO] [stderr]     Checking regex-syntax v0.7.1
[INFO] [stderr]     Checking password-hash v0.4.2
[INFO] [stderr]     Checking gif v0.12.0
[INFO] [stderr]     Checking zune-inflate v0.2.53
[INFO] [stderr]     Checking hmac v0.12.1
[INFO] [stderr]     Checking sha2 v0.10.6
[INFO] [stderr]    Compiling minifb v0.24.0
[INFO] [stderr]     Checking cipher v0.3.0
[INFO] [stderr]     Checking uuid v1.3.1
[INFO] [stderr]     Checking bit_field v0.10.2
[INFO] [stderr]     Checking cty v0.2.2
[INFO] [stderr]     Checking lebe v0.5.2
[INFO] [stderr]     Checking half v2.2.1
[INFO] [stderr]     Checking aes v0.7.5
[INFO] [stderr]     Checking cfb v0.7.3
[INFO] [stderr]     Checking raw-window-handle v0.4.3
[INFO] [stderr]     Checking pbkdf2 v0.11.0
[INFO] [stderr]     Checking regex v1.8.1
[INFO] [stderr]     Checking tracing-log v0.1.3
[INFO] [stderr]     Checking bzip2 v0.4.4
[INFO] [stderr]     Checking matchers v0.1.0
[INFO] [stderr]     Checking rgb v0.8.36
[INFO] [stderr]     Checking qoi v0.4.1
[INFO] [stderr]     Checking png v0.17.7
[INFO] [stderr]     Checking sharded-slab v0.1.4
[INFO] [stderr]     Checking sha1 v0.10.5
[INFO] [stderr]     Checking jpeg-decoder v0.3.0
[INFO] [stderr]     Checking thread_local v1.1.7
[INFO] [stderr]     Checking filetime v0.2.21
[INFO] [stderr]     Checking xattr v0.2.3
[INFO] [stderr]     Checking dirs-sys-next v0.1.2
[INFO] [stderr]     Checking imgref v1.9.4
[INFO] [stderr]     Checking os_str_bytes v6.5.0
[INFO] [stderr]     Checking ciborium-io v0.2.0
[INFO] [stderr]     Checking ciborium-ll v0.2.0
[INFO] [stderr]     Checking tar v0.4.38
[INFO] [stderr]     Checking gif-dispose v4.0.0
[INFO] [stderr]     Checking clap_lex v0.2.4
[INFO] [stderr]     Checking zip v0.6.4
[INFO] [stderr]     Checking dirs-next v2.0.0
[INFO] [stderr]     Checking infer v0.13.0
[INFO] [stderr]     Checking tiff v0.8.1
[INFO] [stderr]     Checking sysinfo v0.28.4
[INFO] [stderr]     Checking lexopt v0.3.0
[INFO] [stderr]     Checking clap v3.2.23
[INFO] [stderr]     Checking criterion-plot v0.5.0
[INFO] [stderr]     Checking plotters v0.3.4
[INFO] [stderr]     Checking atty v0.2.14
[INFO] [stderr]    Compiling pin-project-internal v1.0.12
[INFO] [stderr]    Compiling serde_derive v1.0.160
[INFO] [stderr]    Compiling tracing-attributes v0.1.24
[INFO] [stderr]    Compiling thiserror-impl v1.0.40
[INFO] [stderr]     Checking pin-project v1.0.12
[INFO] [stderr]     Checking flume v0.10.14
[INFO] [stderr]     Checking tracing v0.1.38
[INFO] [stderr]     Checking thiserror v1.0.40
[INFO] [stderr]     Checking exr v1.6.3
[INFO] [stderr]     Checking fast_image_resize v2.7.0
[INFO] [stderr]     Checking tracing-subscriber v0.3.17
[INFO] [stderr]     Checking serde v1.0.160
[INFO] [stderr]     Checking image v0.24.6
[INFO] [stderr]     Checking serde_json v1.0.96
[INFO] [stderr]     Checking ciborium v0.2.0
[INFO] [stderr]     Checking tinytemplate v1.2.1
[INFO] [stderr]     Checking criterion v0.4.0
[INFO] [stderr]     Checking rmg v0.5.11 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unnecessary parentheses around function argument
[INFO] [stdout]    --> src/archive.rs:169:31
[INFO] [stdout]     |
[INFO] [stdout] 169 |         path.extend(vec!['0'; (width - filename.len())]);
[INFO] [stdout]     |                               ^                      ^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 169 -         path.extend(vec!['0'; (width - filename.len())]);
[INFO] [stdout] 169 +         path.extend(vec!['0'; width - filename.len() ]);
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `FPS`
[INFO] [stdout]  --> src/img/gif.rs:1:24
[INFO] [stdout]   |
[INFO] [stdout] 1 | use crate::{img::Size, FPS};
[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: `image`
[INFO] [stdout]  --> src/img.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 | use image;
[INFO] [stdout]   |     ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]    --> src/img.rs:215:20
[INFO] [stdout]     |
[INFO] [stdout] 215 |     let x_offset = ((bgw - fgw) / 2);
[INFO] [stdout]     |                    ^               ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 215 -     let x_offset = ((bgw - fgw) / 2);
[INFO] [stdout] 215 +     let x_offset = (bgw - fgw) / 2;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::img::*`
[INFO] [stdout]    --> src/img.rs:251:13
[INFO] [stdout]     |
[INFO] [stdout] 251 |     pub use crate::img::*;
[INFO] [stdout]     |             ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Turn`, `sleep_ms`, and `thread`
[INFO] [stdout]  --> src/render/display.rs:2:13
[INFO] [stdout]   |
[INFO] [stdout] 2 |     render, sleep_ms, thread, ArchiveType, AsyncTask, Canvas, Config, Data, ForAsyncTask, KeyMap,
[INFO] [stdout]   |             ^^^^^^^^  ^^^^^^
[INFO] [stdout] 3 |     MetaSize, Once, Page, PageList, PathBuf, Scroll, TaskResize, Turn, ViewMode,
[INFO] [stdout]   |                                                                  ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Img` and `Page`
[INFO] [stdout]  --> src/render/scroll.rs:2:80
[INFO] [stdout]   |
[INFO] [stdout] 2 |     match_event, sleep, AsyncTask, Buffer, Canvas, Config, Data, ForAsyncTask, Img, KeyMap, Map,
[INFO] [stdout]   |                                                                                ^^^
[INFO] [stdout] 3 |     Page, PageList, TMetaSize, TransRgba,
[INFO] [stdout]   |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Arc` and `RwLock`
[INFO] [stdout]  --> src/render/turn.rs:7:12
[INFO] [stdout]   |
[INFO] [stdout] 7 |     sync::{Arc, RwLock},
[INFO] [stdout]   |            ^^^  ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::f32::consts::PI`
[INFO] [stdout]  --> src/render/draw.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::f32::consts::PI;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `super::GraphPath`
[INFO] [stdout]   --> src/render/draw.rs:80:9
[INFO] [stdout]    |
[INFO] [stdout] 80 |     use super::GraphPath;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Path` and `yield_now`
[INFO] [stdout]   --> src/render.rs:13:48
[INFO] [stdout]    |
[INFO] [stdout] 13 |     archive::*, img::*, mem, sleep_ms, thread, yield_now, Arc, FilterType, Path, PathBuf, RwLock,
[INFO] [stdout]    |                                                ^^^^^^^^^                   ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `self`
[INFO] [stdout]    --> src/render.rs:324:23
[INFO] [stdout]     |
[INFO] [stdout] 324 |             archive::{self, ForExtract},
[INFO] [stdout]     |                       ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::thread::sleep_ms`: replaced by `std::thread::sleep`
[INFO] [stdout]   --> src/lib.rs:27:20
[INFO] [stdout]    |
[INFO] [stdout] 27 |     thread::{self, sleep_ms, yield_now},
[INFO] [stdout]    |                    ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::thread::sleep_ms`: replaced by `std::thread::sleep`
[INFO] [stdout]   --> src/lib.rs:47:18
[INFO] [stdout]    |
[INFO] [stdout] 47 |     std::thread::sleep_ms(SLEEP_MS);
[INFO] [stdout]    |                  ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::thread::sleep_ms`: replaced by `std::thread::sleep`
[INFO] [stdout]   --> src/render.rs:13:30
[INFO] [stdout]    |
[INFO] [stdout] 13 |     archive::*, img::*, mem, sleep_ms, thread, yield_now, Arc, FilterType, Path, PathBuf, RwLock,
[INFO] [stdout]    |                              ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::thread::sleep_ms`: replaced by `std::thread::sleep`
[INFO] [stdout]   --> src/render.rs:43:13
[INFO] [stdout]    |
[INFO] [stdout] 43 |             sleep_ms(100);
[INFO] [stdout]    |             ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::thread::sleep_ms`: replaced by `std::thread::sleep`
[INFO] [stdout]  --> src/render/display.rs:2:13
[INFO] [stdout]   |
[INFO] [stdout] 2 |     render, sleep_ms, thread, ArchiveType, AsyncTask, Canvas, Config, Data, ForAsyncTask, KeyMap,
[INFO] [stdout]   |             ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::thread::sleep_ms`: replaced by `std::thread::sleep`
[INFO] [stdout]  --> src/render/turn.rs:8:13
[INFO] [stdout]   |
[INFO] [stdout] 8 |     thread::sleep_ms,
[INFO] [stdout]   |             ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::thread::sleep_ms`: replaced by `std::thread::sleep`
[INFO] [stdout]    --> src/render/turn.rs:115:13
[INFO] [stdout]     |
[INFO] [stdout] 115 |             sleep_ms(ms);
[INFO] [stdout]     |             ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable expression
[INFO] [stdout]   --> src/archive/tar.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 10 |         return feat::get_file(path, index);
[INFO] [stdout]    |         ---------------------------------- any code following this expression is unreachable
[INFO] [stdout] ...
[INFO] [stdout] 13 |     anyhow::bail!("")
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^ unreachable expression
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unreachable_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout]    = note: this warning originates in the macro `anyhow::bail` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable expression
[INFO] [stdout]   --> src/archive/tar.rs:25:5
[INFO] [stdout]    |
[INFO] [stdout] 22 |         return feat::get_list(path);
[INFO] [stdout]    |         --------------------------- any code following this expression is unreachable
[INFO] [stdout] ...
[INFO] [stdout] 25 |     anyhow::bail!("")
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^ unreachable expression
[INFO] [stdout]    |
[INFO] [stdout]    = note: this warning originates in the macro `anyhow::bail` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable expression
[INFO] [stdout]   --> src/archive/zip.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout]  9 |         return feat::get_file(path.as_ref(), index);
[INFO] [stdout]    |         ------------------------------------------- any code following this expression is unreachable
[INFO] [stdout] ...
[INFO] [stdout] 12 |     anyhow::bail!("")
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^ unreachable expression
[INFO] [stdout]    |
[INFO] [stdout]    = note: this warning originates in the macro `anyhow::bail` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable expression
[INFO] [stdout]   --> src/archive/zip.rs:24:5
[INFO] [stdout]    |
[INFO] [stdout] 21 |         return feat::get_list(path.as_ref());
[INFO] [stdout]    |         ------------------------------------ any code following this expression is unreachable
[INFO] [stdout] ...
[INFO] [stdout] 24 |     anyhow::bail!("")
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^ unreachable expression
[INFO] [stdout]    |
[INFO] [stdout]    = note: this warning originates in the macro `anyhow::bail` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable expression
[INFO] [stdout]   --> src/archive/zip.rs:36:5
[INFO] [stdout]    |
[INFO] [stdout] 33 |         return feat::extract(from.as_ref(), to.as_ref());
[INFO] [stdout]    |         ------------------------------------------------ any code following this expression is unreachable
[INFO] [stdout] ...
[INFO] [stdout] 36 |     anyhow::bail!("")
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^ unreachable expression
[INFO] [stdout]    |
[INFO] [stdout]    = note: this warning originates in the macro `anyhow::bail` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `TMetaSize`
[INFO] [stdout]  --> src/archive.rs:9:39
[INFO] [stdout]   |
[INFO] [stdout] 9 | use crate::{archive, ImgFormat, Page, TMetaSize, EXT_LIST};
[INFO] [stdout]   |                                       ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `TMetaSize`
[INFO] [stdout]  --> src/render/scroll.rs:3:21
[INFO] [stdout]   |
[INFO] [stdout] 3 |     Page, PageList, TMetaSize, TransRgba,
[INFO] [stdout]   |                     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable pattern
[INFO] [stdout]    --> src/config/rsconf.rs:291:17
[INFO] [stdout]     |
[INFO] [stdout] 291 |                 _ => {}
[INFO] [stdout]     |                 ^ no value can reach this
[INFO] [stdout]     |
[INFO] [stdout] note: multiple earlier patterns match some of the same values
[INFO] [stdout]    --> src/config/rsconf.rs:291:17
[INFO] [stdout]     |
[INFO] [stdout] 279 |                 ConfigType::Base => {
[INFO] [stdout]     |                 ---------------- matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 283 |                 ConfigType::Keymap => {
[INFO] [stdout]     |                 ------------------ matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 287 |                 ConfigType::Window => {
[INFO] [stdout]     |                 ------------------ matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 291 |                 _ => {}
[INFO] [stdout]     |                 ^ collectively making this unreachable
[INFO] [stdout]     = note: `#[warn(unreachable_patterns)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary `unsafe` block
[INFO] [stdout]    --> src/img.rs:190:5
[INFO] [stdout]     |
[INFO] [stdout] 190 |     unsafe {
[INFO] [stdout]     |     ^^^^^^ unnecessary `unsafe` block
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_unsafe)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/render/window.rs:28:13
[INFO] [stdout]    |
[INFO] [stdout] 28 |         let mut window = Window::new("rmg", width, height, windowoptions).unwrap();
[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: unused variable: `mem`
[INFO] [stdout]   --> src/render/scroll.rs:37:13
[INFO] [stdout]    |
[INFO] [stdout] 37 |         let mem = {
[INFO] [stdout]    |             ^^^ help: if this is intentional, prefix it with an underscore: `_mem`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `data`
[INFO] [stdout]    --> src/render/scroll.rs:163:46
[INFO] [stdout]     |
[INFO] [stdout] 163 |     fn flush(&mut self, canvas: &mut Canvas, data: &Data, arc_task: &AsyncTask) {
[INFO] [stdout]     |                                              ^^^^ help: if this is intentional, prefix it with an underscore: `_data`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `arc_task`
[INFO] [stdout]    --> src/render/scroll.rs:300:29
[INFO] [stdout]     |
[INFO] [stdout] 300 |     fn load_next(&mut self, arc_task: &AsyncTask) {
[INFO] [stdout]     |                             ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_arc_task`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `arc_task`
[INFO] [stdout]    --> src/render/scroll.rs:308:29
[INFO] [stdout]     |
[INFO] [stdout] 308 |     fn load_prev(&mut self, arc_task: &AsyncTask) {
[INFO] [stdout]     |                             ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_arc_task`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `cur`
[INFO] [stdout]    --> src/render/scroll.rs:316:38
[INFO] [stdout]     |
[INFO] [stdout] 316 |     pub fn load_from_mark(&mut self, cur: usize) {
[INFO] [stdout]     |                                      ^^^ help: if this is intentional, prefix it with an underscore: `_cur`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `config`
[INFO] [stdout]   --> src/render/turn.rs:55:9
[INFO] [stdout]    |
[INFO] [stdout] 55 |         config: &Config,
[INFO] [stdout]    |         ^^^^^^ help: if this is intentional, prefix it with an underscore: `_config`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `now` is never read
[INFO] [stdout]   --> src/render/turn.rs:62:23
[INFO] [stdout]    |
[INFO] [stdout] 62 |         let mut now = std::time::Instant::now();
[INFO] [stdout]    |                       ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = help: maybe it is overwritten before being read?
[INFO] [stdout]    = note: `#[warn(unused_assignments)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `ms` is never read
[INFO] [stdout]   --> src/render/turn.rs:63:22
[INFO] [stdout]    |
[INFO] [stdout] 63 |         let mut ms = 0_u32;
[INFO] [stdout]    |                      ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `count` is never read
[INFO] [stdout]   --> src/render/turn.rs:64:25
[INFO] [stdout]    |
[INFO] [stdout] 64 |         let mut count = 0;
[INFO] [stdout]    |                         ^
[INFO] [stdout]    |
[INFO] [stdout]    = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `canvas`
[INFO] [stdout]    --> src/render/turn.rs:123:25
[INFO] [stdout]     |
[INFO] [stdout] 123 |     fn flush(&mut self, canvas: &mut Canvas, data: &Data, arc_task: &AsyncTask) {
[INFO] [stdout]     |                         ^^^^^^ help: if this is intentional, prefix it with an underscore: `_canvas`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `data`
[INFO] [stdout]    --> src/render/turn.rs:123:46
[INFO] [stdout]     |
[INFO] [stdout] 123 |     fn flush(&mut self, canvas: &mut Canvas, data: &Data, arc_task: &AsyncTask) {
[INFO] [stdout]     |                                              ^^^^ help: if this is intentional, prefix it with an underscore: `_data`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `arc_task`
[INFO] [stdout]    --> src/render/turn.rs:123:59
[INFO] [stdout]     |
[INFO] [stdout] 123 |     fn flush(&mut self, canvas: &mut Canvas, data: &Data, arc_task: &AsyncTask) {
[INFO] [stdout]     |                                                           ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_arc_task`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `History` is never constructed
[INFO] [stdout]  --> src/config/history.rs:8:8
[INFO] [stdout]   |
[INFO] [stdout] 8 | struct History {
[INFO] [stdout]   |        ^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `MangaHistory` is never constructed
[INFO] [stdout]   --> src/config/history.rs:12:8
[INFO] [stdout]    |
[INFO] [stdout] 12 | struct MangaHistory {
[INFO] [stdout]    |        ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new` and `add` are never used
[INFO] [stdout]   --> src/config/history.rs:20:8
[INFO] [stdout]    |
[INFO] [stdout] 19 | impl History {
[INFO] [stdout]    | ------------ associated items in this implementation
[INFO] [stdout] 20 |     fn new() -> Self {
[INFO] [stdout]    |        ^^^
[INFO] [stdout] ...
[INFO] [stdout] 24 |     fn add(&mut self, val: MangaHistory) {
[INFO] [stdout]    |        ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `set_page_bookmark`, `set_page_number`, and `freq_add` are never used
[INFO] [stdout]   --> src/config/history.rs:37:8
[INFO] [stdout]    |
[INFO] [stdout] 36 | impl MangaHistory {
[INFO] [stdout]    | ----------------- associated items in this implementation
[INFO] [stdout] 37 |     fn new(path: &Path, freq: u32, page_number: u32) -> Self {
[INFO] [stdout]    |        ^^^
[INFO] [stdout] ...
[INFO] [stdout] 46 |     fn set_page_bookmark(&mut self, idx: usize) {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 50 |     fn set_page_number(&mut self, idx: usize) {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 54 |     fn freq_add(&mut self) {
[INFO] [stdout]    |        ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `ram_usage` is never read
[INFO] [stdout]   --> src/render.rs:86:5
[INFO] [stdout]    |
[INFO] [stdout] 84 | pub struct Task {
[INFO] [stdout]    |            ---- field in this struct
[INFO] [stdout] 85 |     list: Vec<TaskResize>,
[INFO] [stdout] 86 |     ram_usage: usize,
[INFO] [stdout]    |     ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Task` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `CmdFn` is never used
[INFO] [stdout]    --> src/render.rs:176:6
[INFO] [stdout]     |
[INFO] [stdout] 176 | enum CmdFn {
[INFO] [stdout]     |      ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `to_next_page` and `to_prev_page` are never used
[INFO] [stdout]    --> src/render/turn.rs:119:8
[INFO] [stdout]     |
[INFO] [stdout]  33 | impl Turn {
[INFO] [stdout]     | --------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 119 |     fn to_next_page(&mut self) {}
[INFO] [stdout]     |        ^^^^^^^^^^^^
[INFO] [stdout] 120 |     fn to_prev_page(&mut self) {}
[INFO] [stdout]     |        ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `x` and `y` are never read
[INFO] [stdout]  --> src/render/draw.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub struct Point<T> {
[INFO] [stdout]   |            ----- fields in this struct
[INFO] [stdout] 5 |     x: T,
[INFO] [stdout]   |     ^
[INFO] [stdout] 6 |     y: T,
[INFO] [stdout]   |     ^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `Point` 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 `Rect` is never constructed
[INFO] [stdout]   --> src/render/draw.rs:10:8
[INFO] [stdout]    |
[INFO] [stdout] 10 | struct Rect<T> {
[INFO] [stdout]    |        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around function argument
[INFO] [stdout]    --> src/archive.rs:169:31
[INFO] [stdout]     |
[INFO] [stdout] 169 |         path.extend(vec!['0'; (width - filename.len())]);
[INFO] [stdout]     |                               ^                      ^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 169 -         path.extend(vec!['0'; (width - filename.len())]);
[INFO] [stdout] 169 +         path.extend(vec!['0'; width - filename.len() ]);
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `FPS`
[INFO] [stdout]  --> src/img/gif.rs:1:24
[INFO] [stdout]   |
[INFO] [stdout] 1 | use crate::{img::Size, FPS};
[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: `image`
[INFO] [stdout]  --> src/img.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 | use image;
[INFO] [stdout]   |     ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around assigned value
[INFO] [stdout]    --> src/img.rs:215:20
[INFO] [stdout]     |
[INFO] [stdout] 215 |     let x_offset = ((bgw - fgw) / 2);
[INFO] [stdout]     |                    ^               ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 215 -     let x_offset = ((bgw - fgw) / 2);
[INFO] [stdout] 215 +     let x_offset = (bgw - fgw) / 2;
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Turn`, `sleep_ms`, and `thread`
[INFO] [stdout]  --> src/render/display.rs:2:13
[INFO] [stdout]   |
[INFO] [stdout] 2 |     render, sleep_ms, thread, ArchiveType, AsyncTask, Canvas, Config, Data, ForAsyncTask, KeyMap,
[INFO] [stdout]   |             ^^^^^^^^  ^^^^^^
[INFO] [stdout] 3 |     MetaSize, Once, Page, PageList, PathBuf, Scroll, TaskResize, Turn, ViewMode,
[INFO] [stdout]   |                                                                  ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Img` and `Page`
[INFO] [stdout]  --> src/render/scroll.rs:2:80
[INFO] [stdout]   |
[INFO] [stdout] 2 |     match_event, sleep, AsyncTask, Buffer, Canvas, Config, Data, ForAsyncTask, Img, KeyMap, Map,
[INFO] [stdout]   |                                                                                ^^^
[INFO] [stdout] 3 |     Page, PageList, TMetaSize, TransRgba,
[INFO] [stdout]   |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Arc` and `RwLock`
[INFO] [stdout]  --> src/render/turn.rs:7:12
[INFO] [stdout]   |
[INFO] [stdout] 7 |     sync::{Arc, RwLock},
[INFO] [stdout]   |            ^^^  ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::f32::consts::PI`
[INFO] [stdout]  --> src/render/draw.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use std::f32::consts::PI;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Path` and `yield_now`
[INFO] [stdout]   --> src/render.rs:13:48
[INFO] [stdout]    |
[INFO] [stdout] 13 |     archive::*, img::*, mem, sleep_ms, thread, yield_now, Arc, FilterType, Path, PathBuf, RwLock,
[INFO] [stdout]    |                                                ^^^^^^^^^                   ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `self`
[INFO] [stdout]    --> src/render.rs:324:23
[INFO] [stdout]     |
[INFO] [stdout] 324 |             archive::{self, ForExtract},
[INFO] [stdout]     |                       ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::thread::sleep_ms`: replaced by `std::thread::sleep`
[INFO] [stdout]   --> src/lib.rs:27:20
[INFO] [stdout]    |
[INFO] [stdout] 27 |     thread::{self, sleep_ms, yield_now},
[INFO] [stdout]    |                    ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(deprecated)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::thread::sleep_ms`: replaced by `std::thread::sleep`
[INFO] [stdout]   --> src/lib.rs:47:18
[INFO] [stdout]    |
[INFO] [stdout] 47 |     std::thread::sleep_ms(SLEEP_MS);
[INFO] [stdout]    |                  ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::thread::sleep_ms`: replaced by `std::thread::sleep`
[INFO] [stdout]   --> src/render.rs:13:30
[INFO] [stdout]    |
[INFO] [stdout] 13 |     archive::*, img::*, mem, sleep_ms, thread, yield_now, Arc, FilterType, Path, PathBuf, RwLock,
[INFO] [stdout]    |                              ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::thread::sleep_ms`: replaced by `std::thread::sleep`
[INFO] [stdout]   --> src/render.rs:43:13
[INFO] [stdout]    |
[INFO] [stdout] 43 |             sleep_ms(100);
[INFO] [stdout]    |             ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::thread::sleep_ms`: replaced by `std::thread::sleep`
[INFO] [stdout]  --> src/render/display.rs:2:13
[INFO] [stdout]   |
[INFO] [stdout] 2 |     render, sleep_ms, thread, ArchiveType, AsyncTask, Canvas, Config, Data, ForAsyncTask, KeyMap,
[INFO] [stdout]   |             ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::thread::sleep_ms`: replaced by `std::thread::sleep`
[INFO] [stdout]  --> src/render/turn.rs:8:13
[INFO] [stdout]   |
[INFO] [stdout] 8 |     thread::sleep_ms,
[INFO] [stdout]   |             ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: use of deprecated function `std::thread::sleep_ms`: replaced by `std::thread::sleep`
[INFO] [stdout]    --> src/render/turn.rs:115:13
[INFO] [stdout]     |
[INFO] [stdout] 115 |             sleep_ms(ms);
[INFO] [stdout]     |             ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `yuvi420_to_rgb8` is never used
[INFO] [stdout]   --> examples/heic.rs:36:4
[INFO] [stdout]    |
[INFO] [stdout] 36 | fn yuvi420_to_rgb8<Yuv_>(img: &[Yuv_], w: usize, h: usize) -> Vec<u8>
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `yuv_to_rgb` is never used
[INFO] [stdout]   --> examples/heic.rs:70:4
[INFO] [stdout]    |
[INFO] [stdout] 70 | fn yuv_to_rgb(y: f32, u: f32, v: f32) -> [u8; 3] {
[INFO] [stdout]    |    ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable expression
[INFO] [stdout]   --> src/archive/tar.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 10 |         return feat::get_file(path, index);
[INFO] [stdout]    |         ---------------------------------- any code following this expression is unreachable
[INFO] [stdout] ...
[INFO] [stdout] 13 |     anyhow::bail!("")
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^ unreachable expression
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unreachable_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout]    = note: this warning originates in the macro `anyhow::bail` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable expression
[INFO] [stdout]   --> src/archive/tar.rs:25:5
[INFO] [stdout]    |
[INFO] [stdout] 22 |         return feat::get_list(path);
[INFO] [stdout]    |         --------------------------- any code following this expression is unreachable
[INFO] [stdout] ...
[INFO] [stdout] 25 |     anyhow::bail!("")
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^ unreachable expression
[INFO] [stdout]    |
[INFO] [stdout]    = note: this warning originates in the macro `anyhow::bail` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable expression
[INFO] [stdout]   --> src/archive/zip.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout]  9 |         return feat::get_file(path.as_ref(), index);
[INFO] [stdout]    |         ------------------------------------------- any code following this expression is unreachable
[INFO] [stdout] ...
[INFO] [stdout] 12 |     anyhow::bail!("")
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^ unreachable expression
[INFO] [stdout]    |
[INFO] [stdout]    = note: this warning originates in the macro `anyhow::bail` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable expression
[INFO] [stdout]   --> src/archive/zip.rs:24:5
[INFO] [stdout]    |
[INFO] [stdout] 21 |         return feat::get_list(path.as_ref());
[INFO] [stdout]    |         ------------------------------------ any code following this expression is unreachable
[INFO] [stdout] ...
[INFO] [stdout] 24 |     anyhow::bail!("")
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^ unreachable expression
[INFO] [stdout]    |
[INFO] [stdout]    = note: this warning originates in the macro `anyhow::bail` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable expression
[INFO] [stdout]   --> src/archive/zip.rs:36:5
[INFO] [stdout]    |
[INFO] [stdout] 33 |         return feat::extract(from.as_ref(), to.as_ref());
[INFO] [stdout]    |         ------------------------------------------------ any code following this expression is unreachable
[INFO] [stdout] ...
[INFO] [stdout] 36 |     anyhow::bail!("")
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^ unreachable expression
[INFO] [stdout]    |
[INFO] [stdout]    = note: this warning originates in the macro `anyhow::bail` (in Nightly builds, run with -Z macro-backtrace for more info)
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `TMetaSize`
[INFO] [stdout]  --> src/archive.rs:9:39
[INFO] [stdout]   |
[INFO] [stdout] 9 | use crate::{archive, ImgFormat, Page, TMetaSize, EXT_LIST};
[INFO] [stdout]   |                                       ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `TMetaSize`
[INFO] [stdout]  --> src/render/scroll.rs:3:21
[INFO] [stdout]   |
[INFO] [stdout] 3 |     Page, PageList, TMetaSize, TransRgba,
[INFO] [stdout]   |                     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable pattern
[INFO] [stdout]    --> src/config/rsconf.rs:291:17
[INFO] [stdout]     |
[INFO] [stdout] 291 |                 _ => {}
[INFO] [stdout]     |                 ^ no value can reach this
[INFO] [stdout]     |
[INFO] [stdout] note: multiple earlier patterns match some of the same values
[INFO] [stdout]    --> src/config/rsconf.rs:291:17
[INFO] [stdout]     |
[INFO] [stdout] 279 |                 ConfigType::Base => {
[INFO] [stdout]     |                 ---------------- matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 283 |                 ConfigType::Keymap => {
[INFO] [stdout]     |                 ------------------ matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 287 |                 ConfigType::Window => {
[INFO] [stdout]     |                 ------------------ matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 291 |                 _ => {}
[INFO] [stdout]     |                 ^ collectively making this unreachable
[INFO] [stdout]     = note: `#[warn(unreachable_patterns)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary `unsafe` block
[INFO] [stdout]    --> src/img.rs:190:5
[INFO] [stdout]     |
[INFO] [stdout] 190 |     unsafe {
[INFO] [stdout]     |     ^^^^^^ unnecessary `unsafe` block
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_unsafe)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/render/window.rs:28:13
[INFO] [stdout]    |
[INFO] [stdout] 28 |         let mut window = Window::new("rmg", width, height, windowoptions).unwrap();
[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: unused variable: `mem`
[INFO] [stdout]   --> src/render/scroll.rs:37:13
[INFO] [stdout]    |
[INFO] [stdout] 37 |         let mem = {
[INFO] [stdout]    |             ^^^ help: if this is intentional, prefix it with an underscore: `_mem`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `data`
[INFO] [stdout]    --> src/render/scroll.rs:163:46
[INFO] [stdout]     |
[INFO] [stdout] 163 |     fn flush(&mut self, canvas: &mut Canvas, data: &Data, arc_task: &AsyncTask) {
[INFO] [stdout]     |                                              ^^^^ help: if this is intentional, prefix it with an underscore: `_data`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `arc_task`
[INFO] [stdout]    --> src/render/scroll.rs:300:29
[INFO] [stdout]     |
[INFO] [stdout] 300 |     fn load_next(&mut self, arc_task: &AsyncTask) {
[INFO] [stdout]     |                             ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_arc_task`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `arc_task`
[INFO] [stdout]    --> src/render/scroll.rs:308:29
[INFO] [stdout]     |
[INFO] [stdout] 308 |     fn load_prev(&mut self, arc_task: &AsyncTask) {
[INFO] [stdout]     |                             ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_arc_task`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `cur`
[INFO] [stdout]    --> src/render/scroll.rs:316:38
[INFO] [stdout]     |
[INFO] [stdout] 316 |     pub fn load_from_mark(&mut self, cur: usize) {
[INFO] [stdout]     |                                      ^^^ help: if this is intentional, prefix it with an underscore: `_cur`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `config`
[INFO] [stdout]   --> src/render/turn.rs:55:9
[INFO] [stdout]    |
[INFO] [stdout] 55 |         config: &Config,
[INFO] [stdout]    |         ^^^^^^ help: if this is intentional, prefix it with an underscore: `_config`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `now` is never read
[INFO] [stdout]   --> src/render/turn.rs:62:23
[INFO] [stdout]    |
[INFO] [stdout] 62 |         let mut now = std::time::Instant::now();
[INFO] [stdout]    |                       ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = help: maybe it is overwritten before being read?
[INFO] [stdout]    = note: `#[warn(unused_assignments)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `ms` is never read
[INFO] [stdout]   --> src/render/turn.rs:63:22
[INFO] [stdout]    |
[INFO] [stdout] 63 |         let mut ms = 0_u32;
[INFO] [stdout]    |                      ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: value assigned to `count` is never read
[INFO] [stdout]   --> src/render/turn.rs:64:25
[INFO] [stdout]    |
[INFO] [stdout] 64 |         let mut count = 0;
[INFO] [stdout]    |                         ^
[INFO] [stdout]    |
[INFO] [stdout]    = help: maybe it is overwritten before being read?
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `canvas`
[INFO] [stdout]    --> src/render/turn.rs:123:25
[INFO] [stdout]     |
[INFO] [stdout] 123 |     fn flush(&mut self, canvas: &mut Canvas, data: &Data, arc_task: &AsyncTask) {
[INFO] [stdout]     |                         ^^^^^^ help: if this is intentional, prefix it with an underscore: `_canvas`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `data`
[INFO] [stdout]    --> src/render/turn.rs:123:46
[INFO] [stdout]     |
[INFO] [stdout] 123 |     fn flush(&mut self, canvas: &mut Canvas, data: &Data, arc_task: &AsyncTask) {
[INFO] [stdout]     |                                              ^^^^ help: if this is intentional, prefix it with an underscore: `_data`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `arc_task`
[INFO] [stdout]    --> src/render/turn.rs:123:59
[INFO] [stdout]     |
[INFO] [stdout] 123 |     fn flush(&mut self, canvas: &mut Canvas, data: &Data, arc_task: &AsyncTask) {
[INFO] [stdout]     |                                                           ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_arc_task`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `History` is never constructed
[INFO] [stdout]  --> src/config/history.rs:8:8
[INFO] [stdout]   |
[INFO] [stdout] 8 | struct History {
[INFO] [stdout]   |        ^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `MangaHistory` is never constructed
[INFO] [stdout]   --> src/config/history.rs:12:8
[INFO] [stdout]    |
[INFO] [stdout] 12 | struct MangaHistory {
[INFO] [stdout]    |        ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new` and `add` are never used
[INFO] [stdout]   --> src/config/history.rs:20:8
[INFO] [stdout]    |
[INFO] [stdout] 19 | impl History {
[INFO] [stdout]    | ------------ associated items in this implementation
[INFO] [stdout] 20 |     fn new() -> Self {
[INFO] [stdout]    |        ^^^
[INFO] [stdout] ...
[INFO] [stdout] 24 |     fn add(&mut self, val: MangaHistory) {
[INFO] [stdout]    |        ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `set_page_bookmark`, `set_page_number`, and `freq_add` are never used
[INFO] [stdout]   --> src/config/history.rs:37:8
[INFO] [stdout]    |
[INFO] [stdout] 36 | impl MangaHistory {
[INFO] [stdout]    | ----------------- associated items in this implementation
[INFO] [stdout] 37 |     fn new(path: &Path, freq: u32, page_number: u32) -> Self {
[INFO] [stdout]    |        ^^^
[INFO] [stdout] ...
[INFO] [stdout] 46 |     fn set_page_bookmark(&mut self, idx: usize) {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 50 |     fn set_page_number(&mut self, idx: usize) {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 54 |     fn freq_add(&mut self) {
[INFO] [stdout]    |        ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `ram_usage` is never read
[INFO] [stdout]   --> src/render.rs:86:5
[INFO] [stdout]    |
[INFO] [stdout] 84 | pub struct Task {
[INFO] [stdout]    |            ---- field in this struct
[INFO] [stdout] 85 |     list: Vec<TaskResize>,
[INFO] [stdout] 86 |     ram_usage: usize,
[INFO] [stdout]    |     ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Task` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `CmdFn` is never used
[INFO] [stdout]    --> src/render.rs:176:6
[INFO] [stdout]     |
[INFO] [stdout] 176 | enum CmdFn {
[INFO] [stdout]     |      ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `to_next_page` and `to_prev_page` are never used
[INFO] [stdout]    --> src/render/turn.rs:119:8
[INFO] [stdout]     |
[INFO] [stdout]  33 | impl Turn {
[INFO] [stdout]     | --------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 119 |     fn to_next_page(&mut self) {}
[INFO] [stdout]     |        ^^^^^^^^^^^^
[INFO] [stdout] 120 |     fn to_prev_page(&mut self) {}
[INFO] [stdout]     |        ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `x` and `y` are never read
[INFO] [stdout]  --> src/render/draw.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub struct Point<T> {
[INFO] [stdout]   |            ----- fields in this struct
[INFO] [stdout] 5 |     x: T,
[INFO] [stdout]   |     ^
[INFO] [stdout] 6 |     y: T,
[INFO] [stdout]   |     ^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `Point` 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 `Rect` is never constructed
[INFO] [stdout]   --> src/render/draw.rs:10:8
[INFO] [stdout]    |
[INFO] [stdout] 10 | struct Rect<T> {
[INFO] [stdout]    |        ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 59.78s
[INFO] running `Command { std: "docker" "inspect" "7f67871a3c791a931402f1648f0d74fb8d359cbc0ebe325539ebc644b5787ea2", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "7f67871a3c791a931402f1648f0d74fb8d359cbc0ebe325539ebc644b5787ea2", kill_on_drop: false }`
[INFO] [stdout] 7f67871a3c791a931402f1648f0d74fb8d359cbc0ebe325539ebc644b5787ea2
