X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Fsystem-start-delimiter-engraver.cc;h=9734f522cbda7ad9af4d33e411a7ab94dda97254;hb=6e227b10eed0ebe522ca7512eb7d2cc1d9561e64;hp=719a5ed17d0a8cb8c91097fa49c65af8cc173650;hpb=664070d837cc4855091455892cb942cdcedeef0c;p=lilypond.git diff --git a/lily/system-start-delimiter-engraver.cc b/lily/system-start-delimiter-engraver.cc index 719a5ed17d..9734f522cb 100644 --- a/lily/system-start-delimiter-engraver.cc +++ b/lily/system-start-delimiter-engraver.cc @@ -1,16 +1,15 @@ -/* +/* system-start-delimiter-engraver.cc -- implement System_start_delimiter_engraver - + source file of the GNU LilyPond music typesetter - - (c) 2000--2004 Han-Wen Nienhuys - - */ + + (c) 2000--2005 Han-Wen Nienhuys +*/ #include "system-start-delimiter.hh" #include "engraver.hh" #include "staff-symbol.hh" -#include "group-interface.hh" +#include "pointer-group-interface.hh" #include "paper-column.hh" #include "output-def.hh" #include "spanner.hh" @@ -21,44 +20,39 @@ public: TRANSLATOR_DECLARATIONS (System_start_delimiter_engraver); protected: - Spanner * delim_; - virtual void acknowledge_grob (Grob_info); - virtual void process_music (); + Spanner *delim_; + DECLARE_ACKNOWLEDGER (system_start_delimiter); + DECLARE_ACKNOWLEDGER (staff_symbol); + + void process_music (); virtual void finalize (); }; +void +System_start_delimiter_engraver::acknowledge_staff_symbol (Grob_info inf) +{ + /* + don't add as Axis_group_interface::add_element (delim_, ), + because that would set the parent as well */ - + Pointer_group_interface::add_grob (delim_, ly_symbol2scm ("elements"), inf.grob ()); +} void -System_start_delimiter_engraver::acknowledge_grob (Grob_info inf) +System_start_delimiter_engraver::acknowledge_system_start_delimiter (Grob_info inf) { - if (Staff_symbol::has_interface (inf.grob_)) - { - /* - don't add as Axis_group_interface::add_element (delim_,), - because that would set the parent as well */ - - Pointer_group_interface::add_grob (delim_, ly_symbol2scm ("elements"), inf.grob_); - } - else if (System_start_delimiter::has_interface (inf.grob_)) - { - SCM gl = inf.grob_->get_property ("glyph"); - SCM my_gl = delim_->get_property ("glyph"); + SCM gl = inf.grob ()->get_property ("glyph"); + SCM my_gl = delim_->get_property ("glyph"); - /* - UGH UGH - */ - if (ly_c_string_p (gl) && ly_c_equal_p (gl, scm_makfrom0str ("brace")) - && ly_c_string_p (my_gl) && ly_c_equal_p (my_gl, scm_makfrom0str ("bracket"))) - inf.grob_->translate_axis (-0.8, X_AXIS); // ugh - else if (ly_c_string_p (gl) && ly_c_equal_p (gl, scm_makfrom0str ("bracket")) - && ly_c_string_p (my_gl) && ly_c_equal_p (my_gl, scm_makfrom0str ("bracket"))) - { - inf.grob_->translate_axis ( -0.8, X_AXIS); // ugh - inf.grob_->set_property ("arch-height", - scm_make_real (ly_scm2double (inf.grob_->get_property - ("arch-height"))+0.5)); - } + /* + UGH UGH + */ + if (scm_is_string (gl) && ly_is_equal (gl, scm_makfrom0str ("brace")) + && scm_is_string (my_gl) && ly_is_equal (my_gl, scm_makfrom0str ("bracket"))) + inf.grob ()->translate_axis (-0.8, X_AXIS); // ugh + else if (scm_is_string (gl) && ly_is_equal (gl, scm_makfrom0str ("bracket")) + && scm_is_string (my_gl) && ly_is_equal (my_gl, scm_makfrom0str ("bracket"))) + { + inf.grob ()->translate_axis (-0.8, X_AXIS); // ugh } } @@ -72,11 +66,11 @@ System_start_delimiter_engraver::process_music () { if (!delim_) { - SCM delim_name =get_property ("systemStartDelimiter"); - delim_ = make_spanner_from_properties (this, delim_name, SCM_EOL); + SCM delim_name = get_property ("systemStartDelimiter"); + delim_ = make_spanner_from_properties (this, delim_name, SCM_EOL, + ly_symbol2string (delim_name).to_str0 ()); delim_->set_bound (LEFT, unsmob_grob (get_property ("currentCommandColumn"))); - } } void @@ -85,14 +79,17 @@ System_start_delimiter_engraver::finalize () if (delim_) { delim_->set_bound (RIGHT, unsmob_grob (get_property ("currentCommandColumn"))); - } } -ENTER_DESCRIPTION (System_start_delimiter_engraver, -/* descr */ "Creates a system start delimiter (ie. SystemStart@{Bar,Brace,Bracket@} spanner", -/* creats*/ "SystemStartBar SystemStartBrace SystemStartBracket", -/* accepts */ "", -/* acks */ "system-start-delimiter-interface staff-symbol-interface", -/* reads */ "systemStartDelimiter", -/* write */ ""); +#include "translator.icc" + +ADD_ACKNOWLEDGER (System_start_delimiter_engraver, system_start_delimiter); +ADD_ACKNOWLEDGER (System_start_delimiter_engraver, staff_symbol); + +ADD_TRANSLATOR (System_start_delimiter_engraver, + /* descr */ "Creates a system start delimiter (ie. SystemStart@{Bar, Brace, Bracket@} spanner", + /* creats*/ "SystemStartBar SystemStartBrace SystemStartBracket", + /* accepts */ "", + /* reads */ "systemStartDelimiter", + /* write */ "");