X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Ftime-signature-engraver.cc;h=d57b35bf6eae9bb95c04d2d0d1dde3d85c9f6764;hb=158a470615ce4ba973bd9f4891bbe23b8812a4be;hp=38989dc882db6d97595fbed75635f83210994efb;hpb=0fe24db3936774a8fb913cb14c997036db7aeb1c;p=lilypond.git diff --git a/lily/time-signature-engraver.cc b/lily/time-signature-engraver.cc index 38989dc882..d57b35bf6e 100644 --- a/lily/time-signature-engraver.cc +++ b/lily/time-signature-engraver.cc @@ -1,7 +1,7 @@ /* This file is part of LilyPond, the GNU music typesetter. - Copyright (C) 1997--2014 Han-Wen Nienhuys + Copyright (C) 1997--2015 Han-Wen Nienhuys LilyPond is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by @@ -24,7 +24,6 @@ #include "misc.hh" #include "moment.hh" #include "stream-event.hh" -#include "time-signature.hh" #include "warn.hh" #include "translator.icc" @@ -44,7 +43,7 @@ protected: void process_music (); public: TRANSLATOR_DECLARATIONS (Time_signature_engraver); - DECLARE_TRANSLATOR_LISTENER (time_signature); + void listen_time_signature (Stream_event *); }; void @@ -61,7 +60,6 @@ Time_signature_engraver::Time_signature_engraver () last_time_fraction_ = SCM_BOOL_F; } -IMPLEMENT_TRANSLATOR_LISTENER (Time_signature_engraver, time_signature); void Time_signature_engraver::listen_time_signature (Stream_event *ev) { @@ -81,10 +79,9 @@ Time_signature_engraver::process_music () time_signature_ = make_item ("TimeSignature", time_cause_); time_signature_->set_property ("fraction", fr); - // Todo: "implicit" does not seem perfectly accurate (issue 4151) - if (last_time_fraction_ == SCM_BOOL_F) + if (scm_is_false (last_time_fraction_)) time_signature_->set_property ("break-visibility", - get_property ("implicitTimeSignatureVisibility")); + get_property ("initialTimeSignatureVisibility")); int den = scm_to_int (scm_cdr (fr)); if (den != (1 << intlog2 (den))) @@ -106,9 +103,9 @@ Time_signature_engraver::process_music () void Time_signature_engraver::stop_translation_timestep () { - if (time_signature_ && (time_cause_ != SCM_EOL)) + if (time_signature_ && !scm_is_null (time_cause_)) { - Moment *mp = Moment::unsmob (get_property ("measurePosition")); + Moment *mp = unsmob (get_property ("measurePosition")); if (mp && (mp->main_part_ > Rational (0)) && !to_boolean (get_property ("partialBusy"))) time_signature_->warning ("mid-measure time signature without \\partial"); @@ -118,7 +115,11 @@ Time_signature_engraver::stop_translation_timestep () time_cause_ = SCM_EOL; } -#include "translator.icc" +void +Time_signature_engraver::boot () +{ + ADD_LISTENER (Time_signature_engraver, time_signature); +} ADD_TRANSLATOR (Time_signature_engraver, /* doc */ @@ -129,7 +130,7 @@ ADD_TRANSLATOR (Time_signature_engraver, "TimeSignature ", /* read */ - "implicitTimeSignatureVisibility " + "initialTimeSignatureVisibility " "partialBusy " "timeSignatureFraction ",