X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;ds=sidebyside;f=lily%2Flyric-combine-music.cc;h=931ef3b04144fd56d660d964172dbd6c15328245;hb=08b2a48bdd102e2e53b4eafaf8bdc4726e4f1119;hp=021c915953faff9a7be9e3ba969871d8c1ad7220;hpb=ac93c7dd01e0b6661c360acf89721ce9d32e4e4c;p=lilypond.git diff --git a/lily/lyric-combine-music.cc b/lily/lyric-combine-music.cc index 021c915953..931ef3b041 100644 --- a/lily/lyric-combine-music.cc +++ b/lily/lyric-combine-music.cc @@ -1,47 +1,26 @@ -/* - lyric-combine-music.cc -- implement Lyric_combine_music - - source file of the GNU LilyPond music typesetter - - (c) 1999--2004 Han-Wen Nienhuys - - */ +/* + lyric-combine-music.cc -- implement Lyric_combine_music -#include "lyric-combine-music.hh" -#include "pitch.hh" + source file of the GNU LilyPond music typesetter -Lyric_combine_music::Lyric_combine_music () - : Music () -{ -} + (c) 1999--2006 Han-Wen Nienhuys +*/ -Moment -Lyric_combine_music::get_length () const -{ - return get_music ()->get_length (); -} +#include "music.hh" +#include "pitch.hh" +#include "moment.hh" -Music* -Lyric_combine_music::get_music () const +struct Lyric_combine_music { - SCM l = get_property ("elements"); - if (!scm_is_pair (l)) - return 0; - return unsmob_music (scm_car (l)); -} +public: + DECLARE_SCHEME_CALLBACK (length_callback, (SCM)); +}; - -Music* -Lyric_combine_music::get_lyrics () const +MAKE_SCHEME_CALLBACK (Lyric_combine_music, length_callback, 1); +SCM +Lyric_combine_music::length_callback (SCM m) { - SCM l = get_property ("elements"); - if (!scm_is_pair (l)) - return 0; - l = scm_cdr (l); - if (!scm_is_pair (l)) - return 0; - return unsmob_music (scm_car (l)); + Music *me = unsmob_music (m); + Music *melody = unsmob_music (scm_car (me->get_property ("elements"))); + return melody->get_length ().smobbed_copy (); } - - -ADD_MUSIC (Lyric_combine_music);