Using ForArrayRemovable

This commit is contained in:
Krzosa Karol
2023-04-02 12:12:21 +02:00
parent ad5c692506
commit 9dfa539563
3 changed files with 8 additions and 8 deletions

View File

@@ -1,3 +1,4 @@
#include "core/defer.hpp"
#define ARRAY_ALLOCATOR_TYPE Allocator
#define ARRAY_ASSERT assert
#define ARRAY_ALLOCATE(allocator, size) allocate_size(allocator, size)

View File

@@ -354,11 +354,10 @@ Ast_Decl *get_or_instantiate_polymorph_lambda(Token *pos, Ast_Decl *poly, Array<
if (!result) {
result = (Ast_Decl *)ast_copy(poly, poly->parent_scope, &poly->polymorph_parameters, &params);
for (int i = 0; i < result->lambda->args.len; i += 1) {
auto &it = result->lambda->args[i];
ForArrayRemovable(result->lambda->args) {
ForArrayRemovablePrepare(result->lambda->args);
if (it->flags & AST_IDENT_POLYMORPH) {
result->lambda->args.ordered_remove(it);
i -= 1; // @verify: Need to pay attention if this is correct
ForArrayRemovableDeclare();
}
}

View File

@@ -1696,12 +1696,12 @@ resolve_expr(Ast_Expr *ast, Resolve_Flag flags, Ast_Type *compound_and_const_str
// Find the polymorph
if (lambda->flags & AST_POLYMORPH) {
Array<Ast_Call_Item *> replacements = {scratch.arena};
for (int i = 0; i < matches.len; i += 1) {
Match &it = matches[i];
ForArrayRemovable(matches) {
ForArrayRemovablePrepare(matches);
if (it.lambda_arg->flags & AST_POLYMORPH) {
replacements.add(it.call_arg);
matches.ordered_remove(it); // @verify: Need to pay attention if this is correct
i -= 1;
ForArrayRemovableDeclare();
}
}