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