[INFO] cloning repository https://github.com/viettran295/fundamental
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/viettran295/fundamental" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fviettran295%2Ffundamental", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fviettran295%2Ffundamental'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] ec0e28168ea92feb18535700c638d409a8a722fb
[INFO] checking viettran295/fundamental against master#61cc47e367d7be91e13bcd01e4e96e0e233d4f6d for pr-133502-17
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fviettran295%2Ffundamental" "/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/viettran295/fundamental
[INFO] finished tweaking git repo https://github.com/viettran295/fundamental
[INFO] tweaked toml for git repo https://github.com/viettran295/fundamental written to /workspace/builds/worker-6-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/viettran295/fundamental on toolchain 61cc47e367d7be91e13bcd01e4e96e0e233d4f6d
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+61cc47e367d7be91e13bcd01e4e96e0e233d4f6d" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/viettran295/fundamental 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" "+61cc47e367d7be91e13bcd01e4e96e0e233d4f6d" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded arcstr v1.2.0
[INFO] [stderr]   Downloaded axum-core v0.5.6
[INFO] [stderr]   Downloaded redis v1.0.2
[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:845e597a41426bbf2703be69acdb67d10b6de511142d05cba7bbe119c898b2c7" "/opt/rustwide/cargo-home/bin/cargo" "+61cc47e367d7be91e13bcd01e4e96e0e233d4f6d" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 1d0dcdb0d0454224a7f7e47212e58177198178ba1e1174c5903efdcd018e0731
[INFO] running `Command { std: "docker" "start" "-a" "1d0dcdb0d0454224a7f7e47212e58177198178ba1e1174c5903efdcd018e0731", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "1d0dcdb0d0454224a7f7e47212e58177198178ba1e1174c5903efdcd018e0731", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "1d0dcdb0d0454224a7f7e47212e58177198178ba1e1174c5903efdcd018e0731", kill_on_drop: false }`
[INFO] [stdout] 1d0dcdb0d0454224a7f7e47212e58177198178ba1e1174c5903efdcd018e0731
[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:845e597a41426bbf2703be69acdb67d10b6de511142d05cba7bbe119c898b2c7" "/opt/rustwide/cargo-home/bin/cargo" "+61cc47e367d7be91e13bcd01e4e96e0e233d4f6d" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] b42ff65d6aa827ccb049875f1f7e350c2a9b0630632cab364782e48ceb00a293
[INFO] running `Command { std: "docker" "start" "-a" "b42ff65d6aa827ccb049875f1f7e350c2a9b0630632cab364782e48ceb00a293", kill_on_drop: false }`
[INFO] [stderr]    Compiling proc-macro2 v1.0.103
[INFO] [stderr]    Compiling cc v1.2.47
[INFO] [stderr]    Compiling serde v1.0.228
[INFO] [stderr]     Checking signal-hook-registry v1.4.6
[INFO] [stderr]     Checking tracing v0.1.41
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]     Checking bitflags v2.10.0
[INFO] [stderr]    Compiling serde_json v1.0.145
[INFO] [stderr]     Checking regex-syntax v0.8.8
[INFO] [stderr]     Checking indexmap v2.12.1
[INFO] [stderr]     Checking socket2 v0.5.10
[INFO] [stderr]     Checking anstyle-query v1.1.5
[INFO] [stderr]     Checking anstyle v1.0.13
[INFO] [stderr]     Checking is_terminal_polyfill v1.70.2
[INFO] [stderr]     Checking xxhash-rust v0.8.15
[INFO] [stderr]     Checking arcstr v1.2.0
[INFO] [stderr]     Checking jiff v0.2.16
[INFO] [stderr]     Checking quick-xml v0.31.0
[INFO] [stderr]     Checking dotenvy v0.15.7
[INFO] [stderr]     Checking axum-core v0.5.6
[INFO] [stderr]     Checking anstream v0.6.21
[INFO] [stderr]    Compiling quote v1.0.42
[INFO] [stderr]     Checking num-integer v0.1.46
[INFO] [stderr]     Checking chrono v0.4.42
[INFO] [stderr]    Compiling syn v2.0.110
[INFO] [stderr]     Checking regex-automata v0.4.13
[INFO] [stderr]    Compiling openssl-sys v0.9.111
[INFO] [stderr]     Checking num-bigint v0.4.6
[INFO] [stderr]    Compiling openssl v0.10.75
[INFO] [stderr]    Compiling native-tls v0.2.14
[INFO] [stderr]     Checking regex v1.12.2
[INFO] [stderr]     Checking env_filter v0.1.4
[INFO] [stderr]     Checking env_logger v0.11.8
[INFO] [stderr]    Compiling synstructure v0.13.2
[INFO] [stderr]    Compiling tokio-macros v2.6.0
[INFO] [stderr]    Compiling zerovec-derive v0.11.2
[INFO] [stderr]    Compiling displaydoc v0.2.5
[INFO] [stderr]    Compiling futures-macro v0.3.31
[INFO] [stderr]    Compiling serde_derive v1.0.228
[INFO] [stderr]    Compiling openssl-macros v0.1.1
[INFO] [stderr]    Compiling axum-macros v0.5.0
[INFO] [stderr]    Compiling async-trait v0.1.89
[INFO] [stderr]    Compiling zerofrom-derive v0.1.6
[INFO] [stderr]    Compiling yoke-derive v0.8.1
[INFO] [stderr]     Checking futures-util v0.3.31
[INFO] [stderr]     Checking tokio v1.48.0
[INFO] [stderr]     Checking zerofrom v0.1.6
[INFO] [stderr]     Checking yoke v0.8.1
[INFO] [stderr]     Checking zerovec v0.11.5
[INFO] [stderr]     Checking zerotrie v0.2.3
[INFO] [stderr]     Checking tinystr v0.8.2
[INFO] [stderr]     Checking potential_utf v0.1.4
[INFO] [stderr]     Checking icu_collections v2.1.1
[INFO] [stderr]     Checking icu_locale_core v2.1.1
[INFO] [stderr]     Checking icu_provider v2.1.1
[INFO] [stderr]     Checking icu_normalizer v2.1.1
[INFO] [stderr]     Checking icu_properties v2.1.1
[INFO] [stderr]     Checking serde_urlencoded v0.7.1
[INFO] [stderr]     Checking futures-executor v0.3.31
[INFO] [stderr]     Checking futures v0.3.31
[INFO] [stderr]     Checking idna_adapter v1.2.1
[INFO] [stderr]     Checking idna v1.1.0
[INFO] [stderr]     Checking url v2.5.7
[INFO] [stderr]     Checking tokio-util v0.7.17
[INFO] [stderr]     Checking hyper v1.8.1
[INFO] [stderr]     Checking tokio-native-tls v0.3.1
[INFO] [stderr]     Checking tower v0.5.2
[INFO] [stderr]     Checking h2 v0.3.27
[INFO] [stderr]     Checking combine v4.6.7
[INFO] [stderr]     Checking hyper-util v0.1.19
[INFO] [stderr]     Checking axum v0.8.8
[INFO] [stderr]     Checking hyper v0.14.32
[INFO] [stderr]     Checking redis v1.0.2
[INFO] [stderr]     Checking hyper-tls v0.5.0
[INFO] [stderr]     Checking reqwest v0.11.27
[INFO] [stderr]     Checking fundamental v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: enum `DataManagerError` is never used
[INFO] [stdout]  --> src/data/mod.rs:6:10
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub enum DataManagerError {
[INFO] [stdout]   |          ^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `DataManager` is never used
[INFO] [stdout]   --> src/data/mod.rs:14:11
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub trait DataManager<K, V> {
[INFO] [stdout]    |           ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `DragonFlyCache` is never constructed
[INFO] [stdout]  --> src/data/dragonfly_cache.rs:7:12
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub struct DragonFlyCache {
[INFO] [stdout]   |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `StatementHistory` is never constructed
[INFO] [stdout]   --> src/financial_stmt/mod.rs:12:12
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub struct StatementHistory<T> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `default` and `fill_history` are never used
[INFO] [stdout]   --> src/financial_stmt/mod.rs:17:12
[INFO] [stdout]    |
[INFO] [stdout] 16 | impl<T: FinancialStatement> StatementHistory<T> {
[INFO] [stdout]    | ----------------------------------------------- associated items in this implementation
[INFO] [stdout] 17 |     pub fn default() -> Self {
[INFO] [stdout]    |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 22 |     pub fn fill_history(&mut self, json_data: &Value) -> Result<(), Box<dyn std::error::Error>> {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `MAX_HISTORY_YEARS` and `parse_history` are never used
[INFO] [stdout]   --> src/financial_stmt/mod.rs:30:11
[INFO] [stdout]    |
[INFO] [stdout] 29 | pub trait FinancialStatement: Default {
[INFO] [stdout]    |           ------------------ associated items in this trait
[INFO] [stdout] 30 |     const MAX_HISTORY_YEARS: usize = 5;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 70 |     fn parse_history(
[INFO] [stdout]    |        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `client` is never read
[INFO] [stdout]   --> src/financial_stmt/sec_client.rs:11:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub struct ConfiguredHttpClient {
[INFO] [stdout]    |            -------------------- field in this struct
[INFO] [stdout] 11 |     client: reqwest::Client,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ConfiguredHttpClient` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `client` is never used
[INFO] [stdout]   --> src/financial_stmt/sec_client.rs:28:12
[INFO] [stdout]    |
[INFO] [stdout] 14 | impl ConfiguredHttpClient {
[INFO] [stdout]    | ------------------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 28 |     pub fn client(&self) -> &reqwest::Client {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `CompanyTickers` is never constructed
[INFO] [stdout]   --> src/financial_stmt/sec_client.rs:44:12
[INFO] [stdout]    |
[INFO] [stdout] 44 | pub struct CompanyTickers {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `SICResponse` is never constructed
[INFO] [stdout]   --> src/financial_stmt/sec_client.rs:51:12
[INFO] [stdout]    |
[INFO] [stdout] 51 | pub struct SICResponse {
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `http_client` is never read
[INFO] [stdout]   --> src/financial_stmt/sec_client.rs:68:5
[INFO] [stdout]    |
[INFO] [stdout] 66 | pub struct SecClient {
[INFO] [stdout]    |            --------- field in this struct
[INFO] [stdout] 67 |     ticker: String,
[INFO] [stdout] 68 |     http_client: ConfiguredHttpClient,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `SecClient` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `COMPANY_TICKERS_SIMPLIFIED`, `SUBMISSIONS_BASE_URL`, `SIC_BASE_URL`, `fetch_sic`, and `fetch_all_company_tickers` are never used
[INFO] [stdout]    --> src/financial_stmt/sec_client.rs:75:11
[INFO] [stdout]     |
[INFO] [stdout]  71 | impl SecClient {
[INFO] [stdout]     | -------------- associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  75 |     const COMPANY_TICKERS_SIMPLIFIED: &str = "https://www.sec.gov/files/company_tickers.json";
[INFO] [stdout]     |           ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]  76 |     /// Base URL for submission data
[INFO] [stdout]  77 |     const SUBMISSIONS_BASE_URL: &str = "https://data.sec.gov/submissions";
[INFO] [stdout]     |           ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  80 |     const SIC_BASE_URL: &str =
[INFO] [stdout]     |           ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  95 |     pub async fn fetch_sic(&self) -> Result<String, Box<dyn std::error::Error>> {
[INFO] [stdout]     |                  ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 109 |     pub async fn fetch_all_company_tickers(
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `fetch_xml` is never used
[INFO] [stdout]   --> src/interface/mod.rs:19:14
[INFO] [stdout]    |
[INFO] [stdout]  5 | pub trait HttpClient<T> {
[INFO] [stdout]    |           ---------- associated function in this trait
[INFO] [stdout] ...
[INFO] [stdout] 19 |     async fn fetch_xml(url: &str) -> Result<String, Self::Error> {
[INFO] [stdout]    |              ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Processor` is never constructed
[INFO] [stdout]  --> src/processor/mod.rs:8:12
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub struct Processor {
[INFO] [stdout]   |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `MAX_CONCURRENT_REQUESTS`, `map_company_by_industry`, and `extract_sic` are never used
[INFO] [stdout]   --> src/processor/mod.rs:15:11
[INFO] [stdout]    |
[INFO] [stdout] 14 | impl Processor {
[INFO] [stdout]    | -------------- associated items in this implementation
[INFO] [stdout] 15 |     const MAX_CONCURRENT_REQUESTS: usize = 8;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 16 |     pub async fn map_company_by_industry(&mut self) -> Result<(), Box<dyn std::error::Error>> {
[INFO] [stdout]    |                  ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 44 |     fn extract_sic(xml: &str) -> Result<Option<String>, Box<dyn std::error::Error>> {
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Ratios` is never constructed
[INFO] [stdout]  --> src/ratios/mod.rs:1:12
[INFO] [stdout]   |
[INFO] [stdout] 1 | pub struct Ratios;
[INFO] [stdout]   |            ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated functions are never used
[INFO] [stdout]   --> src/ratios/mod.rs:8:12
[INFO] [stdout]    |
[INFO] [stdout]  3 | impl Ratios {
[INFO] [stdout]    | ----------- associated functions in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  8 |     pub fn current_ratio(current_assets: f64, current_liabilities: f64) -> f64 {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 17 |     pub fn quick_ratio(current_assets: f64, current_liabilities: f64, inventory: f64) -> f64 {
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 28 |     pub fn equity_ratio(total_equity: f64, total_asset: f64) -> f64 {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 37 |     pub fn debt_ratio(total_liabilities: f64, total_asset: f64) -> f64 {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 47 |     pub fn debt_to_equity_ratio(total_liabilities: f64, total_equity: f64) -> f64 {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 56 |     pub fn gross_profit_margin(gross_income: f64, total_revenue: f64) -> f64 {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 65 |     pub fn operating_profit_margin(gross_income: f64, total_revenue: f64) -> f64 {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 74 |     pub fn net_profit_margin(net_income: f64, total_revenue: f64) -> f64 {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `DataManagerError` is never used
[INFO] [stdout]  --> src/data/mod.rs:6:10
[INFO] [stdout]   |
[INFO] [stdout] 6 | pub enum DataManagerError {
[INFO] [stdout]   |          ^^^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: trait `DataManager` is never used
[INFO] [stdout]   --> src/data/mod.rs:14:11
[INFO] [stdout]    |
[INFO] [stdout] 14 | pub trait DataManager<K, V> {
[INFO] [stdout]    |           ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `DragonFlyCache` is never constructed
[INFO] [stdout]  --> src/data/dragonfly_cache.rs:7:12
[INFO] [stdout]   |
[INFO] [stdout] 7 | pub struct DragonFlyCache {
[INFO] [stdout]   |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `StatementHistory` is never constructed
[INFO] [stdout]   --> src/financial_stmt/mod.rs:12:12
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub struct StatementHistory<T> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `default` and `fill_history` are never used
[INFO] [stdout]   --> src/financial_stmt/mod.rs:17:12
[INFO] [stdout]    |
[INFO] [stdout] 16 | impl<T: FinancialStatement> StatementHistory<T> {
[INFO] [stdout]    | ----------------------------------------------- associated items in this implementation
[INFO] [stdout] 17 |     pub fn default() -> Self {
[INFO] [stdout]    |            ^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 22 |     pub fn fill_history(&mut self, json_data: &Value) -> Result<(), Box<dyn std::error::Error>> {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `MAX_HISTORY_YEARS` and `parse_history` are never used
[INFO] [stdout]   --> src/financial_stmt/mod.rs:30:11
[INFO] [stdout]    |
[INFO] [stdout] 29 | pub trait FinancialStatement: Default {
[INFO] [stdout]    |           ------------------ associated items in this trait
[INFO] [stdout] 30 |     const MAX_HISTORY_YEARS: usize = 5;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 70 |     fn parse_history(
[INFO] [stdout]    |        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `client` is never read
[INFO] [stdout]   --> src/financial_stmt/sec_client.rs:11:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub struct ConfiguredHttpClient {
[INFO] [stdout]    |            -------------------- field in this struct
[INFO] [stdout] 11 |     client: reqwest::Client,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ConfiguredHttpClient` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `client` is never used
[INFO] [stdout]   --> src/financial_stmt/sec_client.rs:28:12
[INFO] [stdout]    |
[INFO] [stdout] 14 | impl ConfiguredHttpClient {
[INFO] [stdout]    | ------------------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 28 |     pub fn client(&self) -> &reqwest::Client {
[INFO] [stdout]    |            ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `CompanyTickers` is never constructed
[INFO] [stdout]   --> src/financial_stmt/sec_client.rs:44:12
[INFO] [stdout]    |
[INFO] [stdout] 44 | pub struct CompanyTickers {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `SICResponse` is never constructed
[INFO] [stdout]   --> src/financial_stmt/sec_client.rs:51:12
[INFO] [stdout]    |
[INFO] [stdout] 51 | pub struct SICResponse {
[INFO] [stdout]    |            ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `http_client` is never read
[INFO] [stdout]   --> src/financial_stmt/sec_client.rs:68:5
[INFO] [stdout]    |
[INFO] [stdout] 66 | pub struct SecClient {
[INFO] [stdout]    |            --------- field in this struct
[INFO] [stdout] 67 |     ticker: String,
[INFO] [stdout] 68 |     http_client: ConfiguredHttpClient,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `SecClient` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `COMPANY_TICKERS_SIMPLIFIED`, `SUBMISSIONS_BASE_URL`, `SIC_BASE_URL`, `fetch_sic`, and `fetch_all_company_tickers` are never used
[INFO] [stdout]    --> src/financial_stmt/sec_client.rs:75:11
[INFO] [stdout]     |
[INFO] [stdout]  71 | impl SecClient {
[INFO] [stdout]     | -------------- associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  75 |     const COMPANY_TICKERS_SIMPLIFIED: &str = "https://www.sec.gov/files/company_tickers.json";
[INFO] [stdout]     |           ^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]  76 |     /// Base URL for submission data
[INFO] [stdout]  77 |     const SUBMISSIONS_BASE_URL: &str = "https://data.sec.gov/submissions";
[INFO] [stdout]     |           ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  80 |     const SIC_BASE_URL: &str =
[INFO] [stdout]     |           ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  95 |     pub async fn fetch_sic(&self) -> Result<String, Box<dyn std::error::Error>> {
[INFO] [stdout]     |                  ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 109 |     pub async fn fetch_all_company_tickers(
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `fetch_xml` is never used
[INFO] [stdout]   --> src/interface/mod.rs:19:14
[INFO] [stdout]    |
[INFO] [stdout]  5 | pub trait HttpClient<T> {
[INFO] [stdout]    |           ---------- associated function in this trait
[INFO] [stdout] ...
[INFO] [stdout] 19 |     async fn fetch_xml(url: &str) -> Result<String, Self::Error> {
[INFO] [stdout]    |              ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Processor` is never constructed
[INFO] [stdout]  --> src/processor/mod.rs:8:12
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub struct Processor {
[INFO] [stdout]   |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `MAX_CONCURRENT_REQUESTS`, `map_company_by_industry`, and `extract_sic` are never used
[INFO] [stdout]   --> src/processor/mod.rs:15:11
[INFO] [stdout]    |
[INFO] [stdout] 14 | impl Processor {
[INFO] [stdout]    | -------------- associated items in this implementation
[INFO] [stdout] 15 |     const MAX_CONCURRENT_REQUESTS: usize = 8;
[INFO] [stdout]    |           ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 16 |     pub async fn map_company_by_industry(&mut self) -> Result<(), Box<dyn std::error::Error>> {
[INFO] [stdout]    |                  ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 44 |     fn extract_sic(xml: &str) -> Result<Option<String>, Box<dyn std::error::Error>> {
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `operating_profit_margin` is never used
[INFO] [stdout]   --> src/ratios/mod.rs:65:12
[INFO] [stdout]    |
[INFO] [stdout]  3 | impl Ratios {
[INFO] [stdout]    | ----------- associated function in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 65 |     pub fn operating_profit_margin(gross_income: f64, total_revenue: f64) -> f64 {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 59.51s
[INFO] running `Command { std: "docker" "inspect" "b42ff65d6aa827ccb049875f1f7e350c2a9b0630632cab364782e48ceb00a293", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "b42ff65d6aa827ccb049875f1f7e350c2a9b0630632cab364782e48ceb00a293", kill_on_drop: false }`
[INFO] [stdout] b42ff65d6aa827ccb049875f1f7e350c2a9b0630632cab364782e48ceb00a293
