X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Frod.cc;h=9d9b6520fc640a46ab6bd07132aa5e0c63e96987;hb=98b662a091d78893004ee5f7cf4f7e9a6d811f57;hp=90af9edf1b67c577cdbd9ef2f3be5aa970a116d7;hpb=d7416352b825c3e9b4858e1ddcf14f0c00e26d89;p=lilypond.git diff --git a/lily/rod.cc b/lily/rod.cc index 90af9edf1b..9d9b6520fc 100644 --- a/lily/rod.cc +++ b/lily/rod.cc @@ -1,56 +1,58 @@ -/* - rod.cc -- implement Rod, Column_rod - - source file of the GNU LilyPond music typesetter - - (c) 1998--2000 Han-Wen Nienhuys - - */ +/* + This file is part of LilyPond, the GNU music typesetter. + + Copyright (C) 1998--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 "rod.hh" + #include "paper-column.hh" -#include "debug.hh" +#include "warn.hh" #include "dimensions.hh" -#include "single-malt-grouping-item.hh" - +#include "spaceable-grob.hh" Rod::Rod () { - distance_f_ = 0.0; - item_l_drul_[LEFT] = item_l_drul_[RIGHT] =0; + distance_ = 0.0; + item_drul_[LEFT] = item_drul_[RIGHT] = 0; } - -Column_rod::Column_rod () -{ - distance_f_ = 0; - other_l_ = 0; -} - -int -Column_rod::compare (const Column_rod &r1, const Column_rod &r2) -{ - return r1.other_l_->rank_i() - r2.other_l_->rank_i(); -} - - void Rod::columnize () { - Direction d = LEFT; - do { - Paper_column * pc = item_l_drul_[d]->column_l (); - distance_f_ += - d * item_l_drul_[d]->relative_coordinate (pc, X_AXIS); - item_l_drul_[d] = pc; - } while ((flip (&d))!=LEFT); - + if (!item_drul_[LEFT] + || !item_drul_[RIGHT]) + return; + + for (LEFT_and_RIGHT (d)) + { + Paper_column *pc = item_drul_[d]->get_column (); + distance_ += -d * item_drul_[d]->relative_coordinate (pc, X_AXIS); + item_drul_[d] = pc; + } } void Rod::add_to_cols () { - columnize(); - if (item_l_drul_[LEFT] != item_l_drul_[RIGHT]) - dynamic_cast (item_l_drul_[LEFT])-> - add_rod(dynamic_cast(item_l_drul_[RIGHT]), distance_f_ ); + columnize (); + if (item_drul_[LEFT] != item_drul_[RIGHT] + && item_drul_[LEFT] && item_drul_[RIGHT]) + Spaceable_grob::add_rod (item_drul_[LEFT], + item_drul_[RIGHT], + distance_); }