X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Ftime-signature-performer.cc;h=3d348931a49d02288651aa71445ddd864be00055;hb=5b4b0d6e9a197e8f9eb085b7c2ad78b8be3e5cfc;hp=aeed66b8068da901e47692ff22e45fbc0db73fdb;hpb=fbb6d20e9f58d691ffe845284cbb4d8bacf9ca60;p=lilypond.git diff --git a/lily/time-signature-performer.cc b/lily/time-signature-performer.cc index aeed66b806..3d348931a4 100644 --- a/lily/time-signature-performer.cc +++ b/lily/time-signature-performer.cc @@ -3,69 +3,83 @@ source file of the GNU LilyPond music typesetter - (c) 1997--2000 Jan Nieuwenhuizen + (c) 1997--2008 Jan Nieuwenhuizen */ -#include "time-signature-performer.hh" -#include "command-request.hh" #include "audio-item.hh" +#include "performer.hh" +#include "protected-scm.hh" -ADD_THIS_TRANSLATOR (Time_signature_performer); +class Time_signature_performer : public Performer +{ +public: + TRANSLATOR_DECLARATIONS (Time_signature_performer); + ~Time_signature_performer (); -Time_signature_performer::Time_signature_performer () +protected: + + void stop_translation_timestep (); + void process_music (); + virtual void derived_mark () const; + SCM prev_fraction_; +private: + + Audio_time_signature *audio_; +}; + +void +Time_signature_performer::derived_mark () const { - time_signature_req_l_ = 0; - audio_p_ = 0; + scm_gc_mark (prev_fraction_); } -Time_signature_performer::~Time_signature_performer () +Time_signature_performer::Time_signature_performer () { + prev_fraction_ = SCM_BOOL_F; + audio_ = 0; } -void -Time_signature_performer::do_print () const +Time_signature_performer::~Time_signature_performer () { -#ifndef NPRINT - if (time_signature_req_l_) - time_signature_req_l_->print (); -#endif } void -Time_signature_performer::do_process_music () +Time_signature_performer::process_music () { - if (time_signature_req_l_) + SCM fr = get_property ("timeSignatureFraction"); + if (scm_is_pair (fr) && !ly_is_equal (fr, prev_fraction_)) { - audio_p_ = new Audio_time_signature (time_signature_req_l_->beats_i_, time_signature_req_l_->one_beat_i_); - Audio_element_info info (audio_p_, time_signature_req_l_); + prev_fraction_ = fr; + int b = scm_to_int (scm_car (fr)); + int o = scm_to_int (scm_cdr (fr)); + + audio_ = new Audio_time_signature (b, o); + Audio_element_info info (audio_, 0); announce_element (info); - time_signature_req_l_ = 0; } } void -Time_signature_performer::do_pre_move_processing () +Time_signature_performer::stop_translation_timestep () { - if (audio_p_) + if (audio_) { - play_element (audio_p_); - audio_p_ = 0; + audio_ = 0; } } -bool -Time_signature_performer::do_try_music (Music* req_l) -{ - if (time_signature_req_l_) - return false; +#include "translator.icc" - if (Time_signature_change_req *t = - dynamic_cast (req_l)) - { - time_signature_req_l_ = t; - return true; - } +ADD_TRANSLATOR (Time_signature_performer, + /* doc */ + "", - return false; -} + /* create */ + "", + + /* read */ + "", + /* write */ + "" + );