X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Ftranslator-dispatch-list.cc;h=eeee8d24831c1417b844919ccc282818864b1b9e;hb=97a0169312a260933246ab224e4f8b0969871dd5;hp=41d5a171827ceb5bdf065d3eaf5eeebd0bcf1884;hpb=0398fdb9df24ac2e22a8cbff1b3c18ca04e9f221;p=lilypond.git diff --git a/lily/translator-dispatch-list.cc b/lily/translator-dispatch-list.cc index 41d5a17182..eeee8d2483 100644 --- a/lily/translator-dispatch-list.cc +++ b/lily/translator-dispatch-list.cc @@ -21,19 +21,18 @@ #include "engraver.hh" -const char * const Engraver_dispatch_list::type_p_name_ = 0; - void Engraver_dispatch_list::apply (Grob_info gi) { - Translator *origin = gi.origin_translator (); + SCM origin = gi.origin_translator ()->self_scm (); + SCM grob = gi.grob ()->self_scm (); for (vsize i = 0; i < dispatch_entries_.size (); i++) { - Engraver_dispatch_entry const &e (dispatch_entries_[i]); - if (e.engraver_ == origin) + Method_instance const &e (dispatch_entries_[i]); + if (scm_is_eq (e.instance (), origin)) continue; - (e.engraver_->*e.function_) (gi); + e (grob, origin); } } @@ -44,32 +43,21 @@ Engraver_dispatch_list::create (SCM trans_list, SCM retval = Engraver_dispatch_list ().smobbed_copy (); Engraver_dispatch_list *list = unsmob (retval); - Engraver_dispatch_entry entry; - bool found = false; for (SCM s = trans_list; scm_is_pair (s); s = scm_cdr (s)) { - Engraver *eng - = unsmob (scm_car (s)); + Engraver *eng = unsmob (scm_car (s)); if (!eng) continue; - entry.engraver_ = eng; for (SCM i = iface_list; scm_is_pair (i); i = scm_cdr (i)) { - Translator::Grob_info_callback ptr - = (start_end == START) - ? eng->get_acknowledger (scm_car (i)) - : eng->get_end_acknowledger (scm_car (i)); + SCM ptr = eng->get_acknowledger (scm_car (i), start_end); - if (ptr) - { - entry.function_ = ptr; - list->dispatch_entries_.push_back (entry); - found = true; - } + if (!SCM_UNBNDP (ptr)) + list->dispatch_entries_.push_back (Method_instance (ptr, eng)); } } - return found ? retval : SCM_EOL; + return list->dispatch_entries_.empty () ? SCM_EOL : retval; }