- if(duration)
- {
- float t = (b-start_beat)/duration;
- float dt = d/duration;
- if(hermite)
- {
- dt = t-dt;
- t = (3-2*t)*t*t;
- dt = t-(3-2*dt)*dt*dt;
- }
- interpolate(t, dt);
- }
- else
- interpolate(1.0f, 1.0f);
+ segment(beat, beat);
+}
+
+void Sequencer::Loader::segment(float start, float end)
+{
+ SegmentLoader ldr(obj, start, end);
+ load_sub_with(ldr);
+}
+
+
+Sequencer::ActionDefLoader::ActionDefLoader(Sequencer &s, Demo &d):
+ DataFile::ObjectLoader<Sequencer>(s),
+ demo(d)
+{
+ for(const auto &t: obj.action_types)
+ add(t.first, t.second->get_loader_func());
+}
+
+void Sequencer::ActionDefLoader::finished()
+{
+ if(action)
+ action->validate();
+}
+
+
+Sequencer::SegmentLoader::SegmentLoader(Sequencer &s, float b, float e):
+ ObjectLoader<Sequencer>(s),
+ start_beat(b),
+ end_beat(e)
+{
+ add("apply", &SegmentLoader::apply);