[INFO] cloning repository https://github.com/alexadam/net-stats
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/alexadam/net-stats" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Falexadam%2Fnet-stats", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Falexadam%2Fnet-stats'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] aaa98517eb61d2a2f8c5c49fe3f84e661bbef0b9
[INFO] checking alexadam/net-stats against master#779e19d8baa3e3625bd4fc5c85cbb2ad47b43155 for pr-147589-1
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Falexadam%2Fnet-stats" "/workspace/builds/worker-1-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-1-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/alexadam/net-stats
[INFO] finished tweaking git repo https://github.com/alexadam/net-stats
[INFO] tweaked toml for git repo https://github.com/alexadam/net-stats written to /workspace/builds/worker-1-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/alexadam/net-stats on toolchain 779e19d8baa3e3625bd4fc5c85cbb2ad47b43155
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+779e19d8baa3e3625bd4fc5c85cbb2ad47b43155" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/alexadam/net-stats already has a lockfile, it will not be regenerated
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+779e19d8baa3e3625bd4fc5c85cbb2ad47b43155" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded simplerand v1.5.1
[INFO] [stderr]   Downloaded native-tls v0.2.13
[INFO] [stderr]   Downloaded libmath v0.2.1
[INFO] [stderr]   Downloaded dns-lookup v2.0.4
[INFO] [stderr]   Downloaded netlink-sys v0.8.7
[INFO] [stderr]   Downloaded netstat2 v0.11.1
[INFO] [stderr]   Downloaded fakeit v1.3.0
[INFO] [stderr]   Downloaded sysinfo v0.33.1
[INFO] [stderr]   Downloaded color-eyre v0.6.3
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+779e19d8baa3e3625bd4fc5c85cbb2ad47b43155" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 82559a0858c5f2b18ef34145c11673143e9541b8b495e003868f8dcadde513c0
[INFO] running `Command { std: "docker" "start" "-a" "82559a0858c5f2b18ef34145c11673143e9541b8b495e003868f8dcadde513c0", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "82559a0858c5f2b18ef34145c11673143e9541b8b495e003868f8dcadde513c0", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "82559a0858c5f2b18ef34145c11673143e9541b8b495e003868f8dcadde513c0", kill_on_drop: false }`
[INFO] [stdout] 82559a0858c5f2b18ef34145c11673143e9541b8b495e003868f8dcadde513c0
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-1-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+779e19d8baa3e3625bd4fc5c85cbb2ad47b43155" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 7810b59e293beb741a3fd14b30f337bc0d2c97139a231e8cd8c70c5ef8703c55
[INFO] running `Command { std: "docker" "start" "-a" "7810b59e293beb741a3fd14b30f337bc0d2c97139a231e8cd8c70c5ef8703c55", kill_on_drop: false }`
[INFO] [stderr]    Compiling syn v2.0.98
[INFO] [stderr]     Checking log v0.4.25
[INFO] [stderr]    Compiling autocfg v0.1.8
[INFO] [stderr]     Checking signal-hook-registry v1.4.2
[INFO] [stderr]     Checking parking_lot_core v0.9.10
[INFO] [stderr]    Compiling openssl-sys v0.9.105
[INFO] [stderr]     Checking socket2 v0.5.8
[INFO] [stderr]     Checking foldhash v0.1.4
[INFO] [stderr]     Checking tracing v0.1.41
[INFO] [stderr]    Compiling openssl v0.10.70
[INFO] [stderr]     Checking http v0.2.12
[INFO] [stderr]    Compiling native-tls v0.2.13
[INFO] [stderr]    Compiling itertools v0.13.0
[INFO] [stderr]    Compiling serde v1.0.217
[INFO] [stderr]    Compiling clang-sys v1.8.1
[INFO] [stderr]    Compiling bitflags v2.8.0
[INFO] [stderr]     Checking hashbrown v0.15.2
[INFO] [stderr]    Compiling rand_pcg v0.1.2
[INFO] [stderr]     Checking mio v1.0.3
[INFO] [stderr]    Compiling rand_chacha v0.1.1
[INFO] [stderr]    Compiling rustix v0.38.44
[INFO] [stderr]     Checking parking_lot v0.12.3
[INFO] [stderr]     Checking signal-hook v0.3.17
[INFO] [stderr]    Compiling rand v0.6.5
[INFO] [stderr]     Checking tracing-subscriber v0.3.19
[INFO] [stderr]    Compiling backtrace v0.3.71
[INFO] [stderr]     Checking rand v0.4.6
[INFO] [stderr]    Compiling serde_json v1.0.138
[INFO] [stderr]    Compiling eyre v0.6.12
[INFO] [stderr]     Checking gimli v0.28.1
[INFO] [stderr]     Checking miniz_oxide v0.7.4
[INFO] [stderr]     Checking signal-hook-mio v0.2.4
[INFO] [stderr]     Checking castaway v0.2.3
[INFO] [stderr]     Checking rand_os v0.1.3
[INFO] [stderr]     Checking getrandom v0.2.15
[INFO] [stderr]     Checking object v0.32.2
[INFO] [stderr]     Checking indenter v0.3.3
[INFO] [stderr]     Checking http-body v0.4.6
[INFO] [stderr]     Checking rustc-demangle v0.1.24
[INFO] [stderr]     Checking owo-colors v3.5.0
[INFO] [stderr]    Compiling indoc v2.0.5
[INFO] [stderr]     Checking uuid v0.8.2
[INFO] [stderr]     Checking rand v0.3.23
[INFO] [stderr]     Checking unicode-truncate v1.1.0
[INFO] [stderr]     Checking libmath v0.2.1
[INFO] [stderr]     Checking indexmap v2.7.1
[INFO] [stderr]     Checking lru v0.12.5
[INFO] [stderr]     Checking compact_str v0.8.1
[INFO] [stderr]     Checking rayon v1.10.0
[INFO] [stderr]     Checking netlink-sys v0.8.7
[INFO] [stderr]     Checking crossterm v0.28.1
[INFO] [stderr]     Checking tracing-error v0.2.1
[INFO] [stderr]     Checking simplerand v1.5.1
[INFO] [stderr]     Checking unicode-width v0.2.0
[INFO] [stderr]     Checking dns-lookup v2.0.4
[INFO] [stderr]     Checking if-addrs v0.6.7
[INFO] [stderr]     Checking color-spantrace v0.2.1
[INFO] [stderr]     Checking fakeit v1.3.0
[INFO] [stderr]     Checking serde_urlencoded v0.7.1
[INFO] [stderr]     Checking addr2line v0.21.0
[INFO] [stderr]     Checking sysinfo v0.33.1
[INFO] [stderr]     Checking color-eyre v0.6.3
[INFO] [stderr]    Compiling synstructure v0.13.1
[INFO] [stderr]    Compiling prettyplease v0.2.29
[INFO] [stderr]    Compiling darling_core v0.20.10
[INFO] [stderr]    Compiling bindgen v0.71.1
[INFO] [stderr]    Compiling zerovec-derive v0.10.3
[INFO] [stderr]    Compiling displaydoc v0.2.5
[INFO] [stderr]    Compiling icu_provider_macros v1.5.0
[INFO] [stderr]    Compiling tokio-macros v2.5.0
[INFO] [stderr]    Compiling futures-macro v0.3.31
[INFO] [stderr]    Compiling thiserror-impl v1.0.69
[INFO] [stderr]    Compiling openssl-macros v0.1.1
[INFO] [stderr]    Compiling thiserror-impl v2.0.11
[INFO] [stderr]    Compiling strum_macros v0.26.4
[INFO] [stderr]    Compiling zerofrom-derive v0.1.5
[INFO] [stderr]    Compiling yoke-derive v0.7.5
[INFO] [stderr]     Checking thiserror v1.0.69
[INFO] [stderr]     Checking tokio v1.43.0
[INFO] [stderr]     Checking netlink-packet-utils v0.5.2
[INFO] [stderr]     Checking futures-util v0.3.31
[INFO] [stderr]     Checking netlink-packet-core v0.7.0
[INFO] [stderr]     Checking netlink-packet-sock-diag v0.4.2
[INFO] [stderr]     Checking zerofrom v0.1.5
[INFO] [stderr]     Checking thiserror v2.0.11
[INFO] [stderr]     Checking yoke v0.7.5
[INFO] [stderr]     Checking strum v0.26.3
[INFO] [stderr]     Checking zerovec v0.10.4
[INFO] [stderr]    Compiling darling_macro v0.20.10
[INFO] [stderr]    Compiling darling v0.20.10
[INFO] [stderr]    Compiling instability v0.3.7
[INFO] [stderr]     Checking ratatui v0.29.0
[INFO] [stderr]     Checking tinystr v0.7.6
[INFO] [stderr]     Checking icu_collections v1.5.0
[INFO] [stderr]     Checking icu_locid v1.5.0
[INFO] [stderr]     Checking futures-executor v0.3.31
[INFO] [stderr]     Checking icu_provider v1.5.0
[INFO] [stderr]     Checking futures v0.3.31
[INFO] [stderr]     Checking icu_locid_transform v1.5.0
[INFO] [stderr]     Checking icu_properties v1.5.1
[INFO] [stderr]     Checking tokio-util v0.7.13
[INFO] [stderr]     Checking tokio-native-tls v0.3.1
[INFO] [stderr]     Checking h2 v0.3.26
[INFO] [stderr]    Compiling netstat2 v0.11.1
[INFO] [stderr]     Checking icu_normalizer v1.5.0
[INFO] [stderr]     Checking idna_adapter v1.2.0
[INFO] [stderr]     Checking idna v1.0.3
[INFO] [stderr]     Checking url v2.5.4
[INFO] [stderr]     Checking hyper v0.14.32
[INFO] [stderr]     Checking hyper-tls v0.5.0
[INFO] [stderr]     Checking reqwest v0.11.27
[INFO] [stderr]     Checking net-stats v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused imports: `KeyEventKind` and `KeyModifiers`
[INFO] [stdout]  --> src/main.rs:4:40
[INFO] [stdout]   |
[INFO] [stdout] 4 | use crossterm::event::{Event, KeyCode, KeyEventKind, KeyModifiers};
[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: `futures::SinkExt`
[INFO] [stdout]  --> src/main.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use futures::SinkExt;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Alignment`
[INFO] [stdout]  --> src/main.rs:7:23
[INFO] [stdout]   |
[INFO] [stdout] 7 | use ratatui::layout::{Alignment, Constraint, Layout, Margin, Rect};
[INFO] [stdout]   |                       ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Masked`
[INFO] [stdout]   --> src/main.rs:10:27
[INFO] [stdout]    |
[INFO] [stdout] 10 | use ratatui::text::{Line, Masked, Span};
[INFO] [stdout]    |                           ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `IP_Address`
[INFO] [stdout]   --> src/main.rs:12:31
[INFO] [stdout]    |
[INFO] [stdout] 12 | use crate::my_ips::{getMyIps, IP_Address};
[INFO] [stdout]    |                               ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `get_dns`
[INFO] [stdout]   --> src/main.rs:13:43
[INFO] [stdout]    |
[INFO] [stdout] 13 | use crate::netstat::{get_all_connections, get_dns, Netstat};
[INFO] [stdout]    |                                           ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `IP_Address` should have an upper camel case name
[INFO] [stdout]  --> src/my_ips.rs:4:12
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub struct IP_Address {
[INFO] [stdout]   |            ^^^^^^^^^^ help: convert the identifier to upper camel case: `IpAddress`
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(non_camel_case_types)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::iter::Map`
[INFO] [stdout]  --> src/netstat.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::iter::Map;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `dns_lookup::lookup_addr`
[INFO] [stdout]  --> src/netstat.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use dns_lookup::lookup_addr;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Process`
[INFO] [stdout]  --> src/netstat.rs:7:15
[INFO] [stdout]   |
[INFO] [stdout] 7 | use sysinfo::{Process, System};
[INFO] [stdout]   |               ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `SocketAddr` and `ToSocketAddrs`
[INFO] [stdout]  --> src/netstat.rs:8:16
[INFO] [stdout]   |
[INFO] [stdout] 8 | use std::net::{SocketAddr, ToSocketAddrs};
[INFO] [stdout]   |                ^^^^^^^^^^  ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Stdio`
[INFO] [stdout]  --> src/netstat.rs:9:29
[INFO] [stdout]   |
[INFO] [stdout] 9 | use std::process::{Command, Stdio};
[INFO] [stdout]   |                             ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `itertools::iproduct`
[INFO] [stdout]   --> src/netstat.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | use itertools::iproduct;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::error::Error`
[INFO] [stdout]   --> src/connections_table.rs:16:5
[INFO] [stdout]    |
[INFO] [stdout] 16 | use std::error::Error;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crossterm::event::KeyModifiers`
[INFO] [stdout]   --> src/connections_table.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 18 | use crossterm::event::KeyModifiers;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Block`, `BorderType`, `DefaultTerminal`, `Event`, `KeyCode`, `KeyEventKind`, `Layout`, `Modifier`, `Paragraph`, and `self`
[INFO] [stdout]   --> src/connections_table.rs:21:22
[INFO] [stdout]    |
[INFO] [stdout] 21 |   crossterm::event::{self, Event, KeyCode, KeyEventKind},
[INFO] [stdout]    |                      ^^^^  ^^^^^  ^^^^^^^  ^^^^^^^^^^^^
[INFO] [stdout] 22 |   layout::{Constraint, Layout, Margin, Rect},
[INFO] [stdout]    |                        ^^^^^^
[INFO] [stdout] 23 |   style::{self, Color, Modifier, Style, Stylize},
[INFO] [stdout]    |                        ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 26 |     Block, BorderType, Cell, HighlightSpacing, Paragraph, Row, Scrollbar, ScrollbarOrientation,
[INFO] [stdout]    |     ^^^^^  ^^^^^^^^^^                          ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 29 |   DefaultTerminal, Frame,
[INFO] [stdout]    |   ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `unicode_width::UnicodeWidthStr`
[INFO] [stdout]   --> src/connections_table.rs:32:5
[INFO] [stdout]    |
[INFO] [stdout] 32 | use unicode_width::UnicodeWidthStr;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/connections_table.rs:335:8
[INFO] [stdout]     |
[INFO] [stdout] 335 |     if (state == "ESTABLISHED") {
[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] 335 -     if (state == "ESTABLISHED") {
[INFO] [stdout] 335 +     if state == "ESTABLISHED" {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/connections_table.rs:337:15
[INFO] [stdout]     |
[INFO] [stdout] 337 |     } else if (state == "LISTEN") {
[INFO] [stdout]     |               ^                 ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 337 -     } else if (state == "LISTEN") {
[INFO] [stdout] 337 +     } else if state == "LISTEN" {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/connections_table.rs:345:8
[INFO] [stdout]     |
[INFO] [stdout] 345 |     if (state == "ESTABLISHED") {
[INFO] [stdout]     |        ^                      ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 345 -     if (state == "ESTABLISHED") {
[INFO] [stdout] 345 +     if state == "ESTABLISHED" {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/main.rs:457:8
[INFO] [stdout]     |
[INFO] [stdout] 457 |     if (state == "ESTABLISHED") {
[INFO] [stdout]     |        ^                      ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 457 -     if (state == "ESTABLISHED") {
[INFO] [stdout] 457 +     if state == "ESTABLISHED"  {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/main.rs:459:15
[INFO] [stdout]     |
[INFO] [stdout] 459 |     } else if (state == "LISTEN") {
[INFO] [stdout]     |               ^                 ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 459 -     } else if (state == "LISTEN") {
[INFO] [stdout] 459 +     } else if state == "LISTEN"  {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/main.rs:467:8
[INFO] [stdout]     |
[INFO] [stdout] 467 |     if (state == "ESTABLISHED") {
[INFO] [stdout]     |        ^                      ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 467 -     if (state == "ESTABLISHED") {
[INFO] [stdout] 467 +     if state == "ESTABLISHED"  {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `KeyEventKind` and `KeyModifiers`
[INFO] [stdout]  --> src/main.rs:4:40
[INFO] [stdout]   |
[INFO] [stdout] 4 | use crossterm::event::{Event, KeyCode, KeyEventKind, KeyModifiers};
[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: `futures::SinkExt`
[INFO] [stdout]  --> src/main.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use futures::SinkExt;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Alignment`
[INFO] [stdout]  --> src/main.rs:7:23
[INFO] [stdout]   |
[INFO] [stdout] 7 | use ratatui::layout::{Alignment, Constraint, Layout, Margin, Rect};
[INFO] [stdout]   |                       ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Masked`
[INFO] [stdout]   --> src/main.rs:10:27
[INFO] [stdout]    |
[INFO] [stdout] 10 | use ratatui::text::{Line, Masked, Span};
[INFO] [stdout]    |                           ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `IP_Address`
[INFO] [stdout]   --> src/main.rs:12:31
[INFO] [stdout]    |
[INFO] [stdout] 12 | use crate::my_ips::{getMyIps, IP_Address};
[INFO] [stdout]    |                               ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `get_dns`
[INFO] [stdout]   --> src/main.rs:13:43
[INFO] [stdout]    |
[INFO] [stdout] 13 | use crate::netstat::{get_all_connections, get_dns, Netstat};
[INFO] [stdout]    |                                           ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: type `IP_Address` should have an upper camel case name
[INFO] [stdout]  --> src/my_ips.rs:4:12
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub struct IP_Address {
[INFO] [stdout]   |            ^^^^^^^^^^ help: convert the identifier to upper camel case: `IpAddress`
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(non_camel_case_types)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::iter::Map`
[INFO] [stdout]  --> src/netstat.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::iter::Map;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `dns_lookup::lookup_addr`
[INFO] [stdout]  --> src/netstat.rs:5:5
[INFO] [stdout]   |
[INFO] [stdout] 5 | use dns_lookup::lookup_addr;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Process`
[INFO] [stdout]  --> src/netstat.rs:7:15
[INFO] [stdout]   |
[INFO] [stdout] 7 | use sysinfo::{Process, System};
[INFO] [stdout]   |               ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `SocketAddr` and `ToSocketAddrs`
[INFO] [stdout]  --> src/netstat.rs:8:16
[INFO] [stdout]   |
[INFO] [stdout] 8 | use std::net::{SocketAddr, ToSocketAddrs};
[INFO] [stdout]   |                ^^^^^^^^^^  ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Stdio`
[INFO] [stdout]  --> src/netstat.rs:9:29
[INFO] [stdout]   |
[INFO] [stdout] 9 | use std::process::{Command, Stdio};
[INFO] [stdout]   |                             ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `itertools::iproduct`
[INFO] [stdout]   --> src/netstat.rs:10:5
[INFO] [stdout]    |
[INFO] [stdout] 10 | use itertools::iproduct;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::error::Error`
[INFO] [stdout]   --> src/connections_table.rs:16:5
[INFO] [stdout]    |
[INFO] [stdout] 16 | use std::error::Error;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `crossterm::event::KeyModifiers`
[INFO] [stdout]   --> src/connections_table.rs:18:5
[INFO] [stdout]    |
[INFO] [stdout] 18 | use crossterm::event::KeyModifiers;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `Block`, `BorderType`, `DefaultTerminal`, `Event`, `KeyCode`, `KeyEventKind`, `Layout`, `Modifier`, `Paragraph`, and `self`
[INFO] [stdout]   --> src/connections_table.rs:21:22
[INFO] [stdout]    |
[INFO] [stdout] 21 |   crossterm::event::{self, Event, KeyCode, KeyEventKind},
[INFO] [stdout]    |                      ^^^^  ^^^^^  ^^^^^^^  ^^^^^^^^^^^^
[INFO] [stdout] 22 |   layout::{Constraint, Layout, Margin, Rect},
[INFO] [stdout]    |                        ^^^^^^
[INFO] [stdout] 23 |   style::{self, Color, Modifier, Style, Stylize},
[INFO] [stdout]    |                        ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 26 |     Block, BorderType, Cell, HighlightSpacing, Paragraph, Row, Scrollbar, ScrollbarOrientation,
[INFO] [stdout]    |     ^^^^^  ^^^^^^^^^^                          ^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 29 |   DefaultTerminal, Frame,
[INFO] [stdout]    |   ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `unicode_width::UnicodeWidthStr`
[INFO] [stdout]   --> src/connections_table.rs:32:5
[INFO] [stdout]    |
[INFO] [stdout] 32 | use unicode_width::UnicodeWidthStr;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/connections_table.rs:335:8
[INFO] [stdout]     |
[INFO] [stdout] 335 |     if (state == "ESTABLISHED") {
[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] 335 -     if (state == "ESTABLISHED") {
[INFO] [stdout] 335 +     if state == "ESTABLISHED" {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/connections_table.rs:337:15
[INFO] [stdout]     |
[INFO] [stdout] 337 |     } else if (state == "LISTEN") {
[INFO] [stdout]     |               ^                 ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 337 -     } else if (state == "LISTEN") {
[INFO] [stdout] 337 +     } else if state == "LISTEN" {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/connections_table.rs:345:8
[INFO] [stdout]     |
[INFO] [stdout] 345 |     if (state == "ESTABLISHED") {
[INFO] [stdout]     |        ^                      ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 345 -     if (state == "ESTABLISHED") {
[INFO] [stdout] 345 +     if state == "ESTABLISHED" {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/main.rs:457:8
[INFO] [stdout]     |
[INFO] [stdout] 457 |     if (state == "ESTABLISHED") {
[INFO] [stdout]     |        ^                      ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 457 -     if (state == "ESTABLISHED") {
[INFO] [stdout] 457 +     if state == "ESTABLISHED"  {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/main.rs:459:15
[INFO] [stdout]     |
[INFO] [stdout] 459 |     } else if (state == "LISTEN") {
[INFO] [stdout]     |               ^                 ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 459 -     } else if (state == "LISTEN") {
[INFO] [stdout] 459 +     } else if state == "LISTEN"  {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unnecessary parentheses around `if` condition
[INFO] [stdout]    --> src/main.rs:467:8
[INFO] [stdout]     |
[INFO] [stdout] 467 |     if (state == "ESTABLISHED") {
[INFO] [stdout]     |        ^                      ^
[INFO] [stdout]     |
[INFO] [stdout] help: remove these parentheses
[INFO] [stdout]     |
[INFO] [stdout] 467 -     if (state == "ESTABLISHED") {
[INFO] [stdout] 467 +     if state == "ESTABLISHED"  {
[INFO] [stdout]     |
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: irrefutable `if let` pattern
[INFO] [stdout]   --> src/my_ips.rs:27:12
[INFO] [stdout]    |
[INFO] [stdout] 27 |         if let ip = iface.ip() {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this pattern will always match, so the `if let` is useless
[INFO] [stdout]    = help: consider replacing the `if let` with a `let`
[INFO] [stdout]    = note: `#[warn(irrefutable_let_patterns)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: irrefutable `if let` pattern
[INFO] [stdout]   --> src/my_ips.rs:35:8
[INFO] [stdout]    |
[INFO] [stdout] 35 |     if let addr = externamIpAddress.unwrap() {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this pattern will always match, so the `if let` is useless
[INFO] [stdout]    = help: consider replacing the `if let` with a `let`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: irrefutable `if let` pattern
[INFO] [stdout]   --> src/my_ips.rs:27:12
[INFO] [stdout]    |
[INFO] [stdout] 27 |         if let ip = iface.ip() {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this pattern will always match, so the `if let` is useless
[INFO] [stdout]    = help: consider replacing the `if let` with a `let`
[INFO] [stdout]    = note: `#[warn(irrefutable_let_patterns)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: irrefutable `if let` pattern
[INFO] [stdout]   --> src/my_ips.rs:35:8
[INFO] [stdout]    |
[INFO] [stdout] 35 |     if let addr = externamIpAddress.unwrap() {
[INFO] [stdout]    |        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: this pattern will always match, so the `if let` is useless
[INFO] [stdout]    = help: consider replacing the `if let` with a `let`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable statement
[INFO] [stdout]    --> src/netstat.rs:131:3
[INFO] [stdout]     |
[INFO] [stdout] 126 |     return "?".to_string();
[INFO] [stdout]     |     ---------------------- any code following this expression is unreachable
[INFO] [stdout] ...
[INFO] [stdout] 131 |   return stdout.to_string();
[INFO] [stdout]     |   ^^^^^^^^^^^^^^^^^^^^^^^^^^ unreachable statement
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unreachable_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unreachable statement
[INFO] [stdout]    --> src/netstat.rs:131:3
[INFO] [stdout]     |
[INFO] [stdout] 126 |     return "?".to_string();
[INFO] [stdout]     |     ---------------------- any code following this expression is unreachable
[INFO] [stdout] ...
[INFO] [stdout] 131 |   return stdout.to_string();
[INFO] [stdout]     |   ^^^^^^^^^^^^^^^^^^^^^^^^^^ unreachable statement
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unreachable_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `color_eyre::owo_colors::OwoColorize`
[INFO] [stdout]   --> src/connections_table.rs:17:5
[INFO] [stdout]    |
[INFO] [stdout] 17 | use color_eyre::owo_colors::OwoColorize;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `itertools::Itertools`
[INFO] [stdout]   --> src/connections_table.rs:19:5
[INFO] [stdout]    |
[INFO] [stdout] 19 | use itertools::Itertools;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `color_eyre::owo_colors::OwoColorize`
[INFO] [stdout]   --> src/connections_table.rs:17:5
[INFO] [stdout]    |
[INFO] [stdout] 17 | use color_eyre::owo_colors::OwoColorize;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `itertools::Itertools`
[INFO] [stdout]   --> src/connections_table.rs:19:5
[INFO] [stdout]    |
[INFO] [stdout] 19 | use itertools::Itertools;
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]   --> src/main.rs:24:9
[INFO] [stdout]    |
[INFO] [stdout] 24 |     let mut ipAddressesStr = String::new();
[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/main.rs:24:9
[INFO] [stdout]    |
[INFO] [stdout] 24 |     let mut ipAddressesStr = String::new();
[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 variable: `ipAddressesStr`
[INFO] [stdout]   --> src/main.rs:24:9
[INFO] [stdout]    |
[INFO] [stdout] 24 |     let mut ipAddressesStr = String::new();
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_ipAddressesStr`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `ipAddressesStr`
[INFO] [stdout]   --> src/main.rs:24:9
[INFO] [stdout]    |
[INFO] [stdout] 24 |     let mut ipAddressesStr = String::new();
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_ipAddressesStr`
[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/main.rs:86:9
[INFO] [stdout]    |
[INFO] [stdout] 86 |     let mut vertical_scroll = 0;
[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/main.rs:86:9
[INFO] [stdout]    |
[INFO] [stdout] 86 |     let mut vertical_scroll = 0;
[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/main.rs:87:9
[INFO] [stdout]    |
[INFO] [stdout] 87 |     let mut vertical_scroll_state: ScrollbarState = Default::default();
[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/main.rs:87:9
[INFO] [stdout]    |
[INFO] [stdout] 87 |     let mut vertical_scroll_state: ScrollbarState = Default::default();
[INFO] [stdout]    |         ----^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]    |         |
[INFO] [stdout]    |         help: remove this `mut`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `vertical_scroll`
[INFO] [stdout]   --> src/main.rs:86:9
[INFO] [stdout]    |
[INFO] [stdout] 86 |     let mut vertical_scroll = 0;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_vertical_scroll`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `vertical_scroll_state`
[INFO] [stdout]   --> src/main.rs:87:9
[INFO] [stdout]    |
[INFO] [stdout] 87 |     let mut vertical_scroll_state: ScrollbarState = Default::default();
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_vertical_scroll_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `vertical_scroll`
[INFO] [stdout]   --> src/main.rs:86:9
[INFO] [stdout]    |
[INFO] [stdout] 86 |     let mut vertical_scroll = 0;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_vertical_scroll`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `vertical_scroll_state`
[INFO] [stdout]   --> src/main.rs:87:9
[INFO] [stdout]    |
[INFO] [stdout] 87 |     let mut vertical_scroll_state: ScrollbarState = Default::default();
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_vertical_scroll_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `scroll_state`
[INFO] [stdout]    --> src/main.rs:366:103
[INFO] [stdout]     |
[INFO] [stdout] 366 | fn render_table(frame: &mut Frame, area: Rect, allConnections: &Vec<Netstat>, state: &mut TableState, scroll_state: &mut ScrollbarState) {
[INFO] [stdout]     |                                                                                                       ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_scroll_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `scroll_state`
[INFO] [stdout]    --> src/main.rs:366:103
[INFO] [stdout]     |
[INFO] [stdout] 366 | fn render_table(frame: &mut Frame, area: Rect, allConnections: &Vec<Netstat>, state: &mut TableState, scroll_state: &mut ScrollbarState) {
[INFO] [stdout]     |                                                                                                       ^^^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_scroll_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `ITEM_HEIGHT` is never used
[INFO] [stdout]   --> src/connections_table.rs:46:7
[INFO] [stdout]    |
[INFO] [stdout] 46 | const ITEM_HEIGHT: usize = 1;
[INFO] [stdout]    |       ^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `TableColors` is never constructed
[INFO] [stdout]   --> src/connections_table.rs:54:8
[INFO] [stdout]    |
[INFO] [stdout] 54 | struct TableColors {
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/connections_table.rs:68:12
[INFO] [stdout]    |
[INFO] [stdout] 67 | impl TableColors {
[INFO] [stdout]    | ---------------- associated function in this implementation
[INFO] [stdout] 68 |   const fn new(color: &tailwind::Palette) -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `ITEM_HEIGHT` is never used
[INFO] [stdout]   --> src/connections_table.rs:46:7
[INFO] [stdout]    |
[INFO] [stdout] 46 | const ITEM_HEIGHT: usize = 1;
[INFO] [stdout]    |       ^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `TableColors` is never constructed
[INFO] [stdout]   --> src/connections_table.rs:54:8
[INFO] [stdout]    |
[INFO] [stdout] 54 | struct TableColors {
[INFO] [stdout]    |        ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `new` is never used
[INFO] [stdout]   --> src/connections_table.rs:68:12
[INFO] [stdout]    |
[INFO] [stdout] 67 | impl TableColors {
[INFO] [stdout]    | ---------------- associated function in this implementation
[INFO] [stdout] 68 |   const fn new(color: &tailwind::Palette) -> Self {
[INFO] [stdout]    |            ^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ConnectionsTable` is never constructed
[INFO] [stdout]    --> src/connections_table.rs:108:12
[INFO] [stdout]     |
[INFO] [stdout] 108 | pub struct ConnectionsTable {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> src/connections_table.rs:118:10
[INFO] [stdout]     |
[INFO] [stdout] 117 | impl ConnectionsTable {
[INFO] [stdout]     | --------------------- associated items in this implementation
[INFO] [stdout] 118 |   pub fn new() -> Self {
[INFO] [stdout]     |          ^^^
[INFO] [stdout] ...
[INFO] [stdout] 129 |   pub fn next_row(&mut self) {
[INFO] [stdout]     |          ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 144 |   pub fn previous_row(&mut self) {
[INFO] [stdout]     |          ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 180 |   pub fn run(mut self, frame: &mut Frame, rect: Rect) {
[INFO] [stdout]     |          ^^^
[INFO] [stdout] ...
[INFO] [stdout] 207 |   fn draw(&mut self, frame: &mut Frame, rect: Rect) {
[INFO] [stdout]     |      ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 218 |   fn render_table(&mut self, frame: &mut Frame, area: Rect) {
[INFO] [stdout]     |      ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 334 |   fn get_style_by_state(&self, state: String) -> Style {
[INFO] [stdout]     |      ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 344 |   fn get_font_style_by_state(&self, state: String) -> Style {
[INFO] [stdout]     |      ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `ipAddresses` should have a snake case name
[INFO] [stdout]   --> src/main.rs:23:9
[INFO] [stdout]    |
[INFO] [stdout] 23 |     let ipAddresses = getMyIps().await.unwrap();
[INFO] [stdout]    |         ^^^^^^^^^^^ help: convert the identifier to snake case: `ip_addresses`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `ConnectionsTable` is never constructed
[INFO] [stdout]    --> src/connections_table.rs:108:12
[INFO] [stdout]     |
[INFO] [stdout] 108 | pub struct ConnectionsTable {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> src/connections_table.rs:118:10
[INFO] [stdout]     |
[INFO] [stdout] 117 | impl ConnectionsTable {
[INFO] [stdout]     | --------------------- associated items in this implementation
[INFO] [stdout] 118 |   pub fn new() -> Self {
[INFO] [stdout]     |          ^^^
[INFO] [stdout] ...
[INFO] [stdout] 129 |   pub fn next_row(&mut self) {
[INFO] [stdout]     |          ^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 144 |   pub fn previous_row(&mut self) {
[INFO] [stdout]     |          ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 180 |   pub fn run(mut self, frame: &mut Frame, rect: Rect) {
[INFO] [stdout]     |          ^^^
[INFO] [stdout] ...
[INFO] [stdout] 207 |   fn draw(&mut self, frame: &mut Frame, rect: Rect) {
[INFO] [stdout]     |      ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 218 |   fn render_table(&mut self, frame: &mut Frame, area: Rect) {
[INFO] [stdout]     |      ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 334 |   fn get_style_by_state(&self, state: String) -> Style {
[INFO] [stdout]     |      ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 344 |   fn get_font_style_by_state(&self, state: String) -> Style {
[INFO] [stdout]     |      ^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `ipAddressesStr` should have a snake case name
[INFO] [stdout]   --> src/main.rs:24:13
[INFO] [stdout]    |
[INFO] [stdout] 24 |     let mut ipAddressesStr = String::new();
[INFO] [stdout]    |             ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `ip_addresses_str`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `ipAddresses` should have a snake case name
[INFO] [stdout]   --> src/main.rs:23:9
[INFO] [stdout]    |
[INFO] [stdout] 23 |     let ipAddresses = getMyIps().await.unwrap();
[INFO] [stdout]    |         ^^^^^^^^^^^ help: convert the identifier to snake case: `ip_addresses`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(non_snake_case)]` (part of `#[warn(nonstandard_style)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `ipAddrsLines` should have a snake case name
[INFO] [stdout]   --> src/main.rs:25:13
[INFO] [stdout]    |
[INFO] [stdout] 25 |     let mut ipAddrsLines = Vec::<Line>::new();
[INFO] [stdout]    |             ^^^^^^^^^^^^ help: convert the identifier to snake case: `ip_addrs_lines`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `ipAddressesStr` should have a snake case name
[INFO] [stdout]   --> src/main.rs:24:13
[INFO] [stdout]    |
[INFO] [stdout] 24 |     let mut ipAddressesStr = String::new();
[INFO] [stdout]    |             ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `ip_addresses_str`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `ipAddrsLines` should have a snake case name
[INFO] [stdout]   --> src/main.rs:25:13
[INFO] [stdout]    |
[INFO] [stdout] 25 |     let mut ipAddrsLines = Vec::<Line>::new();
[INFO] [stdout]    |             ^^^^^^^^^^^^ help: convert the identifier to snake case: `ip_addrs_lines`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `ipAddress` should have a snake case name
[INFO] [stdout]   --> src/main.rs:26:9
[INFO] [stdout]    |
[INFO] [stdout] 26 |     for ipAddress in ipAddresses {
[INFO] [stdout]    |         ^^^^^^^^^ help: convert the identifier to snake case: `ip_address`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `ipAddress` should have a snake case name
[INFO] [stdout]   --> src/main.rs:26:9
[INFO] [stdout]    |
[INFO] [stdout] 26 |     for ipAddress in ipAddresses {
[INFO] [stdout]    |         ^^^^^^^^^ help: convert the identifier to snake case: `ip_address`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `ipAddresses` should have a snake case name
[INFO] [stdout]   --> src/main.rs:83:39
[INFO] [stdout]    |
[INFO] [stdout] 83 | fn run(mut terminal: DefaultTerminal, ipAddresses: Vec<Line>) -> io::Result<()> {
[INFO] [stdout]    |                                       ^^^^^^^^^^^ help: convert the identifier to snake case: `ip_addresses`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `connTableState` should have a snake case name
[INFO] [stdout]   --> src/main.rs:89:13
[INFO] [stdout]    |
[INFO] [stdout] 89 |     let mut connTableState: TableState = TableState::default().with_selected(0);
[INFO] [stdout]    |             ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `conn_table_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `connTableScrollbarState` should have a snake case name
[INFO] [stdout]   --> src/main.rs:90:13
[INFO] [stdout]    |
[INFO] [stdout] 90 |     let mut connTableScrollbarState: ScrollbarState = Default::default();
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `conn_table_scrollbar_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `allConnections` should have a snake case name
[INFO] [stdout]   --> src/main.rs:91:9
[INFO] [stdout]    |
[INFO] [stdout] 91 |     let allConnections = get_all_connections();
[INFO] [stdout]    |         ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `all_connections`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `ipAddresses` should have a snake case name
[INFO] [stdout]   --> src/main.rs:83:39
[INFO] [stdout]    |
[INFO] [stdout] 83 | fn run(mut terminal: DefaultTerminal, ipAddresses: Vec<Line>) -> io::Result<()> {
[INFO] [stdout]    |                                       ^^^^^^^^^^^ help: convert the identifier to snake case: `ip_addresses`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `connTableState` should have a snake case name
[INFO] [stdout]   --> src/main.rs:89:13
[INFO] [stdout]    |
[INFO] [stdout] 89 |     let mut connTableState: TableState = TableState::default().with_selected(0);
[INFO] [stdout]    |             ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `conn_table_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `connTableScrollbarState` should have a snake case name
[INFO] [stdout]   --> src/main.rs:90:13
[INFO] [stdout]    |
[INFO] [stdout] 90 |     let mut connTableScrollbarState: ScrollbarState = Default::default();
[INFO] [stdout]    |             ^^^^^^^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `conn_table_scrollbar_state`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `allConnections` should have a snake case name
[INFO] [stdout]   --> src/main.rs:91:9
[INFO] [stdout]    |
[INFO] [stdout] 91 |     let allConnections = get_all_connections();
[INFO] [stdout]    |         ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `all_connections`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `ScrollbarState::position` that must be used
[INFO] [stdout]    --> src/main.rs:348:5
[INFO] [stdout]     |
[INFO] [stdout] 348 |     scroll_state.position(i * 1);
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: method moves the value of self and returns the modified value
[INFO] [stdout]     = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 348 |     let _ = scroll_state.position(i * 1);
[INFO] [stdout]     |     +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `ScrollbarState::position` that must be used
[INFO] [stdout]    --> src/main.rs:363:5
[INFO] [stdout]     |
[INFO] [stdout] 363 |     scroll_state.position(i * 1);
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: method moves the value of self and returns the modified value
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 363 |     let _ = scroll_state.position(i * 1);
[INFO] [stdout]     |     +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `allConnections` should have a snake case name
[INFO] [stdout]    --> src/main.rs:366:48
[INFO] [stdout]     |
[INFO] [stdout] 366 | fn render_table(frame: &mut Frame, area: Rect, allConnections: &Vec<Netstat>, state: &mut TableState, scroll_state: &mut ScrollbarState) {
[INFO] [stdout]     |                                                ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `all_connections`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `getPublicIp` should have a snake case name
[INFO] [stdout]   --> src/my_ips.rs:10:10
[INFO] [stdout]    |
[INFO] [stdout] 10 | async fn getPublicIp() -> Result<IP_Address, Box<dyn Error>> {
[INFO] [stdout]    |          ^^^^^^^^^^^ help: convert the identifier to snake case: `get_public_ip`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `getMyIps` should have a snake case name
[INFO] [stdout]   --> src/my_ips.rs:21:14
[INFO] [stdout]    |
[INFO] [stdout] 21 | pub async fn getMyIps() -> Result<Vec<IP_Address>, Box<dyn Error>> {
[INFO] [stdout]    |              ^^^^^^^^ help: convert the identifier to snake case: `get_my_ips`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `ipAddresses` should have a snake case name
[INFO] [stdout]   --> src/my_ips.rs:24:13
[INFO] [stdout]    |
[INFO] [stdout] 24 |     let mut ipAddresses = Vec::new();
[INFO] [stdout]    |             ^^^^^^^^^^^ help: convert the identifier to snake case: `ip_addresses`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `externamIpAddress` should have a snake case name
[INFO] [stdout]   --> src/my_ips.rs:33:9
[INFO] [stdout]    |
[INFO] [stdout] 33 |     let externamIpAddress = getPublicIp().await;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `externam_ip_address`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `allProcesses` should have a snake case name
[INFO] [stdout]   --> src/netstat.rs:35:7
[INFO] [stdout]    |
[INFO] [stdout] 35 |   let allProcesses = get_all_processes();
[INFO] [stdout]    |       ^^^^^^^^^^^^ help: convert the identifier to snake case: `all_processes`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `netStats` should have a snake case name
[INFO] [stdout]   --> src/netstat.rs:41:11
[INFO] [stdout]    |
[INFO] [stdout] 41 |   let mut netStats = Vec::new();
[INFO] [stdout]    |           ^^^^^^^^ help: convert the identifier to snake case: `net_stats`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `ipStr` should have a snake case name
[INFO] [stdout]    --> src/netstat.rs:112:16
[INFO] [stdout]     |
[INFO] [stdout] 112 | pub fn get_dns(ipStr: String) -> String {
[INFO] [stdout]     |                ^^^^^ help: convert the identifier to snake case: `ip_str`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `ScrollbarState::position` that must be used
[INFO] [stdout]    --> src/main.rs:348:5
[INFO] [stdout]     |
[INFO] [stdout] 348 |     scroll_state.position(i * 1);
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: method moves the value of self and returns the modified value
[INFO] [stdout]     = note: `#[warn(unused_must_use)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 348 |     let _ = scroll_state.position(i * 1);
[INFO] [stdout]     |     +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused return value of `ScrollbarState::position` that must be used
[INFO] [stdout]    --> src/main.rs:363:5
[INFO] [stdout]     |
[INFO] [stdout] 363 |     scroll_state.position(i * 1);
[INFO] [stdout]     |     ^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: method moves the value of self and returns the modified value
[INFO] [stdout] help: use `let _ = ...` to ignore the resulting value
[INFO] [stdout]     |
[INFO] [stdout] 363 |     let _ = scroll_state.position(i * 1);
[INFO] [stdout]     |     +++++++
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `allConnections` should have a snake case name
[INFO] [stdout]    --> src/main.rs:366:48
[INFO] [stdout]     |
[INFO] [stdout] 366 | fn render_table(frame: &mut Frame, area: Rect, allConnections: &Vec<Netstat>, state: &mut TableState, scroll_state: &mut ScrollbarState) {
[INFO] [stdout]     |                                                ^^^^^^^^^^^^^^ help: convert the identifier to snake case: `all_connections`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `getPublicIp` should have a snake case name
[INFO] [stdout]   --> src/my_ips.rs:10:10
[INFO] [stdout]    |
[INFO] [stdout] 10 | async fn getPublicIp() -> Result<IP_Address, Box<dyn Error>> {
[INFO] [stdout]    |          ^^^^^^^^^^^ help: convert the identifier to snake case: `get_public_ip`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `getMyIps` should have a snake case name
[INFO] [stdout]   --> src/my_ips.rs:21:14
[INFO] [stdout]    |
[INFO] [stdout] 21 | pub async fn getMyIps() -> Result<Vec<IP_Address>, Box<dyn Error>> {
[INFO] [stdout]    |              ^^^^^^^^ help: convert the identifier to snake case: `get_my_ips`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `ipAddresses` should have a snake case name
[INFO] [stdout]   --> src/my_ips.rs:24:13
[INFO] [stdout]    |
[INFO] [stdout] 24 |     let mut ipAddresses = Vec::new();
[INFO] [stdout]    |             ^^^^^^^^^^^ help: convert the identifier to snake case: `ip_addresses`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `externamIpAddress` should have a snake case name
[INFO] [stdout]   --> src/my_ips.rs:33:9
[INFO] [stdout]    |
[INFO] [stdout] 33 |     let externamIpAddress = getPublicIp().await;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^ help: convert the identifier to snake case: `externam_ip_address`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `allProcesses` should have a snake case name
[INFO] [stdout]   --> src/netstat.rs:35:7
[INFO] [stdout]    |
[INFO] [stdout] 35 |   let allProcesses = get_all_processes();
[INFO] [stdout]    |       ^^^^^^^^^^^^ help: convert the identifier to snake case: `all_processes`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `netStats` should have a snake case name
[INFO] [stdout]   --> src/netstat.rs:41:11
[INFO] [stdout]    |
[INFO] [stdout] 41 |   let mut netStats = Vec::new();
[INFO] [stdout]    |           ^^^^^^^^ help: convert the identifier to snake case: `net_stats`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable `ipStr` should have a snake case name
[INFO] [stdout]    --> src/netstat.rs:112:16
[INFO] [stdout]     |
[INFO] [stdout] 112 | pub fn get_dns(ipStr: String) -> String {
[INFO] [stdout]     |                ^^^^^ help: convert the identifier to snake case: `ip_str`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 48.80s
[INFO] running `Command { std: "docker" "inspect" "7810b59e293beb741a3fd14b30f337bc0d2c97139a231e8cd8c70c5ef8703c55", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "7810b59e293beb741a3fd14b30f337bc0d2c97139a231e8cd8c70c5ef8703c55", kill_on_drop: false }`
[INFO] [stdout] 7810b59e293beb741a3fd14b30f337bc0d2c97139a231e8cd8c70c5ef8703c55
