]> git.donarmstrong.com Git - lilypond.git/blobdiff - lily/rod.cc
* lily/ledger-line-spanner.cc (print): swap linear_combination
[lilypond.git] / lily / rod.cc
index 621fd15de231fb93078ed9981d30809c74a67eae..f86fc4e112bcf363035404bb0d9cb7e217d60409 100644 (file)
@@ -3,18 +3,18 @@
   
   source file of the GNU LilyPond music typesetter
   
-  (c) 1998--2000 Han-Wen Nienhuys <hanwen@cs.uu.nl>
+  (c) 1998--2004 Han-Wen Nienhuys <hanwen@cs.uu.nl>
   
  */
 #include "rod.hh"
 #include "paper-column.hh"
-#include "debug.hh"
+#include "warn.hh"
 #include "dimensions.hh"
-#include "spaceable-element.hh"
+#include "spaceable-grob.hh"
 
 Rod::Rod ()
 {
-  distance_f_ = 0.0;
+  distance_ = 0.0;
   item_l_drul_[LEFT] = item_l_drul_[RIGHT] =0;
 }
 
@@ -23,10 +23,14 @@ Rod::Rod ()
 void
 Rod::columnize ()
 {
+  if (!item_l_drul_[LEFT]
+      || !item_l_drul_[RIGHT])
+    return ;
+  
   Direction d = LEFT;
   do {
-    Paper_column * pc = item_l_drul_[d]->column_l ();
-    distance_f_ += - d * item_l_drul_[d]->relative_coordinate (pc, X_AXIS);
+    Paper_column * pc = item_l_drul_[d]->get_column ();
+    distance_ += - d * item_l_drul_[d]->relative_coordinate (pc, X_AXIS);
     item_l_drul_[d] = pc;
   } while ((flip (&d))!=LEFT);
 
@@ -35,10 +39,11 @@ Rod::columnize ()
 void
 Rod::add_to_cols ()
 {
-  columnize();
-  if (item_l_drul_[LEFT] != item_l_drul_[RIGHT])
-    Spaceable_element::add_rod (item_l_drul_[LEFT],
-                               item_l_drul_[RIGHT],
-                               distance_f_ );
+  columnize ();
+  if (item_l_drul_[LEFT] != item_l_drul_[RIGHT]
+      && item_l_drul_[LEFT] && item_l_drul_[RIGHT])
+    Spaceable_grob::add_rod (item_l_drul_[LEFT],
+                            item_l_drul_[RIGHT],
+                            distance_);
 }