From 64e9b0ee4673bf79d42ea14e354b324308f90b93 Mon Sep 17 00:00:00 2001 From: Andrew Kelley Date: Sun, 25 Aug 2019 20:27:56 -0400 Subject: make the zero-bit-ness of pointers lazy this case works now: ```zig const Foo = struct { field: @typeOf(func).ReturnType, }; fn func(self: *Foo) void {} ``` --- src/ir.cpp | 12 ++++++------ 1 file changed, 6 insertions(+), 6 deletions(-) (limited to 'src/ir.cpp') diff --git a/src/ir.cpp b/src/ir.cpp index 558dbca265..3aabb4995f 100644 --- a/src/ir.cpp +++ b/src/ir.cpp @@ -25582,12 +25582,12 @@ static Error ir_resolve_lazy_raw(CodeGen *codegen, AstNode *source_node, ConstEx } } - ResolveStatus needed_status = (align_bytes == 0) ? - ResolveStatusZeroBitsKnown : ResolveStatusAlignmentKnown; - if ((err = type_resolve(codegen, elem_type, needed_status))) - return err; - if (!type_has_bits(elem_type)) - align_bytes = 0; + if (align_bytes != 0) { + if ((err = type_resolve(codegen, elem_type, ResolveStatusAlignmentKnown))) + return err; + if (!type_has_bits(elem_type)) + align_bytes = 0; + } bool allow_zero = lazy_ptr_type->is_allowzero || lazy_ptr_type->ptr_len == PtrLenC; assert(val->type->id == ZigTypeIdMetaType); val->data.x_type = get_pointer_to_type_extra(codegen, elem_type, -- cgit v1.2.3