}
+PipelineTemplate::PostProcessorRegistry &PipelineTemplate::get_postprocessor_registry()
+{
+ static PostProcessorRegistry registry;
+ static bool initialized = false;
+ if(!initialized)
+ {
+ registry.register_type<AmbientOcclusion>("ambient_occlusion");
+ registry.register_type<Bloom>("bloom");
+ registry.register_type<ColorCurve>("colorcurve");
+ initialized = true;
+ }
+ return registry;
+}
+
+
PipelineTemplate::Pass::~Pass()
{ }
void PipelineTemplate::Loader::init()
{
- add("ambient_occlusion", &Loader::postprocessor<AmbientOcclusion>);
- add("bloom", &Loader::postprocessor<Bloom>);
- add("colorcurve", &Loader::postprocessor<ColorCurve>);
add("hdr", &PipelineTemplate::hdr);
add("multisample", &Loader::multisample);
add("multisample", &Loader::multisample_range);
add("pass", &Loader::pass);
+
+ get_postprocessor_registry().add_all(*this);
}
void PipelineTemplate::Loader::multisample(unsigned samples)
obj.passes.push_back(pss);
}
-template<typename T>
-void PipelineTemplate::Loader::postprocessor()
-{
- RefPtr<typename T::Template> postproc = new typename T::Template;
- load_sub(*postproc);
- obj.postprocessors.push_back(postproc.release());
-}
-
PipelineTemplate::Pass::Loader::Loader(Pass &p):
DataFile::CollectionObjectLoader<Pass>(p, 0)