[INFO] cloning repository https://github.com/0x45o/focusdebt
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/0x45o/focusdebt" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2F0x45o%2Ffocusdebt", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2F0x45o%2Ffocusdebt'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] e7c67c43279ca5b0fad66a974dce5344ebcd70f2
[INFO] checking 0x45o/focusdebt against master#32cd9114712a24010b0583624dc52ac302194128 for pr-143717
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2F0x45o%2Ffocusdebt" "/workspace/builds/worker-0-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-0-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/0x45o/focusdebt
[INFO] finished tweaking git repo https://github.com/0x45o/focusdebt
[INFO] tweaked toml for git repo https://github.com/0x45o/focusdebt written to /workspace/builds/worker-0-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/0x45o/focusdebt on toolchain 32cd9114712a24010b0583624dc52ac302194128
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+32cd9114712a24010b0583624dc52ac302194128" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/0x45o/focusdebt 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" "+32cd9114712a24010b0583624dc52ac302194128" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded toml v0.8.23
[INFO] [stderr]   Downloaded toml_write v0.1.2
[INFO] [stderr]   Downloaded fallible-streaming-iterator v0.1.9
[INFO] [stderr]   Downloaded serde_spanned v0.6.9
[INFO] [stderr]   Downloaded rusqlite v0.29.0
[INFO] [stderr]   Downloaded sysinfo v0.30.13
[INFO] [stderr]   Downloaded libsqlite3-sys v0.26.0
[INFO] [stderr]   Downloaded windows v0.52.0
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-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:90999bfc7ae267e83380e433d8e61a7c072ca6729e92edbae886d3423b3a6f4c" "/opt/rustwide/cargo-home/bin/cargo" "+32cd9114712a24010b0583624dc52ac302194128" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 65c0f3699444c2d98aec0c4d098976e4794d51705d2735452a94dd50fb891c2e
[INFO] running `Command { std: "docker" "start" "-a" "65c0f3699444c2d98aec0c4d098976e4794d51705d2735452a94dd50fb891c2e", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "65c0f3699444c2d98aec0c4d098976e4794d51705d2735452a94dd50fb891c2e", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "65c0f3699444c2d98aec0c4d098976e4794d51705d2735452a94dd50fb891c2e", kill_on_drop: false }`
[INFO] [stdout] 65c0f3699444c2d98aec0c4d098976e4794d51705d2735452a94dd50fb891c2e
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-0-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:90999bfc7ae267e83380e433d8e61a7c072ca6729e92edbae886d3423b3a6f4c" "/opt/rustwide/cargo-home/bin/cargo" "+32cd9114712a24010b0583624dc52ac302194128" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 6309ae3c1b5a21143bfb01d083d87fdd44c259e3798b88fddc6550122ea9e743
[INFO] running `Command { std: "docker" "start" "-a" "6309ae3c1b5a21143bfb01d083d87fdd44c259e3798b88fddc6550122ea9e743", kill_on_drop: false }`
[INFO] [stderr]    Compiling proc-macro2 v1.0.95
[INFO] [stderr]    Compiling unicode-ident v1.0.18
[INFO] [stderr]     Checking stable_deref_trait v1.2.0
[INFO] [stderr]    Compiling libc v0.2.174
[INFO] [stderr]     Checking cfg-if v1.0.1
[INFO] [stderr]    Compiling autocfg v1.5.0
[INFO] [stderr]    Compiling serde v1.0.219
[INFO] [stderr]     Checking smallvec v1.15.1
[INFO] [stderr]     Checking litemap v0.8.0
[INFO] [stderr]     Checking writeable v0.6.1
[INFO] [stderr]    Compiling version_check v0.9.5
[INFO] [stderr]    Compiling icu_normalizer_data v2.0.0
[INFO] [stderr]    Compiling zerocopy v0.8.26
[INFO] [stderr]    Compiling icu_properties_data v2.0.1
[INFO] [stderr]     Checking once_cell v1.21.3
[INFO] [stderr]    Compiling cc v1.2.27
[INFO] [stderr]    Compiling parking_lot_core v0.9.11
[INFO] [stderr]    Compiling pkg-config v0.3.32
[INFO] [stderr]     Checking memchr v2.7.5
[INFO] [stderr]    Compiling vcpkg v0.2.15
[INFO] [stderr]     Checking anstyle-parse v0.2.7
[INFO] [stderr]     Checking anstyle-query v1.1.3
[INFO] [stderr]     Checking hashbrown v0.15.4
[INFO] [stderr]     Checking anstyle v1.0.11
[INFO] [stderr]     Checking colorchoice v1.0.4
[INFO] [stderr]     Checking allocator-api2 v0.2.21
[INFO] [stderr]    Compiling ahash v0.8.12
[INFO] [stderr]     Checking equivalent v1.0.2
[INFO] [stderr]     Checking clap_lex v0.7.5
[INFO] [stderr]     Checking toml_write v0.1.2
[INFO] [stderr]     Checking anstream v0.6.19
[INFO] [stderr]     Checking regex-syntax v0.8.5
[INFO] [stderr]     Checking winnow v0.7.11
[INFO] [stderr]     Checking option-ext v0.2.0
[INFO] [stderr]    Compiling serde_json v1.0.140
[INFO] [stderr]     Checking either v1.15.0
[INFO] [stderr]     Checking percent-encoding v2.3.1
[INFO] [stderr]    Compiling lock_api v0.4.13
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]     Checking utf8_iter v1.0.4
[INFO] [stderr]     Checking form_urlencoded v1.2.1
[INFO] [stderr]     Checking rayon v1.10.0
[INFO] [stderr]     Checking clap_builder v4.5.40
[INFO] [stderr]     Checking thread_local v1.1.9
[INFO] [stderr]     Checking itoa v1.0.15
[INFO] [stderr]     Checking iana-time-zone v0.1.63
[INFO] [stderr]     Checking fallible-streaming-iterator v0.1.9
[INFO] [stderr]     Checking aho-corasick v1.1.3
[INFO] [stderr]     Checking ryu v1.0.20
[INFO] [stderr]     Checking fallible-iterator v0.2.0
[INFO] [stderr]     Checking bytes v1.10.1
[INFO] [stderr]    Compiling quote v1.0.40
[INFO] [stderr]     Checking fuzzy-matcher v0.3.7
[INFO] [stderr]    Compiling syn v2.0.104
[INFO] [stderr]     Checking indexmap v2.10.0
[INFO] [stderr]     Checking dirs-sys v0.4.1
[INFO] [stderr]     Checking signal-hook-registry v1.4.5
[INFO] [stderr]     Checking socket2 v0.5.10
[INFO] [stderr]     Checking mio v1.0.4
[INFO] [stderr]     Checking dirs v5.0.1
[INFO] [stderr]     Checking parking_lot v0.12.4
[INFO] [stderr]    Compiling libsqlite3-sys v0.26.0
[INFO] [stderr]     Checking regex-automata v0.4.9
[INFO] [stderr]     Checking hashbrown v0.14.5
[INFO] [stderr]     Checking sysinfo v0.30.13
[INFO] [stderr]     Checking hashlink v0.8.4
[INFO] [stderr]     Checking regex v1.11.1
[INFO] [stderr]    Compiling synstructure v0.13.2
[INFO] [stderr]    Compiling zerofrom-derive v0.1.6
[INFO] [stderr]    Compiling yoke-derive v0.8.0
[INFO] [stderr]    Compiling zerovec-derive v0.11.1
[INFO] [stderr]    Compiling displaydoc v0.2.5
[INFO] [stderr]    Compiling serde_derive v1.0.219
[INFO] [stderr]    Compiling clap_derive v4.5.40
[INFO] [stderr]    Compiling tokio-macros v2.5.0
[INFO] [stderr]     Checking tokio v1.46.0
[INFO] [stderr]     Checking zerofrom v0.1.6
[INFO] [stderr]     Checking yoke v0.8.0
[INFO] [stderr]     Checking zerovec v0.11.2
[INFO] [stderr]     Checking zerotrie v0.2.2
[INFO] [stderr]     Checking clap v4.5.40
[INFO] [stderr]     Checking tinystr v0.8.1
[INFO] [stderr]     Checking potential_utf v0.1.2
[INFO] [stderr]     Checking icu_collections v2.0.0
[INFO] [stderr]     Checking icu_locale_core v2.0.0
[INFO] [stderr]     Checking icu_provider v2.0.0
[INFO] [stderr]     Checking icu_properties v2.0.1
[INFO] [stderr]     Checking icu_normalizer v2.0.0
[INFO] [stderr]     Checking idna_adapter v1.2.1
[INFO] [stderr]     Checking idna v1.0.3
[INFO] [stderr]     Checking url v2.5.4
[INFO] [stderr]     Checking serde_spanned v0.6.9
[INFO] [stderr]     Checking toml_datetime v0.6.11
[INFO] [stderr]     Checking chrono v0.4.41
[INFO] [stderr]     Checking toml_edit v0.22.27
[INFO] [stderr]     Checking rusqlite v0.29.0
[INFO] [stderr]     Checking toml v0.8.23
[INFO] [stderr]     Checking focusdebt v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] error[E0583]: file not found for module `stats`
[INFO] [stdout]  --> examples/test_browser_tabs.rs:1:1
[INFO] [stdout]   |
[INFO] [stdout] 1 | mod stats;
[INFO] [stdout]   | ^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = help: to create the module `stats`, create file "examples/stats.rs" or "examples/stats/mod.rs"
[INFO] [stdout]   = note: if there is a `mod stats` elsewhere in the crate already, import it with `use crate::...` instead
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] error[E0583]: file not found for module `tracking`
[INFO] [stdout]  --> examples/test_browser_tabs.rs:2:1
[INFO] [stdout]   |
[INFO] [stdout] 2 | mod tracking;
[INFO] [stdout]   | ^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = help: to create the module `tracking`, create file "examples/tracking.rs" or "examples/tracking/mod.rs"
[INFO] [stdout]   = note: if there is a `mod tracking` elsewhere in the crate already, import it with `use crate::...` instead
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `chrono::Utc`
[INFO] [stdout]  --> src/main.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use chrono::Utc;
[INFO] [stdout]   |     ^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `url::Url`
[INFO] [stdout]  --> src/utils.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use url::Url;
[INFO] [stdout]   |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] For more information about this error, try `rustc --explain E0583`.
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `chrono::Utc`
[INFO] [stdout]  --> src/main.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use chrono::Utc;
[INFO] [stdout]   |     ^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `url::Url`
[INFO] [stdout]  --> src/utils.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use url::Url;
[INFO] [stdout]   |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr] error: could not compile `focusdebt` (example "test_browser_tabs") due to 2 previous errors
[INFO] [stderr] warning: build failed, waiting for other jobs to finish...
[INFO] [stdout] warning: unused variable: `start`
[INFO] [stdout]    --> src/stats.rs:185:13
[INFO] [stdout]     |
[INFO] [stdout] 185 |         let start = utils::format_datetime_local(session.start_time);
[INFO] [stdout]     |             ^^^^^ help: if this is intentional, prefix it with an underscore: `_start`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `i`
[INFO] [stdout]    --> src/stats.rs:455:18
[INFO] [stdout]     |
[INFO] [stdout] 455 |             for (i, (app, duration, is_focus)) in regular_apps.iter().take(6).enumerate() {
[INFO] [stdout]     |                  ^ help: if this is intentional, prefix it with an underscore: `_i`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `browser_apps`
[INFO] [stdout]    --> src/stats.rs:610:14
[INFO] [stdout]     |
[INFO] [stdout] 610 |         let (browser_apps, regular_apps): (Vec<_>, Vec<_>) = session.app_usage.iter()
[INFO] [stdout]     |              ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_browser_apps`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `i`
[INFO] [stdout]    --> src/stats.rs:617:18
[INFO] [stdout]     |
[INFO] [stdout] 617 |             for (i, (app, duration, is_focus)) in regular_apps.iter().take(6).enumerate() {
[INFO] [stdout]     |                  ^ help: if this is intentional, prefix it with an underscore: `_i`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable pattern
[INFO] [stdout]    --> src/main.rs:318:9
[INFO] [stdout]     |
[INFO] [stdout] 318 |         _ => {}
[INFO] [stdout]     |         ^ no value can reach this
[INFO] [stdout]     |
[INFO] [stdout] note: multiple earlier patterns match some of the same values
[INFO] [stdout]    --> src/main.rs:318:9
[INFO] [stdout]     |
[INFO] [stdout] 190 |         Commands::Start => {
[INFO] [stdout]     |         --------------- matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 199 |         Commands::Stop => {
[INFO] [stdout]     |         -------------- matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 208 |         Commands::Stats => {
[INFO] [stdout]     |         --------------- matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 212 |         Commands::Share => {
[INFO] [stdout]     |         --------------- matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 318 |         _ => {}
[INFO] [stdout]     |         ^ ...and 7 other patterns collectively make this unreachable
[INFO] [stdout]     = note: `#[warn(unreachable_patterns)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `add_focus_app` is never used
[INFO] [stdout]    --> src/main.rs:872:4
[INFO] [stdout]     |
[INFO] [stdout] 872 | fn add_focus_app(app_name: &str) {
[INFO] [stdout]     |    ^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple methods are never used
[INFO] [stdout]    --> src/tracking.rs:62:12
[INFO] [stdout]     |
[INFO] [stdout] 37  | impl FocusTracker {
[INFO] [stdout]     | ----------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 62  |     pub fn stop_tracking(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 75  |     pub fn is_tracking(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 88  |     pub fn remove_focus_app(&mut self, app_name: &str) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 95  |     pub fn list_focus_apps(&self) -> &[String] {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 99  |     pub fn get_focus_apps(&self) -> &[String] {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 112 |     pub fn remove_focus_site(&mut self, domain: &str) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 119 |     pub fn list_focus_sites(&self) -> &[String] {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 123 |     pub fn get_focus_sites(&self) -> &[String] {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 303 |     pub fn get_completed_sessions(&self) -> &[FocusSession] {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 313 |     pub fn get_context_switches(&self) -> &[ContextSwitch] {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 323 |     pub fn get_deep_focus_sessions(&self, _min_duration: Duration) -> Vec<&FocusSession> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 350 |     pub fn get_session_name(&self) -> &str {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `focus_apps_count` is never read
[INFO] [stdout]    --> src/tracking.rs:360:9
[INFO] [stdout]     |
[INFO] [stdout] 356 | pub struct TrackerStats {
[INFO] [stdout]     |            ------------ field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 360 |     pub focus_apps_count: usize,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `TrackerStats` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `add_focus_app`, `get_focus_apps`, `add_focus_site`, `remove_focus_site`, and `get_focus_sites` are never used
[INFO] [stdout]    --> src/storage.rs:121:12
[INFO] [stdout]     |
[INFO] [stdout] 13  | impl Database {
[INFO] [stdout]     | ------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 121 |     pub fn add_focus_app(&self, app_name: &str) -> SqliteResult<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 137 |     pub fn get_focus_apps(&self) -> SqliteResult<Vec<String>> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 150 |     pub fn add_focus_site(&self, domain: &str) -> SqliteResult<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 158 |     pub fn remove_focus_site(&self, domain: &str) -> SqliteResult<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 166 |     pub fn get_focus_sites(&self) -> SqliteResult<Vec<String>> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `date`, `deep_focus_sessions`, and `most_distracting_apps` are never read
[INFO] [stdout]   --> src/stats.rs:11:9
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub struct DailyStats {
[INFO] [stdout]    |            ---------- fields in this struct
[INFO] [stdout] 11 |     pub date: DateTime<Utc>,
[INFO] [stdout]    |         ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 15 |     pub deep_focus_sessions: usize,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 18 |     pub most_distracting_apps: Vec<(String, Duration)>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `DailyStats` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `generate_ascii_report` is never used
[INFO] [stdout]    --> src/stats.rs:145:12
[INFO] [stdout]     |
[INFO] [stdout] 35  | impl Stats {
[INFO] [stdout]     | ---------- associated function in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 145 |     pub fn generate_ascii_report(stats: &DailyStats) -> String {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `format_timestamp` is never used
[INFO] [stdout]   --> src/utils.rs:26:8
[INFO] [stdout]    |
[INFO] [stdout] 26 | pub fn format_timestamp(timestamp: DateTime<Utc>) -> String {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `format_duration_short` is never used
[INFO] [stdout]   --> src/utils.rs:38:8
[INFO] [stdout]    |
[INFO] [stdout] 38 | pub fn format_duration_short(duration: Duration) -> String {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_current_pid` is never used
[INFO] [stdout]    --> src/utils.rs:160:8
[INFO] [stdout]     |
[INFO] [stdout] 160 | pub fn get_current_pid() -> u32 {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `extract_domain_from_title` is never used
[INFO] [stdout]    --> src/utils.rs:168:8
[INFO] [stdout]     |
[INFO] [stdout] 168 | pub fn extract_domain_from_title(window_title: &str, app_name: &str) -> Option<String> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `extract_domain_from_text` is never used
[INFO] [stdout]    --> src/utils.rs:223:4
[INFO] [stdout]     |
[INFO] [stdout] 223 | fn extract_domain_from_text(text: &str) -> Option<String> {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple methods are never used
[INFO] [stdout]    --> src/config.rs:115:12
[INFO] [stdout]     |
[INFO] [stdout] 69  | impl Config {
[INFO] [stdout]     | ----------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 115 |     pub fn add_ignored_app(&mut self, app_name: String) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 121 |     pub fn remove_ignored_app(&mut self, app_name: &str) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 125 |     pub fn is_focus_app(&self, app_name: &str) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 129 |     pub fn is_ignored_app(&self, app_name: &str) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 133 |     pub fn get_database_path(&self) -> PathBuf {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 159 |     pub fn add_ignored_site(&mut self, site: String) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 165 |     pub fn remove_ignored_site(&mut self, site: &str) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 169 |     pub fn is_focus_site(&self, site: &str) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 173 |     pub fn is_ignored_site(&self, site: &str) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: creating a shared reference to mutable static
[INFO] [stdout]    --> src/main.rs:543:103
[INFO] [stdout]     |
[INFO] [stdout] 543 | ...                   println!("~=~ Still on: {} - {} ({} checks)", app_name, window_title, SAME_WINDOW_COUNT);
[INFO] [stdout]     |                                                                                             ^^^^^^^^^^^^^^^^^ shared reference to mutable static
[INFO] [stdout]     |
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2024/static-mut-references.html>
[INFO] [stdout]     = note: shared references to mutable statics are dangerous; it's undefined behavior if the static is mutated or if a mutable reference is created for it while the shared reference lives
[INFO] [stdout]     = note: `#[warn(static_mut_refs)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `start`
[INFO] [stdout]    --> src/stats.rs:185:13
[INFO] [stdout]     |
[INFO] [stdout] 185 |         let start = utils::format_datetime_local(session.start_time);
[INFO] [stdout]     |             ^^^^^ help: if this is intentional, prefix it with an underscore: `_start`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `i`
[INFO] [stdout]    --> src/stats.rs:455:18
[INFO] [stdout]     |
[INFO] [stdout] 455 |             for (i, (app, duration, is_focus)) in regular_apps.iter().take(6).enumerate() {
[INFO] [stdout]     |                  ^ help: if this is intentional, prefix it with an underscore: `_i`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `browser_apps`
[INFO] [stdout]    --> src/stats.rs:610:14
[INFO] [stdout]     |
[INFO] [stdout] 610 |         let (browser_apps, regular_apps): (Vec<_>, Vec<_>) = session.app_usage.iter()
[INFO] [stdout]     |              ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_browser_apps`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `i`
[INFO] [stdout]    --> src/stats.rs:617:18
[INFO] [stdout]     |
[INFO] [stdout] 617 |             for (i, (app, duration, is_focus)) in regular_apps.iter().take(6).enumerate() {
[INFO] [stdout]     |                  ^ help: if this is intentional, prefix it with an underscore: `_i`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable pattern
[INFO] [stdout]    --> src/main.rs:318:9
[INFO] [stdout]     |
[INFO] [stdout] 318 |         _ => {}
[INFO] [stdout]     |         ^ no value can reach this
[INFO] [stdout]     |
[INFO] [stdout] note: multiple earlier patterns match some of the same values
[INFO] [stdout]    --> src/main.rs:318:9
[INFO] [stdout]     |
[INFO] [stdout] 190 |         Commands::Start => {
[INFO] [stdout]     |         --------------- matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 199 |         Commands::Stop => {
[INFO] [stdout]     |         -------------- matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 208 |         Commands::Stats => {
[INFO] [stdout]     |         --------------- matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 212 |         Commands::Share => {
[INFO] [stdout]     |         --------------- matches some of the same values
[INFO] [stdout] ...
[INFO] [stdout] 318 |         _ => {}
[INFO] [stdout]     |         ^ ...and 7 other patterns collectively make this unreachable
[INFO] [stdout]     = note: `#[warn(unreachable_patterns)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `add_focus_app` is never used
[INFO] [stdout]    --> src/main.rs:872:4
[INFO] [stdout]     |
[INFO] [stdout] 872 | fn add_focus_app(app_name: &str) {
[INFO] [stdout]     |    ^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple methods are never used
[INFO] [stdout]    --> src/tracking.rs:62:12
[INFO] [stdout]     |
[INFO] [stdout] 37  | impl FocusTracker {
[INFO] [stdout]     | ----------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 62  |     pub fn stop_tracking(&mut self) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 75  |     pub fn is_tracking(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 88  |     pub fn remove_focus_app(&mut self, app_name: &str) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 95  |     pub fn list_focus_apps(&self) -> &[String] {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 99  |     pub fn get_focus_apps(&self) -> &[String] {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 112 |     pub fn remove_focus_site(&mut self, domain: &str) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 119 |     pub fn list_focus_sites(&self) -> &[String] {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 123 |     pub fn get_focus_sites(&self) -> &[String] {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 303 |     pub fn get_completed_sessions(&self) -> &[FocusSession] {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 313 |     pub fn get_context_switches(&self) -> &[ContextSwitch] {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 323 |     pub fn get_deep_focus_sessions(&self, _min_duration: Duration) -> Vec<&FocusSession> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 350 |     pub fn get_session_name(&self) -> &str {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `focus_apps_count` is never read
[INFO] [stdout]    --> src/tracking.rs:360:9
[INFO] [stdout]     |
[INFO] [stdout] 356 | pub struct TrackerStats {
[INFO] [stdout]     |            ------------ field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 360 |     pub focus_apps_count: usize,
[INFO] [stdout]     |         ^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `TrackerStats` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `add_focus_app`, `get_focus_apps`, `add_focus_site`, `remove_focus_site`, and `get_focus_sites` are never used
[INFO] [stdout]    --> src/storage.rs:121:12
[INFO] [stdout]     |
[INFO] [stdout] 13  | impl Database {
[INFO] [stdout]     | ------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 121 |     pub fn add_focus_app(&self, app_name: &str) -> SqliteResult<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 137 |     pub fn get_focus_apps(&self) -> SqliteResult<Vec<String>> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 150 |     pub fn add_focus_site(&self, domain: &str) -> SqliteResult<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 158 |     pub fn remove_focus_site(&self, domain: &str) -> SqliteResult<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 166 |     pub fn get_focus_sites(&self) -> SqliteResult<Vec<String>> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `date`, `deep_focus_sessions`, and `most_distracting_apps` are never read
[INFO] [stdout]   --> src/stats.rs:11:9
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub struct DailyStats {
[INFO] [stdout]    |            ---------- fields in this struct
[INFO] [stdout] 11 |     pub date: DateTime<Utc>,
[INFO] [stdout]    |         ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 15 |     pub deep_focus_sessions: usize,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 18 |     pub most_distracting_apps: Vec<(String, Duration)>,
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `DailyStats` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `generate_ascii_report` is never used
[INFO] [stdout]    --> src/stats.rs:145:12
[INFO] [stdout]     |
[INFO] [stdout] 35  | impl Stats {
[INFO] [stdout]     | ---------- associated function in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 145 |     pub fn generate_ascii_report(stats: &DailyStats) -> String {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `format_timestamp` is never used
[INFO] [stdout]   --> src/utils.rs:26:8
[INFO] [stdout]    |
[INFO] [stdout] 26 | pub fn format_timestamp(timestamp: DateTime<Utc>) -> String {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `format_duration_short` is never used
[INFO] [stdout]   --> src/utils.rs:38:8
[INFO] [stdout]    |
[INFO] [stdout] 38 | pub fn format_duration_short(duration: Duration) -> String {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_current_pid` is never used
[INFO] [stdout]    --> src/utils.rs:160:8
[INFO] [stdout]     |
[INFO] [stdout] 160 | pub fn get_current_pid() -> u32 {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `extract_domain_from_title` is never used
[INFO] [stdout]    --> src/utils.rs:168:8
[INFO] [stdout]     |
[INFO] [stdout] 168 | pub fn extract_domain_from_title(window_title: &str, app_name: &str) -> Option<String> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `extract_domain_from_text` is never used
[INFO] [stdout]    --> src/utils.rs:223:4
[INFO] [stdout]     |
[INFO] [stdout] 223 | fn extract_domain_from_text(text: &str) -> Option<String> {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple methods are never used
[INFO] [stdout]    --> src/config.rs:115:12
[INFO] [stdout]     |
[INFO] [stdout] 69  | impl Config {
[INFO] [stdout]     | ----------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 115 |     pub fn add_ignored_app(&mut self, app_name: String) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 121 |     pub fn remove_ignored_app(&mut self, app_name: &str) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 125 |     pub fn is_focus_app(&self, app_name: &str) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 129 |     pub fn is_ignored_app(&self, app_name: &str) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 133 |     pub fn get_database_path(&self) -> PathBuf {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 159 |     pub fn add_ignored_site(&mut self, site: String) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 165 |     pub fn remove_ignored_site(&mut self, site: &str) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 169 |     pub fn is_focus_site(&self, site: &str) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 173 |     pub fn is_ignored_site(&self, site: &str) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: creating a shared reference to mutable static
[INFO] [stdout]    --> src/main.rs:543:103
[INFO] [stdout]     |
[INFO] [stdout] 543 | ...                   println!("~=~ Still on: {} - {} ({} checks)", app_name, window_title, SAME_WINDOW_COUNT);
[INFO] [stdout]     |                                                                                             ^^^^^^^^^^^^^^^^^ shared reference to mutable static
[INFO] [stdout]     |
[INFO] [stdout]     = note: for more information, see <https://doc.rust-lang.org/nightly/edition-guide/rust-2024/static-mut-references.html>
[INFO] [stdout]     = note: shared references to mutable statics are dangerous; it's undefined behavior if the static is mutated or if a mutable reference is created for it while the shared reference lives
[INFO] [stdout]     = note: `#[warn(static_mut_refs)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] running `Command { std: "docker" "inspect" "6309ae3c1b5a21143bfb01d083d87fdd44c259e3798b88fddc6550122ea9e743", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "6309ae3c1b5a21143bfb01d083d87fdd44c259e3798b88fddc6550122ea9e743", kill_on_drop: false }`
[INFO] [stdout] 6309ae3c1b5a21143bfb01d083d87fdd44c259e3798b88fddc6550122ea9e743
