delete texturing;
}
+void RenderPass::finalize_material()
+{
+ ensure_private_shader_data();
+
+ if(!texturing)
+ texturing = new Texturing;
+ material->attach_textures_to(*texturing, *shdata);
+}
+
void RenderPass::ensure_private_shader_data()
{
if(!shprog)
{
material = mat;
material.keep();
+ finalize_material();
}
void RenderPass::set_texture(unsigned index, const Texture *tex)
void RenderPass::Loader::init()
{
- add("shader", &RenderPass::shprog);
+ add("shader", &Loader::shader);
add("material", &Loader::material_inline);
add("material", &Loader::material);
add("material_slot", &RenderPass::material_slot);
void RenderPass::Loader::material_inline()
{
- RefPtr<Material> mat = new Material;
- if(coll)
- load_sub(*mat, get_collection());
- else
- load_sub(*mat);
- obj.material = mat;
+ Material::GenericLoader ldr(coll);
+ load_sub_with(ldr);
+ obj.material = ldr.get_material();
+ obj.finalize_material();
}
void RenderPass::Loader::material(const string &name)
{
obj.material = &get_collection().get<Material>(name);
obj.material.keep();
+ obj.finalize_material();
+}
+
+void RenderPass::Loader::shader(const string &n)
+{
+ obj.shprog = &get_collection().get<Program>(n);
+ if(obj.shdata)
+ obj.shdata = new ProgramData(*obj.shdata, obj.shprog);
+ if(obj.material)
+ obj.finalize_material();
}
void RenderPass::Loader::texunit(unsigned i)
void RenderPass::Loader::uniforms()
{
obj.ensure_private_shader_data();
- RefPtr<ProgramData> shd = new ProgramData(obj.shprog);
- load_sub(*shd);
- obj.shdata = shd.release();
+ load_sub(*obj.shdata);
}
void RenderPass::Loader::uniform_slot(const string &name)