3671582c15
The purpose of this is: * Only one way to do things * Changing a function with void return type to return a possible error becomes a 1 character change, subtly encouraging people to use errors. See #632 Here are some imperfect sed commands for performing this update: remove arrow: ``` sed -i 's/\(\bfn\b.*\)-> /\1/g' $(find . -name "*.zig") ``` add void: ``` sed -i 's/\(\bfn\b.*\))\s*{/\1) void {/g' $(find ../ -name "*.zig") ``` Some cleanup may be necessary, but this should do the bulk of the work.
28 lines
728 B
Zig
28 lines
728 B
Zig
const assert = @import("std").debug.assert;
|
|
const mem = @import("std").mem;
|
|
const fmt = @import("std").fmt;
|
|
|
|
const ET = union(enum) {
|
|
SINT: i32,
|
|
UINT: u32,
|
|
|
|
pub fn print(a: &const ET, buf: []u8) %usize {
|
|
return switch (*a) {
|
|
ET.SINT => |x| fmt.formatIntBuf(buf, x, 10, false, 0),
|
|
ET.UINT => |x| fmt.formatIntBuf(buf, x, 10, false, 0),
|
|
};
|
|
}
|
|
};
|
|
|
|
test "enum with members" {
|
|
const a = ET { .SINT = -42 };
|
|
const b = ET { .UINT = 42 };
|
|
var buf: [20]u8 = undefined;
|
|
|
|
assert((a.print(buf[0..]) catch unreachable) == 3);
|
|
assert(mem.eql(u8, buf[0..3], "-42"));
|
|
|
|
assert((b.print(buf[0..]) catch unreachable) == 2);
|
|
assert(mem.eql(u8, buf[0..2], "42"));
|
|
}
|