X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Fnote-spacing-engraver.cc;h=8a5f5c7944228753efbc518241bf09773827fac6;hb=5b4b0d6e9a197e8f9eb085b7c2ad78b8be3e5cfc;hp=33c459cb133d42330fbbcb10945f109183e0929e;hpb=43bf56cad6efa84c004eb0bf636e652a6aec92a6;p=lilypond.git diff --git a/lily/note-spacing-engraver.cc b/lily/note-spacing-engraver.cc index 33c459cb13..8a5f5c7944 100644 --- a/lily/note-spacing-engraver.cc +++ b/lily/note-spacing-engraver.cc @@ -3,36 +3,52 @@ source file of the GNU LilyPond music typesetter - (c) 2006 Han-Wen Nienhuys + (c) 2006--2008 Han-Wen Nienhuys */ #include "engraver.hh" +#include "grob-array.hh" +#include "context.hh" #include "item.hh" #include "pointer-group-interface.hh" +#include + #include "translator.icc" class Note_spacing_engraver : public Engraver { + typedef map Last_spacing_map; + Last_spacing_map last_spacings_; Grob *last_spacing_; + Grob *spacing_; void add_spacing_item (Grob *); - TRANSLATOR_DECLARATIONS (Note_spacing_engraver); protected: DECLARE_ACKNOWLEDGER (rhythmic_grob); DECLARE_ACKNOWLEDGER (note_column); void stop_translation_timestep (); + virtual void finalize (); + virtual void derived_mark () const; }; +void +Note_spacing_engraver::derived_mark () const +{ + for (Last_spacing_map::const_iterator i = last_spacings_.begin (); + i != last_spacings_.end (); i++) + scm_gc_mark (i->first->self_scm ()); +} + Note_spacing_engraver::Note_spacing_engraver () { - last_spacing_ = 0; spacing_ = 0; + last_spacing_ = 0; } void @@ -43,7 +59,6 @@ Note_spacing_engraver::add_spacing_item (Grob *g) spacing_ = make_item ("NoteSpacing", g->self_scm ()); } - if (spacing_) { Pointer_group_interface::add_grob (spacing_, @@ -51,11 +66,9 @@ Note_spacing_engraver::add_spacing_item (Grob *g) g); if (last_spacing_) - { - Pointer_group_interface::add_grob (last_spacing_, - ly_symbol2scm ("right-items"), - g); - } + Pointer_group_interface::add_grob (last_spacing_, + ly_symbol2scm ("right-items"), + g); } } @@ -72,21 +85,61 @@ Note_spacing_engraver::acknowledge_rhythmic_grob (Grob_info gi) add_spacing_item (gi.grob ()); } +void +Note_spacing_engraver::finalize () +{ + Context *parent = context ()->get_parent_context (); + Grob *last_spacing = last_spacings_[parent]; + + if (last_spacing + && !unsmob_grob_array (last_spacing->get_object ("right-items"))) + { + Grob *col = unsmob_grob (get_property ("currentCommandColumn")); + + Pointer_group_interface::add_grob (last_spacing, + ly_symbol2scm ("right-items"), + col); + } +} + void Note_spacing_engraver::stop_translation_timestep () { + Context *parent = context ()->get_parent_context (); + Grob *last_spacing = last_spacings_[parent]; + + if (last_spacing + && to_boolean (get_property ("hasStaffSpacing"))) + { + Grob *col = unsmob_grob (get_property ("currentCommandColumn")); + Pointer_group_interface::add_grob (last_spacing, + ly_symbol2scm ("right-items"), + col); + } + if (spacing_) { + last_spacings_[parent] = spacing_; last_spacing_ = spacing_; spacing_ = 0; } + } ADD_ACKNOWLEDGER (Note_spacing_engraver, note_column); ADD_ACKNOWLEDGER (Note_spacing_engraver, rhythmic_grob); ADD_TRANSLATOR (Note_spacing_engraver, - /* doc */ "Generates NoteSpacing, an object linking horizontal lines for use in spacing.", - /* create */ "NoteSpacing", - /* read */ "", - /* write */ ""); + /* doc */ + "Generate @code{NoteSpacing}, an object linking horizontal" + " lines for use in spacing.", + + /* create */ + "NoteSpacing ", + + /* read */ + "", + + /* write */ + "" + );