[INFO] cloning repository https://github.com/micferna/proxmox-manager
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/micferna/proxmox-manager" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fmicferna%2Fproxmox-manager", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fmicferna%2Fproxmox-manager'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] d0269ab2291fe11e15a2b2364488365fe9b86c48
[INFO] checking micferna/proxmox-manager against try#d336647335db03a0fc5b24fc5325cd3905c5b8e8 for pr-151146
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2Fmicferna%2Fproxmox-manager" "/workspace/builds/worker-7-tc2/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-7-tc2/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/micferna/proxmox-manager
[INFO] finished tweaking git repo https://github.com/micferna/proxmox-manager
[INFO] tweaked toml for git repo https://github.com/micferna/proxmox-manager written to /workspace/builds/worker-7-tc2/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/micferna/proxmox-manager 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/micferna/proxmox-manager 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] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-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] fb024c474f7e47f501f983e51f0d30872002cdc05da0b22bbcb13f23bb6b4fbc
[INFO] running `Command { std: "docker" "start" "-a" "fb024c474f7e47f501f983e51f0d30872002cdc05da0b22bbcb13f23bb6b4fbc", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "fb024c474f7e47f501f983e51f0d30872002cdc05da0b22bbcb13f23bb6b4fbc", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "fb024c474f7e47f501f983e51f0d30872002cdc05da0b22bbcb13f23bb6b4fbc", kill_on_drop: false }`
[INFO] [stdout] fb024c474f7e47f501f983e51f0d30872002cdc05da0b22bbcb13f23bb6b4fbc
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc2/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-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] 0d402969ff9b1f17b1b83146bdfaedb5228075ce09ee180cac1e4433b331f5ea
[INFO] running `Command { std: "docker" "start" "-a" "0d402969ff9b1f17b1b83146bdfaedb5228075ce09ee180cac1e4433b331f5ea", kill_on_drop: false }`
[INFO] [stderr]    Compiling proc-macro2 v1.0.103
[INFO] [stderr]    Compiling rustix v1.1.2
[INFO] [stderr]    Compiling quote v1.0.42
[INFO] [stderr]     Checking tracing-core v0.1.35
[INFO] [stderr]    Compiling cc v1.2.49
[INFO] [stderr]    Compiling zerocopy v0.8.31
[INFO] [stderr]    Compiling wayland-sys v0.31.7
[INFO] [stderr]    Compiling toml_datetime v0.7.3
[INFO] [stderr]    Compiling toml_parser v1.0.4
[INFO] [stderr]    Compiling getrandom v0.3.4
[INFO] [stderr]    Compiling serde_core v1.0.228
[INFO] [stderr]    Compiling memoffset v0.9.1
[INFO] [stderr]     Checking generic-array v0.14.7
[INFO] [stderr]    Compiling endi v1.1.1
[INFO] [stderr]    Compiling static_assertions v1.1.0
[INFO] [stderr]    Compiling nix v0.29.0
[INFO] [stderr]     Checking getrandom v0.2.16
[INFO] [stderr]     Checking async-channel v2.5.0
[INFO] [stderr]     Checking owned_ttf_parser v0.25.1
[INFO] [stderr]     Checking async-lock v3.4.1
[INFO] [stderr]     Checking signal-hook-registry v1.4.7
[INFO] [stderr]     Checking socket2 v0.6.1
[INFO] [stderr]     Checking rand_core v0.6.4
[INFO] [stderr]     Checking mio v1.1.1
[INFO] [stderr]    Compiling rustix v0.38.44
[INFO] [stderr]     Checking blocking v1.6.2
[INFO] [stderr]     Checking ab_glyph v0.2.32
[INFO] [stderr]     Checking icu_properties_data v2.1.2
[INFO] [stderr]     Checking icu_normalizer_data v2.1.1
[INFO] [stderr]     Checking async-executor v1.13.3
[INFO] [stderr]    Compiling toml_edit v0.23.9
[INFO] [stderr]     Checking async-broadcast v0.7.2
[INFO] [stderr]     Checking xdg-home v1.3.0
[INFO] [stderr]     Checking ordered-stream v0.2.0
[INFO] [stderr]    Compiling xml-rs v0.8.28
[INFO] [stderr]    Compiling log v0.4.29
[INFO] [stderr]    Compiling syn v2.0.111
[INFO] [stderr]     Checking async-fs v2.2.0
[INFO] [stderr]    Compiling wayland-scanner v0.31.7
[INFO] [stderr]     Checking block-buffer v0.10.4
[INFO] [stderr]     Checking crypto-common v0.1.7
[INFO] [stderr]     Checking accesskit v0.17.1
[INFO] [stderr]     Checking digest v0.10.7
[INFO] [stderr]     Checking http v1.4.0
[INFO] [stderr]    Compiling smithay-client-toolkit v0.19.2
[INFO] [stderr]     Checking indexmap v2.12.1
[INFO] [stderr]     Checking x11-dl v2.21.0
[INFO] [stderr]     Checking form_urlencoded v1.2.2
[INFO] [stderr]     Checking immutable-chunkmap v2.1.2
[INFO] [stderr]     Checking sha1 v0.10.6
[INFO] [stderr]    Compiling wayland-backend v0.3.11
[INFO] [stderr]    Compiling openssl-sys v0.9.111
[INFO] [stderr]    Compiling gl_generator v0.14.0
[INFO] [stderr]    Compiling proc-macro-crate v3.4.0
[INFO] [stderr]     Checking http-body v1.0.1
[INFO] [stderr]    Compiling winit v0.30.12
[INFO] [stderr]    Compiling openssl v0.10.75
[INFO] [stderr]     Checking epaint_default_fonts v0.30.0
[INFO] [stderr]    Compiling phf_shared v0.11.3
[INFO] [stderr]     Checking accesskit_consumer v0.26.0
[INFO] [stderr]     Checking xkbcommon-dl v0.4.2
[INFO] [stderr]     Checking ppv-lite86 v0.2.21
[INFO] [stderr]     Checking ahash v0.8.12
[INFO] [stderr]    Compiling native-tls v0.2.14
[INFO] [stderr]    Compiling smithay-client-toolkit v0.20.0
[INFO] [stderr]     Checking unicode-width v0.2.2
[INFO] [stderr]    Compiling phf v0.11.3
[INFO] [stderr]     Checking deranged v0.5.5
[INFO] [stderr]     Checking flate2 v1.1.5
[INFO] [stderr]    Compiling glutin_egl_sys v0.7.1
[INFO] [stderr]    Compiling glutin_glx_sys v0.6.1
[INFO] [stderr]    Compiling glutin v0.32.3
[INFO] [stderr]    Compiling syn v1.0.109
[INFO] [stderr]     Checking moxcms v0.7.10
[INFO] [stderr]    Compiling mime_guess2 v2.3.1
[INFO] [stderr]     Checking rand_chacha v0.3.1
[INFO] [stderr]     Checking rand v0.8.5
[INFO] [stderr]     Checking png v0.18.0
[INFO] [stderr]    Compiling proc-macro-error-attr2 v2.0.0
[INFO] [stderr]    Compiling glutin-winit v0.5.0
[INFO] [stderr]     Checking sync_wrapper v1.0.2
[INFO] [stderr]     Checking anstyle-query v1.1.5
[INFO] [stderr]    Compiling portable-atomic v1.11.1
[INFO] [stderr]     Checking tower-layer v0.3.3
[INFO] [stderr]     Checking is_terminal_polyfill v1.70.2
[INFO] [stderr]     Checking zeroize v1.8.2
[INFO] [stderr]     Checking regex-automata v0.4.13
[INFO] [stderr]     Checking serde_json v1.0.145
[INFO] [stderr]     Checking anstream v0.6.21
[INFO] [stderr]     Checking console v0.15.11
[INFO] [stderr]     Checking http-body-util v0.1.3
[INFO] [stderr]     Checking rand_core v0.9.3
[INFO] [stderr]     Checking iri-string v0.7.9
[INFO] [stderr]     Checking clap_lex v0.7.6
[INFO] [stderr]     Checking winnow v0.7.14
[INFO] [stderr]    Compiling anyhow v1.0.100
[INFO] [stderr]     Checking bytecount v0.6.9
[INFO] [stderr]     Checking papergrid v0.13.0
[INFO] [stderr]     Checking clap_builder v4.5.53
[INFO] [stderr]     Checking polling v3.11.0
[INFO] [stderr]     Checking async-io v2.6.0
[INFO] [stderr]     Checking gethostname v1.1.0
[INFO] [stderr]     Checking time v0.3.44
[INFO] [stderr]     Checking x11rb v0.13.2
[INFO] [stderr]     Checking tempfile v3.23.0
[INFO] [stderr]     Checking rand_chacha v0.9.0
[INFO] [stderr]     Checking dirs-sys v0.5.0
[INFO] [stderr]     Checking rustls-pki-types v1.13.1
[INFO] [stderr]     Checking tracing-log v0.2.0
[INFO] [stderr]     Checking rtoolbox v0.0.3
[INFO] [stderr]     Checking encoding_rs v0.8.35
[INFO] [stderr]     Checking iana-time-zone v0.1.64
[INFO] [stderr]     Checking wayland-client v0.31.11
[INFO] [stderr]     Checking wayland-csd-frame v0.3.0
[INFO] [stderr]     Checking number_prefix v0.4.0
[INFO] [stderr]     Checking shell-words v1.1.0
[INFO] [stderr]     Checking rpassword v7.4.0
[INFO] [stderr]     Checking dirs v6.0.0
[INFO] [stderr]     Checking rand v0.9.2
[INFO] [stderr]     Checking matchers v0.2.0
[INFO] [stderr]     Checking indicatif v0.17.11
[INFO] [stderr]     Checking terminal_size v0.4.3
[INFO] [stderr]     Checking mac_address v1.1.8
[INFO] [stderr]     Checking uuid v1.19.0
[INFO] [stderr]     Checking ipnetwork v0.21.1
[INFO] [stderr]     Checking cookie v0.18.1
[INFO] [stderr]    Compiling synstructure v0.13.2
[INFO] [stderr]    Compiling zvariant_utils v2.1.0
[INFO] [stderr]    Compiling proc-macro-error2 v2.0.1
[INFO] [stderr]     Checking wayland-protocols v0.32.9
[INFO] [stderr]     Checking wayland-cursor v0.31.11
[INFO] [stderr]     Checking arboard v3.6.1
[INFO] [stderr]    Compiling serde_derive v1.0.228
[INFO] [stderr]    Compiling tracing-attributes v0.1.31
[INFO] [stderr]    Compiling enumflags2_derive v0.7.12
[INFO] [stderr]    Compiling zerofrom-derive v0.1.6
[INFO] [stderr]    Compiling zvariant_derive v4.2.0
[INFO] [stderr]    Compiling yoke-derive v0.8.1
[INFO] [stderr]    Compiling zerovec-derive v0.11.2
[INFO] [stderr]    Compiling futures-macro v0.3.31
[INFO] [stderr]    Compiling displaydoc v0.2.5
[INFO] [stderr]    Compiling bytemuck_derive v1.10.2
[INFO] [stderr]    Compiling thiserror-impl v1.0.69
[INFO] [stderr]    Compiling tokio-macros v2.6.0
[INFO] [stderr]    Compiling serde_repr v0.1.20
[INFO] [stderr]    Compiling zbus_macros v4.4.0
[INFO] [stderr]    Compiling async-trait v0.1.89
[INFO] [stderr]    Compiling thiserror-impl v2.0.17
[INFO] [stderr]     Checking futures-util v0.3.31
[INFO] [stderr]    Compiling openssl-macros v0.1.1
[INFO] [stderr]    Compiling enum-map-derive v0.17.0
[INFO] [stderr]    Compiling tabled_derive v0.9.0
[INFO] [stderr]     Checking tokio v1.48.0
[INFO] [stderr]    Compiling clap_derive v4.5.49
[INFO] [stderr]     Checking bytemuck v1.24.0
[INFO] [stderr]     Checking tiny-skia-path v0.11.4
[INFO] [stderr]     Checking emath v0.30.0
[INFO] [stderr]     Checking thiserror v1.0.69
[INFO] [stderr]     Checking calloop v0.13.0
[INFO] [stderr]     Checking tracing v0.1.43
[INFO] [stderr]     Checking zerofrom v0.1.6
[INFO] [stderr]     Checking image v0.25.9
[INFO] [stderr]     Checking calloop v0.14.3
[INFO] [stderr]     Checking yoke v0.8.1
[INFO] [stderr]     Checking calloop-wayland-source v0.3.0
[INFO] [stderr]     Checking tracing-subscriber v0.3.22
[INFO] [stderr]     Checking dialoguer v0.11.0
[INFO] [stderr]     Checking zerovec v0.11.5
[INFO] [stderr]     Checking zerotrie v0.2.3
[INFO] [stderr]     Checking ecolor v0.30.0
[INFO] [stderr]     Checking tiny-skia v0.11.4
[INFO] [stderr]     Checking epaint v0.30.0
[INFO] [stderr]     Checking thiserror v2.0.17
[INFO] [stderr]     Checking calloop-wayland-source v0.4.1
[INFO] [stderr]     Checking tabled v0.17.0
[INFO] [stderr]     Checking tinystr v0.8.2
[INFO] [stderr]     Checking potential_utf v0.1.4
[INFO] [stderr]     Checking icu_collections v2.1.1
[INFO] [stderr]     Checking icu_locale_core v2.1.1
[INFO] [stderr]     Checking serde v1.0.228
[INFO] [stderr]     Checking clap v4.5.53
[INFO] [stderr]     Checking egui v0.30.0
[INFO] [stderr]     Checking icu_provider v2.1.1
[INFO] [stderr]     Checking icu_normalizer v2.1.1
[INFO] [stderr]     Checking icu_properties v2.1.2
[INFO] [stderr]     Checking enumflags2 v0.7.12
[INFO] [stderr]     Checking quick-xml v0.30.0
[INFO] [stderr]     Checking serde_spanned v0.6.9
[INFO] [stderr]     Checking toml_datetime v0.6.11
[INFO] [stderr]     Checking serde_urlencoded v0.7.1
[INFO] [stderr]     Checking enum-map v2.7.3
[INFO] [stderr]     Checking chrono v0.4.42
[INFO] [stderr]     Checking zvariant v4.2.0
[INFO] [stderr]     Checking toml_edit v0.22.27
[INFO] [stderr]     Checking idna_adapter v1.2.1
[INFO] [stderr]     Checking idna v1.1.0
[INFO] [stderr]     Checking tokio-util v0.7.17
[INFO] [stderr]     Checking tower v0.5.2
[INFO] [stderr]     Checking tokio-native-tls v0.3.1
[INFO] [stderr]     Checking poll-promise v0.3.0
[INFO] [stderr]     Checking url v2.5.7
[INFO] [stderr]     Checking publicsuffix v2.3.0
[INFO] [stderr]     Checking wayland-protocols-wlr v0.3.9
[INFO] [stderr]     Checking wayland-protocols-plasma v0.3.9
[INFO] [stderr]     Checking wayland-protocols-misc v0.3.9
[INFO] [stderr]     Checking wayland-protocols-experimental v20250721.0.1
[INFO] [stderr]     Checking toml v0.8.23
[INFO] [stderr]     Checking tower-http v0.6.8
[INFO] [stderr]     Checking h2 v0.4.12
[INFO] [stderr]     Checking webbrowser v1.0.6
[INFO] [stderr]     Checking cookie_store v0.21.1
[INFO] [stderr]     Checking egui_glow v0.30.0
[INFO] [stderr]     Checking egui_extras v0.30.0
[INFO] [stderr]     Checking zbus_names v3.0.0
[INFO] [stderr]    Compiling zbus_xml v4.0.0
[INFO] [stderr]     Checking zbus v4.4.0
[INFO] [stderr]    Compiling zbus-lockstep v0.4.4
[INFO] [stderr]    Compiling zbus-lockstep-macros v0.4.4
[INFO] [stderr]     Checking smithay-clipboard v0.7.3
[INFO] [stderr]     Checking sctk-adwaita v0.10.1
[INFO] [stderr]     Checking hyper v1.8.1
[INFO] [stderr]     Checking hyper-util v0.1.19
[INFO] [stderr]     Checking hyper-tls v0.6.0
[INFO] [stderr]     Checking reqwest v0.12.25
[INFO] [stderr]     Checking atspi-common v0.6.0
[INFO] [stderr]     Checking atspi-proxies v0.6.0
[INFO] [stderr]     Checking accesskit_atspi_common v0.10.1
[INFO] [stderr]     Checking atspi-connection v0.6.0
[INFO] [stderr]     Checking atspi v0.22.0
[INFO] [stderr]     Checking accesskit_unix v0.13.1
[INFO] [stderr]     Checking accesskit_winit v0.23.1
[INFO] [stderr]     Checking egui-winit v0.30.0
[INFO] [stderr]     Checking eframe v0.30.0
[INFO] [stderr]     Checking proxmox-manager v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `Serialize`
[INFO] [stdout]  --> src/api/client.rs:4:48
[INFO] [stdout]   |
[INFO] [stdout] 4 | use serde::{de::DeserializeOwned, Deserialize, Serialize};
[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: `MultiSelect`
[INFO] [stdout]  --> src/cli/interactive.rs:5:55
[INFO] [stdout]   |
[INFO] [stdout] 5 | use dialoguer::{theme::ColorfulTheme, Confirm, Input, MultiSelect, Password, Select};
[INFO] [stdout]   |                                                       ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `rand::Rng`
[INFO] [stdout]  --> src/cli/interactive.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use rand::Rng;
[INFO] [stdout]   |     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]  --> src/cli/interactive.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use std::collections::HashMap;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::net::Ipv4Addr`
[INFO] [stdout]  --> src/config/mod.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::net::Ipv4Addr;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Deserializer`
[INFO] [stdout]  --> src/models/vm.rs:1:26
[INFO] [stdout]   |
[INFO] [stdout] 1 | use serde::{Deserialize, Deserializer, Serialize};
[INFO] [stdout]   |                          ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Read`
[INFO] [stdout]  --> src/models/ip_pool.rs:5:15
[INFO] [stdout]   |
[INFO] [stdout] 5 | use std::io::{Read, Write};
[INFO] [stdout]   |               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Serialize`
[INFO] [stdout]  --> src/api/client.rs:4:48
[INFO] [stdout]   |
[INFO] [stdout] 4 | use serde::{de::DeserializeOwned, Deserialize, Serialize};
[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: `MultiSelect`
[INFO] [stdout]  --> src/cli/interactive.rs:5:55
[INFO] [stdout]   |
[INFO] [stdout] 5 | use dialoguer::{theme::ColorfulTheme, Confirm, Input, MultiSelect, Password, Select};
[INFO] [stdout]   |                                                       ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `rand::Rng`
[INFO] [stdout]  --> src/cli/interactive.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use rand::Rng;
[INFO] [stdout]   |     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]  --> src/cli/interactive.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use std::collections::HashMap;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::net::Ipv4Addr`
[INFO] [stdout]  --> src/config/mod.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::net::Ipv4Addr;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Deserializer`
[INFO] [stdout]  --> src/models/vm.rs:1:26
[INFO] [stdout]   |
[INFO] [stdout] 1 | use serde::{Deserialize, Deserializer, Serialize};
[INFO] [stdout]   |                          ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Read`
[INFO] [stdout]  --> src/models/ip_pool.rs:5:15
[INFO] [stdout]   |
[INFO] [stdout] 5 | use std::io::{Read, Write};
[INFO] [stdout]   |               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `vmid`
[INFO] [stdout]    --> src/cli/interactive.rs:371:5
[INFO] [stdout]     |
[INFO] [stdout] 371 |     vmid: u32,
[INFO] [stdout]     |     ^^^^ help: if this is intentional, prefix it with an underscore: `_vmid`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `vmid`
[INFO] [stdout]    --> src/cli/interactive.rs:371:5
[INFO] [stdout]     |
[INFO] [stdout] 371 |     vmid: u32,
[INFO] [stdout]     |     ^^^^ help: if this is intentional, prefix it with an underscore: `_vmid`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `errors` is never read
[INFO] [stdout]   --> src/api/client.rs:27:5
[INFO] [stdout]    |
[INFO] [stdout] 25 | struct ApiResponse<T> {
[INFO] [stdout]    |        ----------- field in this struct
[INFO] [stdout] 26 |     data: Option<T>,
[INFO] [stdout] 27 |     errors: Option<HashMap<String, String>>,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ApiResponse` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `username` is never read
[INFO] [stdout]   --> src/api/client.rs:36:5
[INFO] [stdout]    |
[INFO] [stdout] 32 | struct AuthResponse {
[INFO] [stdout]    |        ------------ field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 36 |     username: String,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `AuthResponse` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `errors` is never read
[INFO] [stdout]   --> src/api/client.rs:27:5
[INFO] [stdout]    |
[INFO] [stdout] 25 | struct ApiResponse<T> {
[INFO] [stdout]    |        ----------- field in this struct
[INFO] [stdout] 26 |     data: Option<T>,
[INFO] [stdout] 27 |     errors: Option<HashMap<String, String>>,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ApiResponse` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `username` is never read
[INFO] [stdout]   --> src/api/client.rs:36:5
[INFO] [stdout]    |
[INFO] [stdout] 32 | struct AuthResponse {
[INFO] [stdout]    |        ------------ field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 36 |     username: String,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `AuthResponse` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `poll_promise::Promise`
[INFO] [stdout]  --> src/gui/widgets/login_dialog.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use poll_promise::Promise;
[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: `std::collections::HashMap`
[INFO] [stdout]  --> src/gui/widgets/cloud_init_dialog.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use std::collections::HashMap;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `poll_promise::Promise`
[INFO] [stdout]  --> src/gui/widgets/login_dialog.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use poll_promise::Promise;
[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: `std::collections::HashMap`
[INFO] [stdout]  --> src/gui/widgets/cloud_init_dialog.rs:3:5
[INFO] [stdout]   |
[INFO] [stdout] 3 | use std::collections::HashMap;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Serialize`
[INFO] [stdout]  --> src/api/client.rs:4:48
[INFO] [stdout]   |
[INFO] [stdout] 4 | use serde::{de::DeserializeOwned, Deserialize, Serialize};
[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 imports: `VmIpEntry` and `VmIpInfo`
[INFO] [stdout]  --> src/api/mod.rs:4:33
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub use client::{ProxmoxClient, VmIpInfo, VmIpEntry};
[INFO] [stdout]   |                                 ^^^^^^^^  ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `error::ApiError`
[INFO] [stdout]  --> src/api/mod.rs:5:9
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub use error::ApiError;
[INFO] [stdout]   |         ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `MultiSelect`
[INFO] [stdout]  --> src/cli/interactive.rs:5:55
[INFO] [stdout]   |
[INFO] [stdout] 5 | use dialoguer::{theme::ColorfulTheme, Confirm, Input, MultiSelect, Password, Select};
[INFO] [stdout]   |                                                       ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `rand::Rng`
[INFO] [stdout]  --> src/cli/interactive.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use rand::Rng;
[INFO] [stdout]   |     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]  --> src/cli/interactive.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use std::collections::HashMap;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::net::Ipv4Addr`
[INFO] [stdout]  --> src/config/mod.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::net::Ipv4Addr;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Deserializer`
[INFO] [stdout]  --> src/models/vm.rs:1:26
[INFO] [stdout]   |
[INFO] [stdout] 1 | use serde::{Deserialize, Deserializer, Serialize};
[INFO] [stdout]   |                          ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Read`
[INFO] [stdout]  --> src/models/ip_pool.rs:5:15
[INFO] [stdout]   |
[INFO] [stdout] 5 | use std::io::{Read, Write};
[INFO] [stdout]   |               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Serialize`
[INFO] [stdout]  --> src/api/client.rs:4:48
[INFO] [stdout]   |
[INFO] [stdout] 4 | use serde::{de::DeserializeOwned, Deserialize, Serialize};
[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 imports: `VmIpEntry` and `VmIpInfo`
[INFO] [stdout]  --> src/api/mod.rs:4:33
[INFO] [stdout]   |
[INFO] [stdout] 4 | pub use client::{ProxmoxClient, VmIpInfo, VmIpEntry};
[INFO] [stdout]   |                                 ^^^^^^^^  ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `error::ApiError`
[INFO] [stdout]  --> src/api/mod.rs:5:9
[INFO] [stdout]   |
[INFO] [stdout] 5 | pub use error::ApiError;
[INFO] [stdout]   |         ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `MultiSelect`
[INFO] [stdout]  --> src/cli/interactive.rs:5:55
[INFO] [stdout]   |
[INFO] [stdout] 5 | use dialoguer::{theme::ColorfulTheme, Confirm, Input, MultiSelect, Password, Select};
[INFO] [stdout]   |                                                       ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `rand::Rng`
[INFO] [stdout]  --> src/cli/interactive.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use rand::Rng;
[INFO] [stdout]   |     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::collections::HashMap`
[INFO] [stdout]  --> src/cli/interactive.rs:7:5
[INFO] [stdout]   |
[INFO] [stdout] 7 | use std::collections::HashMap;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::net::Ipv4Addr`
[INFO] [stdout]  --> src/config/mod.rs:2:5
[INFO] [stdout]   |
[INFO] [stdout] 2 | use std::net::Ipv4Addr;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Deserializer`
[INFO] [stdout]  --> src/models/vm.rs:1:26
[INFO] [stdout]   |
[INFO] [stdout] 1 | use serde::{Deserialize, Deserializer, Serialize};
[INFO] [stdout]   |                          ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `Read`
[INFO] [stdout]  --> src/models/ip_pool.rs:5:15
[INFO] [stdout]   |
[INFO] [stdout] 5 | use std::io::{Read, Write};
[INFO] [stdout]   |               ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `show_network` and `show_vlan` are never read
[INFO] [stdout]   --> src/gui/app.rs:61:9
[INFO] [stdout]    |
[INFO] [stdout] 56 | pub struct Dialogs {
[INFO] [stdout]    |            ------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 61 |     pub show_network: bool,
[INFO] [stdout]    |         ^^^^^^^^^^^^
[INFO] [stdout] 62 |     pub show_vlan: bool,
[INFO] [stdout]    |         ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `vmid`, `interface`, `bridge`, `vlan`, `model`, and `firewall` are never read
[INFO] [stdout]    --> src/gui/app.rs:112:9
[INFO] [stdout]     |
[INFO] [stdout] 111 | pub struct NetworkForm {
[INFO] [stdout]     |            ----------- fields in this struct
[INFO] [stdout] 112 |     pub vmid: u32,
[INFO] [stdout]     |         ^^^^
[INFO] [stdout] 113 |     pub interface: u32,
[INFO] [stdout]     |         ^^^^^^^^^
[INFO] [stdout] 114 |     pub bridge: String,
[INFO] [stdout]     |         ^^^^^^
[INFO] [stdout] 115 |     pub vlan: String,
[INFO] [stdout]     |         ^^^^
[INFO] [stdout] 116 |     pub model: String,
[INFO] [stdout]     |         ^^^^^
[INFO] [stdout] 117 |     pub firewall: bool,
[INFO] [stdout]     |         ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `network_form` is never read
[INFO] [stdout]    --> src/gui/app.rs:164:9
[INFO] [stdout]     |
[INFO] [stdout] 121 | pub struct ProxmoxApp {
[INFO] [stdout]     |            ---------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 164 |     pub network_form: NetworkForm,
[INFO] [stdout]     |         ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `Info` is never constructed
[INFO] [stdout]    --> src/gui/app.rs:191:5
[INFO] [stdout]     |
[INFO] [stdout] 190 | pub enum NotificationLevel {
[INFO] [stdout]     |          ----------------- variant in this enum
[INFO] [stdout] 191 |     Info,
[INFO] [stdout]     |     ^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `NotificationLevel` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `filtered_vms` is never used
[INFO] [stdout]    --> src/gui/app.rs:490:12
[INFO] [stdout]     |
[INFO] [stdout] 197 | impl ProxmoxApp {
[INFO] [stdout]     | --------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 490 |     pub fn filtered_vms(&self) -> Vec<&Vm> {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated constant `BORDER_LIGHT` is never used
[INFO] [stdout]   --> src/gui/theme.rs:37:15
[INFO] [stdout]    |
[INFO] [stdout]  6 | impl Colors {
[INFO] [stdout]    | ----------- associated constant in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 37 |     pub const BORDER_LIGHT: Color32 = Color32::from_rgb(90, 92, 100);
[INFO] [stdout]    |               ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `COL_ACTIONS` is never used
[INFO] [stdout]   --> src/gui/views/vm_list.rs:12:7
[INFO] [stdout]    |
[INFO] [stdout] 12 | const COL_ACTIONS: f32 = 100.0;
[INFO] [stdout]    |       ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `show_network` and `show_vlan` are never read
[INFO] [stdout]   --> src/gui/app.rs:61:9
[INFO] [stdout]    |
[INFO] [stdout] 56 | pub struct Dialogs {
[INFO] [stdout]    |            ------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 61 |     pub show_network: bool,
[INFO] [stdout]    |         ^^^^^^^^^^^^
[INFO] [stdout] 62 |     pub show_vlan: bool,
[INFO] [stdout]    |         ^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `vmid`, `interface`, `bridge`, `vlan`, `model`, and `firewall` are never read
[INFO] [stdout]    --> src/gui/app.rs:112:9
[INFO] [stdout]     |
[INFO] [stdout] 111 | pub struct NetworkForm {
[INFO] [stdout]     |            ----------- fields in this struct
[INFO] [stdout] 112 |     pub vmid: u32,
[INFO] [stdout]     |         ^^^^
[INFO] [stdout] 113 |     pub interface: u32,
[INFO] [stdout]     |         ^^^^^^^^^
[INFO] [stdout] 114 |     pub bridge: String,
[INFO] [stdout]     |         ^^^^^^
[INFO] [stdout] 115 |     pub vlan: String,
[INFO] [stdout]     |         ^^^^
[INFO] [stdout] 116 |     pub model: String,
[INFO] [stdout]     |         ^^^^^
[INFO] [stdout] 117 |     pub firewall: bool,
[INFO] [stdout]     |         ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `network_form` is never read
[INFO] [stdout]    --> src/gui/app.rs:164:9
[INFO] [stdout]     |
[INFO] [stdout] 121 | pub struct ProxmoxApp {
[INFO] [stdout]     |            ---------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 164 |     pub network_form: NetworkForm,
[INFO] [stdout]     |         ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `Info` is never constructed
[INFO] [stdout]    --> src/gui/app.rs:191:5
[INFO] [stdout]     |
[INFO] [stdout] 190 | pub enum NotificationLevel {
[INFO] [stdout]     |          ----------------- variant in this enum
[INFO] [stdout] 191 |     Info,
[INFO] [stdout]     |     ^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `NotificationLevel` has a derived impl for the trait `Clone`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `filtered_vms` is never used
[INFO] [stdout]    --> src/gui/app.rs:490:12
[INFO] [stdout]     |
[INFO] [stdout] 197 | impl ProxmoxApp {
[INFO] [stdout]     | --------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 490 |     pub fn filtered_vms(&self) -> Vec<&Vm> {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated constant `BORDER_LIGHT` is never used
[INFO] [stdout]   --> src/gui/theme.rs:37:15
[INFO] [stdout]    |
[INFO] [stdout]  6 | impl Colors {
[INFO] [stdout]    | ----------- associated constant in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 37 |     pub const BORDER_LIGHT: Color32 = Color32::from_rgb(90, 92, 100);
[INFO] [stdout]    |               ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: constant `COL_ACTIONS` is never used
[INFO] [stdout]   --> src/gui/views/vm_list.rs:12:7
[INFO] [stdout]    |
[INFO] [stdout] 12 | const COL_ACTIONS: f32 = 100.0;
[INFO] [stdout]    |       ^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `vmid`
[INFO] [stdout]    --> src/cli/interactive.rs:371:5
[INFO] [stdout]     |
[INFO] [stdout] 371 |     vmid: u32,
[INFO] [stdout]     |     ^^^^ help: if this is intentional, prefix it with an underscore: `_vmid`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `vmid`
[INFO] [stdout]    --> src/cli/interactive.rs:371:5
[INFO] [stdout]     |
[INFO] [stdout] 371 |     vmid: u32,
[INFO] [stdout]     |     ^^^^ help: if this is intentional, prefix it with an underscore: `_vmid`
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `config`
[INFO] [stdout]    --> src/main.rs:243:48
[INFO] [stdout]     |
[INFO] [stdout] 243 | async fn run_show(client: &api::ProxmoxClient, config: &AppConfig, vmid: u32) -> Result<()> {
[INFO] [stdout]     |                                                ^^^^^^ help: if this is intentional, prefix it with an underscore: `_config`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `config`
[INFO] [stdout]    --> src/main.rs:441:49
[INFO] [stdout]     |
[INFO] [stdout] 441 | async fn run_start(client: &api::ProxmoxClient, config: &AppConfig, vmids: Vec<u32>) -> Result<()> {
[INFO] [stdout]     |                                                 ^^^^^^ help: if this is intentional, prefix it with an underscore: `_config`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `config`
[INFO] [stdout]    --> src/main.rs:461:5
[INFO] [stdout]     |
[INFO] [stdout] 461 |     config: &AppConfig,
[INFO] [stdout]     |     ^^^^^^ help: if this is intentional, prefix it with an underscore: `_config`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `config`
[INFO] [stdout]    --> src/main.rs:488:5
[INFO] [stdout]     |
[INFO] [stdout] 488 |     config: &AppConfig,
[INFO] [stdout]     |     ^^^^^^ help: if this is intentional, prefix it with an underscore: `_config`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `config`
[INFO] [stdout]    --> src/main.rs:510:5
[INFO] [stdout]     |
[INFO] [stdout] 510 |     config: &AppConfig,
[INFO] [stdout]     |     ^^^^^^ help: if this is intentional, prefix it with an underscore: `_config`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `config`
[INFO] [stdout]    --> src/main.rs:532:5
[INFO] [stdout]     |
[INFO] [stdout] 532 |     config: &AppConfig,
[INFO] [stdout]     |     ^^^^^^ help: if this is intentional, prefix it with an underscore: `_config`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `config`
[INFO] [stdout]    --> src/main.rs:570:52
[INFO] [stdout]     |
[INFO] [stdout] 570 | async fn run_template(client: &api::ProxmoxClient, config: &AppConfig, vmid: u32) -> Result<()> {
[INFO] [stdout]     |                                                    ^^^^^^ help: if this is intentional, prefix it with an underscore: `_config`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `upid`
[INFO] [stdout]    --> src/main.rs:627:9
[INFO] [stdout]     |
[INFO] [stdout] 627 |     let upid = client.create_vm(&options.node, &options).await?;
[INFO] [stdout]     |         ^^^^ help: if this is intentional, prefix it with an underscore: `_upid`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `config`
[INFO] [stdout]    --> src/main.rs:895:5
[INFO] [stdout]     |
[INFO] [stdout] 895 |     config: &AppConfig,
[INFO] [stdout]     |     ^^^^^^ help: if this is intentional, prefix it with an underscore: `_config`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `fo_ip`
[INFO] [stdout]    --> src/main.rs:990:17
[INFO] [stdout]     |
[INFO] [stdout] 990 |             let fo_ip = config
[INFO] [stdout]     |                 ^^^^^ help: if this is intentional, prefix it with an underscore: `_fo_ip`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `errors` is never read
[INFO] [stdout]   --> src/api/client.rs:27:5
[INFO] [stdout]    |
[INFO] [stdout] 25 | struct ApiResponse<T> {
[INFO] [stdout]    |        ----------- field in this struct
[INFO] [stdout] 26 |     data: Option<T>,
[INFO] [stdout] 27 |     errors: Option<HashMap<String, String>>,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ApiResponse` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `username` is never read
[INFO] [stdout]   --> src/api/client.rs:36:5
[INFO] [stdout]    |
[INFO] [stdout] 32 | struct AuthResponse {
[INFO] [stdout]    |        ------------ field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 36 |     username: String,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `AuthResponse` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `node`, `upid`, `task_type`, `user`, `starttime`, and `endtime` are never read
[INFO] [stdout]   --> src/api/client.rs:45:9
[INFO] [stdout]    |
[INFO] [stdout] 41 | pub struct TaskStatus {
[INFO] [stdout]    |            ---------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 45 |     pub node: String,
[INFO] [stdout]    |         ^^^^
[INFO] [stdout] 46 |     pub upid: String,
[INFO] [stdout]    |         ^^^^
[INFO] [stdout] 47 |     #[serde(rename = "type")]
[INFO] [stdout] 48 |     pub task_type: Option<String>,
[INFO] [stdout]    |         ^^^^^^^^^
[INFO] [stdout] 49 |     pub user: Option<String>,
[INFO] [stdout]    |         ^^^^
[INFO] [stdout] 50 |     pub starttime: Option<u64>,
[INFO] [stdout]    |         ^^^^^^^^^
[INFO] [stdout] 51 |     pub endtime: Option<u64>,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `TaskStatus` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `disk` and `maxdisk` are never read
[INFO] [stdout]   --> src/api/client.rs:63:9
[INFO] [stdout]    |
[INFO] [stdout] 56 | pub struct Node {
[INFO] [stdout]    |            ---- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 63 |     pub disk: Option<u64>,
[INFO] [stdout]    |         ^^^^
[INFO] [stdout] 64 |     pub maxdisk: Option<u64>,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Node` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `get_node_status`, `get_storage_content`, `is_authenticated`, and `base_url` are never used
[INFO] [stdout]    --> src/api/client.rs:280:18
[INFO] [stdout]     |
[INFO] [stdout]  68 | impl ProxmoxClient {
[INFO] [stdout]     | ------------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 280 |     pub async fn get_node_status(&self, node: &str) -> Result<Node, ApiError> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 604 |     pub async fn get_storage_content(
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 679 |     pub fn is_authenticated(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 684 |     pub fn base_url(&self) -> &str {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `node` is never read
[INFO] [stdout]    --> src/api/client.rs:751:9
[INFO] [stdout]     |
[INFO] [stdout] 748 | pub struct VmIpInfo {
[INFO] [stdout]     |            -------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 751 |     pub node: String,
[INFO] [stdout]     |         ^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `VmIpInfo` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `interface` and `source` are never read
[INFO] [stdout]    --> src/api/client.rs:759:9
[INFO] [stdout]     |
[INFO] [stdout] 757 | pub struct VmIpEntry {
[INFO] [stdout]     |            --------- fields in this struct
[INFO] [stdout] 758 |     pub ip: std::net::IpAddr,
[INFO] [stdout] 759 |     pub interface: String,
[INFO] [stdout]     |         ^^^^^^^^^
[INFO] [stdout] 760 |     pub vlan: Option<u16>,
[INFO] [stdout] 761 |     pub source: String,
[INFO] [stdout]     |         ^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `VmIpEntry` 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: variants `InvalidConfig`, `VmIdExists`, `VmNotFound`, `NodeNotFound`, `StorageNotFound`, and `Other` are never constructed
[INFO] [stdout]   --> src/api/error.rs:21:5
[INFO] [stdout]    |
[INFO] [stdout]  4 | pub enum ApiError {
[INFO] [stdout]    |          -------- variants in this enum
[INFO] [stdout] ...
[INFO] [stdout] 21 |     InvalidConfig(String),
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 30 |     VmIdExists(u32),
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 33 |     VmNotFound(u32),
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 36 |     NodeNotFound(String),
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 39 |     StorageNotFound(String),
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 51 |     Other(String),
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ApiError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `is_auth_error` and `is_not_found` are never used
[INFO] [stdout]   --> src/api/error.rs:55:12
[INFO] [stdout]    |
[INFO] [stdout] 54 | impl ApiError {
[INFO] [stdout]    | ------------- methods in this implementation
[INFO] [stdout] 55 |     pub fn is_auth_error(&self) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 59 |     pub fn is_not_found(&self) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `error` is never used
[INFO] [stdout]    --> src/cli/display.rs:315:8
[INFO] [stdout]     |
[INFO] [stdout] 315 | pub fn error(msg: &str) {
[INFO] [stdout]     |        ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `pool_names` is never used
[INFO] [stdout]    --> src/config/mod.rs:200:12
[INFO] [stdout]     |
[INFO] [stdout] 105 | impl AppConfig {
[INFO] [stdout]     | -------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 200 |     pub fn pool_names(&self) -> Vec<&str> {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Vlan` is never constructed
[INFO] [stdout]    --> src/models/network.rs:119:12
[INFO] [stdout]     |
[INFO] [stdout] 119 | pub struct Vlan {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `IpConfig` is never constructed
[INFO] [stdout]    --> src/models/network.rs:128:12
[INFO] [stdout]     |
[INFO] [stdout] 128 | pub struct IpConfig {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Ipv4Config` is never constructed
[INFO] [stdout]    --> src/models/network.rs:136:12
[INFO] [stdout]     |
[INFO] [stdout] 136 | pub struct Ipv4Config {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Ipv6Config` is never constructed
[INFO] [stdout]    --> src/models/network.rs:142:12
[INFO] [stdout]     |
[INFO] [stdout] 142 | pub struct Ipv6Config {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `dhcp`, `parse`, and `to_proxmox_string` are never used
[INFO] [stdout]    --> src/models/network.rs:149:12
[INFO] [stdout]     |
[INFO] [stdout] 147 | impl IpConfig {
[INFO] [stdout]     | ------------- associated items in this implementation
[INFO] [stdout] 148 |     /// Create DHCP configuration
[INFO] [stdout] 149 |     pub fn dhcp() -> Self {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 160 |     pub fn parse(config: &str) -> Option<Self> {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 203 |     pub fn to_proxmox_string(&self) -> String {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `FailoverIp` is never constructed
[INFO] [stdout]    --> src/models/network.rs:230:12
[INFO] [stdout]     |
[INFO] [stdout] 230 | pub struct FailoverIp {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `supports_iso`, `supports_backup`, and `supports_snippets` are never used
[INFO] [stdout]   --> src/models/storage.rs:35:12
[INFO] [stdout]    |
[INFO] [stdout] 20 | impl Storage {
[INFO] [stdout]    | ------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 35 |     pub fn supports_iso(&self) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 40 |     pub fn supports_backup(&self) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 45 |     pub fn supports_snippets(&self) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `StorageContent` is never constructed
[INFO] [stdout]   --> src/models/storage.rs:72:12
[INFO] [stdout]    |
[INFO] [stdout] 72 | pub struct StorageContent {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `DiskInfo` is never constructed
[INFO] [stdout]   --> src/models/storage.rs:84:12
[INFO] [stdout]    |
[INFO] [stdout] 84 | pub struct DiskInfo {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `parse` and `size_human` are never used
[INFO] [stdout]    --> src/models/storage.rs:95:12
[INFO] [stdout]     |
[INFO] [stdout]  92 | impl DiskInfo {
[INFO] [stdout]     | ------------- associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  95 |     pub fn parse(name: &str, config: &str) -> Option<Self> {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 132 |     pub fn size_human(&self) -> String {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `parse_size` is never used
[INFO] [stdout]    --> src/models/storage.rs:138:4
[INFO] [stdout]     |
[INFO] [stdout] 138 | fn parse_size(s: &str) -> u64 {
[INFO] [stdout]     |    ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `allocated_ips_for_pool`, `release_by_ip`, `update_vm_name`, and `find_by_ipv4` are never used
[INFO] [stdout]    --> src/models/ip_pool.rs:336:12
[INFO] [stdout]     |
[INFO] [stdout] 283 | impl IpAllocations {
[INFO] [stdout]     | ------------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 336 |     pub fn allocated_ips_for_pool(&self, pool: &str) -> Vec<IpAddr> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 376 |     pub fn release_by_ip(&mut self, ip: IpAddr) -> Result<Option<IpAllocation>> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 387 |     pub fn update_vm_name(&mut self, vmid: u32, name: &str) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 420 |     pub fn find_by_ipv4(&self, ip: Ipv4Addr) -> Option<&IpAllocation> {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `DetectedIp` is never constructed
[INFO] [stdout]    --> src/models/ip_pool.rs:448:12
[INFO] [stdout]     |
[INFO] [stdout] 448 | pub struct DetectedIp {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `IpSource` is never used
[INFO] [stdout]    --> src/models/ip_pool.rs:459:10
[INFO] [stdout]     |
[INFO] [stdout] 459 | pub enum IpSource {
[INFO] [stdout]     |          ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `IpScanResult` is never constructed
[INFO] [stdout]    --> src/models/ip_pool.rs:470:12
[INFO] [stdout]     |
[INFO] [stdout] 470 | pub struct IpScanResult {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `IpConflict` is never constructed
[INFO] [stdout]    --> src/models/ip_pool.rs:485:12
[INFO] [stdout]     |
[INFO] [stdout] 485 | pub struct IpConflict {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `all_used_ips`, `ips_in_vlan`, `has_issues`, and `summary` are never used
[INFO] [stdout]    --> src/models/ip_pool.rs:493:12
[INFO] [stdout]     |
[INFO] [stdout] 491 | impl IpScanResult {
[INFO] [stdout]     | ----------------- methods in this implementation
[INFO] [stdout] 492 |     /// Get all IPs that are in use (detected + tracked, deduplicated)
[INFO] [stdout] 493 |     pub fn all_used_ips(&self) -> Vec<IpAddr> {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 507 |     pub fn ips_in_vlan(&self, vlan: u16) -> Vec<&DetectedIp> {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 515 |     pub fn has_issues(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 520 |     pub fn summary(&self) -> String {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `config`
[INFO] [stdout]    --> src/main.rs:243:48
[INFO] [stdout]     |
[INFO] [stdout] 243 | async fn run_show(client: &api::ProxmoxClient, config: &AppConfig, vmid: u32) -> Result<()> {
[INFO] [stdout]     |                                                ^^^^^^ help: if this is intentional, prefix it with an underscore: `_config`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `config`
[INFO] [stdout]    --> src/main.rs:441:49
[INFO] [stdout]     |
[INFO] [stdout] 441 | async fn run_start(client: &api::ProxmoxClient, config: &AppConfig, vmids: Vec<u32>) -> Result<()> {
[INFO] [stdout]     |                                                 ^^^^^^ help: if this is intentional, prefix it with an underscore: `_config`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `config`
[INFO] [stdout]    --> src/main.rs:461:5
[INFO] [stdout]     |
[INFO] [stdout] 461 |     config: &AppConfig,
[INFO] [stdout]     |     ^^^^^^ help: if this is intentional, prefix it with an underscore: `_config`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `config`
[INFO] [stdout]    --> src/main.rs:488:5
[INFO] [stdout]     |
[INFO] [stdout] 488 |     config: &AppConfig,
[INFO] [stdout]     |     ^^^^^^ help: if this is intentional, prefix it with an underscore: `_config`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `config`
[INFO] [stdout]    --> src/main.rs:510:5
[INFO] [stdout]     |
[INFO] [stdout] 510 |     config: &AppConfig,
[INFO] [stdout]     |     ^^^^^^ help: if this is intentional, prefix it with an underscore: `_config`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `config`
[INFO] [stdout]    --> src/main.rs:532:5
[INFO] [stdout]     |
[INFO] [stdout] 532 |     config: &AppConfig,
[INFO] [stdout]     |     ^^^^^^ help: if this is intentional, prefix it with an underscore: `_config`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `config`
[INFO] [stdout]    --> src/main.rs:570:52
[INFO] [stdout]     |
[INFO] [stdout] 570 | async fn run_template(client: &api::ProxmoxClient, config: &AppConfig, vmid: u32) -> Result<()> {
[INFO] [stdout]     |                                                    ^^^^^^ help: if this is intentional, prefix it with an underscore: `_config`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `upid`
[INFO] [stdout]    --> src/main.rs:627:9
[INFO] [stdout]     |
[INFO] [stdout] 627 |     let upid = client.create_vm(&options.node, &options).await?;
[INFO] [stdout]     |         ^^^^ help: if this is intentional, prefix it with an underscore: `_upid`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `config`
[INFO] [stdout]    --> src/main.rs:895:5
[INFO] [stdout]     |
[INFO] [stdout] 895 |     config: &AppConfig,
[INFO] [stdout]     |     ^^^^^^ help: if this is intentional, prefix it with an underscore: `_config`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `fo_ip`
[INFO] [stdout]    --> src/main.rs:990:17
[INFO] [stdout]     |
[INFO] [stdout] 990 |             let fo_ip = config
[INFO] [stdout]     |                 ^^^^^ help: if this is intentional, prefix it with an underscore: `_fo_ip`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `errors` is never read
[INFO] [stdout]   --> src/api/client.rs:27:5
[INFO] [stdout]    |
[INFO] [stdout] 25 | struct ApiResponse<T> {
[INFO] [stdout]    |        ----------- field in this struct
[INFO] [stdout] 26 |     data: Option<T>,
[INFO] [stdout] 27 |     errors: Option<HashMap<String, String>>,
[INFO] [stdout]    |     ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ApiResponse` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout]    = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `username` is never read
[INFO] [stdout]   --> src/api/client.rs:36:5
[INFO] [stdout]    |
[INFO] [stdout] 32 | struct AuthResponse {
[INFO] [stdout]    |        ------------ field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 36 |     username: String,
[INFO] [stdout]    |     ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `AuthResponse` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `node`, `upid`, `task_type`, `user`, `starttime`, and `endtime` are never read
[INFO] [stdout]   --> src/api/client.rs:45:9
[INFO] [stdout]    |
[INFO] [stdout] 41 | pub struct TaskStatus {
[INFO] [stdout]    |            ---------- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 45 |     pub node: String,
[INFO] [stdout]    |         ^^^^
[INFO] [stdout] 46 |     pub upid: String,
[INFO] [stdout]    |         ^^^^
[INFO] [stdout] 47 |     #[serde(rename = "type")]
[INFO] [stdout] 48 |     pub task_type: Option<String>,
[INFO] [stdout]    |         ^^^^^^^^^
[INFO] [stdout] 49 |     pub user: Option<String>,
[INFO] [stdout]    |         ^^^^
[INFO] [stdout] 50 |     pub starttime: Option<u64>,
[INFO] [stdout]    |         ^^^^^^^^^
[INFO] [stdout] 51 |     pub endtime: Option<u64>,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `TaskStatus` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `disk` and `maxdisk` are never read
[INFO] [stdout]   --> src/api/client.rs:63:9
[INFO] [stdout]    |
[INFO] [stdout] 56 | pub struct Node {
[INFO] [stdout]    |            ---- fields in this struct
[INFO] [stdout] ...
[INFO] [stdout] 63 |     pub disk: Option<u64>,
[INFO] [stdout]    |         ^^^^
[INFO] [stdout] 64 |     pub maxdisk: Option<u64>,
[INFO] [stdout]    |         ^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Node` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `get_node_status`, `get_storage_content`, `is_authenticated`, and `base_url` are never used
[INFO] [stdout]    --> src/api/client.rs:280:18
[INFO] [stdout]     |
[INFO] [stdout]  68 | impl ProxmoxClient {
[INFO] [stdout]     | ------------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 280 |     pub async fn get_node_status(&self, node: &str) -> Result<Node, ApiError> {
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 604 |     pub async fn get_storage_content(
[INFO] [stdout]     |                  ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 679 |     pub fn is_authenticated(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 684 |     pub fn base_url(&self) -> &str {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `node` is never read
[INFO] [stdout]    --> src/api/client.rs:751:9
[INFO] [stdout]     |
[INFO] [stdout] 748 | pub struct VmIpInfo {
[INFO] [stdout]     |            -------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 751 |     pub node: String,
[INFO] [stdout]     |         ^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `VmIpInfo` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `interface` and `source` are never read
[INFO] [stdout]    --> src/api/client.rs:759:9
[INFO] [stdout]     |
[INFO] [stdout] 757 | pub struct VmIpEntry {
[INFO] [stdout]     |            --------- fields in this struct
[INFO] [stdout] 758 |     pub ip: std::net::IpAddr,
[INFO] [stdout] 759 |     pub interface: String,
[INFO] [stdout]     |         ^^^^^^^^^
[INFO] [stdout] 760 |     pub vlan: Option<u16>,
[INFO] [stdout] 761 |     pub source: String,
[INFO] [stdout]     |         ^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `VmIpEntry` 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: variants `InvalidConfig`, `VmIdExists`, `VmNotFound`, `NodeNotFound`, `StorageNotFound`, and `Other` are never constructed
[INFO] [stdout]   --> src/api/error.rs:21:5
[INFO] [stdout]    |
[INFO] [stdout]  4 | pub enum ApiError {
[INFO] [stdout]    |          -------- variants in this enum
[INFO] [stdout] ...
[INFO] [stdout] 21 |     InvalidConfig(String),
[INFO] [stdout]    |     ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 30 |     VmIdExists(u32),
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 33 |     VmNotFound(u32),
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 36 |     NodeNotFound(String),
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 39 |     StorageNotFound(String),
[INFO] [stdout]    |     ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 51 |     Other(String),
[INFO] [stdout]    |     ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ApiError` has a derived impl for the trait `Debug`, but this is intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `is_auth_error` and `is_not_found` are never used
[INFO] [stdout]   --> src/api/error.rs:55:12
[INFO] [stdout]    |
[INFO] [stdout] 54 | impl ApiError {
[INFO] [stdout]    | ------------- methods in this implementation
[INFO] [stdout] 55 |     pub fn is_auth_error(&self) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 59 |     pub fn is_not_found(&self) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `error` is never used
[INFO] [stdout]    --> src/cli/display.rs:315:8
[INFO] [stdout]     |
[INFO] [stdout] 315 | pub fn error(msg: &str) {
[INFO] [stdout]     |        ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `pool_names` is never used
[INFO] [stdout]    --> src/config/mod.rs:200:12
[INFO] [stdout]     |
[INFO] [stdout] 105 | impl AppConfig {
[INFO] [stdout]     | -------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 200 |     pub fn pool_names(&self) -> Vec<&str> {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Vlan` is never constructed
[INFO] [stdout]    --> src/models/network.rs:119:12
[INFO] [stdout]     |
[INFO] [stdout] 119 | pub struct Vlan {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `IpConfig` is never constructed
[INFO] [stdout]    --> src/models/network.rs:128:12
[INFO] [stdout]     |
[INFO] [stdout] 128 | pub struct IpConfig {
[INFO] [stdout]     |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Ipv4Config` is never constructed
[INFO] [stdout]    --> src/models/network.rs:136:12
[INFO] [stdout]     |
[INFO] [stdout] 136 | pub struct Ipv4Config {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `Ipv6Config` is never constructed
[INFO] [stdout]    --> src/models/network.rs:142:12
[INFO] [stdout]     |
[INFO] [stdout] 142 | pub struct Ipv6Config {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `dhcp`, `parse`, and `to_proxmox_string` are never used
[INFO] [stdout]    --> src/models/network.rs:149:12
[INFO] [stdout]     |
[INFO] [stdout] 147 | impl IpConfig {
[INFO] [stdout]     | ------------- associated items in this implementation
[INFO] [stdout] 148 |     /// Create DHCP configuration
[INFO] [stdout] 149 |     pub fn dhcp() -> Self {
[INFO] [stdout]     |            ^^^^
[INFO] [stdout] ...
[INFO] [stdout] 160 |     pub fn parse(config: &str) -> Option<Self> {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 203 |     pub fn to_proxmox_string(&self) -> String {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `FailoverIp` is never constructed
[INFO] [stdout]    --> src/models/network.rs:230:12
[INFO] [stdout]     |
[INFO] [stdout] 230 | pub struct FailoverIp {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `supports_iso`, `supports_backup`, and `supports_snippets` are never used
[INFO] [stdout]   --> src/models/storage.rs:35:12
[INFO] [stdout]    |
[INFO] [stdout] 20 | impl Storage {
[INFO] [stdout]    | ------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 35 |     pub fn supports_iso(&self) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 40 |     pub fn supports_backup(&self) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 45 |     pub fn supports_snippets(&self) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `StorageContent` is never constructed
[INFO] [stdout]   --> src/models/storage.rs:72:12
[INFO] [stdout]    |
[INFO] [stdout] 72 | pub struct StorageContent {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `DiskInfo` is never constructed
[INFO] [stdout]   --> src/models/storage.rs:84:12
[INFO] [stdout]    |
[INFO] [stdout] 84 | pub struct DiskInfo {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `parse` and `size_human` are never used
[INFO] [stdout]    --> src/models/storage.rs:95:12
[INFO] [stdout]     |
[INFO] [stdout]  92 | impl DiskInfo {
[INFO] [stdout]     | ------------- associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  95 |     pub fn parse(name: &str, config: &str) -> Option<Self> {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 132 |     pub fn size_human(&self) -> String {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `parse_size` is never used
[INFO] [stdout]    --> src/models/storage.rs:138:4
[INFO] [stdout]     |
[INFO] [stdout] 138 | fn parse_size(s: &str) -> u64 {
[INFO] [stdout]     |    ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `allocated_ips_for_pool`, `release_by_ip`, `update_vm_name`, and `find_by_ipv4` are never used
[INFO] [stdout]    --> src/models/ip_pool.rs:336:12
[INFO] [stdout]     |
[INFO] [stdout] 283 | impl IpAllocations {
[INFO] [stdout]     | ------------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 336 |     pub fn allocated_ips_for_pool(&self, pool: &str) -> Vec<IpAddr> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 376 |     pub fn release_by_ip(&mut self, ip: IpAddr) -> Result<Option<IpAllocation>> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 387 |     pub fn update_vm_name(&mut self, vmid: u32, name: &str) -> Result<()> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 420 |     pub fn find_by_ipv4(&self, ip: Ipv4Addr) -> Option<&IpAllocation> {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `DetectedIp` is never constructed
[INFO] [stdout]    --> src/models/ip_pool.rs:448:12
[INFO] [stdout]     |
[INFO] [stdout] 448 | pub struct DetectedIp {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: enum `IpSource` is never used
[INFO] [stdout]    --> src/models/ip_pool.rs:459:10
[INFO] [stdout]     |
[INFO] [stdout] 459 | pub enum IpSource {
[INFO] [stdout]     |          ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `IpScanResult` is never constructed
[INFO] [stdout]    --> src/models/ip_pool.rs:470:12
[INFO] [stdout]     |
[INFO] [stdout] 470 | pub struct IpScanResult {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `IpConflict` is never constructed
[INFO] [stdout]    --> src/models/ip_pool.rs:485:12
[INFO] [stdout]     |
[INFO] [stdout] 485 | pub struct IpConflict {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `all_used_ips`, `ips_in_vlan`, `has_issues`, and `summary` are never used
[INFO] [stdout]    --> src/models/ip_pool.rs:493:12
[INFO] [stdout]     |
[INFO] [stdout] 491 | impl IpScanResult {
[INFO] [stdout]     | ----------------- methods in this implementation
[INFO] [stdout] 492 |     /// Get all IPs that are in use (detected + tracked, deduplicated)
[INFO] [stdout] 493 |     pub fn all_used_ips(&self) -> Vec<IpAddr> {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 507 |     pub fn ips_in_vlan(&self, vlan: u16) -> Vec<&DetectedIp> {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 515 |     pub fn has_issues(&self) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 520 |     pub fn summary(&self) -> String {
[INFO] [stdout]     |            ^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 1m 23s
[INFO] running `Command { std: "docker" "inspect" "0d402969ff9b1f17b1b83146bdfaedb5228075ce09ee180cac1e4433b331f5ea", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "0d402969ff9b1f17b1b83146bdfaedb5228075ce09ee180cac1e4433b331f5ea", kill_on_drop: false }`
[INFO] [stdout] 0d402969ff9b1f17b1b83146bdfaedb5228075ce09ee180cac1e4433b331f5ea
