X-Git-Url: http://git.tdb.fi/?a=blobdiff_plain;f=source%2Feffects%2Feffect.cpp;h=e59aeed8e039dcbc352d6daf6904a3b44eacaa06;hb=84e0e55710123e54617d342df852007f8b60af24;hp=46a0f2362c0700bdcc47873db7283bbff9724558;hpb=9a63244c1342337915c4610401a24c09fa72cc3d;p=libs%2Fgl.git diff --git a/source/effects/effect.cpp b/source/effects/effect.cpp index 46a0f236..e59aeed8 100644 --- a/source/effects/effect.cpp +++ b/source/effects/effect.cpp @@ -1,5 +1,5 @@ +#include #include "effect.h" -#include "sampler.h" namespace Msp { namespace GL { @@ -7,17 +7,37 @@ namespace GL { Effect::Effect(Renderable &r): renderable(r) { - enabled_passes.insert(Tag()); + enable_for_method(Tag()); } -void Effect::enable_for_pass(const 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(const 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