X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Finclude%2Ftie.hh;h=bcce6c1265449b9529825197195ca35b3250ec95;hb=0387f04497978e37b335a8b99eec905499d6ad0f;hp=80501acf30502737c6d5a114634ea628139603d3;hpb=4bee689d7993ecf9af95d33c7f8f4ecd8d74a3cc;p=lilypond.git diff --git a/lily/include/tie.hh b/lily/include/tie.hh index 80501acf30..bcce6c1265 100644 --- a/lily/include/tie.hh +++ b/lily/include/tie.hh @@ -3,81 +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" - -Interval -get_skyline_attachment (Drul_array< Array < Skyline_entry > > const &skylines, - Real y1); - -struct Tie_details -{ - Real height_limit_; - Real ratio_; - Real staff_space_; - Real x_gap_; - - Tie_details (); - void init (Grob *); -}; - -struct Tie_configuration -{ - int head_position_; - int position_; - Direction dir_; - Interval attachment_x_; - Real delta_y_; - - 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 Tie { public: static void set_head (Grob *, Direction, Grob *head); - static bool has_interface (Grob *); - static void set_direction (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 *, Grob *, Tie_configuration *, - Drul_array< Array > const *, - Tie_details 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)); - 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); - + DECLARE_SCHEME_CALLBACK (calc_direction, (SCM)); + DECLARE_SCHEME_CALLBACK (calc_control_points, (SCM)); + static bool less (Grob *const &s1, + Grob *const &s2); };