X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Finclude%2Fspanner.hh;h=94e98760c0560a857517659a1a0ba20a8a2f50a0;hb=5b4b0d6e9a197e8f9eb085b7c2ad78b8be3e5cfc;hp=e56560744e51b6d08c038e19b285a54e8156b475;hpb=d765f3af45be51f15da55cf570a4b172200e1035;p=lilypond.git diff --git a/lily/include/spanner.hh b/lily/include/spanner.hh index e56560744e..94e98760c0 100644 --- a/lily/include/spanner.hh +++ b/lily/include/spanner.hh @@ -1,71 +1,78 @@ /* spanner.hh -- part of GNU LilyPond - (c) 1996--2002 Han-Wen Nienhuys + (c) 1996--2008 Han-Wen Nienhuys */ #ifndef SPANNER_HH #define SPANNER_HH -#include "lily-proto.hh" #include "grob.hh" -#include "drul-array.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. + symbol which spans across several columns, so its final appearance + can only be calculated after the breaking problem is solved. - Examples + Examples - * (de)crescendo - * slur - * beam - * bracket + * (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 - is absolutely necessary for beams, since they have to adjust the - length of stems of notes they encompass. + 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 spanned_drul_; + vsize break_index_; + + DECLARE_CLASSNAME(Spanner); - */ -class Spanner : public Grob { - Drul_array spanned_drul_; - public: DECLARE_SCHEME_CALLBACK (set_spacing_rods, (SCM)); - - Link_array broken_intos_; + DECLARE_SCHEME_CALLBACK (bounds_width, (SCM)); + + vector broken_intos_; - int break_index_; + vsize get_break_index () const; + Spanner *broken_neighbor (Direction d) 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 spanned_rank_iv (); - void set_bound (Direction d, Grob*); + void substitute_one_mutable_property (SCM sym, SCM val); + + Interval_t spanned_time () const; + virtual Interval_t spanned_rank_interval () const; + void set_bound (Direction d, Grob *); Item *get_bound (Direction d) const; - + Spanner (SCM); Spanner (Spanner const &); - bool broken_b () const; + 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 SCM do_derived_mark () const; - static bool has_interface (Grob*); + static int compare (Spanner *const &, Spanner *const &); + static bool less (Spanner *const &, Spanner *const &); + virtual Grob *find_broken_piece (System *) const; + virtual void derived_mark () const; + DECLARE_GROB_INTERFACE(); virtual System *get_system () const; + protected: void set_my_columns (); - - VIRTUAL_COPY_CONS (Grob); + virtual Grob *clone () const; virtual void do_break_processing (); + bool fast_substitute_grob_array (SCM sym, Grob_array *); }; -void add_bound_item (Spanner*, Grob*); -///DECLARE_UNSMOB (Spanner, spanner); +void add_bound_item (Spanner *, Grob *); +bool spanner_less (Spanner *s1, Spanner *s2); +int broken_spanner_index (Spanner const *sp); #endif