2 This file is part of LilyPond, the GNU music typesetter.
4 Copyright (C) 2004--2015 Han-Wen Nienhuys <hanwen@xs4all.nl>
6 LilyPond is free software: you can redistribute it and/or modify
7 it under the terms of the GNU General Public License as published by
8 the Free Software Foundation, either version 3 of the License, or
9 (at your option) any later version.
11 LilyPond is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 GNU General Public License for more details.
16 You should have received a copy of the GNU General Public License
17 along with LilyPond. If not, see <http://www.gnu.org/licenses/>.
22 #include "output-def.hh"
24 #include "paper-book.hh"
26 LY_DEFINE (ly_make_book, "ly:make-book",
27 2, 0, 1, (SCM paper, SCM header, SCM scores),
28 "Make a @code{\\book} of @var{paper} and @var{header}"
29 " (which may be @code{#f} as well) containing @code{\\scores}.")
31 Output_def *odef = unsmob<Output_def> (paper);
32 LY_ASSERT_SMOB (Output_def, paper, 1);
34 Book *book = new Book;
37 if (ly_is_module (header))
38 book->header_ = header;
40 book->scores_ = scm_append (scm_list_2 (scores, book->scores_));
42 SCM x = book->self_scm ();
47 LY_DEFINE (ly_make_book_part, "ly:make-book-part",
48 1, 0, 0, (SCM scores),
49 "Make a @code{\\bookpart} containing @code{\\scores}.")
51 Book *book = new Book;
52 book->scores_ = scm_append (scm_list_2 (scores, book->scores_));
54 SCM x = book->self_scm ();
59 LY_DEFINE (ly_book_process, "ly:book-process",
60 4, 0, 0, (SCM book_smob,
64 "Print book. @var{output} is passed to the backend unchanged."
65 " For example, it may be a string (for file based outputs)"
66 " or a socket (for network based output).")
68 Book *book = unsmob<Book> (book_smob);
70 LY_ASSERT_SMOB (Book, book_smob, 1);
71 LY_ASSERT_SMOB (Output_def, default_paper, 2);
72 LY_ASSERT_SMOB (Output_def, default_layout, 3);
74 Paper_book *pb = book->process (unsmob<Output_def> (default_paper),
75 unsmob<Output_def> (default_layout));
82 return SCM_UNSPECIFIED;
85 LY_DEFINE (ly_book_process_to_systems, "ly:book-process-to-systems",
86 4, 0, 0, (SCM book_smob,
90 "Print book. @var{output} is passed to the backend unchanged."
91 " For example, it may be a string (for file based outputs)"
92 " or a socket (for network based output).")
94 LY_ASSERT_SMOB (Book, book_smob, 1);
95 LY_ASSERT_SMOB (Output_def, default_paper, 2);
96 LY_ASSERT_SMOB (Output_def, default_layout, 3);
98 Book *book = unsmob<Book> (book_smob);
100 Paper_book *pb = book->process (unsmob<Output_def> (default_paper),
101 unsmob<Output_def> (default_layout));
104 pb->classic_output (output);
108 return SCM_UNSPECIFIED;
111 LY_DEFINE (ly_book_add_score_x, "ly:book-add-score!",
112 2, 0, 0, (SCM book_smob, SCM score),
113 "Add @var{score} to @var{book-smob} score list.")
115 LY_ASSERT_SMOB (Book, book_smob, 1);
116 Book *book = unsmob<Book> (book_smob);
117 book->add_score (score);
118 return SCM_UNSPECIFIED;
121 LY_DEFINE (ly_book_add_bookpart_x, "ly:book-add-bookpart!",
122 2, 0, 0, (SCM book_smob, SCM book_part),
123 "Add @var{book-part} to @var{book-smob} book part list.")
125 LY_ASSERT_SMOB (Book, book_smob, 1);
126 Book *book = unsmob<Book> (book_smob);
127 book->add_bookpart (book_part);
128 return SCM_UNSPECIFIED;
131 LY_DEFINE (ly_book_book_parts, "ly:book-book-parts",
133 "Return book parts in @var{book}.")
135 LY_ASSERT_SMOB (Book, book, 1);
136 Book *b = unsmob<Book> (book);
137 return b->bookparts_;
140 LY_DEFINE (ly_book_paper, "ly:book-paper",
142 "Return paper in @var{book}.")
144 LY_ASSERT_SMOB (Book, book, 1);
145 Book *b = unsmob<Book> (book);
146 return b->paper_ ? b->paper_->self_scm () : SCM_BOOL_F;
149 LY_DEFINE (ly_book_header, "ly:book-header",
151 "Return header in @var{book}.")
153 LY_ASSERT_SMOB (Book, book, 1);
154 Book *b = unsmob<Book> (book);
155 return ly_is_module (b->header_) ? b->header_ : SCM_BOOL_F;
158 LY_DEFINE (ly_book_set_header_x, "ly:book-set-header!",
159 2, 0, 0, (SCM book, SCM module),
160 "Set the book header.")
162 LY_ASSERT_SMOB (Book, book, 1);
163 SCM_ASSERT_TYPE (ly_is_module (module), module, SCM_ARG2, __FUNCTION__,
166 Book *b = unsmob<Book> (book);
167 b->header_ = (module);
168 return SCM_UNSPECIFIED;
171 LY_DEFINE (ly_book_scores, "ly:book-scores",
173 "Return scores in @var{book}.")
175 LY_ASSERT_SMOB (Book, book, 1);
176 Book *b = unsmob<Book> (book);
181 const char * const Book::type_p_name_ = "ly:book?";