]> git.donarmstrong.com Git - lilypond.git/blob - lily/collision-engraver.cc
* lily/include/translator.hh (class Translator): remove
[lilypond.git] / lily / collision-engraver.cc
1 /*
2   collision-engraver.cc -- implement Collision_engraver
3
4   source file of the GNU LilyPond music typesetter
5
6   (c) 1997--2005 Han-Wen Nienhuys <hanwen@cs.uu.nl>
7 */
8
9 #include "note-column.hh"
10 #include "note-collision.hh"
11
12 #include "engraver.hh"
13 #include "axis-group-interface.hh"
14
15 class Collision_engraver : public Engraver
16 {
17   Item *col_;
18   Link_array<Grob> note_columns_;
19
20 protected:
21   DECLARE_ACKNOWLEDGER(note_column);
22   void process_acknowledged ();
23   void stop_translation_timestep ();
24 public:
25   TRANSLATOR_DECLARATIONS (Collision_engraver);
26 };
27
28 void
29 Collision_engraver::process_acknowledged ()
30 {
31   if (col_ || note_columns_.size () < 2)
32     return;
33   if (!col_)
34     {
35       col_ = make_item ("NoteCollision", SCM_EOL);
36     }
37
38   for (int i = 0; i < note_columns_.size (); i++)
39     Note_collision_interface::add_column (col_, note_columns_[i]);
40 }
41
42 void
43 Collision_engraver::acknowledge_note_column (Grob_info i)
44 {
45   if (Note_column::has_interface (i.grob ()))
46     {
47       /*should check Y axis? */
48       if (Note_column::has_rests (i.grob ()) || i.grob ()->get_parent (X_AXIS))
49         return;
50
51       note_columns_.push (i.grob ());
52     }
53 }
54
55 void
56 Collision_engraver::stop_translation_timestep ()
57 {
58   col_ = 0;
59   note_columns_.clear ();
60 }
61
62 Collision_engraver::Collision_engraver ()
63 {
64   col_ = 0;
65 }
66
67 #include "translator.icc"
68
69 ADD_ACKNOWLEDGER(Collision_engraver, note_column);
70
71 ADD_TRANSLATOR (Collision_engraver,
72                 /* descr */ "Collect NoteColumns, and as soon as there are two or more, put them in a NoteCollision object.",
73                 /* creats*/ "NoteCollision",
74                 /* accepts */ "",
75                 /* reads */ "",
76                 /* write */ "");