X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Fbreathing-sign-engraver.cc;h=f24d85541f1c9e9ded778c75864bab72f7a6ad83;hb=358d6e99ada8019268ade9ba9080b2d0d88eeb7a;hp=ba23eede6d3179b589000798c7cabcb1e9950278;hpb=58bcc84c9480dae1b21bc24d8396b91fe19e0131;p=lilypond.git diff --git a/lily/breathing-sign-engraver.cc b/lily/breathing-sign-engraver.cc index ba23eede6d..f24d85541f 100644 --- a/lily/breathing-sign-engraver.cc +++ b/lily/breathing-sign-engraver.cc @@ -1,7 +1,7 @@ /* breathing_sign-engraver.cc -- implement Breathing_sign_engraver - (c) 1999--2005 Michael Krause + (c) 1999--2006 Michael Krause written for the GNU LilyPond music typesetter @@ -12,10 +12,12 @@ . Spacing is not yet completely pretty */ -#include "staff-symbol-referencer.hh" #include "breathing-sign.hh" -#include "engraver-group-engraver.hh" +#include "engraver.hh" #include "item.hh" +#include "stream-event.hh" + +#include "translator.icc" class Breathing_sign_engraver : public Engraver { @@ -23,35 +25,34 @@ public: TRANSLATOR_DECLARATIONS (Breathing_sign_engraver); protected: - virtual bool try_music (Music *req); - virtual void process_acknowledged_grobs (); - virtual void stop_translation_timestep (); + void process_music (); + void stop_translation_timestep (); + DECLARE_TRANSLATOR_LISTENER (breathing); private: - Music *breathing_sign_req_; + Stream_event *breathing_sign_event_; Grob *breathing_sign_; }; Breathing_sign_engraver::Breathing_sign_engraver () { breathing_sign_ = 0; - breathing_sign_req_ = 0; + breathing_sign_event_ = 0; } -bool -Breathing_sign_engraver::try_music (Music *r) +IMPLEMENT_TRANSLATOR_LISTENER (Breathing_sign_engraver, breathing); +void +Breathing_sign_engraver::listen_breathing (Stream_event *ev) { - breathing_sign_req_ = r; - return true; + ASSIGN_EVENT_ONCE (breathing_sign_event_, ev); } void -Breathing_sign_engraver::process_acknowledged_grobs () +Breathing_sign_engraver::process_music () { - if (breathing_sign_req_ && ! breathing_sign_) + if (breathing_sign_event_) { - breathing_sign_ = make_item ("BreathingSign", breathing_sign_req_->self_scm ()); - breathing_sign_req_ = 0; + breathing_sign_ = make_item ("BreathingSign", breathing_sign_event_->self_scm ()); } } @@ -59,13 +60,11 @@ void Breathing_sign_engraver::stop_translation_timestep () { breathing_sign_ = 0; - breathing_sign_req_ = 0; + breathing_sign_event_ = 0; } ADD_TRANSLATOR (Breathing_sign_engraver, - /* descr */ "", - /* creats*/ "BreathingSign", - /* accepts */ "breathing-event", - /* acks */ "", - /* reads */ "", + /* doc */ "", + /* create */ "BreathingSign", + /* read */ "", /* write */ "");