2 piano-pedal-performer.cc -- implement Piano_pedal_performer
4 source file of the GNU LilyPond music typesetter
6 (c) 2000 Jan Nieuwenhuizen <janneke@gnu.org>
9 #include "performer.hh"
10 #include "command-request.hh"
11 #include "musical-request.hh"
12 #include "audio-item.hh"
18 class Piano_pedal_performer : public Performer
23 Span_req* start_req_l_;
24 Drul_array<Span_req*> req_l_drul_;
28 VIRTUAL_COPY_CONS (Translator);
29 Piano_pedal_performer ();
30 ~Piano_pedal_performer ();
33 virtual void initialize ();
34 virtual bool try_music (Music*);
35 virtual void create_audio_elements ();
36 virtual void stop_translation_timestep ();
37 virtual void start_translation_timestep ();
40 Link_array<Audio_piano_pedal> audio_p_arr_;
41 Pedal_info * info_alist_;
44 ADD_THIS_TRANSLATOR (Piano_pedal_performer);
46 Piano_pedal_performer::Piano_pedal_performer ()
51 Piano_pedal_performer::~Piano_pedal_performer ()
57 Piano_pedal_performer::initialize ()
59 info_alist_ = new Pedal_info[4];
60 Pedal_info *p = info_alist_;
62 char * names [] = { "Sostenuto", "Sustain", "UnaChorda", 0 };
67 p->req_l_drul_[START] = 0;
68 p->req_l_drul_[STOP] = 0;
77 Piano_pedal_performer::create_audio_elements ()
79 for (Pedal_info*p = info_alist_; p && p->name_; p ++)
82 if (p->req_l_drul_[STOP])
86 p->req_l_drul_[STOP]->origin ()->warning (_f ("can't find start of piano pedal: `%s'", String (p->name_)));
90 Audio_piano_pedal* a = new Audio_piano_pedal;
91 a->type_str_ = String (p->name_);
93 audio_p_arr_.push (a);
98 if (p->req_l_drul_[START])
100 p->start_req_l_ = p->req_l_drul_[START];
101 Audio_piano_pedal* a = new Audio_piano_pedal;
102 a->type_str_ = String (p->name_);
104 audio_p_arr_.push (a);
106 p->req_l_drul_[START] = 0;
107 p->req_l_drul_[STOP] = 0;
112 Piano_pedal_performer::stop_translation_timestep ()
114 for (int i=0; i< audio_p_arr_.size (); i++)
115 play_element (audio_p_arr_[i]);
116 audio_p_arr_.clear ();
120 Piano_pedal_performer::start_translation_timestep ()
122 for (Pedal_info*p = info_alist_; p && p->name_; p ++)
124 p->req_l_drul_[STOP] = 0;
125 p->req_l_drul_[START] = 0;
130 Piano_pedal_performer::try_music (Music* r)
132 if (Span_req * s = dynamic_cast<Span_req*> (r))
134 for (Pedal_info*p = info_alist_; p->name_; p ++)
136 if (scm_equal_p (s->get_mus_property ("span-type"),
137 ly_str02scm (p->name_)) == SCM_BOOL_T)
139 p->req_l_drul_[s->get_span_dir ()] = s;