(c) 1997--1999 Han-Wen Nienhuys <hanwen@cs.uu.nl>
*/
+
#include "score-engraver.hh"
#include "timing-engraver.hh"
#include "command-request.hh"
#include "score-element-info.hh"
#include "multi-measure-rest.hh"
-
void
Timing_engraver::fill_staff_info (Staff_info &inf)
{
inf.time_C_ = &time_;
- inf.rhythmic_C_ = &default_grouping_;
}
ADD_THIS_TRANSLATOR(Timing_engraver);
+
+
+void
+Timing_engraver::do_post_move_processing( )
+{
+ bar_req_l_ = 0;
+ Timing_translator::do_post_move_processing ();
+}
+
+bool
+Timing_engraver::do_try_music (Music*m)
+{
+ if (Bar_req * b= dynamic_cast <Bar_req *> (m))
+ {
+ if (bar_req_l_ && bar_req_l_->equal_b (b)) // huh?
+ return false;
+
+ bar_req_l_ = b;
+ return true;
+ }
+
+ return Timing_translator::do_try_music (m);
+}
+
+
+String
+Timing_engraver::which_bar ()
+{
+ if (!bar_req_l_)
+ {
+ if (!now_mom ())
+ return "|";
+
+ SCM nonauto = get_property ("barNonAuto", 0);
+ if (!gh_boolean_p (nonauto) && gh_scm2bool (nonauto))
+ {
+ SCM always = get_property ("barAlways", 0);
+ if (!time_.whole_in_measure_ || gh_boolean_p (always) && gh_scm2bool (always))
+ {
+ SCM def=get_property ("defaultBarType" ,0);
+ return (gh_string_p (def))? ly_scm2string (def) : "";
+ }
+ }
+ return "";
+ }
+ else
+ {
+ return bar_req_l_->type_str_;
+ }
+}