X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Ftranslator-group.cc;h=44b4e1fe0a1742dbb1e2fb34eeada2589004c2cd;hb=bc95f4434f760d41191341ab4508b2064eb19025;hp=5445b9bd5b6a9663a9ad0b81315b45fd83266ec3;hpb=e42585017a01fd02f6353b994cf0c87b03a7bb2e;p=lilypond.git diff --git a/lily/translator-group.cc b/lily/translator-group.cc index 5445b9bd5b..44b4e1fe0a 100644 --- a/lily/translator-group.cc +++ b/lily/translator-group.cc @@ -1,10 +1,21 @@ /* - translator-group.cc -- implement Translator_group + This file is part of LilyPond, the GNU music typesetter. - source file of the GNU LilyPond music typesetter - - (c) 1997--2006 Han-Wen Nienhuys , + Copyright (C) 1997--2010 Han-Wen Nienhuys , Erik Sandberg + + 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 "translator-group.hh" @@ -18,10 +29,10 @@ #include "music.hh" #include "output-def.hh" #include "performer-group.hh" +#include "scheme-engraver.hh" #include "scm-hash.hh" #include "warn.hh" - void translator_each (SCM list, Translator_method method) { @@ -141,15 +152,29 @@ Translator_group::create_child_translator (SCM sev) for (SCM s = trans_names; scm_is_pair (s); s = scm_cdr (s)) { - Translator *type = get_translator (scm_car (s)); + SCM definition = scm_car (s); + + Translator *type = 0; + Translator *instance = type; + if (ly_is_symbol (definition)) + { + type = get_translator (definition); + instance = type->clone (); + } + else if (ly_is_pair (definition)) + { + type = get_translator (ly_symbol2scm ("Scheme_engraver")); + instance = type->clone (); + dynamic_cast (instance)->init_from_scheme (definition); + } + if (!type) warning (_f ("cannot find: `%s'", ly_symbol2string (scm_car (s)).c_str ())); else { - Translator *tr = type->clone (); - SCM str = tr->self_scm (); + SCM str = instance->self_scm (); - if (tr->must_be_last ()) + if (instance->must_be_last ()) { SCM cons = scm_cons (str, SCM_EOL); if (scm_is_pair (trans_list)) @@ -160,13 +185,13 @@ Translator_group::create_child_translator (SCM sev) else trans_list = scm_cons (str, trans_list); - tr->daddy_context_ = new_context; - tr->unprotect (); + instance->daddy_context_ = new_context; + instance->unprotect (); } } /* Filter unwanted translator types. Required to make - \with {\consists "..."} work. */ + \with { \consists "..." } work. */ if (dynamic_cast (g)) g->simple_trans_list_ = filter_performers (trans_list); else if (dynamic_cast (g)) @@ -214,7 +239,8 @@ precomputed_recurse_over_translators (Context *c, Translator_precompute_index id } void -recurse_over_translators (Context *c, Translator_method ptr, Translator_group_method tg_ptr, Direction dir) +recurse_over_translators (Context *c, Translator_method ptr, + Translator_group_method tg_ptr, Direction dir) { Translator_group *tg = dynamic_cast (c->implementation ());