Direction d = to_dir (ev->get_property ("span-direction"));
if (d == START && valid_start_point ())
- start_ev_ = ev;
+ ASSIGN_EVENT_ONCE (start_ev_, ev);
else if (d == STOP && valid_end_point ())
- now_stop_ev_ = ev;
+ ASSIGN_EVENT_ONCE (now_stop_ev_, ev);
}
void
void
Beam_engraver::acknowledge_rest (Grob_info info)
{
- if (beam_)
+ if (beam_
+ && !scm_is_number (info.grob ()->get_property_data ("staff-position")))
{
chain_offset_callback (info.grob(),
Beam::rest_collision_callback_proc, Y_AXIS);
int durlog = unsmob_duration (ev->get_property ("duration"))->duration_log ();
if (durlog <= 2)
{
- ev->origin ()->warning (_ ("stem doesn't fit in beam"));
+ ev->origin ()->warning (_ ("stem does not fit in beam"));
prev_start_ev_->origin ()->warning (_ ("beam was started here"));
/*
don't return, since
"printed with flags instead of beams.",
/* create */ "Beam",
- /* accept */ "beam-event",
/* read */
"beamMelismaBusy "
public:
TRANSLATOR_DECLARATIONS (Grace_beam_engraver);
+ DECLARE_TRANSLATOR_LISTENER (beam);
+
protected:
virtual bool valid_start_point ();
virtual bool valid_end_point ();
return beam_ && valid_start_point ();
}
+/*
+ Ugh, C&P code.
+ */
+IMPLEMENT_TRANSLATOR_LISTENER (Grace_beam_engraver, beam);
+void
+Grace_beam_engraver::listen_beam (Stream_event *ev)
+{
+ Direction d = to_dir (ev->get_property ("span-direction"));
+
+ if (d == START && valid_start_point ())
+ start_ev_ = ev;
+ else if (d == STOP && valid_end_point ())
+ now_stop_ev_ = ev;
+}
+
+
ADD_ACKNOWLEDGER (Grace_beam_engraver, stem);
ADD_ACKNOWLEDGER (Grace_beam_engraver, rest);
" are at grace points in time. ",
/* create */ "Beam",
- /* accept */ "beam-event",
/* read */
"beamMelismaBusy "
"beatLength "