aboutsummaryrefslogtreecommitdiff
path: root/src/debug.c
diff options
context:
space:
mode:
authorKimplul <kimi.h.kuparinen@gmail.com>2025-01-04 01:25:31 +0200
committerKimplul <kimi.h.kuparinen@gmail.com>2025-01-04 01:25:31 +0200
commitaec19e55ca32f68536a550f100d3f058b8a93c02 (patch)
treec876d205fa9867aca8b7bb8c072635e2cf876205 /src/debug.c
parent718784ca20b8cb49aec438daecc846f273971793 (diff)
downloadfwd-aec19e55ca32f68536a550f100d3f058b8a93c02.tar.gz
fwd-aec19e55ca32f68536a550f100d3f058b8a93c02.zip
initial move checking
+ Missing implementations for most things, but it already highlights an oversight in my initial plan, namely that currently, a function might call multiple of its closures, meaning that a closure wouldn't be allowed to move a value. I'm debating whether to check that only one closure from a parameter list is called at a time or if I should do what Hylo does and add in some kind of 'subscript' that's like a function but has slightly different rules?
Diffstat (limited to 'src/debug.c')
-rw-r--r--src/debug.c6
1 files changed, 6 insertions, 0 deletions
diff --git a/src/debug.c b/src/debug.c
index cd0b8eb..f72fe9b 100644
--- a/src/debug.c
+++ b/src/debug.c
@@ -144,6 +144,12 @@ void type_mismatch(struct scope *scope, struct ast *node,
free((void *)rs);
}
+void move_error(struct ast *new_use, struct ast *prev_use)
+{
+ semantic_error(new_use->scope, new_use, "using moved value");
+ semantic_info(prev_use->scope, prev_use, "previously moved here");
+}
+
static void _type_str(FILE *f, struct type *t);
static void _type_list_str(FILE *f, struct type *types)