]> git.donarmstrong.com Git - lilypond.git/blob - lily/performer-group.cc
*** empty log message ***
[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--2005 Han-Wen Nienhuys <hanwen@cs.uu.nl>
7   Jan Nieuwenhuizen <janneke@gnu.org>
8 */
9
10 #include "performer-group-performer.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                       /* accept */ "",
20                       /* read */ "",
21                       /* write */ "");
22
23 void
24 Performer_group::announce_element (Audio_element_info info)
25 {
26   announce_infos_.push (info);
27   Translator_group *t
28     = context ()->get_parent_context ()->implementation ();
29
30   if (Performer_group *eg = dynamic_cast<Performer_group *> (t))
31     eg->announce_element (info);
32 }
33
34 void
35 Performer_group::acknowledge_audio_elements ()
36 {
37   for (int j = 0; j < announce_infos_.size (); j++)
38     {
39       Audio_element_info info = announce_infos_[j];
40
41       for (SCM p = get_simple_trans_list (); scm_is_pair (p); p = scm_cdr (p))
42         {
43           Translator *t = unsmob_translator (scm_car (p));
44           Performer *eng = dynamic_cast<Performer *> (t);
45           if (eng && eng != info.origin_trans_)
46             eng->acknowledge_audio_element (info);
47         }
48     }
49 }
50
51 void
52 performer_each (SCM list, Performer_method method)
53 {
54   for (SCM p = list; scm_is_pair (p); p = scm_cdr (p))
55     {
56       Performer *e = dynamic_cast<Performer *> (unsmob_translator (scm_car (p)));
57       if (e)
58         (e->*method) ();
59     }
60 }
61
62 void
63 Performer_group::do_announces ()
64 {
65   while (1)
66     {
67       performer_each (get_simple_trans_list (),
68                       &Performer::create_audio_elements);
69
70       if (!announce_infos_.size ())
71         break;
72
73       acknowledge_audio_elements ();
74       announce_infos_.clear ();
75     }
76 }
77
78 void
79 Performer_group::play_element (Audio_element *e)
80 {
81   Context *c = context_->get_parent_context ();
82   if (c)
83     {
84       Performer_group *pgp = dynamic_cast<Performer_group *> (c->implementation ());
85       pgp->play_element (e);
86     }
87 }
88
89 int
90 Performer_group::get_tempo () const
91 {
92   Context *c = context_->get_parent_context ();
93   if (c)
94     {
95       Performer_group *pgp = dynamic_cast<Performer_group *> (c->implementation ());
96       return pgp->get_tempo ();
97     }
98   return 60;
99 }
100