]> git.donarmstrong.com Git - lilypond.git/blobdiff - lily/include/spanner.hh
Fix some bugs in the dynamic engraver and PostScript backend
[lilypond.git] / lily / include / spanner.hh
index 074a555da2c7ab2e02dab150b57b2a6d1f4f4805..c64c61d6364a1f664b8a8fe334b1a32e1586636c 100644 (file)
@@ -1,57 +1,75 @@
 /*
   spanner.hh -- part of GNU LilyPond
 
-  (c) 1996,97 Han-Wen Nienhuys
+  (c) 1996--2006 Han-Wen Nienhuys
 */
 
 #ifndef SPANNER_HH
 #define SPANNER_HH
 
-#include "lily-proto.hh"
-#include "score-elem.hh"
+#include "grob.hh"
+#include "rod.hh"
 
+/** 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.
 
-#define SPANNER_CLONE(T) VIRTUAL_COPY_CONS(T, Spanner)
+    Examples
 
-/** 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.
+    * (de)crescendo
+    * slur
+    * beam
+    * bracket
 
-  Examples
-
-  \begin{itemize}
-  \item (de)crescendo
-  \item slur
-  \item beam
-  \item bracket
-  \end{itemize}
-  
+    Spanner should know about the items which it should consider:
+    e.g. slurs should be steep enough to "enclose" all those items. This
+    is absolutely necessary for beams, since they have to adjust the
+    length of stems of notes they encompass.
+*/
+class Spanner : public Grob
+{
+  Drul_array<Item *> spanned_drul_;
+  vsize break_index_;
 
-  Spanner should know about the items which it should consider:
-  e.g. slurs should be steep enough to "enclose" all those items. This
-  is absolutely necessary for beams, since they have to adjust the
-  length of stems of notes they encompass.
+  DECLARE_CLASSNAME(Spanner);
 
-  */
-class Spanner:public virtual Score_elem {
 public:
-    PCol *left_col_l_, *right_col_l_;
-    
-    /* *************** */
-    NAME_MEMBERS(Spanner);
-    virtual Spanner* spanner() { return this; }    
-    Spanner();
-    bool broken_b() const;
-    Spanner* find_broken_piece(Line_of_score*)const;
+  DECLARE_SCHEME_CALLBACK (set_spacing_rods, (SCM));
+
+  vector<Spanner*> broken_intos_;
+
+  vsize 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_substitute_grob_array (SCM sym, Grob_array *);
+
+  // TODO: make virtual and do this for Items as well.
+  Interval_t<int> spanned_rank_iv ();
+  void set_bound (Direction d, Grob *);
+  Item *get_bound (Direction d) const;
+
+  Spanner (SCM, Object_key const *);
+  Spanner (Spanner const &, int copy_count);
+  bool is_broken () const;
+  void do_break ();
+  Real spanner_length () const;
+
+  static int compare (Spanner *const &, Spanner *const &);
+  virtual Grob *find_broken_piece (System *) const;
+  virtual void derived_mark () const;
+  static bool has_interface (Grob *);
+  virtual System *get_system () const;
+
 protected:
-    SPANNER_CLONE(Spanner)
-    virtual void break_into_pieces();
-
-    Link_array<Spanner> broken_into_l_arr_;
-       
-    virtual void do_break_processing();
-    virtual Interval do_width()const;
-    virtual void do_print()const;
-    virtual Line_of_score*line_l()const;
+  void set_my_columns ();
+  virtual Grob *clone (int count) const;
+  virtual void do_break_processing ();
 };
+
+void add_bound_item (Spanner *, Grob *);
+
+bool spanner_less (Spanner *s1, Spanner *s2);
+int broken_spanner_index (Spanner *sp);
 #endif