X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Fpitch-squash-engraver.cc;h=a5ccfa483ea70269f9c0c286abc52d2b04e474d5;hb=926115ff42def8bc1ce767029e4f03c8072994ba;hp=4ab2d01f0a502b4dbdada80e674bbd45ae6ef145;hpb=94189ec2b8da6d7e89dc619c646a927adead9b19;p=lilypond.git diff --git a/lily/pitch-squash-engraver.cc b/lily/pitch-squash-engraver.cc index 4ab2d01f0a..a5ccfa483e 100644 --- a/lily/pitch-squash-engraver.cc +++ b/lily/pitch-squash-engraver.cc @@ -1,33 +1,69 @@ -/* - pitch-squash-grav.cc -- implement Pitch_squash_engraver - - source file of the GNU LilyPond music typesetter - - (c) 1997--2001 Han-Wen Nienhuys - - */ +/* + This file is part of LilyPond, the GNU music typesetter. + + 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 + the Free Software Foundation, either version 3 of the License, or + (at your option) any later version. + + LilyPond is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + GNU General Public License for more details. + + You should have received a copy of the GNU General Public License + along with LilyPond. If not, see . +*/ + +#include "engraver.hh" + #include "staff-symbol-referencer.hh" #include "note-head.hh" #include "rhythmic-head.hh" -#include "engraver.hh" +#include "grob.hh" -class Pitch_squash_engraver : public Engraver { +class Pitch_squash_engraver : public Engraver +{ public: - VIRTUAL_COPY_CONS (Translator); - virtual void acknowledge_grob (Grob_info); + TRANSLATOR_DECLARATIONS (Pitch_squash_engraver); + void acknowledge_note_head (Grob_info); }; - void -Pitch_squash_engraver::acknowledge_grob (Grob_info i) +Pitch_squash_engraver::acknowledge_note_head (Grob_info i) { SCM newpos = get_property ("squashedPosition"); - if (Note_head::has_interface (i.elem_l_)) - { - i.elem_l_->set_grob_property ("staff-position", newpos); - } + if (scm_is_number (newpos)) + i.grob ()->set_property ("staff-position", newpos); } -ADD_THIS_TRANSLATOR (Pitch_squash_engraver); +Pitch_squash_engraver::Pitch_squash_engraver (Context *c) + : Engraver (c) +{ +} + +#include "translator.icc" +void +Pitch_squash_engraver::boot () +{ + ADD_ACKNOWLEDGER (Pitch_squash_engraver, note_head); +} + +ADD_TRANSLATOR (Pitch_squash_engraver, + /* doc */ + "Set the vertical position of note heads to" + " @code{squashedPosition}, if that property is set. This can" + " be used to make a single-line staff demonstrating the" + " rhythm of a melody.", + + /* create */ + "", + /* read */ + "squashedPosition ", + /* write */ + "" + );