Commit b99dbb6fb5

David Rubin <daviru007@icloud.com>
2024-12-27 13:19:50
Value: implement `orderAgainstZeroInner` for errors
1 parent 01081cc
Changed files (2)
src
test
src/Value.zig
@@ -1066,6 +1066,7 @@ pub fn orderAgainstZeroInner(
             .float => |float| switch (float.storage) {
                 inline else => |x| std.math.order(x, 0),
             },
+            .err => .gt, // error values cannot be 0
             else => unreachable,
         },
     };
test/behavior/switch_loop.zig
@@ -74,6 +74,31 @@ test "switch loop on enum" {
     try comptime S.doTheTest();
 }
 
+test "switch loop with error set" {
+    if (builtin.zig_backend == .stage2_wasm) return error.SkipZigTest; // TODO
+    if (builtin.zig_backend == .stage2_aarch64) return error.SkipZigTest; // TODO
+    if (builtin.zig_backend == .stage2_arm) return error.SkipZigTest; // TODO
+    if (builtin.zig_backend == .stage2_sparc64) return error.SkipZigTest; // TODO
+    if (builtin.zig_backend == .stage2_spirv64) return error.SkipZigTest; // TODO
+
+    const S = struct {
+        const E = error{ Foo, Bar, Baz };
+
+        fn doTheTest() !void {
+            var start: E = undefined;
+            start = error.Foo;
+            const result: u32 = s: switch (start) {
+                error.Foo => continue :s error.Bar,
+                error.Bar => continue :s error.Baz,
+                error.Baz => 123,
+            };
+            try expect(result == 123);
+        }
+    };
+    try S.doTheTest();
+    try comptime S.doTheTest();
+}
+
 test "switch loop on tagged union" {
     if (builtin.zig_backend == .stage2_wasm) return error.SkipZigTest; // TODO
     if (builtin.zig_backend == .stage2_aarch64) return error.SkipZigTest; // TODO