]> git.donarmstrong.com Git - lilypond.git/blob - lily/note-name-engraver.cc
* The grand 2005-2006 replace.
[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--2006 Han-Wen Nienhuys <hanwen@xs4all.nl>
7 */
8
9 #include "engraver.hh"
10 #include "item.hh"
11
12 class Note_name_engraver : public Engraver
13 {
14 public:
15   TRANSLATOR_DECLARATIONS (Note_name_engraver);
16
17   Link_array<Music> events_;
18   Link_array<Item> texts_;
19   virtual bool try_music (Music *m);
20   void process_music ();
21   void stop_translation_timestep ();
22 };
23
24 bool
25 Note_name_engraver::try_music (Music *m)
26 {
27   if (m->is_mus_type ("note-event"))
28     {
29       events_.push (m);
30       return true;
31     }
32   return false;
33 }
34
35 void
36 Note_name_engraver::process_music ()
37 {
38   String s;
39   for (int i = 0; i < events_.size (); i++)
40     {
41       if (i)
42         s += " ";
43       Pitch p = *unsmob_pitch (events_[i]->get_property ("pitch"));
44
45       if (!to_boolean (get_property ("printOctaveNames")))
46         p = Pitch (-1, p.get_notename (), p.get_alteration ());
47
48       s += p.to_string ();
49     }
50   if (s.length ())
51     {
52       Item *t = make_item ("NoteName", events_[0]->self_scm ());
53       t->set_property ("text", scm_makfrom0str (s.to_str0 ()));
54       texts_.push (t);
55     }
56 }
57
58 void
59 Note_name_engraver::stop_translation_timestep ()
60 {
61   texts_.clear ();
62   events_.clear ();
63 }
64
65 Note_name_engraver::Note_name_engraver ()
66 {
67 }
68
69 #include "translator.icc"
70
71 ADD_TRANSLATOR (Note_name_engraver,
72                 /* doc */ "",
73                 /* create */ "NoteName",
74                 /* accept */ "note-event",
75                 /* read */ "printOctaveNames",
76                 /* write */ "");