aboutsummaryrefslogtreecommitdiff
path: root/src/ir.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'src/ir.cpp')
-rw-r--r--src/ir.cpp18
1 files changed, 11 insertions, 7 deletions
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);
}
}