aboutsummaryrefslogtreecommitdiff
path: root/src/parse
diff options
context:
space:
mode:
Diffstat (limited to 'src/parse')
-rw-r--r--src/parse/containers.c2
-rw-r--r--src/parse/types.c5
2 files changed, 3 insertions, 4 deletions
diff --git a/src/parse/containers.c b/src/parse/containers.c
index 73d30ecd..c6362623 100644
--- a/src/parse/containers.c
+++ b/src/parse/containers.c
@@ -50,7 +50,7 @@ ast_t *parse_table(parse_ctx_t *ctx, const char *pos) {
ast_t *key = optional(ctx, &pos, parse_extended_expr);
if (!key) break;
whitespace(ctx, &pos);
- if (!match(&pos, "=")) return NULL;
+ if (!match(&pos, ":")) return NULL;
ast_t *value = expect(ctx, pos - 1, &pos, parse_expr, "I couldn't parse the value for this table entry");
ast_t *entry = NewAST(ctx->file, entry_start, pos, TableEntry, .key = key, .value = value);
ast_t *suffixed = parse_comprehension_suffix(ctx, entry);
diff --git a/src/parse/types.c b/src/parse/types.c
index ffb7d869..987be7a1 100644
--- a/src/parse/types.c
+++ b/src/parse/types.c
@@ -23,15 +23,14 @@ type_ast_t *parse_table_type(parse_ctx_t *ctx, const char *pos) {
pos = key_type->end;
whitespace(ctx, &pos);
type_ast_t *value_type = NULL;
- if (match(&pos, "=")) {
+ if (match(&pos, ":")) {
value_type = expect(ctx, start, &pos, parse_type, "I couldn't parse the rest of this table type");
} else {
return NULL;
}
spaces(&pos);
ast_t *default_value = NULL;
- if (match(&pos, ";") && match_word(&pos, "default")) {
- expect_str(ctx, pos, &pos, "=", "I expected an '=' here");
+ if (match(&pos, "=")) {
default_value =
expect(ctx, start, &pos, parse_extended_expr, "I couldn't parse the default value for this table");
}