X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Fcontext-specced-music-iterator.cc;h=81c5f4c854df57cc898dca447ad65265513909af;hb=9e781b7dc83b60a543ce218aa1a5f139f74c760f;hp=2f7445fd6760fa34bf96b8f65f93df2eab471d30;hpb=c3214d7d27899529e67f9e57850167775eaf675d;p=lilypond.git diff --git a/lily/context-specced-music-iterator.cc b/lily/context-specced-music-iterator.cc index 2f7445fd67..81c5f4c854 100644 --- a/lily/context-specced-music-iterator.cc +++ b/lily/context-specced-music-iterator.cc @@ -1,20 +1,30 @@ -/* - context-specced-music-iterator.cc -- implement - Context_specced_music_iterator +/* + This file is part of LilyPond, the GNU music typesetter. - source file of the GNU LilyPond music typesetter + Copyright (C) 2002--2014 Han-Wen Nienhuys - (c) 2002--2004 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 "music-wrapper-iterator.hh" #include "context.hh" +#include "music.hh" class Context_specced_music_iterator : public Music_wrapper_iterator { public: - DECLARE_SCHEME_CALLBACK (constructor,()); + DECLARE_SCHEME_CALLBACK (constructor, ()); virtual void construct_children (); }; @@ -23,22 +33,26 @@ Context_specced_music_iterator::construct_children () { SCM ct = get_music ()->get_property ("context-type"); - String c_id; + string c_id; SCM ci = get_music ()->get_property ("context-id"); - if (gh_string_p (ci)) + if (scm_is_string (ci)) c_id = ly_scm2string (ci); SCM ops = get_music ()->get_property ("property-operations"); - - Context * a - = get_outlet ()->find_create_context (ct, c_id, ops); + + Context *a = 0; + + if (to_boolean (get_music ()->get_property ("create-new"))) + a = get_outlet ()->create_unique_context (ct, c_id, ops); + else + a = get_outlet ()->find_create_context (ct, c_id, ops); if (a && to_boolean (get_music ()->get_property ("descend-only")) && !is_child_context (get_outlet (), a)) a = 0; - + if (a) - set_translator (a); + set_context (a); Music_wrapper_iterator::construct_children (); }