/*
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
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 &);
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;