X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Fgrob-info.cc;h=aab0d3cb8d61b352cf381969d479982d7300f08e;hb=90e4d7057f3857da049dfda3d130017d4719bd6b;hp=4ffbcf9c15da408c9c95f406e8b67c490a92781b;hpb=77d72a6b9e7e551dc4a3b365099f9fea339f9c72;p=lilypond.git diff --git a/lily/grob-info.cc b/lily/grob-info.cc index 4ffbcf9c15..aab0d3cb8d 100644 --- a/lily/grob-info.cc +++ b/lily/grob-info.cc @@ -1,23 +1,39 @@ /* - grob-info.cc -- implement Grob_info + This file is part of LilyPond, the GNU music typesetter. - source file of the GNU LilyPond music typesetter + Copyright (C) 1997--2015 Han-Wen Nienhuys - (c) 1997--2005 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 "context.hh" #include "grob-info.hh" -#include "grob.hh" +#include "item.hh" #include "music.hh" -#include "translator-group.hh" -#include "context.hh" #include "spanner.hh" -#include "item.hh" +#include "stream-event.hh" +#include "translator-group.hh" Grob_info::Grob_info (Translator *t, Grob *g) { origin_trans_ = t; grob_ = g; + + /* + assert here, because this is easier to debug. + */ + assert (g); } Grob_info::Grob_info () @@ -26,21 +42,21 @@ Grob_info::Grob_info () origin_trans_ = 0; } -Music * -Grob_info::music_cause () const +Stream_event * +Grob_info::event_cause () const { SCM cause = grob_->get_property ("cause"); - return unsmob_music (cause); + return unsmob (cause); } -Link_array +vector Grob_info::origin_contexts (Translator *end) const { Context *t = origin_trans_->context (); - Link_array r; + vector r; do { - r.push (t); + r.push_back (t); t = t->get_parent_context (); } while (t && t != end->context ()); @@ -66,15 +82,19 @@ Grob_info::item () const return dynamic_cast (grob_); } -Music * -Grob_info::ultimate_music_cause () const +Stream_event * +Grob_info::ultimate_event_cause () const { SCM cause = grob_->self_scm (); - while (unsmob_grob (cause)) + while (unsmob (cause)) { - cause = unsmob_grob (cause)->get_property ("cause"); + cause = unsmob (cause)->get_property ("cause"); } - - return unsmob_music (cause); + return unsmob (cause); } +bool +Grob_info::less (Grob_info i, Grob_info j) +{ + return Grob::less (i.grob (), j.grob ()); +}