X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Fgrace-iterator.cc;h=237ebc81eeecb9b69b4cf697af1d8c224d6b63f1;hb=2c09cab3cbf12753e7cc8b69e20b21b009ea7e92;hp=325a0d5207fe45940a4e8165ae57f7142a9ae1af;hpb=7aabfb20c46e0a1de41698ddc6859ccd3a6dea85;p=lilypond.git diff --git a/lily/grace-iterator.cc b/lily/grace-iterator.cc index 325a0d5207..237ebc81ee 100644 --- a/lily/grace-iterator.cc +++ b/lily/grace-iterator.cc @@ -1,37 +1,36 @@ -/* - grace-music.cc -- implement Grace_music - - source file of the GNU LilyPond music typesetter - - (c) 1999--2003 Han-Wen Nienhuys - - */ +/* + grace-music.cc -- implement Grace_music -#include "grace-music.hh" -#include "grace-iterator.hh" + source file of the GNU LilyPond music typesetter + (c) 1999--2007 Han-Wen Nienhuys +*/ -#include "global-translator.hh" +#include "grace-iterator.hh" +#include "global-context.hh" #include "warn.hh" void Grace_iterator::process (Moment m) { - Moment main ; - main.main_part_ = - start_mom_.grace_part_ + m.grace_part_; + Moment main; + main.main_part_ = -start_mom_.grace_part_ + m.grace_part_; Music_wrapper_iterator::process (main); + + /* 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 { - Moment cp =Music_wrapper_iterator::pending_moment(); + Moment cp = Music_wrapper_iterator::pending_moment (); Moment pending; - pending.grace_part_ = start_mom_.grace_part_ + cp.main_part_; + pending.grace_part_ = start_mom_.grace_part_ + cp.main_part_; return pending; } - IMPLEMENT_CTOR_CALLBACK (Grace_iterator);