(*x) binds x to a pointer into the collection (index_gep) instead of a per-element value copy: passing it on (e.g. to a *T param) is zero-copy and mutations write back. In a value position x auto-derefs — a binary-op operand loads the element, a pointer-typed slot keeps the pointer, and an 'if x == {...}' match derefs the pointee for its tag/payload. Arrays GEP through their storage so writes hit the original. Regression test: examples/for-by-ref-capture.sx.
26 lines
741 B
Plaintext
26 lines
741 B
Plaintext
// `for xs: (*x)` binds each element by pointer — no per-element copy.
|
|
// Mutations write back, and a pointer subject matches through the deref.
|
|
#import "modules/std.sx";
|
|
|
|
Shape :: enum {
|
|
circle: f32;
|
|
none;
|
|
}
|
|
|
|
main :: () -> s32 {
|
|
// By-ref mutation writes back into the array (impossible with a value copy).
|
|
xs : [3]s64 = .[1, 2, 3];
|
|
for xs: (*x) { x.* = x + 100; }
|
|
print("{} {} {}\n", xs[0], xs[1], xs[2]);
|
|
|
|
// Pointer subject matches through the deref; payload reads through the ref.
|
|
shapes : [2]Shape = .[.circle(2.0), .none];
|
|
for shapes: (*s) {
|
|
if s == {
|
|
case .circle: (r) { print("circle {}\n", r); }
|
|
case .none: { print("none\n"); }
|
|
}
|
|
}
|
|
0;
|
|
}
|