From c949ca2a5c8fe18fd965bd294454243c683a042c Mon Sep 17 00:00:00 2001 From: Ginger Bill Date: Mon, 26 Jun 2017 18:20:24 +0100 Subject: Allow for named arguments for polymorphic procedures --- src/ir.cpp | 18 +++++++++++------- 1 file changed, 11 insertions(+), 7 deletions(-) (limited to 'src/ir.cpp') diff --git a/src/ir.cpp b/src/ir.cpp index d5fc33174..e0ca61522 100644 --- a/src/ir.cpp +++ b/src/ir.cpp @@ -4680,15 +4680,19 @@ irValue *ir_build_expr(irProcedure *proc, AstNode *expr) { TypeTuple *pt = &type->params->Tuple; for (isize i = 0; i < param_count; i++) { Entity *e = pt->variables[i]; - GB_ASSERT(e->kind == Entity_Variable); - if (args[i] == NULL) { - if (e->Variable.default_value.kind != ExactValue_Invalid) { - args[i] = ir_value_constant(proc->module->allocator, e->type, e->Variable.default_value); + if (e->kind == Entity_TypeName) { + args[i] = ir_value_nil(proc->module->allocator, e->type); + } else { + GB_ASSERT(e->kind == Entity_Variable); + if (args[i] == NULL) { + if (e->Variable.default_value.kind != ExactValue_Invalid) { + args[i] = ir_value_constant(proc->module->allocator, e->type, e->Variable.default_value); + } else { + args[i] = ir_value_nil(proc->module->allocator, e->type); + } } else { - args[i] = ir_value_nil(proc->module->allocator, e->type); + args[i] = ir_emit_conv(proc, args[i], e->type); } - } else { - args[i] = ir_emit_conv(proc, args[i], e->type); } } -- cgit v1.2.3