return shprog;
}
+#pragma GCC diagnostic push
+#pragma GCC diagnostic ignored "-Wdeprecated-declarations"
void Material::attach_texture_to(const Texture *tex, Texturing &texturing, ProgramData &tex_shdata, const string &name) const
{
if(!tex)
texturing.attach(unit, *tex, sampler);
tex_shdata.uniform(name, unit);
}
+#pragma GCC diagnostic pop
Material::MaterialRegistry &Material::get_material_registry()
{
add("sampler", &Loader::sampler);
}
-void Material::Loader::sampler(const std::string &name)
+void Material::Loader::sampler(const string &name)
{
obj.sampler = &get_collection().get<Sampler>(name);
}
DataFile::Loader::ActionMap Material::GenericLoader::shared_actions;
Material::GenericLoader::GenericLoader(DataFile::Collection *c):
- coll(c)
+ coll(c),
+ material(0),
+ mat_loader(0)
{
set_actions(shared_actions);
}
+Material::GenericLoader::~GenericLoader()
+{
+ delete material;
+ delete mat_loader;
+}
+
void Material::GenericLoader::init_actions()
{
- get_material_registry().add_all(*this);
+ add("type", &GenericLoader::type);
+}
+
+void Material::GenericLoader::type(const DataFile::Symbol &sym)
+{
+ get_material_registry().invoke(sym.name, *this);
}
} // namespace GL