return system_;
}
+void
+Paper_column::set_system (System *s)
+{
+ system_ = s;
+}
+
Paper_column *
Paper_column::get_column () const
{
rank_ = src.rank_;
}
+int
+Paper_column::compare (Grob * const &a,
+ Grob * const &b)
+{
+ return sign (dynamic_cast<Paper_column*> (a)->rank_
+ - dynamic_cast<Paper_column*> (b)->rank_);
+}
+
Moment
Paper_column::when_mom (Grob *me)
{
if (bbm.size ())
return true;
- if (Item::is_breakable (me))
+ if (Paper_column::is_breakable (me))
return true;
if (to_boolean (me->get_property ("used")))
return false;
}
+bool
+Paper_column::is_breakable (Grob *me)
+{
+ return scm_is_symbol (me->get_property ("line-break-permission"));
+}
+
/*
Print a vertical line and the rank number, to aid debugging.
*/
{
Grob *me = unsmob_grob (p);
- String r = to_string (Paper_column::get_rank (me));
+ string r = to_string (Paper_column::get_rank (me));
Moment *mom = unsmob_moment (me->get_property ("when"));
- String when = mom ? mom->to_string () : "?/?";
+ string when = mom ? mom->to_string () : "?/?";
SCM properties = Font_interface::text_font_alist_chain (me);
if (!ga)
return SCM_UNSPECIFIED;
- Link_array<Grob> &array (ga->array_reference ());
+ vector<Grob*> &array (ga->array_reference ());
- for (int i = array.size (); i--;)
+ for (vsize i = array.size (); i--;)
{
Grob *g = array[i];
if (!g || !g->is_live ())
- { // UGH . potentially quadratic.
- array.del (i);
- }
+ /* UGH . potentially quadratic. */
+ array.erase (array.begin () + i);
}
return SCM_UNSPECIFIED;
/* properties */
"between-cols "
"bounded-by-me "
+ "grace-spacing "
"line-break-system-details "
- "page-penalty "
+ "line-break-penalty "
+ "line-break-permission "
+ "page-break-penalty "
+ "page-break-permission "
+ "page-turn-penalty "
+ "page-turn-permission "
"shortest-playing-duration "
"shortest-starter-duration "
+ "spacing "
"used "
"when ");