X-Git-Url: https://git.verplant.org/?a=blobdiff_plain;f=src%2Ftrigger%2Ftrigger_base.cpp;h=a221b2998817c17c37e6651c63844d53ac9a8f2f;hb=4eff38d2a777e7a889428eadbef0d1eae7d35db0;hp=47e09c5325e04401b5c6be9f25ff3c0d3411788e;hpb=c38211432b49e261d1f164d1b04b8f8f1ffcf9d4;p=supertux.git diff --git a/src/trigger/trigger_base.cpp b/src/trigger/trigger_base.cpp index 47e09c532..a221b2998 100644 --- a/src/trigger/trigger_base.cpp +++ b/src/trigger/trigger_base.cpp @@ -22,25 +22,34 @@ #include "trigger_base.hpp" #include "video/drawing_context.hpp" #include "object/player.hpp" +#include "log.hpp" TriggerBase::TriggerBase() - : sprite(0), lasthit(false), hit(false), losetouch_listener(0) + : sprite(0), lasthit(false), hit(false) { set_group(COLGROUP_TOUCHABLE); } TriggerBase::~TriggerBase() { + // unregister remove_listener hooks, so nobody will try to call us after we've been destroyed + for (std::list::iterator i = losetouch_listeners.begin(); i != losetouch_listeners.end(); i++) { + Player* p = *i; + p->del_remove_listener(this); + } + losetouch_listeners.clear(); } void TriggerBase::update(float ) { if (lasthit && !hit) { - if (losetouch_listener) { - event(*losetouch_listener, EVENT_LOSETOUCH); - losetouch_listener = 0; + for (std::list::iterator i = losetouch_listeners.begin(); i != losetouch_listeners.end(); i++) { + Player* p = *i; + event(*p, EVENT_LOSETOUCH); + p->del_remove_listener(this); } + losetouch_listeners.clear(); } lasthit = hit; hit = false; @@ -62,7 +71,7 @@ TriggerBase::collision(GameObject& other, const CollisionHit& ) if(player) { hit = true; if(!lasthit) { - losetouch_listener = player; + losetouch_listeners.push_back(player); player->add_remove_listener(this); event(*player, EVENT_TOUCH); } @@ -74,6 +83,12 @@ TriggerBase::collision(GameObject& other, const CollisionHit& ) void TriggerBase::object_removed(GameObject* object) { - if (losetouch_listener == object) losetouch_listener = 0; + for (std::list::iterator i = losetouch_listeners.begin(); i != losetouch_listeners.end(); i++) { + Player* p = *i; + if (p == object) { + losetouch_listeners.erase(i); + break; + } + } }