X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Finclude%2Ftie.hh;h=bcce6c1265449b9529825197195ca35b3250ec95;hb=5b4b0d6e9a197e8f9eb085b7c2ad78b8be3e5cfc;hp=23c73a46c1e4baecedd63f06d391dfc62775184a;hpb=24894f0870559b225b3afae8663db9fea4dfb98e;p=lilypond.git diff --git a/lily/include/tie.hh b/lily/include/tie.hh index 23c73a46c1..bcce6c1265 100644 --- a/lily/include/tie.hh +++ b/lily/include/tie.hh @@ -3,78 +3,38 @@ source file of the GNU LilyPond music typesetter - (c) 1997--2005 Han-Wen Nienhuys + (c) 1997--2008 Han-Wen Nienhuys */ #ifndef TIE_HH #define TIE_HH -#include "lily-guile.hh" #include "lily-proto.hh" #include "skyline.hh" - +#include "grob-interface.hh" -class Tie_configuration -{ -public: - int position_; - Direction dir_; - Real delta_y_; - - - Interval attachment_x_; - Grob *tie_; - int head_position_; - - Tie_configuration (); - void center_tie_vertically (Tie_details const &); - Bezier get_bezier (Tie_details const &) const; - Real height (Tie_details const&) const; - - static int compare (Tie_configuration const &a, - Tie_configuration const &b); - static Real distance (Tie_configuration const &a, - Tie_configuration const &b); -}; - -INSTANTIATE_COMPARE (Tie_configuration, Tie_configuration::compare); - -class Ties_configuration -{ -public: - Array ties_; - -}; - class Tie { public: static void set_head (Grob *, Direction, Grob *head); - static bool has_interface (Grob *); + DECLARE_GROB_INTERFACE(); static Grob *head (Grob *, Direction); static int get_column_rank (Grob *, Direction); static int get_position (Grob *); - static Direction get_default_dir (Grob *); - static void get_configuration (Grob *, Tie_configuration *, - Tie_formatting_problem const &); - static void set_control_points (Grob *, Grob *, - Tie_configuration const&, - Tie_details const&); - static void set_default_control_points (Grob *); + static Direction get_default_dir (Grob *); + static SCM get_control_points (Grob *, Grob *, + Tie_configuration const&, + Tie_details const&); + static SCM get_default_control_points (Grob *); DECLARE_SCHEME_CALLBACK (print, (SCM)); DECLARE_SCHEME_CALLBACK (set_spacing_rods, (SCM)); DECLARE_SCHEME_CALLBACK (calc_direction, (SCM)); DECLARE_SCHEME_CALLBACK (calc_control_points, (SCM)); - static int compare (Grob *const &s1, - Grob *const &s2); - - static Interval get_default_attachments (Spanner *me, Grob *common, Real gap, - int *staff_position, bool *in_between, - Tie_details const &); - + static bool less (Grob *const &s1, + Grob *const &s2); };