Compare commits

..

1 commit

Author SHA1 Message Date
lolmanurfunny
a606a5a914
Merge 870823f9fc into 263544d77c 2025-03-09 22:56:00 +01:00
2 changed files with 21 additions and 45 deletions

View file

@ -1154,8 +1154,6 @@ do
for archetype_id in idr_t.columns do
local idr_t_archetype = archetypes[archetype_id]
local idr_t_types = idr_t_archetype.types
local to = idr_t_archetype
local children = table.clone(idr_t_archetype.entities)
local n = #children
@ -1165,10 +1163,7 @@ do
end
local object = ecs_pair_second(world, id)
if object ~= delete then
continue
end
if object == delete then
local id_record = component_index[id]
local flags = id_record.flags
local flags_delete_mask: number = bit32.band(flags, ECS_ID_DELETE)
@ -1179,7 +1174,7 @@ do
break
else
local on_remove = id_record.hooks.on_remove
to = archetype_traverse_remove(world, id, to)
local to = archetype_traverse_remove(world, id, idr_t_archetype)
local empty = #to.types == 0
for i = n, 1, -1 do
local child = children[i]
@ -1193,6 +1188,7 @@ do
end
end
end
end
archetype_destroy(world, idr_t_archetype)
end

View file

@ -1333,26 +1333,6 @@ TEST("world:target", function()
CHECK(i == 10)
end
do CASE("should return correct targets after deletion") -- ISSUE #207
local world = jecs.World.new()
local Attacks = world:component()
local Eats = world:component()
local a = world:entity()
local b = world:entity()
local c = world:entity()
world:add(a, jecs.pair(Attacks, b))
world:add(a, jecs.pair(Attacks, c))
world:add(a, jecs.pair(Eats, c))
world:add(a, jecs.pair(Eats, b))
world:delete(c)
CHECK(world:target(a, Attacks, 0) == b)
CHECK(not world:target(a, Attacks, 1))
CHECK(not world:target(a, Attacks, 2))
end
end)
TEST("world:contains", function()