[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] testing nehcuh/gitie against try#d79d87d4c0f7f0d0785ad6e493cf8cf718ed89a6 for pr-146237 [INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fnehcuh%2Fgitie" "/workspace/builds/worker-5-tc2/source", kill_on_drop: false }` [INFO] [stderr] Cloning into '/workspace/builds/worker-5-tc2/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-5-tc2/source/Cargo.toml [INFO] validating manifest of git repo https://github.com/nehcuh/gitie on toolchain d79d87d4c0f7f0d0785ad6e493cf8cf718ed89a6 [INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+d79d87d4c0f7f0d0785ad6e493cf8cf718ed89a6" "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" "+d79d87d4c0f7f0d0785ad6e493cf8cf718ed89a6" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }` [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+d79d87d4c0f7f0d0785ad6e493cf8cf718ed89a6" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }` [INFO] [stdout] 034b047bfc3741d4d3df2258523c9c863a8c0fad3489742a3728951f7dc1a40c [INFO] running `Command { std: "docker" "start" "-a" "034b047bfc3741d4d3df2258523c9c863a8c0fad3489742a3728951f7dc1a40c", kill_on_drop: false }` [INFO] running `Command { std: "docker" "inspect" "034b047bfc3741d4d3df2258523c9c863a8c0fad3489742a3728951f7dc1a40c", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "034b047bfc3741d4d3df2258523c9c863a8c0fad3489742a3728951f7dc1a40c", kill_on_drop: false }` [INFO] [stdout] 034b047bfc3741d4d3df2258523c9c863a8c0fad3489742a3728951f7dc1a40c [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+d79d87d4c0f7f0d0785ad6e493cf8cf718ed89a6" "build" "--frozen" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] 28b2da561e17c0f157fc7dbe57563f49489eeb0c6e4f6bd8ef2d45ec38c5152e [INFO] running `Command { std: "docker" "start" "-a" "28b2da561e17c0f157fc7dbe57563f49489eeb0c6e4f6bd8ef2d45ec38c5152e", kill_on_drop: false }` [INFO] [stderr] Compiling cc v1.0.106 [INFO] [stderr] Compiling tracing-core v0.1.33 [INFO] [stderr] Compiling aho-corasick v1.1.3 [INFO] [stderr] Compiling futures-task v0.3.31 [INFO] [stderr] Compiling syn v2.0.101 [INFO] [stderr] Compiling openssl v0.10.72 [INFO] [stderr] Compiling native-tls v0.2.14 [INFO] [stderr] Compiling atomic-waker v1.1.2 [INFO] [stderr] Compiling bitflags v2.9.1 [INFO] [stderr] Compiling futures-channel v0.3.31 [INFO] [stderr] Compiling openssl-probe v0.1.6 [INFO] [stderr] Compiling num-traits v0.2.19 [INFO] [stderr] Compiling overload v0.1.1 [INFO] [stderr] Compiling toml_write v0.1.1 [INFO] [stderr] Compiling winnow v0.7.10 [INFO] [stderr] Compiling lazy_static v1.5.0 [INFO] [stderr] Compiling option-ext v0.2.0 [INFO] [stderr] Compiling nu-ansi-term v0.46.0 [INFO] [stderr] Compiling futures-util v0.3.31 [INFO] [stderr] Compiling dirs-sys v0.5.0 [INFO] [stderr] Compiling sharded-slab v0.1.7 [INFO] [stderr] Compiling dirs-sys-next v0.1.2 [INFO] [stderr] Compiling encoding_rs v0.8.35 [INFO] [stderr] Compiling thread_local v1.1.8 [INFO] [stderr] Compiling ipnet v2.11.0 [INFO] [stderr] Compiling dirs-next v2.0.0 [INFO] [stderr] Compiling tracing-log v0.2.0 [INFO] [stderr] Compiling colored v3.0.0 [INFO] [stderr] Compiling dirs v6.0.0 [INFO] [stderr] Compiling tracing-subscriber v0.3.19 [INFO] [stderr] Compiling regex-automata v0.4.9 [INFO] [stderr] Compiling chrono v0.4.41 [INFO] [stderr] Compiling openssl-sys v0.9.108 [INFO] [stderr] Compiling tree-sitter v0.20.10 [INFO] [stderr] Compiling tree-sitter-java v0.20.2 [INFO] [stderr] Compiling tree-sitter-go v0.19.1 [INFO] [stderr] Compiling tree-sitter-python v0.20.4 [INFO] [stderr] Compiling tree-sitter-rust v0.20.4 [INFO] [stderr] Compiling 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 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 tokio v1.45.0 [INFO] [stderr] Compiling thiserror v2.0.12 [INFO] [stderr] Compiling zerofrom v0.1.6 [INFO] [stderr] Compiling yoke v0.8.0 [INFO] [stderr] Compiling tracing v0.1.41 [INFO] [stderr] Compiling zerovec v0.11.2 [INFO] [stderr] Compiling zerotrie v0.2.2 [INFO] [stderr] Compiling clap v4.5.38 [INFO] [stderr] Compiling serde v1.0.219 [INFO] [stderr] Compiling tinystr v0.8.1 [INFO] [stderr] Compiling potential_utf v0.1.2 [INFO] [stderr] Compiling icu_collections v2.0.0 [INFO] [stderr] Compiling icu_locale_core v2.0.0 [INFO] [stderr] Compiling icu_provider v2.0.0 [INFO] [stderr] Compiling icu_normalizer v2.0.0 [INFO] [stderr] Compiling icu_properties v2.0.0 [INFO] [stderr] Compiling tokio-util v0.7.15 [INFO] [stderr] Compiling tower v0.5.2 [INFO] [stderr] Compiling tokio-native-tls v0.3.1 [INFO] [stderr] Compiling h2 v0.4.10 [INFO] [stderr] Compiling serde_spanned v0.6.8 [INFO] [stderr] Compiling toml_datetime v0.6.9 [INFO] [stderr] Compiling serde_json v1.0.140 [INFO] [stderr] Compiling serde_urlencoded v0.7.1 [INFO] [stderr] Compiling idna_adapter v1.2.1 [INFO] [stderr] Compiling toml_edit v0.22.26 [INFO] [stderr] Compiling idna v1.0.3 [INFO] [stderr] Compiling url v2.5.4 [INFO] [stderr] Compiling hyper v1.6.0 [INFO] [stderr] Compiling toml v0.8.22 [INFO] [stderr] Compiling hyper-util v0.1.11 [INFO] [stderr] Compiling hyper-tls v0.6.0 [INFO] [stderr] Compiling reqwest v0.12.15 [INFO] [stderr] Compiling 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 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:33 [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: `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 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:33 [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: 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] = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default [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 { [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 { [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, [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, [INFO] [stdout] 162 | pub metadata: Option>, [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, // 新增:变更类型(added, deleted, modified) [INFO] [stdout] 206 | pub additions: Option>, // 新增:添加的行 [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] 207 | pub deletions: Option>, // 新增:删除的行 [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: 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 { [INFO] [stdout] | ^^^^^^^^^^^^^^^^ [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 { [INFO] [stdout] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished `dev` profile [unoptimized + debuginfo] target(s) in 55.03s [INFO] running `Command { std: "docker" "inspect" "28b2da561e17c0f157fc7dbe57563f49489eeb0c6e4f6bd8ef2d45ec38c5152e", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "28b2da561e17c0f157fc7dbe57563f49489eeb0c6e4f6bd8ef2d45ec38c5152e", kill_on_drop: false }` [INFO] [stdout] 28b2da561e17c0f157fc7dbe57563f49489eeb0c6e4f6bd8ef2d45ec38c5152e [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+d79d87d4c0f7f0d0785ad6e493cf8cf718ed89a6" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }` [INFO] [stdout] c9eb71c1e78828ecce551c1aba7c85b3455ee68c6c6954e06c7aa96d6d93f61d [INFO] running `Command { std: "docker" "start" "-a" "c9eb71c1e78828ecce551c1aba7c85b3455ee68c6c6954e06c7aa96d6d93f61d", kill_on_drop: false }` [INFO] [stderr] Compiling openssl v0.10.72 [INFO] [stderr] Compiling tempfile v3.20.0 [INFO] [stderr] Compiling native-tls v0.2.14 [INFO] [stderr] Compiling tokio-native-tls v0.3.1 [INFO] [stderr] Compiling hyper-tls v0.6.0 [INFO] [stderr] Compiling reqwest v0.12.15 [INFO] [stderr] Compiling 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 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:33 [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: `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: `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 { [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 { [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 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 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 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: `file` [INFO] [stdout] --> src/tree_sitter_analyzer/parse_utils.rs:65:33 [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: `file` [INFO] [stdout] --> src/tree_sitter_analyzer/parse_utils.rs:65:33 [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 { [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 { [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 { [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, [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, [INFO] [stdout] 162 | pub metadata: Option>, [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, // 新增:变更类型(added, deleted, modified) [INFO] [stdout] 206 | pub additions: Option>, // 新增:添加的行 [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] 207 | pub deletions: Option>, // 新增:删除的行 [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 { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stdout] warning: unused variable: `file` [INFO] [stdout] --> src/tree_sitter_analyzer/parse_utils.rs:65:33 [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] = 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: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] [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: 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 { [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 { [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 { [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, [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, [INFO] [stdout] 162 | pub metadata: Option>, [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, // 新增:变更类型(added, deleted, modified) [INFO] [stdout] 206 | pub additions: Option>, // 新增:添加的行 [INFO] [stdout] | ^^^^^^^^^ [INFO] [stdout] 207 | pub deletions: Option>, // 新增:删除的行 [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 { [INFO] [stdout] | ^^^^^^^^^^^^^^^ [INFO] [stdout] [INFO] [stdout] [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 21.90s [INFO] running `Command { std: "docker" "inspect" "c9eb71c1e78828ecce551c1aba7c85b3455ee68c6c6954e06c7aa96d6d93f61d", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "c9eb71c1e78828ecce551c1aba7c85b3455ee68c6c6954e06c7aa96d6d93f61d", kill_on_drop: false }` [INFO] [stdout] c9eb71c1e78828ecce551c1aba7c85b3455ee68c6c6954e06c7aa96d6d93f61d [INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc2/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+d79d87d4c0f7f0d0785ad6e493cf8cf718ed89a6" "test" "--frozen", kill_on_drop: false }` [INFO] [stdout] d48c9d7634ece6947def9e7446069811f5f279f7e21b0d0965f96fa0710a56f4 [INFO] running `Command { std: "docker" "start" "-a" "d48c9d7634ece6947def9e7446069811f5f279f7e21b0d0965f96fa0710a56f4", kill_on_drop: false }` [INFO] [stderr] warning: unused import: `AIError` [INFO] [stderr] --> src/ai_module/prompt_handler.rs:2:27 [INFO] [stderr] | [INFO] [stderr] 2 | use crate::core::errors::{AIError, AppError}; [INFO] [stderr] | ^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default [INFO] [stderr] [INFO] [stderr] warning: unused import: `DiffAnalysis` [INFO] [stderr] --> src/command_processing/review.rs:7:78 [INFO] [stderr] | [INFO] [stderr] 7 | use crate::tree_sitter_analyzer::core::{GitDiff, ChangePattern, ChangeScope, DiffAnalysis}; [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::collections::HashMap` [INFO] [stderr] --> src/review_engine/mod.rs:5:5 [INFO] [stderr] | [INFO] [stderr] 5 | use std::collections::HashMap; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused variable: `source_bytes` [INFO] [stderr] --> src/tree_sitter_analyzer/analyzer.rs:746:13 [INFO] [stderr] | [INFO] [stderr] 746 | let source_bytes = file_ast.source.as_bytes(); [INFO] [stderr] | ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_source_bytes` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default [INFO] [stderr] [INFO] [stderr] warning: unused variable: `source_bytes` [INFO] [stderr] --> src/tree_sitter_analyzer/analyzer.rs:793:13 [INFO] [stderr] | [INFO] [stderr] 793 | let source_bytes = file_ast.source.as_bytes(); [INFO] [stderr] | ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_source_bytes` [INFO] [stderr] [INFO] [stderr] warning: unused variable: `file` [INFO] [stderr] --> src/tree_sitter_analyzer/parse_utils.rs:65:33 [INFO] [stderr] | [INFO] [stderr] 65 | if let Some(ref mut file) = current_file { [INFO] [stderr] | ^^^^ help: if this is intentional, prefix it with an underscore: `_file` [INFO] [stderr] [INFO] [stderr] warning: function `parse_line_range` is never used [INFO] [stderr] --> src/tree_sitter_analyzer/core.rs:353:4 [INFO] [stderr] | [INFO] [stderr] 353 | fn parse_line_range(range_str: &str) -> LineRange { [INFO] [stderr] | ^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default [INFO] [stderr] [INFO] [stderr] warning: `gitie` (lib) generated 7 warnings (run `cargo fix --lib -p gitie` to apply 3 suggestions) [INFO] [stderr] warning: `gitie` (lib test) generated 7 warnings (7 duplicates) [INFO] [stderr] warning: unused import: `Path` [INFO] [stderr] --> tests/tree_sitter_analyzer_tests.rs:3:17 [INFO] [stderr] | [INFO] [stderr] 3 | use std::path::{Path, PathBuf}; [INFO] [stderr] | ^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_imports)]` (part of `#[warn(unused)]`) on by default [INFO] [stderr] [INFO] [stderr] warning: unused import: `tree_sitter::Tree` [INFO] [stderr] --> tests/tree_sitter_analyzer_tests.rs:4:5 [INFO] [stderr] | [INFO] [stderr] 4 | use tree_sitter::Tree; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `std::fs` [INFO] [stderr] --> tests/tree_sitter_analyzer_tests.rs:39:9 [INFO] [stderr] | [INFO] [stderr] 39 | use std::fs; [INFO] [stderr] | ^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `tempfile::TempDir` [INFO] [stderr] --> tests/tree_sitter_analyzer_tests.rs:40:9 [INFO] [stderr] | [INFO] [stderr] 40 | use tempfile::TempDir; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused variable: `diff_text` [INFO] [stderr] --> tests/tree_sitter_analyzer_tests.rs:21:19 [INFO] [stderr] | [INFO] [stderr] 21 | fn parse_git_diff(diff_text: &str) -> Result { [INFO] [stderr] | ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_diff_text` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default [INFO] [stderr] [INFO] [stderr] warning: function `get_tree_sitter_rust` is never used [INFO] [stderr] --> tests/tree_sitter_analyzer_tests.rs:11:4 [INFO] [stderr] | [INFO] [stderr] 11 | fn get_tree_sitter_rust() -> tree_sitter::Language { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default [INFO] [stderr] [INFO] [stderr] warning: function `get_tree_sitter_java` is never used [INFO] [stderr] --> tests/tree_sitter_analyzer_tests.rs:16:4 [INFO] [stderr] | [INFO] [stderr] 16 | fn get_tree_sitter_java() -> tree_sitter::Language { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function `parse_git_diff` is never used [INFO] [stderr] --> tests/tree_sitter_analyzer_tests.rs:21:4 [INFO] [stderr] | [INFO] [stderr] 21 | fn parse_git_diff(diff_text: &str) -> Result { [INFO] [stderr] | ^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused imports: `detect_language_from_path`, `parse_simple_diff`, and `summarize_languages` [INFO] [stderr] --> src/tree_sitter_analyzer/mod.rs:14:29 [INFO] [stderr] | [INFO] [stderr] 14 | pub use self::simple_diff::{parse_simple_diff, detect_language_from_path, summarize_languages}; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused imports: `detect_language` and `parse_git_diff_text` [INFO] [stderr] --> src/tree_sitter_analyzer/mod.rs:15:29 [INFO] [stderr] | [INFO] [stderr] 15 | pub use self::parse_utils::{parse_git_diff_text, detect_language}; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `self::java::JavaProjectStructure` [INFO] [stderr] --> src/tree_sitter_analyzer/mod.rs:16:9 [INFO] [stderr] | [INFO] [stderr] 16 | pub use self::java::JavaProjectStructure; // Moved back to java.rs [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused imports: `JavaChangePattern`, `JavaClassRelation`, `JavaClass`, `JavaMethodParam`, `JavaMethod`, `JavaPackage`, and `JavaRelationType` [INFO] [stderr] --> src/tree_sitter_analyzer/mod.rs:17:22 [INFO] [stderr] | [INFO] [stderr] 17 | pub use self::java::{JavaClass, JavaMethod, JavaMethodParam, JavaClassRelation, JavaRelationType, JavaPackage, JavaChangePattern}; [INFO] [stderr] | ^^^^^^^^^ ^^^^^^^^^^ ^^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^ ^^^^^^^^^^^^^^^^ ^^^^^^^^^^^ ^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `self::rust::RustChangePattern` [INFO] [stderr] --> src/tree_sitter_analyzer/mod.rs:18:9 [INFO] [stderr] | [INFO] [stderr] 18 | pub use self::rust::RustChangePattern; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused import: `explain_git_command_output` [INFO] [stderr] --> src/main.rs:10:54 [INFO] [stderr] | [INFO] [stderr] 10 | use crate::ai_module::explainer::{explain_git_error, explain_git_command_output}; [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: unused variable: `file` [INFO] [stderr] --> src/tree_sitter_analyzer/parse_utils.rs:65:33 [INFO] [stderr] | [INFO] [stderr] 65 | if let Some(ref mut file) = current_file { [INFO] [stderr] | ^^^^ help: if this is intentional, prefix it with an underscore: `_file` [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default [INFO] [stderr] [INFO] [stderr] warning: unused variable: `source_bytes` [INFO] [stderr] --> src/tree_sitter_analyzer/analyzer.rs:746:13 [INFO] [stderr] | [INFO] [stderr] 746 | let source_bytes = file_ast.source.as_bytes(); [INFO] [stderr] | ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_source_bytes` [INFO] [stderr] [INFO] [stderr] warning: function `load_prompt_file` is never used [INFO] [stderr] --> src/ai_module/prompt_handler.rs:8:8 [INFO] [stderr] | [INFO] [stderr] 8 | pub fn load_prompt_file(filename: &str, prompt_dirs: &[String]) -> Result { [INFO] [stderr] | ^^^^^^^^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default [INFO] [stderr] [INFO] [stderr] warning: function `get_prompt_directories` is never used [INFO] [stderr] --> src/ai_module/prompt_handler.rs:118:8 [INFO] [stderr] | [INFO] [stderr] 118 | pub fn get_prompt_directories(_config: &AppConfig) -> Vec { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: enum `RuleCategory` is never used [INFO] [stderr] --> src/review_engine/mod.rs:12:10 [INFO] [stderr] | [INFO] [stderr] 12 | pub enum RuleCategory { [INFO] [stderr] | ^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: enum `Severity` is never used [INFO] [stderr] --> src/review_engine/mod.rs:29:10 [INFO] [stderr] | [INFO] [stderr] 29 | pub enum Severity { [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: struct `SimpleReviewResult` is never constructed [INFO] [stderr] --> src/review_engine/mod.rs:53:12 [INFO] [stderr] | [INFO] [stderr] 53 | pub struct SimpleReviewResult { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: struct `SimpleReviewer` is never constructed [INFO] [stderr] --> src/review_engine/mod.rs:63:12 [INFO] [stderr] | [INFO] [stderr] 63 | pub struct SimpleReviewer { [INFO] [stderr] | ^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: associated items `new` and `review` are never used [INFO] [stderr] --> src/review_engine/mod.rs:70:12 [INFO] [stderr] | [INFO] [stderr] 68 | impl SimpleReviewer { [INFO] [stderr] | ------------------- associated items in this implementation [INFO] [stderr] 69 | /// 创建新的代码评审器 [INFO] [stderr] 70 | pub fn new(config: TreeSitterConfig) -> Self { [INFO] [stderr] | ^^^ [INFO] [stderr] ... [INFO] [stderr] 75 | pub fn review(&self, diff: &GitDiff) -> Vec { [INFO] [stderr] | ^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: variant `Renamed` is never constructed [INFO] [stderr] --> src/tree_sitter_analyzer/core.rs:78:5 [INFO] [stderr] | [INFO] [stderr] 74 | pub enum ChangeType { [INFO] [stderr] | ---------- variant in this enum [INFO] [stderr] ... [INFO] [stderr] 78 | Renamed, [INFO] [stderr] | ^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `ChangeType` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis [INFO] [stderr] [INFO] [stderr] warning: fields `start` and `count` are never read [INFO] [stderr] --> src/tree_sitter_analyzer/core.rs:88:9 [INFO] [stderr] | [INFO] [stderr] 87 | pub struct LineRange { [INFO] [stderr] | --------- fields in this struct [INFO] [stderr] 88 | pub start: u32, [INFO] [stderr] | ^^^^^ [INFO] [stderr] 89 | pub count: u32, [INFO] [stderr] | ^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `LineRange` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis [INFO] [stderr] [INFO] [stderr] warning: field `old_path` is never read [INFO] [stderr] --> src/tree_sitter_analyzer/core.rs:121:9 [INFO] [stderr] | [INFO] [stderr] 119 | pub struct FileDiff { [INFO] [stderr] | -------- field in this struct [INFO] [stderr] 120 | pub path: PathBuf, [INFO] [stderr] 121 | pub old_path: Option, [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `FileDiff` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis [INFO] [stderr] [INFO] [stderr] warning: field `metadata` is never read [INFO] [stderr] --> src/tree_sitter_analyzer/core.rs:162:9 [INFO] [stderr] | [INFO] [stderr] 160 | pub struct GitDiff { [INFO] [stderr] | ------- field in this struct [INFO] [stderr] 161 | pub changed_files: Vec, [INFO] [stderr] 162 | pub metadata: Option>, [INFO] [stderr] | ^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `GitDiff` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis [INFO] [stderr] [INFO] [stderr] warning: methods `total_lines` and `changed_lines` are never used [INFO] [stderr] --> src/tree_sitter_analyzer/core.rs:170:12 [INFO] [stderr] | [INFO] [stderr] 168 | impl GitDiff { [INFO] [stderr] | ------------ methods in this implementation [INFO] [stderr] 169 | /// Counts the total number of lines in the diff [INFO] [stderr] 170 | pub fn total_lines(&self) -> usize { [INFO] [stderr] | ^^^^^^^^^^^ [INFO] [stderr] ... [INFO] [stderr] 181 | pub fn changed_lines(&self) -> usize { [INFO] [stderr] | ^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: fields `line_range`, `additions`, and `deletions` are never read [INFO] [stderr] --> src/tree_sitter_analyzer/core.rs:204:9 [INFO] [stderr] | [INFO] [stderr] 198 | pub struct AffectedNode { [INFO] [stderr] | ------------ fields in this struct [INFO] [stderr] ... [INFO] [stderr] 204 | pub line_range: (usize, usize), [INFO] [stderr] | ^^^^^^^^^^ [INFO] [stderr] 205 | pub change_type: Option, // 新增:变更类型(added, deleted, modified) [INFO] [stderr] 206 | pub additions: Option>, // 新增:添加的行 [INFO] [stderr] | ^^^^^^^^^ [INFO] [stderr] 207 | pub deletions: Option>, // 新增:删除的行 [INFO] [stderr] | ^^^^^^^^^ [INFO] [stderr] | [INFO] [stderr] = note: `AffectedNode` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis [INFO] [stderr] [INFO] [stderr] warning: function `parse_line_range` is never used [INFO] [stderr] --> src/tree_sitter_analyzer/core.rs:353:4 [INFO] [stderr] | [INFO] [stderr] 353 | fn parse_line_range(range_str: &str) -> LineRange { [INFO] [stderr] | ^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function `generate_overall_summary` is never used [INFO] [stderr] --> src/tree_sitter_analyzer/core.rs:372:8 [INFO] [stderr] | [INFO] [stderr] 372 | pub fn generate_overall_summary(file_analyses: &[FileAnalysis]) -> String { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: method `create_simple_git_diff` is never used [INFO] [stderr] --> src/tree_sitter_analyzer/analyzer.rs:66:12 [INFO] [stderr] | [INFO] [stderr] 42 | impl TreeSitterAnalyzer { [INFO] [stderr] | ----------------------- method in this implementation [INFO] [stderr] ... [INFO] [stderr] 66 | pub fn create_simple_git_diff(&self, diff_text: &str) -> GitDiff { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: enum `JavaChangePattern` is never used [INFO] [stderr] --> src/tree_sitter_analyzer/java.rs:204:10 [INFO] [stderr] | [INFO] [stderr] 204 | pub enum JavaChangePattern { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function `to_generic_change_pattern` is never used [INFO] [stderr] --> src/tree_sitter_analyzer/java.rs:214:8 [INFO] [stderr] | [INFO] [stderr] 214 | pub fn to_generic_change_pattern(java_pattern: JavaChangePattern) -> ChangePattern { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: enum `RustChangePattern` is never used [INFO] [stderr] --> src/tree_sitter_analyzer/rust.rs:11:10 [INFO] [stderr] | [INFO] [stderr] 11 | pub enum RustChangePattern { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function `to_generic_change_pattern` is never used [INFO] [stderr] --> src/tree_sitter_analyzer/rust.rs:25:8 [INFO] [stderr] | [INFO] [stderr] 25 | pub fn to_generic_change_pattern(rust_pattern: RustChangePattern) -> ChangePattern { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function `summarize_languages` is never used [INFO] [stderr] --> src/tree_sitter_analyzer/simple_diff.rs:119:8 [INFO] [stderr] | [INFO] [stderr] 119 | pub fn summarize_languages(git_diff: &GitDiff) -> Vec<(String, usize)> { [INFO] [stderr] | ^^^^^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: function `detect_language` is never used [INFO] [stderr] --> src/tree_sitter_analyzer/parse_utils.rs:134:8 [INFO] [stderr] | [INFO] [stderr] 134 | pub fn detect_language(path: &PathBuf) -> Option { [INFO] [stderr] | ^^^^^^^^^^^^^^^ [INFO] [stderr] [INFO] [stderr] warning: `gitie` (test "tree_sitter_analyzer_tests") generated 8 warnings (run `cargo fix --test "tree_sitter_analyzer_tests"` to apply 4 suggestions) [INFO] [stderr] warning: `gitie` (bin "gitie" test) generated 34 warnings (4 duplicates) (run `cargo fix --bin "gitie" --tests` to apply 6 suggestions) [INFO] [stderr] warning: `gitie` (bin "gitie") generated 34 warnings (34 duplicates) [INFO] [stderr] Finished `test` profile [unoptimized + debuginfo] target(s) in 0.22s [INFO] [stderr] Running unittests src/lib.rs (/opt/rustwide/target/debug/deps/gitie-70fe484c92f2048a) [INFO] [stdout] [INFO] [stdout] running 21 tests [INFO] [stdout] test ai_module::explainer::tests::test_git_error_formatting ... ok [INFO] [stdout] test ai_module::explainer::tests::test_explain_git_error_empty_output ... ok [INFO] [stdout] test core::errors::tests::test_app_error_display ... ok [INFO] [stdout] test core::errors::tests::test_git_error_display ... ok [INFO] [stdout] test core::errors::tests::test_config_error_display ... ok [INFO] [stdout] test ai_module::utils::tests::test_clean_ai_output_no_closing_tag_leaves_untouched_if_regex_is_strict ... ok [INFO] [stdout] test ai_module::utils::tests::text_clean_ai_output_no_tags ... ok [INFO] [stdout] test ai_module::utils::tests::test_clean_ai_output_tags_with_attributes_ignored_by_current_regex ... ok [INFO] [stdout] test ai_module::utils::tests::test_clean_ai_output_tag_at_end ... ok [INFO] [stdout] test ai_module::utils::tests::test_clean_ai_output_empty_tag ... ok [INFO] [stdout] test ai_module::utils::tests::test_clean_ai_output_single_tag ... ok [INFO] [stdout] test ai_module::utils::tests::test_clean_ai_output_multiline_tag ... ok [INFO] [stdout] test ai_module::utils::tests::test_clean_ai_output_multiple_tags ... ok [INFO] [stdout] test ai_module::utils::tests::test_clean_ai_output_only_tag ... ok [INFO] [stdout] test ai_module::utils::tests::test_complex_scenario_with_varied_spacing_and_content ... ok [INFO] [stdout] test ai_module::utils::tests::test_clean_ai_output_tag_at_start ... ok [INFO] [stdout] test git_module::tests::test_passthrough_with_error_handling_empty_args ... ok [INFO] [stdout] test ai_module::utils::tests::test_clean_ai_output_nested_tags_not_specifically_handled_outermost_wins ... ok [INFO] [stdout] test git_module::tests::test_passthrough_with_error_handling_success ... ok [INFO] [stdout] test git_module::tests::test_passthrough_with_error_handling_failure ... ok [INFO] [stdout] test core::errors::tests::test_ai_error_display ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 21 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.17s [INFO] [stdout] [INFO] [stderr] Running unittests src/main.rs (/opt/rustwide/target/debug/deps/gitie-7344434e14391cbd) [INFO] [stdout] [INFO] [stdout] running 21 tests [INFO] [stdout] test ai_module::explainer::tests::test_git_error_formatting ... ok [INFO] [stdout] test ai_module::explainer::tests::test_explain_git_error_empty_output ... ok [INFO] [stdout] test core::errors::tests::test_app_error_display ... ok [INFO] [stdout] test core::errors::tests::test_git_error_display ... ok [INFO] [stdout] test core::errors::tests::test_config_error_display ... ok [INFO] [stdout] test ai_module::utils::tests::test_clean_ai_output_empty_tag ... ok [INFO] [stdout] test ai_module::utils::tests::test_clean_ai_output_multiline_tag ... ok [INFO] [stdout] test ai_module::utils::tests::test_clean_ai_output_single_tag ... ok [INFO] [stdout] test ai_module::utils::tests::test_clean_ai_output_multiple_tags ... ok [INFO] [stdout] test ai_module::utils::tests::test_clean_ai_output_only_tag ... ok [INFO] [stdout] test ai_module::utils::tests::text_clean_ai_output_no_tags ... ok [INFO] [stdout] test ai_module::utils::tests::test_clean_ai_output_tag_at_end ... ok [INFO] [stdout] test ai_module::utils::tests::test_clean_ai_output_no_closing_tag_leaves_untouched_if_regex_is_strict ... ok [INFO] [stdout] test ai_module::utils::tests::test_clean_ai_output_tags_with_attributes_ignored_by_current_regex ... ok [INFO] [stdout] test ai_module::utils::tests::test_complex_scenario_with_varied_spacing_and_content ... ok [INFO] [stdout] test ai_module::utils::tests::test_clean_ai_output_tag_at_start ... ok [INFO] [stdout] test git_module::tests::test_passthrough_with_error_handling_empty_args ... ok [INFO] [stdout] test ai_module::utils::tests::test_clean_ai_output_nested_tags_not_specifically_handled_outermost_wins ... ok [INFO] [stdout] test git_module::tests::test_passthrough_with_error_handling_success ... ok [INFO] [stdout] test git_module::tests::test_passthrough_with_error_handling_failure ... ok [INFO] [stdout] test core::errors::tests::test_ai_error_display ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 21 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.15s [INFO] [stdout] [INFO] [stderr] Running tests/cli_args_test.rs (/opt/rustwide/target/debug/deps/cli_args_test-05de3d9a55c2fd23) [INFO] [stdout] [INFO] [stdout] running 4 tests [INFO] [stdout] test test_args_contain_ai ... ok [INFO] [stdout] test test_args_contain_help ... ok [INFO] [stdout] test test_args_contain_noai ... ok [INFO] [stdout] test test_should_use_ai ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 4 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.00s [INFO] [stdout] [INFO] [stderr] Running tests/default_ai_behavior_test.rs (/opt/rustwide/target/debug/deps/default_ai_behavior_test-58e68d568455b3b9) [INFO] [stdout] [INFO] [stdout] running 6 tests [INFO] [stdout] test test_ai_flag_backward_compatibility ... ignored, Requires functioning AI service [INFO] [stdout] test test_default_commit_uses_ai ... ignored, Requires functioning AI service [INFO] [stdout] test test_flag_precedence ... ignored, Test needs gitie command to be installed [INFO] [stdout] test test_help_uses_ai_by_default ... ignored, Requires functioning AI service [INFO] [stdout] test test_help_with_noai_disables_ai ... ignored, Test needs gitie command to be installed [INFO] [stdout] test test_noai_flag_disables_ai ... ignored, Test needs gitie command to be installed [INFO] [stdout] [INFO] [stdout] test result: ok. 0 passed; 0 failed; 6 ignored; 0 measured; 0 filtered out; finished in 0.00s [INFO] [stdout] [INFO] [stderr] Running tests/tree_sitter_analyzer_tests.rs (/opt/rustwide/target/debug/deps/tree_sitter_analyzer_tests-d20e16adb57e1373) [INFO] [stdout] [INFO] [stdout] running 8 tests [INFO] [stdout] test tests::test_analyze_diff ... ignored [INFO] [stdout] test tests::test_create_analyzer ... ignored [INFO] [stdout] test tests::test_detect_language ... ignored [INFO] [stdout] test tests::test_java_project_structure ... ignored [INFO] [stdout] test tests::test_java_query_patterns ... ignored [INFO] [stdout] test tests::test_parse_git_diff ... ignored [INFO] [stdout] test tests::test_rust_query_patterns ... ignored [INFO] [stdout] test tests::test_rust_tree_sitter_integration ... ignored [INFO] [stdout] [INFO] [stdout] test result: ok. 0 passed; 0 failed; 8 ignored; 0 measured; 0 filtered out; finished in 0.00s [INFO] [stdout] [INFO] [stderr] Running tests/tree_sitter_tests.rs (/opt/rustwide/target/debug/deps/tree_sitter_tests-95c67b63be148620) [INFO] [stdout] [INFO] [stdout] running 4 tests [INFO] [stdout] test tree_sitter_integration_tests::test_analysis_with_multiple_files ... ok [INFO] [stdout] test tree_sitter_integration_tests::test_tree_sitter_analyzer_creation ... ok [INFO] [stdout] test tree_sitter_integration_tests::test_language_detection ... ok [INFO] [stdout] test tree_sitter_integration_tests::test_diff_parsing ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 4 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.05s [INFO] [stdout] [INFO] [stderr] Doc-tests gitie [INFO] [stdout] [INFO] [stdout] running 1 test [INFO] [stdout] test src/git_module/mod.rs - git_module::execute_git_command_and_capture_output (line 25) ... ok [INFO] [stdout] [INFO] [stdout] test result: ok. 1 passed; 0 failed; 0 ignored; 0 measured; 0 filtered out; finished in 0.04s [INFO] [stdout] [INFO] running `Command { std: "docker" "inspect" "d48c9d7634ece6947def9e7446069811f5f279f7e21b0d0965f96fa0710a56f4", kill_on_drop: false }` [INFO] running `Command { std: "docker" "rm" "-f" "d48c9d7634ece6947def9e7446069811f5f279f7e21b0d0965f96fa0710a56f4", kill_on_drop: false }` [INFO] [stdout] d48c9d7634ece6947def9e7446069811f5f279f7e21b0d0965f96fa0710a56f4