X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Fslash-repeat-engraver.cc;h=62f80c1619c19616854952f678ea398815cf501e;hb=b5362bb4f3c8eb130eb451b60d98271dff79f444;hp=aa5b52c405ccc72ec952aa9fed23a580711b59fd;hpb=70d5609d63efe8a9b42ff763b79348bf99953bf2;p=lilypond.git diff --git a/lily/slash-repeat-engraver.cc b/lily/slash-repeat-engraver.cc index aa5b52c405..62f80c1619 100644 --- a/lily/slash-repeat-engraver.cc +++ b/lily/slash-repeat-engraver.cc @@ -3,18 +3,22 @@ source file of the GNU LilyPond music typesetter - (c) 2000--2006 Han-Wen Nienhuys , Erik Sandberg + (c) 2000--2007 Han-Wen Nienhuys , Erik Sandberg + */ -#include "repeated-music.hh" +#include "bar-line.hh" #include "global-context.hh" -#include "warn.hh" -#include "misc.hh" -#include "spanner.hh" +#include "international.hh" #include "item.hh" -#include "percent-repeat-iterator.hh" -#include "bar-line.hh" +#include "misc.hh" +#include "repeated-music.hh" #include "score-engraver.hh" +#include "spanner.hh" +#include "stream-event.hh" +#include "warn.hh" + +#include "translator.icc" /** This acknowledges repeated music with "percent" style. It typesets @@ -25,9 +29,9 @@ class Slash_repeat_engraver : public Engraver public: TRANSLATOR_DECLARATIONS (Slash_repeat_engraver); protected: - Music *slash_; + Stream_event *slash_; protected: - virtual bool try_music (Music *); + DECLARE_TRANSLATOR_LISTENER (percent); void process_music (); }; @@ -36,24 +40,21 @@ Slash_repeat_engraver::Slash_repeat_engraver () slash_ = 0; } -bool -Slash_repeat_engraver::try_music (Music *m) +IMPLEMENT_TRANSLATOR_LISTENER (Slash_repeat_engraver, percent); +void +Slash_repeat_engraver::listen_percent (Stream_event *ev) { /*todo: separate events for percent and slash */ - if (m->is_mus_type ("percent-event")) - { - Moment meas_length - = robust_scm2moment (get_property ("measureLength"), Moment (0)); - - if (m->get_length () < meas_length) - slash_ = m; - else - return false; - - return true; - } - - return false; + Moment meas_length + = robust_scm2moment (get_property ("measureLength"), Moment (0)); + + if (get_event_length (ev) < meas_length) + ASSIGN_EVENT_ONCE (slash_, ev); + + /* + don't warn if nothing happens: this can happen if there are whole + measure repeats. + */ } void @@ -66,11 +67,16 @@ Slash_repeat_engraver::process_music () } } -#include "translator.icc" - ADD_TRANSLATOR (Slash_repeat_engraver, - /* doc */ "Make beat repeats.", - /* create */ "RepeatSlash", - /* accept */ "percent-event", - /* read */ "measureLength", - /* write */ ""); + /* doc */ + "Make beat repeats.", + + /* create */ + "RepeatSlash ", + + /* read */ + "measureLength ", + + /* write */ + "" + );