X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Fsimple-music-iterator.cc;h=2b8519fbf9b49d60ad8f3a8fb76e48a416a512b7;hb=1f0d3e5ed0e3b1f0a21a7d64e5b9c7e27bba4f5a;hp=d6cc80b0f2388507b634bcb665e74968364084ff;hpb=0e0a18dbaa12275d0a07b76104243a15da821a15;p=lilypond.git diff --git a/lily/simple-music-iterator.cc b/lily/simple-music-iterator.cc index d6cc80b0f2..2b8519fbf9 100644 --- a/lily/simple-music-iterator.cc +++ b/lily/simple-music-iterator.cc @@ -3,7 +3,7 @@ source file of the GNU LilyPond music typesetter - (c) 2000 Han-Wen Nienhuys + (c) 2000--2002 Han-Wen Nienhuys */ @@ -14,25 +14,60 @@ Simple_music_iterator::Simple_music_iterator () : Music_iterator () { + last_processed_mom_ = -1; } Simple_music_iterator::Simple_music_iterator (Simple_music_iterator const &src) : Music_iterator (src) { + last_processed_mom_ = src.last_processed_mom_; +} + +bool +Simple_music_iterator::ok ()const +{ + return last_processed_mom_ < music_get_length (); +} + +/* + TODO: remove last_processed_mom_, and the complete shit. We should + only process a simple-music once, and that is at its start. + + Engravers can detect and event the end-moments to be processed as + well. + +*/ +Moment +Simple_music_iterator::pending_moment ()const +{ + if (last_processed_mom_ < Moment (0)) + return Moment (0); + else + return music_get_length (); } void -Simple_music_iterator::do_process (Moment m) +Simple_music_iterator::skip (Moment m) { -#if 0 - if (ok ()) - { - bool b = try_music (get_music ()); - if (!b) - music_l_->origin ()->warning (_f ("Junking music: `%s'", - classname (music_l_))); - - } - Music_iterator::do_process (m); -#endif + /* + docme??!! + + uncommented because setting MUSIC_L_ = 0 causes core dumps with + grace notes. */ + + // music_ = 0; + + last_processed_mom_ = m; +} + +void +Simple_music_iterator::process (Moment m) +{ + /* + don't do try_music (), since it would make the function useless for + base classes */ + + skip (m); } + +IMPLEMENT_CTOR_CALLBACK (Simple_music_iterator);