diff options
| author | Andrew Kelley <superjoe30@gmail.com> | 2018-02-28 00:29:20 -0500 |
|---|---|---|
| committer | Andrew Kelley <superjoe30@gmail.com> | 2018-02-28 00:29:20 -0500 |
| commit | 6568be575cb87c2f54aad2dfa20d1f35471d2224 (patch) | |
| tree | 88d5964a4281f5c814717023024676539576751d /src/analyze.cpp | |
| parent | 0f449a3ec180f710f8b54023d2c3b3dffcce5ec8 (diff) | |
| parent | 556f22a751e47d572404992befe15c09c0f2eb0b (diff) | |
| download | zig-6568be575cb87c2f54aad2dfa20d1f35471d2224.tar.gz zig-6568be575cb87c2f54aad2dfa20d1f35471d2224.zip | |
Merge branch 'bnoordhuis-fix795'
Diffstat (limited to 'src/analyze.cpp')
| -rw-r--r-- | src/analyze.cpp | 4 |
1 files changed, 3 insertions, 1 deletions
diff --git a/src/analyze.cpp b/src/analyze.cpp index c16a5d462a..45e6780791 100644 --- a/src/analyze.cpp +++ b/src/analyze.cpp @@ -997,7 +997,7 @@ TypeTableEntry *get_fn_type(CodeGen *g, FnTypeId *fn_type_id) { gen_param_info->src_index = i; gen_param_info->gen_index = SIZE_MAX; - ensure_complete_type(g, type_entry); + type_ensure_zero_bits_known(g, type_entry); if (type_has_bits(type_entry)) { TypeTableEntry *gen_type; if (handle_is_ptr(type_entry)) { @@ -2129,6 +2129,7 @@ static void resolve_enum_zero_bits(CodeGen *g, TypeTableEntry *enum_type) { if (enum_type->data.enumeration.zero_bits_loop_flag) { enum_type->data.enumeration.zero_bits_known = true; + enum_type->data.enumeration.zero_bits_loop_flag = false; return; } @@ -2283,6 +2284,7 @@ static void resolve_struct_zero_bits(CodeGen *g, TypeTableEntry *struct_type) { // the alignment is pointer width, then assert that the first field is within that // alignment struct_type->data.structure.zero_bits_known = true; + struct_type->data.structure.zero_bits_loop_flag = false; if (struct_type->data.structure.abi_alignment == 0) { if (struct_type->data.structure.layout == ContainerLayoutPacked) { struct_type->data.structure.abi_alignment = 1; |
