X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Fgrace-iterator.cc;h=1974f0d801722c71bc13c0752f9ca5b08343f514;hb=5b4b0d6e9a197e8f9eb085b7c2ad78b8be3e5cfc;hp=f73e610bada19a1451a8cd037ef9d3f1e2914caa;hpb=4995fea559cd5399b4f462de546a15195d76f4c3;p=lilypond.git diff --git a/lily/grace-iterator.cc b/lily/grace-iterator.cc index f73e610bad..1974f0d801 100644 --- a/lily/grace-iterator.cc +++ b/lily/grace-iterator.cc @@ -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 - - */ + + (c) 1999--2008 Han-Wen Nienhuys +*/ #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 (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);