zig

fork of https://codeberg.org/ziglang/zig
Log | Files | Refs | README | LICENSE

commit 1cde0edff469fbe5ee62cb10a44161b4c9910f98 (tree)
parent fe28d732710b916695c6926a06aad0cc93156516
Author: Andrew Kelley <andrew@ziglang.org>
Date:   Mon, 18 May 2020 19:23:40 -0400

json: properly stringify error sets

I did this wrong originally in
feade9ef0010b1b47d7216e786ed964d09612c2b

Diffstat:
Mlib/std/json.zig | 4++--
1 file changed, 2 insertions(+), 2 deletions(-)

diff --git a/lib/std/json.zig b/lib/std/json.zig @@ -2434,7 +2434,6 @@ pub fn stringify( @compileError("Unable to stringify enum '" ++ @typeName(T) ++ "'"); }, - .ErrorSet => return out_stream.writeAll(@errorName(value)), .Union => { if (comptime std.meta.trait.hasFn("jsonStringify")(T)) { return value.jsonStringify(options, out_stream); @@ -2493,6 +2492,7 @@ pub fn stringify( try out_stream.writeByte('}'); return; }, + .ErrorSet => return stringify(@as([]const u8, @errorName(value)), options, out_stream), .Pointer => |ptr_info| switch (ptr_info.size) { .One => switch (@typeInfo(ptr_info.child)) { .Array => { @@ -2647,7 +2647,7 @@ test "stringify basic types" { try teststringify("42", @as(u128, 42), StringifyOptions{}); try teststringify("4.2e+01", @as(f32, 42), StringifyOptions{}); try teststringify("4.2e+01", @as(f64, 42), StringifyOptions{}); - try teststringify("ItBroke", @as(anyerror, error.ItBroke), StringifyOptions{}); + try teststringify("\"ItBroke\"", @as(anyerror, error.ItBroke), StringifyOptions{}); } test "stringify string" {