]> git.donarmstrong.com Git - lilypond.git/blobdiff - lily/percent-repeat-iterator.cc
Run `make grand-replace'.
[lilypond.git] / lily / percent-repeat-iterator.cc
index 0f40fba6d28eed53efdcd420e28e2da7cfad923d..5573dc7609b988b99667b51b3304cb78169b70e3 100644 (file)
@@ -1,98 +1,54 @@
-/*   
-  percent-repeat-iterator.cc --  implement Percent_repeat_iterator
-  
-  source file of the GNU LilyPond music typesetter
-  
-  (c) 2001--2003  Han-Wen Nienhuys <hanwen@cs.uu.nl>
-  
- */
+/*
+  percent-repeat-iterator.cc -- implement Percent_repeat_iterator
 
-#include "percent-repeat-iterator.hh"
-#include "repeated-music.hh"
-#include "input.hh"
+  source file of the GNU LilyPond music typesetter
 
-IMPLEMENT_CTOR_CALLBACK (Percent_repeat_iterator);
+  (c) 2001--2008  Han-Wen Nienhuys <hanwen@xs4all.nl>
+                  Erik Sandberg <mandolaerik@gmail.com>
+*/
 
+#include "input.hh"
+#include "repeated-music.hh"
+#include "sequential-iterator.hh"
 
-Percent_repeat_iterator::Percent_repeat_iterator ()
+class Percent_repeat_iterator : public Sequential_iterator
 {
-  child_iter_ = 0;
-}
+public:
+  DECLARE_CLASSNAME (Percent_repeat_iterator);
+  DECLARE_SCHEME_CALLBACK (constructor, ());
+  Percent_repeat_iterator ();
+protected:
+  virtual SCM get_music_list () const;
+};
 
-void
-Percent_repeat_iterator::do_quit()
-{
-  if (child_iter_)
-    child_iter_->quit();
-}
-Percent_repeat_iterator::Percent_repeat_iterator (Percent_repeat_iterator const & p)
-  : Music_iterator (p)
-{
-  child_iter_ = 0;
- finish_mom_ = p.finish_mom_ ;
-  if (p.child_iter_)
-    {
-      child_iter_ =  p.child_iter_->clone ();
-      scm_gc_unprotect_object (child_iter_->self_scm());
-    }
-}
+IMPLEMENT_CTOR_CALLBACK (Percent_repeat_iterator);
 
-bool
-Percent_repeat_iterator::ok () const
+Percent_repeat_iterator::Percent_repeat_iterator ()
 {
-  return child_iter_;
 }
 
-void
-Percent_repeat_iterator::construct_children ()
+SCM
+Percent_repeat_iterator::get_music_list () const
 {
-  Repeated_music * mus =dynamic_cast<Repeated_music *> (get_music ());
-  finish_mom_ = mus->get_length ();
-  child_iter_ = unsmob_iterator (get_iterator (mus->body ()));
-}
+  /* TODO: Distinction between percent, double-percent and slash */
+  Music *mus = get_music ();
+  Music *child = Repeated_music::body (mus);
+  SCM length = child->get_length ().smobbed_copy ();
+  SCM child_list = SCM_EOL;
 
-
-void
-Percent_repeat_iterator::process (Moment m)
-{
-  if (!m.to_bool ())
-    {
-      Music_iterator *yeah = try_music (get_music ());
-      if (yeah)
-       set_translator (yeah->report_to ());
-      else
-       get_music ()->origin ()->warning ( _ ("no one to print a percent"));
-    }
+  int repeats = scm_to_int (mus->get_property ("repeat-count"));
+  for (int i = repeats; i > 1; i--)
+  {
+    Music *percent = make_music_by_name (ly_symbol2scm ("PercentEvent"));
+    percent->set_spot (*mus->origin ());
+    percent->set_property ("length", length);
+    if (repeats > 1)
+      percent->set_property ("repeat-count", scm_int2num (i));
+    
+    child_list = scm_cons (percent->unprotect (), child_list);
+  }
   
-  if (child_iter_->ok ())
-    child_iter_->process (m);
-
-  if (finish_mom_ <= m )
-    {
-      child_iter_->quit(); 
-      child_iter_ = 0;
-    }
-}
+  child_list = scm_cons (child->self_scm (), child_list);
 
-Moment
-Percent_repeat_iterator::pending_moment ()const
-{
-  if (child_iter_->ok ())
-    return child_iter_->pending_moment ();
-  else
-    return finish_mom_ ;
-}
-
-Music_iterator*
-Percent_repeat_iterator::try_music_in_children (Music *m) const
-{
-  return child_iter_->try_music (m);
-}
-
-void
-Percent_repeat_iterator::derived_mark()const
-{
-  if (child_iter_)
-    scm_gc_mark (child_iter_->self_scm());
+  return child_list;
 }