2 score-grav.cc -- implement Score_engraver
4 source file of the GNU LilyPond music typesetter
6 (c) 1997 Han-Wen Nienhuys <hanwen@stack.nl>
9 #include "super-elem.hh"
10 #include "scoreline.hh"
13 #include "score-grav.hh"
15 #include "musical-request.hh"
16 #include "score-column.hh"
17 #include "command-request.hh"
18 #include "paper-def.hh"
21 Score_engraver::Score_engraver()
23 disallow_break_b_
= false;
32 Score_engraver::prepare (Moment w
)
34 Global_translator::prepare (w
);
35 set_columns (new Score_column (w
), new Score_column (w
));
37 disallow_break_b_
= false;
38 post_move_processing();
42 Score_engraver::finish()
45 *mlog
<< "[" << breaks_i_
<< "]" << flush
;
52 Score_engraver::do_creation_processing()
54 scoreline_l_
= pscore_p_
->super_elem_l_
->line_of_score_l_
;
55 scoreline_l_
->set_bounds(LEFT
,get_staff_info().command_pcol_l ());
56 command_column_l_
->breakable_b_
= true;
57 Engraver_group_engraver::do_creation_processing();
61 Score_engraver::do_removal_processing()
63 Engraver_group_engraver::do_removal_processing();
64 scoreline_l_
->set_bounds(RIGHT
,get_staff_info().command_pcol_l ());
65 command_column_l_
->breakable_b_
= true;
72 Score_engraver::process()
76 pre_move_processing();
81 Score_engraver::announce_element (Score_elem_info info
)
83 announce_info_arr_
.push (info
);
84 info
.origin_grav_l_arr_
.push (this);
88 Score_engraver::do_announces()
90 /* All elements are propagated to the top upon announcement. If
91 something was created during one run of
92 Engraver_group_engraver::do_announces, then
93 announce_info_arr_.size() will be nonzero again
96 while (announce_info_arr_
.size())
98 for (int i
=0; i
< announce_info_arr_
.size(); i
++)
104 if (announce_info_arr_
[i
].req_l_
)
106 Musical_req
*m
= announce_info_arr_
[i
].req_l_
->musical();
107 if (m
&& m
->rhythmic())
109 musical_column_l_
->add_duration (m
->duration());
112 Engraver_group_engraver::do_announces();
118 Score_engraver::typeset_element (Score_elem
*elem_p
)
120 elem_p_arr_
.push(elem_p
);
124 Score_engraver::typeset_all()
126 for (int i
=0; i
< elem_p_arr_
.size(); i
++)
128 Score_elem
* elem_p
= elem_p_arr_
[i
];
129 if (elem_p
->spanner())
130 pscore_p_
->typeset_unbroken_spanner (elem_p
->spanner());
133 Item
*item_p
= elem_p
->item();
134 pscore_p_
->typeset_element (item_p
);
135 if (!item_p
->axis_group_l_a_
[X_AXIS
]) {
136 if (item_p
->breakable_b_
)
137 command_column_l_
->add_element(item_p
);
139 musical_column_l_
->add_element(item_p
);
142 scoreline_l_
->add (elem_p
);
148 Score_engraver::do_pre_move_processing()
150 if (!disallow_break_b_
)
152 get_staff_info().command_pcol_l ()-> breakable_b_
= true;
155 *mlog
<< "[" << breaks_i_
<< "]" << flush
;
157 // this generates all items.
158 Engraver_group_engraver::do_pre_move_processing();
164 Score_engraver::set_columns (Score_column
*new_command_l
,
165 Score_column
*new_musical_l
)
167 if (command_column_l_
&& command_column_l_
->linked_b())
169 pscore_p_
->add_column (command_column_l_
);
170 scoreline_l_
->add (command_column_l_
);
174 delete command_column_l_
;
175 command_column_l_
=0;
179 command_column_l_
= new_command_l
;
180 command_column_l_
->musical_b_
= false;
182 if (musical_column_l_
&& musical_column_l_
->linked_b())
184 pscore_p_
->add_column (musical_column_l_
);
185 scoreline_l_
->add (musical_column_l_
);
189 delete musical_column_l_
;
190 musical_column_l_
= 0;
195 musical_column_l_
= new_musical_l
;
196 musical_column_l_
->musical_b_
= true;
202 Score_engraver::get_staff_info() const
204 Staff_info inf
= Engraver_group_engraver::get_staff_info();
206 inf
.command_l_
= command_column_l_
;
207 inf
.musical_l_
= musical_column_l_
;
215 Score_engraver::get_output_p ()
217 Music_output
* o
= pscore_p_
;
223 Score_engraver::do_try_request (Request
*r
)
225 bool gotcha
= Engraver_group_engraver::do_try_request (r
);
226 if (!gotcha
&& r
->command() && r
->command ()->disallowbreak ())
227 disallow_break_b_
= true;
231 IMPLEMENT_IS_TYPE_B1(Score_engraver
,Engraver_group_engraver
);
232 ADD_THIS_TRANSLATOR(Score_engraver
);
235 Score_engraver::do_add_processing ()
237 Translator_group::do_add_processing ();
238 assert (output_def_l_
->is_type_b (Paper_def::static_name ()));
239 assert (!daddy_trans_l_
);
240 pscore_p_
= new Paper_score
;
241 pscore_p_
->paper_l_
= (Paper_def
*)output_def_l_
;