]> git.donarmstrong.com Git - lilypond.git/blob - lily/note-name-engraver.cc
*** empty log message ***
[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 #include "stream-event.hh"
12
13 #include "translator.icc"
14
15 class Note_name_engraver : public Engraver
16 {
17 public:
18   TRANSLATOR_DECLARATIONS (Note_name_engraver);
19
20   vector<Stream_event*> events_;
21   vector<Item*> texts_;
22   DECLARE_TRANSLATOR_LISTENER (note);
23   void process_music ();
24   void stop_translation_timestep ();
25 };
26
27 IMPLEMENT_TRANSLATOR_LISTENER (Note_name_engraver, note);
28 void
29 Note_name_engraver::listen_note (Stream_event *ev)
30 {
31   events_.push_back (ev);
32 }
33
34 void
35 Note_name_engraver::process_music ()
36 {
37   string s;
38   for (vsize i = 0; i < events_.size (); i++)
39     {
40       if (i)
41         s += " ";
42       Pitch p = *unsmob_pitch (events_[i]->get_property ("pitch"));
43
44       if (!to_boolean (get_property ("printOctaveNames")))
45         p = Pitch (-1, p.get_notename (), p.get_alteration ());
46
47       s += p.to_string ();
48     }
49   if (s.length ())
50     {
51       Item *t = make_item ("NoteName", events_[0]->self_scm ());
52       t->set_property ("text", scm_makfrom0str (s.c_str ()));
53       texts_.push_back (t);
54     }
55 }
56
57 void
58 Note_name_engraver::stop_translation_timestep ()
59 {
60   texts_.clear ();
61   events_.clear ();
62 }
63
64 Note_name_engraver::Note_name_engraver ()
65 {
66 }
67
68 ADD_TRANSLATOR (Note_name_engraver,
69                 /* doc */ "",
70                 /* create */ "NoteName",
71                 /* accept */ "note-event",
72                 /* read */ "printOctaveNames",
73                 /* write */ "");