[INFO] cloning repository https://github.com/rust-projs/novplayer
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/rust-projs/novplayer" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Frust-projs%2Fnovplayer", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Frust-projs%2Fnovplayer'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] bddabf29aa8ee5b3692f6ad5858367c09513f777
[INFO] checking rust-projs/novplayer against 1.95.0-beta.7 for beta-1.95-4
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Frust-projs%2Fnovplayer" "/workspace/builds/worker-6-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-6-tc2/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/rust-projs/novplayer
[INFO] finished tweaking git repo https://github.com/rust-projs/novplayer
[INFO] tweaked toml for git repo https://github.com/rust-projs/novplayer written to /workspace/builds/worker-6-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/rust-projs/novplayer on toolchain 1.95.0-beta.7
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+1.95.0-beta.7" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/rust-projs/novplayer 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-beta.7" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/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-beta.7" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] c420cc1dd5262c35ab548eff42f5fbb0bc53f91c60be9590e1ebacda845f9774
[INFO] running `Command { std: "docker" "start" "-a" "c420cc1dd5262c35ab548eff42f5fbb0bc53f91c60be9590e1ebacda845f9774", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "c420cc1dd5262c35ab548eff42f5fbb0bc53f91c60be9590e1ebacda845f9774", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "c420cc1dd5262c35ab548eff42f5fbb0bc53f91c60be9590e1ebacda845f9774", kill_on_drop: false }`
[INFO] [stdout] c420cc1dd5262c35ab548eff42f5fbb0bc53f91c60be9590e1ebacda845f9774
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc2/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=warn" "-e" "RUSTDOCFLAGS=--cap-lints=warn" "-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-beta.7" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 48e47bc3637a6c267d45b0993b688a842abe1122e00c686112806930d461eacd
[INFO] running `Command { std: "docker" "start" "-a" "48e47bc3637a6c267d45b0993b688a842abe1122e00c686112806930d461eacd", kill_on_drop: false }`
[INFO] [stderr]    Compiling syn v2.0.114
[INFO] [stderr]    Compiling libc v0.2.180
[INFO] [stderr]     Checking log v0.4.29
[INFO] [stderr]    Compiling rustix v1.1.3
[INFO] [stderr]     Checking linux-raw-sys v0.11.0
[INFO] [stderr]     Checking libloading v0.8.9
[INFO] [stderr]    Compiling memchr v2.7.6
[INFO] [stderr]    Compiling zerocopy v0.8.33
[INFO] [stderr]     Checking dlib v0.5.2
[INFO] [stderr]    Compiling wayland-sys v0.31.8
[INFO] [stderr]     Checking tracing-core v0.1.36
[INFO] [stderr]    Compiling wayland-backend v0.3.12
[INFO] [stderr]     Checking parking v2.2.1
[INFO] [stderr]     Checking concurrent-queue v2.5.0
[INFO] [stderr]     Checking scoped-tls v1.0.1
[INFO] [stderr]     Checking downcast-rs v1.2.1
[INFO] [stderr]     Checking futures-io v0.3.31
[INFO] [stderr]    Compiling quick-xml v0.38.4
[INFO] [stderr]    Compiling wayland-client v0.31.12
[INFO] [stderr]     Checking event-listener v5.4.1
[INFO] [stderr]    Compiling hashbrown v0.16.1
[INFO] [stderr]    Compiling winnow v0.7.14
[INFO] [stderr]    Compiling toml_datetime v0.7.5+spec-1.1.0
[INFO] [stderr]     Checking event-listener-strategy v0.5.4
[INFO] [stderr]     Checking futures-lite v2.6.1
[INFO] [stderr]     Checking flate2 v1.1.5
[INFO] [stderr]     Checking rayon v1.11.0
[INFO] [stderr]    Compiling indexmap v2.13.0
[INFO] [stderr]    Compiling wayland-scanner v0.31.8
[INFO] [stderr]     Checking futures-sink v0.3.31
[INFO] [stderr]     Checking async-task v4.7.1
[INFO] [stderr]     Checking futures-channel v0.3.31
[INFO] [stderr]     Checking piper v0.2.4
[INFO] [stderr]     Checking form_urlencoded v1.2.2
[INFO] [stderr]     Checking memmap2 v0.9.9
[INFO] [stderr]     Checking getrandom v0.2.16
[INFO] [stderr]     Checking async-channel v2.5.0
[INFO] [stderr]    Compiling async-io v2.6.0
[INFO] [stderr]     Checking rand_core v0.6.4
[INFO] [stderr]     Checking blocking v1.6.2
[INFO] [stderr]    Compiling nix v0.29.0
[INFO] [stderr]    Compiling ahash v0.7.8
[INFO] [stderr]     Checking endi v1.1.1
[INFO] [stderr]     Checking raw-window-handle v0.6.2
[INFO] [stderr]    Compiling toml_parser v1.0.6+spec-1.1.0
[INFO] [stderr]     Checking siphasher v1.0.1
[INFO] [stderr]     Checking parking_lot_core v0.9.12
[INFO] [stderr]     Checking async-lock v3.4.2
[INFO] [stderr]    Compiling slotmap v1.1.1
[INFO] [stderr]    Compiling rustix v0.38.44
[INFO] [stderr]    Compiling rand v0.8.5
[INFO] [stderr]    Compiling toml_edit v0.23.10+spec-1.0.0
[INFO] [stderr]     Checking async-fs v2.2.0
[INFO] [stderr]    Compiling phf_shared v0.11.3
[INFO] [stderr]     Checking sha1 v0.10.6
[INFO] [stderr]     Checking parking_lot v0.12.5
[INFO] [stderr]     Checking xdg-home v1.3.0
[INFO] [stderr]     Checking async-executor v1.13.3
[INFO] [stderr]     Checking async-broadcast v0.7.2
[INFO] [stderr]     Checking ordered-stream v0.2.0
[INFO] [stderr]    Compiling ahash v0.8.12
[INFO] [stderr]     Checking roxmltree v0.20.0
[INFO] [stderr]     Checking linux-raw-sys v0.4.15
[INFO] [stderr]    Compiling cfg_aliases v0.1.1
[INFO] [stderr]    Compiling libm v0.2.15
[INFO] [stderr]    Compiling proc-macro-crate v3.4.0
[INFO] [stderr]     Checking hashbrown v0.12.3
[INFO] [stderr]     Checking fontconfig-parser v0.5.8
[INFO] [stderr]    Compiling phf_generator v0.11.3
[INFO] [stderr]     Checking getrandom v0.3.4
[INFO] [stderr]     Checking ttf-parser v0.21.1
[INFO] [stderr]     Checking float-cmp v0.9.0
[INFO] [stderr]     Checking strict-num v0.1.1
[INFO] [stderr]     Checking ordered-multimap v0.4.3
[INFO] [stderr]    Compiling synstructure v0.13.2
[INFO] [stderr]    Compiling zvariant_utils v2.1.0
[INFO] [stderr]     Checking png v0.17.16
[INFO] [stderr]     Checking dirs-sys v0.3.7
[INFO] [stderr]     Checking unicode-script v0.5.8
[INFO] [stderr]     Checking unicode-properties v0.1.4
[INFO] [stderr]     Checking unicode-ccc v0.2.0
[INFO] [stderr]     Checking polling v3.11.0
[INFO] [stderr]    Compiling by_address v1.2.1
[INFO] [stderr]     Checking unicode-bidi-mirroring v0.2.0
[INFO] [stderr]    Compiling palette v0.7.6
[INFO] [stderr]    Compiling dark-light v1.1.1
[INFO] [stderr]     Checking dirs v4.0.0
[INFO] [stderr]     Checking rust-ini v0.18.0
[INFO] [stderr]     Checking num_cpus v1.17.0
[INFO] [stderr]     Checking errno v0.3.14
[INFO] [stderr]     Checking approx v0.5.1
[INFO] [stderr]     Checking unicode-bidi v0.3.18
[INFO] [stderr]     Checking fast-srgb8 v1.0.0
[INFO] [stderr]     Checking rustc-hash v2.1.1
[INFO] [stderr]     Checking bytes v1.11.0
[INFO] [stderr]     Checking dconf_rs v0.3.0
[INFO] [stderr]     Checking detect-desktop-environment v0.2.0
[INFO] [stderr]     Checking as-raw-xcb-connection v1.0.1
[INFO] [stderr]     Checking smol_str v0.2.2
[INFO] [stderr]     Checking signal-hook-registry v1.4.8
[INFO] [stderr]     Checking gethostname v1.1.0
[INFO] [stderr]     Checking jpeg-decoder v0.3.2
[INFO] [stderr]     Checking mio v1.1.1
[INFO] [stderr]     Checking socket2 v0.6.1
[INFO] [stderr]    Compiling glob v0.3.3
[INFO] [stderr]     Checking x11rb-protocol v0.13.2
[INFO] [stderr]    Compiling khronos-egl v6.0.0
[INFO] [stderr]     Checking web-time v1.1.0
[INFO] [stderr]     Checking bit-vec v0.6.3
[INFO] [stderr]    Compiling ash v0.37.3+1.3.251
[INFO] [stderr]     Checking cursor-icon v1.2.0
[INFO] [stderr]     Checking xkeysym v0.2.1
[INFO] [stderr]     Checking termcolor v1.4.1
[INFO] [stderr]    Compiling bytemuck_derive v1.10.2
[INFO] [stderr]    Compiling zerocopy-derive v0.8.33
[INFO] [stderr]    Compiling zerofrom-derive v0.1.6
[INFO] [stderr]    Compiling yoke-derive v0.8.1
[INFO] [stderr]    Compiling zerovec-derive v0.11.2
[INFO] [stderr]    Compiling displaydoc v0.2.5
[INFO] [stderr]    Compiling tracing-attributes v0.1.31
[INFO] [stderr]     Checking zerofrom v0.1.6
[INFO] [stderr]     Checking bytemuck v1.24.0
[INFO] [stderr]    Compiling thiserror-impl v1.0.69
[INFO] [stderr]    Compiling serde_derive v1.0.228
[INFO] [stderr]     Checking yoke v0.8.1
[INFO] [stderr]    Compiling enumflags2_derive v0.7.12
[INFO] [stderr]     Checking zerotrie v0.2.3
[INFO] [stderr]     Checking zerovec v0.11.5
[INFO] [stderr]    Compiling futures-macro v0.3.31
[INFO] [stderr]    Compiling zvariant_derive v4.2.0
[INFO] [stderr]     Checking tracing v0.1.44
[INFO] [stderr]     Checking tinystr v0.8.2
[INFO] [stderr]     Checking potential_utf v0.1.4
[INFO] [stderr]     Checking icu_locale_core v2.1.1
[INFO] [stderr]     Checking thiserror v1.0.69
[INFO] [stderr]    Compiling zbus_macros v4.4.0
[INFO] [stderr]     Checking icu_collections v2.1.1
[INFO] [stderr]     Checking futures-util v0.3.31
[INFO] [stderr]    Compiling async-trait v0.1.89
[INFO] [stderr]    Compiling serde_repr v0.1.20
[INFO] [stderr]     Checking icu_provider v2.1.1
[INFO] [stderr]     Checking icu_properties v2.1.2
[INFO] [stderr]     Checking icu_normalizer v2.1.1
[INFO] [stderr]     Checking wayland-protocols v0.32.10
[INFO] [stderr]     Checking font-types v0.7.3
[INFO] [stderr]     Checking ppv-lite86 v0.2.21
[INFO] [stderr]     Checking rand_chacha v0.3.1
[INFO] [stderr]    Compiling phf_macros v0.11.3
[INFO] [stderr]     Checking idna_adapter v1.2.1
[INFO] [stderr]     Checking idna v1.1.0
[INFO] [stderr]    Compiling profiling-procmacros v1.0.17
[INFO] [stderr]    Compiling thiserror-impl v2.0.17
[INFO] [stderr]     Checking serde v1.0.228
[INFO] [stderr]     Checking phf v0.11.3
[INFO] [stderr]     Checking profiling v1.0.17
[INFO] [stderr]     Checking read-fonts v0.22.7
[INFO] [stderr]     Checking half v2.7.1
[INFO] [stderr]     Checking rustybuzz v0.14.1
[INFO] [stderr]     Checking url v2.5.8
[INFO] [stderr]     Checking enumflags2 v0.7.12
[INFO] [stderr]     Checking tiny-skia-path v0.11.4
[INFO] [stderr]    Compiling palette_derive v0.7.6
[INFO] [stderr]     Checking thiserror v2.0.17
[INFO] [stderr]     Checking futures-executor v0.3.31
[INFO] [stderr]    Compiling tokio-macros v2.6.0
[INFO] [stderr]     Checking zvariant v4.2.0
[INFO] [stderr]     Checking yazi v0.1.6
[INFO] [stderr]     Checking glam v0.25.0
[INFO] [stderr]     Checking xcursor v0.3.10
[INFO] [stderr]     Checking ttf-parser v0.20.0
[INFO] [stderr]     Checking unicode-width v0.1.14
[INFO] [stderr]     Checking zeno v0.2.3
[INFO] [stderr]     Checking zbus_names v3.0.0
[INFO] [stderr]     Checking hashbrown v0.14.5
[INFO] [stderr]     Checking zbus v4.4.0
[INFO] [stderr]     Checking fontdb v0.16.2
[INFO] [stderr]     Checking codespan-reporting v0.11.1
[INFO] [stderr]     Checking wayland-cursor v0.31.12
[INFO] [stderr]     Checking tokio v1.49.0
[INFO] [stderr]     Checking tiny-skia v0.11.4
[INFO] [stderr]     Checking wayland-protocols-wlr v0.3.10
[INFO] [stderr]     Checking futures v0.3.31
[INFO] [stderr]     Checking exr v1.74.0
[INFO] [stderr]     Checking qoi v0.4.1
[INFO] [stderr]     Checking bit-set v0.5.3
[INFO] [stderr]     Checking wayland-csd-frame v0.3.0
[INFO] [stderr]    Compiling clang-sys v1.8.1
[INFO] [stderr]     Checking gif v0.13.3
[INFO] [stderr]    Compiling wgpu-hal v0.19.5
[INFO] [stderr]     Checking spirv v0.3.0+sdk-1.3.268.0
[INFO] [stderr]     Checking gpu-descriptor-types v0.1.2
[INFO] [stderr]     Checking gpu-alloc-types v0.3.0
[INFO] [stderr]     Checking libloading v0.7.4
[INFO] [stderr]     Checking skrifa v0.22.3
[INFO] [stderr]     Checking unicode-xid v0.2.6
[INFO] [stderr]    Compiling drm-sys v0.8.0
[INFO] [stderr]     Checking unicode-linebreak v0.1.5
[INFO] [stderr]     Checking hexf-parse v0.2.1
[INFO] [stderr]     Checking sys-locale v0.3.2
[INFO] [stderr]     Checking rangemap v1.7.1
[INFO] [stderr]     Checking self_cell v1.2.2
[INFO] [stderr]     Checking unicode-segmentation v1.12.0
[INFO] [stderr]     Checking naga v0.19.2
[INFO] [stderr]     Checking x11rb v0.13.2
[INFO] [stderr]     Checking gpu-alloc v0.6.0
[INFO] [stderr]     Checking gpu-descriptor v0.2.4
[INFO] [stderr]     Checking swash v0.1.19
[INFO] [stderr]     Checking rgb v0.8.52
[INFO] [stderr]    Compiling equator-macro v0.4.2
[INFO] [stderr]     Checking tiff v0.9.1
[INFO] [stderr]     Checking iced_core v0.13.2
[INFO] [stderr]    Compiling wgpu-core v0.19.4
[INFO] [stderr]     Checking kurbo v0.11.3
[INFO] [stderr]     Checking wgpu-types v0.19.2
[INFO] [stderr]    Compiling regex-syntax v0.8.8
[INFO] [stderr]     Checking renderdoc-sys v1.1.0
[INFO] [stderr]    Compiling drm-fourcc v2.2.0
[INFO] [stderr]     Checking mutate_once v0.1.2
[INFO] [stderr]    Compiling minimal-lexical v0.2.1
[INFO] [stderr]    Compiling cfg-if v1.0.4
[INFO] [stderr]     Checking linux-raw-sys v0.6.5
[INFO] [stderr]     Checking glow v0.13.1
[INFO] [stderr]     Checking iced_futures v0.13.2
[INFO] [stderr]     Checking svgtypes v0.15.3
[INFO] [stderr]    Compiling nom v7.1.3
[INFO] [stderr]     Checking kamadak-exif v0.5.5
[INFO] [stderr]     Checking image v0.24.9
[INFO] [stderr]    Compiling regex-automata v0.4.13
[INFO] [stderr]     Checking cosmic-text v0.12.1
[INFO] [stderr]     Checking equator v0.4.2
[INFO] [stderr]     Checking calloop v0.14.3
[INFO] [stderr]     Checking fontdb v0.18.0
[INFO] [stderr]    Compiling wgpu v0.19.4
[INFO] [stderr]     Checking simplecss v0.2.2
[INFO] [stderr]     Checking euclid v0.22.11
[INFO] [stderr]    Compiling tiny-xlib v0.2.4
[INFO] [stderr]    Compiling bindgen v0.70.1
[INFO] [stderr]     Checking unicode-vo v0.1.0
[INFO] [stderr]     Checking imagesize v0.12.0
[INFO] [stderr]    Compiling either v1.15.0
[INFO] [stderr]     Checking xmlwriter v0.1.0
[INFO] [stderr]     Checking pico-args v0.5.0
[INFO] [stderr]     Checking svg_fmt v0.4.5
[INFO] [stderr]     Checking data-url v0.3.2
[INFO] [stderr]    Compiling smithay-client-toolkit v0.20.0
[INFO] [stderr]    Compiling itertools v0.13.0
[INFO] [stderr]     Checking usvg v0.42.0
[INFO] [stderr]    Compiling cexpr v0.6.0
[INFO] [stderr]     Checking calloop-wayland-source v0.4.1
[INFO] [stderr]     Checking num-bigint v0.4.6
[INFO] [stderr]     Checking aligned-vec v0.6.4
[INFO] [stderr]    Compiling regex v1.12.2
[INFO] [stderr]     Checking drm-ffi v0.9.0
[INFO] [stderr]     Checking wayland-protocols-misc v0.3.10
[INFO] [stderr]     Checking wayland-protocols-experimental v20250721.0.1
[INFO] [stderr]     Checking iced_graphics v0.13.0
[INFO] [stderr]     Checking calloop v0.13.0
[INFO] [stderr]    Compiling rustc-hash v1.1.0
[INFO] [stderr]    Compiling smithay-client-toolkit v0.19.2
[INFO] [stderr]    Compiling bitflags v2.10.0
[INFO] [stderr]     Checking ctor-lite v0.1.0
[INFO] [stderr]     Checking resvg v0.42.0
[INFO] [stderr]     Checking num-rational v0.4.2
[INFO] [stderr]     Checking drm v0.14.1
[INFO] [stderr]     Checking v_frame v0.3.9
[INFO] [stderr]     Checking calloop-wayland-source v0.3.0
[INFO] [stderr]     Checking etagere v0.2.15
[INFO] [stderr]    Compiling x11-dl v2.21.0
[INFO] [stderr]    Compiling alsa-sys v0.3.1
[INFO] [stderr]     Checking lru v0.12.5
[INFO] [stderr]     Checking guillotiere v0.6.2
[INFO] [stderr]     Checking symphonia-core v0.5.5
[INFO] [stderr]    Compiling arg_enum_proc_macro v0.3.4
[INFO] [stderr]    Compiling winit v0.30.12
[INFO] [stderr]     Checking nom v8.0.0
[INFO] [stderr]     Checking core2 v0.4.0
[INFO] [stderr]     Checking softbuffer v0.4.8
[INFO] [stderr]     Checking kurbo v0.10.4
[INFO] [stderr]     Checking smithay-clipboard v0.7.3
[INFO] [stderr]     Checking av-scenechange v0.14.1
[INFO] [stderr]     Checking sctk-adwaita v0.10.1
[INFO] [stderr]     Checking clipboard_wayland v0.2.2
[INFO] [stderr]     Checking bitstream-io v4.9.0
[INFO] [stderr]     Checking symphonia-metadata v0.5.5
[INFO] [stderr]     Checking iced_tiny_skia v0.13.0
[INFO] [stderr]     Checking iced_runtime v0.13.2
[INFO] [stderr]     Checking clipboard_x11 v0.4.3
[INFO] [stderr]     Checking wayland-protocols-plasma v0.3.10
[INFO] [stderr]     Checking xkbcommon-dl v0.4.2
[INFO] [stderr]    Compiling num-derive v0.4.2
[INFO] [stderr]    Compiling fax_derive v0.2.0
[INFO] [stderr]     Checking maybe-rayon v0.1.1
[INFO] [stderr]     Checking itertools v0.14.0
[INFO] [stderr]    Compiling simd_helpers v0.1.0
[INFO] [stderr]    Compiling cpal v0.15.3
[INFO] [stderr]    Compiling zmij v1.0.12
[INFO] [stderr]     Checking zune-core v0.4.12
[INFO] [stderr]     Checking av1-grain v0.2.5
[INFO] [stderr]     Checking dpi v0.1.2
[INFO] [stderr]     Checking zune-jpeg v0.4.21
[INFO] [stderr]     Checking fax v0.2.6
[INFO] [stderr]     Checking window_clipboard v0.4.1
[INFO] [stderr]     Checking alsa v0.9.1
[INFO] [stderr]     Checking symphonia-bundle-mp3 v0.5.5
[INFO] [stderr]     Checking rav1e v0.8.1
[INFO] [stderr]     Checking ogg v0.8.0
[INFO] [stderr]     Checking async-net v2.0.0
[INFO] [stderr]     Checking avif-serialize v0.8.6
[INFO] [stderr]     Checking pxfm v0.1.27
[INFO] [stderr]     Checking zune-core v0.5.0
[INFO] [stderr]    Compiling rfd v0.14.1
[INFO] [stderr]    Compiling ffmpeg-next v7.1.0
[INFO] [stderr]     Checking dasp_sample v0.11.0
[INFO] [stderr]     Checking zune-jpeg v0.5.8
[INFO] [stderr]     Checking dirs-sys v0.4.1
[INFO] [stderr]     Checking symphonia v0.5.5
[INFO] [stderr]     Checking ashpd v0.8.1
[INFO] [stderr]     Checking lewton v0.10.2
[INFO] [stderr]     Checking matchers v0.2.0
[INFO] [stderr]     Checking tiff v0.10.3
[INFO] [stderr]     Checking sharded-slab v0.1.7
[INFO] [stderr]     Checking png v0.18.0
[INFO] [stderr]     Checking tracing-log v0.2.0
[INFO] [stderr]     Checking moxcms v0.7.11
[INFO] [stderr]     Checking thread_local v1.1.9
[INFO] [stderr]     Checking nu-ansi-term v0.50.3
[INFO] [stderr]     Checking hound v3.5.1
[INFO] [stderr]     Checking pollster v0.3.0
[INFO] [stderr]     Checking claxon v0.4.3
[INFO] [stderr]     Checking urlencoding v2.1.3
[INFO] [stderr]     Checking chrono v0.4.42
[INFO] [stderr]     Checking iced_winit v0.13.0
[INFO] [stderr]    Compiling ffmpeg-sys-next v7.1.3
[INFO] [stderr]     Checking ravif v0.12.0
[INFO] [stderr]     Checking rodio v0.19.0
[INFO] [stderr]     Checking serde_json v1.0.149
[INFO] [stderr]     Checking tracing-subscriber v0.3.22
[INFO] [stderr]     Checking dirs v5.0.1
[INFO] [stderr]     Checking image v0.25.9
[INFO] [stderr]     Checking iced_glyphon v0.6.0
[INFO] [stderr]     Checking iced_wgpu v0.13.5
[INFO] [stderr]     Checking iced_renderer v0.13.0
[INFO] [stderr]     Checking iced_widget v0.13.4
[INFO] [stderr]     Checking iced v0.13.1
[INFO] [stderr]     Checking novplayer v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `JoinHandle`
[INFO] [stdout]   --> src/player/engine.rs:10:25
[INFO] [stdout]    |
[INFO] [stdout] 10 | use std::thread::{self, JoinHandle};
[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: `parking_lot::Mutex as PMutex`
[INFO] [stdout]   --> src/player/engine.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 15 | use parking_lot::Mutex as PMutex;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `formats::MediaFormat`
[INFO] [stdout]  --> src/utils/mod.rs:7:9
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub use formats::MediaFormat;
[INFO] [stdout]   |         ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `JoinHandle`
[INFO] [stdout]   --> src/player/engine.rs:10:25
[INFO] [stdout]    |
[INFO] [stdout] 10 | use std::thread::{self, JoinHandle};
[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: `parking_lot::Mutex as PMutex`
[INFO] [stdout]   --> src/player/engine.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 15 | use parking_lot::Mutex as PMutex;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `formats::MediaFormat`
[INFO] [stdout]  --> src/utils/mod.rs:7:9
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub use formats::MediaFormat;
[INFO] [stdout]   |         ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `PlaybackControls`
[INFO] [stdout]  --> src/app.rs:8:48
[INFO] [stdout]   |
[INFO] [stdout] 8 | use crate::player::{PlayerEngine, PlayerState, PlaybackControls, EqualizerPreset};
[INFO] [stdout]   |                                                ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `PlaybackControls`
[INFO] [stdout]  --> src/app.rs:8:48
[INFO] [stdout]   |
[INFO] [stdout] 8 | use crate::player::{PlayerEngine, PlayerState, PlaybackControls, EqualizerPreset};
[INFO] [stdout]   |                                                ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `channels`
[INFO] [stdout]    --> src/player/decoder.rs:107:13
[INFO] [stdout]     |
[INFO] [stdout] 107 |         let channels = decoder.channels() as u16;
[INFO] [stdout]     |             ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_channels`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `channels`
[INFO] [stdout]    --> src/player/decoder.rs:107:13
[INFO] [stdout]     |
[INFO] [stdout] 107 |         let channels = decoder.channels() as u16;
[INFO] [stdout]     |             ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_channels`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple fields are never read
[INFO] [stdout]   --> src/app.rs:16:5
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub struct NovPlayer {
[INFO] [stdout]    |            --------- fields in this struct
[INFO] [stdout] 15 |     /// Media player engine
[INFO] [stdout] 16 |     player: PlayerEngine,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] 17 |     /// Current player state
[INFO] [stdout] 18 |     state: PlayerState,
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout] 19 |     /// Playlist manager
[INFO] [stdout] 20 |     playlist: PlaylistManager,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 21 |     /// User configuration
[INFO] [stdout] 22 |     config: Config,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] 23 |     /// Current volume (0.0 - 1.0)
[INFO] [stdout] 24 |     volume: f32,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] 25 |     /// Is muted
[INFO] [stdout] 26 |     muted: bool,
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout] 27 |     /// Current playback position in seconds
[INFO] [stdout] 28 |     position: f64,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 29 |     /// Total duration in seconds
[INFO] [stdout] 30 |     duration: f64,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 31 |     /// Is fullscreen
[INFO] [stdout] 32 |     fullscreen: bool,
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] 33 |     /// Show controls overlay
[INFO] [stdout] 34 |     show_controls: bool,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 35 |     /// Show equalizer panel
[INFO] [stdout] 36 |     show_equalizer: bool,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 37 |     /// Current equalizer preset
[INFO] [stdout] 38 |     eq_preset: EqualizerPreset,
[INFO] [stdout]    |     ^^^^^^^^^
[INFO] [stdout] 39 |     /// Custom EQ bands (10 bands, -12 to +12 dB)
[INFO] [stdout] 40 |     eq_bands: [f32; 10],
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 41 |     /// Available subtitle tracks
[INFO] [stdout] 42 |     subtitle_tracks: Vec<String>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 43 |     /// Current subtitle track index (None = disabled)
[INFO] [stdout] 44 |     current_subtitle: Option<usize>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 45 |     /// Error message to display
[INFO] [stdout] 46 |     error_message: Option<String>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 47 |     /// Video frame handle
[INFO] [stdout] 48 |     video_handle: Option<image::Handle>,
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout] 49 |     /// Video buffer (BGRA)
[INFO] [stdout] 50 |     video_buffer: Vec<u8>,
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout] 51 |     /// Window dimensions
[INFO] [stdout] 52 |     width: u32,
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout] 53 |     height: u32,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Message` is never used
[INFO] [stdout]   --> src/app.rs:58:10
[INFO] [stdout]    |
[INFO] [stdout] 58 | pub enum Message {
[INFO] [stdout]    |          ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> src/app.rs:117:8
[INFO] [stdout]     |
[INFO] [stdout] 116 | impl NovPlayer {
[INFO] [stdout]     | -------------- associated items in this implementation
[INFO] [stdout] 117 |     fn new(initial_file: Option<String>) -> (Self, Task<Message>) {
[INFO] [stdout]     |        ^^^
[INFO] [stdout] ...
[INFO] [stdout] 154 |     fn title(&self) -> String {
[INFO] [stdout]     |        ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 163 |     fn theme(&self) -> Theme {
[INFO] [stdout]     |        ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 167 |     fn update(&mut self, message: Message) -> Task<Message> {
[INFO] [stdout]     |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 425 |     fn subscription(&self) -> Subscription<Message> {
[INFO] [stdout]     |        ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 439 |     fn view(&self) -> Element<Message> {
[INFO] [stdout]     |        ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 463 |     fn handle_keyboard(&mut self, key: keyboard::Key) -> Task<Message> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 494 |     fn view_welcome(&self) -> Element<Message> {
[INFO] [stdout]     |        ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 537 |     fn view_player(&self) -> Element<Message> {
[INFO] [stdout]     |        ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 581 |     fn view_controls(&self) -> Element<Message> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 689 |     fn view_equalizer(&self) -> Element<Message> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 747 |     fn view_error_banner(&self, error: &str) -> Element<Message> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `format_duration` is never used
[INFO] [stdout]    --> src/app.rs:773:4
[INFO] [stdout]     |
[INFO] [stdout] 773 | fn format_duration(seconds: f64) -> String {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run` is never used
[INFO] [stdout]    --> src/app.rs:787:8
[INFO] [stdout]     |
[INFO] [stdout] 787 | pub fn run(initial_file: Option<String>) -> iced::Result {
[INFO] [stdout]     |        ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `pts` is never read
[INFO] [stdout]   --> src/player/engine.rs:54:9
[INFO] [stdout]    |
[INFO] [stdout] 50 | pub struct VideoFrame {
[INFO] [stdout]    |            ---------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 54 |     pub pts: f64,
[INFO] [stdout]    |         ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `audio_handle` is never read
[INFO] [stdout]    --> src/player/engine.rs:110:5
[INFO] [stdout]     |
[INFO] [stdout] 101 | pub struct PlayerEngine {
[INFO] [stdout]     |            ------------ field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 110 |     audio_handle: rodio::OutputStreamHandle,
[INFO] [stdout]     |     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `AudioSample` is never constructed
[INFO] [stdout]    --> src/player/engine.rs:248:8
[INFO] [stdout]     |
[INFO] [stdout] 248 | struct AudioSample {
[INFO] [stdout]     |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `EQ_FREQUENCIES` is never used
[INFO] [stdout]    --> src/player/equalizer.rs:149:11
[INFO] [stdout]     |
[INFO] [stdout] 149 | pub const EQ_FREQUENCIES: [u32; 10] = [32, 64, 125, 250, 500, 1000, 2000, 4000, 8000, 16000];
[INFO] [stdout]     |           ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `EQ_LABELS` is never used
[INFO] [stdout]    --> src/player/equalizer.rs:152:11
[INFO] [stdout]     |
[INFO] [stdout] 152 | pub const EQ_LABELS: [&str; 10] = ["32", "64", "125", "250", "500", "1K", "2K", "4K", "8K", "16K"];
[INFO] [stdout]     |           ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/player/audio.rs:18:12
[INFO] [stdout]    |
[INFO] [stdout] 17 | impl AudioSource {
[INFO] [stdout]    | ---------------- associated function in this implementation
[INFO] [stdout] 18 |     pub fn new(receiver: Receiver<f32>, sample_rate: u32, channels: u16) -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `NovTheme` is never constructed
[INFO] [stdout]  --> src/ui/theme.rs:7:12
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub struct NovTheme;
[INFO] [stdout]   |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `dark` is never used
[INFO] [stdout]   --> src/ui/theme.rs:11:12
[INFO] [stdout]    |
[INFO] [stdout]  9 | impl NovTheme {
[INFO] [stdout]    | ------------- associated function in this implementation
[INFO] [stdout] 10 |     /// Create the dark theme
[INFO] [stdout] 11 |     pub fn dark() -> Theme {
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `BACKGROUND_DARK` is never used
[INFO] [stdout]   --> src/ui/theme.rs:30:15
[INFO] [stdout]    |
[INFO] [stdout] 30 |     pub const BACKGROUND_DARK: Color = Color::from_rgb(0.05, 0.05, 0.05);
[INFO] [stdout]    |               ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `BACKGROUND_PANEL` is never used
[INFO] [stdout]   --> src/ui/theme.rs:31:15
[INFO] [stdout]    |
[INFO] [stdout] 31 |     pub const BACKGROUND_PANEL: Color = Color::from_rgb(0.1, 0.1, 0.1);
[INFO] [stdout]    |               ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `BACKGROUND_CONTROL` is never used
[INFO] [stdout]   --> src/ui/theme.rs:32:15
[INFO] [stdout]    |
[INFO] [stdout] 32 |     pub const BACKGROUND_CONTROL: Color = Color::from_rgb(0.15, 0.15, 0.15);
[INFO] [stdout]    |               ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `BACKGROUND_HOVER` is never used
[INFO] [stdout]   --> src/ui/theme.rs:33:15
[INFO] [stdout]    |
[INFO] [stdout] 33 |     pub const BACKGROUND_HOVER: Color = Color::from_rgb(0.2, 0.2, 0.2);
[INFO] [stdout]    |               ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `ACCENT_BLUE` is never used
[INFO] [stdout]   --> src/ui/theme.rs:36:15
[INFO] [stdout]    |
[INFO] [stdout] 36 |     pub const ACCENT_BLUE: Color = Color::from_rgb(0.0, 0.66, 1.0);
[INFO] [stdout]    |               ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `ACCENT_ORANGE` is never used
[INFO] [stdout]   --> src/ui/theme.rs:37:15
[INFO] [stdout]    |
[INFO] [stdout] 37 |     pub const ACCENT_ORANGE: Color = Color::from_rgb(1.0, 0.5, 0.0);
[INFO] [stdout]    |               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `ACCENT_GREEN` is never used
[INFO] [stdout]   --> src/ui/theme.rs:38:15
[INFO] [stdout]    |
[INFO] [stdout] 38 |     pub const ACCENT_GREEN: Color = Color::from_rgb(0.2, 0.8, 0.4);
[INFO] [stdout]    |               ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `ACCENT_RED` is never used
[INFO] [stdout]   --> src/ui/theme.rs:39:15
[INFO] [stdout]    |
[INFO] [stdout] 39 |     pub const ACCENT_RED: Color = Color::from_rgb(0.9, 0.2, 0.2);
[INFO] [stdout]    |               ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `TEXT_PRIMARY` is never used
[INFO] [stdout]   --> src/ui/theme.rs:42:15
[INFO] [stdout]    |
[INFO] [stdout] 42 |     pub const TEXT_PRIMARY: Color = Color::from_rgb(0.9, 0.9, 0.9);
[INFO] [stdout]    |               ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `TEXT_SECONDARY` is never used
[INFO] [stdout]   --> src/ui/theme.rs:43:15
[INFO] [stdout]    |
[INFO] [stdout] 43 |     pub const TEXT_SECONDARY: Color = Color::from_rgb(0.6, 0.6, 0.6);
[INFO] [stdout]    |               ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `TEXT_MUTED` is never used
[INFO] [stdout]   --> src/ui/theme.rs:44:15
[INFO] [stdout]    |
[INFO] [stdout] 44 |     pub const TEXT_MUTED: Color = Color::from_rgb(0.4, 0.4, 0.4);
[INFO] [stdout]    |               ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SEEK_BACKGROUND` is never used
[INFO] [stdout]   --> src/ui/theme.rs:47:15
[INFO] [stdout]    |
[INFO] [stdout] 47 |     pub const SEEK_BACKGROUND: Color = Color::from_rgb(0.2, 0.2, 0.2);
[INFO] [stdout]    |               ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SEEK_PROGRESS` is never used
[INFO] [stdout]   --> src/ui/theme.rs:48:15
[INFO] [stdout]    |
[INFO] [stdout] 48 |     pub const SEEK_PROGRESS: Color = Color::from_rgb(0.0, 0.66, 1.0);
[INFO] [stdout]    |               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SEEK_BUFFERED` is never used
[INFO] [stdout]   --> src/ui/theme.rs:49:15
[INFO] [stdout]    |
[INFO] [stdout] 49 |     pub const SEEK_BUFFERED: Color = Color::from_rgb(0.3, 0.3, 0.3);
[INFO] [stdout]    |               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SEEK_HANDLE` is never used
[INFO] [stdout]   --> src/ui/theme.rs:50:15
[INFO] [stdout]    |
[INFO] [stdout] 50 |     pub const SEEK_HANDLE: Color = Color::from_rgb(1.0, 1.0, 1.0);
[INFO] [stdout]    |               ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `GLASS_BACKGROUND` is never used
[INFO] [stdout]   --> src/ui/theme.rs:53:15
[INFO] [stdout]    |
[INFO] [stdout] 53 |     pub const GLASS_BACKGROUND: Color = Color::from_rgba(0.1, 0.1, 0.1, 0.8);
[INFO] [stdout]    |               ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `GLASS_BORDER` is never used
[INFO] [stdout]   --> src/ui/theme.rs:54:15
[INFO] [stdout]    |
[INFO] [stdout] 54 |     pub const GLASS_BORDER: Color = Color::from_rgba(1.0, 1.0, 1.0, 0.1);
[INFO] [stdout]    |               ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `PLAY` is never used
[INFO] [stdout]   --> src/ui/theme.rs:59:15
[INFO] [stdout]    |
[INFO] [stdout] 59 |     pub const PLAY: &str = "▶";
[INFO] [stdout]    |               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `PAUSE` is never used
[INFO] [stdout]   --> src/ui/theme.rs:60:15
[INFO] [stdout]    |
[INFO] [stdout] 60 |     pub const PAUSE: &str = "⏸";
[INFO] [stdout]    |               ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `STOP` is never used
[INFO] [stdout]   --> src/ui/theme.rs:61:15
[INFO] [stdout]    |
[INFO] [stdout] 61 |     pub const STOP: &str = "⏹";
[INFO] [stdout]    |               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `PREVIOUS` is never used
[INFO] [stdout]   --> src/ui/theme.rs:62:15
[INFO] [stdout]    |
[INFO] [stdout] 62 |     pub const PREVIOUS: &str = "⏮";
[INFO] [stdout]    |               ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `NEXT` is never used
[INFO] [stdout]   --> src/ui/theme.rs:63:15
[INFO] [stdout]    |
[INFO] [stdout] 63 |     pub const NEXT: &str = "⏭";
[INFO] [stdout]    |               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `REWIND` is never used
[INFO] [stdout]   --> src/ui/theme.rs:64:15
[INFO] [stdout]    |
[INFO] [stdout] 64 |     pub const REWIND: &str = "⏪";
[INFO] [stdout]    |               ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `FORWARD` is never used
[INFO] [stdout]   --> src/ui/theme.rs:65:15
[INFO] [stdout]    |
[INFO] [stdout] 65 |     pub const FORWARD: &str = "⏩";
[INFO] [stdout]    |               ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `VOLUME_HIGH` is never used
[INFO] [stdout]   --> src/ui/theme.rs:66:15
[INFO] [stdout]    |
[INFO] [stdout] 66 |     pub const VOLUME_HIGH: &str = "🔊";
[INFO] [stdout]    |               ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `VOLUME_MEDIUM` is never used
[INFO] [stdout]   --> src/ui/theme.rs:67:15
[INFO] [stdout]    |
[INFO] [stdout] 67 |     pub const VOLUME_MEDIUM: &str = "🔉";
[INFO] [stdout]    |               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `VOLUME_LOW` is never used
[INFO] [stdout]   --> src/ui/theme.rs:68:15
[INFO] [stdout]    |
[INFO] [stdout] 68 |     pub const VOLUME_LOW: &str = "🔈";
[INFO] [stdout]    |               ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `VOLUME_MUTE` is never used
[INFO] [stdout]   --> src/ui/theme.rs:69:15
[INFO] [stdout]    |
[INFO] [stdout] 69 |     pub const VOLUME_MUTE: &str = "🔇";
[INFO] [stdout]    |               ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `FULLSCREEN` is never used
[INFO] [stdout]   --> src/ui/theme.rs:70:15
[INFO] [stdout]    |
[INFO] [stdout] 70 |     pub const FULLSCREEN: &str = "⛶";
[INFO] [stdout]    |               ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `FULLSCREEN_EXIT` is never used
[INFO] [stdout]   --> src/ui/theme.rs:71:15
[INFO] [stdout]    |
[INFO] [stdout] 71 |     pub const FULLSCREEN_EXIT: &str = "⊡";
[INFO] [stdout]    |               ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SETTINGS` is never used
[INFO] [stdout]   --> src/ui/theme.rs:72:15
[INFO] [stdout]    |
[INFO] [stdout] 72 |     pub const SETTINGS: &str = "⚙";
[INFO] [stdout]    |               ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `PLAYLIST` is never used
[INFO] [stdout]   --> src/ui/theme.rs:73:15
[INFO] [stdout]    |
[INFO] [stdout] 73 |     pub const PLAYLIST: &str = "☰";
[INFO] [stdout]    |               ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SUBTITLES` is never used
[INFO] [stdout]   --> src/ui/theme.rs:74:15
[INFO] [stdout]    |
[INFO] [stdout] 74 |     pub const SUBTITLES: &str = "CC";
[INFO] [stdout]    |               ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `EQUALIZER` is never used
[INFO] [stdout]   --> src/ui/theme.rs:75:15
[INFO] [stdout]    |
[INFO] [stdout] 75 |     pub const EQUALIZER: &str = "♫";
[INFO] [stdout]    |               ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `FOLDER` is never used
[INFO] [stdout]   --> src/ui/theme.rs:76:15
[INFO] [stdout]    |
[INFO] [stdout] 76 |     pub const FOLDER: &str = "📁";
[INFO] [stdout]    |               ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `FILE` is never used
[INFO] [stdout]   --> src/ui/theme.rs:77:15
[INFO] [stdout]    |
[INFO] [stdout] 77 |     pub const FILE: &str = "📄";
[INFO] [stdout]    |               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `CLOSE` is never used
[INFO] [stdout]   --> src/ui/theme.rs:78:15
[INFO] [stdout]    |
[INFO] [stdout] 78 |     pub const CLOSE: &str = "✕";
[INFO] [stdout]    |               ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `CHECK` is never used
[INFO] [stdout]   --> src/ui/theme.rs:79:15
[INFO] [stdout]    |
[INFO] [stdout] 79 |     pub const CHECK: &str = "✓";
[INFO] [stdout]    |               ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SHUFFLE` is never used
[INFO] [stdout]   --> src/ui/theme.rs:80:15
[INFO] [stdout]    |
[INFO] [stdout] 80 |     pub const SHUFFLE: &str = "🔀";
[INFO] [stdout]    |               ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `REPEAT` is never used
[INFO] [stdout]   --> src/ui/theme.rs:81:15
[INFO] [stdout]    |
[INFO] [stdout] 81 |     pub const REPEAT: &str = "🔁";
[INFO] [stdout]    |               ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `REPEAT_ONE` is never used
[INFO] [stdout]   --> src/ui/theme.rs:82:15
[INFO] [stdout]    |
[INFO] [stdout] 82 |     pub const REPEAT_ONE: &str = "🔂";
[INFO] [stdout]    |               ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `TINY` is never used
[INFO] [stdout]   --> src/ui/theme.rs:87:15
[INFO] [stdout]    |
[INFO] [stdout] 87 |     pub const TINY: u16 = 4;
[INFO] [stdout]    |               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SMALL` is never used
[INFO] [stdout]   --> src/ui/theme.rs:88:15
[INFO] [stdout]    |
[INFO] [stdout] 88 |     pub const SMALL: u16 = 8;
[INFO] [stdout]    |               ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MEDIUM` is never used
[INFO] [stdout]   --> src/ui/theme.rs:89:15
[INFO] [stdout]    |
[INFO] [stdout] 89 |     pub const MEDIUM: u16 = 12;
[INFO] [stdout]    |               ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `LARGE` is never used
[INFO] [stdout]   --> src/ui/theme.rs:90:15
[INFO] [stdout]    |
[INFO] [stdout] 90 |     pub const LARGE: u16 = 16;
[INFO] [stdout]    |               ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `XLARGE` is never used
[INFO] [stdout]   --> src/ui/theme.rs:91:15
[INFO] [stdout]    |
[INFO] [stdout] 91 |     pub const XLARGE: u16 = 24;
[INFO] [stdout]    |               ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `XXLARGE` is never used
[INFO] [stdout]   --> src/ui/theme.rs:92:15
[INFO] [stdout]    |
[INFO] [stdout] 92 |     pub const XXLARGE: u16 = 32;
[INFO] [stdout]    |               ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `TINY` is never used
[INFO] [stdout]   --> src/ui/theme.rs:97:15
[INFO] [stdout]    |
[INFO] [stdout] 97 |     pub const TINY: f32 = 10.0;
[INFO] [stdout]    |               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SMALL` is never used
[INFO] [stdout]   --> src/ui/theme.rs:98:15
[INFO] [stdout]    |
[INFO] [stdout] 98 |     pub const SMALL: f32 = 12.0;
[INFO] [stdout]    |               ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `NORMAL` is never used
[INFO] [stdout]   --> src/ui/theme.rs:99:15
[INFO] [stdout]    |
[INFO] [stdout] 99 |     pub const NORMAL: f32 = 14.0;
[INFO] [stdout]    |               ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MEDIUM` is never used
[INFO] [stdout]    --> src/ui/theme.rs:100:15
[INFO] [stdout]     |
[INFO] [stdout] 100 |     pub const MEDIUM: f32 = 16.0;
[INFO] [stdout]     |               ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `LARGE` is never used
[INFO] [stdout]    --> src/ui/theme.rs:101:15
[INFO] [stdout]     |
[INFO] [stdout] 101 |     pub const LARGE: f32 = 20.0;
[INFO] [stdout]     |               ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `XLARGE` is never used
[INFO] [stdout]    --> src/ui/theme.rs:102:15
[INFO] [stdout]     |
[INFO] [stdout] 102 |     pub const XLARGE: f32 = 24.0;
[INFO] [stdout]     |               ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `TITLE` is never used
[INFO] [stdout]    --> src/ui/theme.rs:103:15
[INFO] [stdout]     |
[INFO] [stdout] 103 |     pub const TITLE: f32 = 32.0;
[INFO] [stdout]     |               ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `HERO` is never used
[INFO] [stdout]    --> src/ui/theme.rs:104:15
[INFO] [stdout]     |
[INFO] [stdout] 104 |     pub const HERO: f32 = 48.0;
[INFO] [stdout]     |               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SMALL` is never used
[INFO] [stdout]    --> src/ui/theme.rs:109:15
[INFO] [stdout]     |
[INFO] [stdout] 109 |     pub const SMALL: f32 = 4.0;
[INFO] [stdout]     |               ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MEDIUM` is never used
[INFO] [stdout]    --> src/ui/theme.rs:110:15
[INFO] [stdout]     |
[INFO] [stdout] 110 |     pub const MEDIUM: f32 = 8.0;
[INFO] [stdout]     |               ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `LARGE` is never used
[INFO] [stdout]    --> src/ui/theme.rs:111:15
[INFO] [stdout]     |
[INFO] [stdout] 111 |     pub const LARGE: f32 = 12.0;
[INFO] [stdout]     |               ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `PILL` is never used
[INFO] [stdout]    --> src/ui/theme.rs:112:15
[INFO] [stdout]     |
[INFO] [stdout] 112 |     pub const PILL: f32 = 999.0;
[INFO] [stdout]     |               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `video_view` is never used
[INFO] [stdout]   --> src/ui/components/video_view.rs:12:8
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub fn video_view<'a, Message: 'a>() -> Element<'a, Message> {
[INFO] [stdout]    |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `AspectRatio` is never used
[INFO] [stdout]   --> src/ui/components/video_view.rs:27:10
[INFO] [stdout]    |
[INFO] [stdout] 27 | pub enum AspectRatio {
[INFO] [stdout]    |          ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `as_str` and `ratio` are never used
[INFO] [stdout]   --> src/ui/components/video_view.rs:42:12
[INFO] [stdout]    |
[INFO] [stdout] 41 | impl AspectRatio {
[INFO] [stdout]    | ---------------- methods in this implementation
[INFO] [stdout] 42 |     pub fn as_str(&self) -> &'static str {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 52 |     pub fn ratio(&self) -> Option<f32> {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `controls_bar` is never used
[INFO] [stdout]   --> src/ui/components/controls_bar.rs:12:8
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub fn controls_bar<'a, Message: 'a>() -> Element<'a, Message> 
[INFO] [stdout]    |        ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `timeline` is never used
[INFO] [stdout]  --> src/ui/components/timeline.rs:8:8
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub fn timeline<'a, Message: 'a>() -> Element<'a, Message> 
[INFO] [stdout]   |        ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `volume_control` is never used
[INFO] [stdout]  --> src/ui/components/volume.rs:8:8
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub fn volume_control<'a, Message: 'a>() -> Element<'a, Message> 
[INFO] [stdout]   |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `equalizer_panel` is never used
[INFO] [stdout]  --> src/ui/components/equalizer.rs:8:8
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub fn equalizer_panel<'a, Message: 'a>() -> Element<'a, Message> 
[INFO] [stdout]   |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `subtitles_panel` is never used
[INFO] [stdout]  --> src/ui/components/subtitles.rs:8:8
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub fn subtitles_panel<'a, Message: 'a>() -> Element<'a, Message> 
[INFO] [stdout]   |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `SubtitleSettings` is never constructed
[INFO] [stdout]   --> src/ui/components/subtitles.rs:17:12
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub struct SubtitleSettings {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `from_path`, `mime_type`, `video_extensions`, `audio_extensions`, and `all_extensions` are never used
[INFO] [stdout]    --> src/utils/formats.rs:39:12
[INFO] [stdout]     |
[INFO] [stdout]  37 | impl MediaFormat {
[INFO] [stdout]     | ---------------- associated items in this implementation
[INFO] [stdout]  38 |     /// Detect format from file extension
[INFO] [stdout]  39 |     pub fn from_path<P: AsRef<Path>>(path: P) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 111 |     pub fn mime_type(&self) -> &'static str {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 135 |     pub fn video_extensions() -> &'static [&'static str] {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 140 |     pub fn audio_extensions() -> &'static [&'static str] {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 145 |     pub fn all_extensions() -> Vec<&'static str> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/app.rs:439:13
[INFO] [stdout]     |
[INFO] [stdout] 439 |     fn view(&self) -> Element<Message> {
[INFO] [stdout]     |             ^^^^^     ^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |             |
[INFO] [stdout]     |             the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]     = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 439 |     fn view(&self) -> Element<'_, Message> {
[INFO] [stdout]     |                               +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/app.rs:494:21
[INFO] [stdout]     |
[INFO] [stdout] 494 |     fn view_welcome(&self) -> Element<Message> {
[INFO] [stdout]     |                     ^^^^^     ^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                     |
[INFO] [stdout]     |                     the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 494 |     fn view_welcome(&self) -> Element<'_, Message> {
[INFO] [stdout]     |                                       +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/app.rs:537:20
[INFO] [stdout]     |
[INFO] [stdout] 537 |     fn view_player(&self) -> Element<Message> {
[INFO] [stdout]     |                    ^^^^^     ^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                    |
[INFO] [stdout]     |                    the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 537 |     fn view_player(&self) -> Element<'_, Message> {
[INFO] [stdout]     |                                      +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/app.rs:581:22
[INFO] [stdout]     |
[INFO] [stdout] 581 |     fn view_controls(&self) -> Element<Message> {
[INFO] [stdout]     |                      ^^^^^     ^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                      |
[INFO] [stdout]     |                      the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 581 |     fn view_controls(&self) -> Element<'_, Message> {
[INFO] [stdout]     |                                        +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/app.rs:689:23
[INFO] [stdout]     |
[INFO] [stdout] 689 |     fn view_equalizer(&self) -> Element<Message> {
[INFO] [stdout]     |                       ^^^^^     ^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                       |
[INFO] [stdout]     |                       the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 689 |     fn view_equalizer(&self) -> Element<'_, Message> {
[INFO] [stdout]     |                                         +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/app.rs:747:26
[INFO] [stdout]     |
[INFO] [stdout] 747 |     fn view_error_banner(&self, error: &str) -> Element<Message> {
[INFO] [stdout]     |                          ^^^^^                  ^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                          |
[INFO] [stdout]     |                          the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 747 |     fn view_error_banner(&self, error: &str) -> Element<'_, Message> {
[INFO] [stdout]     |                                                         +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple fields are never read
[INFO] [stdout]   --> src/app.rs:16:5
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub struct NovPlayer {
[INFO] [stdout]    |            --------- fields in this struct
[INFO] [stdout] 15 |     /// Media player engine
[INFO] [stdout] 16 |     player: PlayerEngine,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] 17 |     /// Current player state
[INFO] [stdout] 18 |     state: PlayerState,
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout] 19 |     /// Playlist manager
[INFO] [stdout] 20 |     playlist: PlaylistManager,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 21 |     /// User configuration
[INFO] [stdout] 22 |     config: Config,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] 23 |     /// Current volume (0.0 - 1.0)
[INFO] [stdout] 24 |     volume: f32,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] 25 |     /// Is muted
[INFO] [stdout] 26 |     muted: bool,
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout] 27 |     /// Current playback position in seconds
[INFO] [stdout] 28 |     position: f64,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 29 |     /// Total duration in seconds
[INFO] [stdout] 30 |     duration: f64,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 31 |     /// Is fullscreen
[INFO] [stdout] 32 |     fullscreen: bool,
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] 33 |     /// Show controls overlay
[INFO] [stdout] 34 |     show_controls: bool,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 35 |     /// Show equalizer panel
[INFO] [stdout] 36 |     show_equalizer: bool,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 37 |     /// Current equalizer preset
[INFO] [stdout] 38 |     eq_preset: EqualizerPreset,
[INFO] [stdout]    |     ^^^^^^^^^
[INFO] [stdout] 39 |     /// Custom EQ bands (10 bands, -12 to +12 dB)
[INFO] [stdout] 40 |     eq_bands: [f32; 10],
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 41 |     /// Available subtitle tracks
[INFO] [stdout] 42 |     subtitle_tracks: Vec<String>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 43 |     /// Current subtitle track index (None = disabled)
[INFO] [stdout] 44 |     current_subtitle: Option<usize>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 45 |     /// Error message to display
[INFO] [stdout] 46 |     error_message: Option<String>,
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] 47 |     /// Video frame handle
[INFO] [stdout] 48 |     video_handle: Option<image::Handle>,
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout] 49 |     /// Video buffer (BGRA)
[INFO] [stdout] 50 |     video_buffer: Vec<u8>,
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout] 51 |     /// Window dimensions
[INFO] [stdout] 52 |     width: u32,
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout] 53 |     height: u32,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Message` is never used
[INFO] [stdout]   --> src/app.rs:58:10
[INFO] [stdout]    |
[INFO] [stdout] 58 | pub enum Message {
[INFO] [stdout]    |          ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> src/app.rs:117:8
[INFO] [stdout]     |
[INFO] [stdout] 116 | impl NovPlayer {
[INFO] [stdout]     | -------------- associated items in this implementation
[INFO] [stdout] 117 |     fn new(initial_file: Option<String>) -> (Self, Task<Message>) {
[INFO] [stdout]     |        ^^^
[INFO] [stdout] ...
[INFO] [stdout] 154 |     fn title(&self) -> String {
[INFO] [stdout]     |        ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 163 |     fn theme(&self) -> Theme {
[INFO] [stdout]     |        ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 167 |     fn update(&mut self, message: Message) -> Task<Message> {
[INFO] [stdout]     |        ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 425 |     fn subscription(&self) -> Subscription<Message> {
[INFO] [stdout]     |        ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 439 |     fn view(&self) -> Element<Message> {
[INFO] [stdout]     |        ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 463 |     fn handle_keyboard(&mut self, key: keyboard::Key) -> Task<Message> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 494 |     fn view_welcome(&self) -> Element<Message> {
[INFO] [stdout]     |        ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 537 |     fn view_player(&self) -> Element<Message> {
[INFO] [stdout]     |        ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 581 |     fn view_controls(&self) -> Element<Message> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 689 |     fn view_equalizer(&self) -> Element<Message> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 747 |     fn view_error_banner(&self, error: &str) -> Element<Message> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `format_duration` is never used
[INFO] [stdout]    --> src/app.rs:773:4
[INFO] [stdout]     |
[INFO] [stdout] 773 | fn format_duration(seconds: f64) -> String {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `run` is never used
[INFO] [stdout]    --> src/app.rs:787:8
[INFO] [stdout]     |
[INFO] [stdout] 787 | pub fn run(initial_file: Option<String>) -> iced::Result {
[INFO] [stdout]     |        ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `pts` is never read
[INFO] [stdout]   --> src/player/engine.rs:54:9
[INFO] [stdout]    |
[INFO] [stdout] 50 | pub struct VideoFrame {
[INFO] [stdout]    |            ---------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 54 |     pub pts: f64,
[INFO] [stdout]    |         ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `audio_handle` is never read
[INFO] [stdout]    --> src/player/engine.rs:110:5
[INFO] [stdout]     |
[INFO] [stdout] 101 | pub struct PlayerEngine {
[INFO] [stdout]     |            ------------ field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 110 |     audio_handle: rodio::OutputStreamHandle,
[INFO] [stdout]     |     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `AudioSample` is never constructed
[INFO] [stdout]    --> src/player/engine.rs:248:8
[INFO] [stdout]     |
[INFO] [stdout] 248 | struct AudioSample {
[INFO] [stdout]     |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `EQ_FREQUENCIES` is never used
[INFO] [stdout]    --> src/player/equalizer.rs:149:11
[INFO] [stdout]     |
[INFO] [stdout] 149 | pub const EQ_FREQUENCIES: [u32; 10] = [32, 64, 125, 250, 500, 1000, 2000, 4000, 8000, 16000];
[INFO] [stdout]     |           ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `EQ_LABELS` is never used
[INFO] [stdout]    --> src/player/equalizer.rs:152:11
[INFO] [stdout]     |
[INFO] [stdout] 152 | pub const EQ_LABELS: [&str; 10] = ["32", "64", "125", "250", "500", "1K", "2K", "4K", "8K", "16K"];
[INFO] [stdout]     |           ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/player/audio.rs:18:12
[INFO] [stdout]    |
[INFO] [stdout] 17 | impl AudioSource {
[INFO] [stdout]    | ---------------- associated function in this implementation
[INFO] [stdout] 18 |     pub fn new(receiver: Receiver<f32>, sample_rate: u32, channels: u16) -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `NovTheme` is never constructed
[INFO] [stdout]  --> src/ui/theme.rs:7:12
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub struct NovTheme;
[INFO] [stdout]   |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `dark` is never used
[INFO] [stdout]   --> src/ui/theme.rs:11:12
[INFO] [stdout]    |
[INFO] [stdout]  9 | impl NovTheme {
[INFO] [stdout]    | ------------- associated function in this implementation
[INFO] [stdout] 10 |     /// Create the dark theme
[INFO] [stdout] 11 |     pub fn dark() -> Theme {
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `BACKGROUND_DARK` is never used
[INFO] [stdout]   --> src/ui/theme.rs:30:15
[INFO] [stdout]    |
[INFO] [stdout] 30 |     pub const BACKGROUND_DARK: Color = Color::from_rgb(0.05, 0.05, 0.05);
[INFO] [stdout]    |               ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `BACKGROUND_PANEL` is never used
[INFO] [stdout]   --> src/ui/theme.rs:31:15
[INFO] [stdout]    |
[INFO] [stdout] 31 |     pub const BACKGROUND_PANEL: Color = Color::from_rgb(0.1, 0.1, 0.1);
[INFO] [stdout]    |               ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `BACKGROUND_CONTROL` is never used
[INFO] [stdout]   --> src/ui/theme.rs:32:15
[INFO] [stdout]    |
[INFO] [stdout] 32 |     pub const BACKGROUND_CONTROL: Color = Color::from_rgb(0.15, 0.15, 0.15);
[INFO] [stdout]    |               ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `BACKGROUND_HOVER` is never used
[INFO] [stdout]   --> src/ui/theme.rs:33:15
[INFO] [stdout]    |
[INFO] [stdout] 33 |     pub const BACKGROUND_HOVER: Color = Color::from_rgb(0.2, 0.2, 0.2);
[INFO] [stdout]    |               ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `ACCENT_BLUE` is never used
[INFO] [stdout]   --> src/ui/theme.rs:36:15
[INFO] [stdout]    |
[INFO] [stdout] 36 |     pub const ACCENT_BLUE: Color = Color::from_rgb(0.0, 0.66, 1.0);
[INFO] [stdout]    |               ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `ACCENT_ORANGE` is never used
[INFO] [stdout]   --> src/ui/theme.rs:37:15
[INFO] [stdout]    |
[INFO] [stdout] 37 |     pub const ACCENT_ORANGE: Color = Color::from_rgb(1.0, 0.5, 0.0);
[INFO] [stdout]    |               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `ACCENT_GREEN` is never used
[INFO] [stdout]   --> src/ui/theme.rs:38:15
[INFO] [stdout]    |
[INFO] [stdout] 38 |     pub const ACCENT_GREEN: Color = Color::from_rgb(0.2, 0.8, 0.4);
[INFO] [stdout]    |               ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `ACCENT_RED` is never used
[INFO] [stdout]   --> src/ui/theme.rs:39:15
[INFO] [stdout]    |
[INFO] [stdout] 39 |     pub const ACCENT_RED: Color = Color::from_rgb(0.9, 0.2, 0.2);
[INFO] [stdout]    |               ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `TEXT_PRIMARY` is never used
[INFO] [stdout]   --> src/ui/theme.rs:42:15
[INFO] [stdout]    |
[INFO] [stdout] 42 |     pub const TEXT_PRIMARY: Color = Color::from_rgb(0.9, 0.9, 0.9);
[INFO] [stdout]    |               ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `TEXT_SECONDARY` is never used
[INFO] [stdout]   --> src/ui/theme.rs:43:15
[INFO] [stdout]    |
[INFO] [stdout] 43 |     pub const TEXT_SECONDARY: Color = Color::from_rgb(0.6, 0.6, 0.6);
[INFO] [stdout]    |               ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `TEXT_MUTED` is never used
[INFO] [stdout]   --> src/ui/theme.rs:44:15
[INFO] [stdout]    |
[INFO] [stdout] 44 |     pub const TEXT_MUTED: Color = Color::from_rgb(0.4, 0.4, 0.4);
[INFO] [stdout]    |               ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SEEK_BACKGROUND` is never used
[INFO] [stdout]   --> src/ui/theme.rs:47:15
[INFO] [stdout]    |
[INFO] [stdout] 47 |     pub const SEEK_BACKGROUND: Color = Color::from_rgb(0.2, 0.2, 0.2);
[INFO] [stdout]    |               ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SEEK_PROGRESS` is never used
[INFO] [stdout]   --> src/ui/theme.rs:48:15
[INFO] [stdout]    |
[INFO] [stdout] 48 |     pub const SEEK_PROGRESS: Color = Color::from_rgb(0.0, 0.66, 1.0);
[INFO] [stdout]    |               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SEEK_BUFFERED` is never used
[INFO] [stdout]   --> src/ui/theme.rs:49:15
[INFO] [stdout]    |
[INFO] [stdout] 49 |     pub const SEEK_BUFFERED: Color = Color::from_rgb(0.3, 0.3, 0.3);
[INFO] [stdout]    |               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SEEK_HANDLE` is never used
[INFO] [stdout]   --> src/ui/theme.rs:50:15
[INFO] [stdout]    |
[INFO] [stdout] 50 |     pub const SEEK_HANDLE: Color = Color::from_rgb(1.0, 1.0, 1.0);
[INFO] [stdout]    |               ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `GLASS_BACKGROUND` is never used
[INFO] [stdout]   --> src/ui/theme.rs:53:15
[INFO] [stdout]    |
[INFO] [stdout] 53 |     pub const GLASS_BACKGROUND: Color = Color::from_rgba(0.1, 0.1, 0.1, 0.8);
[INFO] [stdout]    |               ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `GLASS_BORDER` is never used
[INFO] [stdout]   --> src/ui/theme.rs:54:15
[INFO] [stdout]    |
[INFO] [stdout] 54 |     pub const GLASS_BORDER: Color = Color::from_rgba(1.0, 1.0, 1.0, 0.1);
[INFO] [stdout]    |               ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `PLAY` is never used
[INFO] [stdout]   --> src/ui/theme.rs:59:15
[INFO] [stdout]    |
[INFO] [stdout] 59 |     pub const PLAY: &str = "▶";
[INFO] [stdout]    |               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `PAUSE` is never used
[INFO] [stdout]   --> src/ui/theme.rs:60:15
[INFO] [stdout]    |
[INFO] [stdout] 60 |     pub const PAUSE: &str = "⏸";
[INFO] [stdout]    |               ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `STOP` is never used
[INFO] [stdout]   --> src/ui/theme.rs:61:15
[INFO] [stdout]    |
[INFO] [stdout] 61 |     pub const STOP: &str = "⏹";
[INFO] [stdout]    |               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `PREVIOUS` is never used
[INFO] [stdout]   --> src/ui/theme.rs:62:15
[INFO] [stdout]    |
[INFO] [stdout] 62 |     pub const PREVIOUS: &str = "⏮";
[INFO] [stdout]    |               ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `NEXT` is never used
[INFO] [stdout]   --> src/ui/theme.rs:63:15
[INFO] [stdout]    |
[INFO] [stdout] 63 |     pub const NEXT: &str = "⏭";
[INFO] [stdout]    |               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `REWIND` is never used
[INFO] [stdout]   --> src/ui/theme.rs:64:15
[INFO] [stdout]    |
[INFO] [stdout] 64 |     pub const REWIND: &str = "⏪";
[INFO] [stdout]    |               ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `FORWARD` is never used
[INFO] [stdout]   --> src/ui/theme.rs:65:15
[INFO] [stdout]    |
[INFO] [stdout] 65 |     pub const FORWARD: &str = "⏩";
[INFO] [stdout]    |               ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `VOLUME_HIGH` is never used
[INFO] [stdout]   --> src/ui/theme.rs:66:15
[INFO] [stdout]    |
[INFO] [stdout] 66 |     pub const VOLUME_HIGH: &str = "🔊";
[INFO] [stdout]    |               ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `VOLUME_MEDIUM` is never used
[INFO] [stdout]   --> src/ui/theme.rs:67:15
[INFO] [stdout]    |
[INFO] [stdout] 67 |     pub const VOLUME_MEDIUM: &str = "🔉";
[INFO] [stdout]    |               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `VOLUME_LOW` is never used
[INFO] [stdout]   --> src/ui/theme.rs:68:15
[INFO] [stdout]    |
[INFO] [stdout] 68 |     pub const VOLUME_LOW: &str = "🔈";
[INFO] [stdout]    |               ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `VOLUME_MUTE` is never used
[INFO] [stdout]   --> src/ui/theme.rs:69:15
[INFO] [stdout]    |
[INFO] [stdout] 69 |     pub const VOLUME_MUTE: &str = "🔇";
[INFO] [stdout]    |               ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `FULLSCREEN` is never used
[INFO] [stdout]   --> src/ui/theme.rs:70:15
[INFO] [stdout]    |
[INFO] [stdout] 70 |     pub const FULLSCREEN: &str = "⛶";
[INFO] [stdout]    |               ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `FULLSCREEN_EXIT` is never used
[INFO] [stdout]   --> src/ui/theme.rs:71:15
[INFO] [stdout]    |
[INFO] [stdout] 71 |     pub const FULLSCREEN_EXIT: &str = "⊡";
[INFO] [stdout]    |               ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SETTINGS` is never used
[INFO] [stdout]   --> src/ui/theme.rs:72:15
[INFO] [stdout]    |
[INFO] [stdout] 72 |     pub const SETTINGS: &str = "⚙";
[INFO] [stdout]    |               ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `PLAYLIST` is never used
[INFO] [stdout]   --> src/ui/theme.rs:73:15
[INFO] [stdout]    |
[INFO] [stdout] 73 |     pub const PLAYLIST: &str = "☰";
[INFO] [stdout]    |               ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SUBTITLES` is never used
[INFO] [stdout]   --> src/ui/theme.rs:74:15
[INFO] [stdout]    |
[INFO] [stdout] 74 |     pub const SUBTITLES: &str = "CC";
[INFO] [stdout]    |               ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `EQUALIZER` is never used
[INFO] [stdout]   --> src/ui/theme.rs:75:15
[INFO] [stdout]    |
[INFO] [stdout] 75 |     pub const EQUALIZER: &str = "♫";
[INFO] [stdout]    |               ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `FOLDER` is never used
[INFO] [stdout]   --> src/ui/theme.rs:76:15
[INFO] [stdout]    |
[INFO] [stdout] 76 |     pub const FOLDER: &str = "📁";
[INFO] [stdout]    |               ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `FILE` is never used
[INFO] [stdout]   --> src/ui/theme.rs:77:15
[INFO] [stdout]    |
[INFO] [stdout] 77 |     pub const FILE: &str = "📄";
[INFO] [stdout]    |               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `CLOSE` is never used
[INFO] [stdout]   --> src/ui/theme.rs:78:15
[INFO] [stdout]    |
[INFO] [stdout] 78 |     pub const CLOSE: &str = "✕";
[INFO] [stdout]    |               ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `CHECK` is never used
[INFO] [stdout]   --> src/ui/theme.rs:79:15
[INFO] [stdout]    |
[INFO] [stdout] 79 |     pub const CHECK: &str = "✓";
[INFO] [stdout]    |               ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SHUFFLE` is never used
[INFO] [stdout]   --> src/ui/theme.rs:80:15
[INFO] [stdout]    |
[INFO] [stdout] 80 |     pub const SHUFFLE: &str = "🔀";
[INFO] [stdout]    |               ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `REPEAT` is never used
[INFO] [stdout]   --> src/ui/theme.rs:81:15
[INFO] [stdout]    |
[INFO] [stdout] 81 |     pub const REPEAT: &str = "🔁";
[INFO] [stdout]    |               ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `REPEAT_ONE` is never used
[INFO] [stdout]   --> src/ui/theme.rs:82:15
[INFO] [stdout]    |
[INFO] [stdout] 82 |     pub const REPEAT_ONE: &str = "🔂";
[INFO] [stdout]    |               ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `TINY` is never used
[INFO] [stdout]   --> src/ui/theme.rs:87:15
[INFO] [stdout]    |
[INFO] [stdout] 87 |     pub const TINY: u16 = 4;
[INFO] [stdout]    |               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SMALL` is never used
[INFO] [stdout]   --> src/ui/theme.rs:88:15
[INFO] [stdout]    |
[INFO] [stdout] 88 |     pub const SMALL: u16 = 8;
[INFO] [stdout]    |               ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MEDIUM` is never used
[INFO] [stdout]   --> src/ui/theme.rs:89:15
[INFO] [stdout]    |
[INFO] [stdout] 89 |     pub const MEDIUM: u16 = 12;
[INFO] [stdout]    |               ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `LARGE` is never used
[INFO] [stdout]   --> src/ui/theme.rs:90:15
[INFO] [stdout]    |
[INFO] [stdout] 90 |     pub const LARGE: u16 = 16;
[INFO] [stdout]    |               ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `XLARGE` is never used
[INFO] [stdout]   --> src/ui/theme.rs:91:15
[INFO] [stdout]    |
[INFO] [stdout] 91 |     pub const XLARGE: u16 = 24;
[INFO] [stdout]    |               ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `XXLARGE` is never used
[INFO] [stdout]   --> src/ui/theme.rs:92:15
[INFO] [stdout]    |
[INFO] [stdout] 92 |     pub const XXLARGE: u16 = 32;
[INFO] [stdout]    |               ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `TINY` is never used
[INFO] [stdout]   --> src/ui/theme.rs:97:15
[INFO] [stdout]    |
[INFO] [stdout] 97 |     pub const TINY: f32 = 10.0;
[INFO] [stdout]    |               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SMALL` is never used
[INFO] [stdout]   --> src/ui/theme.rs:98:15
[INFO] [stdout]    |
[INFO] [stdout] 98 |     pub const SMALL: f32 = 12.0;
[INFO] [stdout]    |               ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `NORMAL` is never used
[INFO] [stdout]   --> src/ui/theme.rs:99:15
[INFO] [stdout]    |
[INFO] [stdout] 99 |     pub const NORMAL: f32 = 14.0;
[INFO] [stdout]    |               ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MEDIUM` is never used
[INFO] [stdout]    --> src/ui/theme.rs:100:15
[INFO] [stdout]     |
[INFO] [stdout] 100 |     pub const MEDIUM: f32 = 16.0;
[INFO] [stdout]     |               ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `LARGE` is never used
[INFO] [stdout]    --> src/ui/theme.rs:101:15
[INFO] [stdout]     |
[INFO] [stdout] 101 |     pub const LARGE: f32 = 20.0;
[INFO] [stdout]     |               ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `XLARGE` is never used
[INFO] [stdout]    --> src/ui/theme.rs:102:15
[INFO] [stdout]     |
[INFO] [stdout] 102 |     pub const XLARGE: f32 = 24.0;
[INFO] [stdout]     |               ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `TITLE` is never used
[INFO] [stdout]    --> src/ui/theme.rs:103:15
[INFO] [stdout]     |
[INFO] [stdout] 103 |     pub const TITLE: f32 = 32.0;
[INFO] [stdout]     |               ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `HERO` is never used
[INFO] [stdout]    --> src/ui/theme.rs:104:15
[INFO] [stdout]     |
[INFO] [stdout] 104 |     pub const HERO: f32 = 48.0;
[INFO] [stdout]     |               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SMALL` is never used
[INFO] [stdout]    --> src/ui/theme.rs:109:15
[INFO] [stdout]     |
[INFO] [stdout] 109 |     pub const SMALL: f32 = 4.0;
[INFO] [stdout]     |               ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MEDIUM` is never used
[INFO] [stdout]    --> src/ui/theme.rs:110:15
[INFO] [stdout]     |
[INFO] [stdout] 110 |     pub const MEDIUM: f32 = 8.0;
[INFO] [stdout]     |               ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `LARGE` is never used
[INFO] [stdout]    --> src/ui/theme.rs:111:15
[INFO] [stdout]     |
[INFO] [stdout] 111 |     pub const LARGE: f32 = 12.0;
[INFO] [stdout]     |               ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `PILL` is never used
[INFO] [stdout]    --> src/ui/theme.rs:112:15
[INFO] [stdout]     |
[INFO] [stdout] 112 |     pub const PILL: f32 = 999.0;
[INFO] [stdout]     |               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `video_view` is never used
[INFO] [stdout]   --> src/ui/components/video_view.rs:12:8
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub fn video_view<'a, Message: 'a>() -> Element<'a, Message> {
[INFO] [stdout]    |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `AspectRatio` is never used
[INFO] [stdout]   --> src/ui/components/video_view.rs:27:10
[INFO] [stdout]    |
[INFO] [stdout] 27 | pub enum AspectRatio {
[INFO] [stdout]    |          ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `as_str` and `ratio` are never used
[INFO] [stdout]   --> src/ui/components/video_view.rs:42:12
[INFO] [stdout]    |
[INFO] [stdout] 41 | impl AspectRatio {
[INFO] [stdout]    | ---------------- methods in this implementation
[INFO] [stdout] 42 |     pub fn as_str(&self) -> &'static str {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 52 |     pub fn ratio(&self) -> Option<f32> {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `controls_bar` is never used
[INFO] [stdout]   --> src/ui/components/controls_bar.rs:12:8
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub fn controls_bar<'a, Message: 'a>() -> Element<'a, Message> 
[INFO] [stdout]    |        ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `timeline` is never used
[INFO] [stdout]  --> src/ui/components/timeline.rs:8:8
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub fn timeline<'a, Message: 'a>() -> Element<'a, Message> 
[INFO] [stdout]   |        ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `volume_control` is never used
[INFO] [stdout]  --> src/ui/components/volume.rs:8:8
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub fn volume_control<'a, Message: 'a>() -> Element<'a, Message> 
[INFO] [stdout]   |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `equalizer_panel` is never used
[INFO] [stdout]  --> src/ui/components/equalizer.rs:8:8
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub fn equalizer_panel<'a, Message: 'a>() -> Element<'a, Message> 
[INFO] [stdout]   |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `subtitles_panel` is never used
[INFO] [stdout]  --> src/ui/components/subtitles.rs:8:8
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub fn subtitles_panel<'a, Message: 'a>() -> Element<'a, Message> 
[INFO] [stdout]   |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `SubtitleSettings` is never constructed
[INFO] [stdout]   --> src/ui/components/subtitles.rs:17:12
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub struct SubtitleSettings {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `MediaFormat` is never used
[INFO] [stdout]  --> src/utils/formats.rs:7:10
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub enum MediaFormat {
[INFO] [stdout]   |          ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> src/utils/formats.rs:39:12
[INFO] [stdout]     |
[INFO] [stdout]  37 | impl MediaFormat {
[INFO] [stdout]     | ---------------- associated items in this implementation
[INFO] [stdout]  38 |     /// Detect format from file extension
[INFO] [stdout]  39 |     pub fn from_path<P: AsRef<Path>>(path: P) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  51 |     pub fn from_extension(ext: &str) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  83 |     pub fn is_video(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  92 |     pub fn is_audio(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 101 |     pub fn is_playlist(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 106 |     pub fn is_supported(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 111 |     pub fn mime_type(&self) -> &'static str {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 135 |     pub fn video_extensions() -> &'static [&'static str] {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 140 |     pub fn audio_extensions() -> &'static [&'static str] {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 145 |     pub fn all_extensions() -> Vec<&'static str> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/app.rs:439:13
[INFO] [stdout]     |
[INFO] [stdout] 439 |     fn view(&self) -> Element<Message> {
[INFO] [stdout]     |             ^^^^^     ^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |             |
[INFO] [stdout]     |             the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]     = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 439 |     fn view(&self) -> Element<'_, Message> {
[INFO] [stdout]     |                               +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/app.rs:494:21
[INFO] [stdout]     |
[INFO] [stdout] 494 |     fn view_welcome(&self) -> Element<Message> {
[INFO] [stdout]     |                     ^^^^^     ^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                     |
[INFO] [stdout]     |                     the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 494 |     fn view_welcome(&self) -> Element<'_, Message> {
[INFO] [stdout]     |                                       +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/app.rs:537:20
[INFO] [stdout]     |
[INFO] [stdout] 537 |     fn view_player(&self) -> Element<Message> {
[INFO] [stdout]     |                    ^^^^^     ^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                    |
[INFO] [stdout]     |                    the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 537 |     fn view_player(&self) -> Element<'_, Message> {
[INFO] [stdout]     |                                      +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/app.rs:581:22
[INFO] [stdout]     |
[INFO] [stdout] 581 |     fn view_controls(&self) -> Element<Message> {
[INFO] [stdout]     |                      ^^^^^     ^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                      |
[INFO] [stdout]     |                      the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 581 |     fn view_controls(&self) -> Element<'_, Message> {
[INFO] [stdout]     |                                        +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/app.rs:689:23
[INFO] [stdout]     |
[INFO] [stdout] 689 |     fn view_equalizer(&self) -> Element<Message> {
[INFO] [stdout]     |                       ^^^^^     ^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                       |
[INFO] [stdout]     |                       the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 689 |     fn view_equalizer(&self) -> Element<'_, Message> {
[INFO] [stdout]     |                                         +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/app.rs:747:26
[INFO] [stdout]     |
[INFO] [stdout] 747 |     fn view_error_banner(&self, error: &str) -> Element<Message> {
[INFO] [stdout]     |                          ^^^^^                  ^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                          |
[INFO] [stdout]     |                          the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 747 |     fn view_error_banner(&self, error: &str) -> Element<'_, Message> {
[INFO] [stdout]     |                                                         +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `JoinHandle`
[INFO] [stdout]   --> src/player/engine.rs:10:25
[INFO] [stdout]    |
[INFO] [stdout] 10 | use std::thread::{self, JoinHandle};
[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: `parking_lot::Mutex as PMutex`
[INFO] [stdout]   --> src/player/engine.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 15 | use parking_lot::Mutex as PMutex;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `formats::MediaFormat`
[INFO] [stdout]  --> src/utils/mod.rs:7:9
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub use formats::MediaFormat;
[INFO] [stdout]   |         ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `JoinHandle`
[INFO] [stdout]   --> src/player/engine.rs:10:25
[INFO] [stdout]    |
[INFO] [stdout] 10 | use std::thread::{self, JoinHandle};
[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: `parking_lot::Mutex as PMutex`
[INFO] [stdout]   --> src/player/engine.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 15 | use parking_lot::Mutex as PMutex;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `formats::MediaFormat`
[INFO] [stdout]  --> src/utils/mod.rs:7:9
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub use formats::MediaFormat;
[INFO] [stdout]   |         ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `PlaybackControls`
[INFO] [stdout]  --> src/app.rs:8:48
[INFO] [stdout]   |
[INFO] [stdout] 8 | use crate::player::{PlayerEngine, PlayerState, PlaybackControls, EqualizerPreset};
[INFO] [stdout]   |                                                ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `channels`
[INFO] [stdout]    --> src/player/decoder.rs:107:13
[INFO] [stdout]     |
[INFO] [stdout] 107 |         let channels = decoder.channels() as u16;
[INFO] [stdout]     |             ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_channels`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `config` and `video_buffer` are never read
[INFO] [stdout]   --> src/app.rs:22:5
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub struct NovPlayer {
[INFO] [stdout]    |            --------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 22 |     config: Config,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 50 |     video_buffer: 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: multiple variants are never constructed
[INFO] [stdout]    --> src/app.rs:63:5
[INFO] [stdout]     |
[INFO] [stdout]  58 | pub enum Message {
[INFO] [stdout]     |          ------- variants in this enum
[INFO] [stdout] ...
[INFO] [stdout]  63 |     Stop,
[INFO] [stdout]     |     ^^^^
[INFO] [stdout] ...
[INFO] [stdout]  77 |     FileLoaded(Result<Duration, String>),
[INFO] [stdout]     |     ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  80 |     PositionChanged(f64),
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^
[INFO] [stdout]  81 |     DurationChanged(f64),
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  86 |     ToggleControls,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^
[INFO] [stdout]  87 |     ToggleEqualizer,
[INFO] [stdout]  88 |     HideControls,
[INFO] [stdout]     |     ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  96 |     SetSubtitle(Option<usize>),
[INFO] [stdout]     |     ^^^^^^^^^^^
[INFO] [stdout]  97 |     SubtitlesLoaded(Vec<String>),
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 102 |     AddToPlaylist(PathBuf),
[INFO] [stdout]     |     ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 105 |     WindowResized(u32, u32),
[INFO] [stdout]     |     ^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `Message` 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: method `title` is never used
[INFO] [stdout]    --> src/app.rs:154:8
[INFO] [stdout]     |
[INFO] [stdout] 116 | impl NovPlayer {
[INFO] [stdout]     | -------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 154 |     fn title(&self) -> String {
[INFO] [stdout]     |        ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `pts` is never read
[INFO] [stdout]   --> src/player/engine.rs:54:9
[INFO] [stdout]    |
[INFO] [stdout] 50 | pub struct VideoFrame {
[INFO] [stdout]    |            ---------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 54 |     pub pts: f64,
[INFO] [stdout]    |         ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `MediaMetadata` is never constructed
[INFO] [stdout]   --> src/player/engine.rs:59:12
[INFO] [stdout]    |
[INFO] [stdout] 59 | pub struct MediaMetadata {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `audio_handle` is never read
[INFO] [stdout]    --> src/player/engine.rs:110:5
[INFO] [stdout]     |
[INFO] [stdout] 101 | pub struct PlayerEngine {
[INFO] [stdout]     |            ------------ field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 110 |     audio_handle: rodio::OutputStreamHandle,
[INFO] [stdout]     |     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `seek_relative`, `is_playing`, and `get_metadata` are never used
[INFO] [stdout]    --> src/player/engine.rs:184:12
[INFO] [stdout]     |
[INFO] [stdout] 116 | impl PlayerEngine {
[INFO] [stdout]     | ----------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 184 |     pub fn seek_relative(&mut self, delta: f64) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 197 |     pub fn is_playing(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 229 |     pub fn get_metadata(&self) -> MediaMetadata {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `AudioSample` is never constructed
[INFO] [stdout]    --> src/player/engine.rs:248:8
[INFO] [stdout]     |
[INFO] [stdout] 248 | struct AudioSample {
[INFO] [stdout]     |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `PlaybackControls` is never used
[INFO] [stdout]  --> src/player/controls.rs:6:11
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub trait PlaybackControls {
[INFO] [stdout]   |           ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `TrebleBoost` and `Vocal` are never constructed
[INFO] [stdout]   --> src/player/equalizer.rs:17:5
[INFO] [stdout]    |
[INFO] [stdout]  5 | pub enum EqualizerPreset {
[INFO] [stdout]    |          --------------- variants in this enum
[INFO] [stdout] ...
[INFO] [stdout] 17 |     TrebleBoost,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 18 |     /// Vocal - enhanced mid frequencies for speech
[INFO] [stdout] 19 |     Vocal,
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `EqualizerPreset` 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: associated items `name` and `all` are never used
[INFO] [stdout]    --> src/player/equalizer.rs:121:12
[INFO] [stdout]     |
[INFO] [stdout]  30 | impl EqualizerPreset {
[INFO] [stdout]     | -------------------- associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 121 |     pub fn name(&self) -> &'static str {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 135 |     pub fn all() -> &'static [EqualizerPreset] {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `EQ_FREQUENCIES` is never used
[INFO] [stdout]    --> src/player/equalizer.rs:149:11
[INFO] [stdout]     |
[INFO] [stdout] 149 | pub const EQ_FREQUENCIES: [u32; 10] = [32, 64, 125, 250, 500, 1000, 2000, 4000, 8000, 16000];
[INFO] [stdout]     |           ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `EQ_LABELS` is never used
[INFO] [stdout]    --> src/player/equalizer.rs:152:11
[INFO] [stdout]     |
[INFO] [stdout] 152 | pub const EQ_LABELS: [&str; 10] = ["32", "64", "125", "250", "500", "1K", "2K", "4K", "8K", "16K"];
[INFO] [stdout]     |           ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/player/audio.rs:18:12
[INFO] [stdout]    |
[INFO] [stdout] 17 | impl AudioSource {
[INFO] [stdout]    | ---------------- associated function in this implementation
[INFO] [stdout] 18 |     pub fn new(receiver: Receiver<f32>, sample_rate: u32, channels: u16) -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `All` and `One` are never constructed
[INFO] [stdout]   --> src/playlist/manager.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout]  7 | pub enum RepeatMode {
[INFO] [stdout]    |          ---------- variants in this enum
[INFO] [stdout] ...
[INFO] [stdout] 12 |     All,
[INFO] [stdout]    |     ^^^
[INFO] [stdout] 13 |     /// Repeat current track
[INFO] [stdout] 14 |     One,
[INFO] [stdout]    |     ^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `RepeatMode` 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: multiple methods are never used
[INFO] [stdout]    --> src/playlist/manager.rs:68:12
[INFO] [stdout]     |
[INFO] [stdout]  40 | impl PlaylistManager {
[INFO] [stdout]     | -------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  68 |     pub fn add_many(&mut self, paths: Vec<PathBuf>) {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  75 |     pub fn remove(&mut self, index: usize) {
[INFO] [stdout]     |            ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  99 |     pub fn clear(&mut self) {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 107 |     pub fn current(&self) -> Option<PathBuf> {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 112 |     pub fn current_index(&self) -> Option<usize> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 117 |     pub fn set_current(&mut self, index: usize) {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 226 |     pub fn toggle_shuffle(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 234 |     pub fn set_shuffle(&mut self, enabled: bool) {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 241 |     pub fn is_shuffle(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 246 |     pub fn cycle_repeat(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 255 |     pub fn set_repeat(&mut self, mode: RepeatMode) {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 260 |     pub fn repeat_mode(&self) -> RepeatMode {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 265 |     pub fn tracks(&self) -> &[PathBuf] {
[INFO] [stdout]     |            ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 270 |     pub fn len(&self) -> usize {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 275 |     pub fn is_empty(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 305 |     pub fn move_track(&mut self, from: usize, to: usize) {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `BACKGROUND_DARK` is never used
[INFO] [stdout]   --> src/ui/theme.rs:30:15
[INFO] [stdout]    |
[INFO] [stdout] 30 |     pub const BACKGROUND_DARK: Color = Color::from_rgb(0.05, 0.05, 0.05);
[INFO] [stdout]    |               ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `BACKGROUND_PANEL` is never used
[INFO] [stdout]   --> src/ui/theme.rs:31:15
[INFO] [stdout]    |
[INFO] [stdout] 31 |     pub const BACKGROUND_PANEL: Color = Color::from_rgb(0.1, 0.1, 0.1);
[INFO] [stdout]    |               ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `BACKGROUND_CONTROL` is never used
[INFO] [stdout]   --> src/ui/theme.rs:32:15
[INFO] [stdout]    |
[INFO] [stdout] 32 |     pub const BACKGROUND_CONTROL: Color = Color::from_rgb(0.15, 0.15, 0.15);
[INFO] [stdout]    |               ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `BACKGROUND_HOVER` is never used
[INFO] [stdout]   --> src/ui/theme.rs:33:15
[INFO] [stdout]    |
[INFO] [stdout] 33 |     pub const BACKGROUND_HOVER: Color = Color::from_rgb(0.2, 0.2, 0.2);
[INFO] [stdout]    |               ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `ACCENT_BLUE` is never used
[INFO] [stdout]   --> src/ui/theme.rs:36:15
[INFO] [stdout]    |
[INFO] [stdout] 36 |     pub const ACCENT_BLUE: Color = Color::from_rgb(0.0, 0.66, 1.0);
[INFO] [stdout]    |               ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `ACCENT_ORANGE` is never used
[INFO] [stdout]   --> src/ui/theme.rs:37:15
[INFO] [stdout]    |
[INFO] [stdout] 37 |     pub const ACCENT_ORANGE: Color = Color::from_rgb(1.0, 0.5, 0.0);
[INFO] [stdout]    |               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `ACCENT_GREEN` is never used
[INFO] [stdout]   --> src/ui/theme.rs:38:15
[INFO] [stdout]    |
[INFO] [stdout] 38 |     pub const ACCENT_GREEN: Color = Color::from_rgb(0.2, 0.8, 0.4);
[INFO] [stdout]    |               ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `ACCENT_RED` is never used
[INFO] [stdout]   --> src/ui/theme.rs:39:15
[INFO] [stdout]    |
[INFO] [stdout] 39 |     pub const ACCENT_RED: Color = Color::from_rgb(0.9, 0.2, 0.2);
[INFO] [stdout]    |               ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `TEXT_PRIMARY` is never used
[INFO] [stdout]   --> src/ui/theme.rs:42:15
[INFO] [stdout]    |
[INFO] [stdout] 42 |     pub const TEXT_PRIMARY: Color = Color::from_rgb(0.9, 0.9, 0.9);
[INFO] [stdout]    |               ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `TEXT_SECONDARY` is never used
[INFO] [stdout]   --> src/ui/theme.rs:43:15
[INFO] [stdout]    |
[INFO] [stdout] 43 |     pub const TEXT_SECONDARY: Color = Color::from_rgb(0.6, 0.6, 0.6);
[INFO] [stdout]    |               ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `TEXT_MUTED` is never used
[INFO] [stdout]   --> src/ui/theme.rs:44:15
[INFO] [stdout]    |
[INFO] [stdout] 44 |     pub const TEXT_MUTED: Color = Color::from_rgb(0.4, 0.4, 0.4);
[INFO] [stdout]    |               ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SEEK_BACKGROUND` is never used
[INFO] [stdout]   --> src/ui/theme.rs:47:15
[INFO] [stdout]    |
[INFO] [stdout] 47 |     pub const SEEK_BACKGROUND: Color = Color::from_rgb(0.2, 0.2, 0.2);
[INFO] [stdout]    |               ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SEEK_PROGRESS` is never used
[INFO] [stdout]   --> src/ui/theme.rs:48:15
[INFO] [stdout]    |
[INFO] [stdout] 48 |     pub const SEEK_PROGRESS: Color = Color::from_rgb(0.0, 0.66, 1.0);
[INFO] [stdout]    |               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SEEK_BUFFERED` is never used
[INFO] [stdout]   --> src/ui/theme.rs:49:15
[INFO] [stdout]    |
[INFO] [stdout] 49 |     pub const SEEK_BUFFERED: Color = Color::from_rgb(0.3, 0.3, 0.3);
[INFO] [stdout]    |               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SEEK_HANDLE` is never used
[INFO] [stdout]   --> src/ui/theme.rs:50:15
[INFO] [stdout]    |
[INFO] [stdout] 50 |     pub const SEEK_HANDLE: Color = Color::from_rgb(1.0, 1.0, 1.0);
[INFO] [stdout]    |               ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `GLASS_BACKGROUND` is never used
[INFO] [stdout]   --> src/ui/theme.rs:53:15
[INFO] [stdout]    |
[INFO] [stdout] 53 |     pub const GLASS_BACKGROUND: Color = Color::from_rgba(0.1, 0.1, 0.1, 0.8);
[INFO] [stdout]    |               ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `GLASS_BORDER` is never used
[INFO] [stdout]   --> src/ui/theme.rs:54:15
[INFO] [stdout]    |
[INFO] [stdout] 54 |     pub const GLASS_BORDER: Color = Color::from_rgba(1.0, 1.0, 1.0, 0.1);
[INFO] [stdout]    |               ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `PLAY` is never used
[INFO] [stdout]   --> src/ui/theme.rs:59:15
[INFO] [stdout]    |
[INFO] [stdout] 59 |     pub const PLAY: &str = "▶";
[INFO] [stdout]    |               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `PAUSE` is never used
[INFO] [stdout]   --> src/ui/theme.rs:60:15
[INFO] [stdout]    |
[INFO] [stdout] 60 |     pub const PAUSE: &str = "⏸";
[INFO] [stdout]    |               ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `STOP` is never used
[INFO] [stdout]   --> src/ui/theme.rs:61:15
[INFO] [stdout]    |
[INFO] [stdout] 61 |     pub const STOP: &str = "⏹";
[INFO] [stdout]    |               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `PREVIOUS` is never used
[INFO] [stdout]   --> src/ui/theme.rs:62:15
[INFO] [stdout]    |
[INFO] [stdout] 62 |     pub const PREVIOUS: &str = "⏮";
[INFO] [stdout]    |               ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `NEXT` is never used
[INFO] [stdout]   --> src/ui/theme.rs:63:15
[INFO] [stdout]    |
[INFO] [stdout] 63 |     pub const NEXT: &str = "⏭";
[INFO] [stdout]    |               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `REWIND` is never used
[INFO] [stdout]   --> src/ui/theme.rs:64:15
[INFO] [stdout]    |
[INFO] [stdout] 64 |     pub const REWIND: &str = "⏪";
[INFO] [stdout]    |               ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `FORWARD` is never used
[INFO] [stdout]   --> src/ui/theme.rs:65:15
[INFO] [stdout]    |
[INFO] [stdout] 65 |     pub const FORWARD: &str = "⏩";
[INFO] [stdout]    |               ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `VOLUME_HIGH` is never used
[INFO] [stdout]   --> src/ui/theme.rs:66:15
[INFO] [stdout]    |
[INFO] [stdout] 66 |     pub const VOLUME_HIGH: &str = "🔊";
[INFO] [stdout]    |               ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `VOLUME_MEDIUM` is never used
[INFO] [stdout]   --> src/ui/theme.rs:67:15
[INFO] [stdout]    |
[INFO] [stdout] 67 |     pub const VOLUME_MEDIUM: &str = "🔉";
[INFO] [stdout]    |               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `VOLUME_LOW` is never used
[INFO] [stdout]   --> src/ui/theme.rs:68:15
[INFO] [stdout]    |
[INFO] [stdout] 68 |     pub const VOLUME_LOW: &str = "🔈";
[INFO] [stdout]    |               ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `VOLUME_MUTE` is never used
[INFO] [stdout]   --> src/ui/theme.rs:69:15
[INFO] [stdout]    |
[INFO] [stdout] 69 |     pub const VOLUME_MUTE: &str = "🔇";
[INFO] [stdout]    |               ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `FULLSCREEN` is never used
[INFO] [stdout]   --> src/ui/theme.rs:70:15
[INFO] [stdout]    |
[INFO] [stdout] 70 |     pub const FULLSCREEN: &str = "⛶";
[INFO] [stdout]    |               ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `FULLSCREEN_EXIT` is never used
[INFO] [stdout]   --> src/ui/theme.rs:71:15
[INFO] [stdout]    |
[INFO] [stdout] 71 |     pub const FULLSCREEN_EXIT: &str = "⊡";
[INFO] [stdout]    |               ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SETTINGS` is never used
[INFO] [stdout]   --> src/ui/theme.rs:72:15
[INFO] [stdout]    |
[INFO] [stdout] 72 |     pub const SETTINGS: &str = "⚙";
[INFO] [stdout]    |               ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `PLAYLIST` is never used
[INFO] [stdout]   --> src/ui/theme.rs:73:15
[INFO] [stdout]    |
[INFO] [stdout] 73 |     pub const PLAYLIST: &str = "☰";
[INFO] [stdout]    |               ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SUBTITLES` is never used
[INFO] [stdout]   --> src/ui/theme.rs:74:15
[INFO] [stdout]    |
[INFO] [stdout] 74 |     pub const SUBTITLES: &str = "CC";
[INFO] [stdout]    |               ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `EQUALIZER` is never used
[INFO] [stdout]   --> src/ui/theme.rs:75:15
[INFO] [stdout]    |
[INFO] [stdout] 75 |     pub const EQUALIZER: &str = "♫";
[INFO] [stdout]    |               ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `FOLDER` is never used
[INFO] [stdout]   --> src/ui/theme.rs:76:15
[INFO] [stdout]    |
[INFO] [stdout] 76 |     pub const FOLDER: &str = "📁";
[INFO] [stdout]    |               ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `FILE` is never used
[INFO] [stdout]   --> src/ui/theme.rs:77:15
[INFO] [stdout]    |
[INFO] [stdout] 77 |     pub const FILE: &str = "📄";
[INFO] [stdout]    |               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `CLOSE` is never used
[INFO] [stdout]   --> src/ui/theme.rs:78:15
[INFO] [stdout]    |
[INFO] [stdout] 78 |     pub const CLOSE: &str = "✕";
[INFO] [stdout]    |               ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `CHECK` is never used
[INFO] [stdout]   --> src/ui/theme.rs:79:15
[INFO] [stdout]    |
[INFO] [stdout] 79 |     pub const CHECK: &str = "✓";
[INFO] [stdout]    |               ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SHUFFLE` is never used
[INFO] [stdout]   --> src/ui/theme.rs:80:15
[INFO] [stdout]    |
[INFO] [stdout] 80 |     pub const SHUFFLE: &str = "🔀";
[INFO] [stdout]    |               ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `REPEAT` is never used
[INFO] [stdout]   --> src/ui/theme.rs:81:15
[INFO] [stdout]    |
[INFO] [stdout] 81 |     pub const REPEAT: &str = "🔁";
[INFO] [stdout]    |               ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `REPEAT_ONE` is never used
[INFO] [stdout]   --> src/ui/theme.rs:82:15
[INFO] [stdout]    |
[INFO] [stdout] 82 |     pub const REPEAT_ONE: &str = "🔂";
[INFO] [stdout]    |               ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `TINY` is never used
[INFO] [stdout]   --> src/ui/theme.rs:87:15
[INFO] [stdout]    |
[INFO] [stdout] 87 |     pub const TINY: u16 = 4;
[INFO] [stdout]    |               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SMALL` is never used
[INFO] [stdout]   --> src/ui/theme.rs:88:15
[INFO] [stdout]    |
[INFO] [stdout] 88 |     pub const SMALL: u16 = 8;
[INFO] [stdout]    |               ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MEDIUM` is never used
[INFO] [stdout]   --> src/ui/theme.rs:89:15
[INFO] [stdout]    |
[INFO] [stdout] 89 |     pub const MEDIUM: u16 = 12;
[INFO] [stdout]    |               ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `LARGE` is never used
[INFO] [stdout]   --> src/ui/theme.rs:90:15
[INFO] [stdout]    |
[INFO] [stdout] 90 |     pub const LARGE: u16 = 16;
[INFO] [stdout]    |               ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `XLARGE` is never used
[INFO] [stdout]   --> src/ui/theme.rs:91:15
[INFO] [stdout]    |
[INFO] [stdout] 91 |     pub const XLARGE: u16 = 24;
[INFO] [stdout]    |               ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `XXLARGE` is never used
[INFO] [stdout]   --> src/ui/theme.rs:92:15
[INFO] [stdout]    |
[INFO] [stdout] 92 |     pub const XXLARGE: u16 = 32;
[INFO] [stdout]    |               ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `TINY` is never used
[INFO] [stdout]   --> src/ui/theme.rs:97:15
[INFO] [stdout]    |
[INFO] [stdout] 97 |     pub const TINY: f32 = 10.0;
[INFO] [stdout]    |               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SMALL` is never used
[INFO] [stdout]   --> src/ui/theme.rs:98:15
[INFO] [stdout]    |
[INFO] [stdout] 98 |     pub const SMALL: f32 = 12.0;
[INFO] [stdout]    |               ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `NORMAL` is never used
[INFO] [stdout]   --> src/ui/theme.rs:99:15
[INFO] [stdout]    |
[INFO] [stdout] 99 |     pub const NORMAL: f32 = 14.0;
[INFO] [stdout]    |               ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MEDIUM` is never used
[INFO] [stdout]    --> src/ui/theme.rs:100:15
[INFO] [stdout]     |
[INFO] [stdout] 100 |     pub const MEDIUM: f32 = 16.0;
[INFO] [stdout]     |               ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `LARGE` is never used
[INFO] [stdout]    --> src/ui/theme.rs:101:15
[INFO] [stdout]     |
[INFO] [stdout] 101 |     pub const LARGE: f32 = 20.0;
[INFO] [stdout]     |               ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `XLARGE` is never used
[INFO] [stdout]    --> src/ui/theme.rs:102:15
[INFO] [stdout]     |
[INFO] [stdout] 102 |     pub const XLARGE: f32 = 24.0;
[INFO] [stdout]     |               ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `TITLE` is never used
[INFO] [stdout]    --> src/ui/theme.rs:103:15
[INFO] [stdout]     |
[INFO] [stdout] 103 |     pub const TITLE: f32 = 32.0;
[INFO] [stdout]     |               ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `HERO` is never used
[INFO] [stdout]    --> src/ui/theme.rs:104:15
[INFO] [stdout]     |
[INFO] [stdout] 104 |     pub const HERO: f32 = 48.0;
[INFO] [stdout]     |               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SMALL` is never used
[INFO] [stdout]    --> src/ui/theme.rs:109:15
[INFO] [stdout]     |
[INFO] [stdout] 109 |     pub const SMALL: f32 = 4.0;
[INFO] [stdout]     |               ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MEDIUM` is never used
[INFO] [stdout]    --> src/ui/theme.rs:110:15
[INFO] [stdout]     |
[INFO] [stdout] 110 |     pub const MEDIUM: f32 = 8.0;
[INFO] [stdout]     |               ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `LARGE` is never used
[INFO] [stdout]    --> src/ui/theme.rs:111:15
[INFO] [stdout]     |
[INFO] [stdout] 111 |     pub const LARGE: f32 = 12.0;
[INFO] [stdout]     |               ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `PILL` is never used
[INFO] [stdout]    --> src/ui/theme.rs:112:15
[INFO] [stdout]     |
[INFO] [stdout] 112 |     pub const PILL: f32 = 999.0;
[INFO] [stdout]     |               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `video_view` is never used
[INFO] [stdout]   --> src/ui/components/video_view.rs:12:8
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub fn video_view<'a, Message: 'a>() -> Element<'a, Message> {
[INFO] [stdout]    |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `AspectRatio` is never used
[INFO] [stdout]   --> src/ui/components/video_view.rs:27:10
[INFO] [stdout]    |
[INFO] [stdout] 27 | pub enum AspectRatio {
[INFO] [stdout]    |          ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `as_str` and `ratio` are never used
[INFO] [stdout]   --> src/ui/components/video_view.rs:42:12
[INFO] [stdout]    |
[INFO] [stdout] 41 | impl AspectRatio {
[INFO] [stdout]    | ---------------- methods in this implementation
[INFO] [stdout] 42 |     pub fn as_str(&self) -> &'static str {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 52 |     pub fn ratio(&self) -> Option<f32> {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `controls_bar` is never used
[INFO] [stdout]   --> src/ui/components/controls_bar.rs:12:8
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub fn controls_bar<'a, Message: 'a>() -> Element<'a, Message> 
[INFO] [stdout]    |        ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `timeline` is never used
[INFO] [stdout]  --> src/ui/components/timeline.rs:8:8
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub fn timeline<'a, Message: 'a>() -> Element<'a, Message> 
[INFO] [stdout]   |        ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `volume_control` is never used
[INFO] [stdout]  --> src/ui/components/volume.rs:8:8
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub fn volume_control<'a, Message: 'a>() -> Element<'a, Message> 
[INFO] [stdout]   |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `equalizer_panel` is never used
[INFO] [stdout]  --> src/ui/components/equalizer.rs:8:8
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub fn equalizer_panel<'a, Message: 'a>() -> Element<'a, Message> 
[INFO] [stdout]   |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `subtitles_panel` is never used
[INFO] [stdout]  --> src/ui/components/subtitles.rs:8:8
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub fn subtitles_panel<'a, Message: 'a>() -> Element<'a, Message> 
[INFO] [stdout]   |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `SubtitleSettings` is never constructed
[INFO] [stdout]   --> src/ui/components/subtitles.rs:17:12
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub struct SubtitleSettings {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `save`, `add_recent_file`, `get_eq_preset`, and `set_eq_preset` are never used
[INFO] [stdout]    --> src/utils/config.rs:92:12
[INFO] [stdout]     |
[INFO] [stdout]  72 | impl Config {
[INFO] [stdout]     | ----------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  92 |     pub fn save(&self) -> Result<()> {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 106 |     pub fn add_recent_file(&mut self, path: PathBuf) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 118 |     pub fn get_eq_preset(&self) -> EqualizerPreset {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 132 |     pub fn set_eq_preset(&mut self, preset: EqualizerPreset) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `MediaFormat` is never used
[INFO] [stdout]  --> src/utils/formats.rs:7:10
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub enum MediaFormat {
[INFO] [stdout]   |          ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> src/utils/formats.rs:39:12
[INFO] [stdout]     |
[INFO] [stdout]  37 | impl MediaFormat {
[INFO] [stdout]     | ---------------- associated items in this implementation
[INFO] [stdout]  38 |     /// Detect format from file extension
[INFO] [stdout]  39 |     pub fn from_path<P: AsRef<Path>>(path: P) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  51 |     pub fn from_extension(ext: &str) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  83 |     pub fn is_video(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  92 |     pub fn is_audio(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 101 |     pub fn is_playlist(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 106 |     pub fn is_supported(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 111 |     pub fn mime_type(&self) -> &'static str {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 135 |     pub fn video_extensions() -> &'static [&'static str] {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 140 |     pub fn audio_extensions() -> &'static [&'static str] {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 145 |     pub fn all_extensions() -> Vec<&'static str> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/app.rs:439:13
[INFO] [stdout]     |
[INFO] [stdout] 439 |     fn view(&self) -> Element<Message> {
[INFO] [stdout]     |             ^^^^^     ^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |             |
[INFO] [stdout]     |             the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]     = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 439 |     fn view(&self) -> Element<'_, Message> {
[INFO] [stdout]     |                               +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/app.rs:494:21
[INFO] [stdout]     |
[INFO] [stdout] 494 |     fn view_welcome(&self) -> Element<Message> {
[INFO] [stdout]     |                     ^^^^^     ^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                     |
[INFO] [stdout]     |                     the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 494 |     fn view_welcome(&self) -> Element<'_, Message> {
[INFO] [stdout]     |                                       +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/app.rs:537:20
[INFO] [stdout]     |
[INFO] [stdout] 537 |     fn view_player(&self) -> Element<Message> {
[INFO] [stdout]     |                    ^^^^^     ^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                    |
[INFO] [stdout]     |                    the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 537 |     fn view_player(&self) -> Element<'_, Message> {
[INFO] [stdout]     |                                      +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/app.rs:581:22
[INFO] [stdout]     |
[INFO] [stdout] 581 |     fn view_controls(&self) -> Element<Message> {
[INFO] [stdout]     |                      ^^^^^     ^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                      |
[INFO] [stdout]     |                      the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 581 |     fn view_controls(&self) -> Element<'_, Message> {
[INFO] [stdout]     |                                        +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/app.rs:689:23
[INFO] [stdout]     |
[INFO] [stdout] 689 |     fn view_equalizer(&self) -> Element<Message> {
[INFO] [stdout]     |                       ^^^^^     ^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                       |
[INFO] [stdout]     |                       the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 689 |     fn view_equalizer(&self) -> Element<'_, Message> {
[INFO] [stdout]     |                                         +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/app.rs:747:26
[INFO] [stdout]     |
[INFO] [stdout] 747 |     fn view_error_banner(&self, error: &str) -> Element<Message> {
[INFO] [stdout]     |                          ^^^^^                  ^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                          |
[INFO] [stdout]     |                          the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 747 |     fn view_error_banner(&self, error: &str) -> Element<'_, Message> {
[INFO] [stdout]     |                                                         +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `PlaybackControls`
[INFO] [stdout]  --> src/app.rs:8:48
[INFO] [stdout]   |
[INFO] [stdout] 8 | use crate::player::{PlayerEngine, PlayerState, PlaybackControls, EqualizerPreset};
[INFO] [stdout]   |                                                ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `channels`
[INFO] [stdout]    --> src/player/decoder.rs:107:13
[INFO] [stdout]     |
[INFO] [stdout] 107 |         let channels = decoder.channels() as u16;
[INFO] [stdout]     |             ^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_channels`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `config` and `video_buffer` are never read
[INFO] [stdout]   --> src/app.rs:22:5
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub struct NovPlayer {
[INFO] [stdout]    |            --------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 22 |     config: Config,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 50 |     video_buffer: 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: multiple variants are never constructed
[INFO] [stdout]    --> src/app.rs:63:5
[INFO] [stdout]     |
[INFO] [stdout]  58 | pub enum Message {
[INFO] [stdout]     |          ------- variants in this enum
[INFO] [stdout] ...
[INFO] [stdout]  63 |     Stop,
[INFO] [stdout]     |     ^^^^
[INFO] [stdout] ...
[INFO] [stdout]  77 |     FileLoaded(Result<Duration, String>),
[INFO] [stdout]     |     ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  80 |     PositionChanged(f64),
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^
[INFO] [stdout]  81 |     DurationChanged(f64),
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  86 |     ToggleControls,
[INFO] [stdout]     |     ^^^^^^^^^^^^^^
[INFO] [stdout]  87 |     ToggleEqualizer,
[INFO] [stdout]  88 |     HideControls,
[INFO] [stdout]     |     ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  96 |     SetSubtitle(Option<usize>),
[INFO] [stdout]     |     ^^^^^^^^^^^
[INFO] [stdout]  97 |     SubtitlesLoaded(Vec<String>),
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 102 |     AddToPlaylist(PathBuf),
[INFO] [stdout]     |     ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 105 |     WindowResized(u32, u32),
[INFO] [stdout]     |     ^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `Message` 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: method `title` is never used
[INFO] [stdout]    --> src/app.rs:154:8
[INFO] [stdout]     |
[INFO] [stdout] 116 | impl NovPlayer {
[INFO] [stdout]     | -------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 154 |     fn title(&self) -> String {
[INFO] [stdout]     |        ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `pts` is never read
[INFO] [stdout]   --> src/player/engine.rs:54:9
[INFO] [stdout]    |
[INFO] [stdout] 50 | pub struct VideoFrame {
[INFO] [stdout]    |            ---------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 54 |     pub pts: f64,
[INFO] [stdout]    |         ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `MediaMetadata` is never constructed
[INFO] [stdout]   --> src/player/engine.rs:59:12
[INFO] [stdout]    |
[INFO] [stdout] 59 | pub struct MediaMetadata {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `audio_handle` is never read
[INFO] [stdout]    --> src/player/engine.rs:110:5
[INFO] [stdout]     |
[INFO] [stdout] 101 | pub struct PlayerEngine {
[INFO] [stdout]     |            ------------ field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 110 |     audio_handle: rodio::OutputStreamHandle,
[INFO] [stdout]     |     ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `seek_relative`, `is_playing`, and `get_metadata` are never used
[INFO] [stdout]    --> src/player/engine.rs:184:12
[INFO] [stdout]     |
[INFO] [stdout] 116 | impl PlayerEngine {
[INFO] [stdout]     | ----------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 184 |     pub fn seek_relative(&mut self, delta: f64) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 197 |     pub fn is_playing(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 229 |     pub fn get_metadata(&self) -> MediaMetadata {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `AudioSample` is never constructed
[INFO] [stdout]    --> src/player/engine.rs:248:8
[INFO] [stdout]     |
[INFO] [stdout] 248 | struct AudioSample {
[INFO] [stdout]     |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `PlaybackControls` is never used
[INFO] [stdout]  --> src/player/controls.rs:6:11
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub trait PlaybackControls {
[INFO] [stdout]   |           ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `TrebleBoost` and `Vocal` are never constructed
[INFO] [stdout]   --> src/player/equalizer.rs:17:5
[INFO] [stdout]    |
[INFO] [stdout]  5 | pub enum EqualizerPreset {
[INFO] [stdout]    |          --------------- variants in this enum
[INFO] [stdout] ...
[INFO] [stdout] 17 |     TrebleBoost,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 18 |     /// Vocal - enhanced mid frequencies for speech
[INFO] [stdout] 19 |     Vocal,
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `EqualizerPreset` 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: associated items `name` and `all` are never used
[INFO] [stdout]    --> src/player/equalizer.rs:121:12
[INFO] [stdout]     |
[INFO] [stdout]  30 | impl EqualizerPreset {
[INFO] [stdout]     | -------------------- associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 121 |     pub fn name(&self) -> &'static str {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 135 |     pub fn all() -> &'static [EqualizerPreset] {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `EQ_FREQUENCIES` is never used
[INFO] [stdout]    --> src/player/equalizer.rs:149:11
[INFO] [stdout]     |
[INFO] [stdout] 149 | pub const EQ_FREQUENCIES: [u32; 10] = [32, 64, 125, 250, 500, 1000, 2000, 4000, 8000, 16000];
[INFO] [stdout]     |           ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `EQ_LABELS` is never used
[INFO] [stdout]    --> src/player/equalizer.rs:152:11
[INFO] [stdout]     |
[INFO] [stdout] 152 | pub const EQ_LABELS: [&str; 10] = ["32", "64", "125", "250", "500", "1K", "2K", "4K", "8K", "16K"];
[INFO] [stdout]     |           ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/player/audio.rs:18:12
[INFO] [stdout]    |
[INFO] [stdout] 17 | impl AudioSource {
[INFO] [stdout]    | ---------------- associated function in this implementation
[INFO] [stdout] 18 |     pub fn new(receiver: Receiver<f32>, sample_rate: u32, channels: u16) -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `One` is never constructed
[INFO] [stdout]   --> src/playlist/manager.rs:14:5
[INFO] [stdout]    |
[INFO] [stdout]  7 | pub enum RepeatMode {
[INFO] [stdout]    |          ---------- variant in this enum
[INFO] [stdout] ...
[INFO] [stdout] 14 |     One,
[INFO] [stdout]    |     ^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `RepeatMode` 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: multiple methods are never used
[INFO] [stdout]    --> src/playlist/manager.rs:68:12
[INFO] [stdout]     |
[INFO] [stdout]  40 | impl PlaylistManager {
[INFO] [stdout]     | -------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  68 |     pub fn add_many(&mut self, paths: Vec<PathBuf>) {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  75 |     pub fn remove(&mut self, index: usize) {
[INFO] [stdout]     |            ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  99 |     pub fn clear(&mut self) {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 107 |     pub fn current(&self) -> Option<PathBuf> {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 226 |     pub fn toggle_shuffle(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 234 |     pub fn set_shuffle(&mut self, enabled: bool) {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 241 |     pub fn is_shuffle(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 246 |     pub fn cycle_repeat(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 260 |     pub fn repeat_mode(&self) -> RepeatMode {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 265 |     pub fn tracks(&self) -> &[PathBuf] {
[INFO] [stdout]     |            ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 275 |     pub fn is_empty(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 305 |     pub fn move_track(&mut self, from: usize, to: usize) {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `BACKGROUND_DARK` is never used
[INFO] [stdout]   --> src/ui/theme.rs:30:15
[INFO] [stdout]    |
[INFO] [stdout] 30 |     pub const BACKGROUND_DARK: Color = Color::from_rgb(0.05, 0.05, 0.05);
[INFO] [stdout]    |               ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `BACKGROUND_PANEL` is never used
[INFO] [stdout]   --> src/ui/theme.rs:31:15
[INFO] [stdout]    |
[INFO] [stdout] 31 |     pub const BACKGROUND_PANEL: Color = Color::from_rgb(0.1, 0.1, 0.1);
[INFO] [stdout]    |               ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `BACKGROUND_CONTROL` is never used
[INFO] [stdout]   --> src/ui/theme.rs:32:15
[INFO] [stdout]    |
[INFO] [stdout] 32 |     pub const BACKGROUND_CONTROL: Color = Color::from_rgb(0.15, 0.15, 0.15);
[INFO] [stdout]    |               ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `BACKGROUND_HOVER` is never used
[INFO] [stdout]   --> src/ui/theme.rs:33:15
[INFO] [stdout]    |
[INFO] [stdout] 33 |     pub const BACKGROUND_HOVER: Color = Color::from_rgb(0.2, 0.2, 0.2);
[INFO] [stdout]    |               ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `ACCENT_BLUE` is never used
[INFO] [stdout]   --> src/ui/theme.rs:36:15
[INFO] [stdout]    |
[INFO] [stdout] 36 |     pub const ACCENT_BLUE: Color = Color::from_rgb(0.0, 0.66, 1.0);
[INFO] [stdout]    |               ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `ACCENT_ORANGE` is never used
[INFO] [stdout]   --> src/ui/theme.rs:37:15
[INFO] [stdout]    |
[INFO] [stdout] 37 |     pub const ACCENT_ORANGE: Color = Color::from_rgb(1.0, 0.5, 0.0);
[INFO] [stdout]    |               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `ACCENT_GREEN` is never used
[INFO] [stdout]   --> src/ui/theme.rs:38:15
[INFO] [stdout]    |
[INFO] [stdout] 38 |     pub const ACCENT_GREEN: Color = Color::from_rgb(0.2, 0.8, 0.4);
[INFO] [stdout]    |               ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `ACCENT_RED` is never used
[INFO] [stdout]   --> src/ui/theme.rs:39:15
[INFO] [stdout]    |
[INFO] [stdout] 39 |     pub const ACCENT_RED: Color = Color::from_rgb(0.9, 0.2, 0.2);
[INFO] [stdout]    |               ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `TEXT_PRIMARY` is never used
[INFO] [stdout]   --> src/ui/theme.rs:42:15
[INFO] [stdout]    |
[INFO] [stdout] 42 |     pub const TEXT_PRIMARY: Color = Color::from_rgb(0.9, 0.9, 0.9);
[INFO] [stdout]    |               ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `TEXT_SECONDARY` is never used
[INFO] [stdout]   --> src/ui/theme.rs:43:15
[INFO] [stdout]    |
[INFO] [stdout] 43 |     pub const TEXT_SECONDARY: Color = Color::from_rgb(0.6, 0.6, 0.6);
[INFO] [stdout]    |               ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `TEXT_MUTED` is never used
[INFO] [stdout]   --> src/ui/theme.rs:44:15
[INFO] [stdout]    |
[INFO] [stdout] 44 |     pub const TEXT_MUTED: Color = Color::from_rgb(0.4, 0.4, 0.4);
[INFO] [stdout]    |               ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SEEK_BACKGROUND` is never used
[INFO] [stdout]   --> src/ui/theme.rs:47:15
[INFO] [stdout]    |
[INFO] [stdout] 47 |     pub const SEEK_BACKGROUND: Color = Color::from_rgb(0.2, 0.2, 0.2);
[INFO] [stdout]    |               ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SEEK_PROGRESS` is never used
[INFO] [stdout]   --> src/ui/theme.rs:48:15
[INFO] [stdout]    |
[INFO] [stdout] 48 |     pub const SEEK_PROGRESS: Color = Color::from_rgb(0.0, 0.66, 1.0);
[INFO] [stdout]    |               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SEEK_BUFFERED` is never used
[INFO] [stdout]   --> src/ui/theme.rs:49:15
[INFO] [stdout]    |
[INFO] [stdout] 49 |     pub const SEEK_BUFFERED: Color = Color::from_rgb(0.3, 0.3, 0.3);
[INFO] [stdout]    |               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SEEK_HANDLE` is never used
[INFO] [stdout]   --> src/ui/theme.rs:50:15
[INFO] [stdout]    |
[INFO] [stdout] 50 |     pub const SEEK_HANDLE: Color = Color::from_rgb(1.0, 1.0, 1.0);
[INFO] [stdout]    |               ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `GLASS_BACKGROUND` is never used
[INFO] [stdout]   --> src/ui/theme.rs:53:15
[INFO] [stdout]    |
[INFO] [stdout] 53 |     pub const GLASS_BACKGROUND: Color = Color::from_rgba(0.1, 0.1, 0.1, 0.8);
[INFO] [stdout]    |               ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `GLASS_BORDER` is never used
[INFO] [stdout]   --> src/ui/theme.rs:54:15
[INFO] [stdout]    |
[INFO] [stdout] 54 |     pub const GLASS_BORDER: Color = Color::from_rgba(1.0, 1.0, 1.0, 0.1);
[INFO] [stdout]    |               ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `PLAY` is never used
[INFO] [stdout]   --> src/ui/theme.rs:59:15
[INFO] [stdout]    |
[INFO] [stdout] 59 |     pub const PLAY: &str = "▶";
[INFO] [stdout]    |               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `PAUSE` is never used
[INFO] [stdout]   --> src/ui/theme.rs:60:15
[INFO] [stdout]    |
[INFO] [stdout] 60 |     pub const PAUSE: &str = "⏸";
[INFO] [stdout]    |               ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `STOP` is never used
[INFO] [stdout]   --> src/ui/theme.rs:61:15
[INFO] [stdout]    |
[INFO] [stdout] 61 |     pub const STOP: &str = "⏹";
[INFO] [stdout]    |               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `PREVIOUS` is never used
[INFO] [stdout]   --> src/ui/theme.rs:62:15
[INFO] [stdout]    |
[INFO] [stdout] 62 |     pub const PREVIOUS: &str = "⏮";
[INFO] [stdout]    |               ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `NEXT` is never used
[INFO] [stdout]   --> src/ui/theme.rs:63:15
[INFO] [stdout]    |
[INFO] [stdout] 63 |     pub const NEXT: &str = "⏭";
[INFO] [stdout]    |               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `REWIND` is never used
[INFO] [stdout]   --> src/ui/theme.rs:64:15
[INFO] [stdout]    |
[INFO] [stdout] 64 |     pub const REWIND: &str = "⏪";
[INFO] [stdout]    |               ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `FORWARD` is never used
[INFO] [stdout]   --> src/ui/theme.rs:65:15
[INFO] [stdout]    |
[INFO] [stdout] 65 |     pub const FORWARD: &str = "⏩";
[INFO] [stdout]    |               ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `VOLUME_HIGH` is never used
[INFO] [stdout]   --> src/ui/theme.rs:66:15
[INFO] [stdout]    |
[INFO] [stdout] 66 |     pub const VOLUME_HIGH: &str = "🔊";
[INFO] [stdout]    |               ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `VOLUME_MEDIUM` is never used
[INFO] [stdout]   --> src/ui/theme.rs:67:15
[INFO] [stdout]    |
[INFO] [stdout] 67 |     pub const VOLUME_MEDIUM: &str = "🔉";
[INFO] [stdout]    |               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `VOLUME_LOW` is never used
[INFO] [stdout]   --> src/ui/theme.rs:68:15
[INFO] [stdout]    |
[INFO] [stdout] 68 |     pub const VOLUME_LOW: &str = "🔈";
[INFO] [stdout]    |               ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `VOLUME_MUTE` is never used
[INFO] [stdout]   --> src/ui/theme.rs:69:15
[INFO] [stdout]    |
[INFO] [stdout] 69 |     pub const VOLUME_MUTE: &str = "🔇";
[INFO] [stdout]    |               ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `FULLSCREEN` is never used
[INFO] [stdout]   --> src/ui/theme.rs:70:15
[INFO] [stdout]    |
[INFO] [stdout] 70 |     pub const FULLSCREEN: &str = "⛶";
[INFO] [stdout]    |               ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `FULLSCREEN_EXIT` is never used
[INFO] [stdout]   --> src/ui/theme.rs:71:15
[INFO] [stdout]    |
[INFO] [stdout] 71 |     pub const FULLSCREEN_EXIT: &str = "⊡";
[INFO] [stdout]    |               ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SETTINGS` is never used
[INFO] [stdout]   --> src/ui/theme.rs:72:15
[INFO] [stdout]    |
[INFO] [stdout] 72 |     pub const SETTINGS: &str = "⚙";
[INFO] [stdout]    |               ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `PLAYLIST` is never used
[INFO] [stdout]   --> src/ui/theme.rs:73:15
[INFO] [stdout]    |
[INFO] [stdout] 73 |     pub const PLAYLIST: &str = "☰";
[INFO] [stdout]    |               ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SUBTITLES` is never used
[INFO] [stdout]   --> src/ui/theme.rs:74:15
[INFO] [stdout]    |
[INFO] [stdout] 74 |     pub const SUBTITLES: &str = "CC";
[INFO] [stdout]    |               ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `EQUALIZER` is never used
[INFO] [stdout]   --> src/ui/theme.rs:75:15
[INFO] [stdout]    |
[INFO] [stdout] 75 |     pub const EQUALIZER: &str = "♫";
[INFO] [stdout]    |               ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `FOLDER` is never used
[INFO] [stdout]   --> src/ui/theme.rs:76:15
[INFO] [stdout]    |
[INFO] [stdout] 76 |     pub const FOLDER: &str = "📁";
[INFO] [stdout]    |               ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `FILE` is never used
[INFO] [stdout]   --> src/ui/theme.rs:77:15
[INFO] [stdout]    |
[INFO] [stdout] 77 |     pub const FILE: &str = "📄";
[INFO] [stdout]    |               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `CLOSE` is never used
[INFO] [stdout]   --> src/ui/theme.rs:78:15
[INFO] [stdout]    |
[INFO] [stdout] 78 |     pub const CLOSE: &str = "✕";
[INFO] [stdout]    |               ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `CHECK` is never used
[INFO] [stdout]   --> src/ui/theme.rs:79:15
[INFO] [stdout]    |
[INFO] [stdout] 79 |     pub const CHECK: &str = "✓";
[INFO] [stdout]    |               ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SHUFFLE` is never used
[INFO] [stdout]   --> src/ui/theme.rs:80:15
[INFO] [stdout]    |
[INFO] [stdout] 80 |     pub const SHUFFLE: &str = "🔀";
[INFO] [stdout]    |               ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `REPEAT` is never used
[INFO] [stdout]   --> src/ui/theme.rs:81:15
[INFO] [stdout]    |
[INFO] [stdout] 81 |     pub const REPEAT: &str = "🔁";
[INFO] [stdout]    |               ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `REPEAT_ONE` is never used
[INFO] [stdout]   --> src/ui/theme.rs:82:15
[INFO] [stdout]    |
[INFO] [stdout] 82 |     pub const REPEAT_ONE: &str = "🔂";
[INFO] [stdout]    |               ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `TINY` is never used
[INFO] [stdout]   --> src/ui/theme.rs:87:15
[INFO] [stdout]    |
[INFO] [stdout] 87 |     pub const TINY: u16 = 4;
[INFO] [stdout]    |               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SMALL` is never used
[INFO] [stdout]   --> src/ui/theme.rs:88:15
[INFO] [stdout]    |
[INFO] [stdout] 88 |     pub const SMALL: u16 = 8;
[INFO] [stdout]    |               ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MEDIUM` is never used
[INFO] [stdout]   --> src/ui/theme.rs:89:15
[INFO] [stdout]    |
[INFO] [stdout] 89 |     pub const MEDIUM: u16 = 12;
[INFO] [stdout]    |               ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `LARGE` is never used
[INFO] [stdout]   --> src/ui/theme.rs:90:15
[INFO] [stdout]    |
[INFO] [stdout] 90 |     pub const LARGE: u16 = 16;
[INFO] [stdout]    |               ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `XLARGE` is never used
[INFO] [stdout]   --> src/ui/theme.rs:91:15
[INFO] [stdout]    |
[INFO] [stdout] 91 |     pub const XLARGE: u16 = 24;
[INFO] [stdout]    |               ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `XXLARGE` is never used
[INFO] [stdout]   --> src/ui/theme.rs:92:15
[INFO] [stdout]    |
[INFO] [stdout] 92 |     pub const XXLARGE: u16 = 32;
[INFO] [stdout]    |               ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `TINY` is never used
[INFO] [stdout]   --> src/ui/theme.rs:97:15
[INFO] [stdout]    |
[INFO] [stdout] 97 |     pub const TINY: f32 = 10.0;
[INFO] [stdout]    |               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SMALL` is never used
[INFO] [stdout]   --> src/ui/theme.rs:98:15
[INFO] [stdout]    |
[INFO] [stdout] 98 |     pub const SMALL: f32 = 12.0;
[INFO] [stdout]    |               ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `NORMAL` is never used
[INFO] [stdout]   --> src/ui/theme.rs:99:15
[INFO] [stdout]    |
[INFO] [stdout] 99 |     pub const NORMAL: f32 = 14.0;
[INFO] [stdout]    |               ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MEDIUM` is never used
[INFO] [stdout]    --> src/ui/theme.rs:100:15
[INFO] [stdout]     |
[INFO] [stdout] 100 |     pub const MEDIUM: f32 = 16.0;
[INFO] [stdout]     |               ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `LARGE` is never used
[INFO] [stdout]    --> src/ui/theme.rs:101:15
[INFO] [stdout]     |
[INFO] [stdout] 101 |     pub const LARGE: f32 = 20.0;
[INFO] [stdout]     |               ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `XLARGE` is never used
[INFO] [stdout]    --> src/ui/theme.rs:102:15
[INFO] [stdout]     |
[INFO] [stdout] 102 |     pub const XLARGE: f32 = 24.0;
[INFO] [stdout]     |               ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `TITLE` is never used
[INFO] [stdout]    --> src/ui/theme.rs:103:15
[INFO] [stdout]     |
[INFO] [stdout] 103 |     pub const TITLE: f32 = 32.0;
[INFO] [stdout]     |               ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `HERO` is never used
[INFO] [stdout]    --> src/ui/theme.rs:104:15
[INFO] [stdout]     |
[INFO] [stdout] 104 |     pub const HERO: f32 = 48.0;
[INFO] [stdout]     |               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SMALL` is never used
[INFO] [stdout]    --> src/ui/theme.rs:109:15
[INFO] [stdout]     |
[INFO] [stdout] 109 |     pub const SMALL: f32 = 4.0;
[INFO] [stdout]     |               ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `MEDIUM` is never used
[INFO] [stdout]    --> src/ui/theme.rs:110:15
[INFO] [stdout]     |
[INFO] [stdout] 110 |     pub const MEDIUM: f32 = 8.0;
[INFO] [stdout]     |               ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `LARGE` is never used
[INFO] [stdout]    --> src/ui/theme.rs:111:15
[INFO] [stdout]     |
[INFO] [stdout] 111 |     pub const LARGE: f32 = 12.0;
[INFO] [stdout]     |               ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `PILL` is never used
[INFO] [stdout]    --> src/ui/theme.rs:112:15
[INFO] [stdout]     |
[INFO] [stdout] 112 |     pub const PILL: f32 = 999.0;
[INFO] [stdout]     |               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `video_view` is never used
[INFO] [stdout]   --> src/ui/components/video_view.rs:12:8
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub fn video_view<'a, Message: 'a>() -> Element<'a, Message> {
[INFO] [stdout]    |        ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `AspectRatio` is never used
[INFO] [stdout]   --> src/ui/components/video_view.rs:27:10
[INFO] [stdout]    |
[INFO] [stdout] 27 | pub enum AspectRatio {
[INFO] [stdout]    |          ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `as_str` and `ratio` are never used
[INFO] [stdout]   --> src/ui/components/video_view.rs:42:12
[INFO] [stdout]    |
[INFO] [stdout] 41 | impl AspectRatio {
[INFO] [stdout]    | ---------------- methods in this implementation
[INFO] [stdout] 42 |     pub fn as_str(&self) -> &'static str {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 52 |     pub fn ratio(&self) -> Option<f32> {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `controls_bar` is never used
[INFO] [stdout]   --> src/ui/components/controls_bar.rs:12:8
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub fn controls_bar<'a, Message: 'a>() -> Element<'a, Message> 
[INFO] [stdout]    |        ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `timeline` is never used
[INFO] [stdout]  --> src/ui/components/timeline.rs:8:8
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub fn timeline<'a, Message: 'a>() -> Element<'a, Message> 
[INFO] [stdout]   |        ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `volume_control` is never used
[INFO] [stdout]  --> src/ui/components/volume.rs:8:8
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub fn volume_control<'a, Message: 'a>() -> Element<'a, Message> 
[INFO] [stdout]   |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `equalizer_panel` is never used
[INFO] [stdout]  --> src/ui/components/equalizer.rs:8:8
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub fn equalizer_panel<'a, Message: 'a>() -> Element<'a, Message> 
[INFO] [stdout]   |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `subtitles_panel` is never used
[INFO] [stdout]  --> src/ui/components/subtitles.rs:8:8
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub fn subtitles_panel<'a, Message: 'a>() -> Element<'a, Message> 
[INFO] [stdout]   |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `SubtitleSettings` is never constructed
[INFO] [stdout]   --> src/ui/components/subtitles.rs:17:12
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub struct SubtitleSettings {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `save`, `add_recent_file`, `get_eq_preset`, and `set_eq_preset` are never used
[INFO] [stdout]    --> src/utils/config.rs:92:12
[INFO] [stdout]     |
[INFO] [stdout]  72 | impl Config {
[INFO] [stdout]     | ----------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  92 |     pub fn save(&self) -> Result<()> {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 106 |     pub fn add_recent_file(&mut self, path: PathBuf) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 118 |     pub fn get_eq_preset(&self) -> EqualizerPreset {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 132 |     pub fn set_eq_preset(&mut self, preset: EqualizerPreset) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `from_path`, `mime_type`, `video_extensions`, `audio_extensions`, and `all_extensions` are never used
[INFO] [stdout]    --> src/utils/formats.rs:39:12
[INFO] [stdout]     |
[INFO] [stdout]  37 | impl MediaFormat {
[INFO] [stdout]     | ---------------- associated items in this implementation
[INFO] [stdout]  38 |     /// Detect format from file extension
[INFO] [stdout]  39 |     pub fn from_path<P: AsRef<Path>>(path: P) -> Self {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 111 |     pub fn mime_type(&self) -> &'static str {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 135 |     pub fn video_extensions() -> &'static [&'static str] {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 140 |     pub fn audio_extensions() -> &'static [&'static str] {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 145 |     pub fn all_extensions() -> Vec<&'static str> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/app.rs:439:13
[INFO] [stdout]     |
[INFO] [stdout] 439 |     fn view(&self) -> Element<Message> {
[INFO] [stdout]     |             ^^^^^     ^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |             |
[INFO] [stdout]     |             the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout]     = note: `#[warn(mismatched_lifetime_syntaxes)]` on by default
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 439 |     fn view(&self) -> Element<'_, Message> {
[INFO] [stdout]     |                               +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/app.rs:494:21
[INFO] [stdout]     |
[INFO] [stdout] 494 |     fn view_welcome(&self) -> Element<Message> {
[INFO] [stdout]     |                     ^^^^^     ^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                     |
[INFO] [stdout]     |                     the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 494 |     fn view_welcome(&self) -> Element<'_, Message> {
[INFO] [stdout]     |                                       +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/app.rs:537:20
[INFO] [stdout]     |
[INFO] [stdout] 537 |     fn view_player(&self) -> Element<Message> {
[INFO] [stdout]     |                    ^^^^^     ^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                    |
[INFO] [stdout]     |                    the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 537 |     fn view_player(&self) -> Element<'_, Message> {
[INFO] [stdout]     |                                      +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/app.rs:581:22
[INFO] [stdout]     |
[INFO] [stdout] 581 |     fn view_controls(&self) -> Element<Message> {
[INFO] [stdout]     |                      ^^^^^     ^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                      |
[INFO] [stdout]     |                      the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 581 |     fn view_controls(&self) -> Element<'_, Message> {
[INFO] [stdout]     |                                        +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/app.rs:689:23
[INFO] [stdout]     |
[INFO] [stdout] 689 |     fn view_equalizer(&self) -> Element<Message> {
[INFO] [stdout]     |                       ^^^^^     ^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                       |
[INFO] [stdout]     |                       the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 689 |     fn view_equalizer(&self) -> Element<'_, Message> {
[INFO] [stdout]     |                                         +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: hiding a lifetime that's elided elsewhere is confusing
[INFO] [stdout]    --> src/app.rs:747:26
[INFO] [stdout]     |
[INFO] [stdout] 747 |     fn view_error_banner(&self, error: &str) -> Element<Message> {
[INFO] [stdout]     |                          ^^^^^                  ^^^^^^^^^^^^^^^^ the same lifetime is hidden here
[INFO] [stdout]     |                          |
[INFO] [stdout]     |                          the lifetime is elided here
[INFO] [stdout]     |
[INFO] [stdout]     = help: the same lifetime is referred to in inconsistent ways, making the signature confusing
[INFO] [stdout] help: use `'_` for type paths
[INFO] [stdout]     |
[INFO] [stdout] 747 |     fn view_error_banner(&self, error: &str) -> Element<'_, Message> {
[INFO] [stdout]     |                                                         +++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 5m 16s
[INFO] [stderr] warning: the following packages contain code that will be rejected by a future version of Rust: ashpd v0.8.1
[INFO] [stderr] note: to see what the problems were, use the option `--future-incompat-report`, or run `cargo report future-incompatibilities --id 3`
[INFO] running `Command { std: "docker" "inspect" "48e47bc3637a6c267d45b0993b688a842abe1122e00c686112806930d461eacd", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "48e47bc3637a6c267d45b0993b688a842abe1122e00c686112806930d461eacd", kill_on_drop: false }`
[INFO] [stdout] 48e47bc3637a6c267d45b0993b688a842abe1122e00c686112806930d461eacd
