X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Fpure-from-neighbor-interface.cc;h=745c23dbec0d982ab59e1d5d3aec275d0ae86bcd;hb=8659a99f233f5c4684292728e7ad4206669b35b0;hp=d0c85aab9e7b0483566e3ae601c170349ea7c8c0;hpb=3ef893f1fe182e9f6cf5841cbff0706789bd3361;p=lilypond.git diff --git a/lily/pure-from-neighbor-interface.cc b/lily/pure-from-neighbor-interface.cc index d0c85aab9e..745c23dbec 100644 --- a/lily/pure-from-neighbor-interface.cc +++ b/lily/pure-from-neighbor-interface.cc @@ -1,7 +1,7 @@ /* This file is part of LilyPond, the GNU music typesetter. - Copyright (C) 2011 Mike Solomon + Copyright (C) 2011--2015 Mike Solomon LilyPond is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by @@ -17,43 +17,43 @@ along with LilyPond. If not, see . */ +#include "axis-group-interface.hh" #include "grob.hh" #include "grob-array.hh" +#include "moment.hh" +#include "paper-column.hh" #include "pointer-group-interface.hh" #include "pure-from-neighbor-interface.hh" #include "spanner.hh" #include "system.hh" -MAKE_SCHEME_CALLBACK (Pure_from_neighbor_interface, filter_elements, 1); +MAKE_SCHEME_CALLBACK (Pure_from_neighbor_interface, calc_pure_relevant_grobs, 1); SCM -Pure_from_neighbor_interface::filter_elements (SCM smob) +Pure_from_neighbor_interface::calc_pure_relevant_grobs (SCM smob) { - Grob *me = unsmob_grob (smob); - extract_grob_set (me, "elements", elts); + Grob *me = unsmob (smob); + extract_grob_set ((me->original () && me->original ()->is_live () + ? me->original () + : me), + "neighbors", + elts); + vector new_elts; - Interval_t srl = me->get_system ()->spanned_rank_interval (); - for (vsize i = 0; i < elts.size (); i++) - if (srl.contains (elts[i]->spanned_rank_interval ()[LEFT])) - new_elts.push_back (elts[i]); - - SCM elements_scm = me->get_object ("elements"); - if (Grob_array::unsmob (elements_scm)) - { - vector &arr - = unsmob_grob_array (elements_scm)->array_reference (); - arr = new_elts; - } - - return SCM_BOOL_T; + new_elts.insert (new_elts.end (), elts.begin (), elts.end ()); + + if (Grob_array *a = unsmob (me->get_object ("neighbors"))) + a->set_array (new_elts); + + return Axis_group_interface::internal_calc_pure_relevant_grobs (me, "neighbors"); } ADD_INTERFACE (Pure_from_neighbor_interface, - "A collection of routines to allow for objects' pure" - "heights and heights to be calculated based on the" + "A collection of routines to allow for objects' pure " + "heights and heights to be calculated based on the " "heights of the objects' neighbors.", /* properties */ - "elements-filtered " + "neighbors " "pure-relevant-grobs " "pure-Y-common " );