X-Git-Url: http://git.tdb.fi/?p=libs%2Fgl.git;a=blobdiff_plain;f=source%2Fbuilders%2Fsequencebuilder.cpp;h=eff9348b8395a78226436110633a400c9e373d26;hp=bf3fef42dfb82f55989a21f8c325139ee569ba7d;hb=b8b7c6b251cace40021bdfacc6aa17242aa51e1d;hpb=0bd265b929f0b2a9289dd72262968ad8e7bc1a0d diff --git a/source/builders/sequencebuilder.cpp b/source/builders/sequencebuilder.cpp index bf3fef42..eff9348b 100644 --- a/source/builders/sequencebuilder.cpp +++ b/source/builders/sequencebuilder.cpp @@ -16,8 +16,8 @@ namespace GL { SequenceBuilder::SequenceBuilder(const SequenceTemplate &t): tmpl(t) { - for(const SequenceTemplate::Step &s: tmpl.get_steps()) - renderables[s.slot_name] = s.default_renderable; + for(const SequenceTemplate::Renderable &r: tmpl.get_renderables()) + renderables[r.slot_name] = r.renderable; for(const SequenceTemplate::PostProcessor &p: tmpl.get_postprocessors()) if(!p.slot_name.empty()) postprocessors[p.slot_name] = 0; @@ -59,9 +59,9 @@ void SequenceBuilder::build(Sequence &sequence) const for(const SequenceTemplate::Step &s: tmpl.get_steps()) { - Renderable *renderable = get_item(renderables, s.slot_name); + Renderable *renderable = get_item(renderables, s.renderable_name); if(!renderable) - continue; + throw missing_renderable(s.renderable_name); Sequence::Step &step = sequence.add_step(s.tag, *renderable); step.set_depth_test(s.depth_test); @@ -92,6 +92,9 @@ void SequenceBuilder::build(Sequence &sequence) const sequence.add_owned(proc.release()); } } + + if(!proc) + throw invalid_operation("SequenceBuilder::build"); } }