[INFO] cloning repository https://github.com/vdemeester/abs-tui
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/vdemeester/abs-tui" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fvdemeester%2Fabs-tui", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fvdemeester%2Fabs-tui'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 7bc85e8bcfb8ac6e30586ba60a98a3969ea0d89a
[INFO] checking vdemeester/abs-tui against try#012cd62c9add58ab3910e44c137d87db3ab70f61 for pr-155915
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fvdemeester%2Fabs-tui" "/workspace/builds/worker-1-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-1-tc2/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/vdemeester/abs-tui
[INFO] finished tweaking git repo https://github.com/vdemeester/abs-tui
[INFO] tweaked toml for git repo https://github.com/vdemeester/abs-tui written to /workspace/builds/worker-1-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/vdemeester/abs-tui on toolchain 012cd62c9add58ab3910e44c137d87db3ab70f61
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+012cd62c9add58ab3910e44c137d87db3ab70f61" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/vdemeester/abs-tui 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" "+012cd62c9add58ab3910e44c137d87db3ab70f61" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-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" "+012cd62c9add58ab3910e44c137d87db3ab70f61" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] cb1d3684a343289ab700cc7d5a0a85c7e725efbcf6f1bcc47c6a4aee854d2f04
[INFO] running `Command { std: "docker" "start" "-a" "cb1d3684a343289ab700cc7d5a0a85c7e725efbcf6f1bcc47c6a4aee854d2f04", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "cb1d3684a343289ab700cc7d5a0a85c7e725efbcf6f1bcc47c6a4aee854d2f04", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "cb1d3684a343289ab700cc7d5a0a85c7e725efbcf6f1bcc47c6a4aee854d2f04", kill_on_drop: false }`
[INFO] [stdout] cb1d3684a343289ab700cc7d5a0a85c7e725efbcf6f1bcc47c6a4aee854d2f04
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-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=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:d429b63d4308055ea97f60fb1d3dfca48854a00942f1bd2ad806beaf015945ec" "/opt/rustwide/cargo-home/bin/cargo" "+012cd62c9add58ab3910e44c137d87db3ab70f61" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 31c864000ceeb8afe5e7d118b37dd7eb3e8cccc3c63a678a86b7f0b15f4f0c61
[INFO] running `Command { std: "docker" "start" "-a" "31c864000ceeb8afe5e7d118b37dd7eb3e8cccc3c63a678a86b7f0b15f4f0c61", kill_on_drop: false }`
[INFO] [stderr]    Compiling crossbeam-utils v0.8.21
[INFO] [stderr]    Compiling find-msvc-tools v0.1.8
[INFO] [stderr]     Checking errno v0.3.14
[INFO] [stderr]     Checking parking_lot_core v0.9.12
[INFO] [stderr]     Checking mio v1.1.1
[INFO] [stderr]     Checking socket2 v0.6.2
[INFO] [stderr]    Compiling futures-macro v0.3.31
[INFO] [stderr]    Compiling toml_parser v1.0.6+spec-1.1.0
[INFO] [stderr]     Checking serde v1.0.228
[INFO] [stderr]     Checking tracing v0.1.44
[INFO] [stderr]    Compiling toml_datetime v0.7.5+spec-1.1.0
[INFO] [stderr]    Compiling zerocopy v0.8.34
[INFO] [stderr]    Compiling rustix v1.1.3
[INFO] [stderr]     Checking futures-lite v2.6.1
[INFO] [stderr]    Compiling zvariant_utils v2.1.0
[INFO] [stderr]     Checking linux-raw-sys v0.11.0
[INFO] [stderr]     Checking signal-hook-registry v1.4.8
[INFO] [stderr]    Compiling enumflags2_derive v0.7.12
[INFO] [stderr]    Compiling openssl-macros v0.1.1
[INFO] [stderr]    Compiling cc v1.2.54
[INFO] [stderr]     Checking getrandom v0.2.17
[INFO] [stderr]     Checking parking_lot v0.12.5
[INFO] [stderr]    Compiling native-tls v0.2.14
[INFO] [stderr]    Compiling darling_core v0.23.0
[INFO] [stderr]    Compiling nix v0.29.0
[INFO] [stderr]     Checking icu_normalizer v2.1.1
[INFO] [stderr]     Checking tokio v1.49.0
[INFO] [stderr]    Compiling async-io v2.6.0
[INFO] [stderr]     Checking rand_core v0.6.4
[INFO] [stderr]     Checking piper v0.2.4
[INFO] [stderr]    Compiling zmij v1.0.17
[INFO] [stderr]     Checking endi v1.1.1
[INFO] [stderr]    Compiling toml_edit v0.23.10+spec-1.0.0
[INFO] [stderr]     Checking enumflags2 v0.7.12
[INFO] [stderr]     Checking futures-util v0.3.31
[INFO] [stderr]     Checking signal-hook v0.3.18
[INFO] [stderr]    Compiling instability v0.3.11
[INFO] [stderr]    Compiling libmpv2-sys v4.0.1
[INFO] [stderr]     Checking concurrent-queue v2.5.0
[INFO] [stderr]     Checking idna_adapter v1.2.1
[INFO] [stderr]     Checking regex-syntax v0.8.8
[INFO] [stderr]     Checking idna v1.1.0
[INFO] [stderr]     Checking sha1 v0.10.6
[INFO] [stderr]     Checking rustix v0.38.44
[INFO] [stderr]     Checking signal-hook-mio v0.2.5
[INFO] [stderr]     Checking event-listener v5.4.1
[INFO] [stderr]     Checking serde_spanned v0.6.9
[INFO] [stderr]     Checking toml_datetime v0.6.11
[INFO] [stderr]    Compiling strum_macros v0.26.4
[INFO] [stderr]    Compiling serde_repr v0.1.20
[INFO] [stderr]    Compiling async-trait v0.1.89
[INFO] [stderr]     Checking async-executor v1.13.3
[INFO] [stderr]    Compiling proc-macro-crate v3.4.0
[INFO] [stderr]     Checking event-listener-strategy v0.5.4
[INFO] [stderr]     Checking async-channel v2.5.0
[INFO] [stderr]     Checking async-lock v3.4.2
[INFO] [stderr]     Checking async-broadcast v0.7.2
[INFO] [stderr]     Checking blocking v1.6.2
[INFO] [stderr]     Checking xdg-home v1.3.0
[INFO] [stderr]     Checking ordered-stream v0.2.0
[INFO] [stderr]     Checking winnow v0.7.14
[INFO] [stderr]    Compiling libmpv2 v4.1.0
[INFO] [stderr]     Checking clap_lex v0.7.7
[INFO] [stderr]    Compiling openssl-sys v0.9.111
[INFO] [stderr]     Checking unicode-truncate v1.1.0
[INFO] [stderr]     Checking crossterm v0.28.1
[INFO] [stderr]    Compiling zvariant_derive v4.2.0
[INFO] [stderr]    Compiling zbus_macros v4.4.0
[INFO] [stderr]     Checking async-fs v2.2.0
[INFO] [stderr]     Checking clap_builder v4.5.54
[INFO] [stderr]     Checking url v2.5.8
[INFO] [stderr]     Checking regex-automata v0.4.13
[INFO] [stderr]     Checking compact_str v0.8.1
[INFO] [stderr]     Checking serde_json v1.0.149
[INFO] [stderr]     Checking serde_urlencoded v0.7.1
[INFO] [stderr]    Compiling openssl v0.10.75
[INFO] [stderr]    Compiling clap_derive v4.5.49
[INFO] [stderr]    Compiling trait-variant v0.1.2
[INFO] [stderr]     Checking strum v0.26.3
[INFO] [stderr]     Checking rtoolbox v0.0.3
[INFO] [stderr]     Checking rpassword v7.4.0
[INFO] [stderr]     Checking toml_edit v0.22.27
[INFO] [stderr]     Checking directories v5.0.1
[INFO] [stderr]     Checking getrandom v0.3.4
[INFO] [stderr]     Checking zvariant v4.2.0
[INFO] [stderr]     Checking keyring v3.6.3
[INFO] [stderr]    Compiling darling_macro v0.23.0
[INFO] [stderr]    Compiling darling v0.23.0
[INFO] [stderr]     Checking matchers v0.2.0
[INFO] [stderr]     Checking tracing-subscriber v0.3.22
[INFO] [stderr]     Checking ratatui v0.29.0
[INFO] [stderr]     Checking ppv-lite86 v0.2.21
[INFO] [stderr]     Checking polling v3.11.0
[INFO] [stderr]     Checking tempfile v3.24.0
[INFO] [stderr]     Checking futures-executor v0.3.31
[INFO] [stderr]     Checking futures v0.3.31
[INFO] [stderr]     Checking clap v4.5.54
[INFO] [stderr]     Checking rand_chacha v0.3.1
[INFO] [stderr]     Checking rand v0.8.5
[INFO] [stderr]     Checking toml v0.8.23
[INFO] [stderr]     Checking tokio-util v0.7.18
[INFO] [stderr]     Checking tower v0.5.3
[INFO] [stderr]     Checking tokio-stream v0.1.18
[INFO] [stderr]     Checking zbus_names v3.0.0
[INFO] [stderr]     Checking tokio-test v0.4.5
[INFO] [stderr]     Checking tower-http v0.6.8
[INFO] [stderr]     Checking h2 v0.4.13
[INFO] [stderr]     Checking zbus v4.4.0
[INFO] [stderr]     Checking tokio-native-tls v0.3.1
[INFO] [stderr]     Checking hyper v1.8.1
[INFO] [stderr]     Checking hyper-util v0.1.19
[INFO] [stderr]     Checking hyper-tls v0.6.0
[INFO] [stderr]     Checking reqwest v0.12.28
[INFO] [stderr]     Checking mpris-server v0.8.1
[INFO] [stderr]     Checking abs-tui v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused imports: `TokenStore`, `delete_token`, `get_token`, `has_token`, and `store_token`
[INFO] [stdout]   --> src/api/mod.rs:10:23
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub use credentials::{delete_token, get_token, has_token, store_token, TokenStore, FileStore};
[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: `crate::ui::DetailsWidget`
[INFO] [stdout]  --> src/tui.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use crate::ui::DetailsWidget;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `self`
[INFO] [stdout]  --> src/tui.rs:9:13
[INFO] [stdout]   |
[INFO] [stdout] 9 |     event::{self, Event as CrosstermEvent, EventStream, KeyEventKind},
[INFO] [stdout]   |             ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `MediaProgress`
[INFO] [stdout]  --> src/ui/details.rs:3:31
[INFO] [stdout]   |
[INFO] [stdout] 3 | use crate::api::{LibraryItem, MediaProgress, PodcastEpisode};
[INFO] [stdout]   |                               ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `StatusFilter`
[INFO] [stdout]   --> src/ui/mod.rs:14:34
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub use library::{LibraryWidget, StatusFilter};
[INFO] [stdout]    |                                  ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::fs`
[INFO] [stdout]    --> src/api/credentials.rs:182:9
[INFO] [stdout]     |
[INFO] [stdout] 182 |     use std::fs;
[INFO] [stdout]     |         ^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `TokenStore`, `delete_token`, `get_token`, `has_token`, and `store_token`
[INFO] [stdout]   --> src/api/mod.rs:10:23
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub use credentials::{delete_token, get_token, has_token, store_token, TokenStore, FileStore};
[INFO] [stdout]    |                       ^^^^^^^^^^^^  ^^^^^^^^^  ^^^^^^^^^  ^^^^^^^^^^^  ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::ui::DetailsWidget`
[INFO] [stdout]  --> src/tui.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use crate::ui::DetailsWidget;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `self`
[INFO] [stdout]  --> src/tui.rs:9:13
[INFO] [stdout]   |
[INFO] [stdout] 9 |     event::{self, Event as CrosstermEvent, EventStream, KeyEventKind},
[INFO] [stdout]   |             ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `StatusFilter`
[INFO] [stdout]   --> src/ui/mod.rs:14:34
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub use library::{LibraryWidget, StatusFilter};
[INFO] [stdout]    |                                  ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `media_progress` is never used
[INFO] [stdout]    --> src/api/client.rs:147:18
[INFO] [stdout]     |
[INFO] [stdout]  15 | impl Client {
[INFO] [stdout]     | ----------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 147 |     pub async fn media_progress(&self, item_id: &str) -> Result<Option<MediaProgress>> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `SERVICE_NAME` is never used
[INFO] [stdout]  --> src/api/credentials.rs:9:7
[INFO] [stdout]   |
[INFO] [stdout] 9 | const SERVICE_NAME: &str = "abs-tui";
[INFO] [stdout]   |       ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `delete` and `has` are never used
[INFO] [stdout]   --> src/api/credentials.rs:15:8
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub trait TokenStore {
[INFO] [stdout]    |           ---------- methods in this trait
[INFO] [stdout] ...
[INFO] [stdout] 15 |     fn delete(&self, server_url: &str) -> Result<()>;
[INFO] [stdout]    |        ^^^^^^
[INFO] [stdout] 16 |     fn has(&self, server_url: &str) -> Result<bool> {
[INFO] [stdout]    |        ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `KeyringStore` is never constructed
[INFO] [stdout]   --> src/api/credentials.rs:22:12
[INFO] [stdout]    |
[INFO] [stdout] 22 | pub struct KeyringStore;
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `with_path` is never used
[INFO] [stdout]   --> src/api/credentials.rs:68:12
[INFO] [stdout]    |
[INFO] [stdout] 60 | impl FileStore {
[INFO] [stdout]    | -------------- associated function in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 68 |     pub fn with_path(path: PathBuf) -> Self {
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `AutoStore` is never constructed
[INFO] [stdout]    --> src/api/credentials.rs:111:12
[INFO] [stdout]     |
[INFO] [stdout] 111 | pub struct AutoStore {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]    --> src/api/credentials.rs:118:12
[INFO] [stdout]     |
[INFO] [stdout] 117 | impl AutoStore {
[INFO] [stdout]     | -------------- associated function in this implementation
[INFO] [stdout] 118 |     pub fn new() -> Result<Self> {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `store_token` is never used
[INFO] [stdout]    --> src/api/credentials.rs:163:8
[INFO] [stdout]     |
[INFO] [stdout] 163 | pub fn store_token(server_url: &str, token: &str) -> Result<()> {
[INFO] [stdout]     |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_token` is never used
[INFO] [stdout]    --> src/api/credentials.rs:167:8
[INFO] [stdout]     |
[INFO] [stdout] 167 | pub fn get_token(server_url: &str) -> Result<Option<String>> {
[INFO] [stdout]     |        ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `delete_token` is never used
[INFO] [stdout]    --> src/api/credentials.rs:171:8
[INFO] [stdout]     |
[INFO] [stdout] 171 | pub fn delete_token(server_url: &str) -> Result<()> {
[INFO] [stdout]     |        ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `has_token` is never used
[INFO] [stdout]    --> src/api/credentials.rs:175:8
[INFO] [stdout]     |
[INFO] [stdout] 175 | pub fn has_token(server_url: &str) -> Result<bool> {
[INFO] [stdout]     |        ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `is_selected_downloaded` is never used
[INFO] [stdout]     --> src/app.rs:1071:12
[INFO] [stdout]      |
[INFO] [stdout]   84 | impl App {
[INFO] [stdout]      | -------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 1071 |     pub fn is_selected_downloaded(&self) -> bool {
[INFO] [stdout]      |            ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `DownloadStatus` is never used
[INFO] [stdout]   --> src/downloads.rs:40:10
[INFO] [stdout]    |
[INFO] [stdout] 40 | pub enum DownloadStatus {
[INFO] [stdout]    |          ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `status`, `total_size`, and `base_dir` are never used
[INFO] [stdout]    --> src/downloads.rs:129:12
[INFO] [stdout]     |
[INFO] [stdout]  61 | impl DownloadManager {
[INFO] [stdout]     | -------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 129 |     pub fn status(&self, item_id: &str, episode_id: Option<&str>) -> DownloadStatus {
[INFO] [stdout]     |            ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 201 |     pub fn total_size(&self) -> u64 {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 206 |     pub fn base_dir(&self) -> &PathBuf {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `download_file` is never used
[INFO] [stdout]    --> src/downloads.rs:213:14
[INFO] [stdout]     |
[INFO] [stdout] 213 | pub async fn download_file(
[INFO] [stdout]     |              ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `Quit` and `Player` are never constructed
[INFO] [stdout]   --> src/event.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout]  8 | pub enum Event {
[INFO] [stdout]    |          ----- variants in this enum
[INFO] [stdout]  9 |     /// Quit the application
[INFO] [stdout] 10 |     Quit,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 14 |     Player(PlayerEvent),
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Event` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `item_id` and `episode_id` are never read
[INFO] [stdout]   --> src/event.rs:48:9
[INFO] [stdout]    |
[INFO] [stdout] 47 |     Failed {
[INFO] [stdout]    |     ------ fields in this variant
[INFO] [stdout] 48 |         item_id: String,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout] 49 |         episode_id: Option<String>,
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `DownloadEvent` 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 variants are never constructed
[INFO] [stdout]   --> src/player/mod.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub enum PlayerEvent {
[INFO] [stdout]    |          ----------- variants in this enum
[INFO] [stdout] 12 |     /// Playback started
[INFO] [stdout] 13 |     Playing,
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout] 14 |     /// Playback paused
[INFO] [stdout] 15 |     Paused,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] 16 |     /// Playback stopped
[INFO] [stdout] 17 |     Stopped,
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout] 18 |     /// Position changed (in seconds)
[INFO] [stdout] 19 |     PositionChanged(f64),
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 20 |     /// Duration changed (in seconds)
[INFO] [stdout] 21 |     DurationChanged(f64),
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 22 |     /// Chapter changed
[INFO] [stdout] 23 |     ChapterChanged(u32),
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 24 |     /// End of file reached
[INFO] [stdout] 25 |     EndOfFile,
[INFO] [stdout]    |     ^^^^^^^^^
[INFO] [stdout] 26 |     /// Error occurred
[INFO] [stdout] 27 |     Error(String),
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `PlayerEvent` 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: methods `album` and `art_url` are never used
[INFO] [stdout]   --> src/player/mpris.rs:65:12
[INFO] [stdout]    |
[INFO] [stdout] 52 | impl Metadata {
[INFO] [stdout]    | ------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 65 |     pub fn album(mut self, album: impl Into<String>) -> Self {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 70 |     pub fn art_url(mut self, url: impl Into<String>) -> Self {
[INFO] [stdout]    |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `MprisController` is never constructed
[INFO] [stdout]    --> src/player/mpris.rs:294:12
[INFO] [stdout]     |
[INFO] [stdout] 294 | pub struct MprisController;
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `play_url` is never used
[INFO] [stdout]   --> src/player/mpv.rs:74:12
[INFO] [stdout]    |
[INFO] [stdout] 22 | impl Player {
[INFO] [stdout]    | ----------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 74 |     pub fn play_url(&mut self, url: &str) -> Result<()> {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `stop_session`, `clear_session`, `session_id`, and `item_id` are never used
[INFO] [stdout]    --> src/progress.rs:45:12
[INFO] [stdout]     |
[INFO] [stdout]  22 | impl ProgressTracker {
[INFO] [stdout]     | -------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  45 |     pub fn stop_session(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  53 |     pub fn clear_session(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  99 |     pub fn session_id(&self) -> Option<&str> {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 104 |     pub fn item_id(&self) -> Option<&str> {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `push_front`, `peek`, `clear`, `items`, and `remove` are never used
[INFO] [stdout]   --> src/queue.rs:34:12
[INFO] [stdout]    |
[INFO] [stdout] 20 | impl PlaybackQueue {
[INFO] [stdout]    | ------------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 34 |     pub fn push_front(&mut self, item: QueueItem) {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 44 |     pub fn peek(&self) -> Option<&QueueItem> {
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 59 |     pub fn clear(&mut self) {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 64 |     pub fn items(&self) -> impl Iterator<Item = &QueueItem> {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 69 |     pub fn remove(&mut self, index: usize) -> Option<QueueItem> {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `TerminalPrompter` is never constructed
[INFO] [stdout]   --> src/startup.rs:60:12
[INFO] [stdout]    |
[INFO] [stdout] 60 | pub struct TerminalPrompter;
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `Widget` is never used
[INFO] [stdout]   --> src/ui/mod.rs:20:11
[INFO] [stdout]    |
[INFO] [stdout] 20 | pub trait Widget {
[INFO] [stdout]    |           ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `reset_navigation` and `current_chapter` are never used
[INFO] [stdout]   --> src/ui/chapters.rs:46:12
[INFO] [stdout]    |
[INFO] [stdout] 21 | impl ChaptersWidget {
[INFO] [stdout]    | ------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 46 |     pub fn reset_navigation(&mut self) {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 64 |     pub fn current_chapter(&self) -> Option<&Chapter> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `selected_index` and `is_empty` are never used
[INFO] [stdout]   --> src/ui/episodes.rs:87:12
[INFO] [stdout]    |
[INFO] [stdout] 25 | impl EpisodesWidget {
[INFO] [stdout]    | ------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 87 |     pub fn selected_index(&self) -> Option<usize> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 97 |     pub fn is_empty(&self) -> bool {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `is_downloaded`, `is_empty`, and `status_filter` are never used
[INFO] [stdout]    --> src/ui/library.rs:97:12
[INFO] [stdout]     |
[INFO] [stdout]  79 | impl LibraryWidget {
[INFO] [stdout]     | ------------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  97 |     pub fn is_downloaded(&self, item_id: &str) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 109 |     pub fn is_empty(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 141 |     pub fn status_filter(&self) -> StatusFilter {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `set_chapter` is never used
[INFO] [stdout]   --> src/ui/player.rs:41:12
[INFO] [stdout]    |
[INFO] [stdout] 23 | impl PlayerWidget {
[INFO] [stdout]    | ----------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 41 |     pub fn set_chapter(&mut self, chapter: Option<String>) {
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `media_progress` is never used
[INFO] [stdout]    --> src/api/client.rs:147:18
[INFO] [stdout]     |
[INFO] [stdout]  15 | impl Client {
[INFO] [stdout]     | ----------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 147 |     pub async fn media_progress(&self, item_id: &str) -> Result<Option<MediaProgress>> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `AutoStore` is never constructed
[INFO] [stdout]    --> src/api/credentials.rs:111:12
[INFO] [stdout]     |
[INFO] [stdout] 111 | pub struct AutoStore {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]    --> src/api/credentials.rs:118:12
[INFO] [stdout]     |
[INFO] [stdout] 117 | impl AutoStore {
[INFO] [stdout]     | -------------- associated function in this implementation
[INFO] [stdout] 118 |     pub fn new() -> Result<Self> {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `store_token` is never used
[INFO] [stdout]    --> src/api/credentials.rs:163:8
[INFO] [stdout]     |
[INFO] [stdout] 163 | pub fn store_token(server_url: &str, token: &str) -> Result<()> {
[INFO] [stdout]     |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_token` is never used
[INFO] [stdout]    --> src/api/credentials.rs:167:8
[INFO] [stdout]     |
[INFO] [stdout] 167 | pub fn get_token(server_url: &str) -> Result<Option<String>> {
[INFO] [stdout]     |        ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `delete_token` is never used
[INFO] [stdout]    --> src/api/credentials.rs:171:8
[INFO] [stdout]     |
[INFO] [stdout] 171 | pub fn delete_token(server_url: &str) -> Result<()> {
[INFO] [stdout]     |        ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `has_token` is never used
[INFO] [stdout]    --> src/api/credentials.rs:175:8
[INFO] [stdout]     |
[INFO] [stdout] 175 | pub fn has_token(server_url: &str) -> Result<bool> {
[INFO] [stdout]     |        ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `is_selected_downloaded` is never used
[INFO] [stdout]     --> src/app.rs:1071:12
[INFO] [stdout]      |
[INFO] [stdout]   84 | impl App {
[INFO] [stdout]      | -------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 1071 |     pub fn is_selected_downloaded(&self) -> bool {
[INFO] [stdout]      |            ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `0` is never read
[INFO] [stdout]   --> src/downloads.rs:46:16
[INFO] [stdout]    |
[INFO] [stdout] 46 |     Downloaded(PathBuf),
[INFO] [stdout]    |     ---------- ^^^^^^^
[INFO] [stdout]    |     |
[INFO] [stdout]    |     field in this variant
[INFO] [stdout]    |
[INFO] [stdout]    = note: `DownloadStatus` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] help: consider changing the field to be of unit type to suppress this warning while preserving the field numbering, or remove the field
[INFO] [stdout]    |
[INFO] [stdout] 46 -     Downloaded(PathBuf),
[INFO] [stdout] 46 +     Downloaded(()),
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `Downloading` and `Failed` are never constructed
[INFO] [stdout]   --> src/downloads.rs:44:5
[INFO] [stdout]    |
[INFO] [stdout] 40 | pub enum DownloadStatus {
[INFO] [stdout]    |          -------------- variants in this enum
[INFO] [stdout] ...
[INFO] [stdout] 44 |     Downloading(f64),
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 48 |     Failed(String),
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `DownloadStatus` 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 `base_dir` is never used
[INFO] [stdout]    --> src/downloads.rs:206:12
[INFO] [stdout]     |
[INFO] [stdout]  61 | impl DownloadManager {
[INFO] [stdout]     | -------------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 206 |     pub fn base_dir(&self) -> &PathBuf {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `download_file` is never used
[INFO] [stdout]    --> src/downloads.rs:213:14
[INFO] [stdout]     |
[INFO] [stdout] 213 | pub async fn download_file(
[INFO] [stdout]     |              ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `Quit` and `Player` are never constructed
[INFO] [stdout]   --> src/event.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout]  8 | pub enum Event {
[INFO] [stdout]    |          ----- variants in this enum
[INFO] [stdout]  9 |     /// Quit the application
[INFO] [stdout] 10 |     Quit,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 14 |     Player(PlayerEvent),
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Event` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `item_id` and `episode_id` are never read
[INFO] [stdout]   --> src/event.rs:48:9
[INFO] [stdout]    |
[INFO] [stdout] 47 |     Failed {
[INFO] [stdout]    |     ------ fields in this variant
[INFO] [stdout] 48 |         item_id: String,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout] 49 |         episode_id: Option<String>,
[INFO] [stdout]    |         ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `DownloadEvent` 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 variants are never constructed
[INFO] [stdout]   --> src/player/mod.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub enum PlayerEvent {
[INFO] [stdout]    |          ----------- variants in this enum
[INFO] [stdout] 12 |     /// Playback started
[INFO] [stdout] 13 |     Playing,
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout] 14 |     /// Playback paused
[INFO] [stdout] 15 |     Paused,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout] 16 |     /// Playback stopped
[INFO] [stdout] 17 |     Stopped,
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout] 18 |     /// Position changed (in seconds)
[INFO] [stdout] 19 |     PositionChanged(f64),
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 20 |     /// Duration changed (in seconds)
[INFO] [stdout] 21 |     DurationChanged(f64),
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] 22 |     /// Chapter changed
[INFO] [stdout] 23 |     ChapterChanged(u32),
[INFO] [stdout]    |     ^^^^^^^^^^^^^^
[INFO] [stdout] 24 |     /// End of file reached
[INFO] [stdout] 25 |     EndOfFile,
[INFO] [stdout]    |     ^^^^^^^^^
[INFO] [stdout] 26 |     /// Error occurred
[INFO] [stdout] 27 |     Error(String),
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `PlayerEvent` 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 `art_url` is never used
[INFO] [stdout]   --> src/player/mpris.rs:70:12
[INFO] [stdout]    |
[INFO] [stdout] 52 | impl Metadata {
[INFO] [stdout]    | ------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 70 |     pub fn art_url(mut self, url: impl Into<String>) -> Self {
[INFO] [stdout]    |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `MprisController` is never constructed
[INFO] [stdout]    --> src/player/mpris.rs:294:12
[INFO] [stdout]     |
[INFO] [stdout] 294 | pub struct MprisController;
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `items` is never used
[INFO] [stdout]   --> src/queue.rs:64:12
[INFO] [stdout]    |
[INFO] [stdout] 20 | impl PlaybackQueue {
[INFO] [stdout]    | ------------------ method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 64 |     pub fn items(&self) -> impl Iterator<Item = &QueueItem> {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `TerminalPrompter` is never constructed
[INFO] [stdout]   --> src/startup.rs:60:12
[INFO] [stdout]    |
[INFO] [stdout] 60 | pub struct TerminalPrompter;
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `Widget` is never used
[INFO] [stdout]   --> src/ui/mod.rs:20:11
[INFO] [stdout]    |
[INFO] [stdout] 20 | pub trait Widget {
[INFO] [stdout]    |           ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `is_downloaded` is never used
[INFO] [stdout]   --> src/ui/library.rs:97:12
[INFO] [stdout]    |
[INFO] [stdout] 79 | impl LibraryWidget {
[INFO] [stdout]    | ------------------ method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 97 |     pub fn is_downloaded(&self, item_id: &str) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `set_chapter` is never used
[INFO] [stdout]   --> src/ui/player.rs:41:12
[INFO] [stdout]    |
[INFO] [stdout] 23 | impl PlayerWidget {
[INFO] [stdout]    | ----------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 41 |     pub fn set_chapter(&mut self, chapter: Option<String>) {
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 49.24s
[INFO] running `Command { std: "docker" "inspect" "31c864000ceeb8afe5e7d118b37dd7eb3e8cccc3c63a678a86b7f0b15f4f0c61", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "31c864000ceeb8afe5e7d118b37dd7eb3e8cccc3c63a678a86b7f0b15f4f0c61", kill_on_drop: false }`
[INFO] [stdout] 31c864000ceeb8afe5e7d118b37dd7eb3e8cccc3c63a678a86b7f0b15f4f0c61
