Przeglądaj źródła

Merge pull request #4608 from zen3ger/assignment-of-non-specialized-parapoly

Fix crash on assignment of parapoly proc to variable
gingerBill 7 miesięcy temu
rodzic
commit
bfbcc02aff
1 zmienionych plików z 6 dodań i 4 usunięć
  1. 6 4
      src/check_decl.cpp

+ 6 - 4
src/check_decl.cpp

@@ -94,12 +94,14 @@ gb_internal Type *check_init_variable(CheckerContext *ctx, Entity *e, Operand *o
 				return nullptr;
 			}
 			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));
-				e->type = t_invalid;
+				e->type = t;
 				return nullptr;
 			}
+			gbString str = type_to_string(t);
+			defer (gb_string_free(str));
+			error(operand->expr, "Invalid use of a non-specialized polymorphic type '%s' in %.*s", str, LIT(context_name));
+			e->type = t_invalid;
+			return nullptr;
 		} else if (is_type_empty_union(t)) {
 			gbString str = type_to_string(t);
 			defer (gb_string_free(str));