lilypond-1.1.61
[lilypond.git] / lily / music-list.cc
blob3b9c830fbaac781242709085aa0b4244d0740ed0
1 /*
2 music-list.cc -- implement Music_sequence, Simultaneous_music, Sequential_music
4 source file of the GNU LilyPond music typesetter
6 (c) 1997--1999 Han-Wen Nienhuys <hanwen@cs.uu.nl>
7 */
9 #include "music-list.hh"
10 #include "music-wrapper.hh"
11 #include "musical-pitch.hh"
12 #include "request.hh"
13 #include "musical-request.hh"
14 #include "music-iterator.hh"
15 #include "main.hh"
16 #include "killing-cons.tcc"
18 Moment
19 Simultaneous_music::length_mom () const
21 return maximum_length ();
25 void
26 Music_sequence::compress (Moment m)
28 for (Cons<Music> *i = music_p_list_p_->head_; i; i = i->next_)
29 i->car_->compress (m);
32 Simultaneous_music::Simultaneous_music(Music_list *p)
33 : Music_sequence (p)
38 Sequential_music::Sequential_music(Music_list *p)
39 : Music_sequence (p)
43 Moment
44 Sequential_music::length_mom () const
46 return cumulative_length ();
49 Musical_pitch
50 Simultaneous_music::to_relative_octave (Musical_pitch p)
52 return do_relative_octave (p, true);
55 Music_iterator*
56 Simultaneous_music::to_rhythm (Music_iterator* r)
58 return do_rhythm (r);
61 Musical_pitch
62 Music_sequence::do_relative_octave (Musical_pitch p, bool b)
64 return music_p_list_p_->do_relative_octave (p, b);
67 Music_iterator*
68 Music_sequence::do_rhythm (Music_iterator* r)
70 return music_p_list_p_->do_rhythm (r);
73 Musical_pitch
74 Music_list::do_relative_octave (Musical_pitch last, bool ret_first)
76 Musical_pitch retval;
77 int count=0;
78 for (Cons<Music> *i = head_; i ; i = i->next_)
80 last = i->car_->to_relative_octave (last);
81 if (!count ++ )
82 retval = last;
85 if (!ret_first)
86 retval = last;
88 return retval;
91 Music_iterator*
92 Music_list::do_rhythm (Music_iterator* r)
94 for (Cons<Music> *i = head_; i ; i = i->next_)
96 r = i->car_->to_rhythm (r);
98 return r;
101 Music_list::Music_list (Music_list const &s)
102 : Cons_list<Music> (s)
104 Cons_list<Music>::init ();
105 clone_killing_cons_list (*this, s.head_);
109 void
110 Music_list::add_music (Music*m_p)
112 if (!m_p)
113 return;
115 append (new Killing_cons<Music> (m_p, 0));
118 Request_chord::Request_chord()
119 : Simultaneous_music (new Music_list)
124 Musical_pitch
125 Request_chord::to_relative_octave (Musical_pitch last)
127 for (Cons<Music> *i = music_p_list_p_->head_; i ; i = i->next_)
129 if (Melodic_req *m= dynamic_cast <Melodic_req *> (i->car_))
131 Musical_pitch &pit = m->pitch_;
132 pit.to_relative_octave (last);
133 return pit;
136 return last;
139 Music_iterator*
140 Request_chord::to_rhythm (Music_iterator* it)
142 for (Cons<Music>* i = music_p_list_p_->head_; i ; i = i->next_)
144 if (Rhythmic_req* r= dynamic_cast <Rhythmic_req*> (i->car_))
146 for (Music*m = it->next_music_l (); m; m = it->next_music_l ())
148 #if 0
149 // is it sane to assume we don't want rests on lyrics/in rhythm?
150 if (dynamic_cast <Rest_req*> (r)
151 || dynamic_cast <Multi_measure_rest_req*> (r)
152 || dynamic_cast <Skip_req*> (r))
154 continue;
156 #endif
157 if (Rhythmic_req* d= dynamic_cast <Rhythmic_req*> (m))
159 r->duration_ = d->duration_;
160 return it;
165 return it;
168 Music_list::Music_list ()
172 Music_sequence::~Music_sequence ()
174 delete music_p_list_p_;