[INFO] cloning repository https://github.com/dkzhang/gen_svg
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/dkzhang/gen_svg" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fdkzhang%2Fgen_svg", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fdkzhang%2Fgen_svg'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 8087feed68c61bb83c9d657cd232c1d8c862c7fc
[INFO] checking dkzhang/gen_svg against try#d336647335db03a0fc5b24fc5325cd3905c5b8e8 for pr-151146
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fdkzhang%2Fgen_svg" "/workspace/builds/worker-1-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-1-tc2/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/dkzhang/gen_svg
[INFO] finished tweaking git repo https://github.com/dkzhang/gen_svg
[INFO] tweaked toml for git repo https://github.com/dkzhang/gen_svg written to /workspace/builds/worker-1-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/dkzhang/gen_svg on toolchain d336647335db03a0fc5b24fc5325cd3905c5b8e8
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+d336647335db03a0fc5b24fc5325cd3905c5b8e8" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/dkzhang/gen_svg 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" "+d336647335db03a0fc5b24fc5325cd3905c5b8e8" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded svg v0.13.1
[INFO] [stderr]   Downloaded windows-targets v0.48.2
[INFO] [stderr]   Downloaded thiserror-impl v1.0.46
[INFO] [stderr]   Downloaded simplelog v0.11.2
[INFO] [stderr]   Downloaded matchit v0.7.2
[INFO] [stderr]   Downloaded thiserror v1.0.46
[INFO] [stderr]   Downloaded windows_aarch64_gnullvm v0.48.2
[INFO] [stderr]   Downloaded windows_x86_64_gnullvm v0.48.2
[INFO] [stderr]   Downloaded windows_aarch64_msvc v0.48.2
[INFO] [stderr]   Downloaded windows_i686_msvc v0.48.2
[INFO] [stderr]   Downloaded windows_i686_gnu v0.48.2
[INFO] [stderr]   Downloaded windows_x86_64_gnu v0.48.2
[INFO] [stderr]   Downloaded windows_x86_64_msvc v0.48.2
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-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:98afbf2d16093dec2546ff8915fddc74e65664aa03fc460b3712b1c2c54a33e4" "/opt/rustwide/cargo-home/bin/cargo" "+d336647335db03a0fc5b24fc5325cd3905c5b8e8" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 0d0e3693752a3b03d74b98e08496afbd06c54b5fe8280ea98961fe486bc9ec9b
[INFO] running `Command { std: "docker" "start" "-a" "0d0e3693752a3b03d74b98e08496afbd06c54b5fe8280ea98961fe486bc9ec9b", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "0d0e3693752a3b03d74b98e08496afbd06c54b5fe8280ea98961fe486bc9ec9b", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "0d0e3693752a3b03d74b98e08496afbd06c54b5fe8280ea98961fe486bc9ec9b", kill_on_drop: false }`
[INFO] [stdout] 0d0e3693752a3b03d74b98e08496afbd06c54b5fe8280ea98961fe486bc9ec9b
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-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:98afbf2d16093dec2546ff8915fddc74e65664aa03fc460b3712b1c2c54a33e4" "/opt/rustwide/cargo-home/bin/cargo" "+d336647335db03a0fc5b24fc5325cd3905c5b8e8" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] a5c83fde3751ad693c67573a3cb04933f1fd1507e9d779abc833829c429737d6
[INFO] running `Command { std: "docker" "start" "-a" "a5c83fde3751ad693c67573a3cb04933f1fd1507e9d779abc833829c429737d6", kill_on_drop: false }`
[INFO] [stderr]    Compiling serde v1.0.183
[INFO] [stderr]    Compiling serde_derive v1.0.183
[INFO] [stderr]     Checking tracing-core v0.1.31
[INFO] [stderr]    Compiling num-traits v0.2.16
[INFO] [stderr]     Checking http v0.2.9
[INFO] [stderr]    Compiling futures-channel v0.3.28
[INFO] [stderr]    Compiling syn v2.0.28
[INFO] [stderr]     Checking futures-util v0.3.28
[INFO] [stderr]     Checking aho-corasick v1.0.4
[INFO] [stderr]    Compiling axum-core v0.3.4
[INFO] [stderr]     Checking tower-layer v0.3.2
[INFO] [stderr]    Compiling serde_json v1.0.105
[INFO] [stderr]    Compiling thiserror v1.0.46
[INFO] [stderr]     Checking want v0.3.1
[INFO] [stderr]     Checking time v0.1.45
[INFO] [stderr]    Compiling axum v0.6.20
[INFO] [stderr]     Checking sharded-slab v0.1.4
[INFO] [stderr]     Checking thread_local v1.1.7
[INFO] [stderr]     Checking xml-rs v0.8.16
[INFO] [stderr]     Checking matchit v0.7.2
[INFO] [stderr]     Checking svg v0.13.1
[INFO] [stderr]     Checking tracing-log v0.1.3
[INFO] [stderr]     Checking http-body v0.4.5
[INFO] [stderr]     Checking regex-automata v0.3.6
[INFO] [stderr]     Checking regex v1.9.3
[INFO] [stderr]     Checking chrono v0.4.26
[INFO] [stderr]     Checking serde_path_to_error v0.1.14
[INFO] [stderr]     Checking serde_urlencoded v0.7.1
[INFO] [stderr]     Checking toml v0.5.11
[INFO] [stderr]    Compiling tracing-attributes v0.1.26
[INFO] [stderr]    Compiling tokio-macros v2.1.0
[INFO] [stderr]    Compiling pin-project-internal v1.1.3
[INFO] [stderr]    Compiling thiserror-impl v1.0.46
[INFO] [stderr]    Compiling async-trait v0.1.73
[INFO] [stderr]     Checking tokio v1.32.0
[INFO] [stderr]     Checking simplelog v0.11.2
[INFO] [stderr]     Checking pin-project v1.1.3
[INFO] [stderr]     Checking serde-xml-rs v0.6.0
[INFO] [stderr]     Checking tracing v0.1.37
[INFO] [stderr]     Checking tracing-subscriber v0.3.17
[INFO] [stderr]     Checking tower v0.4.13
[INFO] [stderr]     Checking hyper v0.14.27
[INFO] [stderr]     Checking gen_svg v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `crate::element::Project`
[INFO] [stdout]  --> src/config/gradient.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use crate::element::Project;
[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: `Deserializer`
[INFO] [stdout]  --> src/config/gradient.rs:2:26
[INFO] [stdout]   |
[INFO] [stdout] 2 | use serde::{Deserialize, Deserializer};
[INFO] [stdout]   |                          ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Duration` and `NaiveDate`
[INFO] [stdout]  --> src/gen_element/col_header.rs:3:14
[INFO] [stdout]   |
[INFO] [stdout] 3 | use chrono::{NaiveDate, Duration, Datelike};
[INFO] [stdout]   |              ^^^^^^^^^  ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `CoordinateUnit` and `LogicalUnit`
[INFO] [stdout]  --> src/parse/grid.rs:2:49
[INFO] [stdout]   |
[INFO] [stdout] 2 | use crate::element::{ColumnHeaders, Coordinate, CoordinateUnit, Grid, LogicalUnit, PointLogical, RowHeaders};
[INFO] [stdout]   |                                                 ^^^^^^^^^^^^^^        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Line`
[INFO] [stdout]  --> src/parse/grid.rs:4:26
[INFO] [stdout]   |
[INFO] [stdout] 4 | use crate::shape::{Draw, Line, Path, Rectangle, Text};
[INFO] [stdout]   |                          ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]  --> src/parse/grid.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use std::collections::HashMap;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around type
[INFO] [stdout]   --> src/parse/grid.rs:51:6
[INFO] [stdout]    |
[INFO] [stdout] 51 | ) -> (Vec<Box<dyn Draw>>) {
[INFO] [stdout]    |      ^                  ^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 51 - ) -> (Vec<Box<dyn Draw>>) {
[INFO] [stdout] 51 + ) -> Vec<Box<dyn Draw>>  {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Coordinate` and `PointLogical`
[INFO] [stdout]  --> src/parse/table.rs:2:22
[INFO] [stdout]   |
[INFO] [stdout] 2 | use crate::element::{Coordinate, PointLogical, Table};
[INFO] [stdout]   |                      ^^^^^^^^^^  ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]  --> src/parse/table.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use std::collections::HashMap;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `log::log`
[INFO] [stdout]  --> src/parse/project.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use log::log;
[INFO] [stdout]   |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `grid::*`
[INFO] [stdout]   --> src/parse.rs:18:9
[INFO] [stdout]    |
[INFO] [stdout] 18 | pub use grid::*;
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `get_projects`
[INFO] [stdout]   --> src/create_svg_metering.rs:10:27
[INFO] [stdout]    |
[INFO] [stdout] 10 | use crate::get_projects::{get_projects, get_projects0};
[INFO] [stdout]    |                           ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Coordinate`, `PROJECT_EXPEDITED`, `PROJECT_HISTORICAL`, `PROJECT_NORMAL`, `PROJECT_QUEUED`, `PROJECT_RUNNING`, `ProjectRect`, and `ProjectStatus`
[INFO] [stdout]  --> src/get_projects.rs:5:22
[INFO] [stdout]   |
[INFO] [stdout] 5 | ...::{Coordinate, Project, ProjectRect, ProjectStatus, PROJECT_NORMAL, PROJECT_RUNNING, PROJECT_HISTORICAL, PROJECT_EXPEDITED, PROJECT_QUEUED};
[INFO] [stdout]   |       ^^^^^^^^^^           ^^^^^^^^^^^  ^^^^^^^^^^^^^  ^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Deserialize` and `Serialize`
[INFO] [stdout]  --> src/my_utils/date.rs:3:13
[INFO] [stdout]   |
[INFO] [stdout] 3 | use serde::{Deserialize, Serialize};
[INFO] [stdout]   |             ^^^^^^^^^^^  ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::shape::Draw`
[INFO] [stdout]   --> src/main.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 12 | use crate::shape::Draw;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `svg::Node`
[INFO] [stdout]   --> src/main.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 13 | use svg::Node;
[INFO] [stdout]    |     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `serde_json`
[INFO] [stdout]   --> src/main.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 15 | use serde_json;
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Write`
[INFO] [stdout]   --> src/main.rs:20:21
[INFO] [stdout]    |
[INFO] [stdout] 20 | use std::io::{Read, Write};
[INFO] [stdout]    |                     ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::str::FromStr`
[INFO] [stdout]   --> src/main.rs:22:5
[INFO] [stdout]    |
[INFO] [stdout] 22 | use std::str::FromStr;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Json` and `post`
[INFO] [stdout]   --> src/main.rs:31:20
[INFO] [stdout]    |
[INFO] [stdout] 31 |     routing::{get, post},
[INFO] [stdout]    |                    ^^^^
[INFO] [stdout] 32 |     Json, Router,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Deserializer` and `Serialize`
[INFO] [stdout]   --> src/main.rs:35:26
[INFO] [stdout]    |
[INFO] [stdout] 35 | use serde::{Deserialize, Deserializer, Serialize};
[INFO] [stdout]    |                          ^^^^^^^^^^^^  ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `simplelog`
[INFO] [stdout]   --> src/main.rs:16:5
[INFO] [stdout]    |
[INFO] [stdout] 16 | use simplelog::*;
[INFO] [stdout]    |     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::element::Project`
[INFO] [stdout]  --> src/config/gradient.rs:1:5
[INFO] [stdout]   |
[INFO] [stdout] 1 | use crate::element::Project;
[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: `Deserializer`
[INFO] [stdout]  --> src/config/gradient.rs:2:26
[INFO] [stdout]   |
[INFO] [stdout] 2 | use serde::{Deserialize, Deserializer};
[INFO] [stdout]   |                          ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Duration` and `NaiveDate`
[INFO] [stdout]  --> src/gen_element/col_header.rs:3:14
[INFO] [stdout]   |
[INFO] [stdout] 3 | use chrono::{NaiveDate, Duration, Datelike};
[INFO] [stdout]   |              ^^^^^^^^^  ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `CoordinateUnit` and `LogicalUnit`
[INFO] [stdout]  --> src/parse/grid.rs:2:49
[INFO] [stdout]   |
[INFO] [stdout] 2 | use crate::element::{ColumnHeaders, Coordinate, CoordinateUnit, Grid, LogicalUnit, PointLogical, RowHeaders};
[INFO] [stdout]   |                                                 ^^^^^^^^^^^^^^        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Line`
[INFO] [stdout]  --> src/parse/grid.rs:4:26
[INFO] [stdout]   |
[INFO] [stdout] 4 | use crate::shape::{Draw, Line, Path, Rectangle, Text};
[INFO] [stdout]   |                          ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]  --> src/parse/grid.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use std::collections::HashMap;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around type
[INFO] [stdout]   --> src/parse/grid.rs:51:6
[INFO] [stdout]    |
[INFO] [stdout] 51 | ) -> (Vec<Box<dyn Draw>>) {
[INFO] [stdout]    |      ^                  ^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_parens)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]    |
[INFO] [stdout] 51 - ) -> (Vec<Box<dyn Draw>>) {
[INFO] [stdout] 51 + ) -> Vec<Box<dyn Draw>>  {
[INFO] [stdout]    |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/config/gradient.rs:56:17
[INFO] [stdout]    |
[INFO] [stdout] 56 |             let mut stop = Stop {
[INFO] [stdout]    |                 ----^^^^
[INFO] [stdout]    |                 |
[INFO] [stdout]    |                 help: remove this `mut`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Coordinate` and `PointLogical`
[INFO] [stdout]  --> src/parse/table.rs:2:22
[INFO] [stdout]   |
[INFO] [stdout] 2 | use crate::element::{Coordinate, PointLogical, Table};
[INFO] [stdout]   |                      ^^^^^^^^^^  ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]  --> src/parse/table.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use std::collections::HashMap;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `log::log`
[INFO] [stdout]  --> src/parse/project.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use log::log;
[INFO] [stdout]   |     ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `grid::*`
[INFO] [stdout]   --> src/parse.rs:18:9
[INFO] [stdout]    |
[INFO] [stdout] 18 | pub use grid::*;
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `get_projects`
[INFO] [stdout]   --> src/create_svg_metering.rs:10:27
[INFO] [stdout]    |
[INFO] [stdout] 10 | use crate::get_projects::{get_projects, get_projects0};
[INFO] [stdout]    |                           ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Coordinate`, `PROJECT_EXPEDITED`, `PROJECT_HISTORICAL`, `PROJECT_NORMAL`, `PROJECT_QUEUED`, `PROJECT_RUNNING`, `ProjectRect`, and `ProjectStatus`
[INFO] [stdout]  --> src/get_projects.rs:5:22
[INFO] [stdout]   |
[INFO] [stdout] 5 | ...::{Coordinate, Project, ProjectRect, ProjectStatus, PROJECT_NORMAL, PROJECT_RUNNING, PROJECT_HISTORICAL, PROJECT_EXPEDITED, PROJECT_QUEUED};
[INFO] [stdout]   |       ^^^^^^^^^^           ^^^^^^^^^^^  ^^^^^^^^^^^^^  ^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^^^^  ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Deserialize` and `Serialize`
[INFO] [stdout]  --> src/my_utils/date.rs:3:13
[INFO] [stdout]   |
[INFO] [stdout] 3 | use serde::{Deserialize, Serialize};
[INFO] [stdout]   |             ^^^^^^^^^^^  ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crate::shape::Draw`
[INFO] [stdout]   --> src/main.rs:12:5
[INFO] [stdout]    |
[INFO] [stdout] 12 | use crate::shape::Draw;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `svg::Node`
[INFO] [stdout]   --> src/main.rs:13:5
[INFO] [stdout]    |
[INFO] [stdout] 13 | use svg::Node;
[INFO] [stdout]    |     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `serde_json`
[INFO] [stdout]   --> src/main.rs:15:5
[INFO] [stdout]    |
[INFO] [stdout] 15 | use serde_json;
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Write`
[INFO] [stdout]   --> src/main.rs:20:21
[INFO] [stdout]    |
[INFO] [stdout] 20 | use std::io::{Read, Write};
[INFO] [stdout]    |                     ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::str::FromStr`
[INFO] [stdout]   --> src/main.rs:22:5
[INFO] [stdout]    |
[INFO] [stdout] 22 | use std::str::FromStr;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Json` and `post`
[INFO] [stdout]   --> src/main.rs:31:20
[INFO] [stdout]    |
[INFO] [stdout] 31 |     routing::{get, post},
[INFO] [stdout]    |                    ^^^^
[INFO] [stdout] 32 |     Json, Router,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Deserializer` and `Serialize`
[INFO] [stdout]   --> src/main.rs:35:26
[INFO] [stdout]    |
[INFO] [stdout] 35 | use serde::{Deserialize, Deserializer, Serialize};
[INFO] [stdout]    |                          ^^^^^^^^^^^^  ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/element/project.rs:189:16
[INFO] [stdout]     |
[INFO] [stdout] 189 |     pub fn add(mut self, c: u64) -> Self {
[INFO] [stdout]     |                ----^^^^
[INFO] [stdout]     |                |
[INFO] [stdout]     |                help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/element/project.rs:193:19
[INFO] [stdout]     |
[INFO] [stdout] 193 |     pub fn remove(mut self, c: u64) -> Self {
[INFO] [stdout]     |                   ----^^^^
[INFO] [stdout]     |                   |
[INFO] [stdout]     |                   help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `height`
[INFO] [stdout]    --> src/parse/grid.rs:169:9
[INFO] [stdout]     |
[INFO] [stdout] 169 |     let height = para.head_height;
[INFO] [stdout]     |         ^^^^^^ help: if this is intentional, prefix it with an underscore: `_height`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/parse/project.rs:448:10
[INFO] [stdout]     |
[INFO] [stdout] 448 |     let (mut dx, mut dy, mut i) = match d2 {
[INFO] [stdout]     |          ----^^
[INFO] [stdout]     |          |
[INFO] [stdout]     |          help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/parse/project.rs:448:18
[INFO] [stdout]     |
[INFO] [stdout] 448 |     let (mut dx, mut dy, mut i) = match d2 {
[INFO] [stdout]     |                  ----^^
[INFO] [stdout]     |                  |
[INFO] [stdout]     |                  help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/parse/project.rs:448:26
[INFO] [stdout]     |
[INFO] [stdout] 448 |     let (mut dx, mut dy, mut i) = match d2 {
[INFO] [stdout]     |                          ----^
[INFO] [stdout]     |                          |
[INFO] [stdout]     |                          help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/create_svg.rs:64:10
[INFO] [stdout]    |
[INFO] [stdout] 64 |     let (mut vd, c2ps) = convert_table(&table, &app_config);
[INFO] [stdout]    |          ----^^
[INFO] [stdout]    |          |
[INFO] [stdout]    |          help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/create_svg.rs:86:9
[INFO] [stdout]    |
[INFO] [stdout] 86 |     let mut projects_vd = projects
[INFO] [stdout]    |         ----^^^^^^^^^^^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/create_svg.rs:99:13
[INFO] [stdout]    |
[INFO] [stdout] 99 |         let mut today_line_vd = convert_today_line(today_index, &c2ps, &app_config);
[INFO] [stdout]    |             ----^^^^^^^^^^^^^
[INFO] [stdout]    |             |
[INFO] [stdout]    |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `min_x`
[INFO] [stdout]   --> src/create_svg.rs:68:10
[INFO] [stdout]    |
[INFO] [stdout] 68 |     let (min_x, min_y, max_x, max_y) = c2ps.get_ps_min_max();
[INFO] [stdout]    |          ^^^^^ help: if this is intentional, prefix it with an underscore: `_min_x`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `min_y`
[INFO] [stdout]   --> src/create_svg.rs:68:17
[INFO] [stdout]    |
[INFO] [stdout] 68 |     let (min_x, min_y, max_x, max_y) = c2ps.get_ps_min_max();
[INFO] [stdout]    |                 ^^^^^ help: if this is intentional, prefix it with an underscore: `_min_y`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/create_svg_metering.rs:77:10
[INFO] [stdout]    |
[INFO] [stdout] 77 |     let (mut vd, c2ps) = convert_table(&table, &app_config);
[INFO] [stdout]    |          ----^^
[INFO] [stdout]    |          |
[INFO] [stdout]    |          help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/create_svg_metering.rs:96:9
[INFO] [stdout]    |
[INFO] [stdout] 96 |     let mut projects_vd = projects
[INFO] [stdout]    |         ----^^^^^^^^^^^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/create_svg_metering.rs:107:9
[INFO] [stdout]     |
[INFO] [stdout] 107 |     let mut today_line_vd = convert_today_line(10, &c2ps, &app_config);
[INFO] [stdout]     |         ----^^^^^^^^^^^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `min_x`
[INFO] [stdout]   --> src/create_svg_metering.rs:81:10
[INFO] [stdout]    |
[INFO] [stdout] 81 |     let (min_x, min_y, max_x, max_y) = c2ps.get_ps_min_max();
[INFO] [stdout]    |          ^^^^^ help: if this is intentional, prefix it with an underscore: `_min_x`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `min_y`
[INFO] [stdout]   --> src/create_svg_metering.rs:81:17
[INFO] [stdout]    |
[INFO] [stdout] 81 |     let (min_x, min_y, max_x, max_y) = c2ps.get_ps_min_max();
[INFO] [stdout]    |                 ^^^^^ help: if this is intentional, prefix it with an underscore: `_min_y`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `save_to_json` and `load_from_json` are never used
[INFO] [stdout]   --> src/element/table.rs:48:12
[INFO] [stdout]    |
[INFO] [stdout] 47 | impl Table {
[INFO] [stdout]    | ---------- associated items in this implementation
[INFO] [stdout] 48 |     pub fn save_to_json(&self, path: &str) {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 53 |     pub fn load_from_json(path: &str) -> Table {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `metering` is never read
[INFO] [stdout]   --> src/element/project.rs:30:9
[INFO] [stdout]    |
[INFO] [stdout] 25 | pub struct Project {
[INFO] [stdout]    |            ------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 30 |     pub metering: Vec<f64>,
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Project` 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: associated function `new` is never used
[INFO] [stdout]    --> src/element/project.rs:142:12
[INFO] [stdout]     |
[INFO] [stdout] 141 | impl ProjectRect {
[INFO] [stdout]     | ---------------- associated function in this implementation
[INFO] [stdout] 142 |     pub fn new(c: &Coordinate, status: ProjectStatus) -> ProjectRect {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `add`, `remove`, and `to_string` are never used
[INFO] [stdout]    --> src/element/project.rs:189:12
[INFO] [stdout]     |
[INFO] [stdout] 184 | impl ProjectStatus {
[INFO] [stdout]     | ------------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 189 |     pub fn add(mut self, c: u64) -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 193 |     pub fn remove(mut self, c: u64) -> Self {
[INFO] [stdout]     |            ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 227 |     pub fn to_string(&self) -> String {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `eliminate_merge_edges` is never used
[INFO] [stdout]    --> src/parse/project.rs:159:4
[INFO] [stdout]     |
[INFO] [stdout] 159 | fn eliminate_merge_edges(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `str_to_date70` is never used
[INFO] [stdout]   --> src/my_utils/date.rs:12:8
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub fn str_to_date70(date: &str) -> Option<Date70> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `save_to_json` is never used
[INFO] [stdout]   --> src/my_utils/device.rs:14:12
[INFO] [stdout]    |
[INFO] [stdout] 13 | impl DeviceList{
[INFO] [stdout]    | --------------- method in this implementation
[INFO] [stdout] 14 |     pub fn save_to_json(&self, path: &str){
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `simplelog`
[INFO] [stdout]   --> src/main.rs:16:5
[INFO] [stdout]    |
[INFO] [stdout] 16 | use simplelog::*;
[INFO] [stdout]    |     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/config/gradient.rs:56:17
[INFO] [stdout]    |
[INFO] [stdout] 56 |             let mut stop = Stop {
[INFO] [stdout]    |                 ----^^^^
[INFO] [stdout]    |                 |
[INFO] [stdout]    |                 help: remove this `mut`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_mut)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/element/project.rs:189:16
[INFO] [stdout]     |
[INFO] [stdout] 189 |     pub fn add(mut self, c: u64) -> Self {
[INFO] [stdout]     |                ----^^^^
[INFO] [stdout]     |                |
[INFO] [stdout]     |                help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/element/project.rs:193:19
[INFO] [stdout]     |
[INFO] [stdout] 193 |     pub fn remove(mut self, c: u64) -> Self {
[INFO] [stdout]     |                   ----^^^^
[INFO] [stdout]     |                   |
[INFO] [stdout]     |                   help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `height`
[INFO] [stdout]    --> src/parse/grid.rs:169:9
[INFO] [stdout]     |
[INFO] [stdout] 169 |     let height = para.head_height;
[INFO] [stdout]     |         ^^^^^^ help: if this is intentional, prefix it with an underscore: `_height`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/parse/project.rs:448:10
[INFO] [stdout]     |
[INFO] [stdout] 448 |     let (mut dx, mut dy, mut i) = match d2 {
[INFO] [stdout]     |          ----^^
[INFO] [stdout]     |          |
[INFO] [stdout]     |          help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/parse/project.rs:448:18
[INFO] [stdout]     |
[INFO] [stdout] 448 |     let (mut dx, mut dy, mut i) = match d2 {
[INFO] [stdout]     |                  ----^^
[INFO] [stdout]     |                  |
[INFO] [stdout]     |                  help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/parse/project.rs:448:26
[INFO] [stdout]     |
[INFO] [stdout] 448 |     let (mut dx, mut dy, mut i) = match d2 {
[INFO] [stdout]     |                          ----^
[INFO] [stdout]     |                          |
[INFO] [stdout]     |                          help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/create_svg.rs:64:10
[INFO] [stdout]    |
[INFO] [stdout] 64 |     let (mut vd, c2ps) = convert_table(&table, &app_config);
[INFO] [stdout]    |          ----^^
[INFO] [stdout]    |          |
[INFO] [stdout]    |          help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/create_svg.rs:86:9
[INFO] [stdout]    |
[INFO] [stdout] 86 |     let mut projects_vd = projects
[INFO] [stdout]    |         ----^^^^^^^^^^^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/create_svg.rs:99:13
[INFO] [stdout]    |
[INFO] [stdout] 99 |         let mut today_line_vd = convert_today_line(today_index, &c2ps, &app_config);
[INFO] [stdout]    |             ----^^^^^^^^^^^^^
[INFO] [stdout]    |             |
[INFO] [stdout]    |             help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `min_x`
[INFO] [stdout]   --> src/create_svg.rs:68:10
[INFO] [stdout]    |
[INFO] [stdout] 68 |     let (min_x, min_y, max_x, max_y) = c2ps.get_ps_min_max();
[INFO] [stdout]    |          ^^^^^ help: if this is intentional, prefix it with an underscore: `_min_x`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `min_y`
[INFO] [stdout]   --> src/create_svg.rs:68:17
[INFO] [stdout]    |
[INFO] [stdout] 68 |     let (min_x, min_y, max_x, max_y) = c2ps.get_ps_min_max();
[INFO] [stdout]    |                 ^^^^^ help: if this is intentional, prefix it with an underscore: `_min_y`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/create_svg_metering.rs:77:10
[INFO] [stdout]    |
[INFO] [stdout] 77 |     let (mut vd, c2ps) = convert_table(&table, &app_config);
[INFO] [stdout]    |          ----^^
[INFO] [stdout]    |          |
[INFO] [stdout]    |          help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/create_svg_metering.rs:96:9
[INFO] [stdout]    |
[INFO] [stdout] 96 |     let mut projects_vd = projects
[INFO] [stdout]    |         ----^^^^^^^^^^^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/create_svg_metering.rs:107:9
[INFO] [stdout]     |
[INFO] [stdout] 107 |     let mut today_line_vd = convert_today_line(10, &c2ps, &app_config);
[INFO] [stdout]     |         ----^^^^^^^^^^^^^
[INFO] [stdout]     |         |
[INFO] [stdout]     |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `min_x`
[INFO] [stdout]   --> src/create_svg_metering.rs:81:10
[INFO] [stdout]    |
[INFO] [stdout] 81 |     let (min_x, min_y, max_x, max_y) = c2ps.get_ps_min_max();
[INFO] [stdout]    |          ^^^^^ help: if this is intentional, prefix it with an underscore: `_min_x`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `min_y`
[INFO] [stdout]   --> src/create_svg_metering.rs:81:17
[INFO] [stdout]    |
[INFO] [stdout] 81 |     let (min_x, min_y, max_x, max_y) = c2ps.get_ps_min_max();
[INFO] [stdout]    |                 ^^^^^ help: if this is intentional, prefix it with an underscore: `_min_y`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `save_to_json` and `load_from_json` are never used
[INFO] [stdout]   --> src/element/table.rs:48:12
[INFO] [stdout]    |
[INFO] [stdout] 47 | impl Table {
[INFO] [stdout]    | ---------- associated items in this implementation
[INFO] [stdout] 48 |     pub fn save_to_json(&self, path: &str) {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 53 |     pub fn load_from_json(path: &str) -> Table {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `metering` is never read
[INFO] [stdout]   --> src/element/project.rs:30:9
[INFO] [stdout]    |
[INFO] [stdout] 25 | pub struct Project {
[INFO] [stdout]    |            ------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 30 |     pub metering: Vec<f64>,
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Project` 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: associated function `new` is never used
[INFO] [stdout]    --> src/element/project.rs:142:12
[INFO] [stdout]     |
[INFO] [stdout] 141 | impl ProjectRect {
[INFO] [stdout]     | ---------------- associated function in this implementation
[INFO] [stdout] 142 |     pub fn new(c: &Coordinate, status: ProjectStatus) -> ProjectRect {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `add`, `remove`, and `to_string` are never used
[INFO] [stdout]    --> src/element/project.rs:189:12
[INFO] [stdout]     |
[INFO] [stdout] 184 | impl ProjectStatus {
[INFO] [stdout]     | ------------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 189 |     pub fn add(mut self, c: u64) -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 193 |     pub fn remove(mut self, c: u64) -> Self {
[INFO] [stdout]     |            ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 227 |     pub fn to_string(&self) -> String {
[INFO] [stdout]     |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `eliminate_merge_edges` is never used
[INFO] [stdout]    --> src/parse/project.rs:159:4
[INFO] [stdout]     |
[INFO] [stdout] 159 | fn eliminate_merge_edges(
[INFO] [stdout]     |    ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `str_to_date70` is never used
[INFO] [stdout]   --> src/my_utils/date.rs:12:8
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub fn str_to_date70(date: &str) -> Option<Date70> {
[INFO] [stdout]    |        ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `save_to_json` is never used
[INFO] [stdout]   --> src/my_utils/device.rs:14:12
[INFO] [stdout]    |
[INFO] [stdout] 13 | impl DeviceList{
[INFO] [stdout]    | --------------- method in this implementation
[INFO] [stdout] 14 |     pub fn save_to_json(&self, path: &str){
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 26.16s
[INFO] running `Command { std: "docker" "inspect" "a5c83fde3751ad693c67573a3cb04933f1fd1507e9d779abc833829c429737d6", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "a5c83fde3751ad693c67573a3cb04933f1fd1507e9d779abc833829c429737d6", kill_on_drop: false }`
[INFO] [stdout] a5c83fde3751ad693c67573a3cb04933f1fd1507e9d779abc833829c429737d6
