]> git.donarmstrong.com Git - lilypond.git/blob - lily/note-name-engraver.cc
* lily/engraver-group-engraver.cc (do_announces): rename
[lilypond.git] / lily / note-name-engraver.cc
1 /*   
2   note-name-engraver.cc --  implement Note_name_engraver
3   
4   source file of the GNU LilyPond music typesetter
5   
6   (c) 1999--2002 Han-Wen Nienhuys <hanwen@cs.uu.nl>
7   
8  */
9
10 #include "engraver.hh"
11 #include "musical-request.hh"
12 #include "item.hh"
13
14 class Note_name_engraver : public Engraver
15 {
16 public:
17   TRANSLATOR_DECLARATIONS(Note_name_engraver);
18
19   Link_array<Note_req> req_l_arr_;
20   Link_array<Item> texts_;
21   virtual bool  try_music (Music*m);
22   virtual void process_acknowledged_grobs ();
23   virtual void stop_translation_timestep ();
24 };
25
26 bool
27 Note_name_engraver::try_music (Music *m)
28 {
29   if (Note_req *r = dynamic_cast<Note_req* > (m))
30     {
31       req_l_arr_.push (r);
32       return true;
33     }
34   return false;
35 }
36
37 void
38 Note_name_engraver::process_acknowledged_grobs ()
39 {
40   if (texts_.size ())
41     return;
42   String s ;
43   for (int i=0; i < req_l_arr_.size (); i++)
44     {
45       if (i)
46         s += " ";
47       s += unsmob_pitch (req_l_arr_[i]->get_mus_property ("pitch"))->str ();
48     }
49   if (s.length_i ())
50     {
51       Item * t = new Item (get_property ("NoteName"));
52       t->set_grob_property ("text", ly_str02scm (s.ch_C ()));
53       announce_grob(t, req_l_arr_[0]->self_scm());
54       texts_.push (t);
55     }
56 }
57
58 void
59 Note_name_engraver::stop_translation_timestep ()
60 {
61   for (int i=0; i < texts_.size (); i++)
62     {
63       typeset_grob (texts_[i]);
64     }
65   texts_.clear () ;
66   req_l_arr_.clear ();
67 }
68
69
70 Note_name_engraver::Note_name_engraver()
71 {
72 }
73
74 ENTER_DESCRIPTION(Note_name_engraver,
75 /* descr */       "",
76 /* creats*/       "NoteName",
77 /* acks  */       "",
78 /* reads */       "",
79 /* write */       "");