X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=input%2Fregression%2Ftie-chord.ly;h=af3ec740a9c0f26e4216f6fd72f1c9d11b78ab5a;hb=38ca8905ad17945008b3516be0034a0fa7f4ff24;hp=21b6fd57a85f853a558107fe34190d207d29c553;hpb=3db08de4502e30616808fc348b054d32822e5cc4;p=lilypond.git diff --git a/input/regression/tie-chord.ly b/input/regression/tie-chord.ly index 21b6fd57a8..af3ec740a9 100644 --- a/input/regression/tie-chord.ly +++ b/input/regression/tie-chord.ly @@ -1,23 +1,101 @@ -\version "1.7.18" -\header{ -texidoc=" -When tieing chords, the outer slurs point outwards, the inner slurs -point away from the center of the staff. Override with -@code{tieVerticalDirection}. -" +\header { + + texidoc = "In chords, ties keep closer to the note head vertically, +but never collide with heads or stems. Seconds are formatted up/@/down; +the rest of the ties are positioned according to their vertical +position. + +The code does not handle all cases. Sometimes ties will printed on top +of or very close to each other. This happens in the last chords of +each system." + } +\version "2.16.0" + +\paper { + indent = #0.0 + ragged-right = ##t +} + + + +generateTiePattern += #(define-music-function (parser location is-long chords) (boolean? ly:music?) + + " -t = \notes \relative c' { <> ~ <> } +translate x y z to x~x y~y z~z - \score { -\notes \context Voice { - \t - \transpose c g \t +" + + (define (chord->tied-chord chord) + (let* + ((ch1 (ly:music-deep-copy chord)) + (ch2 (ly:music-deep-copy chord)) + (dur1 (ly:make-duration + (if is-long + 1 2))) + (dur2 (ly:make-duration + (if is-long + 3 2)))) - \property Voice.TieColumn \override #'direction = #-1 - \t + (for-each (lambda (e) + (ly:music-set-property! e 'duration dur1)) + (ly:music-property ch1 'elements)) - } + (for-each (lambda (e) + (ly:music-set-property! e 'duration dur2)) + (ly:music-property ch2 'elements)) + + (set! (ly:music-property ch1 'elements) + (cons + (make-music 'TieEvent) + (ly:music-property ch1 'elements))) + + (list ch1 ch2))) + + (make-music 'SequentialMusic 'elements (append-map + chord->tied-chord (ly:music-property chords 'elements)))) + +baseChords = +\applyMusic #(lambda (mus) + (ly:music-property mus 'element)) +\relative c'' { + + + + + + + + + + + } +testShort = +{ + \key c \major + \generateTiePattern ##f \baseChords +} + +testLong = +{ + \key c \major + \generateTiePattern ##t \baseChords +} + +\new Voice +{ + \time 2/4 + + \testShort \break + \transpose c d \testShort \break + \time 5/8 + \testLong \break + \transpose c d \testLong \break +} + +