2 dynamic-reg.cc -- implement Dynamic_register
4 source file of the LilyPond music typesetter
6 (c) 1997 Han-Wen Nienhuys <hanwen@stack.nl>
9 #include "crescendo.hh"
10 #include "dynamic-reg.hh"
11 #include "musical-request.hh"
12 #include "text-item.hh"
14 #include "paper-def.hh"
15 #include "score-column.hh"
17 Dynamic_register::Dynamic_register()
20 post_move_processing();
22 to_end_cresc_p_ = cresc_p_ = 0;
27 Dynamic_register::post_move_processing()
29 dynamic_req_l_arr_.set_size(0);
33 Dynamic_register::try_request(Request * r)
35 Musical_req * m = r->musical();
36 if (!m || !m->dynamic())
38 dynamic_req_l_arr_.push(m->dynamic());
42 Dynamic_register::process_requests()
44 Crescendo* new_cresc_p=0;
45 for (int i=0; i < dynamic_req_l_arr_.size(); i++) {
46 Dynamic_req *dreq_l = dynamic_req_l_arr_[i];
47 if (dreq_l->absdynamic()) {
48 Text_def * td_p = new Text_def;
50 String loud =Dynamic_req::loudness_str(
51 dreq_l->absdynamic()->loudness_);
53 td_p->text_str_ = paper()->lookup_l()->dynamic(loud).tex;
54 td_p->style_str_ = "dynamic";
56 assert (!dynamic_p_) ; // TODO
58 dynamic_p_ = new Text_item(td_p, 10 ); // TODO!
59 announce_element(Staff_elem_info(dynamic_p_, dreq_l));
60 } else if (dreq_l->span_dynamic()) {
62 Span_dynamic_req* span_l = dreq_l->span_dynamic();
63 if (span_l->spantype == Span_req::STOP) {
65 span_l->warning("Can't find cresc to end " );
67 assert(!to_end_cresc_p_);
68 to_end_cresc_p_ =cresc_p_;
71 } else if (span_l->spantype == Span_req::START) {
72 cresc_req_l_ = span_l;
74 new_cresc_p = new Crescendo(10);
75 new_cresc_p->grow_dir_i_ = span_l->dynamic_dir_i_;
76 announce_element(Staff_elem_info(new_cresc_p, span_l));
82 cresc_p_ = new_cresc_p;
83 cresc_p_->left_col_l_ = get_staff_info().musical_l()->pcol_l_;
85 cresc_p_->left_dyn_b_ = true;
91 Dynamic_register::pre_move_processing()
94 typeset_element(dynamic_p_);
97 if ( to_end_cresc_p_) {
99 to_end_cresc_p_->right_dyn_b_=true;
101 to_end_cresc_p_->right_col_l_ = get_staff_info().musical_l()->pcol_l_;
103 typeset_element(to_end_cresc_p_);
109 Dynamic_register::acceptable_request_b(Request*r)const
111 Musical_req * m = r->musical();
112 return (m && m->dynamic());
116 Dynamic_register::set_feature(Features i)
118 dir_i_ = i.direction_i_;
121 IMPLEMENT_STATIC_NAME(Dynamic_register);
122 ADD_THIS_REGISTER(Dynamic_register);
124 Dynamic_register::~Dynamic_register()
127 delete to_end_cresc_p_;
129 cresc_req_l_->warning("unended crescendo");