diff options
| author | LemonBoy <thatlemon@gmail.com> | 2020-11-05 20:40:20 +0100 |
|---|---|---|
| committer | Andrew Kelley <andrew@ziglang.org> | 2020-11-05 17:24:04 -0500 |
| commit | 78840c4ab20d844ca866fa0ab437d72fdec62d0d (patch) | |
| tree | afd5ee223f3c9ec0a13b9fa621d43c62e66bf9f5 /src | |
| parent | f85d7199521290121ade4506ea53acdaf6284982 (diff) | |
| download | zig-78840c4ab20d844ca866fa0ab437d72fdec62d0d.tar.gz zig-78840c4ab20d844ca866fa0ab437d72fdec62d0d.zip | |
stage1: Make sure union(enum(T)) is valid
The T type should be wide enough to fit values in the 0...num field
range.
Closes #6988
Diffstat (limited to 'src')
| -rw-r--r-- | src/stage1/analyze.cpp | 16 |
1 files changed, 16 insertions, 0 deletions
diff --git a/src/stage1/analyze.cpp b/src/stage1/analyze.cpp index a013bb052c..45cd240949 100644 --- a/src/stage1/analyze.cpp +++ b/src/stage1/analyze.cpp @@ -3178,6 +3178,22 @@ static Error resolve_union_zero_bits(CodeGen *g, ZigType *union_type) { union_type->data.unionation.resolve_status = ResolveStatusInvalid; return ErrorSemanticAnalyzeFail; } + if (tag_int_type->id == ZigTypeIdInt) { + BigInt bi; + bigint_init_unsigned(&bi, field_count - 1); + if (!bigint_fits_in_bits(&bi, + tag_int_type->data.integral.bit_count, + tag_int_type->data.integral.is_signed)) + { + ErrorMsg *msg = add_node_error(g, enum_type_node, + buf_sprintf("specified integer tag type cannot represent every field")); + add_error_note(g, msg, enum_type_node, + buf_sprintf("type %s cannot fit values in range 0...%" PRIu32, + buf_ptr(&tag_int_type->name), field_count - 1)); + union_type->data.unionation.resolve_status = ResolveStatusInvalid; + return ErrorSemanticAnalyzeFail; + } + } } else { tag_int_type = get_smallest_unsigned_int_type(g, field_count - 1); } |
