]> git.donarmstrong.com Git - lilypond.git/blobdiff - lily/include/paper-book.hh
Merge commit 'origin/dev/jneeman' into systems-per-page
[lilypond.git] / lily / include / paper-book.hh
index 0a18454979cf902d3512506db329aa849adedc9d..90e816f66da6257ae6d94af69736635bacffdd72 100644 (file)
@@ -3,32 +3,67 @@
 
   source file of the GNU LilyPond music typesetter
 
-  (c) 2004  Jan Nieuwenhuizen <janneke@gnu.org>
+  (c) 2004--2009  Jan Nieuwenhuizen <janneke@gnu.org>
 */
-
 #ifndef PAPER_BOOK_HH
 #define PAPER_BOOK_HH
 
-#include "lily-guile.hh"
-#include "parray.hh"
-#include "protected-scm.hh"
+#include "std-vector.hh"
+#include "smobs.hh"
+#include "lily-proto.hh"
 
-#define PAGE_LAYOUT "ps"
+/** Paper_book collects headers, systems (Paper_system) and texts, and
+    exports them to the output backend, either as systems or as
+    completely formatted pages.  */
 
 class Paper_book
 {
+  DECLARE_SMOBS (Paper_book);
+
+  SCM systems_;
+  SCM pages_;
+  SCM performances_;
+
+  void add_score_title (SCM);
+  SCM get_score_title (SCM);
+  
 public:
-  Array<SCM> headers_;
-  Link_array<Paper_def> papers_;
-  Array<SCM> scores_;
+  SCM header_;
+  SCM header_0_;
+  SCM scores_;
+  SCM bookparts_;
+  Paper_book *parent_;
+  Output_def *paper_;
 
   Paper_book ();
-  Link_array<Page> *get_pages ();
-  SCM get_scopes (int);
-  Stencil* get_title (int);
-  void output (String);
-  void classic_output (String);
+
+  Output_def *top_paper ();
+
+  void add_score (SCM);
+  void add_bookpart (SCM);
+  void add_performance (SCM);
+
+  SCM performances () const;
+  SCM systems ();
+  SCM pages ();
+  SCM get_system_specs ();
+
+
+  Stencil book_title ();
+  Stencil score_title (SCM);
+  
+  void classic_output (SCM output_channel);
+  void output (SCM output_channel);
+
+protected:
+  void classic_output_aux (SCM output,
+                          int *first_performance_number);
+  int output_aux (SCM output_channel,
+                 bool is_last,
+                 int *first_page_number,
+                 int *first_performance_number);
 };
 
-#endif /* PAPER_BOOK_HH */
+DECLARE_UNSMOB (Paper_book, paper_book)
 
+#endif /* PAPER_BOOK_HH */