mirror of
https://github.com/ziglang/zig.git
synced 2025-12-06 06:13:07 +00:00
langref: add example for errdefer |err| sytnax
This commit is contained in:
parent
aa73bb6bc9
commit
8267929742
@ -2992,6 +2992,10 @@ fn createFoo(param: i32) !Foo {
|
||||
the verbosity and cognitive overhead of trying to make sure every exit path
|
||||
is covered. The deallocation code is always directly following the allocation code.
|
||||
</p>
|
||||
<p>
|
||||
The {#syntax#}errdefer{#endsyntax#} statement can optionally capture the error:
|
||||
</p>
|
||||
{#code|test_errdefer_capture.zig#}
|
||||
{#header_close#}
|
||||
{#header_open|Common errdefer Slip-Ups#}
|
||||
<p>
|
||||
|
||||
19
doc/langref/test_errdefer_capture.zig
Normal file
19
doc/langref/test_errdefer_capture.zig
Normal file
@ -0,0 +1,19 @@
|
||||
const std = @import("std");
|
||||
|
||||
fn captureError(captured: *?anyerror) !void {
|
||||
errdefer |err| {
|
||||
captured.* = err;
|
||||
}
|
||||
return error.GeneralFailure;
|
||||
}
|
||||
|
||||
test "errdefer capture" {
|
||||
var captured: ?anyerror = null;
|
||||
|
||||
if (captureError(&captured)) unreachable else |err| {
|
||||
try std.testing.expectEqual(error.GeneralFailure, captured.?);
|
||||
try std.testing.expectEqual(error.GeneralFailure, err);
|
||||
}
|
||||
}
|
||||
|
||||
// test
|
||||
Loading…
x
Reference in New Issue
Block a user