2 ' separating-line-group-engraver.cc -- implement Separating_line_group_engraver
4 source file of the GNU LilyPond music typesetter
6 (c) 1998--2001 Han-Wen Nienhuys <hanwen@cs.uu.nl>
11 #include "separating-group-spanner.hh"
12 #include "separation-item.hh"
13 #include "paper-column.hh"
14 #include "paper-def.hh"
15 #include "engraver.hh"
16 #include "axis-group-interface.hh"
18 class Separating_line_group_engraver : public Engraver
22 Item * musical_malt_p_;
25 malt_p_ : we used to have a Single_malt_grouping_item
28 Item * last_step_musical_malt_p_;
29 Item * last_nonnil_musical_malt_p_;
30 Item * last_nonnil_break_malt_p_;
32 Spanner * sep_span_p_;
34 virtual void acknowledge_grob (Grob_info);
35 virtual void initialize ();
36 virtual void finalize ();
37 virtual void stop_translation_timestep ();
39 Separating_line_group_engraver ();
40 VIRTUAL_COPY_CONS (Translator);
43 Separating_line_group_engraver::Separating_line_group_engraver ()
45 last_step_musical_malt_p_ = 0;
46 last_nonnil_break_malt_p_ = 0;
47 last_nonnil_musical_malt_p_ = 0;
55 Separating_line_group_engraver::initialize ()
57 sep_span_p_ = new Spanner (get_property ("SeparatingGroupSpanner"));
59 announce_grob (sep_span_p_, 0);
60 sep_span_p_->set_bound (LEFT, unsmob_grob (get_property ("currentCommandColumn")));
64 Separating_line_group_engraver::finalize ()
66 sep_span_p_->set_bound (RIGHT, unsmob_grob (get_property ("currentCommandColumn")));
67 typeset_grob (sep_span_p_);
72 Separating_line_group_engraver::acknowledge_grob (Grob_info i)
74 Item * it = dynamic_cast <Item *> (i.elem_l_);
77 if (it->parent_l (X_AXIS)
78 && it->parent_l (X_AXIS)->has_extent_callback_b
79 (Axis_group_interface::group_extent_callback_proc, X_AXIS))
83 bool ib =Item::breakable_b (it);
84 Item *&p_ref_ (ib ? break_malt_p_
90 (get_property ("SeparationItem"));
93 p_ref_->set_grob_property ("breakable", SCM_BOOL_T);
94 announce_grob (p_ref_, 0);
96 Separation_item::add_item (p_ref_,it);
100 Separating_line_group_engraver::stop_translation_timestep ()
104 Separating_group_spanner::add_spacing_unit (sep_span_p_, break_malt_p_);
106 typeset_grob (break_malt_p_);
108 last_nonnil_break_malt_p_ = break_malt_p_;
114 Separating_group_spanner::add_spacing_unit (sep_span_p_, musical_malt_p_);
119 move this mucketry into separation-spanner.
122 if (last_nonnil_break_malt_p_ && last_nonnil_musical_malt_p_)
124 cout << now_mom ().str () <<endl;
125 Item *col = last_nonnil_break_malt_p_->column_l();
127 col = dynamic_cast<Item*> (unsmob_grob (get_property ("currentCommandColumn")));
129 SCM between = col->get_grob_property ("between-cols");
131 SCM left = last_nonnil_musical_malt_p_->column_l()->self_scm ();
132 SCM right = get_property ("currentMusicalColumn"); // musical_malt_p_->column_l()->self_scm ();
133 if (gh_pair_p (between))
138 if (Paper_column::rank_i (unsmob_grob (gh_car (between))) < Paper_column::rank_i (unsmob_grob (left)))
139 gh_set_car_x (between, left);
140 if (Paper_column::rank_i (unsmob_grob (gh_cdr (between))) > Paper_column::rank_i (unsmob_grob (right)))
141 gh_set_cdr_x (between, right);
145 col->set_grob_property ("between-cols", gh_cons (left, right));
149 if (last_step_musical_malt_p_)
152 last_step_musical_malt_p_->column_l();
153 SCM newtup = gh_cons (last_step_musical_malt_p_->self_scm (),
154 musical_malt_p_->self_scm ());
155 col->set_grob_property ("spacing-sequence",
157 col->get_grob_property ("spacing-sequence")));
162 last_nonnil_break_malt_p_ = 0;
163 last_nonnil_musical_malt_p_ = musical_malt_p_;
164 typeset_grob (musical_malt_p_);
166 last_step_musical_malt_p_ = musical_malt_p_;
173 ADD_THIS_TRANSLATOR (Separating_line_group_engraver);