diff options
Diffstat (limited to 'src/check_expr.cpp')
| -rw-r--r-- | src/check_expr.cpp | 22 |
1 files changed, 22 insertions, 0 deletions
diff --git a/src/check_expr.cpp b/src/check_expr.cpp index 215299f96..ba182db3f 100644 --- a/src/check_expr.cpp +++ b/src/check_expr.cpp @@ -4081,6 +4081,13 @@ Entity *check_selector(Checker *c, Operand *operand, AstNode *node, Type *type_h String op_name = op_expr->Ident.token.string; Entity *e = scope_lookup_entity(c->context.scope, op_name); + bool is_alias = false; + while (e->kind == Entity_Alias) { + GB_ASSERT(e->Alias.base != nullptr); + e = e->Alias.base; + is_alias = true; + } + add_entity_use(c, op_expr, e); expr_entity = e; @@ -4111,9 +4118,24 @@ Entity *check_selector(Checker *c, Operand *operand, AstNode *node, Type *type_h operand->expr = node; return nullptr; } + + + bool is_alias = false; + while (entity->kind == Entity_Alias) { + GB_ASSERT(e->Alias.base != nullptr); + entity = entity->Alias.base; + is_alias = true; + } + check_entity_decl(c, entity, nullptr, nullptr); GB_ASSERT(entity->type != nullptr); + if (is_alias) { + // TODO(bill): Which scope do you search for for an alias? + // import_scope = entity->scope; + entity_name = entity->token.string; + } + isize overload_count = entity_overload_count(import_scope, entity_name); bool is_overloaded = overload_count > 1; |