]> git.donarmstrong.com Git - lilypond.git/blobdiff - lily/rest-engraver.cc
Doc-es: various updates.
[lilypond.git] / lily / rest-engraver.cc
index f4e2b08ebf4a6ce2319b64b7e0905f3ddbcf3f65..8902e3591121c0adfc98a969c7af5da6e6eae4b1 100644 (file)
@@ -1,9 +1,20 @@
 /*
-  rest-engraver.cc -- implement Rest_engraver
+  This file is part of LilyPond, the GNU music typesetter.
 
-  source file of the GNU LilyPond music typesetter
+  Copyright (C) 1997--2015 Han-Wen Nienhuys <hanwen@xs4all.nl>
 
-  (c) 1997--2008 Han-Wen Nienhuys <hanwen@xs4all.nl>
+  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 <http://www.gnu.org/licenses/>.
 */
 
 #include "engraver.hh"
@@ -26,7 +37,7 @@ class Rest_engraver : public Engraver
 protected:
   void start_translation_timestep ();
   void process_music ();
-  DECLARE_TRANSLATOR_LISTENER (rest);
+  void listen_rest (Stream_event *);
 public:
   TRANSLATOR_DECLARATIONS (Rest_engraver);
 };
@@ -34,7 +45,8 @@ public:
 /*
   Should merge with Note_head_engraver
 */
-Rest_engraver::Rest_engraver ()
+Rest_engraver::Rest_engraver (Context *c)
+  : Engraver (c)
 {
   rest_event_ = 0;
   rest_ = 0;
@@ -55,37 +67,42 @@ Rest_engraver::process_music ()
   if (rest_event_ && !rest_)
     {
       rest_ = make_item ("Rest", rest_event_->self_scm ());
-      Pitch *p = unsmob_pitch (rest_event_->get_property ("pitch"));
+      Pitch *p = unsmob<Pitch> (rest_event_->get_property ("pitch"));
 
       if (p)
-       {
-         int pos = p->steps ();
-         SCM c0 = get_property ("middleCPosition");
-         if (scm_is_number (c0))
-           pos += scm_to_int (c0);
-
-         rest_->set_property ("staff-position", scm_from_int (pos));
-       }
+        {
+          int pos = p->steps ();
+          SCM c0 = get_property ("middleCPosition");
+          if (scm_is_number (c0))
+            pos += scm_to_int (c0);
+
+          rest_->set_property ("staff-position", scm_from_int (pos));
+        }
     }
 }
 
-IMPLEMENT_TRANSLATOR_LISTENER (Rest_engraver, rest);
 void
 Rest_engraver::listen_rest (Stream_event *ev)
 {
   ASSIGN_EVENT_ONCE (rest_event_, ev);
 }
 
+void
+Rest_engraver::boot ()
+{
+  ADD_LISTENER (Rest_engraver, rest);
+}
+
 ADD_TRANSLATOR (Rest_engraver,
-               /* doc */
-               "Engrave rests.",
+                /* doc */
+                "Engrave rests.",
 
-               /* create */
-               "Rest ",
+                /* create */
+                "Rest ",
 
-               /* read */
-               "middleCPosition ",
+                /* read */
+                "middleCPosition ",
 
-               /* write */
-               ""
-               );
+                /* write */
+                ""
+               );