aboutsummaryrefslogtreecommitdiff
path: root/typecheck.c
diff options
context:
space:
mode:
Diffstat (limited to 'typecheck.c')
-rw-r--r--typecheck.c11
1 files changed, 10 insertions, 1 deletions
diff --git a/typecheck.c b/typecheck.c
index 2d212f76..ced1f028 100644
--- a/typecheck.c
+++ b/typecheck.c
@@ -374,7 +374,16 @@ type_t *get_type(env_t *env, ast_t *ast)
code_err(ast, "Table entries should not be typechecked directly");
}
case Comprehension: {
- code_err(ast, "Comprehensions should not be typechecked directly");
+ auto comp = Match(ast, Comprehension);
+ env_t *scope = for_scope(env, FakeAST(For, .iter=comp->iter, .index=comp->key, .value=comp->value));
+ if (comp->expr->tag == Comprehension) {
+ return get_type(scope, comp->expr);
+ } else if (comp->expr->tag == TableEntry) {
+ auto e = Match(comp->expr, TableEntry);
+ return Type(TableType, .key_type=get_type(scope, e->key), .value_type=get_type(scope, e->value));
+ } else {
+ return Type(ArrayType, .item_type=get_type(scope, comp->expr));
+ }
}
case FieldAccess: {
auto access = Match(ast, FieldAccess);