]> git.donarmstrong.com Git - lilypond.git/blobdiff - lily/grace-iterator.cc
Run `make grand-replace'.
[lilypond.git] / lily / grace-iterator.cc
index f73e610bada19a1451a8cd037ef9d3f1e2914caa..1974f0d801722c71bc13c0752f9ca5b08343f514 100644 (file)
@@ -1,54 +1,36 @@
-/*   
-  grace-iterator.cc --  implement Grace_iterator
-  
+/*
+  grace-music.cc -- implement Grace_music
+
   source file of the GNU LilyPond music typesetter
-  
-  (c) 1999--2001 Han-Wen Nienhuys <hanwen@cs.uu.nl>
-  
- */
+
+  (c) 1999--2008 Han-Wen Nienhuys <hanwen@xs4all.nl>
+*/
 
 #include "grace-iterator.hh"
-#include "global-translator.hh"
+#include "global-context.hh"
 #include "warn.hh"
 
-Grace_iterator::~Grace_iterator () 
-{
-  //  child_iter_p_ = 0;
-}
-
 void
-Grace_iterator::construct_children () 
+Grace_iterator::process (Moment m)
 {
-  Translator_group * t = report_to_l ()->find_create_translator_l ("Grace", ""); // umgh.
-
-  if (t)
-    set_translator (t);
-  Music_wrapper_iterator::construct_children ();
-}
+  Moment main;
+  main.main_part_ = -start_mom_.grace_part_ + m.grace_part_;
+  Music_wrapper_iterator::process (main);
 
-void
-Grace_iterator::process (Moment)
-{
-  Global_translator * t = dynamic_cast<Global_translator*> (report_to_l ());
-  if (t)
-    {
-      t->start ();
-      t->run_iterator_on_me (child_iter_p_);
-      delete child_iter_p_;
-      child_iter_p_ = 0;
-      t->finish ();
-    }
-  else
-    {
-      warning (_ ("no Grace context available")); 
-    }
+  /* We can safely do this, since \grace should always be inside
+     sequential.  */
+  descend_to_child (child_iter_->get_outlet ());
 }
 
 Moment
 Grace_iterator::pending_moment () const
 {
-  return  0;
-}
+  Moment cp = Music_wrapper_iterator::pending_moment ();
+
+  Moment pending;
+  pending.grace_part_ = start_mom_.grace_part_ + cp.main_part_;
 
+  return pending;
+}
 
 IMPLEMENT_CTOR_CALLBACK (Grace_iterator);