X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;ds=sidebyside;f=lily%2Fpart-combine-engraver.cc;h=016b08598e3e3ebe9600dcf6d210ea80e34e7994;hb=ae0484ae139f4de639f91e64a3788583e5f84d87;hp=9bd1a12085dc46c10b88b872b1fb195a9dc5c201;hpb=02c656d3b0cb895cc81b428d699d960746800e45;p=lilypond.git diff --git a/lily/part-combine-engraver.cc b/lily/part-combine-engraver.cc index 9bd1a12085..016b08598e 100644 --- a/lily/part-combine-engraver.cc +++ b/lily/part-combine-engraver.cc @@ -3,13 +3,13 @@ source file of the GNU LilyPond music typesetter - (c) 2000--2005 Jan Nieuwenhuizen + (c) 2000--2006 Jan Nieuwenhuizen Han-Wen Nienhuys */ #include "engraver.hh" -#include "text-item.hh" +#include "text-interface.hh" #include "note-head.hh" #include "stem.hh" #include "side-position-interface.hh" @@ -20,9 +20,11 @@ class Part_combine_engraver : public Engraver TRANSLATOR_DECLARATIONS (Part_combine_engraver); protected: - virtual void acknowledge_grob (Grob_info); - virtual void process_music (); - virtual void stop_translation_timestep (); + DECLARE_ACKNOWLEDGER (note_head); + DECLARE_ACKNOWLEDGER (stem); + + void process_music (); + void stop_translation_timestep (); virtual bool try_music (Music *); private: Item *text_; @@ -57,7 +59,7 @@ Part_combine_engraver::process_music () else if (what == ly_symbol2scm ("unisono")) text = get_property ("aDueText"); - if (Text_interface::markup_p (text)) + if (Text_interface::is_markup (text)) { text_ = make_item ("CombineTextScript", event_->self_scm ()); text_->set_property ("text", text); @@ -66,25 +68,25 @@ Part_combine_engraver::process_music () } void -Part_combine_engraver::acknowledge_grob (Grob_info i) +Part_combine_engraver::acknowledge_note_head (Grob_info i) { if (text_) { - if (Note_head::has_interface (i.grob ())) - { - Grob *t = text_; - Side_position_interface::add_support (t, i.grob ()); - if (Side_position_interface::get_axis (t) == X_AXIS - && !t->get_parent (Y_AXIS)) - t->set_parent (i.grob (), Y_AXIS); - } - if (Stem::has_interface (i.grob ())) - { - Side_position_interface::add_support (text_, i.grob ()); - } + Grob *t = text_; + Side_position_interface::add_support (t, i.grob ()); + if (Side_position_interface::get_axis (t) == X_AXIS + && !t->get_parent (Y_AXIS)) + t->set_parent (i.grob (), Y_AXIS); } } +void +Part_combine_engraver::acknowledge_stem (Grob_info i) +{ + if (text_) + Side_position_interface::add_support (text_, i.grob ()); +} + void Part_combine_engraver::stop_translation_timestep () { @@ -92,13 +94,14 @@ Part_combine_engraver::stop_translation_timestep () event_ = 0; } +#include "translator.icc" +ADD_ACKNOWLEDGER (Part_combine_engraver, note_head); +ADD_ACKNOWLEDGER (Part_combine_engraver, stem); ADD_TRANSLATOR (Part_combine_engraver, - /* descr */ "Part combine engraver for orchestral scores: " + /* doc */ "Part combine engraver for orchestral scores: " "Print markings a2, Solo, Solo II, and unisono ", - /* creats*/ "CombineTextScript", - /* accepts */ "part-combine-event", - /* acks */ "multi-measure-rest-interface " - "slur-interface stem-interface note-head-interface", - /* reads */ "printPartCombineTexts soloText soloIIText " + /* create */ "CombineTextScript", + /* accept */ "part-combine-event", + /* read */ "printPartCombineTexts soloText soloIIText " "aDueText", /* write */ "");