032 nested for scopes

✗ Failing This test is currently failing.

Failed: backend-exec

Failure Output

Showing last 10 of 11 lines
  --> phantom_semantic_check:14:0

❌ Compiler coordination error: Phantom semantic validation failed
error: CompilerCoordinationFailed
/Users/larsde/src/koru/tests/regression/300_ADVANCED_FEATURES/330_PHANTOM_TYPES/330_032_nested_for_scopes/backend.zig:9544:17: 0x1001064af in emit (backend)
                return error.CompilerCoordinationFailed;
                ^
/Users/larsde/src/koru/tests/regression/300_ADVANCED_FEATURES/330_PHANTOM_TYPES/330_032_nested_for_scopes/backend.zig:9628:28: 0x1001072b7 in main (backend)
    const generated_code = try RuntimeEmitter.emit(compile_allocator, final_ast);
                           ^

Code

// TEST: Nested for-loops with resources at different scope levels
// STATUS: TESTING
//
// Three scope levels:
// 1. outermost_f - opened BEFORE outer loop, manually closed AFTER both loops
// 2. inner_f - opened IN inner loop, auto-closed in inner each branch
//
// This tests that @scope nesting works correctly with auto-discharge.

~import "$std/control"
~import "$app/fs"

~app.fs:open(path: "outermost.txt")
| opened outermost_f |>
    std.control:for(0..2)
    | each _ |>
        std.control:for(0..2)
        | each _ |>
            app.fs:open(path: "inner.txt")
            | opened _ |>
                _  // inner_f auto-closed here (innermost @scope)
        | done |> _
    | done |>
        app.fs:close(file: outermost_f)
        | closed |> _

pub fn main() void {}
input.kz

Expected

Opening file: outermost.txt
Opening file: inner.txt
Closing file
Opening file: inner.txt
Closing file
Opening file: inner.txt
Closing file
Opening file: inner.txt
Closing file
Closing file

Imported Files

// Library module: fs
// Single disposal event - auto-discharge should work

const std = @import("std");

const File = struct { handle: i32 };

// Open a file - returns opened! state (requires cleanup)
~pub event open { path: []const u8 }
| opened *File[opened!]

~proc open {
    std.debug.print("Opening file: {s}\n", .{path});
    const f = std.heap.page_allocator.create(File) catch unreachable;
    f.* = File{ .handle = 42 };
    return .{ .opened = f };
}

// Close - the ONLY consumer of [!opened]
~pub event close { file: *File[!opened] }
| closed

~proc close {
    std.debug.print("Closing file\n", .{});
    return .{ .closed = .{} };
}
fs.kz

Test Configuration

MUST_RUN