Compare commits
8 Commits
chordExcep
...
c49dba89f7
Author | SHA1 | Date | |
---|---|---|---|
c49dba89f7 | |||
195110923a | |||
8d0ddcee06 | |||
c47ceb443e | |||
377beeab57 | |||
cb4b74d4f7 | |||
616034baca | |||
34c9c5a932 |
@ -29,12 +29,14 @@
|
|||||||
\include "swing_style.ly"
|
\include "swing_style.ly"
|
||||||
\include "inline_score.ly"
|
\include "inline_score.ly"
|
||||||
\include "custom_indentation.ily"
|
\include "custom_indentation.ily"
|
||||||
|
\include "include_from_song.ily"
|
||||||
|
|
||||||
% reset important variables
|
% reset important variables
|
||||||
LAYOUT = \layout { \generalLayout }
|
LAYOUT = \layout { \generalLayout }
|
||||||
HEADER = {}
|
HEADER = {}
|
||||||
MUSIC = {}
|
MUSIC = {}
|
||||||
TEXT = \markuplist {""}
|
TEXT = \markuplist {}
|
||||||
|
TEXT_PAGES = #f
|
||||||
|
|
||||||
verseChords = {}
|
verseChords = {}
|
||||||
firstVoice = {}
|
firstVoice = {}
|
||||||
|
@ -114,7 +114,7 @@ width may require additional tweaking.)"
|
|||||||
|
|
||||||
|
|
||||||
includeSong =
|
includeSong =
|
||||||
#(define-void-function (parser location textproc filename) ((procedure?) string?)
|
#(define-void-function (parser location filename) (string?)
|
||||||
#{
|
#{
|
||||||
\bookOutputName #filename
|
\bookOutputName #filename
|
||||||
#}
|
#}
|
||||||
@ -125,7 +125,15 @@ includeSong =
|
|||||||
(acons label additional-page-numbers additional-page-switch-label-list))
|
(acons label additional-page-numbers additional-page-switch-label-list))
|
||||||
(set! song-list
|
(set! song-list
|
||||||
(acons (string->symbol filename)
|
(acons (string->symbol filename)
|
||||||
(acons 'label label (acons 'header HEADER (acons 'music MUSIC (acons 'layout LAYOUT (acons 'text #{ \markuplist \setsongfilename $filename $(if textproc (textproc TEXT) TEXT) #} '())))))
|
(acons 'label label
|
||||||
|
(acons 'header HEADER
|
||||||
|
(acons 'music MUSIC
|
||||||
|
(acons 'layout LAYOUT
|
||||||
|
(acons 'text-pages
|
||||||
|
(map (lambda (text)
|
||||||
|
#{ \markuplist \setsongfilename $filename $text #})
|
||||||
|
TEXT_PAGES)
|
||||||
|
'())))))
|
||||||
song-list))
|
song-list))
|
||||||
))
|
))
|
||||||
|
|
||||||
@ -184,14 +192,14 @@ songs =
|
|||||||
;(header (assq-ref songvars 'header))
|
;(header (assq-ref songvars 'header))
|
||||||
(music (assq-ref songvars 'music))
|
(music (assq-ref songvars 'music))
|
||||||
(layout (assq-ref songvars 'layout))
|
(layout (assq-ref songvars 'layout))
|
||||||
(text (assq-ref songvars 'text))
|
(text-pages (assq-ref songvars 'text-pages))
|
||||||
(label (assq-ref songvars 'label)))
|
(label (assq-ref songvars 'label)))
|
||||||
#{
|
#{
|
||||||
\bookpart {
|
\bookpart {
|
||||||
$header
|
$header
|
||||||
\headerToTOC #header #label
|
\headerToTOC #header #label
|
||||||
\score { $music \layout { $layout } }
|
\score { $music \layout { $layout } }
|
||||||
$text
|
$(add-text-pages text-pages)
|
||||||
}
|
}
|
||||||
#}))))))
|
#}))))))
|
||||||
(reverse song-list)
|
(reverse song-list)
|
||||||
|
@ -68,6 +68,18 @@ altChord =
|
|||||||
#mainchord
|
#mainchord
|
||||||
#}))
|
#}))
|
||||||
|
|
||||||
|
% Akkorde werden so transponiert, dass sie passen, wenn man mit Kapo im angegebenen Bund spielt
|
||||||
|
capoTranspose =
|
||||||
|
#(define-music-function (fret chords) (number? ly:music?)
|
||||||
|
(define semi->pitch
|
||||||
|
(make-semitone->pitch
|
||||||
|
(music-pitches
|
||||||
|
#{ h b a gis g fis f e es d cis c #})))
|
||||||
|
(transpose
|
||||||
|
(ly:pitch-transpose (semi->pitch fret) (ly:make-pitch 0 0))
|
||||||
|
(ly:make-pitch 0 0)
|
||||||
|
chords))
|
||||||
|
|
||||||
% kleine Mollakkorde und Alteration ausgeschrieben
|
% kleine Mollakkorde und Alteration ausgeschrieben
|
||||||
#(define (note-name->german-markup-nosym pitch lowercase?)
|
#(define (note-name->german-markup-nosym pitch lowercase?)
|
||||||
(define (pitch-alteration-semitones pitch) (inexact->exact (round (* (ly:pitch-alteration pitch) 2))))
|
(define (pitch-alteration-semitones pitch) (inexact->exact (round (* (ly:pitch-alteration pitch) 2))))
|
||||||
|
@ -2,6 +2,7 @@
|
|||||||
poetPrefix = "Worte:"
|
poetPrefix = "Worte:"
|
||||||
composerPrefix = "Weise:"
|
composerPrefix = "Weise:"
|
||||||
compositionPrefix = "Satz:"
|
compositionPrefix = "Satz:"
|
||||||
|
adaptionPrefix = "Bearbeitung:"
|
||||||
poetAndComposerEqualPrefix = "Worte und Weise:"
|
poetAndComposerEqualPrefix = "Worte und Weise:"
|
||||||
voicePrefix = "Stimme:"
|
voicePrefix = "Stimme:"
|
||||||
versePrefix = "Strophe:"
|
versePrefix = "Strophe:"
|
||||||
|
@ -102,14 +102,16 @@
|
|||||||
(verseComposerData (find-author-id-with-part-numbers 'meloverse authors))
|
(verseComposerData (find-author-id-with-part-numbers 'meloverse authors))
|
||||||
(voiceComposerData (find-author-id-with-part-numbers 'voice authors))
|
(voiceComposerData (find-author-id-with-part-numbers 'voice authors))
|
||||||
(compositionIds (find-author-ids-by 'composition authors))
|
(compositionIds (find-author-ids-by 'composition authors))
|
||||||
|
(adaptionIds (find-author-ids-by 'adaption authors))
|
||||||
(bridgeIds (find-author-ids-by 'bridge authors))
|
(bridgeIds (find-author-ids-by 'bridge authors))
|
||||||
(interludeIds (find-author-ids-by 'interlude authors))
|
(interludeIds (find-author-ids-by 'interlude authors))
|
||||||
(year_text (chain-assoc-get 'header:year_text props #f))
|
(year_text (chain-assoc-get 'header:year_text props #f))
|
||||||
(year_translation (chain-assoc-get 'header:year_translation props #f))
|
(year_translation (chain-assoc-get 'header:year_translation props #f))
|
||||||
(year_melody (chain-assoc-get 'header:year_melody props #f))
|
(year_melody (chain-assoc-get 'header:year_melody props #f))
|
||||||
(year_composition (chain-assoc-get 'header:year_composition props #f))
|
(year_composition (chain-assoc-get 'header:year_composition props #f))
|
||||||
|
(year_adaption (chain-assoc-get 'header:year_adaption props #f))
|
||||||
)
|
)
|
||||||
(if (and (equal? poetIds composerIds) (null? translatorIds) (null? versePoetData) (null? verseComposerData) (null? voiceComposerData) (null? compositionIds) (null? bridgeIds) (null? interludeIds))
|
(if (and (equal? poetIds composerIds) (null? translatorIds) (null? versePoetData) (null? verseComposerData) (null? voiceComposerData) (null? compositionIds) (null? adaptionIds) (null? bridgeIds) (null? interludeIds))
|
||||||
(list
|
(list
|
||||||
(join-present (list
|
(join-present (list
|
||||||
(render-contribution-group (ly:output-def-lookup layout 'poetAndComposerEqualPrefix) poetIds)
|
(render-contribution-group (ly:output-def-lookup layout 'poetAndComposerEqualPrefix) poetIds)
|
||||||
@ -133,7 +135,7 @@
|
|||||||
) ", ")
|
) ", ")
|
||||||
) "; ")
|
) "; ")
|
||||||
))
|
))
|
||||||
(if (and (null? composerIds) (null? compositionIds) (null? verseComposerData) (null? voiceComposerData) (null? bridgeIds) (null? interludeIds)) #f
|
(if (and (null? composerIds) (null? compositionIds) (null? adaptionIds) (null? verseComposerData) (null? voiceComposerData) (null? bridgeIds) (null? interludeIds)) #f
|
||||||
(string-append
|
(string-append
|
||||||
(ly:output-def-lookup layout 'composerPrefix)
|
(ly:output-def-lookup layout 'composerPrefix)
|
||||||
" "
|
" "
|
||||||
@ -148,6 +150,10 @@
|
|||||||
(render-contribution-group (ly:output-def-lookup layout 'compositionPrefix) compositionIds)
|
(render-contribution-group (ly:output-def-lookup layout 'compositionPrefix) compositionIds)
|
||||||
year_composition
|
year_composition
|
||||||
) ", ")
|
) ", ")
|
||||||
|
(join-present (list
|
||||||
|
(render-contribution-group (ly:output-def-lookup layout 'adaptionPrefix) adaptionIds)
|
||||||
|
year_adaption
|
||||||
|
) ", ")
|
||||||
(render-contribution-group (ly:output-def-lookup layout 'bridgePrefix) bridgeIds)
|
(render-contribution-group (ly:output-def-lookup layout 'bridgePrefix) bridgeIds)
|
||||||
(render-contribution-group (ly:output-def-lookup layout 'interludePrefix) interludeIds)
|
(render-contribution-group (ly:output-def-lookup layout 'interludePrefix) interludeIds)
|
||||||
) "; ")
|
) "; ")
|
||||||
|
7
include_from_song.ily
Normal file
7
include_from_song.ily
Normal file
@ -0,0 +1,7 @@
|
|||||||
|
includeFromSong =
|
||||||
|
#(define-void-function (filename) (string?)
|
||||||
|
(let ((noDefaultOutputBackup noDefaultOutput))
|
||||||
|
(set! noDefaultOutput #t)
|
||||||
|
(ly:parser-parse-string (ly:parser-clone)
|
||||||
|
(ly:format "\\include \"~a\"" filename))
|
||||||
|
(set! noDefaultOutput noDefaultOutputBackup)))
|
@ -26,6 +26,34 @@ TEXT = \markuplist {
|
|||||||
\TEXT
|
\TEXT
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#(define TEXT_PAGES
|
||||||
|
(map
|
||||||
|
(lambda (text) #{
|
||||||
|
\markuplist {
|
||||||
|
\override #`(transposition . ,TRANSPOSITION)
|
||||||
|
\override #`(verselayout . ,verselayout)
|
||||||
|
\override #`(verse-chords . ,#{ \chords { \verseChords } #})
|
||||||
|
\override #`(verse-reference-voice . ,#{ \global \firstVoice #})
|
||||||
|
#text
|
||||||
|
}
|
||||||
|
#})
|
||||||
|
(if
|
||||||
|
(and
|
||||||
|
(defined? 'TEXT_PAGES)
|
||||||
|
(pair? TEXT_PAGES))
|
||||||
|
TEXT_PAGES
|
||||||
|
(list TEXT))))
|
||||||
|
|
||||||
|
#(define (add-text-pages text-pages)
|
||||||
|
(if (pair? text-pages)
|
||||||
|
(begin
|
||||||
|
(add-score (car text-pages))
|
||||||
|
(for-each
|
||||||
|
(lambda (text)
|
||||||
|
(add-music (pageBreak))
|
||||||
|
(add-score text))
|
||||||
|
(cdr text-pages)))))
|
||||||
|
|
||||||
#(if (not noStandaloneOutput)
|
#(if (not noStandaloneOutput)
|
||||||
(begin
|
(begin
|
||||||
(let ((header (ly:book-header HEADER)) (paper (ly:book-paper HEADER)))
|
(let ((header (ly:book-header HEADER)) (paper (ly:book-paper HEADER)))
|
||||||
@ -37,7 +65,7 @@ TEXT = \markuplist {
|
|||||||
\MUSIC
|
\MUSIC
|
||||||
\layout { \LAYOUT }
|
\layout { \LAYOUT }
|
||||||
}#})
|
}#})
|
||||||
(add-score TEXT)
|
(add-text-pages TEXT_PAGES)
|
||||||
(add-score #{
|
(add-score #{
|
||||||
\score {
|
\score {
|
||||||
\unfoldRepeats { \MUSIC \INLINESCOREMUSIC }
|
\unfoldRepeats { \MUSIC \INLINESCOREMUSIC }
|
||||||
|
@ -279,10 +279,11 @@ headerToTOC = #(define-music-function (parser location header label) (ly:book? s
|
|||||||
(verseComposerData (find-author-id-with-part-numbers 'meloverse authors))
|
(verseComposerData (find-author-id-with-part-numbers 'meloverse authors))
|
||||||
(voiceComposerData (find-author-id-with-part-numbers 'voice authors))
|
(voiceComposerData (find-author-id-with-part-numbers 'voice authors))
|
||||||
(compositionIds (find-author-ids-by 'composition authors))
|
(compositionIds (find-author-ids-by 'composition authors))
|
||||||
|
(adaptionIds (find-author-ids-by 'adaption authors))
|
||||||
(bridgeIds (find-author-ids-by 'bridge authors))
|
(bridgeIds (find-author-ids-by 'bridge authors))
|
||||||
(interludeIds (find-author-ids-by 'interlude authors)))
|
(interludeIds (find-author-ids-by 'interlude authors)))
|
||||||
(delete-duplicates
|
(delete-duplicates
|
||||||
(append poetIds translatorIds (map car versePoetData) composerIds (map car verseComposerData) (map car voiceComposerData) compositionIds bridgeIds interludeIds))
|
(append poetIds translatorIds (map car versePoetData) composerIds (map car verseComposerData) (map car voiceComposerData) compositionIds adaptionIds bridgeIds interludeIds))
|
||||||
))
|
))
|
||||||
(let*
|
(let*
|
||||||
(
|
(
|
||||||
@ -358,7 +359,7 @@ headerToTOC = #(define-music-function (parser location header label) (ly:book? s
|
|||||||
(songvars (cdr song))
|
(songvars (cdr song))
|
||||||
(page-number (number->string (assoc-get (assq-ref songvars 'label) labelPageTable)))
|
(page-number (number->string (assoc-get (assq-ref songvars 'label) labelPageTable)))
|
||||||
(extractedheadervars (extract-and-check-vars-from-header (assq-ref songvars 'header)
|
(extractedheadervars (extract-and-check-vars-from-header (assq-ref songvars 'header)
|
||||||
'(title starttext alttitle categorytitle categories authors year_text year_melody year_translation year_composition infotext translation pronunciation copyright source)))
|
'(title starttext alttitle categorytitle categories authors year_text year_melody year_translation year_composition year_adaption infotext translation pronunciation copyright source)))
|
||||||
(headervar-or-empty (lambda (varsym)
|
(headervar-or-empty (lambda (varsym)
|
||||||
(let ((extracted (assq-ref extractedheadervars varsym)))
|
(let ((extracted (assq-ref extractedheadervars varsym)))
|
||||||
(if extracted extracted ""))))
|
(if extracted extracted ""))))
|
||||||
@ -370,6 +371,7 @@ headerToTOC = #(define-music-function (parser location header label) (ly:book? s
|
|||||||
(verseComposerData (find-author-id-with-part-numbers 'meloverse authors))
|
(verseComposerData (find-author-id-with-part-numbers 'meloverse authors))
|
||||||
(voiceComposerData (find-author-id-with-part-numbers 'voice authors))
|
(voiceComposerData (find-author-id-with-part-numbers 'voice authors))
|
||||||
(compositionIds (find-author-ids-by 'composition authors))
|
(compositionIds (find-author-ids-by 'composition authors))
|
||||||
|
(adaptionIds (find-author-ids-by 'adaption authors))
|
||||||
(bridgeIds (find-author-ids-by 'bridge authors))
|
(bridgeIds (find-author-ids-by 'bridge authors))
|
||||||
(interludeIds (find-author-ids-by 'interlude authors)))
|
(interludeIds (find-author-ids-by 'interlude authors)))
|
||||||
(map csv-escape
|
(map csv-escape
|
||||||
@ -387,11 +389,12 @@ headerToTOC = #(define-music-function (parser location header label) (ly:book? s
|
|||||||
(headervar-or-empty 'categories)
|
(headervar-or-empty 'categories)
|
||||||
(format-authors (append poetIds (map car versePoetData)))
|
(format-authors (append poetIds (map car versePoetData)))
|
||||||
(format-authors translatorIds)
|
(format-authors translatorIds)
|
||||||
(format-authors (append composerIds compositionIds bridgeIds interludeIds (map car voiceComposerData) (map car verseComposerData)))
|
(format-authors (append composerIds compositionIds adaptionIds bridgeIds interludeIds (map car voiceComposerData) (map car verseComposerData)))
|
||||||
(headervar-or-empty 'year_text)
|
(headervar-or-empty 'year_text)
|
||||||
(headervar-or-empty 'year_melody)
|
(headervar-or-empty 'year_melody)
|
||||||
(headervar-or-empty 'year_translation)
|
(headervar-or-empty 'year_translation)
|
||||||
(headervar-or-empty 'year_composition)
|
(headervar-or-empty 'year_composition)
|
||||||
|
(headervar-or-empty 'year_adaption)
|
||||||
(headervar-or-empty 'copyright)
|
(headervar-or-empty 'copyright)
|
||||||
(headervar-or-empty 'source)
|
(headervar-or-empty 'source)
|
||||||
(format-info-paragraphs (headervar-or-empty 'infotext))
|
(format-info-paragraphs (headervar-or-empty 'infotext))
|
||||||
@ -416,6 +419,7 @@ headerToTOC = #(define-music-function (parser location header label) (ly:book? s
|
|||||||
"year_melody"
|
"year_melody"
|
||||||
"year_translation"
|
"year_translation"
|
||||||
"year_composition"
|
"year_composition"
|
||||||
|
"year_adaption"
|
||||||
"copyright"
|
"copyright"
|
||||||
"source"
|
"source"
|
||||||
"infotext"
|
"infotext"
|
||||||
|
@ -221,14 +221,28 @@
|
|||||||
(cons (car x) (+ (cdr x) amount))
|
(cons (car x) (+ (cdr x) amount))
|
||||||
y)))
|
y)))
|
||||||
|
|
||||||
#(define-markup-command (score-equal-height layout props reference-height lines)
|
#(define-markup-command (score-equal-height-with-indents layout props lines)
|
||||||
(number? markup-list?)
|
(markup-list?)
|
||||||
#:category music
|
#:category music
|
||||||
#:properties ((baseline-skip))
|
#:properties ((intraverse-vspace 0)
|
||||||
(stack-stencils Y DOWN baseline-skip
|
(verse-line-height songTextLineHeigth)
|
||||||
(map
|
(line-indents '()))
|
||||||
(lambda (line) (ly:make-stencil (ly:stencil-expr line) (ly:stencil-extent line X) `(,(/ reference-height -2.0) . ,(/ reference-height 2.0))))
|
(let ((indents-max-index (- (length line-indents) 1)))
|
||||||
(interpret-markup-list layout props lines))))
|
(stack-stencils Y DOWN intraverse-vspace
|
||||||
|
(index-map
|
||||||
|
(lambda (index line)
|
||||||
|
(let ((stil
|
||||||
|
(ly:make-stencil
|
||||||
|
(ly:stencil-expr line)
|
||||||
|
(ly:stencil-extent line X)
|
||||||
|
`(,(/ verse-line-height -2.0) . ,(/ verse-line-height 2.0)))))
|
||||||
|
(if (<= index indents-max-index)
|
||||||
|
(ly:stencil-translate-axis
|
||||||
|
stil
|
||||||
|
(list-ref line-indents index)
|
||||||
|
X)
|
||||||
|
stil)))
|
||||||
|
(interpret-markup-list layout props lines)))))
|
||||||
|
|
||||||
#(define-public (custom-lyric-text::print grob)
|
#(define-public (custom-lyric-text::print grob)
|
||||||
"Allow interpretation of tildes as lyric tieing marks."
|
"Allow interpretation of tildes as lyric tieing marks."
|
||||||
@ -243,20 +257,17 @@
|
|||||||
#:properties ((verse-chords #{#})
|
#:properties ((verse-chords #{#})
|
||||||
(verse-reference-voice #{#})
|
(verse-reference-voice #{#})
|
||||||
(verse-break-voice #{#})
|
(verse-break-voice #{#})
|
||||||
(verse-line-height songTextLineHeigth)
|
|
||||||
(verse-text-chord-distance songTextChordDistance)
|
(verse-text-chord-distance songTextChordDistance)
|
||||||
(intraverse-vspace 0)
|
|
||||||
(transposition (cons #f #f))
|
(transposition (cons #f #f))
|
||||||
(verselayout generalLayout))
|
(verselayout generalLayout))
|
||||||
"Vers mit Akkorden"
|
"Vers mit Akkorden"
|
||||||
(interpret-markup layout props
|
(interpret-markup layout props
|
||||||
#{
|
#{
|
||||||
\markup {
|
\markup {
|
||||||
\override #`(baseline-skip . ,intraverse-vspace)
|
\score-equal-height-with-indents \score-lines {
|
||||||
\score-equal-height #verse-line-height \score-lines {
|
|
||||||
<<
|
<<
|
||||||
\new Devnull { #verse-break-voice }
|
\new Devnull { #(music-clone verse-break-voice) }
|
||||||
\new NullVoice = "dummyvoice" { #verse-reference-voice }
|
\new NullVoice = "dummyvoice" { #(music-clone verse-reference-voice) }
|
||||||
\transposable #transposition #(music-clone verse-chords)
|
\transposable #transposition #(music-clone verse-chords)
|
||||||
\new Lyrics \lyricsto "dummyvoice" { #lyrics }
|
\new Lyrics \lyricsto "dummyvoice" { #lyrics }
|
||||||
>>
|
>>
|
||||||
@ -292,6 +303,7 @@
|
|||||||
\remove Jump_engraver
|
\remove Jump_engraver
|
||||||
\remove Volta_engraver
|
\remove Volta_engraver
|
||||||
\remove Parenthesis_engraver
|
\remove Parenthesis_engraver
|
||||||
|
\remove Metronome_mark_engraver
|
||||||
}
|
}
|
||||||
\context {
|
\context {
|
||||||
\Staff
|
\Staff
|
||||||
@ -318,8 +330,9 @@
|
|||||||
\NullVoice
|
\NullVoice
|
||||||
\consists Rest_engraver
|
\consists Rest_engraver
|
||||||
\omit Rest
|
\omit Rest
|
||||||
% \undo \omit NoteHead
|
\undo \omit NoteHead
|
||||||
% \hide NoteHead
|
\hide NoteHead
|
||||||
|
\override NoteHead.X-extent = #'(0 . 0)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user