X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Fcompletion-note-heads-engraver.cc;h=18b51cd4ec9440217301156565d22dc11addf128;hb=8e2eaf4959bec63a1128a444591a540f4f1e2937;hp=8a55ddf4621bbd90876ecaf27f8aa33091e69c1b;hpb=e8b68d8a878a0ee0381719230cf911dbcefa168d;p=lilypond.git diff --git a/lily/completion-note-heads-engraver.cc b/lily/completion-note-heads-engraver.cc index 8a55ddf462..18b51cd4ec 100644 --- a/lily/completion-note-heads-engraver.cc +++ b/lily/completion-note-heads-engraver.cc @@ -1,7 +1,7 @@ /* This file is part of LilyPond, the GNU music typesetter. - Copyright (C) 1997--2014 Han-Wen Nienhuys + Copyright (C) 1997--2015 Han-Wen Nienhuys LilyPond is free software: you can redistribute it and/or modify it under the terms of the GNU General Public License as published by @@ -59,7 +59,7 @@ class Completion_heads_engraver : public Engraver vector notes_; vector prev_notes_; // Must remember notes for explicit ties. - vector ties_; + vector ties_; vector note_events_; Spanner *tie_column_; Moment note_end_mom_; @@ -80,7 +80,7 @@ protected: void start_translation_timestep (); void process_music (); void stop_translation_timestep (); - DECLARE_TRANSLATOR_LISTENER (note); + void listen_note (Stream_event *); }; void @@ -89,7 +89,6 @@ Completion_heads_engraver::initialize () is_first_ = false; } -IMPLEMENT_TRANSLATOR_LISTENER (Completion_heads_engraver, note); void Completion_heads_engraver::listen_note (Stream_event *ev) { @@ -109,8 +108,8 @@ Completion_heads_engraver::listen_note (Stream_event *ev) Moment Completion_heads_engraver::next_moment (Rational const ¬e_len) { - Moment *e = Moment::unsmob (get_property ("measurePosition")); - Moment *l = Moment::unsmob (get_property ("measureLength")); + Moment *e = unsmob (get_property ("measurePosition")); + Moment *l = unsmob (get_property ("measureLength")); if (!e || !l || !to_boolean (get_property ("timing"))) { return Moment (0, 0); @@ -123,7 +122,7 @@ Completion_heads_engraver::next_moment (Rational const ¬e_len) + e->to_string () + " of " + l->to_string ()); return 0; } - Moment const *unit = Moment::unsmob (get_property ("completionUnit")); + Moment const *unit = unsmob (get_property ("completionUnit")); if (unit) { @@ -162,9 +161,9 @@ Item * Completion_heads_engraver::make_note_head (Stream_event *ev) { Item *note = make_item ("NoteHead", ev->self_scm ()); - Pitch *pit = Pitch::unsmob (ev->get_property ("pitch")); + Pitch *pit = unsmob (ev->get_property ("pitch")); - int pos = pit->steps (); + int pos = pit ? pit->steps () : 0; SCM c0 = get_property ("middleCPosition"); if (scm_is_number (c0)) pos += scm_to_int (c0); @@ -198,7 +197,7 @@ Completion_heads_engraver::process_music () } else { - orig = Duration::unsmob (note_events_[0]->get_property ("duration")); + orig = unsmob (note_events_[0]->get_property ("duration")); note_dur = *orig; SCM factor = get_property ("completionFactor"); if (ly_is_procedure (factor)) @@ -271,7 +270,7 @@ Completion_heads_engraver::process_music () void Completion_heads_engraver::make_tie (Grob *left, Grob *right) { - Grob *p = make_spanner ("Tie", SCM_EOL); + Spanner *p = make_spanner ("Tie", SCM_EOL); Tie::set_head (p, LEFT, left); Tie::set_head (p, RIGHT, right); announce_end_grob (p, SCM_EOL); @@ -302,11 +301,18 @@ Completion_heads_engraver::start_translation_timestep () ly_bool2scm (note_events_.size ())); } -Completion_heads_engraver::Completion_heads_engraver () +Completion_heads_engraver::Completion_heads_engraver (Context *c) + : Engraver (c) { tie_column_ = 0; } +void +Completion_heads_engraver::boot () +{ + ADD_LISTENER (Completion_heads_engraver, note); +} + ADD_TRANSLATOR (Completion_heads_engraver, /* doc */ "This engraver replaces @code{Note_heads_engraver}. It plays"