[INFO] cloning repository https://github.com/APConduct/lucid-lang
[INFO] running `Command { std: "git" "-c" "credential.helper=" "-c" "credential.helper=/workspace/cargo-home/bin/git-credential-null" "clone" "--bare" "https://github.com/APConduct/lucid-lang" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FAPConduct%2Flucid-lang", kill_on_drop: false }`
[INFO] [stderr] Cloning into bare repository '/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FAPConduct%2Flucid-lang'...
[INFO] running `Command { std: "git" "rev-parse" "HEAD", kill_on_drop: false }`
[INFO] [stdout] bc4bceb92db664dbcb3c6278142a00f7a17e62a3
[INFO] testing APConduct/lucid-lang against master#d98a5da813da67eb189387b8ccfb73cf481275d8+rustflags=-Copt-level=3 for pr-138759
[INFO] running `Command { std: "git" "clone" "/workspace/cache/git-repos/https%3A%2F%2Fgithub.com%2FAPConduct%2Flucid-lang" "/workspace/builds/worker-7-tc1/source", kill_on_drop: false }`
[INFO] [stderr] Cloning into '/workspace/builds/worker-7-tc1/source'...
[INFO] [stderr] done.
[INFO] started tweaking git repo https://github.com/APConduct/lucid-lang
[INFO] finished tweaking git repo https://github.com/APConduct/lucid-lang
[INFO] tweaked toml for git repo https://github.com/APConduct/lucid-lang written to /workspace/builds/worker-7-tc1/source/Cargo.toml
[INFO] validating manifest of git repo https://github.com/APConduct/lucid-lang on toolchain d98a5da813da67eb189387b8ccfb73cf481275d8
[INFO] running `Command { std: CARGO_HOME="/workspace/cargo-home" RUSTUP_HOME="/workspace/rustup-home" "/workspace/cargo-home/bin/cargo" "+d98a5da813da67eb189387b8ccfb73cf481275d8" "metadata" "--manifest-path" "Cargo.toml" "--no-deps", kill_on_drop: false }`
[INFO] crate git repo https://github.com/APConduct/lucid-lang 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" "+d98a5da813da67eb189387b8ccfb73cf481275d8" "fetch" "--manifest-path" "Cargo.toml", kill_on_drop: false }`
[INFO] [stderr]     Updating crates.io index
[INFO] [stderr]  Downloading crates ...
[INFO] [stderr]   Downloaded vte_generate_state_changes v0.1.2
[INFO] [stderr]   Downloaded vt100 v0.15.2
[INFO] [stderr]   Downloaded windows-link v0.2.0
[INFO] [stderr]   Downloaded tracing-indicatif v0.3.13
[INFO] [stderr]   Downloaded strip-ansi-escapes v0.2.1
[INFO] [stderr]   Downloaded console v0.16.1
[INFO] [stderr]   Downloaded windows-targets v0.53.4
[INFO] [stderr]   Downloaded vte v0.11.1
[INFO] [stderr]   Downloaded castaway v0.2.4
[INFO] [stderr]   Downloaded windows-core v0.62.1
[INFO] [stderr]   Downloaded fd-lock v3.0.13
[INFO] [stderr]   Downloaded reedline v0.27.1
[INFO] [stderr]   Downloaded vte v0.14.1
[INFO] [stderr]   Downloaded instability v0.3.9
[INFO] [stderr]   Downloaded windows-implement v0.60.1
[INFO] [stderr]   Downloaded windows-interface v0.59.2
[INFO] [stderr]   Downloaded windows-result v0.4.0
[INFO] [stderr]   Downloaded windows-strings v0.5.0
[INFO] [stderr]   Downloaded nu-ansi-term v0.49.0
[INFO] [stderr]   Downloaded windows-sys v0.61.1
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/source:/opt/rustwide/workdir:ro,Z" "-v" "/var/lib/crater-agent-workspace/cargo-home:/opt/rustwide/cargo-home:ro,Z" "-v" "/var/lib/crater-agent-workspace/rustup-home:/opt/rustwide/rustup-home:ro,Z" "-e" "SOURCE_DIR=/opt/rustwide/workdir" "-e" "CARGO_TARGET_DIR=/opt/rustwide/target" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+d98a5da813da67eb189387b8ccfb73cf481275d8" "metadata" "--no-deps" "--format-version=1", kill_on_drop: false }`
[INFO] [stdout] 66c299596049a32871938c00b0988ff5aaf368a02cbd10a1ab4a617fe613f5de
[INFO] running `Command { std: "docker" "start" "-a" "66c299596049a32871938c00b0988ff5aaf368a02cbd10a1ab4a617fe613f5de", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "inspect" "66c299596049a32871938c00b0988ff5aaf368a02cbd10a1ab4a617fe613f5de", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "66c299596049a32871938c00b0988ff5aaf368a02cbd10a1ab4a617fe613f5de", kill_on_drop: false }`
[INFO] [stdout] 66c299596049a32871938c00b0988ff5aaf368a02cbd10a1ab4a617fe613f5de
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-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 -Copt-level=3" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+d98a5da813da67eb189387b8ccfb73cf481275d8" "build" "--frozen" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 594278df05c3e17edb86bc1aec2eec7d115468ff8a8ed901f0ee558a4a484b44
[INFO] running `Command { std: "docker" "start" "-a" "594278df05c3e17edb86bc1aec2eec7d115468ff8a8ed901f0ee558a4a484b44", kill_on_drop: false }`
[INFO] [stderr]    Compiling proc-macro2 v1.0.101
[INFO] [stderr]    Compiling unicode-ident v1.0.19
[INFO] [stderr]    Compiling libc v0.2.176
[INFO] [stderr]    Compiling log v0.4.28
[INFO] [stderr]    Compiling autocfg v1.5.0
[INFO] [stderr]    Compiling serde_core v1.0.228
[INFO] [stderr]    Compiling cfg-if v1.0.3
[INFO] [stderr]    Compiling serde v1.0.228
[INFO] [stderr]    Compiling rustversion v1.0.22
[INFO] [stderr]    Compiling smallvec v1.15.1
[INFO] [stderr]    Compiling signal-hook v0.3.18
[INFO] [stderr]    Compiling once_cell v1.21.3
[INFO] [stderr]    Compiling parking_lot_core v0.9.11
[INFO] [stderr]    Compiling quote v1.0.41
[INFO] [stderr]    Compiling rustix v0.38.44
[INFO] [stderr]    Compiling unicode-width v0.1.14
[INFO] [stderr]    Compiling either v1.15.0
[INFO] [stderr]    Compiling ident_case v1.0.1
[INFO] [stderr]    Compiling unicode-width v0.2.0
[INFO] [stderr]    Compiling arrayvec v0.7.6
[INFO] [stderr]    Compiling tracing-core v0.1.34
[INFO] [stderr]    Compiling portable-atomic v1.11.1
[INFO] [stderr]    Compiling anstyle-parse v0.2.7
[INFO] [stderr]    Compiling anstyle-query v1.1.4
[INFO] [stderr]    Compiling foldhash v0.1.5
[INFO] [stderr]    Compiling colorchoice v1.0.4
[INFO] [stderr]    Compiling unicode-segmentation v1.12.0
[INFO] [stderr]    Compiling anstyle v1.0.13
[INFO] [stderr]    Compiling instability v0.3.9
[INFO] [stderr]    Compiling tracing-log v0.2.0
[INFO] [stderr]    Compiling sharded-slab v0.1.7
[INFO] [stderr]    Compiling hashbrown v0.15.5
[INFO] [stderr]    Compiling vte v0.14.1
[INFO] [stderr]    Compiling itertools v0.13.0
[INFO] [stderr]    Compiling syn v2.0.106
[INFO] [stderr]    Compiling anstream v0.6.21
[INFO] [stderr]    Compiling thread_local v1.1.9
[INFO] [stderr]    Compiling nu-ansi-term v0.50.1
[INFO] [stderr]    Compiling iana-time-zone v0.1.64
[INFO] [stderr]    Compiling clap_lex v0.7.5
[INFO] [stderr]    Compiling unit-prefix v0.5.1
[INFO] [stderr]    Compiling indoc v2.0.6
[INFO] [stderr]    Compiling clap_builder v4.5.48
[INFO] [stderr]    Compiling tracing-subscriber v0.3.20
[INFO] [stderr]    Compiling strip-ansi-escapes v0.2.1
[INFO] [stderr]    Compiling lru v0.12.5
[INFO] [stderr]    Compiling lock_api v0.4.13
[INFO] [stderr]    Compiling num-traits v0.2.19
[INFO] [stderr]    Compiling itertools v0.10.5
[INFO] [stderr]    Compiling strum v0.25.0
[INFO] [stderr]    Compiling cassowary v0.3.0
[INFO] [stderr]    Compiling nu-ansi-term v0.49.0
[INFO] [stderr]    Compiling colored v3.0.0
[INFO] [stderr]    Compiling castaway v0.2.4
[INFO] [stderr]    Compiling compact_str v0.8.1
[INFO] [stderr]    Compiling signal-hook-registry v1.4.6
[INFO] [stderr]    Compiling mio v1.0.4
[INFO] [stderr]    Compiling mio v0.8.11
[INFO] [stderr]    Compiling vte_generate_state_changes v0.1.2
[INFO] [stderr]    Compiling parking_lot v0.12.4
[INFO] [stderr]    Compiling console v0.16.1
[INFO] [stderr]    Compiling signal-hook-mio v0.2.4
[INFO] [stderr]    Compiling unicode-truncate v1.1.0
[INFO] [stderr]    Compiling vte v0.11.1
[INFO] [stderr]    Compiling vt100 v0.15.2
[INFO] [stderr]    Compiling indicatif v0.18.0
[INFO] [stderr]    Compiling darling_core v0.20.11
[INFO] [stderr]    Compiling serde_derive v1.0.228
[INFO] [stderr]    Compiling strum_macros v0.26.4
[INFO] [stderr]    Compiling tracing-attributes v0.1.30
[INFO] [stderr]    Compiling thiserror-impl v1.0.69
[INFO] [stderr]    Compiling clap_derive v4.5.47
[INFO] [stderr]    Compiling strum_macros v0.25.3
[INFO] [stderr]    Compiling darling_macro v0.20.11
[INFO] [stderr]    Compiling darling v0.20.11
[INFO] [stderr]    Compiling thiserror v1.0.69
[INFO] [stderr]    Compiling clap v4.5.48
[INFO] [stderr]    Compiling strum v0.26.3
[INFO] [stderr]    Compiling bitflags v2.9.4
[INFO] [stderr]    Compiling chrono v0.4.42
[INFO] [stderr]    Compiling crossterm v0.27.0
[INFO] [stderr]    Compiling tracing v0.1.41
[INFO] [stderr]    Compiling tracing-indicatif v0.3.13
[INFO] [stderr]    Compiling crossterm v0.28.1
[INFO] [stderr]    Compiling fd-lock v3.0.13
[INFO] [stderr]    Compiling reedline v0.27.1
[INFO] [stderr]    Compiling ratatui v0.29.0
[INFO] [stderr]    Compiling lucid v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `tracing::event`
[INFO] [stdout]  --> src/parser.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use tracing::event;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `tracing::span`
[INFO] [stdout]  --> src/parser.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 | use tracing::span;
[INFO] [stdout]   |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `error` is never used
[INFO] [stdout]   --> src/parser.rs:46:8
[INFO] [stdout]    |
[INFO] [stdout] 17 | impl Parser {
[INFO] [stdout]    | ----------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 46 |     fn error(&self, message: String) -> String {
[INFO] [stdout]    |        ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `dev` profile [unoptimized + debuginfo] target(s) in 2m 57s
[INFO] running `Command { std: "docker" "inspect" "594278df05c3e17edb86bc1aec2eec7d115468ff8a8ed901f0ee558a4a484b44", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "594278df05c3e17edb86bc1aec2eec7d115468ff8a8ed901f0ee558a4a484b44", kill_on_drop: false }`
[INFO] [stdout] 594278df05c3e17edb86bc1aec2eec7d115468ff8a8ed901f0ee558a4a484b44
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-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 -Copt-level=3" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+d98a5da813da67eb189387b8ccfb73cf481275d8" "test" "--frozen" "--no-run" "--message-format=json", kill_on_drop: false }`
[INFO] [stdout] 6dfdc6cbfb4ac2a2ad62406862408ea815713995ac657361fd360baea4ff6bd9
[INFO] running `Command { std: "docker" "start" "-a" "6dfdc6cbfb4ac2a2ad62406862408ea815713995ac657361fd360baea4ff6bd9", kill_on_drop: false }`
[INFO] [stderr]    Compiling lucid v0.1.0 (/opt/rustwide/workdir)
[INFO] [stdout] warning: unused import: `tracing::event`
[INFO] [stdout]  --> src/parser.rs:8:5
[INFO] [stdout]   |
[INFO] [stdout] 8 | use tracing::event;
[INFO] [stdout]   |     ^^^^^^^^^^^^^^
[INFO] [stdout]   |
[INFO] [stdout]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: unused import: `tracing::span`
[INFO] [stdout]  --> src/parser.rs:9:5
[INFO] [stdout]   |
[INFO] [stdout] 9 | use tracing::span;
[INFO] [stdout]   |     ^^^^^^^^^^^^^
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stdout] warning: method `error` is never used
[INFO] [stdout]   --> src/parser.rs:46:8
[INFO] [stdout]    |
[INFO] [stdout] 17 | impl Parser {
[INFO] [stdout]    | ----------- method in this implementation
[INFO] [stdout] ...
[INFO] [stdout] 46 |     fn error(&self, message: String) -> String {
[INFO] [stdout]    |        ^^^^^
[INFO] [stdout]    |
[INFO] [stdout]    = note: `#[warn(dead_code)]` on by default
[INFO] [stdout] 
[INFO] [stdout] 
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 6.02s
[INFO] running `Command { std: "docker" "inspect" "6dfdc6cbfb4ac2a2ad62406862408ea815713995ac657361fd360baea4ff6bd9", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "6dfdc6cbfb4ac2a2ad62406862408ea815713995ac657361fd360baea4ff6bd9", kill_on_drop: false }`
[INFO] [stdout] 6dfdc6cbfb4ac2a2ad62406862408ea815713995ac657361fd360baea4ff6bd9
[INFO] running `Command { std: "docker" "create" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-tc1/target:/opt/rustwide/target:rw,Z" "-v" "/var/lib/crater-agent-workspace/builds/worker-7-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 -Copt-level=3" "-e" "RUSTDOCFLAGS=--cap-lints=forbid" "-e" "CARGO_HOME=/opt/rustwide/cargo-home" "-e" "RUSTUP_HOME=/opt/rustwide/rustup-home" "-w" "/opt/rustwide/workdir" "-m" "1610612736" "--user" "0:0" "--network" "none" "ghcr.io/rust-lang/crates-build-env/linux@sha256:e90291280db7d1fac5b66fc6dad9f9662629e7365a55743daf9bdf73ebc4ea79" "/opt/rustwide/cargo-home/bin/cargo" "+d98a5da813da67eb189387b8ccfb73cf481275d8" "test" "--frozen", kill_on_drop: false }`
[INFO] [stdout] 04e3e42ffc26018ac8af51239c4d77630ffa05c1992452d7039483e2e5f2b217
[INFO] running `Command { std: "docker" "start" "-a" "04e3e42ffc26018ac8af51239c4d77630ffa05c1992452d7039483e2e5f2b217", kill_on_drop: false }`
[INFO] [stderr] warning: unused import: `tracing::event`
[INFO] [stderr]  --> src/parser.rs:8:5
[INFO] [stderr]   |
[INFO] [stderr] 8 | use tracing::event;
[INFO] [stderr]   |     ^^^^^^^^^^^^^^
[INFO] [stderr]   |
[INFO] [stderr]   = note: `#[warn(unused_imports)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: unused import: `tracing::span`
[INFO] [stderr]  --> src/parser.rs:9:5
[INFO] [stderr]   |
[INFO] [stderr] 9 | use tracing::span;
[INFO] [stderr]   |     ^^^^^^^^^^^^^
[INFO] [stderr] 
[INFO] [stderr] warning: method `error` is never used
[INFO] [stderr]   --> src/parser.rs:46:8
[INFO] [stderr]    |
[INFO] [stderr] 17 | impl Parser {
[INFO] [stderr]    | ----------- method in this implementation
[INFO] [stderr] ...
[INFO] [stderr] 46 |     fn error(&self, message: String) -> String {
[INFO] [stderr]    |        ^^^^^
[INFO] [stderr]    |
[INFO] [stderr]    = note: `#[warn(dead_code)]` on by default
[INFO] [stderr] 
[INFO] [stderr] warning: `lucid` (bin "lucid" test) generated 3 warnings (run `cargo fix --bin "lucid" --tests` to apply 2 suggestions)
[INFO] [stderr]     Finished `test` profile [unoptimized + debuginfo] target(s) in 0.16s
[INFO] [stderr]      Running unittests src/main.rs (/opt/rustwide/target/debug/deps/lucid-70f1ecc0a8390755)
[INFO] [stdout] 
[INFO] [stdout] running 38 tests
[INFO] [stdout] test ast::tests::test_program ... ok
[INFO] [stdout] test ast::tests::test_program_with_function ... ok
[INFO] [stdout] test ast::tests::test_program_with_statements ... ok
[INFO] [stdout] test codegen::tests::test_codegen_function ... ok
[INFO] [stdout] test codegen::tests::test_codegen_if_else ... ok
[INFO] [stdout] test codegen::tests::test_codegen_local_assign ... ok
[INFO] [stdout] test codegen::tests::test_codegen_print ... ok
[INFO] [stdout] test codegen::tests::test_codegen_simple ... ok
[INFO] [stdout] test codegen::tests::test_codegen_table ... ok
[INFO] [stdout] test codegen::tests::test_codegen_table_with_bracket_notation ... ok
[INFO] [stdout] test codegen::tests::test_codegen_table_with_keys ... ok
[INFO] [stdout] test compiler::tests::test_comments_are_stripped ... ok
[INFO] [stdout] test compiler::tests::test_compile_function ... ok
[INFO] [stdout] test compiler::tests::test_complex_union ... ok
[INFO] [stdout] test compiler::tests::test_compile_generic_function ... ok
[INFO] [stdout] test compiler::tests::test_interface_declaration ... ok
[INFO] [stdout] test compiler::tests::test_generic_with_union ... ok
[INFO] [stdout] test compiler::tests::test_generic_function_map ... ok
[INFO] [stdout] test lexer::tests::test_block_comment ... ok
[INFO] [stdout] test lexer::tests::test_lexer ... ok
[INFO] [stdout] test lexer::tests::test_lexer_keywords ... ok
[INFO] [stdout] [2m2025-10-11T04:41:48.807944Z[0m [32m INFO[0m [1mcompile[0m[1m{[0m[3msource[0m[2m=[0m"\n   local x: number | nil = 42\n   local y: number | nil = nil\n   "[1m}[0m[2m:[0m [2mlucid::compiler[0m[2m:[0m Starting compilation
[INFO] [stdout] [2m2025-10-11T04:41:48.807965Z[0m [32m INFO[0m [1mcompile[0m[1m{[0m[3msource[0m[2m=[0m"\n   local x: number | nil = 42\n   local y: number | nil = nil\n   "[1m}[0m[2m:[0m [2mlucid::parser[0m[2m:[0m Parsing program
[INFO] [stdout] test lexer::tests::test_single_line_comment ... ok
[INFO] [stdout] [2m2025-10-11T04:41:48.807979Z[0m [32m INFO[0m [1mcompile[0m[1m{[0m[3msource[0m[2m=[0m"\n   local x: number | nil = 42\n   local y: number | nil = nil\n   "[1m}[0m[2m:[0m[1mparse_stmt[0m[2m:[0m[1mparse_local[0m[2m:[0m [2mparser[0m[2m:[0m Parsed variable: x
[INFO] [stdout] test compiler::tests::test_union_type_error ... ok
[INFO] [stdout] [2m2025-10-11T04:41:48.807989Z[0m [32m INFO[0m [1mcompile[0m[1m{[0m[3msource[0m[2m=[0m"\n   local x: number | nil = 42\n   local y: number | nil = nil\n   "[1m}[0m[2m:[0m[1mparse_stmt[0m[2m:[0m[1mparse_local[0m[2m:[0m [2mparser[0m[2m:[0m Parsed variable: x as type nil | number
[INFO] [stdout] test parser::tests::test_parse_expression ... ok
[INFO] [stdout] test lexer::tests::test_multiline_block_comment ... ok[2m2025-10-11T04:41:48.807995Z[0m [33m WARN[0m [1mcompile[0m[1m{[0m[3msource[0m[2m=[0m"\n   local x: number | nil = 42\n   local y: number | nil = nil\n   "[1m}[0m[2m:[0m[1mparse_stmt[0m[2m:[0m[1mparse_local[0m[2m:[0m [2mlucid::parser[0m[2m:[0m About to call parse_postfix
[INFO] [stdout] 
[INFO] [stdout] test lexer::tests::test_minus_vs_comment ... ok
[INFO] [stdout] [2m2025-10-11T04:41:48.808006Z[0m [32m INFO[0m [1mcompile[0m[1m{[0m[3msource[0m[2m=[0m"\n   local x: number | nil = 42\n   local y: number | nil = nil\n   "[1m}[0m[2m:[0m[1mparse_stmt[0m[2m:[0m[1mparse_local[0m[2m:[0m [2mparser[0m[2m:[0m Parsed variable: y
[INFO] [stdout] test lexer::tests::test_multiple_comments ... ok
[INFO] [stdout] [2m2025-10-11T04:41:48.808012Z[0m [32m INFO[0m [1mcompile[0m[1m{[0m[3msource[0m[2m=[0m"\n   local x: number | nil = 42\n   local y: number | nil = nil\n   "[1m}[0m[2m:[0m[1mparse_stmt[0m[2m:[0m[1mparse_local[0m[2m:[0m [2mparser[0m[2m:[0m Parsed variable: y as type nil | number
[INFO] [stdout] test parser::tests::test_parse_table_with_keys ... ignored, key/value pairs are not supported yet
[INFO] [stdout] [2m2025-10-11T04:41:48.808018Z[0m [33m WARN[0m [1mcompile[0m[1m{[0m[3msource[0m[2m=[0m"\n   local x: number | nil = 42\n   local y: number | nil = nil\n   "[1m}[0m[2m:[0m[1mparse_stmt[0m[2m:[0m[1mparse_local[0m[2m:[0m [2mlucid::parser[0m[2m:[0m About to call parse_postfix
[INFO] [stdout] [2m2025-10-11T04:41:48.808033Z[0m [32m INFO[0m [1mcompile[0m[1m{[0m[3msource[0m[2m=[0m"\n   local x: number | nil = 42\n   local y: number | nil = nil\n   "[1m}[0m[2m:[0m [2mlucid::compiler[0m[2m:[0m Compilation successful
[INFO] [stdout] [2m2025-10-11T04:41:48.808040Z[0m [32m INFO[0m [1mcompile[0m[1m{[0m[3msource[0m[2m=[0m"\n  interface Animal\n      name: string\n      age: number\n      speak: function\n  end\n\n  function create_dog(): Animal\n      local dog = {\n          name = \"Buddy\",\n          age = 5,\n          speak = function() end\n      }\n      return dog\n  end\n  "[1m}[0m[2m:[0m [2mlucid::compiler[0m[2m:[0m Starting compilation
[INFO] [stdout] [2m2025-10-11T04:41:48.808070Z[0m [32m INFO[0m [1mcompile[0m[1m{[0m[3msource[0m[2m=[0m"\n  interface Animal\n      name: string\n      age: number\n      speak: function\n  end\n\n  function create_dog(): Animal\n      local dog = {\n          name = \"Buddy\",\n          age = 5,\n          speak = function() end\n      }\n      return dog\n  end\n  "[1m}[0m[2m:[0m [2mlucid::parser[0m[2m:[0m Parsing program
[INFO] [stdout] test compiler::tests::test_union_with_nil ... ok
[INFO] [stdout] [2m2025-10-11T04:41:48.808098Z[0m [32m INFO[0m [1mcompile[0m[1m{[0m[3msource[0m[2m=[0m"\n  interface Animal\n      name: string\n      age: number\n      speak: function\n  end\n\n  function create_dog(): Animal\n      local dog = {\n          name = \"Buddy\",\n          age = 5,\n          speak = function() end\n      }\n      return dog\n  end\n  "[1m}[0m[2m:[0m[1mparse_stmt[0m[2m:[0m[1mparse_stmt[0m[2m:[0m[1mparse_local[0m[2m:[0m [2mparser[0m[2m:[0m Parsed variable: dog
[INFO] [stdout] [2m2025-10-11T04:41:48.808105Z[0m [32m INFO[0m [1mcompile[0m[1m{[0m[3msource[0m[2m=[0m"\n  interface Animal\n      name: string\n      age: number\n      speak: function\n  end\n\n  function create_dog(): Animal\n      local dog = {\n          name = \"Buddy\",\n          age = 5,\n          speak = function() end\n      }\n      return dog\n  end\n  "[1m}[0m[2m:[0m[1mparse_stmt[0m[2m:[0m[1mparse_stmt[0m[2m:[0m[1mparse_local[0m[2m:[0m [2mparser[0m[2m:[0m Parsed variable: dog as type None
[INFO] [stdout] [2m2025-10-11T04:41:48.808115Z[0m [33m WARN[0m [1mcompile[0m[1m{[0m[3msource[0m[2m=[0m"\n  interface Animal\n      name: string\n      age: number\n      speak: function\n  end\n\n  function create_dog(): Animal\n      local dog = {\n          name = \"Buddy\",\n          age = 5,\n          speak = function() end\n      }\n      return dog\n  end\n  "[1m}[0m[2m:[0m[1mparse_stmt[0m[2m:[0m[1mparse_stmt[0m[2m:[0m[1mparse_local[0m[2m:[0m [2mlucid::parser[0m[2m:[0m About to call parse_postfix
[INFO] [stdout] [2m2025-10-11T04:41:48.808125Z[0m [33m WARN[0m [1mcompile[0m[1m{[0m[3msource[0m[2m=[0m"\n  interface Animal\n      name: string\n      age: number\n      speak: function\n  end\n\n  function create_dog(): Animal\n      local dog = {\n          name = \"Buddy\",\n          age = 5,\n          speak = function() end\n      }\n      return dog\n  end\n  "[1m}[0m[2m:[0m[1mparse_stmt[0m[2m:[0m[1mparse_stmt[0m[2m:[0m[1mparse_local[0m[2m:[0m [2mlucid::parser[0m[2m:[0m About to call parse_postfix
[INFO] [stdout] [2m2025-10-11T04:41:48.808133Z[0m [33m WARN[0m [1mcompile[0m[1m{[0m[3msource[0m[2m=[0m"\n  interface Animal\n      name: string\n      age: number\n      speak: function\n  end\n\n  function create_dog(): Animal\n      local dog = {\n          name = \"Buddy\",\n          age = 5,\n          speak = function() end\n      }\n      return dog\n  end\n  "[1m}[0m[2m:[0m[1mparse_stmt[0m[2m:[0m[1mparse_stmt[0m[2m:[0m[1mparse_local[0m[2m:[0m [2mlucid::parser[0m[2m:[0m About to call parse_postfix
[INFO] [stdout] [2m2025-10-11T04:41:48.808159Z[0m [33m WARN[0m [1mcompile[0m[1m{[0m[3msource[0m[2m=[0m"\n  interface Animal\n      name: string\n      age: number\n      speak: function\n  end\n\n  function create_dog(): Animal\n      local dog = {\n          name = \"Buddy\",\n          age = 5,\n          speak = function() end\n      }\n      return dog\n  end\n  "[1m}[0m[2m:[0m[1mparse_stmt[0m[2m:[0m[1mparse_stmt[0m[2m:[0m[1mparse_local[0m[2m:[0m [2mlucid::parser[0m[2m:[0m About to call parse_postfix
[INFO] [stdout] [2m2025-10-11T04:41:48.808165Z[0m [33m WARN[0m [1mcompile[0m[1m{[0m[3msource[0m[2m=[0m"\n  interface Animal\n      name: string\n      age: number\n      speak: function\n  end\n\n  function create_dog(): Animal\n      local dog = {\n          name = \"Buddy\",\n          age = 5,\n          speak = function() end\n      }\n      return dog\n  end\n  "[1m}[0m[2m:[0m[1mparse_stmt[0m[2m:[0m[1mparse_stmt[0m[2m:[0m[1mparse_local[0m[2m:[0m [2mlucid::parser[0m[2m:[0m About to call parse_postfix
[INFO] [stdout] [2m2025-10-11T04:41:48.808171Z[0m [33m WARN[0m [1mcompile[0m[1m{[0m[3msource[0m[2m=[0m"\n  interface Animal\n      name: string\n      age: number\n      speak: function\n  end\n\n  function create_dog(): Animal\n      local dog = {\n          name = \"Buddy\",\n          age = 5,\n          speak = function() end\n      }\n      return dog\n  end\n  "[1m}[0m[2m:[0m[1mparse_stmt[0m[2m:[0m[1mparse_stmt[0m[2m:[0m[1mparse_local[0m[2m:[0m [2mlucid::parser[0m[2m:[0m About to call parse_postfix
[INFO] [stdout] [2m2025-10-11T04:41:48.808189Z[0m [33m WARN[0m [1mcompile[0m[1m{[0m[3msource[0m[2m=[0m"\n  interface Animal\n      name: string\n      age: number\n      speak: function\n  end\n\n  function create_dog(): Animal\n      local dog = {\n          name = \"Buddy\",\n          age = 5,\n          speak = function() end\n      }\n      return dog\n  end\n  "[1m}[0m[2m:[0m[1mparse_stmt[0m[2m:[0m[1mparse_stmt[0m[2m:[0m[1mparse_local[0m[2m:[0m [2mlucid::parser[0m[2m:[0m About to call parse_postfix
[INFO] [stdout] [2m2025-10-11T04:41:48.808205Z[0m [33m WARN[0m [1mcompile[0m[1m{[0m[3msource[0m[2m=[0m"\n  interface Animal\n      name: string\n      age: number\n      speak: function\n  end\n\n  function create_dog(): Animal\n      local dog = {\n          name = \"Buddy\",\n          age = 5,\n          speak = function() end\n      }\n      return dog\n  end\n  "[1m}[0m[2m:[0m[1mparse_stmt[0m[2m:[0m[1mparse_stmt[0m[2m:[0m [2mlucid::parser[0m[2m:[0m About to call parse_postfix
[INFO] [stdout] [2m2025-10-11T04:41:48.808233Z[0m [33m WARN[0m [1mcompile[0m[1m{[0m[3msource[0m[2m=[0m"\n  interface Animal\n      name: string\n      age: number\n      speak: function\n  end\n\n  function create_dog(): Animal\n      local dog = {\n          name = \"Buddy\",\n          age = 5,\n          speak = function() end\n      }\n      return dog\n  end\n  "[1m}[0m[2m:[0m [2mlucid::type_checker[0m[2m:[0m Proper return type checking is not implemented yet
[INFO] [stdout] [2m2025-10-11T04:41:48.808245Z[0m [32m INFO[0m [1mcompile[0m[1m{[0m[3msource[0m[2m=[0m"\n  interface Animal\n      name: string\n      age: number\n      speak: function\n  end\n\n  function create_dog(): Animal\n      local dog = {\n          name = \"Buddy\",\n          age = 5,\n          speak = function() end\n      }\n      return dog\n  end\n  "[1m}[0m[2m:[0m [2mlucid::compiler[0m[2m:[0m Compilation successful
[INFO] [stdout] test compiler::tests::test_interface_with_function ... ok
[INFO] [stdout] [2m2025-10-11T04:41:48.808367Z[0m [33m WARN[0m [2mlucid::parser[0m[2m:[0m About to call parse_postfix
[INFO] [stdout] [2m2025-10-11T04:41:48.808383Z[0m [33m WARN[0m [2mlucid::parser[0m[2m:[0m About to call parse_postfix
[INFO] [stdout] [2m2025-10-11T04:41:48.808404Z[0m [33m WARN[0m [2mlucid::parser[0m[2m:[0m About to call parse_postfix
[INFO] [stdout] [2m2025-10-11T04:41:48.808408Z[0m [33m WARN[0m [2mlucid::parser[0m[2m:[0m About to call parse_postfix
[INFO] [stdout] test parser::tests::test_parse_table ... ok
[INFO] [stdout] [2m2025-10-11T04:41:48.812578Z[0m [32m INFO[0m [1mcompile[0m[1m{[0m[3msource[0m[2m=[0m"\nlocal function swap<T, U>(a: T, b: U): U, T\n    return b, a\nend\n"[1m}[0m[2m:[0m [2mlucid::compiler[0m[2m:[0m Starting compilation
[INFO] [stdout] [2m2025-10-11T04:41:48.812613Z[0m [32m INFO[0m [1mcompile[0m[1m{[0m[3msource[0m[2m=[0m"\nlocal function swap<T, U>(a: T, b: U): U, T\n    return b, a\nend\n"[1m}[0m[2m:[0m [2mlucid::parser[0m[2m:[0m Parsing program
[INFO] [stdout] [2m2025-10-11T04:41:48.812644Z[0m [33m WARN[0m [1mcompile[0m[1m{[0m[3msource[0m[2m=[0m"\nlocal function swap<T, U>(a: T, b: U): U, T\n    return b, a\nend\n"[1m}[0m[2m:[0m[1mparse_stmt[0m[2m:[0m[1mparse_local[0m[2m:[0m[1mparse_stmt[0m[2m:[0m [2mlucid::parser[0m[2m:[0m About to call parse_postfix
[INFO] [stdout] [2m2025-10-11T04:41:48.812653Z[0m [33m WARN[0m [1mcompile[0m[1m{[0m[3msource[0m[2m=[0m"\nlocal function swap<T, U>(a: T, b: U): U, T\n    return b, a\nend\n"[1m}[0m[2m:[0m[1mparse_stmt[0m[2m:[0m[1mparse_local[0m[2m:[0m[1mparse_stmt[0m[2m:[0m [2mlucid::parser[0m[2m:[0m About to call parse_postfix
[INFO] [stdout] test lexer::tests::test_lexer_numbers ... ok
[INFO] [stdout] [2m2025-10-11T04:41:48.812670Z[0m [33m WARN[0m [1mcompile[0m[1m{[0m[3msource[0m[2m=[0m"\nlocal function swap<T, U>(a: T, b: U): U, T\n    return b, a\nend\n"[1m}[0m[2m:[0m [2mlucid::type_checker[0m[2m:[0m Proper return type checking is not implemented yet
[INFO] [stdout] [2m2025-10-11T04:41:48.812681Z[0m [32m INFO[0m [1mcompile[0m[1m{[0m[3msource[0m[2m=[0m"\nlocal function swap<T, U>(a: T, b: U): U, T\n    return b, a\nend\n"[1m}[0m[2m:[0m [2mlucid::compiler[0m[2m:[0m Compilation successful
[INFO] [stdout] test compiler::tests::test_generic_local_function ... ok
[INFO] [stdout] test codegen::tests::test_codegen_table_with_identifier_keys ... ok
[INFO] [stdout] test ast::tests::test_program_with_if_statement ... ok
[INFO] [stdout] [2m2025-10-11T04:41:48.919582Z[0m [32m INFO[0m [1mcompile[0m[1m{[0m[3msource[0m[2m=[0m"\n   function process(value: number | string): string\n       return \"processed\"\n   end\n\n   local a = process(42)\n   local b = process(\"test\")\n   "[1m}[0m[2m:[0m [2mlucid::compiler[0m[2m:[0m Starting compilation
[INFO] [stdout] [2m2025-10-11T04:41:48.919624Z[0m [32m INFO[0m [1mcompile[0m[1m{[0m[3msource[0m[2m=[0m"\n   function process(value: number | string): string\n       return \"processed\"\n   end\n\n   local a = process(42)\n   local b = process(\"test\")\n   "[1m}[0m[2m:[0m [2mlucid::parser[0m[2m:[0m Parsing program
[INFO] [stdout] [2m2025-10-11T04:41:48.919661Z[0m [33m WARN[0m [1mcompile[0m[1m{[0m[3msource[0m[2m=[0m"\n   function process(value: number | string): string\n       return \"processed\"\n   end\n\n   local a = process(42)\n   local b = process(\"test\")\n   "[1m}[0m[2m:[0m[1mparse_stmt[0m[2m:[0m[1mparse_stmt[0m[2m:[0m [2mlucid::parser[0m[2m:[0m About to call parse_postfix
[INFO] [stdout] [2m2025-10-11T04:41:48.919673Z[0m [32m INFO[0m [1mcompile[0m[1m{[0m[3msource[0m[2m=[0m"\n   function process(value: number | string): string\n       return \"processed\"\n   end\n\n   local a = process(42)\n   local b = process(\"test\")\n   "[1m}[0m[2m:[0m[1mparse_stmt[0m[2m:[0m[1mparse_local[0m[2m:[0m [2mparser[0m[2m:[0m Parsed variable: a
[INFO] [stdout] [2m2025-10-11T04:41:48.919678Z[0m [32m INFO[0m [1mcompile[0m[1m{[0m[3msource[0m[2m=[0m"\n   function process(value: number | string): string\n       return \"processed\"\n   end\n\n   local a = process(42)\n   local b = process(\"test\")\n   "[1m}[0m[2m:[0m[1mparse_stmt[0m[2m:[0m[1mparse_local[0m[2m:[0m [2mparser[0m[2m:[0m Parsed variable: a as type None
[INFO] [stdout] [2m2025-10-11T04:41:48.919684Z[0m [33m WARN[0m [1mcompile[0m[1m{[0m[3msource[0m[2m=[0m"\n   function process(value: number | string): string\n       return \"processed\"\n   end\n\n   local a = process(42)\n   local b = process(\"test\")\n   "[1m}[0m[2m:[0m[1mparse_stmt[0m[2m:[0m[1mparse_local[0m[2m:[0m [2mlucid::parser[0m[2m:[0m About to call parse_postfix
[INFO] [stdout] [2m2025-10-11T04:41:48.919689Z[0m [33m WARN[0m [1mcompile[0m[1m{[0m[3msource[0m[2m=[0m"\n   function process(value: number | string): string\n       return \"processed\"\n   end\n\n   local a = process(42)\n   local b = process(\"test\")\n   "[1m}[0m[2m:[0m[1mparse_stmt[0m[2m:[0m[1mparse_local[0m[2m:[0m [2mlucid::parser[0m[2m:[0m About to call parse_postfix
[INFO] [stdout] [2m2025-10-11T04:41:48.919702Z[0m [32m INFO[0m [1mcompile[0m[1m{[0m[3msource[0m[2m=[0m"\n   function process(value: number | string): string\n       return \"processed\"\n   end\n\n   local a = process(42)\n   local b = process(\"test\")\n   "[1m}[0m[2m:[0m[1mparse_stmt[0m[2m:[0m[1mparse_local[0m[2m:[0m [2mparser[0m[2m:[0m Parsed variable: b
[INFO] [stdout] [2m2025-10-11T04:41:48.919708Z[0m [32m INFO[0m [1mcompile[0m[1m{[0m[3msource[0m[2m=[0m"\n   function process(value: number | string): string\n       return \"processed\"\n   end\n\n   local a = process(42)\n   local b = process(\"test\")\n   "[1m}[0m[2m:[0m[1mparse_stmt[0m[2m:[0m[1mparse_local[0m[2m:[0m [2mparser[0m[2m:[0m Parsed variable: b as type None
[INFO] [stdout] [2m2025-10-11T04:41:48.919713Z[0m [33m WARN[0m [1mcompile[0m[1m{[0m[3msource[0m[2m=[0m"\n   function process(value: number | string): string\n       return \"processed\"\n   end\n\n   local a = process(42)\n   local b = process(\"test\")\n   "[1m}[0m[2m:[0m[1mparse_stmt[0m[2m:[0m[1mparse_local[0m[2m:[0m [2mlucid::parser[0m[2m:[0m About to call parse_postfix
[INFO] [stdout] [2m2025-10-11T04:41:48.919719Z[0m [33m WARN[0m [1mcompile[0m[1m{[0m[3msource[0m[2m=[0m"\n   function process(value: number | string): string\n       return \"processed\"\n   end\n\n   local a = process(42)\n   local b = process(\"test\")\n   "[1m}[0m[2m:[0m[1mparse_stmt[0m[2m:[0m[1mparse_local[0m[2m:[0m [2mlucid::parser[0m[2m:[0m About to call parse_postfix
[INFO] [stdout] [2m2025-10-11T04:41:48.919739Z[0m [33m WARN[0m [1mcompile[0m[1m{[0m[3msource[0m[2m=[0m"\n   function process(value: number | string): string\n       return \"processed\"\n   end\n\n   local a = process(42)\n   local b = process(\"test\")\n   "[1m}[0m[2m:[0m [2mlucid::type_checker[0m[2m:[0m Proper return type checking is not implemented yet
[INFO] [stdout] [2m2025-10-11T04:41:48.919755Z[0m [32m INFO[0m [1mcompile[0m[1m{[0m[3msource[0m[2m=[0m"\n   function process(value: number | string): string\n       return \"processed\"\n   end\n\n   local a = process(42)\n   local b = process(\"test\")\n   "[1m}[0m[2m:[0m [2mlucid::compiler[0m[2m:[0m Compilation successful
[INFO] [stdout] [2m2025-10-11T04:41:48.919881Z[0m [32m INFO[0m [1mcompile[0m[1m{[0m[3msource[0m[2m=[0m"\n  local x: number | string = 42\n  local y: number | string = \"hello\"\n  "[1m}[0m[2m:[0m [2mlucid::compiler[0m[2m:[0m Starting compilation
[INFO] [stdout] [2m2025-10-11T04:41:48.919894Z[0m [32m INFO[0m [1mcompile[0m[1m{[0m[3msource[0m[2m=[0m"\n  local x: number | string = 42\n  local y: number | string = \"hello\"\n  "[1m}[0m[2m:[0m [2mlucid::parser[0m[2m:[0m Parsing program
[INFO] [stdout] [2m2025-10-11T04:41:48.919907Z[0m [32m INFO[0m [1mcompile[0m[1m{[0m[3msource[0m[2m=[0m"\n  local x: number | string = 42\n  local y: number | string = \"hello\"\n  "[1m}[0m[2m:[0m[1mparse_stmt[0m[2m:[0m[1mparse_local[0m[2m:[0m [2mparser[0m[2m:[0m Parsed variable: x
[INFO] [stdout] [2m2025-10-11T04:41:48.919918Z[0m [32m INFO[0m [1mcompile[0m[1m{[0m[3msource[0m[2m=[0m"\n  local x: number | string = 42\n  local y: number | string = \"hello\"\n  "[1m}[0m[2m:[0m[1mparse_stmt[0m[2m:[0m[1mparse_local[0m[2m:[0m [2mparser[0m[2m:[0m Parsed variable: x as type number | string
[INFO] [stdout] [2m2025-10-11T04:41:48.919924Z[0m [33m WARN[0m [1mcompile[0m[1m{[0m[3msource[0m[2m=[0m"\n  local x: number | string = 42\n  local y: number | string = \"hello\"\n  "[1m}[0m[2m:[0m[1mparse_stmt[0m[2m:[0m[1mparse_local[0m[2m:[0m [2mlucid::parser[0m[2m:[0m About to call parse_postfix
[INFO] [stdout] [2m2025-10-11T04:41:48.919932Z[0m [32m INFO[0m [1mcompile[0m[1m{[0m[3msource[0m[2m=[0m"\n  local x: number | string = 42\n  local y: number | string = \"hello\"\n  "[1m}[0m[2m:[0m[1mparse_stmt[0m[2m:[0m[1mparse_local[0m[2m:[0m [2mparser[0m[2m:[0m Parsed variable: y
[INFO] [stdout] [2m2025-10-11T04:41:48.919940Z[0m [32m INFO[0m [1mcompile[0m[1m{[0m[3msource[0m[2m=[0m"\n  local x: number | string = 42\n  local y: number | string = \"hello\"\n  "[1m}[0m[2m:[0m[1mparse_stmt[0m[2m:[0m[1mparse_local[0m[2m:[0m [2mparser[0m[2m:[0m Parsed variable: y as type number | string
[INFO] [stdout] [2m2025-10-11T04:41:48.919945Z[0m [33m WARN[0m [1mcompile[0m[1m{[0m[3msource[0m[2m=[0m"\n  local x: number | string = 42\n  local y: number | string = \"hello\"\n  "[1m}[0m[2m:[0m[1mparse_stmt[0m[2m:[0m[1mparse_local[0m[2m:[0m [2mlucid::parser[0m[2m:[0m About to call parse_postfix
[INFO] [stdout] [2m2025-10-11T04:41:48.919957Z[0m [32m INFO[0m [1mcompile[0m[1m{[0m[3msource[0m[2m=[0m"\n  local x: number | string = 42\n  local y: number | string = \"hello\"\n  "[1m}[0m[2m:[0m [2mlucid::compiler[0m[2m:[0m Compilation successful
[INFO] [stdout] test compiler::tests::test_union_in_function ... ok
[INFO] [stdout] test compiler::tests::test_union_types ... ok
[INFO] [stdout] test lexer::tests::test_comment_at_start ... ok
[INFO] [stdout] 
[INFO] [stdout] test result: ok. 37 passed; 0 failed; 1 ignored; 0 measured; 0 filtered out; finished in 0.17s
[INFO] [stdout] 
[INFO] running `Command { std: "docker" "inspect" "04e3e42ffc26018ac8af51239c4d77630ffa05c1992452d7039483e2e5f2b217", kill_on_drop: false }`
[INFO] running `Command { std: "docker" "rm" "-f" "04e3e42ffc26018ac8af51239c4d77630ffa05c1992452d7039483e2e5f2b217", kill_on_drop: false }`
[INFO] [stdout] 04e3e42ffc26018ac8af51239c4d77630ffa05c1992452d7039483e2e5f2b217
