]> git.donarmstrong.com Git - lilypond.git/blob - lily/performer-group.cc
add 2007 to (c) year.
[lilypond.git] / lily / performer-group.cc
1 /*
2   performer-group-performer.cc -- implement Performer_group
3
4   source file of the GNU LilyPond music typesetter
5
6   (c) 1996--2007 Han-Wen Nienhuys <hanwen@xs4all.nl>
7   Jan Nieuwenhuizen <janneke@gnu.org>
8 */
9
10 #include "performer-group.hh"
11
12 #include "context.hh"
13 #include "audio-element.hh"
14 #include "warn.hh"
15
16 ADD_TRANSLATOR_GROUP (Performer_group,
17                       /* doc */ "",
18                       /* create */ "",
19                       /* read */ "",
20                       /* write */ "");
21
22 void
23 Performer_group::announce_element (Audio_element_info info)
24 {
25   announce_infos_.push_back (info);
26   Translator_group *t
27     = context ()->get_parent_context ()->implementation ();
28
29   if (Performer_group *eg = dynamic_cast<Performer_group *> (t))
30     eg->announce_element (info);
31 }
32
33 void
34 Performer_group::acknowledge_audio_elements ()
35 {
36   for (vsize j = 0; j < announce_infos_.size (); j++)
37     {
38       Audio_element_info info = announce_infos_[j];
39
40       for (SCM p = get_simple_trans_list (); scm_is_pair (p); p = scm_cdr (p))
41         {
42           Translator *t = unsmob_translator (scm_car (p));
43           Performer *eng = dynamic_cast<Performer *> (t);
44           if (eng && eng != info.origin_trans_)
45             eng->acknowledge_audio_element (info);
46         }
47     }
48 }
49
50 void
51 performer_each (SCM list, Performer_method method)
52 {
53   for (SCM p = list; scm_is_pair (p); p = scm_cdr (p))
54     {
55       Performer *e = dynamic_cast<Performer *> (unsmob_translator (scm_car (p)));
56       if (e)
57         (e->*method) ();
58     }
59 }
60
61 void
62 Performer_group::do_announces ()
63 {
64   for (SCM s = context ()->children_contexts ();
65        scm_is_pair (s); s = scm_cdr (s))
66     {
67       Context *c = unsmob_context (scm_car (s));
68       Performer_group *group
69         = dynamic_cast<Performer_group *> (c->implementation ());
70       if (group)
71         group->do_announces ();
72     }
73
74   while (1)
75     {
76       performer_each (get_simple_trans_list (),
77                       &Performer::create_audio_elements);
78
79       if (!announce_infos_.size ())
80         break;
81
82       acknowledge_audio_elements ();
83       announce_infos_.clear ();
84     }
85 }