]> git.donarmstrong.com Git - lilypond.git/blobdiff - lily/include/collision.hh
release: 1.3.18
[lilypond.git] / lily / include / collision.hh
index 62cee06041d52a641664141ef1250eb34335a5ab..f17e4378342cbfdc0d4039ec0380d7c99ea54ee4 100644 (file)
@@ -3,29 +3,36 @@
 
   source file of the GNU LilyPond music typesetter
 
-  (c) 1997 Han-Wen Nienhuys <hanwen@stack.nl>
+  (c)  1997--1999 Han-Wen Nienhuys <hanwen@cs.uu.nl>
 */
 
 
 #ifndef COLLISION_HH
 #define COLLISION_HH
 #include "lily-proto.hh"
-#include "item.hh"
+#include "axis-group-item.hh"
+#include "tuple.hh"
 
-/** TODO 
+//junkme, use SCM conses.
+typedef Tuple<Score_element*, Real> Shift_tup;
+
+/**
+  Resolve conflicts between various Note_columns (chords).
+  
+  TODO 
 
   multistaff support (see Chlapik: equal noteheads should be on the
   same hpos.)  
 */
-class Collision : public Item {
+class Collision : public Axis_group_item {
 protected:
-    virtual void do_substitute_dependency(Score_elem*,Score_elem*);
-    virtual void do_pre_processing();
+  Array<Shift_tup> automatic_shift ();
+  Array<Shift_tup> forced_shift ();
+  
+  virtual void do_pre_processing();
 public:
-    Link_array<Note_column> clash_l_arr_;
-    NAME_MEMBERS();
-    void add (Note_column*ncol_l);
-    Collision();
     
+  void add_column (Note_column*ncol_l);
+  Collision();
 };
 #endif // COLLISION_HH