123 lines
2.1 KiB
Zig
123 lines
2.1 KiB
Zig
pub fn foo() -> %i32 {
|
|
const x = %return bar();
|
|
return x + 1
|
|
}
|
|
|
|
pub fn bar() -> %i32 {
|
|
return 13;
|
|
}
|
|
|
|
pub fn baz() -> %i32 {
|
|
const y = foo() %% 1234;
|
|
return y + 1;
|
|
}
|
|
|
|
fn errorWrapping() {
|
|
@setFnTest(this);
|
|
|
|
assert(%%baz() == 15);
|
|
}
|
|
|
|
error ItBroke;
|
|
fn gimmeItBroke() -> []const u8 {
|
|
@errorName(error.ItBroke)
|
|
}
|
|
|
|
fn errorName() {
|
|
@setFnTest(this);
|
|
assert(memeql(@errorName(error.AnError), "AnError"));
|
|
assert(memeql(@errorName(error.ALongerErrorName), "ALongerErrorName"));
|
|
}
|
|
error AnError;
|
|
error ALongerErrorName;
|
|
|
|
|
|
fn errorValues() {
|
|
@setFnTest(this);
|
|
|
|
const a = i32(error.err1);
|
|
const b = i32(error.err2);
|
|
assert(a != b);
|
|
}
|
|
error err1;
|
|
error err2;
|
|
|
|
|
|
fn redefinitionOfErrorValuesAllowed() {
|
|
@setFnTest(this);
|
|
|
|
shouldBeNotEqual(error.AnError, error.SecondError);
|
|
}
|
|
error AnError;
|
|
error AnError;
|
|
error SecondError;
|
|
fn shouldBeNotEqual(a: error, b: error) {
|
|
if (a == b) @unreachable()
|
|
}
|
|
|
|
|
|
fn errBinaryOperator() {
|
|
@setFnTest(this);
|
|
|
|
const a = errBinaryOperatorG(true) %% 3;
|
|
const b = errBinaryOperatorG(false) %% 3;
|
|
assert(a == 3);
|
|
assert(b == 10);
|
|
}
|
|
error ItBroke;
|
|
fn errBinaryOperatorG(x: bool) -> %isize {
|
|
if (x) {
|
|
error.ItBroke
|
|
} else {
|
|
isize(10)
|
|
}
|
|
}
|
|
|
|
|
|
fn unwrapSimpleValueFromError() {
|
|
@setFnTest(this);
|
|
|
|
const i = %%unwrapSimpleValueFromErrorDo();
|
|
assert(i == 13);
|
|
}
|
|
fn unwrapSimpleValueFromErrorDo() -> %isize { 13 }
|
|
|
|
|
|
fn errReturnInAssignment() {
|
|
@setFnTest(this);
|
|
|
|
%%doErrReturnInAssignment();
|
|
}
|
|
|
|
fn doErrReturnInAssignment() -> %void {
|
|
var x : i32 = undefined;
|
|
x = %return makeANonErr();
|
|
}
|
|
|
|
fn makeANonErr() -> %i32 {
|
|
return 1;
|
|
}
|
|
|
|
|
|
|
|
// TODO const assert = @import("std").debug.assert;
|
|
fn assert(ok: bool) {
|
|
if (!ok)
|
|
@unreachable();
|
|
}
|
|
|
|
// TODO import from std.str
|
|
pub fn memeql(a: []const u8, b: []const u8) -> bool {
|
|
sliceEql(u8, a, b)
|
|
}
|
|
|
|
// TODO import from std.str
|
|
pub fn sliceEql(inline T: type, a: []const T, b: []const T) -> bool {
|
|
if (a.len != b.len) return false;
|
|
for (a) |item, index| {
|
|
if (b[index] != item) return false;
|
|
}
|
|
return true;
|
|
}
|
|
|