X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;ds=sidebyside;f=lily%2Flyric-performer.cc;h=db78f744fe32017ee62d1282c1963066fbaff473;hb=54404c570a48ddf9772c5ca64a154d0c0149e61e;hp=81014b9d5df526522d8042636c1eb4669c320ac6;hpb=6a0ea5e307744ad53d8b4a7381f2b27c2cfc9c13;p=lilypond.git diff --git a/lily/lyric-performer.cc b/lily/lyric-performer.cc index 81014b9d5d..db78f744fe 100644 --- a/lily/lyric-performer.cc +++ b/lily/lyric-performer.cc @@ -3,55 +3,74 @@ source file of the GNU LilyPond music typesetter - (c) 1997 Jan Nieuwenhuizen + (c) 1997--2001 Jan Nieuwenhuizen */ -#include "lyric-performer.hh" -#include "text-def.hh" #include "musical-request.hh" -#include "midi-item.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 (); -IMPLEMENT_STATIC_NAME(Lyric_performer); -IMPLEMENT_IS_TYPE_B1(Lyric_performer,Performer); -ADD_THIS_PERFORMER(Lyric_performer); +protected: -Lyric_performer::Lyric_performer() -{ -} + 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_; +}; -Lyric_performer::~Lyric_performer() +ADD_THIS_TRANSLATOR (Lyric_performer); + +Lyric_performer::Lyric_performer () { + audio_p_ = 0; } -void -Lyric_performer::do_print() const + +void +Lyric_performer::create_audio_elements () { -#ifndef NPRINT - if ( lreq_arr_.size() ) - lreq_arr_[ 0 ]->print(); -#endif + // 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, + ly_scm2string (lreq_arr_[0]->get_mus_property ("text"))); + Audio_element_info info (audio_p_, lreq_arr_[0]); + announce_element (info); + } + lreq_arr_.clear (); } void -Lyric_performer::process_requests() +Lyric_performer::stop_translation_timestep () { - if ( lreq_arr_.size() ) { - Midi_text t( Midi_text::LYRIC, lreq_arr_[ 0 ]->tdef_p_->text_str_ ); - play_event( &t ); + if (audio_p_) + { + play_element (audio_p_); + audio_p_ = 0; } - - lreq_arr_.clear(); + lreq_arr_.clear (); } bool -Lyric_performer::try_request( Request* req_l ) +Lyric_performer::try_music (Music* req_l) { - Musical_req* m_l = req_l->musical(); - if ( !m_l || ! m_l->lreq_l() ) - return false; - lreq_arr_.push( m_l->lreq_l() ); - - return true; + if (Lyric_req *lr = dynamic_cast (req_l)) + { + lreq_arr_.push (lr); + return true; + } + return false; }