X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=ly%2Ftitling-init.ly;h=e99b23064522f8dab17b2ae9b11228746cf55caf;hb=ff5b756b319b1a577e0ebcbe90b77feeef3eb1da;hp=9ef8cd48dd9b598f6d8f8a216474c6e117518781;hpb=5cfe4870e6871699219fa7a27a27d852d47bc54f;p=lilypond.git diff --git a/ly/titling-init.ly b/ly/titling-init.ly index 9ef8cd48dd..e99b230645 100644 --- a/ly/titling-init.ly +++ b/ly/titling-init.ly @@ -1,4 +1,4 @@ -\version "2.11.57" +\version "2.12.0" slashSeparator = \markup { \center-align @@ -10,8 +10,7 @@ slashSeparator = \markup { tagline = \markup { \with-url - %% todo: lilypond.org/music-engraving - #"http://lilypond.org/web/" + #"http://lilypond.org/" \line { %% 2014 = em dash. @@ -69,22 +68,51 @@ scoreTitleMarkup = \markup { \column { } } +%% Book first page and last page predicates +#(define (book-first-page? layout props) + "Return #t iff the current page number, got from @code{props}, is the +book first one." + (define (ancestor layout) + "Return the topmost layout ancestor" + (let ((parent (ly:output-def-parent layout))) + (if (not (ly:output-def? parent)) + layout + (ancestor parent)))) + (= (chain-assoc-get 'page:page-number props -1) + (ly:output-def-lookup (ancestor layout) 'first-page-number))) + +#(define (book-last-page? layout props) + "Return #t iff the current page number, got from @code{props}, is the +book last one." + (and (chain-assoc-get 'page:is-bookpart-last-page props #f) + (chain-assoc-get 'page:is-last-bookpart props #f))) + #(define (first-page layout props arg) - (if (= (chain-assoc-get 'page:page-number props -1) - (ly:output-def-lookup layout 'first-page-number)) + (if (book-first-page? layout props) (interpret-markup layout props arg) empty-stencil)) #(define (last-page layout props arg) - (if (chain-assoc-get 'page:last? props #f) - (interpret-markup layout props arg) - empty-stencil)) + (if (book-last-page? layout props) + (interpret-markup layout props arg) + empty-stencil)) #(define (not-first-page layout props arg) - (if (not (= (chain-assoc-get 'page:page-number props -1) - (ly:output-def-lookup layout 'first-page-number))) - (interpret-markup layout props arg) - empty-stencil)) + (if (not (book-first-page? layout props)) + (interpret-markup layout props arg) + empty-stencil)) + +%% Bookpart first page and last page predicates +#(define (part-first-page layout props arg) + (if (= (chain-assoc-get 'page:page-number props -1) + (ly:output-def-lookup layout 'first-page-number)) + (interpret-markup layout props arg) + empty-stencil)) + +#(define (part-last-page layout props arg) + (if (chain-assoc-get 'page:is-bookpart-last-page props #f) + (interpret-markup layout props arg) + empty-stencil)) %% unused #(define (not-single-page layout props arg) @@ -100,8 +128,7 @@ scoreTitleMarkup = \markup { \column { empty-stencil)) #(define (print-page-number-check-first layout props arg) - (if (or (not (= (chain-assoc-get 'page:page-number props -1) - (ly:output-def-lookup layout 'first-page-number))) + (if (or (not (book-first-page? layout props)) (eq? (ly:output-def-lookup layout 'print-first-page-number) #t)) (create-page-number-stencil layout props arg) empty-stencil))