X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Feffects%2Feffect.cpp;h=878e23fb571cf1881e0af3cf163a1696a3cfd661;hb=bdcae47bf2f4e49d2d9e4ba15e6f17171ce5fa0c;hp=e335b46a69dae807d8e0bb3b58f7c55ead2f72f9;hpb=233dff2a6c552e08da832496aecd88ef4f8948f1;p=libs%2Fgl.git diff --git a/source/effects/effect.cpp b/source/effects/effect.cpp index e335b46a..878e23fb 100644 --- a/source/effects/effect.cpp +++ b/source/effects/effect.cpp @@ -1,23 +1,43 @@ +#include #include "effect.h" -#include "sampler.h" namespace Msp { namespace GL { -Effect::Effect(Renderable &r): - renderable(r) +Effect::Effect(Renderable &c): + content(c) { - enabled_passes.insert(Tag()); + enable_for_method(Tag()); } -void Effect::enable_for_pass(Tag tag) +void Effect::enable_for_method(Tag tag) { - enabled_passes.insert(tag); + auto i = lower_bound(enabled_methods, tag); + if(i==enabled_methods.end() || *i!=tag) + enabled_methods.insert(i, tag); } -void Effect::disable_for_pass(Tag tag) +void Effect::disable_for_method(Tag tag) { - enabled_passes.erase(tag); + auto i = lower_bound(enabled_methods, tag); + if(i!=enabled_methods.end() && *i==tag) + enabled_methods.erase(i); +} + +bool Effect::is_enabled_for_method(Tag tag) const +{ + auto i = lower_bound(enabled_methods, tag); + return (i!=enabled_methods.end() && *i==tag); +} + + +Effect::Template::Loader::Loader(Template &t, Collection &c): + CollectionObjectLoader