X-Git-Url: https://git.verplant.org/?a=blobdiff_plain;f=src%2Fsector.cpp;h=295c57dbb1f05a938beb7387487ec962dfa874a9;hb=f53572ad2b744ddddd7cc4b6479489543d44f98d;hp=3a0e2299d84253018905f7fd3100cc00b065195e;hpb=c62711567861587107d124642db29e2674ee6533;p=supertux.git diff --git a/src/sector.cpp b/src/sector.cpp index 3a0e2299d..295c57dbb 100644 --- a/src/sector.cpp +++ b/src/sector.cpp @@ -84,6 +84,8 @@ Sector::Sector(Level* parent) // create a new squirrel table for the sector using namespace Scripting; + sq_collectgarbage(global_vm); + sq_newtable(global_vm); sq_pushroottable(global_vm); if(SQ_FAILED(sq_setdelegate(global_vm, -2))) @@ -108,14 +110,16 @@ Sector::~Sector() sq_release(global_vm, &object); } sq_release(global_vm, §or_table); + sq_collectgarbage(global_vm); update_game_objects(); assert(gameobjects_new.size() == 0); - for(GameObjects::iterator i = gameobjects.begin(); i != gameobjects.end(); - ++i) { - before_object_remove(*i); - delete *i; + for(GameObjects::iterator i = gameobjects.begin(); + i != gameobjects.end(); ++i) { + GameObject* object = *i; + before_object_remove(object); + object->unref(); } for(SpawnPoints::iterator i = spawnpoints.begin(); i != spawnpoints.end(); @@ -451,6 +455,7 @@ Sector::add_object(GameObject* object) } #endif + object->ref(); gameobjects_new.push_back(object); } @@ -485,7 +490,7 @@ Sector::activate(const Vector& player_pos) _current->deactivate(); _current = this; - // register sectortable as current_sector in scripting + // register sectortable as sector in scripting HSQUIRRELVM vm = Scripting::global_vm; sq_pushroottable(vm); sq_pushstring(vm, "sector", -1); @@ -614,7 +619,7 @@ Sector::update_game_objects() before_object_remove(object); - delete *i; + object->unref(); i = gameobjects.erase(i); }