X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=ly%2Ftitling-init.ly;h=679742f29190cf87a086b6cadd404e902e393551;hb=23218d3fabd1599e709803b36a9eab48d25db810;hp=b5f5797c4e018915793b69f04f35018f604decec;hpb=19e574828ecfeb68ca7f6477348ed963c5e1fc92;p=lilypond.git diff --git a/ly/titling-init.ly b/ly/titling-init.ly index b5f5797c4e..679742f291 100644 --- a/ly/titling-init.ly +++ b/ly/titling-init.ly @@ -1,7 +1,7 @@ -\version "2.7.39" +\version "2.14.0" slashSeparator = \markup { - \hcenter + \center-align \vcenter \combine \beam #2.0 #0.5 #0.48 \raise #0.7 \beam #2.0 #0.5 #0.48 @@ -10,21 +10,21 @@ slashSeparator = \markup { tagline = \markup { \with-url - %% todo: lilypond.org/music-engraving - #"http://lilypond.org/web/" + #"http://lilypond.org/" \line { - "Music engraving by LilyPond" - " " - #(ly:export (lilypond-version)) - + %% 2014 = em dash. - #(ly:export (ly:wide-char->utf-8 #x2014)) - "www.lilypond.org" + + #(ly:export + (format #f "Music engraving by LilyPond ~a~awww.lilypond.org" + (lilypond-version) + (ly:wide-char->utf-8 #x2014) + )) } } #(define (print-all-headers layout props arg) - (if (eq? (ly:output-def-lookup layout 'printallheaders) #t) + (if (eq? (ly:output-def-lookup layout 'print-all-headers) #t) (interpret-markup layout props arg) empty-stencil)) @@ -34,13 +34,13 @@ bookTitleMarkup = \markup { \fill-line { \fromproperty #'header:dedication } \override #'(baseline-skip . 3.5) \column { - \huge \bigger \bold + \huge \larger \bold \fill-line { - \bigger \fromproperty #'header:title + \larger \fromproperty #'header:title } \fill-line { \large \smaller \bold - \bigger \fromproperty #'header:subtitle + \larger \fromproperty #'header:subtitle } \fill-line { \smaller \bold @@ -68,40 +68,69 @@ 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)) (interpret-markup layout props arg) - empty-stencil)) + (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) - (if (not (and (= (chain-assoc-get 'page:page-number props -1) + (if (not (and (= (chain-assoc-get 'page:page-number props -1) (ly:output-def-lookup layout 'first-page-number)) (chain-assoc-get 'page:last? props -1))) (interpret-markup layout props arg) empty-stencil)) -#(define (print-page-number layout props arg) +#(define (create-page-number-stencil layout props arg) (if (eq? (ly:output-def-lookup layout 'print-page-number) #t) (interpret-markup layout props arg) 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)) - (print-page-number layout props arg) + (create-page-number-stencil layout props arg) empty-stencil)) oddHeaderMarkup = \markup @@ -113,6 +142,8 @@ oddHeaderMarkup = \markup \on-the-fly #print-page-number-check-first \fromproperty #'page:page-number-string } +%% evenHeaderMarkup would inherit the value of +%% oddHeaderMarkup if it were not defined here evenHeaderMarkup = \markup \fill-line { \on-the-fly #print-page-number-check-first \fromproperty #'page:page-number-string @@ -133,3 +164,6 @@ oddFooterMarkup = \markup { } } +%% As long as evenFooterMarkup is unset, it inherits the value of +%% oddFooterMarkup, as if this were declared here: +% evenFooterMarkup = \oddFooterMarkup