]> git.donarmstrong.com Git - lilypond.git/blobdiff - lily/include/spanner.hh
release: 1.3.38
[lilypond.git] / lily / include / spanner.hh
index 08c7f361f32e50d7f65fdc0465e6e36d4b69b1f1..2a50a826b2d986719502650e0ae2382c30888d7c 100644 (file)
@@ -1,7 +1,7 @@
 /*
   spanner.hh -- part of GNU LilyPond
 
-  (c) 1996--1999 Han-Wen Nienhuys
+  (c) 1996--2000 Han-Wen Nienhuys
 */
 
 #ifndef SPANNER_HH
 #include "drul-array.hh"
 #include "rod.hh"
 
-
-class Axis_group_spanner;
 /** A symbol which is attached between two columns. A spanner is a
   symbol which spans across several columns, so its final appearance
   can only be calculated after the breaking problem is solved.
 
   Examples
 
-  \begin{itemize}
-  \item (de)crescendo
-  \item slur
-  \item beam
-  \item bracket
-  \end{itemize}
-  
+  * (de)crescendo
+  * slur
+  * beam
+  * bracket
 
   Spanner should know about the items which it should consider:
   e.g. slurs should be steep enough to "enclose" all those items. This
@@ -34,12 +29,16 @@ class Axis_group_spanner;
   length of stems of notes they encompass.
 
   */
-class Spanner : public virtual Score_element {
-public:
+class Spanner : public  Score_element {
   Drul_array<Item*> spanned_drul_;
+
+public:
   Link_array<Spanner> broken_into_l_arr_;
-  void set_bounds (Direction d, Item*);
 
+  // TODO: make virtual and do this for Items as well.
+  Interval_t<int> spanned_rank_iv ();
+  void set_bound (Direction d, Item*);
+  Item *get_bound (Direction d) const;
   
   Spanner ();
   Spanner (Spanner const &);
@@ -53,17 +52,9 @@ public:
 protected:
   void set_my_columns ();
   VIRTUAL_COPY_CONS(Score_element);
-
-  /**
-    this is virtual; for instance, Line_of_score overrides it.
-    */
-  virtual void break_into_pieces ();
   Real get_broken_left_end_align () const;
 
-  friend Axis_group_spanner; // UGH
-
   virtual void do_space_processing ();
-  //  void handle_broken_dependents ();
   virtual void do_break_processing ();
   Real spanner_length () const;
   virtual Line_of_score*line_l () const;