X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Flyric-combine-music.cc;h=3ab20f6d33af597aef3f625f2c25915e45cffdbb;hb=7cb049f7f3705e414c2a49c7cf14f43a51914c48;hp=0b1f86b332836e5d207d0f9164dea67942bceb97;hpb=9c8bcb9a2a1fedb5459e593b18a8c550318e6800;p=lilypond.git diff --git a/lily/lyric-combine-music.cc b/lily/lyric-combine-music.cc index 0b1f86b332..3ab20f6d33 100644 --- a/lily/lyric-combine-music.cc +++ b/lily/lyric-combine-music.cc @@ -3,33 +3,29 @@ source file of the GNU LilyPond music typesetter - (c) 1999--2000 Han-Wen Nienhuys + (c) 1999--2002 Han-Wen Nienhuys */ #include "lyric-combine-music.hh" -#include "musical-pitch.hh" +#include "lyric-combine-music-iterator.hh" +#include "pitch.hh" -Lyric_combine_music::Lyric_combine_music (Music * m, Music * l) +Lyric_combine_music::Lyric_combine_music (SCM l) + : Music (l) { - set_mus_property ("music", m->self_scm ()); - set_mus_property ("lyrics", l->self_scm ()); + set_mus_property ("iterator-ctor", + Lyric_combine_music_iterator::constructor_cxx_function); } void -Lyric_combine_music::transpose (Musical_pitch p) +Lyric_combine_music::transpose (Pitch p) { music_l ()->transpose (p); lyrics_l () ->transpose (p); } -void -Lyric_combine_music::do_print () const -{ - music_l ()->print(); - lyrics_l () ->print (); -} Moment Lyric_combine_music::length_mom () const @@ -37,8 +33,8 @@ Lyric_combine_music::length_mom () const return music_l ()->length_mom (); } -Musical_pitch -Lyric_combine_music::to_relative_octave ( Musical_pitch p ) +Pitch +Lyric_combine_music::to_relative_octave (Pitch p) { p = music_l ()->to_relative_octave (p); return lyrics_l () ->to_relative_octave (p); @@ -50,14 +46,33 @@ Lyric_combine_music::compress (Moment m) music_l ()->compress (m); } + + Music* Lyric_combine_music::music_l () const { - return unsmob_music (get_mus_property ("music")); + SCM l = get_mus_property ("elements"); + if (!gh_pair_p (l)) + return 0; + return unsmob_music (gh_car (l)); } + Music* Lyric_combine_music::lyrics_l () const { - return unsmob_music (get_mus_property ("lyrics")); + SCM l = get_mus_property ("elements"); + if (!gh_pair_p (l)) + return 0; + l = gh_cdr (l); + if (!gh_pair_p (l)) + return 0; + return unsmob_music (gh_car (l)); } + +Lyric_combine_music::Lyric_combine_music () + : Music (SCM_EOL) +{ +} + +ADD_MUSIC (Lyric_combine_music);