X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Ffigured-bass-engraver.cc;h=8c001bb4dbc6795f464d6690580ce05001ed17fc;hb=ea20c95eec3f834ef7d63da4c31bf23bcd80ff28;hp=d5bb6aad248d6fe963d26a526ffbd27ab5bc9792;hpb=947454c5cc430a9627262de4f25274a64789d3c2;p=lilypond.git diff --git a/lily/figured-bass-engraver.cc b/lily/figured-bass-engraver.cc index d5bb6aad24..8c001bb4db 100644 --- a/lily/figured-bass-engraver.cc +++ b/lily/figured-bass-engraver.cc @@ -1,15 +1,13 @@ -/* -figured-bass-engraver.cc -- implement Figured_bass_engraver +/* + figured-bass-engraver.cc -- implement Figured_bass_engraver -source file of the GNU LilyPond music typesetter + source file of the GNU LilyPond music typesetter -(c) 2002--2004 Han-Wen Nienhuys - - */ + (c) 2002--2005 Han-Wen Nienhuys +*/ #include "engraver.hh" #include "text-item.hh" -#include "event.hh" #include "item.hh" #include "context.hh" @@ -18,16 +16,15 @@ class Figured_bass_engraver : public Engraver TRANSLATOR_DECLARATIONS (Figured_bass_engraver); protected: Link_array figures_; - Music * rest_req_; + Music *rest_req_; + + Grob *figure_; - Grob * figure_; - - virtual bool try_music (Music*); + virtual bool try_music (Music *); virtual void stop_translation_timestep (); virtual void process_music (); }; - Figured_bass_engraver::Figured_bass_engraver () { figure_ = 0; @@ -37,18 +34,14 @@ Figured_bass_engraver::Figured_bass_engraver () void Figured_bass_engraver::stop_translation_timestep () { - if (figure_) - { - typeset_grob (figure_); - figure_ = 0; - } + figure_ = 0; figures_.clear (); rest_req_ = 0; } bool -Figured_bass_engraver::try_music (Music*m) +Figured_bass_engraver::try_music (Music *m) { if (m->is_mus_type ("bass-figure-event")) { @@ -68,34 +61,32 @@ Figured_bass_engraver::process_music () { if (rest_req_) { - figure_ = make_item ("BassFigure"); - announce_grob (figure_, rest_req_->self_scm ()); // todo - figure_->set_property ("text" , scm_makfrom0str ("-")); + figure_ = make_item ("BassFigure", rest_req_->self_scm ()); + figure_->set_property ("text", scm_makfrom0str ("-")); } else if (figures_.size ()) { SCM proc = get_property ("bassFigureFormatFunction"); - if (gh_procedure_p (proc)) + if (ly_c_procedure_p (proc)) { SCM l = SCM_EOL; - - for (int i = 0; i self_scm (), l); - - SCM markup = scm_call_2 (proc, l, daddy_context_->self_scm ()); - - figure_ = make_item ("BassFigure"); - figure_->set_property ("text", markup); - announce_grob (figure_, figures_[0]->self_scm ()); // todo + SCM *t = &l; + for (int i = 0; i < figures_.size (); i++) + { + *t = scm_cons (figures_[i]->self_scm (), SCM_EOL); + t = SCM_CDRLOC (*t); + } + figure_ = make_item ("BassFigure", figures_[0]->self_scm ()); + scm_call_3 (proc, l, context ()->self_scm (), + figure_->self_scm ()); } } } - -ENTER_DESCRIPTION (Figured_bass_engraver, -/* descr */ "Make figured bass numbers.", -/* creats*/ "BassFigure", -/* accepts */ "rest-event bass-figure-event", -/* acks */ "", -/* reads */ "bassFigureFormatFunction", -/* write */ ""); +ADD_TRANSLATOR (Figured_bass_engraver, + /* descr */ "Make figured bass numbers.", + /* creats*/ "BassFigure", + /* accepts */ "rest-event bass-figure-event", + /* acks */ "", + /* reads */ "bassFigureFormatFunction", + /* write */ "");