zig

fork of https://codeberg.org/ziglang/zig
Log | Files | Refs | README | LICENSE

commit 6c71e9a54da068202794c309e895b3f9ccfeb161 (tree)
parent cf9200b81594071d6378df2294da1c737c780c05
Author: Andrew Kelley <superjoe30@gmail.com>
Date:   Mon, 17 Sep 2018 18:44:45 -0400

fix crash when bit shifting a u1

Diffstat:
Msrc/ir.cpp | 6++++++
Mtest/cases/eval.zig | 5+++++
2 files changed, 11 insertions(+), 0 deletions(-)

diff --git a/src/ir.cpp b/src/ir.cpp @@ -12070,6 +12070,12 @@ static ZigType *ir_analyze_bit_shift(IrAnalyze *ira, IrInstructionBinOp *bin_op_ ir_add_error(ira, &bin_op_instruction->base, buf_sprintf("LHS of shift must be an integer type, or RHS must be compile-time known")); return ira->codegen->builtin_types.entry_invalid; + } else if (instr_is_comptime(casted_op2) && bigint_cmp_zero(&casted_op2->value.data.x_bigint) == CmpEQ) { + IrInstruction *result = ir_build_cast(&ira->new_irb, bin_op_instruction->base.scope, + bin_op_instruction->base.source_node, op1->value.type, op1, CastOpNoop); + result->value.type = op1->value.type; + ir_link_new_instruction(result, &bin_op_instruction->base); + return result->value.type; } ir_build_bin_op_from(&ira->new_irb, &bin_op_instruction->base, op_id, diff --git a/test/cases/eval.zig b/test/cases/eval.zig @@ -688,3 +688,8 @@ test "zero extend from u0 to u1" { var zero_u1: u1 = zero_u0; assert(zero_u1 == 0); } + +test "bit shift a u1" { + var x: u1 = 1; + var y = x << 0; +}