-/*
- font-size-engraver.cc -- implement Font_size_engraver
-
+/*
+ font-size-engraver.cc -- implement Font_size_engraver
+
source file of the GNU LilyPond music typesetter
-
- (c) 2001--2003 Han-Wen Nienhuys <hanwen@cs.uu.nl>
-
- */
+
+ (c) 2001--2009 Han-Wen Nienhuys <hanwen@xs4all.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);
+ DECLARE_ACKNOWLEDGER (font);
+ void process_music ();
+ Real size;
private:
};
-
Font_size_engraver::Font_size_engraver ()
{
-
+ size = 0.0;
}
void
-Font_size_engraver::acknowledge_grob (Grob_info gi)
+Font_size_engraver::process_music ()
{
- SCM sz = get_property ("fontSize");
+ size = robust_scm2double (get_property ("fontSize"), 0.0);
+}
+void
+Font_size_engraver::acknowledge_font (Grob_info gi)
+{
/*
We only want to process a grob once.
- */
- if (gi.origin_trans_->daddy_trans_ != daddy_trans_)
- return ;
-
- if (gh_number_p (sz) && gh_scm2double (sz))
- {
- Real font_size = gh_scm2double (sz);
-
- font_size += robust_scm2double (gi.grob_->get_grob_property ("font-size"), 0);
- gi.grob_->set_grob_property ("font-size", gh_double2scm (font_size));
- }
+ */
+ if (!size)
+ return;
+
+ if (gi.context () != context ())
+ return;
+
+ Real font_size = size
+ + robust_scm2double (gi.grob ()->get_property ("font-size"), 0);
+ gi.grob ()->set_property ("font-size", scm_from_double (font_size));
}
+#include "translator.icc"
+
+ADD_ACKNOWLEDGER (Font_size_engraver, font);
+ADD_TRANSLATOR (Font_size_engraver,
+ /* doc */
+ "Put @code{fontSize} into @code{font-size} grob property.",
+
+ /* create */
+ "",
+
+ /* read */
+ "fontSize ",
-ENTER_DESCRIPTION(Font_size_engraver,
-/* descr */ "Puts fontSize into font-relative-size grob property.",
-/* creats*/ "",
-/* accepts */ "",
-/* acks */ "font-interface",
-/* reads */ "fontSize",
-/* write */ "");
+ /* write */
+ ""
+ );