mirror of
https://github.com/ziglang/zig.git
synced 2025-12-08 15:23:14 +00:00
Conflicts:
* doc/langref.html.in
* lib/std/enums.zig
* lib/std/fmt.zig
* lib/std/hash/auto_hash.zig
* lib/std/math.zig
* lib/std/mem.zig
* lib/std/meta.zig
* test/behavior/alignof.zig
* test/behavior/bitcast.zig
* test/behavior/bugs/1421.zig
* test/behavior/cast.zig
* test/behavior/ptrcast.zig
* test/behavior/type_info.zig
* test/behavior/vector.zig
Master branch added `try` to a bunch of testing function calls, and some
lines also had changed how to refer to the native architecture and other
`@import("builtin")` stuff.
31 lines
646 B
Zig
31 lines
646 B
Zig
const expect = @import("std").testing.expect;
|
|
|
|
var read_count: u64 = 0;
|
|
|
|
fn readOnce() anyerror!u64 {
|
|
read_count += 1;
|
|
return read_count;
|
|
}
|
|
|
|
const FormValue = union(enum) {
|
|
Address: u64,
|
|
Other: bool,
|
|
};
|
|
|
|
fn doThing(form_id: u64) anyerror!FormValue {
|
|
return switch (form_id) {
|
|
17 => FormValue{ .Address = try readOnce() },
|
|
else => error.InvalidDebugInfo,
|
|
};
|
|
}
|
|
|
|
test "switch prong returns error enum" {
|
|
switch (doThing(17) catch unreachable) {
|
|
FormValue.Address => |payload| {
|
|
try expect(payload == 1);
|
|
},
|
|
else => unreachable,
|
|
}
|
|
try expect(read_count == 1);
|
|
}
|