]> git.donarmstrong.com Git - lilypond.git/blobdiff - lily/note-name-engraver.cc
Fix some bugs in the dynamic engraver and PostScript backend
[lilypond.git] / lily / note-name-engraver.cc
index df2c4872143ba67e697c69f43865798de11e026b..585eb1fae208abd700f643aeda59ad6125d929a2 100644 (file)
@@ -1,67 +1,76 @@
-/*   
-  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--2000 Han-Wen Nienhuys <hanwen@cs.uu.nl>
-  
- */
+
+  (c) 1999--2006 Han-Wen Nienhuys <hanwen@xs4all.nl>
+*/
 
 #include "engraver.hh"
-#include "musical-request.hh"
 #include "item.hh"
 
 class Note_name_engraver : public Engraver
 {
 public:
-  VIRTUAL_COPY_CONS(Translator);
-  Link_array<Note_req> req_l_arr_;
-  Link_array<Item> texts_;
-  virtual bool  do_try_music (Music*m);
-  virtual void do_process_music ();
-  virtual void do_pre_move_processing ();
+  TRANSLATOR_DECLARATIONS (Note_name_engraver);
+
+  vector<Music*> events_;
+  vector<Item*> texts_;
+  virtual bool try_music (Music *m);
+  void process_music ();
+  void stop_translation_timestep ();
 };
 
 bool
-Note_name_engraver::do_try_music (Music *m)
+Note_name_engraver::try_music (Music *m)
 {
-  if (Note_req *r = dynamic_cast<Note_req* > (m))
+  if (m->is_mus_type ("note-event"))
     {
-      req_l_arr_.push (r);
+      events_.push_back (m);
       return true;
     }
   return false;
 }
 
-
 void
-Note_name_engraver::do_process_music ()
+Note_name_engraver::process_music ()
 {
-  String s ;
-  for (int i=0; i < req_l_arr_.size (); i++)
+  string s;
+  for (vsize i = 0; i < events_.size (); i++)
     {
       if (i)
        s += " ";
-      s += req_l_arr_[i]->pitch_.str ();
+      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_i())
+  if (s.length ())
     {
-      Item * t = new Item (get_property ("NoteName"));
-      t->set_elt_property ("text", ly_str02scm ( s.ch_C()));
-      announce_element (t, req_l_arr_[0]);
-      texts_.push (t);
+      Item *t = make_item ("NoteName", events_[0]->self_scm ());
+      t->set_property ("text", scm_makfrom0str (s.c_str ()));
+      texts_.push_back (t);
     }
 }
 
 void
-Note_name_engraver::do_pre_move_processing ()
+Note_name_engraver::stop_translation_timestep ()
+{
+  texts_.clear ();
+  events_.clear ();
+}
+
+Note_name_engraver::Note_name_engraver ()
 {
-  for (int i=0; i < texts_.size (); i++)
-    {
-      typeset_element (texts_[i]);
-    }
-  texts_.clear() ;
-  req_l_arr_.clear ();
 }
 
-ADD_THIS_TRANSLATOR(Note_name_engraver);
+#include "translator.icc"
+
+ADD_TRANSLATOR (Note_name_engraver,
+               /* doc */ "",
+               /* create */ "NoteName",
+               /* accept */ "note-event",
+               /* read */ "printOctaveNames",
+               /* write */ "");