From 02a2f1f933e2b8d830cc8c6d91eba399ebe62498 Mon Sep 17 00:00:00 2001 From: David Capello Date: Sat, 16 Jul 2022 13:11:05 -0300 Subject: [PATCH] Test when Sprite.events are created just when the sprite is being closed As app 'sitechange' event is generated when we close a sprite, accessing Sprite.events on that event will re-create the app::script::SpriteEvents instance associated with the sprite. --- scripts/events.lua | 25 +++++++++++++++++++++++++ 1 file changed, 25 insertions(+) diff --git a/scripts/events.lua b/scripts/events.lua index 78b8fe7d2..0a523bb45 100644 --- a/scripts/events.lua +++ b/scripts/events.lua @@ -109,3 +109,28 @@ do -- listener instead of doing nothing. expect_eq(2, i) end + +-- Accessing Sprite.events when closing the same sprite will call +-- push_sprite_events() creating a new app::script::SpriteEvents +-- instance again even when we've just destroyed the old one (because +-- we're just closing the sprite). +do + local s = Sprite(32, 32) + function onSpriteChange() + -- Do nothing + end + -- Here we access s.events for first time, creating the + -- app::script::SpriteEvents for this sprite. + s.events:on('change', onSpriteChange) + function onSiteChange() + -- Accessing s.events again on 'sitechange' when we're just + -- closing the sprite, re-generating its SpriteEvents instance. + -- We've to have special care of this case. + s.events:off(onSpriteChange) + end + app.events:on('sitechange', onSiteChange) + -- Closing the sprite will create a 'sitechange' event calling + -- onSiteChange() function. + s:close() + app.events:off(onSiteChange) +end