From 3a05a2e562f59768eea8e2c0dacb77c4247cea1b Mon Sep 17 00:00:00 2001 From: gingerBill Date: Mon, 17 Dec 2018 13:12:48 +0000 Subject: Fix `not` for bit sets --- src/ir_print.cpp | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) (limited to 'src/ir_print.cpp') diff --git a/src/ir_print.cpp b/src/ir_print.cpp index 457fc57a7..74da92bf0 100644 --- a/src/ir_print.cpp +++ b/src/ir_print.cpp @@ -1609,7 +1609,7 @@ void ir_print_instr(irFileBuffer *f, irModule *m, irValue *value) { case irInstr_UnaryOp: { irInstrUnaryOp *uo = &value->Instr.UnaryOp; - Type *type = base_type(ir_type(uo->expr)); + Type *type = base_type(ir_type(uo->expr)); Type *elem_type = type; ir_fprintf(f, "%%%d = ", value->index); @@ -1623,7 +1623,7 @@ void ir_print_instr(irFileBuffer *f, irModule *m, irValue *value) { break; case Token_Xor: case Token_Not: - GB_ASSERT(is_type_integer(type) || is_type_boolean(type)); + GB_ASSERT(is_type_integer(type) || is_type_boolean(type) || is_type_bit_set(type)); ir_write_str_lit(f, "xor"); break; default: @@ -1644,7 +1644,7 @@ void ir_print_instr(irFileBuffer *f, irModule *m, irValue *value) { break; case Token_Xor: case Token_Not: - GB_ASSERT(is_type_integer(type) || is_type_boolean(type)); + GB_ASSERT(is_type_integer(type) || is_type_boolean(type) || is_type_bit_set(type)); ir_write_str_lit(f, "-1"); break; } -- cgit v1.2.3