2 request-chord-iterator.cc -- implement Request_chord_iterator
4 source file of the GNU LilyPond music typesetter
6 (c) 1997--2001 Han-Wen Nienhuys <hanwen@cs.uu.nl>
9 #include "translator-group.hh"
11 #include "request-chord-iterator.hh"
12 #include "music-list.hh"
15 Request_chord_iterator::Request_chord_iterator ()
19 Request_chord_iterator::Request_chord_iterator (Request_chord_iterator
const &src
)
20 : Simple_music_iterator (src
)
25 Request_chord_iterator::get_req_translator_l ()
27 assert (report_to_l ());
28 if (report_to_l ()->is_bottom_translator_b ())
29 return report_to_l ();
31 set_translator (report_to_l ()->get_default_interpreter ());
32 return report_to_l ();
36 Request_chord_iterator::construct_children ()
38 Simple_music_iterator::construct_children ();
39 get_req_translator_l ();
43 Request_chord_iterator::elt_l () const
45 return (Request_chord
*) music_l ();
49 Request_chord_iterator::get_music (Moment
) const
52 if (last_processed_mom_
< Moment (0))
54 Music_sequence
* ms
= dynamic_cast<Music_sequence
*> (music_l ());
56 for (SCM m
= ms
->music_list (); gh_pair_p (m
); m
= gh_cdr (m
))
58 s
= gh_cons (gh_car (m
) , s
);
65 Request_chord_iterator::process (Moment m
)
67 if (last_processed_mom_
< Moment (0))
69 for (SCM s
= dynamic_cast<Music_sequence
*> (music_l ())->music_list ();
70 gh_pair_p (s
); s
= gh_cdr (s
))
72 Music
*mus
= unsmob_music (gh_car (s
));
74 bool gotcha
= try_music (mus
);
76 mus
->origin ()->warning (_f ("Junking request: `%s'", classname (mus
)));
82 IMPLEMENT_CTOR_CALLBACK (Request_chord_iterator
);