X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Fdot-column-engraver.cc;h=2cdc4a0f7f68b84b5d3331691fcebced1ff5b243;hb=33f2e59ea0b2a1ba41e943b5afa29e5fee97ba94;hp=935d3f3e65e28375bb2ce9870c03b36cbe4e77c4;hpb=9661ba1fb275f3e14f8a69f2cee2f02a2f893e48;p=lilypond.git diff --git a/lily/dot-column-engraver.cc b/lily/dot-column-engraver.cc index 935d3f3e65..2cdc4a0f7f 100644 --- a/lily/dot-column-engraver.cc +++ b/lily/dot-column-engraver.cc @@ -3,7 +3,7 @@ source file of the GNU LilyPond music typesetter - (c) 1998--2000 Han-Wen Nienhuys + (c) 1998--2003 Han-Wen Nienhuys */ @@ -12,57 +12,78 @@ #include "dot-column.hh" #include "side-position-interface.hh" #include "engraver.hh" +#include "stem.hh" class Dot_column_engraver : public Engraver { - Score_element *dotcol_p_ ; - Link_array head_l_arr_; + Grob *dotcol_ ; + Grob * stem_; + Link_array heads_; public: - VIRTUAL_COPY_CONS(Translator); - Dot_column_engraver(); + TRANSLATOR_DECLARATIONS( + Dot_column_engraver ); protected: - virtual void acknowledge_element (Score_element_info); - virtual void do_pre_move_processing (); + virtual void acknowledge_grob (Grob_info); + virtual void stop_translation_timestep (); }; Dot_column_engraver::Dot_column_engraver () { - dotcol_p_ =0; + dotcol_ =0; + stem_ = 0; } void -Dot_column_engraver::do_pre_move_processing () +Dot_column_engraver::stop_translation_timestep () { - if (dotcol_p_) + if (dotcol_) { - typeset_element (dotcol_p_); - dotcol_p_ =0; + + /* + Add the stem to the support so dots stay clear of flags. + + See [Ross, p 171] + */ + if (stem_) + dotcol_->set_grob_property ("stem", stem_->self_scm ()); + + typeset_grob (dotcol_); + dotcol_ =0; } - head_l_arr_.clear (); + heads_.clear (); + stem_ =0; } void -Dot_column_engraver::acknowledge_element (Score_element_info info) +Dot_column_engraver::acknowledge_grob (Grob_info info) { - Score_element *d = unsmob_element (info.elem_l_->get_elt_property ("dot")); + Grob *d = unsmob_grob (info.grob_->get_grob_property ("dot")); if (d) { - if (!dotcol_p_) + if (!dotcol_) { - dotcol_p_ = new Item(get_property ("basicDotColumnProperties")); - - Dot_column::set_interface (dotcol_p_); - Side_position::set_axis (dotcol_p_, X_AXIS); - Side_position::set_direction (dotcol_p_, RIGHT); - announce_element (dotcol_p_, 0); + dotcol_ = make_item ("DotColumn"); + announce_grob(dotcol_, SCM_EOL); } - Dot_column::add_head (dotcol_p_, info.elem_l_); + Dot_column::add_head (dotcol_, info.grob_); + } + else if (Stem::has_interface (info.grob_)) + { + stem_ = info.grob_; } } -ADD_THIS_TRANSLATOR(Dot_column_engraver); + +ENTER_DESCRIPTION(Dot_column_engraver, +/* descr */ " Engraves dots on dotted notes shifted to the right of the note.\n" +"If omitted, then dots appear on top of the notes.", +/* creats*/ "DotColumn", +/* accepts */ "", +/* acks */ "rhythmic-head-interface dot-column-interface stem-interface", +/* reads */ "", +/* write */ "");