X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Fgrace-iterator.cc;h=237ebc81eeecb9b69b4cf697af1d8c224d6b63f1;hb=4dba22cdae8ec59067ab18a3ae2f73522fc26e8c;hp=f93e13e942990681a7a6d6d987de3bfa5654bc43;hpb=da7dbf5f2f54bc66984ab2524c490335d567b5e7;p=lilypond.git diff --git a/lily/grace-iterator.cc b/lily/grace-iterator.cc index f93e13e942..237ebc81ee 100644 --- a/lily/grace-iterator.cc +++ b/lily/grace-iterator.cc @@ -1,47 +1,36 @@ -/* - grace-iterator.cc -- implement Grace_iterator - +/* + grace-music.cc -- implement Grace_music + source file of the GNU LilyPond music typesetter - - (c) 1999 Han-Wen Nienhuys - - */ + + (c) 1999--2007 Han-Wen Nienhuys +*/ #include "grace-iterator.hh" -#include "global-translator.hh" +#include "global-context.hh" #include "warn.hh" void -Grace_iterator::construct_children () +Grace_iterator::process (Moment m) { - Translator_group * t = report_to_l ()->find_create_translator_l ("Grace", ""); // umgh. + Moment main; + main.main_part_ = -start_mom_.grace_part_ + m.grace_part_; + Music_wrapper_iterator::process (main); - if (t) - set_translator (t); - Music_wrapper_iterator::construct_children (); -} - -void -Grace_iterator::do_process_and_next (Moment m) -{ - 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!")); - } - Music_iterator::do_process_and_next (m); + /* We can safely do this, since \grace should always be inside + sequential. */ + descend_to_child (child_iter_->get_outlet ()); } Moment -Grace_iterator::next_moment () const +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);