source file of the GNU LilyPond music typesetter
- (c) 2000--2001 Han-Wen Nienhuys <hanwen@cs.uu.nl>
+ (c) 2000--2002 Han-Wen Nienhuys <hanwen@cs.uu.nl>
*/
#include "spanner.hh"
#include "item.hh"
#include "percent-repeat-iterator.hh"
-#include "bar.hh"
+#include "bar-line.hh"
#include "score-engraver.hh"
#include "translator-group.hh"
{
void typeset_perc ();
public:
- VIRTUAL_COPY_CONS (Translator);
- Percent_repeat_engraver ();
+ TRANSLATOR_DECLARATIONS(Percent_repeat_engraver);
protected:
Repeated_music * repeat_;
meas_len = *unsmob_moment (m);
if (body_length_ < meas_len &&
- meas_len.mod_rat (body_length_) == Moment (0,0))
+ meas_len.main_part_.mod_rat (body_length_.main_part_) == Moment (Rational (0,0)))
repeat_sign_type_ = BEAT;
else if (meas_len == body_length_)
repeat_sign_type_ = MEASURE;
if (repeat_sign_type_ == BEAT)
{
beat_slash_ = new Item (get_property ("RepeatSlash"));
- announce_grob (beat_slash_, repeat_);
+ announce_grob(beat_slash_, repeat_->self_scm());
}
else if (repeat_sign_type_ == MEASURE)
{
perc_p_ = new Spanner (get_property ("PercentRepeat"));
SCM col =get_property ("currentCommandColumn");
perc_p_->set_bound (LEFT, unsmob_grob (col));
- announce_grob (perc_p_, repeat_);
+ announce_grob(perc_p_, repeat_->self_scm());
}
else if (repeat_sign_type_ == DOUBLE_MEASURE)
{
double_percent_ = new Item (get_property ("DoublePercentRepeat"));
- announce_grob (double_percent_, repeat_);
+ announce_grob(double_percent_, repeat_->self_scm());
/*
forbid breaks on a % line. Should forbid all breaks, really.
*/
- Score_engraver * e = 0;
- Translator * t = daddy_grav_l ();
- for (; !e && t; t = t->daddy_trans_l_)
- {
- e = dynamic_cast<Score_engraver*> (t);
- }
-
- if (!e)
- programming_error ("No score engraver!");
- else
- e->forbid_breaks (); // guh. Use properties!
+
+ top_engraver()->forbid_breaks (); // guh. Use properties!
}
next_moment_ = next_moment_ + body_length_;
}
typeset_perc ();
}
-ADD_THIS_TRANSLATOR (Percent_repeat_engraver);
+
+ENTER_DESCRIPTION(Percent_repeat_engraver,
+/* descr */ "Make beat, whole bar and double bar repeats.",
+/* creats*/ "PercentRepeat RepeatSlash DoublePercentRepeat",
+/* acks */ "",
+/* reads */ "measureLength currentCommandColumn",
+/* write */ "");