X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Fdirectional-element-interface.cc;h=eb342fe1ac1c89a01cbe50eeb734ce97444b2edb;hb=5d84bfad4626892bcffd05adcced53c8a2329047;hp=e4481d6bcbf6019ad678ea3e8df7d4472bec65b7;hpb=7e72a1e50e94a7f9738d62599de79fe7745f600c;p=lilypond.git diff --git a/lily/directional-element-interface.cc b/lily/directional-element-interface.cc index e4481d6bcb..eb342fe1ac 100644 --- a/lily/directional-element-interface.cc +++ b/lily/directional-element-interface.cc @@ -1,28 +1,45 @@ -/* - directional-element-interface.cc -- implement Directional_element - - source file of the GNU LilyPond music typesetter - - (c) 1999--2004 Han-Wen Nienhuys - - */ +/* + This file is part of LilyPond, the GNU music typesetter. -#include "directional-element-interface.hh" + Copyright (C) 1999--2015 Han-Wen Nienhuys + + LilyPond is free software: you can redistribute it and/or modify + it under the terms of the GNU General Public License as published by + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + LilyPond is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + You should have received a copy of the GNU General Public License + along with LilyPond. If not, see . +*/ + +#include "directional-element-interface.hh" +#include "warn.hh" +#include "grob.hh" Direction -get_grob_direction (Grob*me) +get_grob_direction (Grob *me) { - SCM d= me->get_grob_property ("direction"); + SCM d = me->get_property ("direction"); + if (scm_is_eq (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 -set_grob_direction (Grob*me, Direction d) +set_grob_direction (Grob *me, Direction d) { - SCM sd = gh_int2scm (d); - me->set_grob_property ("direction", sd); + SCM sd = scm_from_int (d); + me->set_property ("direction", sd); }