commit 9b5586ab7cd18d49dfe6d6dbdfbce39941bd3093 (tree)
parent f5239677e27a25beb450d2361fb15987d56de053
Author: Evan Haas <evan@lagerdata.com>
Date: Sat, 29 Jul 2023 10:30:18 -0700
add behavior test for vector bitcast at comptime
closes #8184
Diffstat:
1 file changed, 25 insertions(+), 0 deletions(-)
diff --git a/test/behavior/vector.zig b/test/behavior/vector.zig
@@ -1440,3 +1440,28 @@ test "boolean vector with 2 or more booleans" {
const vec2 = @Vector(3, bool){ true, true, true };
_ = vec2;
}
+
+test "bitcast to vector with different child type" {
+ 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_wasm) return error.SkipZigTest; // TODO
+ if (builtin.zig_backend == .stage2_x86_64) 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 {
+ fn doTheTest() !void {
+ const VecA = @Vector(8, u16);
+ const VecB = @Vector(4, u32);
+
+ var vec_a = VecA{ 1, 1, 1, 1, 1, 1, 1, 1 };
+ var vec_b: VecB = @bitCast(vec_a);
+ var vec_c: VecA = @bitCast(vec_b);
+ try expectEqual(vec_a, vec_c);
+ }
+ };
+
+ // Originally reported at https://github.com/ziglang/zig/issues/8184
+ try S.doTheTest();
+ try comptime S.doTheTest();
+}