diff options
author | Dave Gauer <dave@ratfactor.com> | 2021-01-30 20:00:32 -0500 |
---|---|---|
committer | Dave Gauer <dave@ratfactor.com> | 2021-01-30 20:00:32 -0500 |
commit | 2de8a8c54d7090dd063bed8b6b283c2fcb452e43 (patch) | |
tree | 80c1fc20d0a171aef52d0fbd0ccaa99409b3e63f /23_errors3.zig | |
parent | 08ec029f20381580ebe76ad8bd3feca2e5cd262a (diff) | |
download | ziglings-2de8a8c54d7090dd063bed8b6b283c2fcb452e43.tar.gz ziglings-2de8a8c54d7090dd063bed8b6b283c2fcb452e43.tar.bz2 ziglings-2de8a8c54d7090dd063bed8b6b283c2fcb452e43.tar.xz ziglings-2de8a8c54d7090dd063bed8b6b283c2fcb452e43.zip |
Added ex 21-26 for error handling
Diffstat (limited to '23_errors3.zig')
-rw-r--r-- | 23_errors3.zig | 28 |
1 files changed, 28 insertions, 0 deletions
diff --git a/23_errors3.zig b/23_errors3.zig new file mode 100644 index 0000000..6060bf1 --- /dev/null +++ b/23_errors3.zig @@ -0,0 +1,28 @@ +// +// One way to deal with error unions is to "catch" any error and +// replace it with a default value. +// +// foo = canFail() catch 6; +// +// If canFail() fails, foo will equal 6. +// +const std = @import("std"); + +const MyNumberError = error{ TooSmall }; + +pub fn main() void { + var a: u32 = addTwenty(44) catch 22; + var b: u32 = addTwenty(4) ??? 22; + + std.debug.print("a={}, b={}", .{a,b}); +} + +// Please provide the return type from this function. +// Hint: it'll be an error union. +fn addTwenty(n: u32) ??? { + if (n < 5) { + return MyNumberError.TooSmall; + } else { + return n + 20; + } +} |