]> git.donarmstrong.com Git - lilypond.git/blob - lily/multi-measure-rest-engraver.cc
release: 1.1.31
[lilypond.git] / lily / multi-measure-rest-engraver.cc
1 /*
2   multi_measure_rest-engraver.cc -- implement Multi_measure_rest_engraver
3
4   (c) 1998--1999 Jan Nieuwenhuizen <janneke@gnu.org>
5        Han-Wen Nienhuys <hanwen@cs.uu.nl>
6 */
7
8 #include "proto.hh"
9 #include "musical-request.hh"
10 #include "multi-measure-rest.hh"
11 #include "multi-measure-rest-engraver.hh"
12 #include "score-column.hh"
13 #include "time-description.hh"
14 #include "bar.hh"
15
16
17 ADD_THIS_TRANSLATOR (Multi_measure_rest_engraver);
18
19 Multi_measure_rest_engraver::Multi_measure_rest_engraver ()
20 {
21   start_measure_i_ = 0;
22   rest_moments_[START] =
23     rest_moments_[STOP] =0;
24   multi_measure_req_l_ = 0;
25   mmrest_p_ = 0;
26 }
27
28 void
29 Multi_measure_rest_engraver::acknowledge_element (Score_element_info i)
30 {
31   if (Bar *c = dynamic_cast<Bar*> (i.elem_l_))
32     {
33       if (mmrest_p_) 
34         mmrest_p_->add_column (c);
35       if (lastrest_p_)
36         lastrest_p_->add_column (c);
37     }
38 }
39
40 bool
41 Multi_measure_rest_engraver::do_try_music (Music* req_l)
42 {
43  if (Multi_measure_rest_req *mr = dynamic_cast<Multi_measure_rest_req *> (req_l))
44    {
45      if (multi_measure_req_l_)
46        if (!multi_measure_req_l_->equal_b (mr)
47            || rest_moments_[START] != now_mom ())
48          return false;
49   
50      multi_measure_req_l_ = mr;
51      rest_moments_[START] = now_mom ();
52      
53      rest_moments_[STOP] = rest_moments_[START] + multi_measure_req_l_->duration_.length_mom ();
54      return true;
55    }
56  return false;
57 }
58
59 void
60 Multi_measure_rest_engraver::do_process_requests ()
61 {
62   if (multi_measure_req_l_ && !mmrest_p_)
63     {
64       Time_description const *time = get_staff_info().time_C_;
65       mmrest_p_ = new Multi_measure_rest;
66       announce_element (Score_element_info (mmrest_p_, multi_measure_req_l_));
67       start_measure_i_ = time->bars_i_;
68     }
69 }
70
71 void
72 Multi_measure_rest_engraver::do_pre_move_processing ()
73 {
74   Moment now (now_mom ());
75   Time_description const *time = get_staff_info().time_C_;
76   if (mmrest_p_ && (now >= rest_moments_[START]) 
77     && !time->whole_in_measure_
78     && (mmrest_p_->column_arr_.size () >= 2))
79     {
80       typeset_element (mmrest_p_);
81       /*
82         must keep mmrest_p_ around to set measures_i_
83        */
84     }
85   if (lastrest_p_)
86     {
87       typeset_element (lastrest_p_);
88       lastrest_p_ = 0;
89     }
90 }
91
92 void
93 Multi_measure_rest_engraver::do_post_move_processing ()
94 {
95   Time_description const *time = get_staff_info().time_C_;
96   Moment now (now_mom ());
97
98   if (mmrest_p_ && !time->whole_in_measure_)
99     {
100       lastrest_p_ = mmrest_p_;
101       lastrest_p_->measures_i_ = time->bars_i_ - start_measure_i_;
102       mmrest_p_ = 0;
103     }
104
105   if (now >= rest_moments_[STOP])
106     {
107       multi_measure_req_l_ = 0;
108       mmrest_p_ = 0;
109     }
110 }
111