X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Flyric-performer.cc;h=db78f744fe32017ee62d1282c1963066fbaff473;hb=a2991295b2c1fb36bec19de207161855ca3c1756;hp=4569505c4adb4738c0a6a2b682f1b70c9fe05fe7;hpb=f988425624a6f6d1a48aea0ac0c1c84ff0857e56;p=lilypond.git diff --git a/lily/lyric-performer.cc b/lily/lyric-performer.cc index 4569505c4a..db78f744fe 100644 --- a/lily/lyric-performer.cc +++ b/lily/lyric-performer.cc @@ -3,12 +3,30 @@ source file of the GNU LilyPond music typesetter - (c) 1997--2000 Jan Nieuwenhuizen + (c) 1997--2001 Jan Nieuwenhuizen */ -#include "lyric-performer.hh" #include "musical-request.hh" #include "audio-item.hh" +#include "lily-proto.hh" +#include "performer.hh" +#include "array.hh" + +class Lyric_performer : public Performer { +public: + VIRTUAL_COPY_CONS (Translator); + Lyric_performer (); + +protected: + + virtual bool try_music (Music* req_l); + virtual void stop_translation_timestep (); + virtual void create_audio_elements (); + +private: + Link_array lreq_arr_; + Audio_text* audio_p_; +}; ADD_THIS_TRANSLATOR (Lyric_performer); @@ -19,30 +37,34 @@ Lyric_performer::Lyric_performer () void -Lyric_performer::do_process_music () +Lyric_performer::create_audio_elements () { - if (lreq_arr_.size () && lreq_arr_[0]->text_str_.length_i ()) + // FIXME: won't work with fancy lyrics + if (lreq_arr_.size () + && gh_string_p (lreq_arr_[0]->get_mus_property ("text")) + && ly_scm2string (lreq_arr_[0]->get_mus_property ("text")).length_i ()) { - audio_p_ = new Audio_text (Audio_text::LYRIC, lreq_arr_[0]->text_str_); + audio_p_ = new Audio_text (Audio_text::LYRIC, + ly_scm2string (lreq_arr_[0]->get_mus_property ("text"))); Audio_element_info info (audio_p_, lreq_arr_[0]); announce_element (info); } - lreq_arr_.clear(); + lreq_arr_.clear (); } void -Lyric_performer::do_pre_move_processing () +Lyric_performer::stop_translation_timestep () { if (audio_p_) { play_element (audio_p_); audio_p_ = 0; } - lreq_arr_.clear(); + lreq_arr_.clear (); } bool -Lyric_performer::do_try_music (Music* req_l) +Lyric_performer::try_music (Music* req_l) { if (Lyric_req *lr = dynamic_cast (req_l)) {