]> git.donarmstrong.com Git - lilypond.git/blobdiff - lily/simple-music-iterator.cc
Run `make grand-replace'.
[lilypond.git] / lily / simple-music-iterator.cc
index ef83a5abda1a3de36eb1a633c2fb50b4b8b406a7..c89f0f52be1d45b270016b12904ebcc11319a375 100644 (file)
@@ -1,13 +1,13 @@
-/*   
-  simple-music-iterator.cc --  implement Simple_music_iterator
-  
+/*
+  simple-music-iterator.cc -- implement Simple_music_iterator
+
   source file of the GNU LilyPond music typesetter
-  
-  (c) 2000--2001 Han-Wen Nienhuys <hanwen@cs.uu.nl>
-  
- */
+
+  (c) 2000--2008 Han-Wen Nienhuys <hanwen@xs4all.nl>
+*/
 
 #include "simple-music-iterator.hh"
+
 #include "music.hh"
 #include "input.hh"
 
@@ -17,42 +17,37 @@ Simple_music_iterator::Simple_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_length_mom ();
+  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_length_mom ();
-}
-
-void
-Simple_music_iterator::skip (Moment m)
-{
-  music_l_ = 0;
-  last_processed_mom_ = m;
+    return music_get_length ();
 }
 
 void
 Simple_music_iterator::process (Moment m)
 {
   /*
-  don't do try_music (), since it would make the function useless for
-  base classes */
+    don't do report_event (), since it would make the function useless for
+    base classes
+  */
 
-  skip (m);
+  last_processed_mom_ = m;
 }
 
 IMPLEMENT_CTOR_CALLBACK (Simple_music_iterator);