]> git.donarmstrong.com Git - lilypond.git/blobdiff - lily/include/spanner.hh
2003 -> 2004
[lilypond.git] / lily / include / spanner.hh
index 63274734bd300594ef8da948fba3783e2d7876dc..40617f18e131b8fe1028f8a924488b701b7aaaf2 100644 (file)
@@ -1,7 +1,7 @@
 /*
   spanner.hh -- part of GNU LilyPond
 
-  (c) 1996--2002 Han-Wen Nienhuys
+  (c) 1996--2004 Han-Wen Nienhuys
 */
 
 #ifndef SPANNER_HH
   */
 class Spanner : public  Grob {
   Drul_array<Item*> spanned_drul_;
-
+  int break_index_;
+  
 public:
   DECLARE_SCHEME_CALLBACK (set_spacing_rods, (SCM));
   
-  Link_array<Spanner> broken_into_l_arr_;
+  Link_array<Spanner> broken_intos_;
 
+  int get_break_index () const;
   // todo: move to somewhere else.
   Real get_broken_left_end_align () const;
-  
+  void substitute_one_mutable_property (SCM sym, SCM val)  ;
+  bool fast_fubstitute_grob_list (SCM sym, SCM grob_list);
   // TODO: make virtual and do this for Items as well.
   Interval_t<int> spanned_rank_iv ();
   void set_bound (Direction d, Grob*);
@@ -53,18 +56,18 @@ public:
 
   static int compare (Spanner * const &,Spanner * const &);
   virtual Grob* find_broken_piece (System*) const;
-  virtual SCM do_derived_mark ();
+  virtual SCM do_derived_mark () const;
   static bool has_interface (Grob*);
+  virtual System *get_system () const;
 protected:
   void set_my_columns ();
 
   VIRTUAL_COPY_CONS (Grob);
   virtual void do_break_processing ();
-  virtual System *get_system () const;
 };
 
-
 void add_bound_item (Spanner*, Grob*);
 ///DECLARE_UNSMOB (Spanner, spanner);
 
+int broken_spanner_index (Spanner * sp);
 #endif