X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Frender%2Fscene.cpp;h=3c101b8a172cdba1fc421eecc5a182946bb3f308;hb=e92de029768eef5f0fd744329e589161b46d0762;hp=cec2683abd2f0303b0fe90e1b6d3fc7db90e6127;hpb=885b8ad08cfcefba4b95ec9028fa1e25df2fe171;p=libs%2Fgl.git diff --git a/source/render/scene.cpp b/source/render/scene.cpp index cec2683a..3c101b8a 100644 --- a/source/render/scene.cpp +++ b/source/render/scene.cpp @@ -1,4 +1,5 @@ #include +#include #include "camera.h" #include "objectinstance.h" #include "occludedscene.h" @@ -13,12 +14,6 @@ using namespace std; namespace Msp { namespace GL { -Scene::~Scene() -{ - for(vector::iterator i=owned_data.begin(); i!=owned_data.end(); ++i) - delete *i; -} - bool Scene::setup_frustum(const Renderer &renderer) const { const Camera *camera = renderer.get_camera(); @@ -109,6 +104,8 @@ Scene::Loader::Loader(Scene &s, Collection &c, ContentMap &m): void Scene::Loader::init() { + inst_counter = 0; + add("object", &Loader::object); add("object", &Loader::object_tagged); add("scene", &Loader::scene); @@ -123,10 +120,10 @@ void Scene::Loader::object_tagged(const string &n, const string &t) { RefPtr inst = new ObjectInstance(get_collection().get(n)); load_sub(*inst); - obj.add(*inst); + get_collection().add(format("%s/%d.inst", FS::basename(get_source()), inst_counter++), inst.get()); if(content && !t.empty()) (*content)[t] = inst.get(); - obj.owned_data.push_back(inst.release()); + obj.add(*inst.release()); } void Scene::Loader::scene(const string &n)