commit aa60d2a688c965dcccf8e2c42afe5c180daba8fc (tree)
parent 7c5ceb0c4cdf5fafadd92b13048bc9878554abc4
Author: Jimmi HC <jimmiholstchristensen@gmail.com>
Date: Sun, 16 Jun 2019 02:10:06 +0200
fixes resolving aligment of child type in slice
Diffstat:
3 files changed, 9 insertions(+), 1 deletion(-)
diff --git a/src/ir.cpp b/src/ir.cpp
@@ -16794,7 +16794,7 @@ static IrInstruction *ir_analyze_instruction_slice_type(IrAnalyze *ira,
case ZigTypeIdPromise:
case ZigTypeIdVector:
{
- if ((err = type_resolve(ira->codegen, child_type, ResolveStatusZeroBitsKnown)))
+ if ((err = type_resolve(ira->codegen, child_type, ResolveStatusAlignmentKnown)))
return ira->codegen->invalid_instruction;
ZigType *slice_ptr_type = get_pointer_to_type_extra(ira->codegen, child_type,
is_const, is_volatile, PtrLenUnknown, align_bytes, 0, 0, is_allow_zero);
diff --git a/test/stage1/behavior.zig b/test/stage1/behavior.zig
@@ -27,6 +27,7 @@ comptime {
_ = @import("behavior/bugs/2114.zig");
_ = @import("behavior/bugs/2346.zig");
_ = @import("behavior/bugs/2578.zig");
+ _ = @import("behavior/bugs/2689.zig");
_ = @import("behavior/bugs/394.zig");
_ = @import("behavior/bugs/421.zig");
_ = @import("behavior/bugs/529.zig");
diff --git a/test/stage1/behavior/bugs/2689.zig b/test/stage1/behavior/bugs/2689.zig
@@ -0,0 +1,7 @@
+test "slice with alignment" {
+ const S = packed struct {
+ a: u8,
+ };
+
+ var a: []align(8) S = undefined;
+}