X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Flyric-combine-music.cc;h=a1256ae62fad739fe622054c7e999981d95eb370;hb=eee9576c5d8ee45e432365d15159044f9a06229c;hp=82f1e56de7eba7cd5299ec13c0c7eab07375c6f2;hpb=c659cb200486c2f908703696a1b2873e78c8160a;p=lilypond.git diff --git a/lily/lyric-combine-music.cc b/lily/lyric-combine-music.cc index 82f1e56de7..a1256ae62f 100644 --- a/lily/lyric-combine-music.cc +++ b/lily/lyric-combine-music.cc @@ -1,48 +1,35 @@ -/* - lyric-combine-music.cc -- implement Lyric_combine_music - - source file of the GNU LilyPond music typesetter - - (c) 1999--2004 Han-Wen Nienhuys - - */ +/* + This file is part of LilyPond, the GNU music typesetter. -#include "lyric-combine-music.hh" + Copyright (C) 1999--2009 Han-Wen Nienhuys -#include "pitch.hh" + LilyPond is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. -Lyric_combine_music::Lyric_combine_music () - : Music () -{ -} + LilyPond is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. -Moment -Lyric_combine_music::get_length () const -{ - return get_music ()->get_length (); -} + You should have received a copy of the GNU General Public License + along with LilyPond. If not, see . +*/ -Music* -Lyric_combine_music::get_music () const -{ - SCM l = get_property ("elements"); - if (!scm_is_pair (l)) - return 0; - return unsmob_music (scm_car (l)); -} +#include "music.hh" +struct Lyric_combine_music +{ +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);