aboutsummaryrefslogtreecommitdiff
path: root/src/ir.cpp
diff options
context:
space:
mode:
authorIsaac Hier <isaachier@gmail.com>2018-07-04 13:27:10 -0400
committerIsaac Hier <isaachier@gmail.com>2018-07-04 13:27:10 -0400
commit9cff23dbf9ff3da716a1c4397f9411eba09f6cac (patch)
treeebde3411341a755db5a13b13b9324dd99e8e0a51 /src/ir.cpp
parent9395162a7c41689bcd1c0c48f9eabffc1485fc74 (diff)
downloadzig-9cff23dbf9ff3da716a1c4397f9411eba09f6cac.tar.gz
zig-9cff23dbf9ff3da716a1c4397f9411eba09f6cac.zip
Fix assertion crash on enum switch values
Diffstat (limited to 'src/ir.cpp')
-rw-r--r--src/ir.cpp7
1 files changed, 6 insertions, 1 deletions
diff --git a/src/ir.cpp b/src/ir.cpp
index c16f3c09b8..37d673bbd7 100644
--- a/src/ir.cpp
+++ b/src/ir.cpp
@@ -19149,9 +19149,14 @@ static TypeTableEntry *ir_analyze_instruction_check_switch_prongs(IrAnalyze *ira
if (!end_val)
return ira->codegen->builtin_types.entry_invalid;
- printf("%s\n", buf_ptr(&start_val->type->name));
+ if (start_val->type->id == TypeTableEntryIdEnum)
+ return ira->codegen->builtin_types.entry_invalid;
assert(start_val->type->id == TypeTableEntryIdInt || start_val->type->id == TypeTableEntryIdComptimeInt);
+
+ if (end_val->type->id == TypeTableEntryIdEnum)
+ return ira->codegen->builtin_types.entry_invalid;
assert(end_val->type->id == TypeTableEntryIdInt || end_val->type->id == TypeTableEntryIdComptimeInt);
+
AstNode *prev_node = rangeset_add_range(&rs, &start_val->data.x_bigint, &end_val->data.x_bigint,
start_value->source_node);
if (prev_node != nullptr) {