diff options
| author | Ginger Bill <bill@gingerbill.org> | 2017-07-18 16:02:01 +0100 |
|---|---|---|
| committer | Ginger Bill <bill@gingerbill.org> | 2017-07-18 16:02:01 +0100 |
| commit | 5af0acc4aff068f2afaa4366518ed6ac8c97e61a (patch) | |
| tree | e03bb6fe5a89972ed71c3ec5187ffd26b686be88 /src | |
| parent | a459364de37353a4a7a4bf77cc68bfdbd6b7fbc3 (diff) | |
Disallow default struct values for `any`; `new_clone`
Diffstat (limited to 'src')
| -rw-r--r-- | src/check_expr.cpp | 8 |
1 files changed, 5 insertions, 3 deletions
diff --git a/src/check_expr.cpp b/src/check_expr.cpp index e4f21704f..580ccecaa 100644 --- a/src/check_expr.cpp +++ b/src/check_expr.cpp @@ -887,7 +887,11 @@ void check_record_field_decl(Checker *c, AstNode *decl, Array<Entity *> *fields, } else if (is_operand_undef(a)) { e->Variable.default_is_undef = true; } else if (b.mode != Addressing_Constant) { - error(b.expr, "Default field parameter must be a constant"); + error(b.expr, "Default field value must be a constant"); + } else if (is_type_any(e->type)) { + gbString str = type_to_string(e->type); + error(b.expr, "A struct field of type `%s` cannot have a default value", str); + gb_string_free(str); } else { e->Variable.default_value = b.value; } @@ -900,8 +904,6 @@ void check_record_field_decl(Checker *c, AstNode *decl, Array<Entity *> *fields, if (is_blank_ident(name_token)) { array_add(fields, e); - } else if (name_token.string == "__tag") { - error(name, "`__tag` is a reserved identifier for fields"); } else { HashKey key = hash_string(name_token.string); Entity **found = map_get(entity_map, key); |