]> git.donarmstrong.com Git - lilypond.git/blobdiff - lily/font-size-engraver.cc
remove TEXMF from variables.
[lilypond.git] / lily / font-size-engraver.cc
index 6ca9eea7cacd2ff1ea54fe5f28b642f1a4b7f059..a5f7848c7f455063899787b15ba332d2fe94b7a4 100644 (file)
@@ -1,28 +1,25 @@
-/*   
-  font-size-engraver.cc --  implement 
-  
+/*
+  font-size-engraver.cc -- implement Font_size_engraver
+
   source file of the GNU LilyPond music typesetter
-  
-  (c) 2001--2002  Han-Wen Nienhuys <hanwen@cs.uu.nl>
-  
- */
+
+  (c) 2001--2005  Han-Wen Nienhuys <hanwen@cs.uu.nl>
+*/
 
 #include "grob.hh"
 #include "engraver.hh"
 
 class Font_size_engraver : public Engraver
 {
-  
-  TRANSLATOR_DECLARATIONS(Font_size_engraver);
+
+  TRANSLATOR_DECLARATIONS (Font_size_engraver);
 protected:
   virtual void acknowledge_grob (Grob_info gi);
 private:
 };
 
-
 Font_size_engraver::Font_size_engraver ()
 {
-
 }
 
 void
@@ -30,19 +27,25 @@ Font_size_engraver::acknowledge_grob (Grob_info gi)
 {
   SCM sz = get_property ("fontSize");
 
-  if (gh_number_p (sz)
-      && gh_scm2int (sz)
-      && !gh_number_p (gi.grob_l_->get_grob_property ("font-relative-size")))
+  /*
+    We only want to process a grob once.
+  */
+  if (gi.origin_trans_->context () != context ())
+    return;
+
+  if (scm_is_number (sz) && scm_to_double (sz))
     {
-      gi.grob_l_->set_grob_property ("font-relative-size", sz);
+      Real font_size = scm_to_double (sz);
+
+      font_size += robust_scm2double (gi.grob_->get_property ("font-size"), 0);
+      gi.grob_->set_property ("font-size", scm_make_real (font_size));
     }
 }
 
-
-
-ENTER_DESCRIPTION(Font_size_engraver,
-/* descr */       "Puts fontSize into font-relative-size grob property.",
-/* creats*/       "",
-/* acks  */       "grob-interface",
-/* reads */       "fontSize",
-/* write */       "");
+ADD_TRANSLATOR (Font_size_engraver,
+               /* descr */ "Puts fontSize into font-relative-size grob property.",
+               /* creats*/ "",
+               /* accepts */ "",
+               /* acks  */ "font-interface",
+               /* reads */ "fontSize",
+               /* write */ "");