X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;ds=sidebyside;f=lily%2Fstanza-number-engraver.cc;h=3434f06167c81a40707a30152d9c7d2c51ef7236;hb=38d7d319eabc906e82fb42002678c6d42a23b6f7;hp=2f77b5d4f74e1c8f286162cea87ca0f66c4305c4;hpb=bdf4ab13203502e7ec7cf9cf5896527643a07c1f;p=lilypond.git diff --git a/lily/stanza-number-engraver.cc b/lily/stanza-number-engraver.cc index 2f77b5d4f7..3434f06167 100644 --- a/lily/stanza-number-engraver.cc +++ b/lily/stanza-number-engraver.cc @@ -3,29 +3,33 @@ source file of the GNU LilyPond music typesetter - (c) 2000--2005 Han-Wen Nienhuys , Glen Prideaux + (c) 2000--2009 Han-Wen Nienhuys , Glen Prideaux */ #include "engraver.hh" #include "side-position-interface.hh" +#include "text-interface.hh" +#include "item.hh" class Stanza_number_engraver : public Engraver { Item *text_; - /* - This is naughty, since last_stanza_ may be GCd from under us. But - since we don't look at the contents, we are/should be (knock on - wood) OK. - */ SCM last_stanza_; public: TRANSLATOR_DECLARATIONS (Stanza_number_engraver); - virtual void process_music (); - virtual void stop_translation_timestep (); - virtual void acknowledge_grob (Grob_info); + void process_music (); + virtual void derived_mark () const; + void stop_translation_timestep (); + DECLARE_ACKNOWLEDGER (lyric_syllable); }; +void +Stanza_number_engraver::derived_mark () const +{ + scm_gc_mark (last_stanza_); +} + /* TODO: should make engraver that collects all the stanzas on a higher level, and then groups them to the side. Stanza numbers should be @@ -35,6 +39,7 @@ public: Stanza_number_engraver::Stanza_number_engraver () { text_ = 0; + last_stanza_ = SCM_EOL; } void @@ -42,7 +47,8 @@ Stanza_number_engraver::process_music () { SCM stanza = get_property ("stanza"); - if (scm_is_string (stanza) && stanza != last_stanza_) + if (Text_interface::is_markup (stanza) + && stanza != last_stanza_) { last_stanza_ = stanza; @@ -52,13 +58,10 @@ Stanza_number_engraver::process_music () } void -Stanza_number_engraver::acknowledge_grob (Grob_info inf) +Stanza_number_engraver::acknowledge_lyric_syllable (Grob_info inf) { - if (text_ - && inf.grob_->internal_has_interface (ly_symbol2scm ("lyric-syllable-interface"))) - { - Side_position_interface::add_support (text_, inf.grob_); - } + if (text_) + Side_position_interface::add_support (text_, inf.grob ()); } void @@ -67,10 +70,19 @@ Stanza_number_engraver::stop_translation_timestep () text_ = 0; } +#include "translator.icc" + +ADD_ACKNOWLEDGER (Stanza_number_engraver, lyric_syllable); ADD_TRANSLATOR (Stanza_number_engraver, - /* descr */ "", - /* creats*/ "StanzaNumber", - /* accepts */ "", - /* acks */ "lyric-syllable-interface", - /* reads */ "stanza", - /* write */ ""); + /* doc */ + "Engrave stanza numbers.", + + /* create */ + "StanzaNumber ", + + /* read */ + "stanza ", + + /* write */ + "" + );