[INFO] cloning repository https://github.com/Susch12/Network_interpreter
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/Susch12/Network_interpreter" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FSusch12%2FNetwork_interpreter", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FSusch12%2FNetwork_interpreter'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] 10c24f58b198d9e2dbb2fdc2ce0116d543518d90
[INFO] checking Susch12/Network_interpreter against master#2ca7bcd03b87b52f7055a59b817443b0ac4a530d for pr-150322
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FSusch12%2FNetwork_interpreter" "/workspace/builds/worker-5-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-5-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/Susch12/Network_interpreter
[INFO] finished tweaking git repo https://github.com/Susch12/Network_interpreter
[INFO] tweaked toml for git repo https://github.com/Susch12/Network_interpreter written to /workspace/builds/worker-5-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/Susch12/Network_interpreter on toolchain 2ca7bcd03b87b52f7055a59b817443b0ac4a530d
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+2ca7bcd03b87b52f7055a59b817443b0ac4a530d" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/Susch12/Network_interpreter 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" "+2ca7bcd03b87b52f7055a59b817443b0ac4a530d" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]     Blocking waiting for file lock on package cache
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded egui_glow v0.29.1
[INFO] [stderr]   Downloaded ecolor v0.29.1
[INFO] [stderr]   Downloaded eframe v0.29.1
[INFO] [stderr]   Downloaded accesskit v0.16.3
[INFO] [stderr]   Downloaded emath v0.29.1
[INFO] [stderr]   Downloaded type-map v0.5.1
[INFO] [stderr]   Downloaded endi v1.1.1
[INFO] [stderr]   Downloaded document-features v0.2.12
[INFO] [stderr]   Downloaded bit-set v0.6.0
[INFO] [stderr]   Downloaded accesskit_atspi_common v0.9.3
[INFO] [stderr]   Downloaded egui-wgpu v0.29.1
[INFO] [stderr]   Downloaded litrs v1.0.0
[INFO] [stderr]   Downloaded gpu-allocator v0.26.0
[INFO] [stderr]   Downloaded accesskit_windows v0.23.2
[INFO] [stderr]   Downloaded clap v4.5.51
[INFO] [stderr]   Downloaded widestring v1.2.1
[INFO] [stderr]   Downloaded epaint v0.29.1
[INFO] [stderr]   Downloaded webbrowser v1.0.6
[INFO] [stderr]   Downloaded wgpu-types v22.0.0
[INFO] [stderr]   Downloaded clap_builder v4.5.51
[INFO] [stderr]   Downloaded wgpu v22.1.0
[INFO] [stderr]   Downloaded immutable-chunkmap v2.1.2
[INFO] [stderr]   Downloaded accesskit_consumer v0.24.3
[INFO] [stderr]   Downloaded accesskit_winit v0.22.4
[INFO] [stderr]   Downloaded wgpu-core v22.1.0
[INFO] [stderr]   Downloaded accesskit_macos v0.17.4
[INFO] [stderr]   Downloaded accesskit_unix v0.12.3
[INFO] [stderr]   Downloaded egui v0.29.1
[INFO] [stderr]   Downloaded egui-winit v0.29.1
[INFO] [stderr]   Downloaded wgpu-hal v22.0.0
[INFO] [stderr]   Downloaded naga v22.1.0
[INFO] [stderr]   Downloaded epaint_default_fonts v0.29.1
[INFO] [stderr]   Downloaded orbclient v0.3.49
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:845e597a41426bbf2703be69acdb67d10b6de511142d05cba7bbe119c898b2c7" "/opt/rustwide/cargo-home/bin/cargo" "+2ca7bcd03b87b52f7055a59b817443b0ac4a530d" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] fe4e05c52fef58453371b711a0b2b39f5ad71678d3156de7cb33ea891abe8f88
[INFO] running `Command { std: "docker" "start" "-a" "fe4e05c52fef58453371b711a0b2b39f5ad71678d3156de7cb33ea891abe8f88", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "fe4e05c52fef58453371b711a0b2b39f5ad71678d3156de7cb33ea891abe8f88", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "fe4e05c52fef58453371b711a0b2b39f5ad71678d3156de7cb33ea891abe8f88", kill_on_drop: false }`
[INFO] [stdout] fe4e05c52fef58453371b711a0b2b39f5ad71678d3156de7cb33ea891abe8f88
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-5-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_INCREMENTAL=0" "-e" "RUST_BACKTRACE=full" "-e" "RUSTFLAGS=--cap-lints=forbid" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:845e597a41426bbf2703be69acdb67d10b6de511142d05cba7bbe119c898b2c7" "/opt/rustwide/cargo-home/bin/cargo" "+2ca7bcd03b87b52f7055a59b817443b0ac4a530d" "check" "--frozen" "--all" "--all-targets" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 32630070043da100fc941927184ab3434775b00ac4033732cace48f5317c958b
[INFO] running `Command { std: "docker" "start" "-a" "32630070043da100fc941927184ab3434775b00ac4033732cace48f5317c958b", kill_on_drop: false }`
[INFO] [stderr]    Compiling libc v0.2.177
[INFO] [stderr]    Compiling rustix v1.1.2
[INFO] [stderr]     Checking linux-raw-sys v0.11.0
[INFO] [stderr]     Checking smallvec v1.15.1
[INFO] [stderr]     Checking libloading v0.8.9
[INFO] [stderr]    Compiling winnow v0.7.14
[INFO] [stderr]    Compiling hashbrown v0.16.1
[INFO] [stderr]    Compiling wayland-sys v0.31.7
[INFO] [stderr]    Compiling toml_datetime v0.7.3
[INFO] [stderr]    Compiling cc v1.2.47
[INFO] [stderr]    Compiling enumflags2_derive v0.7.12
[INFO] [stderr]     Checking serde v1.0.228
[INFO] [stderr]    Compiling zvariant_utils v2.1.0
[INFO] [stderr]     Checking downcast-rs v1.2.1
[INFO] [stderr]     Checking scoped-tls v1.0.1
[INFO] [stderr]     Checking parking v2.2.1
[INFO] [stderr]     Checking concurrent-queue v2.5.0
[INFO] [stderr]    Compiling quick-xml v0.37.5
[INFO] [stderr]    Compiling serde_core v1.0.228
[INFO] [stderr]     Checking dlib v0.5.2
[INFO] [stderr]    Compiling wayland-client v0.31.11
[INFO] [stderr]     Checking tracing-core v0.1.35
[INFO] [stderr]    Compiling tracing-attributes v0.1.31
[INFO] [stderr]    Compiling bytemuck_derive v1.10.2
[INFO] [stderr]     Checking futures-lite v2.6.1
[INFO] [stderr]    Compiling memoffset v0.9.1
[INFO] [stderr]    Compiling endi v1.1.1
[INFO] [stderr]     Checking event-listener v5.4.1
[INFO] [stderr]    Compiling static_assertions v1.1.0
[INFO] [stderr]     Checking async-task v4.7.1
[INFO] [stderr]     Checking piper v0.2.4
[INFO] [stderr]    Compiling nix v0.29.0
[INFO] [stderr]    Compiling async-io v2.6.0
[INFO] [stderr]    Compiling khronos_api v3.1.0
[INFO] [stderr]     Checking enumflags2 v0.7.12
[INFO] [stderr]     Checking quick-xml v0.30.0
[INFO] [stderr]    Compiling rustix v0.38.44
[INFO] [stderr]     Checking event-listener-strategy v0.5.4
[INFO] [stderr]    Compiling indexmap v2.12.1
[INFO] [stderr]     Checking ttf-parser v0.25.1
[INFO] [stderr]     Checking arrayvec v0.7.6
[INFO] [stderr]    Compiling wayland-scanner v0.31.7
[INFO] [stderr]     Checking async-channel v2.5.0
[INFO] [stderr]     Checking async-lock v3.4.1
[INFO] [stderr]     Checking futures-util v0.3.31
[INFO] [stderr]     Checking async-broadcast v0.7.2
[INFO] [stderr]     Checking ordered-stream v0.2.0
[INFO] [stderr]    Compiling ahash v0.8.12
[INFO] [stderr]     Checking blocking v1.6.2
[INFO] [stderr]     Checking async-executor v1.13.3
[INFO] [stderr]     Checking tracing v0.1.41
[INFO] [stderr]     Checking bytemuck v1.24.0
[INFO] [stderr]     Checking xkeysym v0.2.1
[INFO] [stderr]     Checking linux-raw-sys v0.4.15
[INFO] [stderr]     Checking async-fs v2.2.0
[INFO] [stderr]    Compiling wayland-backend v0.3.11
[INFO] [stderr]     Checking cursor-icon v1.2.0
[INFO] [stderr]     Checking ab_glyph_rasterizer v0.1.10
[INFO] [stderr]     Checking xcursor v0.3.10
[INFO] [stderr]    Compiling xml-rs v0.8.28
[INFO] [stderr]    Compiling x11-dl v2.21.0
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]     Checking arrayref v0.3.9
[INFO] [stderr]     Checking strict-num v0.1.1
[INFO] [stderr]     Checking accesskit v0.16.3
[INFO] [stderr]    Compiling smithay-client-toolkit v0.19.2
[INFO] [stderr]     Checking tiny-skia-path v0.11.4
[INFO] [stderr]     Checking x11rb-protocol v0.13.2
[INFO] [stderr]     Checking getrandom v0.2.16
[INFO] [stderr]     Checking xdg-home v1.3.0
[INFO] [stderr]     Checking memmap2 v0.9.9
[INFO] [stderr]     Checking getrandom v0.3.4
[INFO] [stderr]     Checking rand_core v0.6.4
[INFO] [stderr]     Checking rand_chacha v0.3.1
[INFO] [stderr]     Checking parking_lot_core v0.9.12
[INFO] [stderr]     Checking as-raw-xcb-connection v1.0.1
[INFO] [stderr]     Checking tiny-skia v0.11.4
[INFO] [stderr]     Checking icu_normalizer v2.1.1
[INFO] [stderr]     Checking parking_lot v0.12.5
[INFO] [stderr]     Checking emath v0.29.1
[INFO] [stderr]     Checking rand v0.8.5
[INFO] [stderr]    Compiling gl_generator v0.14.0
[INFO] [stderr]     Checking immutable-chunkmap v2.1.2
[INFO] [stderr]    Compiling winit v0.30.12
[INFO] [stderr]     Checking simd-adler32 v0.3.7
[INFO] [stderr]     Checking raw-window-handle v0.6.2
[INFO] [stderr]     Checking owned_ttf_parser v0.25.1
[INFO] [stderr]    Compiling toml_parser v1.0.4
[INFO] [stderr]     Checking ecolor v0.29.1
[INFO] [stderr]     Checking ab_glyph v0.2.32
[INFO] [stderr]     Checking idna_adapter v1.2.1
[INFO] [stderr]     Checking xkbcommon-dl v0.4.2
[INFO] [stderr]    Compiling smithay-client-toolkit v0.20.0
[INFO] [stderr]     Checking dpi v0.1.2
[INFO] [stderr]     Checking nohash-hasher v0.2.0
[INFO] [stderr]     Checking epaint_default_fonts v0.29.1
[INFO] [stderr]     Checking smol_str v0.2.2
[INFO] [stderr]     Checking miniz_oxide v0.8.9
[INFO] [stderr]     Checking idna v1.1.0
[INFO] [stderr]     Checking form_urlencoded v1.2.2
[INFO] [stderr]     Checking accesskit_consumer v0.24.3
[INFO] [stderr]     Checking epaint v0.29.1
[INFO] [stderr]    Compiling glutin v0.32.3
[INFO] [stderr]     Checking pxfm v0.1.25
[INFO] [stderr]    Compiling glutin_glx_sys v0.6.1
[INFO] [stderr]    Compiling glutin_egl_sys v0.7.1
[INFO] [stderr]     Checking fdeflate v0.3.7
[INFO] [stderr]    Compiling toml_edit v0.23.7
[INFO] [stderr]     Checking flate2 v1.1.5
[INFO] [stderr]     Checking url v2.5.7
[INFO] [stderr]    Compiling glutin-winit v0.5.0
[INFO] [stderr]    Compiling litrs v1.0.0
[INFO] [stderr]     Checking glow v0.14.2
[INFO] [stderr]     Checking byteorder-lite v0.1.0
[INFO] [stderr]    Compiling rayon-core v1.13.0
[INFO] [stderr]     Checking png v0.18.0
[INFO] [stderr]     Checking half v2.7.1
[INFO] [stderr]     Checking clap_builder v4.5.51
[INFO] [stderr]     Checking regex-automata v0.4.13
[INFO] [stderr]     Checking egui v0.29.1
[INFO] [stderr]    Compiling proc-macro-crate v3.4.0
[INFO] [stderr]    Compiling document-features v0.2.12
[INFO] [stderr]     Checking webbrowser v1.0.6
[INFO] [stderr]     Checking ciborium-ll v0.2.2
[INFO] [stderr]     Checking rayon v1.11.0
[INFO] [stderr]     Checking tinytemplate v1.2.1
[INFO] [stderr]    Compiling zvariant_derive v4.2.0
[INFO] [stderr]    Compiling zbus_macros v4.4.0
[INFO] [stderr]     Checking ciborium v0.2.2
[INFO] [stderr]     Checking plotters v0.3.7
[INFO] [stderr]     Checking is-terminal v0.4.17
[INFO] [stderr]    Compiling zvariant v4.2.0
[INFO] [stderr]     Checking regex v1.12.2
[INFO] [stderr]     Checking moxcms v0.7.9
[INFO] [stderr]     Checking clap v4.5.51
[INFO] [stderr]     Checking polling v3.11.0
[INFO] [stderr]     Checking gethostname v1.1.0
[INFO] [stderr]     Checking calloop v0.14.3
[INFO] [stderr]     Checking calloop v0.13.0
[INFO] [stderr]     Checking wayland-csd-frame v0.3.0
[INFO] [stderr]     Checking egui_glow v0.29.1
[INFO] [stderr]     Checking criterion v0.5.1
[INFO] [stderr]     Checking zbus_names v3.0.0
[INFO] [stderr]     Checking wayland-protocols v0.32.9
[INFO] [stderr]     Checking wayland-cursor v0.31.11
[INFO] [stderr]     Checking calloop-wayland-source v0.3.0
[INFO] [stderr]     Checking calloop-wayland-source v0.4.1
[INFO] [stderr]     Checking zbus_xml v4.0.0
[INFO] [stderr]     Checking zbus v4.4.0
[INFO] [stderr]     Checking zbus-lockstep v0.4.4
[INFO] [stderr]    Compiling zbus-lockstep-macros v0.4.4
[INFO] [stderr]     Checking image v0.25.9
[INFO] [stderr]     Checking wayland-protocols-wlr v0.3.9
[INFO] [stderr]     Checking wayland-protocols-plasma v0.3.9
[INFO] [stderr]     Checking wayland-protocols-experimental v20250721.0.1
[INFO] [stderr]     Checking wayland-protocols-misc v0.3.9
[INFO] [stderr]     Checking x11rb v0.13.2
[INFO] [stderr]     Checking atspi-common v0.6.0
[INFO] [stderr]     Checking arboard v3.6.1
[INFO] [stderr]     Checking sctk-adwaita v0.10.1
[INFO] [stderr]     Checking smithay-clipboard v0.7.3
[INFO] [stderr]     Checking atspi-proxies v0.6.0
[INFO] [stderr]     Checking accesskit_atspi_common v0.9.3
[INFO] [stderr]     Checking atspi-connection v0.6.0
[INFO] [stderr]     Checking atspi v0.22.0
[INFO] [stderr]     Checking accesskit_unix v0.12.3
[INFO] [stderr]     Checking accesskit_winit v0.22.4
[INFO] [stderr]     Checking egui-winit v0.29.1
[INFO] [stderr]     Checking eframe v0.29.1
[INFO] [stderr]     Checking network_interpreter v0.2.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused variable: `is_negated`
[INFO] [stdout]   --> src/lexer_new/automaton.rs:71:17
[INFO] [stdout]    |
[INFO] [stdout] 71 |             let is_negated = inner.starts_with('^');
[INFO] [stdout]    |                 ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_is_negated`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `start_pos`
[INFO] [stdout]    --> src/lexer_new/scanner.rs:154:40
[INFO] [stdout]     |
[INFO] [stdout] 154 |     fn update_position_from(&mut self, start_pos: usize) {
[INFO] [stdout]     |                                        ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_start_pos`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `is_negated`
[INFO] [stdout]   --> src/lexer_new/automaton.rs:71:17
[INFO] [stdout]    |
[INFO] [stdout] 71 |             let is_negated = inner.starts_with('^');
[INFO] [stdout]    |                 ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_is_negated`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `start_pos`
[INFO] [stdout]    --> src/lexer_new/scanner.rs:154:40
[INFO] [stdout]     |
[INFO] [stdout] 154 |     fn update_position_from(&mut self, start_pos: usize) {
[INFO] [stdout]     |                                        ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_start_pos`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/lexer_new/scanner.rs:233:13
[INFO] [stdout]     |
[INFO] [stdout] 233 |         let mut scanner = Scanner::new("", &TEST_AUTOMATON);
[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: field `state_map` is never read
[INFO] [stdout]    --> src/lexer_new/automaton.rs:184:5
[INFO] [stdout]     |
[INFO] [stdout] 170 | pub struct Automaton {
[INFO] [stdout]     |            --------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 184 |     state_map: HashMap<String, StateId>,
[INFO] [stdout]     |     ^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `state_map` is never read
[INFO] [stdout]    --> src/lexer_new/automaton.rs:184:5
[INFO] [stdout]     |
[INFO] [stdout] 170 | pub struct Automaton {
[INFO] [stdout]     |            --------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 184 |     state_map: HashMap<String, StateId>,
[INFO] [stdout]     |     ^^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `#[warn(dead_code)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::io::Write`
[INFO] [stdout]  --> src/bin/generate_ll1_table.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use std::io::Write;
[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: `automaton::Automaton`
[INFO] [stdout]  --> src/lexer_new/mod.rs:9:9
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub use automaton::Automaton;
[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: `scanner::Scanner`
[INFO] [stdout]   --> src/lexer_new/mod.rs:10:9
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub use scanner::Scanner;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `TokenType` and `Token`
[INFO] [stdout]   --> src/lexer_new/mod.rs:11:17
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub use token::{Token, TokenType};
[INFO] [stdout]    |                 ^^^^^  ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `error::LexicalError`
[INFO] [stdout]   --> src/lexer_new/mod.rs:12:9
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub use error::LexicalError;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `FirstFollowSets`, `NonTerminal`, and `Symbol`
[INFO] [stdout]  --> src/parser_ll1/mod.rs:8:24
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub use first_follow::{FirstFollowSets, NonTerminal, Symbol};
[INFO] [stdout]   |                        ^^^^^^^^^^^^^^^  ^^^^^^^^^^^  ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `LL1Table`, `Production`, and `TokenClass`
[INFO] [stdout]  --> src/parser_ll1/mod.rs:9:21
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub use ll1_table::{LL1Table, Production, TokenClass};
[INFO] [stdout]   |                     ^^^^^^^^  ^^^^^^^^^^  ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `std::io::Write`
[INFO] [stdout]  --> src/bin/generate_ll1_table.rs:6:5
[INFO] [stdout]   |
[INFO] [stdout] 6 | use std::io::Write;
[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: `automaton::Automaton`
[INFO] [stdout]  --> src/lexer_new/mod.rs:9:9
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub use automaton::Automaton;
[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: `scanner::Scanner`
[INFO] [stdout]   --> src/lexer_new/mod.rs:10:9
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub use scanner::Scanner;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `TokenType` and `Token`
[INFO] [stdout]   --> src/lexer_new/mod.rs:11:17
[INFO] [stdout]    |
[INFO] [stdout] 11 | pub use token::{Token, TokenType};
[INFO] [stdout]    |                 ^^^^^  ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `error::LexicalError`
[INFO] [stdout]   --> src/lexer_new/mod.rs:12:9
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub use error::LexicalError;
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `FirstFollowSets`, `NonTerminal`, and `Symbol`
[INFO] [stdout]  --> src/parser_ll1/mod.rs:8:24
[INFO] [stdout]   |
[INFO] [stdout] 8 | pub use first_follow::{FirstFollowSets, NonTerminal, Symbol};
[INFO] [stdout]   |                        ^^^^^^^^^^^^^^^  ^^^^^^^^^^^  ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused imports: `LL1Table`, `Production`, and `TokenClass`
[INFO] [stdout]  --> src/parser_ll1/mod.rs:9:21
[INFO] [stdout]   |
[INFO] [stdout] 9 | pub use ll1_table::{LL1Table, Production, TokenClass};
[INFO] [stdout]   |                     ^^^^^^^^  ^^^^^^^^^^  ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `is_negated`
[INFO] [stdout]   --> src/lexer_new/automaton.rs:71:17
[INFO] [stdout]    |
[INFO] [stdout] 71 |             let is_negated = inner.starts_with('^');
[INFO] [stdout]    |                 ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_is_negated`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `start_pos`
[INFO] [stdout]    --> src/lexer_new/scanner.rs:154:40
[INFO] [stdout]     |
[INFO] [stdout] 154 |     fn update_position_from(&mut self, start_pos: usize) {
[INFO] [stdout]     |                                        ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_start_pos`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `is_negated`
[INFO] [stdout]   --> src/lexer_new/automaton.rs:71:17
[INFO] [stdout]    |
[INFO] [stdout] 71 |             let is_negated = inner.starts_with('^');
[INFO] [stdout]    |                 ^^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_is_negated`
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(unused_variables)]` (part of `#[warn(unused)]`) on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `start_pos`
[INFO] [stdout]    --> src/lexer_new/scanner.rs:154:40
[INFO] [stdout]     |
[INFO] [stdout] 154 |     fn update_position_from(&mut self, start_pos: usize) {
[INFO] [stdout]     |                                        ^^^^^^^^^ help: if this is intentional, prefix it with an underscore: `_start_pos`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `ui`
[INFO] [stdout]    --> src/visualizer.rs:473:28
[INFO] [stdout]     |
[INFO] [stdout] 473 |     fn draw_network(&self, ui: &mut egui::Ui, painter: &egui::Painter, rect: egui::Rect) {
[INFO] [stdout]     |                            ^^ help: if this is intentional, prefix it with an underscore: `_ui`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variable does not need to be mutable
[INFO] [stdout]    --> src/lexer_new/scanner.rs:233:13
[INFO] [stdout]     |
[INFO] [stdout] 233 |         let mut scanner = Scanner::new("", &TEST_AUTOMATON);
[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: variant `Whitespace` is never constructed
[INFO] [stdout]   --> src/lexer.rs:67:5
[INFO] [stdout]    |
[INFO] [stdout]  9 | pub enum Token {
[INFO] [stdout]    |          ----- variant in this enum
[INFO] [stdout] ...
[INFO] [stdout] 67 |     Whitespace,
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Token` has derived impls for the traits `Clone` and `Debug`, but these are 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: struct `LexerError` is never constructed
[INFO] [stdout]   --> src/lexer.rs:84:12
[INFO] [stdout]    |
[INFO] [stdout] 84 | pub struct LexerError {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `as_usize` is never used
[INFO] [stdout]   --> src/lexer_new/automaton.rs:17:12
[INFO] [stdout]    |
[INFO] [stdout] 12 | impl StateId {
[INFO] [stdout]    | ------------ method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 17 |     pub fn as_usize(&self) -> usize {
[INFO] [stdout]    |            ^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `state_map` is never read
[INFO] [stdout]    --> src/lexer_new/automaton.rs:184:5
[INFO] [stdout]     |
[INFO] [stdout] 170 | pub struct Automaton {
[INFO] [stdout]     |            --------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 184 |     state_map: HashMap<String, StateId>,
[INFO] [stdout]     |     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `length` is never read
[INFO] [stdout]   --> src/lexer_new/error.rs:19:9
[INFO] [stdout]    |
[INFO] [stdout]  8 | pub struct LexicalError {
[INFO] [stdout]    |            ------------ field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 19 |     pub length: usize,
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `LexicalError` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated functions `unterminated_string` and `invalid_number` are never used
[INFO] [stdout]   --> src/lexer_new/error.rs:44:12
[INFO] [stdout]    |
[INFO] [stdout] 22 | impl LexicalError {
[INFO] [stdout]    | ----------------- associated functions in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 44 |     pub fn unterminated_string(line: usize, column: usize) -> Self {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 54 |     pub fn invalid_number(lexeme: String, line: usize, column: usize) -> Self {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `location` is never read
[INFO] [stdout]   --> src/parser.rs:14:9
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub struct ParseError {
[INFO] [stdout]    |            ---------- field in this struct
[INFO] [stdout] 13 |     pub message: String,
[INFO] [stdout] 14 |     pub location: Location,
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ParseError` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `report_parse_errors` is never used
[INFO] [stdout]     --> src/parser.rs:1067:8
[INFO] [stdout]      |
[INFO] [stdout] 1067 | pub fn report_parse_errors(errors: &[ParseError], source: &str, filename: &str) {
[INFO] [stdout]      |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: struct `FirstFollowSets` is never constructed
[INFO] [stdout]    --> src/parser_ll1/first_follow.rs:119:12
[INFO] [stdout]     |
[INFO] [stdout] 119 | pub struct FirstFollowSets {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: multiple associated items are never used
[INFO] [stdout]    --> src/parser_ll1/first_follow.rs:126:12
[INFO] [stdout]     |
[INFO] [stdout] 124 | impl FirstFollowSets {
[INFO] [stdout]     | -------------------- associated items in this implementation
[INFO] [stdout] 125 |     /// Crea los conjuntos FIRST y FOLLOW según la gramática
[INFO] [stdout] 126 |     pub fn new() -> Self {
[INFO] [stdout]     |            ^^^
[INFO] [stdout] ...
[INFO] [stdout] 139 |     fn initialize_first_sets(first: &mut HashMap<NonTerminal, HashSet<Symbol>>) {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 323 |     fn initialize_follow_sets(follow: &mut HashMap<NonTerminal, HashSet<Symbol>>) {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 463 |     pub fn first(&self, nt: NonTerminal) -> Option<&HashSet<Symbol>> {
[INFO] [stdout]     |            ^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 468 |     pub fn follow(&self, nt: NonTerminal) -> Option<&HashSet<Symbol>> {
[INFO] [stdout]     |            ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 473 |     pub fn is_in_first(&self, nt: NonTerminal, symbol: &Symbol) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 480 |     pub fn is_in_follow(&self, nt: NonTerminal, symbol: &Symbol) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `Eof` is never constructed
[INFO] [stdout]   --> src/parser_ll1/ll1_table.rs:68:5
[INFO] [stdout]    |
[INFO] [stdout] 25 | pub enum TokenClass {
[INFO] [stdout]    |          ---------- variant in this enum
[INFO] [stdout] ...
[INFO] [stdout] 68 |     Eof,
[INFO] [stdout]    |     ^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `TokenClass` 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: method `as_str` is never used
[INFO] [stdout]    --> src/parser_ll1/ll1_table.rs:121:12
[INFO] [stdout]     |
[INFO] [stdout]  71 | impl TokenClass {
[INFO] [stdout]     | --------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 121 |     pub fn as_str(&self) -> &'static str {
[INFO] [stdout]     |            ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `get_production`, `export_table`, `format_rhs`, and `format_terminal` are never used
[INFO] [stdout]     --> src/parser_ll1/ll1_table.rs:956:12
[INFO] [stdout]      |
[INFO] [stdout]  170 | impl LL1Table {
[INFO] [stdout]      | ------------- associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  956 |     pub fn get_production(&self, id: usize) -> Option<&Production> {
[INFO] [stdout]      |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  961 |     pub fn export_table(&self) -> String {
[INFO] [stdout]      |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1036 |     fn format_rhs(rhs: &[Symbol]) -> String {
[INFO] [stdout]      |        ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1053 |     fn format_terminal(token: &Token) -> String {
[INFO] [stdout]      |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `get_errors` is never used
[INFO] [stdout]    --> src/parser_ll1/predictive.rs:223:12
[INFO] [stdout]     |
[INFO] [stdout]  21 | impl PredictiveParser {
[INFO] [stdout]     | --------------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 223 |     pub fn get_errors(&self) -> &[String] {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `location` is never read
[INFO] [stdout]   --> src/ast.rs:45:9
[INFO] [stdout]    |
[INFO] [stdout] 40 | pub struct Program {
[INFO] [stdout]    |            ------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 45 |     pub location: Location,
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Program` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `location` is never read
[INFO] [stdout]   --> src/ast.rs:57:9
[INFO] [stdout]    |
[INFO] [stdout] 53 | pub struct Definitions {
[INFO] [stdout]    |            ----------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 57 |     pub location: Location,
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Definitions` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `empty` is never used
[INFO] [stdout]   --> src/ast.rs:61:12
[INFO] [stdout]    |
[INFO] [stdout] 60 | impl Definitions {
[INFO] [stdout]    | ---------------- associated function in this implementation
[INFO] [stdout] 61 |     pub fn empty() -> Self {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `LexicalError`, `SyntaxError`, and `RuntimeError` are never constructed
[INFO] [stdout]   --> src/error.rs:9:5
[INFO] [stdout]    |
[INFO] [stdout]  8 | pub enum DiagnosticKind {
[INFO] [stdout]    |          -------------- variants in this enum
[INFO] [stdout]  9 |     LexicalError,
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout] 10 |     SyntaxError,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 11 |     SemanticError,
[INFO] [stdout] 12 |     RuntimeError,
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `DiagnosticKind` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `lexical_error`, `syntax_error`, `runtime_error`, and `with_help` are never used
[INFO] [stdout]   --> src/error.rs:26:12
[INFO] [stdout]    |
[INFO] [stdout] 25 | impl Diagnostic {
[INFO] [stdout]    | --------------- associated items in this implementation
[INFO] [stdout] 26 |     pub fn lexical_error(line: usize, column: usize, length: usize, message: String) -> Self {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 37 |     pub fn syntax_error(line: usize, column: usize, length: usize, message: String) -> Self {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 59 |     pub fn runtime_error(line: usize, column: usize, length: usize, message: String) -> Self {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 70 |     pub fn with_help(mut self, help: String) -> Self {
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `Void` is never constructed
[INFO] [stdout]   --> src/semantic.rs:16:5
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub enum Type {
[INFO] [stdout]    |          ---- variant in this enum
[INFO] [stdout] ...
[INFO] [stdout] 16 |     Void,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Type` 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 `nombre` and `location` are never read
[INFO] [stdout]   --> src/semantic.rs:44:9
[INFO] [stdout]    |
[INFO] [stdout] 43 | pub struct MaquinaSymbol {
[INFO] [stdout]    |            ------------- fields in this struct
[INFO] [stdout] 44 |     pub nombre: String,
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 45 |     pub presente: bool,        // Si fue colocada en pantalla
[INFO] [stdout] 46 |     pub location: Location,
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `MaquinaSymbol` 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 `nombre`, `puertos_ocupados`, `coaxial_asignado`, and `location` are never read
[INFO] [stdout]   --> src/semantic.rs:51:9
[INFO] [stdout]    |
[INFO] [stdout] 50 | pub struct ConcentradorSymbol {
[INFO] [stdout]    |            ------------------ fields in this struct
[INFO] [stdout] 51 |     pub nombre: String,
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 54 |     pub puertos_ocupados: Vec<bool>,  // Estado de cada puerto (true = ocupado)
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^
[INFO] [stdout] 55 |     pub disponibles: i32,      // Puertos disponibles
[INFO] [stdout] 56 |     pub coaxial_asignado: Option<String>,  // Nombre del coaxial asignado
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^
[INFO] [stdout] 57 |     pub presente: bool,        // Si fue colocado en pantalla
[INFO] [stdout] 58 |     pub location: Location,
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ConcentradorSymbol` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `asignar_puerto` and `primer_puerto_disponible` are never used
[INFO] [stdout]   --> src/semantic.rs:76:12
[INFO] [stdout]    |
[INFO] [stdout] 61 | impl ConcentradorSymbol {
[INFO] [stdout]    | ----------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 76 |     pub fn asignar_puerto(&mut self, puerto: usize) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 86 |     pub fn primer_puerto_disponible(&self) -> Option<usize> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `nombre`, `maquinas`, `posiciones`, and `location` are never read
[INFO] [stdout]    --> src/semantic.rs:98:9
[INFO] [stdout]     |
[INFO] [stdout]  97 | pub struct CoaxialSymbol {
[INFO] [stdout]     |            ------------- fields in this struct
[INFO] [stdout]  98 |     pub nombre: String,
[INFO] [stdout]     |         ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 102 |     pub maquinas: Vec<String>,            // Nombres de máquinas
[INFO] [stdout]     |         ^^^^^^^^
[INFO] [stdout] 103 |     pub posiciones: Vec<i32>,             // Posiciones de cada máquina
[INFO] [stdout]     |         ^^^^^^^^^^
[INFO] [stdout] 104 |     pub presente: bool,                   // Si fue colocado en pantalla
[INFO] [stdout] 105 |     pub location: Location,
[INFO] [stdout]     |         ^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `CoaxialSymbol` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `puede_agregar_maquina`, `agregar_maquina`, and `encontrar_posicion_disponible` are never used
[INFO] [stdout]    --> src/semantic.rs:122:12
[INFO] [stdout]     |
[INFO] [stdout] 108 | impl CoaxialSymbol {
[INFO] [stdout]     | ------------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 122 |     pub fn puede_agregar_maquina(&self, posicion: i32) -> Result<(), String> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 148 |     pub fn agregar_maquina(&mut self, nombre: String, posicion: i32) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 154 |     pub fn encontrar_posicion_disponible(&self) -> Option<i32> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `obtener_maquina_mut`, `obtener_concentrador_mut`, and `obtener_coaxial_mut` are never used
[INFO] [stdout]    --> src/semantic.rs:212:12
[INFO] [stdout]     |
[INFO] [stdout] 177 | impl SymbolTable {
[INFO] [stdout]     | ---------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 212 |     pub fn obtener_maquina_mut(&mut self, nombre: &str) -> Option<&mut MaquinaSymbol> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 242 |     pub fn obtener_concentrador_mut(&mut self, nombre: &str) -> Option<&mut ConcentradorSymbol> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 275 |     pub fn obtener_coaxial_mut(&mut self, nombre: &str) -> Option<&mut CoaxialSymbol> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `analyze_module` is never used
[INFO] [stdout]    --> src/semantic.rs:399:8
[INFO] [stdout]     |
[INFO] [stdout] 322 | impl SemanticAnalyzer {
[INFO] [stdout]     | --------------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 399 |     fn analyze_module(&mut self, modulo: &Modulo) {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `Void` is never constructed
[INFO] [stdout]   --> src/interpreter.rs:21:5
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub enum Value {
[INFO] [stdout]    |          ----- variant in this enum
[INFO] [stdout] ...
[INFO] [stdout] 21 |     Void,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Value` 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: method `to_string` is never used
[INFO] [stdout]   --> src/interpreter.rs:50:12
[INFO] [stdout]    |
[INFO] [stdout] 24 | impl Value {
[INFO] [stdout]    | ---------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 50 |     pub fn to_string(&self) -> String {
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `nombre` is never read
[INFO] [stdout]   --> src/interpreter.rs:61:9
[INFO] [stdout]    |
[INFO] [stdout] 60 | pub struct RuntimeMaquina {
[INFO] [stdout]    |            -------------- field in this struct
[INFO] [stdout] 61 |     pub nombre: String,
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `RuntimeMaquina` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `nombre` is never read
[INFO] [stdout]   --> src/interpreter.rs:76:9
[INFO] [stdout]    |
[INFO] [stdout] 75 | pub struct RuntimeConcentrador {
[INFO] [stdout]    |            ------------------- field in this struct
[INFO] [stdout] 76 |     pub nombre: String,
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `RuntimeConcentrador` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `nombre` is never read
[INFO] [stdout]    --> src/interpreter.rs:124:9
[INFO] [stdout]     |
[INFO] [stdout] 123 | pub struct RuntimeCoaxial {
[INFO] [stdout]     |            -------------- field in this struct
[INFO] [stdout] 124 |     pub nombre: String,
[INFO] [stdout]     |         ^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `RuntimeCoaxial` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `nombre` is never read
[INFO] [stdout]   --> src/visualizer.rs:11:9
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub struct Maquina {
[INFO] [stdout]    |            ------- field in this struct
[INFO] [stdout] 11 |     pub nombre: String,
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Maquina` 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 `nombre` and `tiene_coaxial` are never read
[INFO] [stdout]   --> src/visualizer.rs:25:9
[INFO] [stdout]    |
[INFO] [stdout] 24 | pub struct Concentrador {
[INFO] [stdout]    |            ------------ fields in this struct
[INFO] [stdout] 25 |     pub nombre: String,
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 30 |     pub tiene_coaxial: bool,
[INFO] [stdout]    |         ^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Concentrador` 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 `nombre` and `maquinas` are never read
[INFO] [stdout]   --> src/visualizer.rs:35:9
[INFO] [stdout]    |
[INFO] [stdout] 34 | pub struct Coaxial {
[INFO] [stdout]    |            ------- fields in this struct
[INFO] [stdout] 35 |     pub nombre: String,
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 40 |     pub maquinas: Vec<(String, usize)>,
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Coaxial` 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: constant `COLOR_GRID` is never used
[INFO] [stdout]    --> src/visualizer.rs:154:7
[INFO] [stdout]     |
[INFO] [stdout] 154 | const COLOR_GRID: egui::Color32 = egui::Color32::from_rgb(30, 30, 40);
[INFO] [stdout]     |       ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused variable: `ui`
[INFO] [stdout]    --> src/visualizer.rs:473:28
[INFO] [stdout]     |
[INFO] [stdout] 473 |     fn draw_network(&self, ui: &mut egui::Ui, painter: &egui::Painter, rect: egui::Rect) {
[INFO] [stdout]     |                            ^^ help: if this is intentional, prefix it with an underscore: `_ui`
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `Whitespace` is never constructed
[INFO] [stdout]   --> src/lexer.rs:67:5
[INFO] [stdout]    |
[INFO] [stdout]  9 | pub enum Token {
[INFO] [stdout]    |          ----- variant in this enum
[INFO] [stdout] ...
[INFO] [stdout] 67 |     Whitespace,
[INFO] [stdout]    |     ^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Token` has derived impls for the traits `Clone` and `Debug`, but these are 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: struct `LexerError` is never constructed
[INFO] [stdout]   --> src/lexer.rs:84:12
[INFO] [stdout]    |
[INFO] [stdout] 84 | pub struct LexerError {
[INFO] [stdout]    |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `state_map` is never read
[INFO] [stdout]    --> src/lexer_new/automaton.rs:184:5
[INFO] [stdout]     |
[INFO] [stdout] 170 | pub struct Automaton {
[INFO] [stdout]     |            --------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 184 |     state_map: HashMap<String, StateId>,
[INFO] [stdout]     |     ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `length` is never read
[INFO] [stdout]   --> src/lexer_new/error.rs:19:9
[INFO] [stdout]    |
[INFO] [stdout]  8 | pub struct LexicalError {
[INFO] [stdout]    |            ------------ field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 19 |     pub length: usize,
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `LexicalError` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `invalid_number` is never used
[INFO] [stdout]   --> src/lexer_new/error.rs:54:12
[INFO] [stdout]    |
[INFO] [stdout] 22 | impl LexicalError {
[INFO] [stdout]    | ----------------- associated function in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 54 |     pub fn invalid_number(lexeme: String, line: usize, column: usize) -> Self {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `location` is never read
[INFO] [stdout]   --> src/parser.rs:14:9
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub struct ParseError {
[INFO] [stdout]    |            ---------- field in this struct
[INFO] [stdout] 13 |     pub message: String,
[INFO] [stdout] 14 |     pub location: Location,
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ParseError` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: function `report_parse_errors` is never used
[INFO] [stdout]     --> src/parser.rs:1067:8
[INFO] [stdout]      |
[INFO] [stdout] 1067 | pub fn report_parse_errors(errors: &[ParseError], source: &str, filename: &str) {
[INFO] [stdout]      |        ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `follow` is never read
[INFO] [stdout]    --> src/parser_ll1/first_follow.rs:121:5
[INFO] [stdout]     |
[INFO] [stdout] 119 | pub struct FirstFollowSets {
[INFO] [stdout]     |            --------------- field in this struct
[INFO] [stdout] 120 |     first: HashMap<NonTerminal, HashSet<Symbol>>,
[INFO] [stdout] 121 |     follow: HashMap<NonTerminal, HashSet<Symbol>>,
[INFO] [stdout]     |     ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `follow` and `is_in_follow` are never used
[INFO] [stdout]    --> src/parser_ll1/first_follow.rs:468:12
[INFO] [stdout]     |
[INFO] [stdout] 124 | impl FirstFollowSets {
[INFO] [stdout]     | -------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 468 |     pub fn follow(&self, nt: NonTerminal) -> Option<&HashSet<Symbol>> {
[INFO] [stdout]     |            ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 480 |     pub fn is_in_follow(&self, nt: NonTerminal, symbol: &Symbol) -> bool {
[INFO] [stdout]     |            ^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `Eof` is never constructed
[INFO] [stdout]   --> src/parser_ll1/ll1_table.rs:68:5
[INFO] [stdout]    |
[INFO] [stdout] 25 | pub enum TokenClass {
[INFO] [stdout]    |          ---------- variant in this enum
[INFO] [stdout] ...
[INFO] [stdout] 68 |     Eof,
[INFO] [stdout]    |     ^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `TokenClass` 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: method `as_str` is never used
[INFO] [stdout]    --> src/parser_ll1/ll1_table.rs:121:12
[INFO] [stdout]     |
[INFO] [stdout]  71 | impl TokenClass {
[INFO] [stdout]     | --------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 121 |     pub fn as_str(&self) -> &'static str {
[INFO] [stdout]     |            ^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `get_production`, `export_table`, `format_rhs`, and `format_terminal` are never used
[INFO] [stdout]     --> src/parser_ll1/ll1_table.rs:956:12
[INFO] [stdout]      |
[INFO] [stdout]  170 | impl LL1Table {
[INFO] [stdout]      | ------------- associated items in this implementation
[INFO] [stdout] ...
[INFO] [stdout]  956 |     pub fn get_production(&self, id: usize) -> Option<&Production> {
[INFO] [stdout]      |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout]  961 |     pub fn export_table(&self) -> String {
[INFO] [stdout]      |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1036 |     fn format_rhs(rhs: &[Symbol]) -> String {
[INFO] [stdout]      |        ^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 1053 |     fn format_terminal(token: &Token) -> String {
[INFO] [stdout]      |        ^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `get_errors` is never used
[INFO] [stdout]    --> src/parser_ll1/predictive.rs:223:12
[INFO] [stdout]     |
[INFO] [stdout]  21 | impl PredictiveParser {
[INFO] [stdout]     | --------------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 223 |     pub fn get_errors(&self) -> &[String] {
[INFO] [stdout]     |            ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `location` is never read
[INFO] [stdout]   --> src/ast.rs:45:9
[INFO] [stdout]    |
[INFO] [stdout] 40 | pub struct Program {
[INFO] [stdout]    |            ------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 45 |     pub location: Location,
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Program` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `location` is never read
[INFO] [stdout]   --> src/ast.rs:57:9
[INFO] [stdout]    |
[INFO] [stdout] 53 | pub struct Definitions {
[INFO] [stdout]    |            ----------- field in this struct
[INFO] [stdout] ...
[INFO] [stdout] 57 |     pub location: Location,
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Definitions` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated function `empty` is never used
[INFO] [stdout]   --> src/ast.rs:61:12
[INFO] [stdout]    |
[INFO] [stdout] 60 | impl Definitions {
[INFO] [stdout]    | ---------------- associated function in this implementation
[INFO] [stdout] 61 |     pub fn empty() -> Self {
[INFO] [stdout]    |            ^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variants `LexicalError`, `SyntaxError`, and `RuntimeError` are never constructed
[INFO] [stdout]   --> src/error.rs:9:5
[INFO] [stdout]    |
[INFO] [stdout]  8 | pub enum DiagnosticKind {
[INFO] [stdout]    |          -------------- variants in this enum
[INFO] [stdout]  9 |     LexicalError,
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout] 10 |     SyntaxError,
[INFO] [stdout]    |     ^^^^^^^^^^^
[INFO] [stdout] 11 |     SemanticError,
[INFO] [stdout] 12 |     RuntimeError,
[INFO] [stdout]    |     ^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `DiagnosticKind` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: associated items `lexical_error`, `syntax_error`, `runtime_error`, and `with_help` are never used
[INFO] [stdout]   --> src/error.rs:26:12
[INFO] [stdout]    |
[INFO] [stdout] 25 | impl Diagnostic {
[INFO] [stdout]    | --------------- associated items in this implementation
[INFO] [stdout] 26 |     pub fn lexical_error(line: usize, column: usize, length: usize, message: String) -> Self {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 37 |     pub fn syntax_error(line: usize, column: usize, length: usize, message: String) -> Self {
[INFO] [stdout]    |            ^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 59 |     pub fn runtime_error(line: usize, column: usize, length: usize, message: String) -> Self {
[INFO] [stdout]    |            ^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 70 |     pub fn with_help(mut self, help: String) -> Self {
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `Void` is never constructed
[INFO] [stdout]   --> src/semantic.rs:16:5
[INFO] [stdout]    |
[INFO] [stdout] 12 | pub enum Type {
[INFO] [stdout]    |          ---- variant in this enum
[INFO] [stdout] ...
[INFO] [stdout] 16 |     Void,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Type` 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 `nombre` and `location` are never read
[INFO] [stdout]   --> src/semantic.rs:44:9
[INFO] [stdout]    |
[INFO] [stdout] 43 | pub struct MaquinaSymbol {
[INFO] [stdout]    |            ------------- fields in this struct
[INFO] [stdout] 44 |     pub nombre: String,
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] 45 |     pub presente: bool,        // Si fue colocada en pantalla
[INFO] [stdout] 46 |     pub location: Location,
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `MaquinaSymbol` 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 `nombre`, `puertos_ocupados`, `coaxial_asignado`, and `location` are never read
[INFO] [stdout]   --> src/semantic.rs:51:9
[INFO] [stdout]    |
[INFO] [stdout] 50 | pub struct ConcentradorSymbol {
[INFO] [stdout]    |            ------------------ fields in this struct
[INFO] [stdout] 51 |     pub nombre: String,
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 54 |     pub puertos_ocupados: Vec<bool>,  // Estado de cada puerto (true = ocupado)
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^
[INFO] [stdout] 55 |     pub disponibles: i32,      // Puertos disponibles
[INFO] [stdout] 56 |     pub coaxial_asignado: Option<String>,  // Nombre del coaxial asignado
[INFO] [stdout]    |         ^^^^^^^^^^^^^^^^
[INFO] [stdout] 57 |     pub presente: bool,        // Si fue colocado en pantalla
[INFO] [stdout] 58 |     pub location: Location,
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `ConcentradorSymbol` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `asignar_puerto` and `primer_puerto_disponible` are never used
[INFO] [stdout]   --> src/semantic.rs:76:12
[INFO] [stdout]    |
[INFO] [stdout] 61 | impl ConcentradorSymbol {
[INFO] [stdout]    | ----------------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 76 |     pub fn asignar_puerto(&mut self, puerto: usize) -> bool {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 86 |     pub fn primer_puerto_disponible(&self) -> Option<usize> {
[INFO] [stdout]    |            ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: fields `nombre`, `maquinas`, `posiciones`, and `location` are never read
[INFO] [stdout]    --> src/semantic.rs:98:9
[INFO] [stdout]     |
[INFO] [stdout]  97 | pub struct CoaxialSymbol {
[INFO] [stdout]     |            ------------- fields in this struct
[INFO] [stdout]  98 |     pub nombre: String,
[INFO] [stdout]     |         ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 102 |     pub maquinas: Vec<String>,            // Nombres de máquinas
[INFO] [stdout]     |         ^^^^^^^^
[INFO] [stdout] 103 |     pub posiciones: Vec<i32>,             // Posiciones de cada máquina
[INFO] [stdout]     |         ^^^^^^^^^^
[INFO] [stdout] 104 |     pub presente: bool,                   // Si fue colocado en pantalla
[INFO] [stdout] 105 |     pub location: Location,
[INFO] [stdout]     |         ^^^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `CoaxialSymbol` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `puede_agregar_maquina`, `agregar_maquina`, and `encontrar_posicion_disponible` are never used
[INFO] [stdout]    --> src/semantic.rs:122:12
[INFO] [stdout]     |
[INFO] [stdout] 108 | impl CoaxialSymbol {
[INFO] [stdout]     | ------------------ methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 122 |     pub fn puede_agregar_maquina(&self, posicion: i32) -> Result<(), String> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 148 |     pub fn agregar_maquina(&mut self, nombre: String, posicion: i32) {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 154 |     pub fn encontrar_posicion_disponible(&self) -> Option<i32> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: methods `obtener_maquina_mut`, `obtener_concentrador_mut`, and `obtener_coaxial_mut` are never used
[INFO] [stdout]    --> src/semantic.rs:212:12
[INFO] [stdout]     |
[INFO] [stdout] 177 | impl SymbolTable {
[INFO] [stdout]     | ---------------- methods in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 212 |     pub fn obtener_maquina_mut(&mut self, nombre: &str) -> Option<&mut MaquinaSymbol> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 242 |     pub fn obtener_concentrador_mut(&mut self, nombre: &str) -> Option<&mut ConcentradorSymbol> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 275 |     pub fn obtener_coaxial_mut(&mut self, nombre: &str) -> Option<&mut CoaxialSymbol> {
[INFO] [stdout]     |            ^^^^^^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `analyze_module` is never used
[INFO] [stdout]    --> src/semantic.rs:399:8
[INFO] [stdout]     |
[INFO] [stdout] 322 | impl SemanticAnalyzer {
[INFO] [stdout]     | --------------------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 399 |     fn analyze_module(&mut self, modulo: &Modulo) {
[INFO] [stdout]     |        ^^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: variant `Void` is never constructed
[INFO] [stdout]   --> src/interpreter.rs:21:5
[INFO] [stdout]    |
[INFO] [stdout] 17 | pub enum Value {
[INFO] [stdout]    |          ----- variant in this enum
[INFO] [stdout] ...
[INFO] [stdout] 21 |     Void,
[INFO] [stdout]    |     ^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Value` 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: method `to_string` is never used
[INFO] [stdout]   --> src/interpreter.rs:50:12
[INFO] [stdout]    |
[INFO] [stdout] 24 | impl Value {
[INFO] [stdout]    | ---------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 50 |     pub fn to_string(&self) -> String {
[INFO] [stdout]    |            ^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `nombre` is never read
[INFO] [stdout]   --> src/interpreter.rs:61:9
[INFO] [stdout]    |
[INFO] [stdout] 60 | pub struct RuntimeMaquina {
[INFO] [stdout]    |            -------------- field in this struct
[INFO] [stdout] 61 |     pub nombre: String,
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `RuntimeMaquina` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `nombre` is never read
[INFO] [stdout]   --> src/interpreter.rs:76:9
[INFO] [stdout]    |
[INFO] [stdout] 75 | pub struct RuntimeConcentrador {
[INFO] [stdout]    |            ------------------- field in this struct
[INFO] [stdout] 76 |     pub nombre: String,
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `RuntimeConcentrador` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `nombre` is never read
[INFO] [stdout]    --> src/interpreter.rs:124:9
[INFO] [stdout]     |
[INFO] [stdout] 123 | pub struct RuntimeCoaxial {
[INFO] [stdout]     |            -------------- field in this struct
[INFO] [stdout] 124 |     pub nombre: String,
[INFO] [stdout]     |         ^^^^^^
[INFO] [stdout]     |
[INFO] [stdout]     = note: `RuntimeCoaxial` has derived impls for the traits `Clone` and `Debug`, but these are intentionally ignored during dead code analysis
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: field `nombre` is never read
[INFO] [stdout]   --> src/visualizer.rs:11:9
[INFO] [stdout]    |
[INFO] [stdout] 10 | pub struct Maquina {
[INFO] [stdout]    |            ------- field in this struct
[INFO] [stdout] 11 |     pub nombre: String,
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Maquina` 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 `nombre` and `tiene_coaxial` are never read
[INFO] [stdout]   --> src/visualizer.rs:25:9
[INFO] [stdout]    |
[INFO] [stdout] 24 | pub struct Concentrador {
[INFO] [stdout]    |            ------------ fields in this struct
[INFO] [stdout] 25 |     pub nombre: String,
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 30 |     pub tiene_coaxial: bool,
[INFO] [stdout]    |         ^^^^^^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Concentrador` 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 `nombre` and `maquinas` are never read
[INFO] [stdout]   --> src/visualizer.rs:35:9
[INFO] [stdout]    |
[INFO] [stdout] 34 | pub struct Coaxial {
[INFO] [stdout]    |            ------- fields in this struct
[INFO] [stdout] 35 |     pub nombre: String,
[INFO] [stdout]    |         ^^^^^^
[INFO] [stdout] ...
[INFO] [stdout] 40 |     pub maquinas: Vec<(String, usize)>,
[INFO] [stdout]    |         ^^^^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `Coaxial` 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: constant `COLOR_GRID` is never used
[INFO] [stdout]    --> src/visualizer.rs:154:7
[INFO] [stdout]     |
[INFO] [stdout] 154 | const COLOR_GRID: egui::Color32 = egui::Color32::from_rgb(30, 30, 40);
[INFO] [stdout]     |       ^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 1m 34s
[INFO] running `Command { std: "docker" "inspect" "32630070043da100fc941927184ab3434775b00ac4033732cace48f5317c958b", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "32630070043da100fc941927184ab3434775b00ac4033732cace48f5317c958b", kill_on_drop: false }`
[INFO] [stdout] 32630070043da100fc941927184ab3434775b00ac4033732cace48f5317c958b
