X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Fevent-chord-iterator.cc;h=ea1a105ea4c7083ffbad7b52b5415361704c4892;hb=b8f63200f0dde97e6d066e5f1082808e224d9774;hp=24b6ef5ad14235454c0643f85a92eed2187e35db;hpb=ef8093ad63c7a00a169cf88d71368b204dd65655;p=lilypond.git diff --git a/lily/event-chord-iterator.cc b/lily/event-chord-iterator.cc index 24b6ef5ad1..ea1a105ea4 100644 --- a/lily/event-chord-iterator.cc +++ b/lily/event-chord-iterator.cc @@ -3,57 +3,46 @@ source file of the GNU LilyPond music typesetter - (c) 1997--2003 Han-Wen Nienhuys + (c) 1997--2006 Han-Wen Nienhuys */ -#include "translator-group.hh" -#include "warn.hh" #include "event-chord-iterator.hh" -#include "music-list.hh" -#include "event.hh" -Event_chord_iterator::Event_chord_iterator () -{ -} +#include "context.hh" +#include "dispatcher.hh" +#include "duration.hh" +#include "input.hh" +#include "international.hh" +#include "music.hh" +#include "warn.hh" -Translator_group* -Event_chord_iterator::get_req_translator () +Event_chord_iterator::Event_chord_iterator () { - assert (get_outlet ()); - if (get_outlet ()->is_bottom_context ()) - return get_outlet (); - - set_translator (get_outlet ()->get_default_interpreter ()); - return get_outlet (); } void Event_chord_iterator::construct_children () { Simple_music_iterator::construct_children (); - get_req_translator (); + descend_to_bottom_context (); } -Event_chord* -Event_chord_iterator::get_elt () const -{ - return (Event_chord*) get_music (); -} - - void Event_chord_iterator::process (Moment m) { if (last_processed_mom_ < Moment (0)) { - for (SCM s = dynamic_cast (get_music ())->music_list (); - gh_pair_p (s); s = ly_cdr (s)) + for (SCM s = get_music ()->get_property ("elements"); + scm_is_pair (s); s = scm_cdr (s)) { - Music *mus = unsmob_music (ly_car (s)); - - bool gotcha = try_music (mus); - if (!gotcha) - mus->origin ()->warning (_f ("Junking event: `%s'", mus->name())); + Music *mus = unsmob_music (scm_car (s)); + report_event (mus); + } + for (SCM s = get_music ()->get_property ("events"); + scm_is_pair (s); s = scm_cdr (s)) + { + Stream_event *ev = unsmob_stream_event (scm_car (s)); + get_outlet ()->event_source ()->broadcast (ev); } } Simple_music_iterator::process (m);