- tg->definition_ = self_scm ();
-
- SCM trans_names = get_translator_names (ops);
-
- Translator *g = get_translator (translator_group_type_);
- g = g->clone ();
-
- SCM trans_list = SCM_EOL;
-
- for (SCM s = trans_names; ly_c_pair_p (s) ; s = ly_cdr (s))
- {
- Translator *t = get_translator (ly_car (s));
- if (!t)
- warning (_f ("can't find: `%s'", s));
- else
- {
- Translator *tr = t->clone ();
- SCM str = tr->self_scm ();
-
- if (tr->must_be_last ())
- {
- SCM cons = scm_cons (str, SCM_EOL);
- if (ly_c_pair_p (trans_list))
- scm_set_cdr_x (scm_last_pair (trans_list), cons);
- else
- trans_list= cons;
- }
- else
- {
- trans_list = scm_cons (str, trans_list);
- }
-
- tr->daddy_context_ = tg;
- scm_gc_unprotect_object (str);
- }
- }
-
- g->simple_trans_list_ = trans_list;
-
- tg->implementation_ = g->self_scm ();
- if (dynamic_cast<Engraver*> (g))
- g->simple_trans_list_ = filter_performers (g->simple_trans_list_);
- else if (dynamic_cast<Performer*> (g))
- g->simple_trans_list_ = filter_engravers (g->simple_trans_list_);
-
- g->daddy_context_ = tg;
- tg->aliases_ = context_aliases_ ;
-
- scm_gc_unprotect_object (g->self_scm ());
-
- tg->accepts_list_ = get_accepted (ops);
-
- return tg;
-}
+ context->definition_ = self_scm ();
+ context->definition_mods_ = ops;
+ context->aliases_ = context_aliases_;
+ context->accepts_list_ = get_accepted (ops);