Files
sx/examples/packs/0541-packs-pack-to-protocol-tuple.sx
agra 40b5fb5f7e docs: tuple syntax cutover — Tuple(...) type, .(...) value, channel-outside-Tuple failables
Rewrite specs.md tuple/failable/pack/UFCS/grammar sections to the new
syntax, update readme.md, and refresh stale tuple references in example
header comments. Also fixes two pre-existing doc inaccuracies surfaced in
review: drop the value-discarding `;` in the tuple-return examples, and
correct the §13 function-type grammar production (optional param list +
optional trailing `!` channel). Optional semantics unchanged.

current/CHECKPOINT-LANG.md logs the cutover.
2026-06-25 18:41:22 +03:00

29 lines
1019 B
Plaintext

// Phase 6 — `c.sources = .(..sources)`: materialize a pack into a
// protocol-typed tuple field, erasing each concrete pack element to the field's
// protocol slot. The pack `..sources: VL` holds concrete cells; `.(..sources)`
// into a `Tuple(..VL(Ts))` field `xx`-erases each to its `VL(Ti)` value.
#import "modules/std.sx";
VL :: protocol(T: Type) { get :: (self: *Self) -> T; }
IntCell :: struct { v: i64; }
StrCell :: struct { s: string; }
impl VL(i64) for IntCell { get :: (self: *IntCell) -> i64 => self.v; }
impl VL(string) for StrCell { get :: (self: *StrCell) -> string => self.s; }
Combined :: struct($R: Type, ..$Ts: []Type) {
sources: Tuple(..VL(Ts));
value: $R;
}
build :: (..sources: VL) -> void {
c : Combined(i64, ..sources.T) = ---;
c.sources = .(..sources); // pack → tuple, per-element erase
print("{} {}\n", c.sources.0.get(), c.sources.1.get());
}
main :: () -> i32 {
build(IntCell.{ v = 10 }, StrCell.{ s = "hi" }); // 10 hi
0
}