aboutsummaryrefslogtreecommitdiff
path: root/src/check_decl.cpp
diff options
context:
space:
mode:
authorgingerBill <gingerBill@users.noreply.github.com>2024-10-23 15:25:06 +0100
committerGitHub <noreply@github.com>2024-10-23 15:25:06 +0100
commit33cc6713028b1bebfb3b023faad88795761a6276 (patch)
treeaf16ac9463351486c00cc18351e6f0c581bf0293 /src/check_decl.cpp
parentc5ae7daecd1fe027b1540f46c07d5c06950875e3 (diff)
parent01c7380df8b2c42da103ce93e0bd8631ace8ad12 (diff)
Merge pull request #4403 from tf2spi/issue-4390-fix
Fix #4390 by assigning invalid entity type
Diffstat (limited to 'src/check_decl.cpp')
-rw-r--r--src/check_decl.cpp7
1 files changed, 4 insertions, 3 deletions
diff --git a/src/check_decl.cpp b/src/check_decl.cpp
index 0cc89435d..60eb030ff 100644
--- a/src/check_decl.cpp
+++ b/src/check_decl.cpp
@@ -88,11 +88,12 @@ gb_internal Type *check_init_variable(CheckerContext *ctx, Entity *e, Operand *o
e->type = t_invalid;
return nullptr;
} else if (is_type_polymorphic(t)) {
- Entity *e = entity_of_node(operand->expr);
- if (e == nullptr) {
+ Entity *e2 = entity_of_node(operand->expr);
+ if (e2 == nullptr) {
+ e->type = t_invalid;
return nullptr;
}
- if (e->state.load() != EntityState_Resolved) {
+ if (e2->state.load() != EntityState_Resolved) {
gbString str = type_to_string(t);
defer (gb_string_free(str));
error(e->token, "Invalid use of a polymorphic type '%s' in %.*s", str, LIT(context_name));