From 3306e43984a8b17472ecc4b13a2f2815d6630eef Mon Sep 17 00:00:00 2001 From: Andrew Kelley Date: Sun, 24 Mar 2019 18:51:24 -0400 Subject: add compile error test for invalid enum literal implicit cast See #683 --- src/ir.cpp | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) (limited to 'src/ir.cpp') diff --git a/src/ir.cpp b/src/ir.cpp index 58db315665..46fb86e33f 100644 --- a/src/ir.cpp +++ b/src/ir.cpp @@ -11601,8 +11601,10 @@ static IrInstruction *ir_analyze_cast(IrAnalyze *ira, IrInstruction *source_inst TypeEnumField *field = find_enum_type_field(wanted_type, value->value.data.x_enum_literal); if (field == nullptr) { - ir_add_error(ira, source_instr, buf_sprintf("enum '%s' has no field named '%s'", + ErrorMsg *msg = ir_add_error(ira, source_instr, buf_sprintf("enum '%s' has no field named '%s'", buf_ptr(&wanted_type->name), buf_ptr(value->value.data.x_enum_literal))); + add_error_note(ira->codegen, msg, wanted_type->data.enumeration.decl_node, + buf_sprintf("'%s' declared here", buf_ptr(&wanted_type->name))); return ira->codegen->invalid_instruction; } IrInstruction *result = ir_const(ira, source_instr, wanted_type); -- cgit v1.2.3