X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Flyric-combine-music.cc;h=9cf603a3a4929f70aaef18db2c0a5779f0985c8e;hb=90e4d7057f3857da049dfda3d130017d4719bd6b;hp=8e36faa6747190296c2ac9da5ed56b639fd40e76;hpb=d765f3af45be51f15da55cf570a4b172200e1035;p=lilypond.git diff --git a/lily/lyric-combine-music.cc b/lily/lyric-combine-music.cc index 8e36faa674..9cf603a3a4 100644 --- a/lily/lyric-combine-music.cc +++ b/lily/lyric-combine-music.cc @@ -1,78 +1,35 @@ -/* - lyric-combine-music.cc -- implement Lyric_combine_music - - source file of the GNU LilyPond music typesetter - - (c) 1999--2002 Han-Wen Nienhuys - - */ +/* + This file is part of LilyPond, the GNU music typesetter. -#include "lyric-combine-music.hh" -#include "lyric-combine-music-iterator.hh" -#include "pitch.hh" + Copyright (C) 1999--2015 Han-Wen Nienhuys -Lyric_combine_music::Lyric_combine_music (SCM l) - : Music (l) -{ - set_mus_property ("iterator-ctor", - Lyric_combine_music_iterator::constructor_proc); -} + 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. + 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. -void -Lyric_combine_music::transpose (Pitch p) -{ - get_music ()->transpose (p); - get_lyrics () ->transpose (p); -} + You should have received a copy of the GNU General Public License + along with LilyPond. If not, see . +*/ +#include "music.hh" -Moment -Lyric_combine_music::length_mom () const +struct Lyric_combine_music { - return get_music ()->length_mom (); -} +public: + DECLARE_SCHEME_CALLBACK (length_callback, (SCM)); +}; -Pitch -Lyric_combine_music::to_relative_octave (Pitch p) +MAKE_SCHEME_CALLBACK (Lyric_combine_music, length_callback, 1); +SCM +Lyric_combine_music::length_callback (SCM m) { - p = get_music ()->to_relative_octave (p); - return get_lyrics () ->to_relative_octave (p); + Music *me = unsmob (m); + Music *melody = unsmob (scm_car (me->get_property ("elements"))); + return melody->get_length ().smobbed_copy (); } - -void -Lyric_combine_music::compress (Moment m) -{ - get_music ()->compress (m); -} - - - -Music* -Lyric_combine_music::get_music () const -{ - SCM l = get_mus_property ("elements"); - if (!gh_pair_p (l)) - return 0; - return unsmob_music (gh_car (l)); -} - - -Music* -Lyric_combine_music::get_lyrics () const -{ - 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);