source file of the GNU LilyPond music typesetter
- (c) 1996--2005 Han-Wen Nienhuys <hanwen@cs.uu.nl>
+ (c) 1996--2006 Han-Wen Nienhuys <hanwen@xs4all.nl>
*/
#include "paper-score.hh"
#include "all-font-metrics.hh"
+#include "book.hh"
#include "gourlay-breaking.hh"
+#include "international.hh"
#include "main.hh"
#include "misc.hh"
#include "output-def.hh"
assert (false);
}
-
void
Paper_score::derived_mark () const
{
+ if (layout_)
+ scm_gc_mark (layout_->self_scm ());
scm_gc_mark (systems_);
scm_gc_mark (paper_systems_);
}
systems_ = scm_cons (system->self_scm (), systems_);
system->pscore_ = this;
-
- scm_gc_unprotect_object (system->self_scm ());
+ system->layout_ = layout_;
+ system->unprotect ();
}
-Array<Column_x_positions>
+std::vector<Column_x_positions>
Paper_score::calc_breaking ()
{
Break_algorithm *algorithm = 0;
- Array<Column_x_positions> sol;
+ std::vector<Column_x_positions> sol;
algorithm = new Gourlay_breaking;
algorithm->set_pscore (this);
doubly, also done in Score_engraver */
Link_array<Grob> pc (system_->columns ());
pc[0]->set_property ("breakable", SCM_BOOL_T);
- pc.top ()->set_property ("breakable", SCM_BOOL_T);
+ pc.back ()->set_property ("breakable", SCM_BOOL_T);
system_->pre_processing ();
- Array<Column_x_positions> breaking = calc_breaking ();
+ std::vector<Column_x_positions> breaking = calc_breaking ();
system_->break_into_pieces (breaking);
paper_systems_ = system_->get_paper_systems ();
{
return layout_;
}
-
SCM
Paper_score::get_paper_systems () const