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>
9 #include "music-list.hh"
10 #include "music-wrapper.hh"
11 #include "musical-pitch.hh"
13 #include "musical-request.hh"
14 #include "music-iterator.hh"
16 #include "killing-cons.tcc"
19 Simultaneous_music::length_mom () const
21 return maximum_length ();
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
)
38 Sequential_music::Sequential_music(Music_list
*p
)
44 Sequential_music::length_mom () const
46 return cumulative_length ();
50 Simultaneous_music::to_relative_octave (Musical_pitch p
)
52 return do_relative_octave (p
, true);
56 Simultaneous_music::to_rhythm (Music_iterator
* r
)
62 Music_sequence::do_relative_octave (Musical_pitch p
, bool b
)
64 return music_p_list_p_
->do_relative_octave (p
, b
);
68 Music_sequence::do_rhythm (Music_iterator
* r
)
70 return music_p_list_p_
->do_rhythm (r
);
74 Music_list::do_relative_octave (Musical_pitch last
, bool ret_first
)
78 for (Cons
<Music
> *i
= head_
; i
; i
= i
->next_
)
80 last
= i
->car_
->to_relative_octave (last
);
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
);
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_
);
110 Music_list::add_music (Music
*m_p
)
115 append (new Killing_cons
<Music
> (m_p
, 0));
118 Request_chord::Request_chord()
119 : Simultaneous_music (new Music_list
)
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
);
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 ())
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
))
157 if (Rhythmic_req
* d
= dynamic_cast <Rhythmic_req
*> (m
))
159 r
->duration_
= d
->duration_
;
168 Music_list::Music_list ()
172 Music_sequence::~Music_sequence ()
174 delete music_p_list_p_
;