+ if (!dots[i]->is_live ())
+ dots.erase (dots.begin () + i);
+ else
+ // Undo any fake translations that were done in add_head.
+ dots[i]->translate_axis (-dots[i]->relative_coordinate (me, X_AXIS), X_AXIS);
+ }
+
+ Dot_formatting_problem problem (boxes, base_x);
+
+ Dot_configuration cfg (problem);
+ for (vsize i = 0; i < dots.size (); i++)
+ {
+ Dot_position dp;
+ dp.dot_ = dots[i];
+
+ Grob *note = dots[i]->get_parent (Y_AXIS);
+ if (note)
+ {
+ if (has_interface<Note_head> (note))
+ dp.dir_ = to_dir (dp.dot_->get_property ("direction"));
+
+ dp.x_extent_ = note->extent (commonx, X_AXIS);
+ }
+
+ int p = Staff_symbol_referencer::pure_get_rounded_position (dp.dot_);
+
+ /* icky, since this should go via a Staff_symbol_referencer
+ offset callback but adding a dot overwrites Y-offset. */
+ p += (int) robust_scm2double (dp.dot_->get_property ("staff-position"), 0.0);
+ dp.pos_ = p;
+
+ cfg.remove_collision (p);
+ cfg[p] = dp;
+ if (Staff_symbol_referencer::on_line (dp.dot_, p)
+ && !scm_is_eq (dp.dot_->get_property ("style"),
+ ly_symbol2scm ("kievan")))
+ cfg.remove_collision (p);
+ }
+
+ problem.register_configuration (cfg);
+
+ for (Dot_configuration::const_iterator i (cfg.begin ());
+ i != cfg.end (); i++)
+ {
+ /*
+ Junkme?
+ */
+ Staff_symbol_referencer::pure_set_position (i->second.dot_, i->first);
+ }
+
+ me->translate_axis (cfg.x_offset () - me->relative_coordinate (commonx, X_AXIS),
+ X_AXIS);
+ return SCM_BOOL_T;
+}
+
+void
+Dot_column::add_head (Grob *me, Grob *head)
+{
+ Grob *d = unsmob<Grob> (head->get_object ("dot"));
+ if (d)
+ {
+ Side_position_interface::add_support (me, head);
+
+ Pointer_group_interface::add_grob (me, ly_symbol2scm ("dots"), d);
+ d->set_property ("Y-offset", Grob::x_parent_positioning_proc);
+ // Dot formatting requests the Y-offset, which for rests may
+ // trigger post-linebreak callbacks. On the other hand, we need the
+ // correct X-offset of the dots for horizontal collision avoidance.
+ // The translation here is undone in calc_positioning_done, where we
+ // do the X-offset properly.
+ if (has_interface<Rest> (head))
+ d->translate_axis (head->extent (head, X_AXIS).length (), X_AXIS);
+ else
+ d->set_property ("X-offset", Grob::x_parent_positioning_proc);
+ Axis_group_interface::add_element (me, d);