X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Fstaff-symbol-engraver.cc;h=5d5acd9a4285addc9213e70fe4b9d63c98d1394c;hb=3af2bf4ef314f540a53832c6651e6c56333a37d1;hp=3bb94567713d49c31e43369cad1445768e60d999;hpb=8a28f0429e9ce4ce7258156d62261b939edd72d1;p=lilypond.git diff --git a/lily/staff-symbol-engraver.cc b/lily/staff-symbol-engraver.cc index 3bb9456771..5d5acd9a42 100644 --- a/lily/staff-symbol-engraver.cc +++ b/lily/staff-symbol-engraver.cc @@ -1,94 +1,162 @@ /* - staff-sym-reg.cc -- implement Staff_symbol_engraver + staff-symbol-engraver.cc -- implement Staff_symbol_engraver source file of the GNU LilyPond music typesetter - (c) 1997--1999 Han-Wen Nienhuys + (c) 1997--2007 Han-Wen Nienhuys */ -#include "staff-symbol.hh" -#include "score.hh" -#include "paper-column.hh" -#include "paper-def.hh" -#include "side-position-interface.hh" #include "engraver.hh" -#include "moment.hh" +#include "international.hh" +#include "spanner.hh" +#include "stream-event.hh" +#include "warn.hh" -/** - Manage the staff symbol. - */ -class Staff_symbol_engraver : public Engraver { - Staff_symbol *span_p_; +#include "translator.icc" + +class Staff_symbol_engraver : public Engraver +{ public: - VIRTUAL_COPY_CONS(Translator); - Staff_symbol_engraver(); - + TRANSLATOR_DECLARATIONS (Staff_symbol_engraver); + protected: - virtual ~Staff_symbol_engraver(); + Drul_array span_events_; + Spanner *span_; + Spanner *finished_span_; + bool first_start_; - virtual void acknowledge_element (Score_element_info); - virtual void do_removal_processing(); - virtual void do_creation_processing(); - +protected: + virtual void start_spanner (); + virtual void stop_spanner (); + + void stop_translation_timestep (); + virtual ~Staff_symbol_engraver (); + DECLARE_ACKNOWLEDGER (grob); + DECLARE_TRANSLATOR_LISTENER (staff_span); + virtual void finalize (); + void process_music (); }; - -Staff_symbol_engraver::~Staff_symbol_engraver() +Staff_symbol_engraver::~Staff_symbol_engraver () { - assert (!span_p_); + assert (!span_); } -Staff_symbol_engraver::Staff_symbol_engraver() +Staff_symbol_engraver::Staff_symbol_engraver () { - span_p_ = 0; + finished_span_ = 0; + first_start_ = true; + span_ = 0; + span_events_[LEFT] = 0; + span_events_[RIGHT] = 0; } +IMPLEMENT_TRANSLATOR_LISTENER (Staff_symbol_engraver, staff_span); void -Staff_symbol_engraver::do_creation_processing() +Staff_symbol_engraver::listen_staff_span (Stream_event *ev) { - span_p_ = new Staff_symbol; - span_p_->set_bounds(LEFT,get_staff_info().command_pcol_l ()); - announce_element (Score_element_info (span_p_, 0)); + Direction d = to_dir (ev->get_property ("span-direction")); + if (d) + ASSIGN_EVENT_ONCE (span_events_[d], ev); + else + programming_error (_ ("staff-span event has no direction")); } void -Staff_symbol_engraver::do_removal_processing() +Staff_symbol_engraver::process_music () { - SCM l (get_property ("numberOfStaffLines", 0)); - if (gh_number_p(l)) + if (span_events_[STOP]) { - span_p_->no_lines_i_ = gh_scm2int (l); + finished_span_ = span_; + span_ = 0; + if (first_start_) + first_start_ = false; } - SCM sz (get_property ("staffLineLeading", 0)); - if (gh_number_p(sz)) + if (span_events_[START] + || (first_start_ && !span_events_[STOP])) + start_spanner (); +} + +void +Staff_symbol_engraver::start_spanner () +{ + if (!span_) { - span_p_->staff_space_ = gh_scm2double (sz); + span_ = make_spanner ("StaffSymbol", SCM_EOL); + span_->set_bound (LEFT, + unsmob_grob (get_property ("currentCommandColumn"))); } - else +} + +void +Staff_symbol_engraver::stop_spanner () +{ + if (!finished_span_) + return; + + if (!finished_span_->get_bound (RIGHT)) + finished_span_->set_bound (RIGHT, unsmob_grob (get_property ("currentCommandColumn"))); + + announce_end_grob (finished_span_, + span_events_[STOP] + ? span_events_[STOP]->self_scm () + : SCM_EOL); + + finished_span_ = 0; +} + +void +Staff_symbol_engraver::stop_translation_timestep () +{ + if ((span_events_[START] || first_start_) + && span_) { - span_p_->staff_space_ = paper_l ()->get_var ("interline"); + first_start_ = false; } - span_p_->set_bounds(RIGHT,get_staff_info().command_pcol_l ()); - typeset_element (span_p_); - span_p_ =0; + + span_events_[START] = 0; + span_events_[STOP] = 0; + stop_spanner (); } void -Staff_symbol_engraver::acknowledge_element (Score_element_info s) +Staff_symbol_engraver::finalize () { - s.elem_l_->set_elt_property ("staff-symbol", span_p_->self_scm_); - s.elem_l_->add_dependency (span_p_); // UGH. UGH. UGH + finished_span_ = span_; + span_ = 0; + stop_spanner (); +} - SCM ss =s.elem_l_->remove_elt_property ("staff-support"); - if (gh_boolean_p (ss) && gh_scm2bool (ss)) +/* + Todo: staff-symbol-referencer iface. +*/ +void +Staff_symbol_engraver::acknowledge_grob (Grob_info s) +{ + /* + Perhaps should try to take SeparationItem as bound of the staff + symbol? + */ + if (span_ || finished_span_) { - Side_position_interface si (s.elem_l_); - if (si.has_interface_b ()) - si.add_support (span_p_); + Spanner *my = span_ ? span_ : finished_span_; + s.grob ()->set_object ("staff-symbol", my->self_scm ()); } } +ADD_ACKNOWLEDGER (Staff_symbol_engraver, grob); + +ADD_TRANSLATOR (Staff_symbol_engraver, + /* doc */ + "Create the constellation of five (default) staff lines.", + + /* create */ + "StaffSymbol ", -ADD_THIS_TRANSLATOR(Staff_symbol_engraver); + /* read */ + "", + /* write */ + "" + );