X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Fdirectional-element-interface.cc;h=25a05c648d761852cbb46d931dde03a0e6d46d1f;hb=01c8ce74ab33974388c01031bb8522bf9edbfa10;hp=4a6a9e4d11c1b6de5c470b5706fea495f5503e07;hpb=0af2486a28f1c60b9de929a9101964d880927e54;p=lilypond.git diff --git a/lily/directional-element-interface.cc b/lily/directional-element-interface.cc index 4a6a9e4d11..25a05c648d 100644 --- a/lily/directional-element-interface.cc +++ b/lily/directional-element-interface.cc @@ -1,42 +1,45 @@ -/* - directional-element.cc -- implement Directional_element - - source file of the GNU LilyPond music typesetter - - (c) 1999--2000 Han-Wen Nienhuys - - */ - -#include "directional-element-interface.hh" +/* + This file is part of LilyPond, the GNU music typesetter. + Copyright (C) 1999--2012 Han-Wen Nienhuys -Directional_element_interface::Directional_element_interface (Score_element const *s) -{ - elt_l_ = (Score_element*)s; -} + 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. -bool -Directional_element_interface::has_interface () const -{ - return isdir_b (elt_l_->get_elt_property ("direction")); -} + 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 -Directional_element_interface::get () const +get_grob_direction (Grob *me) { - // return dir_; - SCM d= elt_l_->get_elt_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 (Direction d) +set_grob_direction (Grob *me, Direction d) { - elt_l_->set_elt_property ("direction", gh_int2scm (d)); + SCM sd = scm_from_int (d); + me->set_property ("direction", sd); }