]> git.donarmstrong.com Git - lilypond.git/blob - lily/request-chord-iterator.cc
patch::: 1.3.87.jcn1
[lilypond.git] / lily / request-chord-iterator.cc
1 /*
2   request-chord-iterator.cc -- implement Request_chord_iterator
3
4   source file of the GNU LilyPond music typesetter
5
6   (c)  1997--2000 Han-Wen Nienhuys <hanwen@cs.uu.nl>
7 */
8
9 #include "translator-group.hh"
10 #include "debug.hh"
11 #include "request-chord-iterator.hh"
12 #include "music-list.hh"
13 #include "request.hh"
14
15 Request_chord_iterator::Request_chord_iterator ()
16 {
17 }
18
19 Request_chord_iterator::Request_chord_iterator (Request_chord_iterator const &src)
20   : Simple_music_iterator (src)
21 {
22 }
23
24 Translator_group*
25 Request_chord_iterator::get_req_translator_l ()
26 {
27   assert (report_to_l ());
28   if (report_to_l ()->is_bottom_translator_b ())
29     return report_to_l ();
30
31   set_translator (report_to_l ()->get_default_interpreter ());
32   return report_to_l ();
33 }
34
35 void
36 Request_chord_iterator::construct_children()
37 {
38   Simple_music_iterator::construct_children ();
39   get_req_translator_l();
40 }
41
42 Request_chord*
43 Request_chord_iterator::elt_l () const
44 {
45   return (Request_chord*) music_l_;
46 }
47
48 SCM
49 Request_chord_iterator::get_music (Moment m) const
50 {
51   Request_chord_iterator* urg = (Request_chord_iterator*)this;
52   urg->last_processed_mom_ = m;
53   urg->last_processed_mom_.set_infinite (1);
54   SCM s = SCM_EOL;
55   if (music_l_)
56     {
57       Music_sequence * ms = dynamic_cast<Music_sequence*> (music_l_);
58      
59       for (SCM m = ms->music_list (); gh_pair_p (m); m = gh_cdr (m))
60         {
61           s = gh_cons (gh_car (m) , s);
62         }
63       urg->music_l_ = 0;
64     }
65   return s;
66 }
67
68 void
69 Request_chord_iterator::process (Moment m)
70 {
71   last_processed_mom_ = m;
72   if (music_l_)
73     {
74       for (SCM s = dynamic_cast<Music_sequence *> (music_l_)->music_list ();
75            gh_pair_p (s);  s = gh_cdr (s))
76         {
77           Music *mus = unsmob_music (gh_car (s));
78
79           if (Request * req_l = dynamic_cast<Request*> (mus))
80             {
81               bool gotcha = try_music (req_l);
82               if (!gotcha)
83                 req_l->origin ()->warning (_f ("Junking request: `%s'", classname( req_l)));
84             }
85           else
86             mus->origin ()->warning (_f ("Huh?  Not a Request: `%s'",
87                                          classname (mus)));
88         }
89
90      music_l_ =0;
91     }
92 }