X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Fglissando-engraver.cc;h=4c506df38d14efc8d4e9e47cdc327bea35a8f72e;hb=d5c4d98d29e9bd22f3474700186219d38d5000f6;hp=424d8664f51a7ec386ea0f72cbd223bb46736261;hpb=2c22efe5a46a37065b10c3f51c5d7db00d07d318;p=lilypond.git diff --git a/lily/glissando-engraver.cc b/lily/glissando-engraver.cc index 424d8664f5..4c506df38d 100644 --- a/lily/glissando-engraver.cc +++ b/lily/glissando-engraver.cc @@ -3,13 +3,17 @@ source file of the GNU LilyPond music typesetter - (c) 2000--2005 Jan Nieuwenhuizen + (c) 2000--2006 Jan Nieuwenhuizen */ -#include "warn.hh" -#include "spanner.hh" -#include "rhythmic-head.hh" #include "engraver.hh" +#include "international.hh" +#include "rhythmic-head.hh" +#include "spanner.hh" +#include "stream-event.hh" +#include "warn.hh" + +#include "translator.icc" /** Create line-spanner grobs for glissandi lines that connect note @@ -21,15 +25,16 @@ public: TRANSLATOR_DECLARATIONS (Glissando_engraver); protected: + DECLARE_TRANSLATOR_LISTENER (glissando); DECLARE_ACKNOWLEDGER (rhythmic_head); virtual void finalize (); + void stop_translation_timestep (); - virtual bool try_music (Music *); void process_music (); private: Spanner *line_; Spanner *last_line_; - Music *event_; + Stream_event *event_; }; Glissando_engraver::Glissando_engraver () @@ -38,24 +43,18 @@ Glissando_engraver::Glissando_engraver () event_ = 0; } -bool -Glissando_engraver::try_music (Music *m) +IMPLEMENT_TRANSLATOR_LISTENER (Glissando_engraver, glissando); +void +Glissando_engraver::listen_glissando (Stream_event *ev) { - if (!event_) - { - event_ = m; - return true; - } - return false; + ASSIGN_EVENT_ONCE (event_, ev); } void Glissando_engraver::process_music () { if (event_) - { - line_ = make_spanner ("Glissando", event_->self_scm ()); - } + line_ = make_spanner ("Glissando", event_->self_scm ()); } void @@ -73,9 +72,8 @@ void Glissando_engraver::stop_translation_timestep () { if (last_line_ && last_line_->get_bound (RIGHT)) - { - last_line_ = 0; - } + last_line_ = 0; + if (line_) { if (last_line_) @@ -91,7 +89,7 @@ Glissando_engraver::finalize () { if (line_) { - String msg = _ ("unterminated glissando"); + string msg = _ ("unterminated glissando"); if (event_) event_->origin ()->warning (msg); @@ -103,12 +101,9 @@ Glissando_engraver::finalize () } } -#include "translator.icc" - ADD_ACKNOWLEDGER (Glissando_engraver, rhythmic_head); ADD_TRANSLATOR (Glissando_engraver, /* doc */ "Engrave a glissandi", /* create */ "Glissando", - /* accept */ "glissando-event", /* read */ "followVoice", /* write */ "");