Rename all example tests/companions to the XXXX-category-test-name scheme (per-category 100-blocks: basic 0010, types 0100, ... errors 1000, diagnostics 1100, ffi 1200, ffi-objc 1300, ffi-jni 1400, vectors 1500, platform 1600). Companions and dir/C fixtures move in lockstep with their parent test; #import/#source/#include paths rewritten to match. Expected output now lives in examples/expected/ (a sibling dir of the tests) split into three streams per the new convention: <name>.exit / <name>.stdout / <name>.stderr (+ optional <name>.ir) run_examples.sh rewritten: scans examples/ and issues/ for an expected/<name>.exit marker, captures stdout and stderr separately (no more 2>&1), compares each stream + exit + optional IR snapshot. Behavior validated unchanged: every renamed test reproduces its prior merged output + exit (diffs limited to file paths/basenames embedded in diagnostics + traces, which correctly reflect the new names). Suite: 292 passed, 0 failed. 50-smoke.sx split + issue relocation + docs follow in subsequent commits.
40 lines
1.2 KiB
Plaintext
40 lines
1.2 KiB
Plaintext
// Range-based for loops: `for start..end: (i) { }` (cursor optional, `end`
|
|
// exclusive) is a runtime counting loop; `inline for start..end: (i) { }`
|
|
// is comptime-unrolled — the cursor is a compile-time constant each
|
|
// iteration, so `xs[i]` over a heterogeneous pack substitutes the concrete
|
|
// per-position element (this is what drives pack iteration).
|
|
|
|
#import "modules/std.sx";
|
|
|
|
Show :: protocol {
|
|
show :: () -> string;
|
|
}
|
|
A :: struct { x: s64; }
|
|
B :: struct { s: string; }
|
|
impl Show for A { show :: (self: *A) -> string => "A"; }
|
|
impl Show for B { show :: (self: *B) -> string => "B"; }
|
|
|
|
// Comptime-unrolled iteration over a pack; cursor `i` indexes the pack.
|
|
each :: (..xs: Show) -> void {
|
|
inline for 0..xs.len: (i) {
|
|
print("[{}]={}\n", i, xs[i].show());
|
|
}
|
|
}
|
|
|
|
main :: () -> s32 {
|
|
// Runtime range, cursor used.
|
|
for 0..3: (i) { print("i={}\n", i); }
|
|
|
|
// Runtime range, no cursor — body runs `end - start` times.
|
|
n := 0;
|
|
for 0..5 { n = n + 1; }
|
|
print("n={}\n", n);
|
|
|
|
// Non-zero start.
|
|
for 2..5: (j) { print("j={}\n", j); }
|
|
|
|
// Inline unroll over a heterogeneous pack.
|
|
each(A.{ x = 1 }, B.{ s = "hi" }, A.{ x = 3 });
|
|
0;
|
|
}
|