X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Ftuplet-iterator.cc;h=80a75a9beb7ad2d8c64f14c66d12158b7e3e0089;hb=47db9a3883d726ca53e2133a3b2298f78dd6a32e;hp=bf9a223684840885a32edf9d1efbcfa5354676b0;hpb=c3d30cde5a4e1ba4d8e044fec7677629269b9443;p=lilypond.git diff --git a/lily/tuplet-iterator.cc b/lily/tuplet-iterator.cc index bf9a223684..80a75a9beb 100644 --- a/lily/tuplet-iterator.cc +++ b/lily/tuplet-iterator.cc @@ -1,7 +1,7 @@ /* This file is part of LilyPond, the GNU music typesetter. - Copyright (C) 1998--2012 Han-Wen Nienhuys , + Copyright (C) 1998--2015 Han-Wen Nienhuys , Erik Sandberg LilyPond is free software: you can redistribute it and/or modify @@ -68,7 +68,7 @@ Tuplet_iterator::create_event (Direction d) Music *mus = get_music (); - Music *ev = unsmob_music (ev_scm); + Music *ev = Music::unsmob (ev_scm); ev->set_spot (*mus->origin ()); if (d == START) { @@ -109,6 +109,8 @@ Tuplet_iterator::process (Moment m) if (m.main_part_ < music_get_length ().main_part_) { + spanner_duration_ = + min (music_get_length () - next_split_mom_, spanner_duration_); tuplet_handler_.set_context (get_outlet ()); report_event (create_event (START)); @@ -126,17 +128,13 @@ Tuplet_iterator::process (Moment m) void Tuplet_iterator::construct_children () { - if (Duration *d = unsmob_duration (get_music ()->get_property ("duration"))) + if (Duration *d = Duration::unsmob (get_music ()->get_property ("duration"))) spanner_duration_ = d->get_length (); + else if (Moment *mp + = Moment::unsmob (get_outlet ()->get_property ("tupletSpannerDuration"))) + spanner_duration_ = mp->main_part_; else - { - spanner_duration_ = music_get_length (); - - Moment *mp - = unsmob_moment (get_outlet ()->get_property ("tupletSpannerDuration")); - if (mp) - spanner_duration_ = min (mp->main_part_, spanner_duration_); - } + spanner_duration_.set_infinite (1); Music_wrapper_iterator::construct_children ();