X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Fdirectional-element-interface.cc;h=c217677606119577b77c11e43a112973233ed257;hb=5c9c9c0ae6cd4bed8f7a2c62b2c014f3659a188a;hp=ac2c40927d4c35f287465cb551339345b4094cd8;hpb=0817e0513d1016ff22a633b6fee20ddba2a062f2;p=lilypond.git diff --git a/lily/directional-element-interface.cc b/lily/directional-element-interface.cc index ac2c40927d..c217677606 100644 --- a/lily/directional-element-interface.cc +++ b/lily/directional-element-interface.cc @@ -1,39 +1,33 @@ -/* - directional-element.cc -- implement Directional_element - - source file of the GNU LilyPond music typesetter - - (c) 1999--2001 Han-Wen Nienhuys - - */ - -#include "directional-element-interface.hh" - +/* + directional-element-interface.cc -- implement Directional_element + source file of the GNU LilyPond music typesetter + (c) 1999--2008 Han-Wen Nienhuys +*/ -bool -Directional_element_interface::has_interface (Grob*me) -{ - return isdir_b (me->get_grob_property ("direction")); -} +#include "directional-element-interface.hh" +#include "warn.hh" +#include "grob.hh" Direction -Directional_element_interface::get (Grob*me) +get_grob_direction (Grob *me) { - // return dir_; - SCM d= me->get_grob_property ("direction"); - if (!isdir_b (d)) + SCM d = me->get_property ("direction"); + if (d == ly_symbol2scm ("calculation-in-progress")) + { + programming_error ("Grob direction requested while calculation in progress. "); + return UP; + } + if (!is_direction (d)) return CENTER; - + return to_dir (d); } void -Directional_element_interface::set (Grob*me, Direction d) +set_grob_direction (Grob *me, Direction d) { - SCM sd = gh_int2scm (d); - - if (me->get_grob_property ("direction") != sd) - me->set_grob_property ("direction", sd); + SCM sd = scm_from_int (d); + me->set_property ("direction", sd); }