[INFO] cloning repository https://github.com/nehcuh/gitie
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/nehcuh/gitie" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fnehcuh%2Fgitie", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fnehcuh%2Fgitie'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 6e42dd906d1b530483b3f0aa4283d487606b7871
[INFO] checking nehcuh/gitie against master#779e19d8baa3e3625bd4fc5c85cbb2ad47b43155 for pr-147589-1
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fnehcuh%2Fgitie" "/workspace/builds/worker-6-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-6-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/nehcuh/gitie
[INFO] finished tweaking git repo https://github.com/nehcuh/gitie
[INFO] tweaked toml for git repo https://github.com/nehcuh/gitie written to /workspace/builds/worker-6-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/nehcuh/gitie on toolchain 779e19d8baa3e3625bd4fc5c85cbb2ad47b43155
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+779e19d8baa3e3625bd4fc5c85cbb2ad47b43155" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/nehcuh/gitie 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" "+779e19d8baa3e3625bd4fc5c85cbb2ad47b43155" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded tree-sitter-go v0.19.1
[INFO] [stderr]   Downloaded tree-sitter-python v0.20.4
[INFO] [stderr]   Downloaded tree-sitter-java v0.20.2
[INFO] [stderr]   Downloaded ring v0.17.9
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+779e19d8baa3e3625bd4fc5c85cbb2ad47b43155" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 7b21c48d2b22ea572f5e4f521fdd976ea5d6bdd10aa39b9df19756a0a01c76ac
[INFO] running `Command { std: "docker" "start" "-a" "7b21c48d2b22ea572f5e4f521fdd976ea5d6bdd10aa39b9df19756a0a01c76ac", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "7b21c48d2b22ea572f5e4f521fdd976ea5d6bdd10aa39b9df19756a0a01c76ac", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "7b21c48d2b22ea572f5e4f521fdd976ea5d6bdd10aa39b9df19756a0a01c76ac", kill_on_drop: false }`
[INFO] [stdout] 7b21c48d2b22ea572f5e4f521fdd976ea5d6bdd10aa39b9df19756a0a01c76ac
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-6-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:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+779e19d8baa3e3625bd4fc5c85cbb2ad47b43155" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] b2df5bafc673ccb21bde21c94c229dd746175f85f56c5af7e01bedbbd589bb7d
[INFO] running `Command { std: "docker" "start" "-a" "b2df5bafc673ccb21bde21c94c229dd746175f85f56c5af7e01bedbbd589bb7d", kill_on_drop: false }`
[INFO] [stderr]    Compiling libc v0.2.172
[INFO] [stderr]     Checking smallvec v1.15.0
[INFO] [stderr]     Checking tracing-core v0.1.33
[INFO] [stderr]     Checking hashbrown v0.15.3
[INFO] [stderr]    Compiling openssl-sys v0.9.108
[INFO] [stderr]     Checking http v1.3.1
[INFO] [stderr]    Compiling icu_properties_data v2.0.0
[INFO] [stderr]    Compiling tree-sitter v0.20.10
[INFO] [stderr]    Compiling syn v2.0.101
[INFO] [stderr]    Compiling openssl v0.10.72
[INFO] [stderr]     Checking log v0.4.27
[INFO] [stderr]    Compiling native-tls v0.2.14
[INFO] [stderr]     Checking futures-channel v0.3.31
[INFO] [stderr]     Checking openssl-probe v0.1.6
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]    Compiling tree-sitter-python v0.20.4
[INFO] [stderr]    Compiling tree-sitter-rust v0.20.4
[INFO] [stderr]    Compiling tree-sitter-go v0.19.1
[INFO] [stderr]    Compiling tree-sitter-java v0.20.2
[INFO] [stderr]     Checking option-ext v0.2.0
[INFO] [stderr]     Checking winnow v0.7.10
[INFO] [stderr]     Checking toml_write v0.1.1
[INFO] [stderr]     Checking clap_builder v4.5.38
[INFO] [stderr]     Checking rustls-pemfile v2.2.0
[INFO] [stderr]     Checking indexmap v2.9.0
[INFO] [stderr]     Checking thread_local v1.1.8
[INFO] [stderr]    Compiling rustix v1.0.7
[INFO] [stderr]     Checking tracing-log v0.2.0
[INFO] [stderr]     Checking colored v3.0.0
[INFO] [stderr]     Checking tracing-subscriber v0.3.19
[INFO] [stderr]     Checking http-body v1.0.1
[INFO] [stderr]     Checking http-body-util v0.1.3
[INFO] [stderr]     Checking parking_lot_core v0.9.10
[INFO] [stderr]     Checking socket2 v0.5.9
[INFO] [stderr]     Checking mio v1.0.3
[INFO] [stderr]     Checking signal-hook-registry v1.4.5
[INFO] [stderr]     Checking dirs-sys v0.5.0
[INFO] [stderr]     Checking dirs-sys-next v0.1.2
[INFO] [stderr]     Checking dirs v6.0.0
[INFO] [stderr]     Checking chrono v0.4.41
[INFO] [stderr]     Checking getrandom v0.3.3
[INFO] [stderr]     Checking dirs-next v2.0.0
[INFO] [stderr]     Checking parking_lot v0.12.3
[INFO] [stderr]     Checking tempfile v3.20.0
[INFO] [stderr]    Compiling synstructure v0.13.2
[INFO] [stderr]    Compiling zerovec-derive v0.11.1
[INFO] [stderr]    Compiling displaydoc v0.2.5
[INFO] [stderr]    Compiling tokio-macros v2.5.0
[INFO] [stderr]    Compiling serde_derive v1.0.219
[INFO] [stderr]    Compiling tracing-attributes v0.1.28
[INFO] [stderr]    Compiling openssl-macros v0.1.1
[INFO] [stderr]    Compiling clap_derive v4.5.32
[INFO] [stderr]    Compiling thiserror-impl v2.0.12
[INFO] [stderr]    Compiling zerofrom-derive v0.1.6
[INFO] [stderr]    Compiling yoke-derive v0.8.0
[INFO] [stderr]     Checking tokio v1.45.0
[INFO] [stderr]     Checking thiserror v2.0.12
[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.38
[INFO] [stderr]     Checking tracing v0.1.41
[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 serde v1.0.219
[INFO] [stderr]     Checking icu_normalizer v2.0.0
[INFO] [stderr]     Checking icu_properties 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 tokio-util v0.7.15
[INFO] [stderr]     Checking tokio-native-tls v0.3.1
[INFO] [stderr]     Checking tower v0.5.2
[INFO] [stderr]     Checking toml_datetime v0.6.9
[INFO] [stderr]     Checking serde_spanned v0.6.8
[INFO] [stderr]     Checking serde_urlencoded v0.7.1
[INFO] [stderr]     Checking serde_json v1.0.140
[INFO] [stderr]     Checking toml_edit v0.22.26
[INFO] [stderr]     Checking h2 v0.4.10
[INFO] [stderr]     Checking toml v0.8.22
[INFO] [stderr]     Checking hyper v1.6.0
[INFO] [stderr]     Checking hyper-util v0.1.11
[INFO] [stderr]     Checking hyper-tls v0.6.0
[INFO] [stderr]     Checking reqwest v0.12.15
[INFO] [stderr]     Checking gitie v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `AIError`
[INFO] [stdout]  --> src/ai_module/prompt_handler.rs:2:27
[INFO] [stdout]   |
[INFO] [stdout] 2 | use crate::core::errors::{AIError, AppError};
[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: `DiffAnalysis`
[INFO] [stdout]  --> src/command_processing/review.rs:7:78
[INFO] [stdout]   |
[INFO] [stdout] 7 | use crate::tree_sitter_analyzer::core::{GitDiff, ChangePattern, ChangeScope, DiffAnalysis};
[INFO] [stdout]   |                                                                              ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]  --> src/review_engine/mod.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use std::collections::HashMap;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `AIError`
[INFO] [stdout]  --> src/ai_module/prompt_handler.rs:2:27
[INFO] [stdout]   |
[INFO] [stdout] 2 | use crate::core::errors::{AIError, AppError};
[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: `DiffAnalysis`
[INFO] [stdout]  --> src/command_processing/review.rs:7:78
[INFO] [stdout]   |
[INFO] [stdout] 7 | use crate::tree_sitter_analyzer::core::{GitDiff, ChangePattern, ChangeScope, DiffAnalysis};
[INFO] [stdout]   |                                                                              ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]  --> src/review_engine/mod.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use std::collections::HashMap;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `source_bytes`
[INFO] [stdout]    --> src/tree_sitter_analyzer/analyzer.rs:746:13
[INFO] [stdout]     |
[INFO] [stdout] 746 |         let source_bytes = file_ast.source.as_bytes();
[INFO] [stdout]     |             ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_source_bytes`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `source_bytes`
[INFO] [stdout]    --> src/tree_sitter_analyzer/analyzer.rs:793:13
[INFO] [stdout]     |
[INFO] [stdout] 793 |         let source_bytes = file_ast.source.as_bytes();
[INFO] [stdout]     |             ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_source_bytes`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `file`
[INFO] [stdout]   --> src/tree_sitter_analyzer/parse_utils.rs:65:25
[INFO] [stdout]    |
[INFO] [stdout] 65 |             if let Some(ref mut file) = current_file {
[INFO] [stdout]    |                         ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_file`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `parse_line_range` is never used
[INFO] [stdout]    --> src/tree_sitter_analyzer/core.rs:353:4
[INFO] [stdout]     |
[INFO] [stdout] 353 | fn parse_line_range(range_str: &str) -> LineRange {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Path`
[INFO] [stdout]  --> tests/tree_sitter_analyzer_tests.rs:3:17
[INFO] [stdout]   |
[INFO] [stdout] 3 | use std::path::{Path, PathBuf};
[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: `tree_sitter::Tree`
[INFO] [stdout]  --> tests/tree_sitter_analyzer_tests.rs:4:5
[INFO] [stdout]   |
[INFO] [stdout] 4 | use tree_sitter::Tree;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::fs`
[INFO] [stdout]   --> tests/tree_sitter_analyzer_tests.rs:39:9
[INFO] [stdout]    |
[INFO] [stdout] 39 |     use std::fs;
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `tempfile::TempDir`
[INFO] [stdout]   --> tests/tree_sitter_analyzer_tests.rs:40:9
[INFO] [stdout]    |
[INFO] [stdout] 40 |     use tempfile::TempDir;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `diff_text`
[INFO] [stdout]   --> tests/tree_sitter_analyzer_tests.rs:21:19
[INFO] [stdout]    |
[INFO] [stdout] 21 | fn parse_git_diff(diff_text: &str) -> Result<gitie::tree_sitter_analyzer::core::GitDiff, String> {
[INFO] [stdout]    |                   ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_diff_text`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_tree_sitter_rust` is never used
[INFO] [stdout]   --> tests/tree_sitter_analyzer_tests.rs:11:4
[INFO] [stdout]    |
[INFO] [stdout] 11 | fn get_tree_sitter_rust() -> tree_sitter::Language {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_tree_sitter_java` is never used
[INFO] [stdout]   --> tests/tree_sitter_analyzer_tests.rs:16:4
[INFO] [stdout]    |
[INFO] [stdout] 16 | fn get_tree_sitter_java() -> tree_sitter::Language {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `parse_git_diff` is never used
[INFO] [stdout]   --> tests/tree_sitter_analyzer_tests.rs:21:4
[INFO] [stdout]    |
[INFO] [stdout] 21 | fn parse_git_diff(diff_text: &str) -> Result<gitie::tree_sitter_analyzer::core::GitDiff, String> {
[INFO] [stdout]    |    ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `AIError`
[INFO] [stdout]  --> src/ai_module/prompt_handler.rs:2:27
[INFO] [stdout]   |
[INFO] [stdout] 2 | use crate::core::errors::{AIError, AppError};
[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: `AIError`
[INFO] [stdout]  --> src/ai_module/prompt_handler.rs:2:27
[INFO] [stdout]   |
[INFO] [stdout] 2 | use crate::core::errors::{AIError, AppError};
[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: `DiffAnalysis`
[INFO] [stdout]  --> src/command_processing/review.rs:7:78
[INFO] [stdout]   |
[INFO] [stdout] 7 | use crate::tree_sitter_analyzer::core::{GitDiff, ChangePattern, ChangeScope, DiffAnalysis};
[INFO] [stdout]   |                                                                              ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `DiffAnalysis`
[INFO] [stdout]  --> src/command_processing/review.rs:7:78
[INFO] [stdout]   |
[INFO] [stdout] 7 | use crate::tree_sitter_analyzer::core::{GitDiff, ChangePattern, ChangeScope, DiffAnalysis};
[INFO] [stdout]   |                                                                              ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]  --> src/review_engine/mod.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use std::collections::HashMap;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `detect_language_from_path`, `parse_simple_diff`, and `summarize_languages`
[INFO] [stdout]   --> src/tree_sitter_analyzer/mod.rs:14:29
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub use self::simple_diff::{parse_simple_diff, detect_language_from_path, summarize_languages};
[INFO] [stdout]    |                             ^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `detect_language` and `parse_git_diff_text`
[INFO] [stdout]   --> src/tree_sitter_analyzer/mod.rs:15:29
[INFO] [stdout]    |
[INFO] [stdout] 15 | pub use self::parse_utils::{parse_git_diff_text, detect_language};
[INFO] [stdout]    |                             ^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `self::java::JavaProjectStructure`
[INFO] [stdout]   --> src/tree_sitter_analyzer/mod.rs:16:9
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub use self::java::JavaProjectStructure; // Moved back to java.rs
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `JavaChangePattern`, `JavaClassRelation`, `JavaClass`, `JavaMethodParam`, `JavaMethod`, `JavaPackage`, and `JavaRelationType`
[INFO] [stdout]   --> src/tree_sitter_analyzer/mod.rs:17:22
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub use self::java::{JavaClass, JavaMethod, JavaMethodParam, JavaClassRelation, JavaRelationType, JavaPackage, JavaChangePattern};
[INFO] [stdout]    |                      ^^^^^^^^^  ^^^^^^^^^^  ^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^  ^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `self::rust::RustChangePattern`
[INFO] [stdout]   --> src/tree_sitter_analyzer/mod.rs:18:9
[INFO] [stdout]    |
[INFO] [stdout] 18 | pub use self::rust::RustChangePattern;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `explain_git_command_output`
[INFO] [stdout]   --> src/main.rs:10:54
[INFO] [stdout]    |
[INFO] [stdout] 10 | use crate::ai_module::explainer::{explain_git_error, explain_git_command_output};
[INFO] [stdout]    |                                                      ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]  --> src/review_engine/mod.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use std::collections::HashMap;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `detect_language_from_path`, `parse_simple_diff`, and `summarize_languages`
[INFO] [stdout]   --> src/tree_sitter_analyzer/mod.rs:14:29
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub use self::simple_diff::{parse_simple_diff, detect_language_from_path, summarize_languages};
[INFO] [stdout]    |                             ^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `detect_language` and `parse_git_diff_text`
[INFO] [stdout]   --> src/tree_sitter_analyzer/mod.rs:15:29
[INFO] [stdout]    |
[INFO] [stdout] 15 | pub use self::parse_utils::{parse_git_diff_text, detect_language};
[INFO] [stdout]    |                             ^^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `self::java::JavaProjectStructure`
[INFO] [stdout]   --> src/tree_sitter_analyzer/mod.rs:16:9
[INFO] [stdout]    |
[INFO] [stdout] 16 | pub use self::java::JavaProjectStructure; // Moved back to java.rs
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `JavaChangePattern`, `JavaClassRelation`, `JavaClass`, `JavaMethodParam`, `JavaMethod`, `JavaPackage`, and `JavaRelationType`
[INFO] [stdout]   --> src/tree_sitter_analyzer/mod.rs:17:22
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub use self::java::{JavaClass, JavaMethod, JavaMethodParam, JavaClassRelation, JavaRelationType, JavaPackage, JavaChangePattern};
[INFO] [stdout]    |                      ^^^^^^^^^  ^^^^^^^^^^  ^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^  ^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `self::rust::RustChangePattern`
[INFO] [stdout]   --> src/tree_sitter_analyzer/mod.rs:18:9
[INFO] [stdout]    |
[INFO] [stdout] 18 | pub use self::rust::RustChangePattern;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `explain_git_command_output`
[INFO] [stdout]   --> src/main.rs:10:54
[INFO] [stdout]    |
[INFO] [stdout] 10 | use crate::ai_module::explainer::{explain_git_error, explain_git_command_output};
[INFO] [stdout]    |                                                      ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `source_bytes`
[INFO] [stdout]    --> src/tree_sitter_analyzer/analyzer.rs:746:13
[INFO] [stdout]     |
[INFO] [stdout] 746 |         let source_bytes = file_ast.source.as_bytes();
[INFO] [stdout]     |             ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_source_bytes`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `source_bytes`
[INFO] [stdout]    --> src/tree_sitter_analyzer/analyzer.rs:793:13
[INFO] [stdout]     |
[INFO] [stdout] 793 |         let source_bytes = file_ast.source.as_bytes();
[INFO] [stdout]     |             ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_source_bytes`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `file`
[INFO] [stdout]   --> src/tree_sitter_analyzer/parse_utils.rs:65:25
[INFO] [stdout]    |
[INFO] [stdout] 65 |             if let Some(ref mut file) = current_file {
[INFO] [stdout]    |                         ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_file`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `parse_line_range` is never used
[INFO] [stdout]    --> src/tree_sitter_analyzer/core.rs:353:4
[INFO] [stdout]     |
[INFO] [stdout] 353 | fn parse_line_range(range_str: &str) -> LineRange {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `source_bytes`
[INFO] [stdout]    --> src/tree_sitter_analyzer/analyzer.rs:746:13
[INFO] [stdout]     |
[INFO] [stdout] 746 |         let source_bytes = file_ast.source.as_bytes();
[INFO] [stdout]     |             ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_source_bytes`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `source_bytes`
[INFO] [stdout]    --> src/tree_sitter_analyzer/analyzer.rs:793:13
[INFO] [stdout]     |
[INFO] [stdout] 793 |         let source_bytes = file_ast.source.as_bytes();
[INFO] [stdout]     |             ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_source_bytes`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `source_bytes`
[INFO] [stdout]    --> src/tree_sitter_analyzer/analyzer.rs:746:13
[INFO] [stdout]     |
[INFO] [stdout] 746 |         let source_bytes = file_ast.source.as_bytes();
[INFO] [stdout]     |             ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_source_bytes`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `source_bytes`
[INFO] [stdout]    --> src/tree_sitter_analyzer/analyzer.rs:793:13
[INFO] [stdout]     |
[INFO] [stdout] 793 |         let source_bytes = file_ast.source.as_bytes();
[INFO] [stdout]     |             ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_source_bytes`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `file`
[INFO] [stdout]   --> src/tree_sitter_analyzer/parse_utils.rs:65:25
[INFO] [stdout]    |
[INFO] [stdout] 65 |             if let Some(ref mut file) = current_file {
[INFO] [stdout]    |                         ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_file`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `file`
[INFO] [stdout]   --> src/tree_sitter_analyzer/parse_utils.rs:65:25
[INFO] [stdout]    |
[INFO] [stdout] 65 |             if let Some(ref mut file) = current_file {
[INFO] [stdout]    |                         ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_file`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `load_prompt_file` is never used
[INFO] [stdout]  --> src/ai_module/prompt_handler.rs:8:8
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub fn load_prompt_file(filename: &str, prompt_dirs: &[String]) -> Result<String, AppError> {
[INFO] [stdout]   |        ^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_prompt_directories` is never used
[INFO] [stdout]    --> src/ai_module/prompt_handler.rs:118:8
[INFO] [stdout]     |
[INFO] [stdout] 118 | pub fn get_prompt_directories(_config: &AppConfig) -> Vec<String> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `RuleCategory` is never used
[INFO] [stdout]   --> src/review_engine/mod.rs:12:10
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub enum RuleCategory {
[INFO] [stdout]    |          ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Severity` is never used
[INFO] [stdout]   --> src/review_engine/mod.rs:29:10
[INFO] [stdout]    |
[INFO] [stdout] 29 | pub enum Severity {
[INFO] [stdout]    |          ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `SimpleReviewResult` is never constructed
[INFO] [stdout]   --> src/review_engine/mod.rs:53:12
[INFO] [stdout]    |
[INFO] [stdout] 53 | pub struct SimpleReviewResult {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `SimpleReviewer` is never constructed
[INFO] [stdout]   --> src/review_engine/mod.rs:63:12
[INFO] [stdout]    |
[INFO] [stdout] 63 | pub struct SimpleReviewer {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new` and `review` are never used
[INFO] [stdout]   --> src/review_engine/mod.rs:70:12
[INFO] [stdout]    |
[INFO] [stdout] 68 | impl SimpleReviewer {
[INFO] [stdout]    | ------------------- associated items in this implementation
[INFO] [stdout] 69 |     /// 创建新的代码评审器
[INFO] [stdout] 70 |     pub fn new(config: TreeSitterConfig) -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 75 |     pub fn review(&self, diff: &GitDiff) -> Vec<SimpleReviewResult> {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `Renamed` is never constructed
[INFO] [stdout]   --> src/tree_sitter_analyzer/core.rs:78:5
[INFO] [stdout]    |
[INFO] [stdout] 74 | pub enum ChangeType {
[INFO] [stdout]    |          ---------- variant in this enum
[INFO] [stdout] ...
[INFO] [stdout] 78 |     Renamed,
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ChangeType` 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: fields `start` and `count` are never read
[INFO] [stdout]   --> src/tree_sitter_analyzer/core.rs:88:9
[INFO] [stdout]    |
[INFO] [stdout] 87 | pub struct LineRange {
[INFO] [stdout]    |            --------- fields in this struct
[INFO] [stdout] 88 |     pub start: u32,
[INFO] [stdout]    |         ^^^^^
[INFO] [stdout] 89 |     pub count: u32,
[INFO] [stdout]    |         ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `LineRange` 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: field `old_path` is never read
[INFO] [stdout]    --> src/tree_sitter_analyzer/core.rs:121:9
[INFO] [stdout]     |
[INFO] [stdout] 119 | pub struct FileDiff {
[INFO] [stdout]     |            -------- field in this struct
[INFO] [stdout] 120 |     pub path: PathBuf,
[INFO] [stdout] 121 |     pub old_path: Option<PathBuf>,
[INFO] [stdout]     |         ^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `FileDiff` 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: field `metadata` is never read
[INFO] [stdout]    --> src/tree_sitter_analyzer/core.rs:162:9
[INFO] [stdout]     |
[INFO] [stdout] 160 | pub struct GitDiff {
[INFO] [stdout]     |            ------- field in this struct
[INFO] [stdout] 161 |     pub changed_files: Vec<ChangedFile>,
[INFO] [stdout] 162 |     pub metadata: Option<HashMap<String, String>>,
[INFO] [stdout]     |         ^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `GitDiff` 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 `total_lines` and `changed_lines` are never used
[INFO] [stdout]    --> src/tree_sitter_analyzer/core.rs:170:12
[INFO] [stdout]     |
[INFO] [stdout] 168 | impl GitDiff {
[INFO] [stdout]     | ------------ methods in this implementation
[INFO] [stdout] 169 |     /// Counts the total number of lines in the diff
[INFO] [stdout] 170 |     pub fn total_lines(&self) -> usize {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 181 |     pub fn changed_lines(&self) -> usize {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `line_range`, `additions`, and `deletions` are never read
[INFO] [stdout]    --> src/tree_sitter_analyzer/core.rs:204:9
[INFO] [stdout]     |
[INFO] [stdout] 198 | pub struct AffectedNode {
[INFO] [stdout]     |            ------------ fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 204 |     pub line_range: (usize, usize),
[INFO] [stdout]     |         ^^^^^^^^^^
[INFO] [stdout] 205 |     pub change_type: Option<String>,    // 新增：变更类型（added, deleted, modified）
[INFO] [stdout] 206 |     pub additions: Option<Vec<String>>, // 新增：添加的行
[INFO] [stdout]     |         ^^^^^^^^^
[INFO] [stdout] 207 |     pub deletions: Option<Vec<String>>, // 新增：删除的行
[INFO] [stdout]     |         ^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `AffectedNode` 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: function `parse_line_range` is never used
[INFO] [stdout]    --> src/tree_sitter_analyzer/core.rs:353:4
[INFO] [stdout]     |
[INFO] [stdout] 353 | fn parse_line_range(range_str: &str) -> LineRange {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `generate_overall_summary` is never used
[INFO] [stdout]    --> src/tree_sitter_analyzer/core.rs:372:8
[INFO] [stdout]     |
[INFO] [stdout] 372 | pub fn generate_overall_summary(file_analyses: &[FileAnalysis]) -> String {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `create_simple_git_diff` is never used
[INFO] [stdout]   --> src/tree_sitter_analyzer/analyzer.rs:66:12
[INFO] [stdout]    |
[INFO] [stdout] 42 | impl TreeSitterAnalyzer {
[INFO] [stdout]    | ----------------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 66 |     pub fn create_simple_git_diff(&self, diff_text: &str) -> GitDiff {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `JavaChangePattern` is never used
[INFO] [stdout]    --> src/tree_sitter_analyzer/java.rs:204:10
[INFO] [stdout]     |
[INFO] [stdout] 204 | pub enum JavaChangePattern {
[INFO] [stdout]     |          ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `to_generic_change_pattern` is never used
[INFO] [stdout]    --> src/tree_sitter_analyzer/java.rs:214:8
[INFO] [stdout]     |
[INFO] [stdout] 214 | pub fn to_generic_change_pattern(java_pattern: JavaChangePattern) -> ChangePattern {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `RustChangePattern` is never used
[INFO] [stdout]   --> src/tree_sitter_analyzer/rust.rs:11:10
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub enum RustChangePattern {
[INFO] [stdout]    |          ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `to_generic_change_pattern` is never used
[INFO] [stdout]   --> src/tree_sitter_analyzer/rust.rs:25:8
[INFO] [stdout]    |
[INFO] [stdout] 25 | pub fn to_generic_change_pattern(rust_pattern: RustChangePattern) -> ChangePattern {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `summarize_languages` is never used
[INFO] [stdout]    --> src/tree_sitter_analyzer/simple_diff.rs:119:8
[INFO] [stdout]     |
[INFO] [stdout] 119 | pub fn summarize_languages(git_diff: &GitDiff) -> Vec<(String, usize)> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `detect_language` is never used
[INFO] [stdout]    --> src/tree_sitter_analyzer/parse_utils.rs:134:8
[INFO] [stdout]     |
[INFO] [stdout] 134 | pub fn detect_language(path: &PathBuf) -> Option<String> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `load_prompt_file` is never used
[INFO] [stdout]  --> src/ai_module/prompt_handler.rs:8:8
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub fn load_prompt_file(filename: &str, prompt_dirs: &[String]) -> Result<String, AppError> {
[INFO] [stdout]   |        ^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `get_prompt_directories` is never used
[INFO] [stdout]    --> src/ai_module/prompt_handler.rs:118:8
[INFO] [stdout]     |
[INFO] [stdout] 118 | pub fn get_prompt_directories(_config: &AppConfig) -> Vec<String> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `RuleCategory` is never used
[INFO] [stdout]   --> src/review_engine/mod.rs:12:10
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub enum RuleCategory {
[INFO] [stdout]    |          ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `Severity` is never used
[INFO] [stdout]   --> src/review_engine/mod.rs:29:10
[INFO] [stdout]    |
[INFO] [stdout] 29 | pub enum Severity {
[INFO] [stdout]    |          ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `SimpleReviewResult` is never constructed
[INFO] [stdout]   --> src/review_engine/mod.rs:53:12
[INFO] [stdout]    |
[INFO] [stdout] 53 | pub struct SimpleReviewResult {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `SimpleReviewer` is never constructed
[INFO] [stdout]   --> src/review_engine/mod.rs:63:12
[INFO] [stdout]    |
[INFO] [stdout] 63 | pub struct SimpleReviewer {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `new` and `review` are never used
[INFO] [stdout]   --> src/review_engine/mod.rs:70:12
[INFO] [stdout]    |
[INFO] [stdout] 68 | impl SimpleReviewer {
[INFO] [stdout]    | ------------------- associated items in this implementation
[INFO] [stdout] 69 |     /// 创建新的代码评审器
[INFO] [stdout] 70 |     pub fn new(config: TreeSitterConfig) -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 75 |     pub fn review(&self, diff: &GitDiff) -> Vec<SimpleReviewResult> {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `Renamed` is never constructed
[INFO] [stdout]   --> src/tree_sitter_analyzer/core.rs:78:5
[INFO] [stdout]    |
[INFO] [stdout] 74 | pub enum ChangeType {
[INFO] [stdout]    |          ---------- variant in this enum
[INFO] [stdout] ...
[INFO] [stdout] 78 |     Renamed,
[INFO] [stdout]    |     ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ChangeType` 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: fields `start` and `count` are never read
[INFO] [stdout]   --> src/tree_sitter_analyzer/core.rs:88:9
[INFO] [stdout]    |
[INFO] [stdout] 87 | pub struct LineRange {
[INFO] [stdout]    |            --------- fields in this struct
[INFO] [stdout] 88 |     pub start: u32,
[INFO] [stdout]    |         ^^^^^
[INFO] [stdout] 89 |     pub count: u32,
[INFO] [stdout]    |         ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `LineRange` 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: field `old_path` is never read
[INFO] [stdout]    --> src/tree_sitter_analyzer/core.rs:121:9
[INFO] [stdout]     |
[INFO] [stdout] 119 | pub struct FileDiff {
[INFO] [stdout]     |            -------- field in this struct
[INFO] [stdout] 120 |     pub path: PathBuf,
[INFO] [stdout] 121 |     pub old_path: Option<PathBuf>,
[INFO] [stdout]     |         ^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `FileDiff` 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: field `metadata` is never read
[INFO] [stdout]    --> src/tree_sitter_analyzer/core.rs:162:9
[INFO] [stdout]     |
[INFO] [stdout] 160 | pub struct GitDiff {
[INFO] [stdout]     |            ------- field in this struct
[INFO] [stdout] 161 |     pub changed_files: Vec<ChangedFile>,
[INFO] [stdout] 162 |     pub metadata: Option<HashMap<String, String>>,
[INFO] [stdout]     |         ^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `GitDiff` 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 `total_lines` and `changed_lines` are never used
[INFO] [stdout]    --> src/tree_sitter_analyzer/core.rs:170:12
[INFO] [stdout]     |
[INFO] [stdout] 168 | impl GitDiff {
[INFO] [stdout]     | ------------ methods in this implementation
[INFO] [stdout] 169 |     /// Counts the total number of lines in the diff
[INFO] [stdout] 170 |     pub fn total_lines(&self) -> usize {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 181 |     pub fn changed_lines(&self) -> usize {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `line_range`, `additions`, and `deletions` are never read
[INFO] [stdout]    --> src/tree_sitter_analyzer/core.rs:204:9
[INFO] [stdout]     |
[INFO] [stdout] 198 | pub struct AffectedNode {
[INFO] [stdout]     |            ------------ fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 204 |     pub line_range: (usize, usize),
[INFO] [stdout]     |         ^^^^^^^^^^
[INFO] [stdout] 205 |     pub change_type: Option<String>,    // 新增：变更类型（added, deleted, modified）
[INFO] [stdout] 206 |     pub additions: Option<Vec<String>>, // 新增：添加的行
[INFO] [stdout]     |         ^^^^^^^^^
[INFO] [stdout] 207 |     pub deletions: Option<Vec<String>>, // 新增：删除的行
[INFO] [stdout]     |         ^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `AffectedNode` 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: function `parse_line_range` is never used
[INFO] [stdout]    --> src/tree_sitter_analyzer/core.rs:353:4
[INFO] [stdout]     |
[INFO] [stdout] 353 | fn parse_line_range(range_str: &str) -> LineRange {
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `generate_overall_summary` is never used
[INFO] [stdout]    --> src/tree_sitter_analyzer/core.rs:372:8
[INFO] [stdout]     |
[INFO] [stdout] 372 | pub fn generate_overall_summary(file_analyses: &[FileAnalysis]) -> String {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `create_simple_git_diff` is never used
[INFO] [stdout]   --> src/tree_sitter_analyzer/analyzer.rs:66:12
[INFO] [stdout]    |
[INFO] [stdout] 42 | impl TreeSitterAnalyzer {
[INFO] [stdout]    | ----------------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 66 |     pub fn create_simple_git_diff(&self, diff_text: &str) -> GitDiff {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `JavaChangePattern` is never used
[INFO] [stdout]    --> src/tree_sitter_analyzer/java.rs:204:10
[INFO] [stdout]     |
[INFO] [stdout] 204 | pub enum JavaChangePattern {
[INFO] [stdout]     |          ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `to_generic_change_pattern` is never used
[INFO] [stdout]    --> src/tree_sitter_analyzer/java.rs:214:8
[INFO] [stdout]     |
[INFO] [stdout] 214 | pub fn to_generic_change_pattern(java_pattern: JavaChangePattern) -> ChangePattern {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `RustChangePattern` is never used
[INFO] [stdout]   --> src/tree_sitter_analyzer/rust.rs:11:10
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub enum RustChangePattern {
[INFO] [stdout]    |          ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `to_generic_change_pattern` is never used
[INFO] [stdout]   --> src/tree_sitter_analyzer/rust.rs:25:8
[INFO] [stdout]    |
[INFO] [stdout] 25 | pub fn to_generic_change_pattern(rust_pattern: RustChangePattern) -> ChangePattern {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `summarize_languages` is never used
[INFO] [stdout]    --> src/tree_sitter_analyzer/simple_diff.rs:119:8
[INFO] [stdout]     |
[INFO] [stdout] 119 | pub fn summarize_languages(git_diff: &GitDiff) -> Vec<(String, usize)> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `detect_language` is never used
[INFO] [stdout]    --> src/tree_sitter_analyzer/parse_utils.rs:134:8
[INFO] [stdout]     |
[INFO] [stdout] 134 | pub fn detect_language(path: &PathBuf) -> Option<String> {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 36.11s
[INFO] running `Command { std: "docker" "inspect" "b2df5bafc673ccb21bde21c94c229dd746175f85f56c5af7e01bedbbd589bb7d", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "b2df5bafc673ccb21bde21c94c229dd746175f85f56c5af7e01bedbbd589bb7d", kill_on_drop: false }`
[INFO] [stdout] b2df5bafc673ccb21bde21c94c229dd746175f85f56c5af7e01bedbbd589bb7d
