2 slur-reg.cc -- implement Slur_register
4 (c) 1997 Han-Wen Nienhuys <hanwen@stack.nl>
9 #include "musical-request.hh"
10 #include "complex-walker.hh"
11 #include "slur-reg.hh"
14 #include "note-column.hh"
17 Slur_register::acceptable_request_b(Request*req_l)
19 return req_l->musical() && req_l->musical()->slur();
23 Slur_register::try_request(Request *req_l)
28 new_slur_req_l_arr_.push(req_l->slur());
33 Slur_register::acknowledge_element(Staff_elem_info info)
35 if (info.elem_l_->name() == Note_column::static_name()) {
36 Note_column *col_l =(Note_column*) info.elem_l_ ;// ugh
37 for (int i = 0; i < slur_l_stack_.size(); i++)
38 slur_l_stack_[i]->add(col_l );
39 for (int i = 0; i < end_slur_l_arr_.size(); i++)
40 end_slur_l_arr_[i]->add(col_l);
47 Slur_register::process_requests()
49 Array<Slur*> start_slur_l_arr_;
50 for (int i=0; i< new_slur_req_l_arr_.size(); i++) {
51 Slur_req* slur_req_l = new_slur_req_l_arr_[i];
52 // end slur: move the slur to other array
53 if (slur_req_l->spantype == Span_req::STOP) {
54 if (slur_l_stack_.empty())
56 slur_req_l->warning("can't find slur to end");
58 end_slur_l_arr_.push(slur_l_stack_.pop());
61 } else if (slur_req_l->spantype == Span_req::START) {
62 // push a new slur onto stack.
63 //(use temp. array to wait for all slur STOPs)
65 requests_arr_.push(slur_req_l);
66 start_slur_l_arr_.push(s_p);
67 announce_element(Staff_elem_info(s_p, slur_req_l));
70 for (int i=0; i < start_slur_l_arr_.size(); i++)
71 slur_l_stack_.push(start_slur_l_arr_[i]);
75 Slur_register::pre_move_processing()
77 for (int i = 0; i < end_slur_l_arr_.size(); i++) {
78 typeset_element(end_slur_l_arr_[i]);
80 end_slur_l_arr_.set_size(0);
84 Slur_register::post_move_processing()
86 new_slur_req_l_arr_.set_size(0);
88 Slur_register::~Slur_register()
90 for (int i=0; i < requests_arr_.size(); i++) {
91 requests_arr_[i]->warning("unterminated slur");
94 IMPLEMENT_STATIC_NAME(Slur_register);
95 ADD_THIS_REGISTER(Slur_register);