X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Ftime-signature-engraver.cc;h=e4e76e17d685154c2868ab75c2efd8d8feae5dbe;hb=97a0169312a260933246ab224e4f8b0969871dd5;hp=8c444e57471d86cd13ecfc1ed5d7d1063b789e3e;hpb=78c9194fe61a9cbe372b12ec5125779acf706a77;p=lilypond.git diff --git a/lily/time-signature-engraver.cc b/lily/time-signature-engraver.cc index 8c444e5747..e4e76e17d6 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 @@ -22,8 +22,8 @@ #include "item.hh" #include "international.hh" #include "misc.hh" +#include "moment.hh" #include "stream-event.hh" -#include "time-signature.hh" #include "warn.hh" #include "translator.icc" @@ -43,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 @@ -53,14 +53,14 @@ Time_signature_engraver::derived_mark () const scm_gc_mark (time_cause_); } -Time_signature_engraver::Time_signature_engraver () +Time_signature_engraver::Time_signature_engraver (Context *c) + : Engraver (c) { time_signature_ = 0; time_cause_ = SCM_EOL; last_time_fraction_ = SCM_BOOL_F; } -IMPLEMENT_TRANSLATOR_LISTENER (Time_signature_engraver, time_signature); void Time_signature_engraver::listen_time_signature (Stream_event *ev) { @@ -70,11 +70,19 @@ Time_signature_engraver::listen_time_signature (Stream_event *ev) void Time_signature_engraver::process_music () { + if (time_signature_) + return; + SCM fr = get_property ("timeSignatureFraction"); - if (!time_signature_ - && last_time_fraction_ != fr - && scm_is_pair (fr)) + if (!scm_is_eq (last_time_fraction_, fr) && scm_is_pair (fr)) { + time_signature_ = make_item ("TimeSignature", time_cause_); + time_signature_->set_property ("fraction", fr); + + if (scm_is_false (last_time_fraction_)) + time_signature_->set_property ("break-visibility", + get_property ("initialTimeSignatureVisibility")); + int den = scm_to_int (scm_cdr (fr)); if (den != (1 << intlog2 (den))) { @@ -83,18 +91,11 @@ Time_signature_engraver::process_music () OTOH, Tristan Keuris writes 8/20 in his Intermezzi. */ - warning (_f ("strange time signature found: %d/%d", - int (scm_to_int (scm_car (fr))), - den)); + time_signature_->warning (_f ("strange time signature found: %d/%d", + int (scm_to_int (scm_car (fr))), + den)); } - time_signature_ = make_item ("TimeSignature", time_cause_); - time_signature_->set_property ("fraction", fr); - - if (last_time_fraction_ == SCM_BOOL_F) - time_signature_->set_property ("break-visibility", - get_property ("implicitTimeSignatureVisibility")); - last_time_fraction_ = fr; } } @@ -102,11 +103,23 @@ Time_signature_engraver::process_music () void Time_signature_engraver::stop_translation_timestep () { + if (time_signature_ && !scm_is_null (time_cause_)) + { + 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"); + } + time_signature_ = 0; 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 */ @@ -117,7 +130,8 @@ ADD_TRANSLATOR (Time_signature_engraver, "TimeSignature ", /* read */ - "implicitTimeSignatureVisibility " + "initialTimeSignatureVisibility " + "partialBusy " "timeSignatureFraction ", /* write */