* stepmake/stepmake/metafont-rules.make: backport 1.7 fixes.
[lilypond.git] / lily / repeated-music.cc
blob7b3ffe6e4d8f1e686922ca634b29fc2ed376ae00
1 /*
2 repeated-music.cc -- implement Repeated_music
4 source file of the GNU LilyPond music typesetter
6 (c) 1999--2002 Han-Wen Nienhuys <hanwen@cs.uu.nl>
8 */
10 #include "repeated-music.hh"
11 #include "music-list.hh"
12 #include "pitch.hh"
13 #include "warn.hh"
14 #include "music-sequence.hh"
16 Music *
17 Repeated_music::body ()const
19 return unsmob_music (get_mus_property ("element"));
22 SCM
23 Repeated_music::alternatives ()const
25 return get_mus_property ("elements");
29 Repeated_music::Repeated_music (SCM l)
30 : Music (l)
32 set_mus_property ("type", ly_symbol2scm ("repeated-music"));
36 Pitch
37 Repeated_music::to_relative_octave (Pitch p)
39 if (body ())
40 p = body ()->to_relative_octave (p);
42 Pitch last = p ;
43 if (alternatives ())
44 for (SCM s = alternatives (); gh_pair_p (s); s = ly_cdr (s))
45 unsmob_music (ly_car (s))->to_relative_octave (p);
48 return last;
51 void
52 Repeated_music::transpose (Pitch p)
54 if (body ())
55 body ()->transpose (p);
57 Music_sequence::transpose_list (get_mus_property ("elements"), p);
60 void
61 Repeated_music::compress (Moment p)
63 if (body ())
64 body ()->compress (p);
66 Music_sequence::compress_list (alternatives (), p);
69 Moment
70 Repeated_music::alternatives_length_mom (bool fold) const
72 if (!alternatives ())
73 return 0;
75 if (fold)
76 return Music_sequence::maximum_length (alternatives ());
78 Moment m =0;
79 int done =0;
81 SCM p = alternatives ();
82 while (gh_pair_p (p) && done < repeat_count ())
84 m = m + unsmob_music (ly_car (p))->length_mom ();
85 done ++;
86 if (repeat_count () - done < scm_ilength (alternatives ()))
87 p = ly_cdr (p);
89 return m;
93 Sum all duration of all available alternatives. This is for the case
94 of volta repeats, where the alternatives are iterated just as they
95 were entered. */
96 Moment
97 Repeated_music::alternatives_volta_length_mom () const
99 if (!alternatives ())
100 return 0;
102 Moment m;
103 SCM p = alternatives ();
104 while (gh_pair_p (p))
106 m = m + unsmob_music (ly_car (p))->length_mom ();
107 p = ly_cdr (p);
109 return m;
114 Length of the body in THIS. Disregards REPEAT-COUNT.
116 Moment
117 Repeated_music::body_length_mom () const
119 Moment m = 0;
120 if (body ())
122 m = body ()->length_mom ();
124 return m;
128 Repeated_music::repeat_count () const
130 return gh_scm2int (get_mus_property ("repeat-count"));
134 MAKE_SCHEME_CALLBACK (Repeated_music,unfolded_music_length, 1);
135 MAKE_SCHEME_CALLBACK (Repeated_music,folded_music_length, 1);
136 MAKE_SCHEME_CALLBACK (Repeated_music,volta_music_length, 1);
139 Repeated_music::unfolded_music_length (SCM m)
141 Repeated_music* r = dynamic_cast<Repeated_music*> (unsmob_music (m));
143 Moment l = Moment (r->repeat_count ()) * r->body_length_mom () + r->alternatives_length_mom (false);
144 return l.smobbed_copy ();
148 Repeated_music::folded_music_length (SCM m)
150 Repeated_music* r = dynamic_cast<Repeated_music*> (unsmob_music (m));
152 Moment l = r->body_length_mom () + r->alternatives_length_mom (true);
153 return l.smobbed_copy ();
157 Repeated_music::volta_music_length (SCM m)
159 Repeated_music* r = dynamic_cast<Repeated_music*> (unsmob_music (m));
160 Moment l = r->body_length_mom () + r->alternatives_volta_length_mom ();
161 return l.smobbed_copy ();
164 ADD_MUSIC (Repeated_music);
166 Repeated_music::Repeated_music ()
167 : Music (SCM_EOL)
169 set_mus_property ("type", ly_symbol2scm ("repeated-music"));
173 MAKE_SCHEME_CALLBACK (Repeated_music,minimum_start, 1);
174 MAKE_SCHEME_CALLBACK (Repeated_music,first_start, 1);
177 Repeated_music::minimum_start (SCM m)
179 Music * me = unsmob_music (m);
180 Music * body = unsmob_music (me->get_mus_property ("element"));
182 if (body)
183 return body->start_mom ().smobbed_copy();
184 else
186 return Music_sequence::minimum_start (me->get_mus_property ("elements")).smobbed_copy();
191 Repeated_music::first_start (SCM m)
193 Music * me = unsmob_music (m);
194 Music * body = unsmob_music (me->get_mus_property ("element"));
196 Moment rv = (body) ? body->start_mom () :
197 Music_sequence::first_start (me->get_mus_property ("elements"));
199 return rv.smobbed_copy ();