X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=lily%2Fbook.cc;h=265632a3656d26145d53ad7e8beb0e86ab6131f5;hb=d060f0152577ccb01bfa3d4c50a3f91d676573ca;hp=114ef0cdf2df8cc5c56bedef16beb90f3c68a4a4;hpb=0fee6eb672cef04454e02856412f9bcea3f4115b;p=lilypond.git diff --git a/lily/book.cc b/lily/book.cc index 114ef0cdf2..265632a365 100644 --- a/lily/book.cc +++ b/lily/book.cc @@ -3,7 +3,7 @@ source file of the GNU LilyPond music typesetter - (c) 1997--2006 Han-Wen Nienhuys + (c) 1997--2007 Han-Wen Nienhuys */ #include "book.hh" @@ -11,21 +11,16 @@ #include using namespace std; -#include "lilypond-key.hh" -#include "global-context.hh" #include "main.hh" -#include "music-iterator.hh" -#include "music-output.hh" #include "music.hh" #include "output-def.hh" #include "paper-book.hh" #include "score.hh" -#include "stencil.hh" #include "text-interface.hh" #include "warn.hh" - #include "performance.hh" #include "paper-score.hh" +#include "page-marker.hh" #include "ly-smobs.icc" @@ -49,20 +44,24 @@ Book::Book (Book const &s) smobify_self (); if (s.paper_) - paper_ = s.paper_->clone (); + { + paper_ = s.paper_->clone (); + paper_->unprotect (); + } input_location_ = make_input (*s.origin ()); + header_ = ly_make_anonymous_module (false); if (ly_is_module (s.header_)) ly_module_copy (header_, s.header_); - + SCM *t = &scores_; for (SCM p = s.scores_; scm_is_pair (p); p = scm_cdr (p)) { Score *newscore = unsmob_score (scm_car (p))->clone (); *t = scm_cons (newscore->self_scm (), SCM_EOL); - t = SCM_CDRLOC(*t); + t = SCM_CDRLOC (*t); newscore->unprotect (); } } @@ -85,11 +84,6 @@ Book::mark_smob (SCM s) { Book *book = (Book *) SCM_CELL_WORD_1 (s); -#if 0 - if (book->key_) - scm_gc_mark (book->key_->self_scm ()); -#endif - if (book->paper_) scm_gc_mark (book->paper_->self_scm ()); scm_gc_mark (book->scores_); @@ -118,7 +112,7 @@ Paper_book * Book::process (Output_def *default_paper, Output_def *default_layout) { - for (SCM s = scores_; s != SCM_EOL; s = scm_cdr (s)) + for (SCM s = scores_; scm_is_pair (s); s = scm_cdr (s)) if (Score *score = unsmob_score (scm_car (s))) if (score->error_found_) return 0; @@ -131,21 +125,18 @@ Book::process (Output_def *default_paper, Real scale = scm_to_double (paper->c_variable ("output-scale")); Output_def *scaled_bookdef = scale_output_def (paper, scale); - Object_key *key = new Lilypond_general_key (0, user_key_, 0); - SCM scm_key = key->unprotect (); - paper_book->paper_ = scaled_bookdef; scaled_bookdef->unprotect (); paper_book->header_ = header_; /* Render in order of parsing. */ - for (SCM s = scm_reverse (scores_); s != SCM_EOL; s = scm_cdr (s)) + for (SCM s = scm_reverse (scores_); scm_is_pair (s); s = scm_cdr (s)) { if (Score *score = unsmob_score (scm_car (s))) { SCM outputs = score - ->book_rendering (paper_book->paper_, default_layout, key); + ->book_rendering (paper_book->paper_, default_layout); while (scm_is_pair (outputs)) { @@ -163,13 +154,13 @@ Book::process (Output_def *default_paper, outputs = scm_cdr (outputs); } } - else if (Text_interface::is_markup (scm_car (s))) + else if (Text_interface::is_markup (scm_car (s)) + || unsmob_page_marker (scm_car (s))) paper_book->add_score (scm_car (s)); else assert (0); } - scm_remember_upto_here_1 (scm_key); return paper_book; }