X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Fnote-name-engraver.cc;h=7acf90e419226268f3aa7e5fa4c28336706057d1;hb=5b4b0d6e9a197e8f9eb085b7c2ad78b8be3e5cfc;hp=1e7806e676b9bd05c48d773df02fd97192bf5b00;hpb=baf32731650d510882eeb52d02f4ca0c816c7c29;p=lilypond.git diff --git a/lily/note-name-engraver.cc b/lily/note-name-engraver.cc index 1e7806e676..7acf90e419 100644 --- a/lily/note-name-engraver.cc +++ b/lily/note-name-engraver.cc @@ -1,79 +1,81 @@ -/* - note-name-engraver.cc -- implement Note_name_engraver - +/* + note-name-engraver.cc -- implement Note_name_engraver + source file of the GNU LilyPond music typesetter - - (c) 1999--2002 Han-Wen Nienhuys - - */ + + (c) 1999--2008 Han-Wen Nienhuys +*/ #include "engraver.hh" -#include "musical-request.hh" #include "item.hh" +#include "pitch.hh" +#include "stream-event.hh" + +#include "translator.icc" class Note_name_engraver : public Engraver { public: - TRANSLATOR_DECLARATIONS(Note_name_engraver); + TRANSLATOR_DECLARATIONS (Note_name_engraver); - Link_array reqs_; - Link_array texts_; - virtual bool try_music (Music*m); - virtual void process_acknowledged_grobs (); - virtual void stop_translation_timestep (); + vector events_; + vector texts_; + DECLARE_TRANSLATOR_LISTENER (note); + void process_music (); + void stop_translation_timestep (); }; -bool -Note_name_engraver::try_music (Music *m) +IMPLEMENT_TRANSLATOR_LISTENER (Note_name_engraver, note); +void +Note_name_engraver::listen_note (Stream_event *ev) { - if (Note_req *r = dynamic_cast (m)) - { - reqs_.push (r); - return true; - } - return false; + events_.push_back (ev); } void -Note_name_engraver::process_acknowledged_grobs () +Note_name_engraver::process_music () { - if (texts_.size ()) - return; - String s ; - for (int i=0; i < reqs_.size (); i++) + string s; + for (vsize i = 0; i < events_.size (); i++) { if (i) s += " "; - s += unsmob_pitch (reqs_[i]->get_mus_property ("pitch"))->string (); + Pitch p = *unsmob_pitch (events_[i]->get_property ("pitch")); + + if (!to_boolean (get_property ("printOctaveNames"))) + p = Pitch (-1, p.get_notename (), p.get_alteration ()); + + s += p.to_string (); } if (s.length ()) { - Item * t = new Item (get_property ("NoteName")); - t->set_grob_property ("text", scm_makfrom0str (s.to_str0 ())); - announce_grob(t, reqs_[0]->self_scm()); - texts_.push (t); + Item *t = make_item ("NoteName", events_[0]->self_scm ()); + t->set_property ("text", ly_string2scm (s)); + texts_.push_back (t); } } void Note_name_engraver::stop_translation_timestep () { - for (int i=0; i < texts_.size (); i++) - { - typeset_grob (texts_[i]); - } - texts_.clear () ; - reqs_.clear (); + texts_.clear (); + events_.clear (); } - -Note_name_engraver::Note_name_engraver() +Note_name_engraver::Note_name_engraver () { } -ENTER_DESCRIPTION(Note_name_engraver, -/* descr */ "", -/* creats*/ "NoteName", -/* acks */ "", -/* reads */ "", -/* write */ ""); +ADD_TRANSLATOR (Note_name_engraver, + /* doc */ + "Print pitches as words.", + + /* create */ + "NoteName ", + + /* read */ + "printOctaveNames ", + + /* write */ + "" + );