[INFO] cloning repository https://github.com/stibiums/terminator_task_manager
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/stibiums/terminator_task_manager" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fstibiums%2Fterminator_task_manager", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fstibiums%2Fterminator_task_manager'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 4b558832df52b9dfebe39edcd32d73f41bfbc505
[INFO] checking stibiums/terminator_task_manager against master#377656d3dd3f9c23a9c8713e163f4365a5261a84 for pr-146470-3
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fstibiums%2Fterminator_task_manager" "/workspace/builds/worker-3-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-3-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/stibiums/terminator_task_manager
[INFO] finished tweaking git repo https://github.com/stibiums/terminator_task_manager
[INFO] tweaked toml for git repo https://github.com/stibiums/terminator_task_manager written to /workspace/builds/worker-3-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/stibiums/terminator_task_manager on toolchain 377656d3dd3f9c23a9c8713e163f4365a5261a84
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+377656d3dd3f9c23a9c8713e163f4365a5261a84" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/stibiums/terminator_task_manager 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" "+377656d3dd3f9c23a9c8713e163f4365a5261a84" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded mac-notification-sys v0.6.6
[INFO] [stderr]   Downloaded async-process v2.5.0
[INFO] [stderr]   Downloaded async-signal v0.2.13
[INFO] [stderr]   Downloaded tauri-winrt-notification v0.7.2
[INFO] [stderr]   Downloaded interprocess v2.2.3
[INFO] [stderr]   Downloaded clap v4.5.49
[INFO] [stderr]   Downloaded async-io v2.6.0
[INFO] [stderr]   Downloaded widestring v1.2.1
[INFO] [stderr]   Downloaded notify-rust v4.11.7
[INFO] [stderr]   Downloaded clap_builder v4.5.49
[INFO] [stderr]   Downloaded ratatui v0.28.1
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:845e597a41426bbf2703be69acdb67d10b6de511142d05cba7bbe119c898b2c7" "/opt/rustwide/cargo-home/bin/cargo" "+377656d3dd3f9c23a9c8713e163f4365a5261a84" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 2f26cee7e7208880678a6393a2212a5060d5c7f22b8c25ccc1d26e33046a5331
[INFO] running `Command { std: "docker" "start" "-a" "2f26cee7e7208880678a6393a2212a5060d5c7f22b8c25ccc1d26e33046a5331", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "2f26cee7e7208880678a6393a2212a5060d5c7f22b8c25ccc1d26e33046a5331", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "2f26cee7e7208880678a6393a2212a5060d5c7f22b8c25ccc1d26e33046a5331", kill_on_drop: false }`
[INFO] [stdout] 2f26cee7e7208880678a6393a2212a5060d5c7f22b8c25ccc1d26e33046a5331
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-3-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:845e597a41426bbf2703be69acdb67d10b6de511142d05cba7bbe119c898b2c7" "/opt/rustwide/cargo-home/bin/cargo" "+377656d3dd3f9c23a9c8713e163f4365a5261a84" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] d2e230eb7811177366540442f38e1fe8ad3e25ef833e8425cc22fa78d0f6fa1e
[INFO] running `Command { std: "docker" "start" "-a" "d2e230eb7811177366540442f38e1fe8ad3e25ef833e8425cc22fa78d0f6fa1e", kill_on_drop: false }`
[INFO] [stderr]    Compiling proc-macro2 v1.0.101
[INFO] [stderr]    Compiling crossbeam-utils v0.8.21
[INFO] [stderr]    Compiling winnow v0.7.13
[INFO] [stderr]    Compiling quote v1.0.41
[INFO] [stderr]    Compiling hashbrown v0.16.0
[INFO] [stderr]    Compiling toml_datetime v0.7.3
[INFO] [stderr]    Compiling rustix v1.1.2
[INFO] [stderr]     Checking linux-raw-sys v0.11.0
[INFO] [stderr]    Compiling serde_core v1.0.228
[INFO] [stderr]     Checking futures-lite v2.6.1
[INFO] [stderr]    Compiling async-io v2.6.0
[INFO] [stderr]    Compiling zerocopy v0.8.27
[INFO] [stderr]     Checking signal-hook-registry v1.4.6
[INFO] [stderr]    Compiling memoffset v0.9.1
[INFO] [stderr]     Checking async-task v4.7.1
[INFO] [stderr]    Compiling endi v1.1.0
[INFO] [stderr]    Compiling nix v0.30.1
[INFO] [stderr]     Checking parking_lot_core v0.9.12
[INFO] [stderr]     Checking mio v1.0.4
[INFO] [stderr]    Compiling libsqlite3-sys v0.30.1
[INFO] [stderr]     Checking piper v0.2.4
[INFO] [stderr]     Checking syn v2.0.106
[INFO] [stderr]     Checking parking_lot v0.12.5
[INFO] [stderr]     Checking signal-hook v0.3.18
[INFO] [stderr]    Compiling indexmap v2.12.0
[INFO] [stderr]     Checking regex-automata v0.4.13
[INFO] [stderr]     Checking hashbrown v0.15.5
[INFO] [stderr]     Checking concurrent-queue v2.5.0
[INFO] [stderr]     Checking event-listener v5.4.1
[INFO] [stderr]     Checking signal-hook-mio v0.2.4
[INFO] [stderr]     Checking rustix v0.38.44
[INFO] [stderr]     Checking async-executor v1.13.3
[INFO] [stderr]     Checking event-listener-strategy v0.5.4
[INFO] [stderr]     Checking castaway v0.2.4
[INFO] [stderr]     Checking ordered-stream v0.2.0
[INFO] [stderr]     Checking clap_lex v0.7.6
[INFO] [stderr]     Checking async-channel v2.5.0
[INFO] [stderr]     Checking async-lock v3.4.1
[INFO] [stderr]     Checking async-broadcast v0.7.2
[INFO] [stderr]     Checking blocking v1.6.2
[INFO] [stderr]     Checking toml_write v0.1.2
[INFO] [stderr]     Checking clap_builder v4.5.49
[INFO] [stderr]     Checking dirs-sys v0.4.1
[INFO] [stderr]     Checking compact_str v0.8.1
[INFO] [stderr]     Checking lru v0.12.5
[INFO] [stderr]     Checking tracing-log v0.2.0
[INFO] [stderr]     Checking socket2 v0.6.1
[INFO] [stderr]     Checking thread_local v1.1.9
[INFO] [stderr]     Checking crossterm v0.28.1
[INFO] [stderr]     Checking nu-ansi-term v0.50.3
[INFO] [stderr]     Checking fallible-iterator v0.3.0
[INFO] [stderr]    Compiling doctest-file v1.0.0
[INFO] [stderr]    Compiling getrandom v0.3.4
[INFO] [stderr]    Compiling toml_parser v1.0.4
[INFO] [stderr]     Checking ahash v0.8.12
[INFO] [stderr]     Checking fallible-streaming-iterator v0.1.9
[INFO] [stderr]     Checking serde_json v1.0.145
[INFO] [stderr]     Checking directories v5.0.1
[INFO] [stderr]     Checking hashbrown v0.14.5
[INFO] [stderr]     Checking interprocess v2.2.3
[INFO] [stderr]     Checking matchers v0.2.0
[INFO] [stderr]    Compiling toml_edit v0.23.7
[INFO] [stderr]     Checking hashlink v0.9.1
[INFO] [stderr]    Compiling proc-macro-crate v3.4.0
[INFO] [stderr]     Checking polling v3.11.0
[INFO] [stderr]     Checking tempfile v3.23.0
[INFO] [stderr]     Checking async-signal v0.2.13
[INFO] [stderr]     Checking async-process v2.5.0
[INFO] [stderr]    Compiling darling_core v0.20.11
[INFO] [stderr]    Compiling serde_derive v1.0.228
[INFO] [stderr]    Compiling enumflags2_derive v0.7.12
[INFO] [stderr]    Compiling tracing-attributes v0.1.30
[INFO] [stderr]    Compiling serde_repr v0.1.20
[INFO] [stderr]    Compiling async-trait v0.1.89
[INFO] [stderr]    Compiling strum_macros v0.26.4
[INFO] [stderr]    Compiling tokio-macros v2.6.0
[INFO] [stderr]    Compiling thiserror-impl v1.0.69
[INFO] [stderr]    Compiling clap_derive v4.5.49
[INFO] [stderr]     Checking tokio v1.48.0
[INFO] [stderr]     Checking tracing v0.1.41
[INFO] [stderr]     Checking thiserror v1.0.69
[INFO] [stderr]     Checking tracing-subscriber v0.3.20
[INFO] [stderr]    Compiling darling_macro v0.20.11
[INFO] [stderr]    Compiling darling v0.20.11
[INFO] [stderr]    Compiling instability v0.3.9
[INFO] [stderr]     Checking clap v4.5.49
[INFO] [stderr]     Checking strum v0.26.3
[INFO] [stderr]     Checking ratatui v0.28.1
[INFO] [stderr]     Checking serde v1.0.228
[INFO] [stderr]     Checking zvariant_utils v3.2.1
[INFO] [stderr]     Checking enumflags2 v0.7.12
[INFO] [stderr]     Checking uuid v1.18.1
[INFO] [stderr]     Checking toml_datetime v0.6.11
[INFO] [stderr]     Checking serde_spanned v0.6.9
[INFO] [stderr]     Checking chrono v0.4.42
[INFO] [stderr]     Checking toml_edit v0.22.27
[INFO] [stderr]    Compiling zvariant_derive v5.8.0
[INFO] [stderr]     Checking rusqlite v0.32.1
[INFO] [stderr]    Compiling zvariant v5.8.0
[INFO] [stderr]     Checking toml v0.8.23
[INFO] [stderr]     Checking zbus_names v4.2.0
[INFO] [stderr]    Compiling zbus_macros v5.12.0
[INFO] [stderr]     Checking zbus v5.12.0
[INFO] [stderr]     Checking notify-rust v4.11.7
[INFO] [stderr]     Checking terminator-task v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `OptionalExtension`
[INFO] [stdout]  --> src/db/mod.rs:3:36
[INFO] [stdout]   |
[INFO] [stdout] 3 | use rusqlite::{params, Connection, OptionalExtension};
[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: `Duration`
[INFO] [stdout]  --> src/pomodoro/mod.rs:1:24
[INFO] [stdout]   |
[INFO] [stdout] 1 | use chrono::{DateTime, Duration, Utc};
[INFO] [stdout]   |                        ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Arc` and `Mutex`
[INFO] [stdout]  --> src/pomodoro/mod.rs:2:17
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::sync::{Arc, Mutex};
[INFO] [stdout]   |                 ^^^  ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Duration as TokioDuration` and `sleep`
[INFO] [stdout]  --> src/pomodoro/mod.rs:3:19
[INFO] [stdout]   |
[INFO] [stdout] 3 | use tokio::time::{sleep, Duration as TokioDuration};
[INFO] [stdout]   |                   ^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::models::PomodoroSession`
[INFO] [stdout]  --> src/pomodoro/mod.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use crate::models::PomodoroSession;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ratatui::widgets::Widget`
[INFO] [stdout]  --> src/ui/task_list.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use ratatui::widgets::Widget;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ratatui::widgets::Widget`
[INFO] [stdout]  --> src/ui/note_list.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use ratatui::widgets::Widget;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ratatui::widgets::Widget`
[INFO] [stdout]  --> src/ui/pomodoro_view.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use ratatui::widgets::Widget;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `task_list::TaskListWidget`
[INFO] [stdout]   --> src/ui/mod.rs:28:9
[INFO] [stdout]    |
[INFO] [stdout] 28 | pub use task_list::TaskListWidget;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `note_list::NoteListWidget`
[INFO] [stdout]   --> src/ui/mod.rs:29:9
[INFO] [stdout]    |
[INFO] [stdout] 29 | pub use note_list::NoteListWidget;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `pomodoro_view::PomodoroWidget`
[INFO] [stdout]   --> src/ui/mod.rs:30:9
[INFO] [stdout]    |
[INFO] [stdout] 30 | pub use pomodoro_view::PomodoroWidget;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Note`
[INFO] [stdout]   --> src/main.rs:14:14
[INFO] [stdout]    |
[INFO] [stdout] 14 | use models::{Note, Task};
[INFO] [stdout]    |              ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `OptionalExtension`
[INFO] [stdout]  --> src/daemon/../db/mod.rs:3:36
[INFO] [stdout]   |
[INFO] [stdout] 3 | use rusqlite::{params, Connection, OptionalExtension};
[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: `Duration`
[INFO] [stdout]  --> src/daemon/../pomodoro/mod.rs:1:24
[INFO] [stdout]   |
[INFO] [stdout] 1 | use chrono::{DateTime, Duration, Utc};
[INFO] [stdout]   |                        ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Arc` and `Mutex`
[INFO] [stdout]  --> src/daemon/../pomodoro/mod.rs:2:17
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::sync::{Arc, Mutex};
[INFO] [stdout]   |                 ^^^  ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Duration as TokioDuration` and `sleep`
[INFO] [stdout]  --> src/daemon/../pomodoro/mod.rs:3:19
[INFO] [stdout]   |
[INFO] [stdout] 3 | use tokio::time::{sleep, Duration as TokioDuration};
[INFO] [stdout]   |                   ^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::models::PomodoroSession`
[INFO] [stdout]  --> src/daemon/../pomodoro/mod.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use crate::models::PomodoroSession;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `OptionalExtension`
[INFO] [stdout]  --> src/daemon/../db/mod.rs:3:36
[INFO] [stdout]   |
[INFO] [stdout] 3 | use rusqlite::{params, Connection, OptionalExtension};
[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: `Duration`
[INFO] [stdout]  --> src/daemon/../pomodoro/mod.rs:1:24
[INFO] [stdout]   |
[INFO] [stdout] 1 | use chrono::{DateTime, Duration, Utc};
[INFO] [stdout]   |                        ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Arc` and `Mutex`
[INFO] [stdout]  --> src/daemon/../pomodoro/mod.rs:2:17
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::sync::{Arc, Mutex};
[INFO] [stdout]   |                 ^^^  ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Duration as TokioDuration` and `sleep`
[INFO] [stdout]  --> src/daemon/../pomodoro/mod.rs:3:19
[INFO] [stdout]   |
[INFO] [stdout] 3 | use tokio::time::{sleep, Duration as TokioDuration};
[INFO] [stdout]   |                   ^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::models::PomodoroSession`
[INFO] [stdout]  --> src/daemon/../pomodoro/mod.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use crate::models::PomodoroSession;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `OptionalExtension`
[INFO] [stdout]  --> src/db/mod.rs:3:36
[INFO] [stdout]   |
[INFO] [stdout] 3 | use rusqlite::{params, Connection, OptionalExtension};
[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: `Duration`
[INFO] [stdout]  --> src/pomodoro/mod.rs:1:24
[INFO] [stdout]   |
[INFO] [stdout] 1 | use chrono::{DateTime, Duration, Utc};
[INFO] [stdout]   |                        ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Arc` and `Mutex`
[INFO] [stdout]  --> src/pomodoro/mod.rs:2:17
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::sync::{Arc, Mutex};
[INFO] [stdout]   |                 ^^^  ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Duration as TokioDuration` and `sleep`
[INFO] [stdout]  --> src/pomodoro/mod.rs:3:19
[INFO] [stdout]   |
[INFO] [stdout] 3 | use tokio::time::{sleep, Duration as TokioDuration};
[INFO] [stdout]   |                   ^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::models::PomodoroSession`
[INFO] [stdout]  --> src/pomodoro/mod.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use crate::models::PomodoroSession;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ratatui::widgets::Widget`
[INFO] [stdout]  --> src/ui/task_list.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use ratatui::widgets::Widget;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ratatui::widgets::Widget`
[INFO] [stdout]  --> src/ui/note_list.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use ratatui::widgets::Widget;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `ratatui::widgets::Widget`
[INFO] [stdout]  --> src/ui/pomodoro_view.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use ratatui::widgets::Widget;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `task_list::TaskListWidget`
[INFO] [stdout]   --> src/ui/mod.rs:28:9
[INFO] [stdout]    |
[INFO] [stdout] 28 | pub use task_list::TaskListWidget;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `note_list::NoteListWidget`
[INFO] [stdout]   --> src/ui/mod.rs:29:9
[INFO] [stdout]    |
[INFO] [stdout] 29 | pub use note_list::NoteListWidget;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `pomodoro_view::PomodoroWidget`
[INFO] [stdout]   --> src/ui/mod.rs:30:9
[INFO] [stdout]    |
[INFO] [stdout] 30 | pub use pomodoro_view::PomodoroWidget;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Note`
[INFO] [stdout]   --> src/main.rs:14:14
[INFO] [stdout]    |
[INFO] [stdout] 14 | use models::{Note, Task};
[INFO] [stdout]    |              ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple methods are never used
[INFO] [stdout]    --> src/daemon/../db/mod.rs:76:12
[INFO] [stdout]     |
[INFO] [stdout]  12 | impl Database {
[INFO] [stdout]     | ------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  76 |     pub fn create_task(&self, task: &Task) -> Result<i64> {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 148 |     pub fn update_task(&self, task: &Task) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 171 |     pub fn delete_task(&self, id: i64) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 180 |     pub fn create_note(&self, note: &Note) -> Result<i64> {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 196 |     pub fn get_all_notes(&self) -> Result<Vec<Note>> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 224 |     pub fn update_note(&self, note: &Note) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 240 |     pub fn delete_note(&self, id: i64) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 249 |     pub fn create_pomodoro(&self, session: &PomodoroSession) -> Result<i64> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 265 |     pub fn complete_pomodoro(&self, id: i64) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 274 |     pub fn get_task_pomodoros(&self, task_id: i64) -> Result<Vec<PomodoroSession>> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 304 |     pub fn get_today_pomodoro_stats(&self) -> Result<(usize, usize)> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 330 |     pub fn get_config(&self, key: &str) -> Result<Option<String>> {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 337 |     pub fn set_config(&self, key: &str, value: &str) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 346 |     pub fn get_pomodoro_config(&self) -> Result<(i32, i32)> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 357 |     pub fn save_pomodoro_config(&self, work_duration: i32, break_duration: i32) -> Result<()> {
[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 `Note` is never constructed
[INFO] [stdout]   --> src/daemon/../models/mod.rs:38:12
[INFO] [stdout]    |
[INFO] [stdout] 38 | pub struct Note {
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PomodoroSession` is never constructed
[INFO] [stdout]   --> src/daemon/../models/mod.rs:49:12
[INFO] [stdout]    |
[INFO] [stdout] 49 | pub struct PomodoroSession {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new` and `is_overdue` are never used
[INFO] [stdout]   --> src/daemon/../models/mod.rs:59:12
[INFO] [stdout]    |
[INFO] [stdout] 58 | impl Task {
[INFO] [stdout]    | --------- associated items in this implementation
[INFO] [stdout] 59 |     pub fn new(title: String) -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 76 |     pub fn is_overdue(&self) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/daemon/../models/mod.rs:86:12
[INFO] [stdout]    |
[INFO] [stdout] 85 | impl Note {
[INFO] [stdout]    | --------- associated function in this implementation
[INFO] [stdout] 86 |     pub fn new(title: String, content: String) -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `send_pomodoro_complete` and `send_notification` are never used
[INFO] [stdout]   --> src/daemon/../notify/mod.rs:24:12
[INFO] [stdout]    |
[INFO] [stdout]  7 | impl NotificationManager {
[INFO] [stdout]    | ------------------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 24 |     pub fn send_pomodoro_complete(&self, is_break: bool) -> Result<()> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 41 |     pub fn send_notification(&self, title: &str, body: &str) -> Result<()> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `NoteManager` is never constructed
[INFO] [stdout]  --> src/daemon/../notes/mod.rs:7:12
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub struct NoteManager;
[INFO] [stdout]   |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `search_notes`, and `notes_by_task` are never used
[INFO] [stdout]   --> src/daemon/../notes/mod.rs:10:12
[INFO] [stdout]    |
[INFO] [stdout]  9 | impl NoteManager {
[INFO] [stdout]    | ---------------- associated items in this implementation
[INFO] [stdout] 10 |     pub fn new() -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 15 |     pub fn search_notes(&self, notes: &[Note], query: &str) -> Vec<Note> {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 28 |     pub fn notes_by_task(&self, notes: &[Note], task_id: i64) -> Vec<Note> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `PomodoroState` is never used
[INFO] [stdout]  --> src/daemon/../pomodoro/mod.rs:9:10
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub enum PomodoroState {
[INFO] [stdout]   |          ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PomodoroTimer` is never constructed
[INFO] [stdout]   --> src/daemon/../pomodoro/mod.rs:18:12
[INFO] [stdout]    |
[INFO] [stdout] 18 | pub struct PomodoroTimer {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> src/daemon/../pomodoro/mod.rs:43:12
[INFO] [stdout]     |
[INFO] [stdout]  42 | impl PomodoroTimer {
[INFO] [stdout]     | ------------------ associated items in this implementation
[INFO] [stdout]  43 |     pub fn new(work_duration: i32, break_duration: i32) -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout]  52 |     pub fn start_work(&mut self, task_id: Option<i64>) {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  60 |     pub fn start_break(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  67 |     pub fn pause(&mut self) {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  74 |     pub fn resume(&mut self) {
[INFO] [stdout]     |            ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  83 |     pub fn stop(&mut self) {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] ...
[INFO] [stdout]  92 |     pub fn tick(&mut self) -> bool {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 106 |     pub fn progress(&self) -> f32 {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 135 |     pub fn format_remaining(&self) -> String {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple methods are never used
[INFO] [stdout]    --> src/daemon/../db/mod.rs:76:12
[INFO] [stdout]     |
[INFO] [stdout]  12 | impl Database {
[INFO] [stdout]     | ------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  76 |     pub fn create_task(&self, task: &Task) -> Result<i64> {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 148 |     pub fn update_task(&self, task: &Task) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 171 |     pub fn delete_task(&self, id: i64) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 180 |     pub fn create_note(&self, note: &Note) -> Result<i64> {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 196 |     pub fn get_all_notes(&self) -> Result<Vec<Note>> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 224 |     pub fn update_note(&self, note: &Note) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 240 |     pub fn delete_note(&self, id: i64) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 249 |     pub fn create_pomodoro(&self, session: &PomodoroSession) -> Result<i64> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 265 |     pub fn complete_pomodoro(&self, id: i64) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 274 |     pub fn get_task_pomodoros(&self, task_id: i64) -> Result<Vec<PomodoroSession>> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 304 |     pub fn get_today_pomodoro_stats(&self) -> Result<(usize, usize)> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 330 |     pub fn get_config(&self, key: &str) -> Result<Option<String>> {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 337 |     pub fn set_config(&self, key: &str, value: &str) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 346 |     pub fn get_pomodoro_config(&self) -> Result<(i32, i32)> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 357 |     pub fn save_pomodoro_config(&self, work_duration: i32, break_duration: i32) -> Result<()> {
[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 `Note` is never constructed
[INFO] [stdout]   --> src/daemon/../models/mod.rs:38:12
[INFO] [stdout]    |
[INFO] [stdout] 38 | pub struct Note {
[INFO] [stdout]    |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PomodoroSession` is never constructed
[INFO] [stdout]   --> src/daemon/../models/mod.rs:49:12
[INFO] [stdout]    |
[INFO] [stdout] 49 | pub struct PomodoroSession {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new` and `is_overdue` are never used
[INFO] [stdout]   --> src/daemon/../models/mod.rs:59:12
[INFO] [stdout]    |
[INFO] [stdout] 58 | impl Task {
[INFO] [stdout]    | --------- associated items in this implementation
[INFO] [stdout] 59 |     pub fn new(title: String) -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 76 |     pub fn is_overdue(&self) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/daemon/../models/mod.rs:86:12
[INFO] [stdout]    |
[INFO] [stdout] 85 | impl Note {
[INFO] [stdout]    | --------- associated function in this implementation
[INFO] [stdout] 86 |     pub fn new(title: String, content: String) -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `send_pomodoro_complete` and `send_notification` are never used
[INFO] [stdout]   --> src/daemon/../notify/mod.rs:24:12
[INFO] [stdout]    |
[INFO] [stdout]  7 | impl NotificationManager {
[INFO] [stdout]    | ------------------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 24 |     pub fn send_pomodoro_complete(&self, is_break: bool) -> Result<()> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 41 |     pub fn send_notification(&self, title: &str, body: &str) -> Result<()> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `NoteManager` is never constructed
[INFO] [stdout]  --> src/daemon/../notes/mod.rs:7:12
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub struct NoteManager;
[INFO] [stdout]   |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `search_notes`, and `notes_by_task` are never used
[INFO] [stdout]   --> src/daemon/../notes/mod.rs:10:12
[INFO] [stdout]    |
[INFO] [stdout]  9 | impl NoteManager {
[INFO] [stdout]    | ---------------- associated items in this implementation
[INFO] [stdout] 10 |     pub fn new() -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 15 |     pub fn search_notes(&self, notes: &[Note], query: &str) -> Vec<Note> {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 28 |     pub fn notes_by_task(&self, notes: &[Note], task_id: i64) -> Vec<Note> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `PomodoroState` is never used
[INFO] [stdout]  --> src/daemon/../pomodoro/mod.rs:9:10
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub enum PomodoroState {
[INFO] [stdout]   |          ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PomodoroTimer` is never constructed
[INFO] [stdout]   --> src/daemon/../pomodoro/mod.rs:18:12
[INFO] [stdout]    |
[INFO] [stdout] 18 | pub struct PomodoroTimer {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> src/daemon/../pomodoro/mod.rs:43:12
[INFO] [stdout]     |
[INFO] [stdout]  42 | impl PomodoroTimer {
[INFO] [stdout]     | ------------------ associated items in this implementation
[INFO] [stdout]  43 |     pub fn new(work_duration: i32, break_duration: i32) -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout]  52 |     pub fn start_work(&mut self, task_id: Option<i64>) {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  60 |     pub fn start_break(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  67 |     pub fn pause(&mut self) {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  74 |     pub fn resume(&mut self) {
[INFO] [stdout]     |            ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  83 |     pub fn stop(&mut self) {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] ...
[INFO] [stdout]  92 |     pub fn tick(&mut self) -> bool {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 106 |     pub fn progress(&self) -> f32 {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 135 |     pub fn format_remaining(&self) -> String {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable pattern
[INFO] [stdout]     --> src/ui/mod.rs:1479:20
[INFO] [stdout]      |
[INFO] [stdout] 1269 |         "wq" | "x" => {
[INFO] [stdout]      |                --- matches all the relevant values
[INFO] [stdout] ...
[INFO] [stdout] 1479 |         "toggle" | "x" => {
[INFO] [stdout]      |                    ^^^ no value can reach this
[INFO] [stdout]      |
[INFO] [stdout]      = note: `#[warn(unreachable_patterns)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable pattern
[INFO] [stdout]     --> src/ui/mod.rs:1479:20
[INFO] [stdout]      |
[INFO] [stdout] 1269 |         "wq" | "x" => {
[INFO] [stdout]      |                --- matches all the relevant values
[INFO] [stdout] ...
[INFO] [stdout] 1479 |         "toggle" | "x" => {
[INFO] [stdout]      |                    ^^^ no value can reach this
[INFO] [stdout]      |
[INFO] [stdout]      = note: `#[warn(unreachable_patterns)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/ui/mod.rs:2772:9
[INFO] [stdout]      |
[INFO] [stdout] 2772 |     let mut timer_display = vec![
[INFO] [stdout]      |         ----^^^^^^^^^^^^^
[INFO] [stdout]      |         |
[INFO] [stdout]      |         help: remove this `mut`
[INFO] [stdout]      |
[INFO] [stdout]      = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]     --> src/ui/mod.rs:2772:9
[INFO] [stdout]      |
[INFO] [stdout] 2772 |     let mut timer_display = vec![
[INFO] [stdout]      |         ----^^^^^^^^^^^^^
[INFO] [stdout]      |         |
[INFO] [stdout]      |         help: remove this `mut`
[INFO] [stdout]      |
[INFO] [stdout]      = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `complete_pomodoro` and `get_task_pomodoros` are never used
[INFO] [stdout]    --> src/db/mod.rs:265:12
[INFO] [stdout]     |
[INFO] [stdout]  12 | impl Database {
[INFO] [stdout]     | ------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 265 |     pub fn complete_pomodoro(&self, id: i64) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 274 |     pub fn get_task_pomodoros(&self, task_id: i64) -> Result<Vec<PomodoroSession>> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `is_overdue` is never used
[INFO] [stdout]   --> src/models/mod.rs:76:12
[INFO] [stdout]    |
[INFO] [stdout] 58 | impl Task {
[INFO] [stdout]    | --------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 76 |     pub fn is_overdue(&self) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `NotificationManager` is never constructed
[INFO] [stdout]  --> src/notify/mod.rs:5:12
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub struct NotificationManager;
[INFO] [stdout]   |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `send_task_reminder`, `send_pomodoro_complete`, and `send_notification` are never used
[INFO] [stdout]   --> src/notify/mod.rs:8:12
[INFO] [stdout]    |
[INFO] [stdout]  7 | impl NotificationManager {
[INFO] [stdout]    | ------------------------ associated items in this implementation
[INFO] [stdout]  8 |     pub fn new() -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 13 |     pub fn send_task_reminder(&self, title: &str, body: &str) -> Result<()> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 24 |     pub fn send_pomodoro_complete(&self, is_break: bool) -> Result<()> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 41 |     pub fn send_notification(&self, title: &str, body: &str) -> Result<()> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `NoteManager` is never constructed
[INFO] [stdout]  --> src/notes/mod.rs:7:12
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub struct NoteManager;
[INFO] [stdout]   |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `search_notes`, and `notes_by_task` are never used
[INFO] [stdout]   --> src/notes/mod.rs:10:12
[INFO] [stdout]    |
[INFO] [stdout]  9 | impl NoteManager {
[INFO] [stdout]    | ---------------- associated items in this implementation
[INFO] [stdout] 10 |     pub fn new() -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 15 |     pub fn search_notes(&self, notes: &[Note], query: &str) -> Vec<Note> {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 28 |     pub fn notes_by_task(&self, notes: &[Note], task_id: i64) -> Vec<Note> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/pomodoro/mod.rs:43:12
[INFO] [stdout]    |
[INFO] [stdout] 42 | impl PomodoroTimer {
[INFO] [stdout]    | ------------------ associated function in this implementation
[INFO] [stdout] 43 |     pub fn new(work_duration: i32, break_duration: i32) -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `CreateTask`, `EditTask`, and `CreateNote` are never constructed
[INFO] [stdout]   --> src/ui/mod.rs:90:5
[INFO] [stdout]    |
[INFO] [stdout] 88 | pub enum DialogType {
[INFO] [stdout]    |          ---------- variants in this enum
[INFO] [stdout] 89 |     None,
[INFO] [stdout] 90 |     CreateTask,
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] 91 |     EditTask,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 92 |     DeleteConfirm,
[INFO] [stdout] 93 |     CreateNote,
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `DialogType` 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 `create_task` and `init_edit_task` are never used
[INFO] [stdout]    --> src/ui/mod.rs:456:12
[INFO] [stdout]     |
[INFO] [stdout] 150 | impl App {
[INFO] [stdout]     | -------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 456 |     pub fn create_task(&mut self) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 510 |     pub fn init_edit_task(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `handle_mouse_event` is never used
[INFO] [stdout]     --> src/ui/mod.rs:2336:4
[INFO] [stdout]      |
[INFO] [stdout] 2336 | fn handle_mouse_event(app: &mut App, mouse: MouseEvent) -> Result<()> {
[INFO] [stdout]      |    ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `TaskListWidget` is never constructed
[INFO] [stdout]  --> src/ui/task_list.rs:6:12
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub struct TaskListWidget;
[INFO] [stdout]   |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `NoteListWidget` is never constructed
[INFO] [stdout]  --> src/ui/note_list.rs:6:12
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub struct NoteListWidget;
[INFO] [stdout]   |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PomodoroWidget` is never constructed
[INFO] [stdout]  --> src/ui/pomodoro_view.rs:6:12
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub struct PomodoroWidget;
[INFO] [stdout]   |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `complete_pomodoro` and `get_task_pomodoros` are never used
[INFO] [stdout]    --> src/db/mod.rs:265:12
[INFO] [stdout]     |
[INFO] [stdout]  12 | impl Database {
[INFO] [stdout]     | ------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 265 |     pub fn complete_pomodoro(&self, id: i64) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 274 |     pub fn get_task_pomodoros(&self, task_id: i64) -> Result<Vec<PomodoroSession>> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `is_overdue` is never used
[INFO] [stdout]   --> src/models/mod.rs:76:12
[INFO] [stdout]    |
[INFO] [stdout] 58 | impl Task {
[INFO] [stdout]    | --------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 76 |     pub fn is_overdue(&self) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `NotificationManager` is never constructed
[INFO] [stdout]  --> src/notify/mod.rs:5:12
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub struct NotificationManager;
[INFO] [stdout]   |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `send_task_reminder`, `send_pomodoro_complete`, and `send_notification` are never used
[INFO] [stdout]   --> src/notify/mod.rs:8:12
[INFO] [stdout]    |
[INFO] [stdout]  7 | impl NotificationManager {
[INFO] [stdout]    | ------------------------ associated items in this implementation
[INFO] [stdout]  8 |     pub fn new() -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 13 |     pub fn send_task_reminder(&self, title: &str, body: &str) -> Result<()> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 24 |     pub fn send_pomodoro_complete(&self, is_break: bool) -> Result<()> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 41 |     pub fn send_notification(&self, title: &str, body: &str) -> Result<()> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `NoteManager` is never constructed
[INFO] [stdout]  --> src/notes/mod.rs:7:12
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub struct NoteManager;
[INFO] [stdout]   |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new`, `search_notes`, and `notes_by_task` are never used
[INFO] [stdout]   --> src/notes/mod.rs:10:12
[INFO] [stdout]    |
[INFO] [stdout]  9 | impl NoteManager {
[INFO] [stdout]    | ---------------- associated items in this implementation
[INFO] [stdout] 10 |     pub fn new() -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 15 |     pub fn search_notes(&self, notes: &[Note], query: &str) -> Vec<Note> {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 28 |     pub fn notes_by_task(&self, notes: &[Note], task_id: i64) -> Vec<Note> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/pomodoro/mod.rs:43:12
[INFO] [stdout]    |
[INFO] [stdout] 42 | impl PomodoroTimer {
[INFO] [stdout]    | ------------------ associated function in this implementation
[INFO] [stdout] 43 |     pub fn new(work_duration: i32, break_duration: i32) -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `CreateTask`, `EditTask`, and `CreateNote` are never constructed
[INFO] [stdout]   --> src/ui/mod.rs:90:5
[INFO] [stdout]    |
[INFO] [stdout] 88 | pub enum DialogType {
[INFO] [stdout]    |          ---------- variants in this enum
[INFO] [stdout] 89 |     None,
[INFO] [stdout] 90 |     CreateTask,
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] 91 |     EditTask,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout] 92 |     DeleteConfirm,
[INFO] [stdout] 93 |     CreateNote,
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `DialogType` 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 `create_task` and `init_edit_task` are never used
[INFO] [stdout]    --> src/ui/mod.rs:456:12
[INFO] [stdout]     |
[INFO] [stdout] 150 | impl App {
[INFO] [stdout]     | -------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 456 |     pub fn create_task(&mut self) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 510 |     pub fn init_edit_task(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `handle_mouse_event` is never used
[INFO] [stdout]     --> src/ui/mod.rs:2336:4
[INFO] [stdout]      |
[INFO] [stdout] 2336 | fn handle_mouse_event(app: &mut App, mouse: MouseEvent) -> Result<()> {
[INFO] [stdout]      |    ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `TaskListWidget` is never constructed
[INFO] [stdout]  --> src/ui/task_list.rs:6:12
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub struct TaskListWidget;
[INFO] [stdout]   |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `NoteListWidget` is never constructed
[INFO] [stdout]  --> src/ui/note_list.rs:6:12
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub struct NoteListWidget;
[INFO] [stdout]   |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `PomodoroWidget` is never constructed
[INFO] [stdout]  --> src/ui/pomodoro_view.rs:6:12
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub struct PomodoroWidget;
[INFO] [stdout]   |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 1m 03s
[INFO] running `Command { std: "docker" "inspect" "d2e230eb7811177366540442f38e1fe8ad3e25ef833e8425cc22fa78d0f6fa1e", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "d2e230eb7811177366540442f38e1fe8ad3e25ef833e8425cc22fa78d0f6fa1e", kill_on_drop: false }`
[INFO] [stdout] d2e230eb7811177366540442f38e1fe8ad3e25ef833e8425cc22fa78d0f6fa1e
