2 laissez-vibrer-tie.cc -- implement Laissez_vibrer_tie
4 source file of the GNU LilyPond music typesetter
6 (c) 2005 Han-Wen Nienhuys <hanwen@xs4all.nl>
10 #include "laissez-vibrer-tie-column.hh"
11 #include "laissez-vibrer-tie.hh"
12 #include "directional-element-interface.hh"
16 #include "staff-symbol-referencer.hh"
18 ADD_INTERFACE(Laissez_vibrer_tie,
19 "laissez-vibrer-tie-interface",
20 "The interface for l.v. tie items.",
31 MAKE_SCHEME_CALLBACK (Laissez_vibrer_tie, print, 1);
33 Laissez_vibrer_tie::print (SCM smob)
35 Grob *me = unsmob_grob (smob);
36 if (CENTER == get_grob_direction (me))
39 if (!get_grob_direction (me))
40 me->programming_error ("lv. tie direction not set.");
42 SCM cp = me->get_property ("control-points");
43 if (!scm_is_pair (cp))
44 if (Laissez_vibrer_tie_column::has_interface (me->get_parent (Y_AXIS)))
46 Laissez_vibrer_tie_column::set_directions (me->get_parent (Y_AXIS));
49 return Tie::print (smob);
53 Laissez_vibrer_tie::set_direction (Grob *me)
55 if (!get_grob_direction (me))
57 if (Laissez_vibrer_tie_column::has_interface (me->get_parent (Y_AXIS)))
58 Laissez_vibrer_tie_column::set_directions (me->get_parent (Y_AXIS));
61 programming_error ("lv tie without Laissez_vibrer_tie_column");
62 set_grob_direction (me, UP);
68 Laissez_vibrer_tie::get_position (Grob *me)
70 Grob *h = unsmob_grob (me->get_object ("note-head"));
71 return (int) rint (Staff_symbol_referencer::get_position (h));
75 Laissez_vibrer_tie::compare (Grob *const &s1,
78 return sign (get_position (s1) - get_position (s2));