X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Fgrob-pq-engraver.cc;h=7cb4afab87900821d25ee4f39df5e28a8cec35ea;hb=c5a3f0c024f4cb629811cff9eb04abff36e94138;hp=d40552b6ae60dbbca4aa92af35bd85c526297906;hpb=2c22efe5a46a37065b10c3f51c5d7db00d07d318;p=lilypond.git diff --git a/lily/grob-pq-engraver.cc b/lily/grob-pq-engraver.cc index d40552b6ae..7cb4afab87 100644 --- a/lily/grob-pq-engraver.cc +++ b/lily/grob-pq-engraver.cc @@ -3,7 +3,7 @@ source file of the GNU LilyPond music typesetter - (c) 2001--2005 Han-Wen Nienhuys + (c) 2001--2007 Han-Wen Nienhuys */ #include "context.hh" @@ -15,13 +15,14 @@ struct Grob_pq_entry { Grob *grob_; Moment end_; - static int compare (Grob_pq_entry const &a, - Grob_pq_entry const &b) - { - return Moment::compare (a.end_, b.end_); - } }; +bool +operator< (Grob_pq_entry const &a, Grob_pq_entry const &b) +{ + return a.end_ < b.end_; +} + class Grob_pq_engraver : public Engraver { public: @@ -31,8 +32,9 @@ protected: DECLARE_ACKNOWLEDGER (grob); void start_translation_timestep (); void stop_translation_timestep (); - - Array started_now_; + void process_acknowledged (); + + vector started_now_; }; Grob_pq_engraver::Grob_pq_engraver () @@ -45,7 +47,7 @@ Grob_pq_engraver::initialize () context ()->set_property ("busyGrobs", SCM_EOL); } -LY_DEFINE (ly_grob_pq_less_p, "ly:grob-pq-less?", +LY_DEFINE (ly_grob_pq_less_p, "ly:grob-pqinternal_has_interface (ly_symbol2scm ("multi-measure-interface"))) { Moment n = now_mom (); - Moment l = m->get_length (); + Moment l = get_event_length (ev); if (!l.to_bool ()) return; @@ -82,25 +84,17 @@ Grob_pq_engraver::acknowledge_grob (Grob_info gi) e.grob_ = gi.grob (); e.end_ = end; - started_now_.push (e); + started_now_.push_back (e); } } void -Grob_pq_engraver::stop_translation_timestep () +Grob_pq_engraver::process_acknowledged () { - Moment now = now_mom (); - SCM start_busy = get_property ("busyGrobs"); - SCM busy = start_busy; - while (scm_is_pair (busy) && *unsmob_moment (scm_caar (busy)) == now) - { - busy = scm_cdr (busy); - } - - started_now_.sort (Grob_pq_entry::compare); + vector_sort (started_now_, less ()); SCM lst = SCM_EOL; SCM *tail = &lst; - for (int i = 0; i < started_now_.size (); i++) + for (vsize i = 0; i < started_now_.size (); i++) { *tail = scm_acons (started_now_[i].end_.smobbed_copy (), started_now_[i].grob_->self_scm (), @@ -108,12 +102,24 @@ Grob_pq_engraver::stop_translation_timestep () tail = SCM_CDRLOC (*tail); } + SCM busy = get_property ("busyGrobs"); busy = scm_merge_x (lst, busy, ly_grob_pq_less_p_proc); context ()->set_property ("busyGrobs", busy); started_now_.clear (); } +void +Grob_pq_engraver::stop_translation_timestep () +{ + Moment now = now_mom (); + SCM start_busy = get_property ("busyGrobs"); + SCM busy = start_busy; + while (scm_is_pair (busy) && *unsmob_moment (scm_caar (busy)) == now) + busy = scm_cdr (busy); + +} + void Grob_pq_engraver::start_translation_timestep () { @@ -140,6 +146,5 @@ ADD_TRANSLATOR (Grob_pq_engraver, /* doc */ "Administrate when certain grobs (eg. note heads) stop playing", /* create */ "", - /* accept */ "", /* read */ "busyGrobs", /* write */ "busyGrobs");