]> git.donarmstrong.com Git - lilypond.git/blobdiff - lily/chord-tremolo-iterator.cc
input/test fixes
[lilypond.git] / lily / chord-tremolo-iterator.cc
index fd456b6ac3cb1aab4e1d79b2560ebfb0be4622b4..d9bb1f39636594dbcbad5dd64c877bb2c4198fb0 100644 (file)
@@ -3,7 +3,7 @@
   
   source file of the GNU LilyPond music typesetter
   
-  (c) 2000--2002 Han-Wen Nienhuys <hanwen@cs.uu.nl>
+  (c) 2000--2004 Han-Wen Nienhuys <hanwen@cs.uu.nl>
   
  */
 
@@ -21,7 +21,7 @@ void
 Chord_tremolo_iterator::construct_children ()
 {
   Repeated_music * rep = dynamic_cast<Repeated_music*> (get_music ());
-  factor_  = Moment (Rational(1, 1));
+  factor_  = Moment (Rational (1, 1));
   child_iter_ = unsmob_iterator (get_iterator (rep->body ()));
 }
 
@@ -31,30 +31,25 @@ Chord_tremolo_iterator::Chord_tremolo_iterator ()
   child_iter_ = 0;
 }
 
-Chord_tremolo_iterator::Chord_tremolo_iterator (Chord_tremolo_iterator const &src)
-  : Music_iterator (src)
+void
+Chord_tremolo_iterator::do_quit ()
 {
-  factor_ = src.factor_;
-  child_iter_ = 0;
-  if (src.child_iter_)
-    {
-      child_iter_ = src.child_iter_->clone ();
-      scm_gc_unprotect_object (child_iter_->self_scm());
-    }
+  if (child_iter_)
+    child_iter_->quit ();
 }
 
 void
-Chord_tremolo_iterator::do_quit()
+Chord_tremolo_iterator::derived_mark () const
 {
   if (child_iter_)
-    child_iter_->quit();
+    scm_gc_mark (child_iter_->self_scm ());
 }
 
 void
-Chord_tremolo_iterator::derived_mark () const
+Chord_tremolo_iterator::derived_substitute (Context *f, Context *t) 
 {
   if (child_iter_)
-    scm_gc_mark (child_iter_->self_scm());
+    child_iter_->substitute_outlet (f,t);
 }
 
 void
@@ -64,7 +59,7 @@ Chord_tremolo_iterator::process (Moment m)
     {
       Music_iterator *yeah = try_music (get_music ());
       if (yeah)
-       set_translator (yeah->report_to ());
+       set_translator (yeah->get_outlet ());
       else
        get_music ()->origin ()->warning (_ ("no one to print a tremolos"));
     }