force printing first chord on newline

This commit is contained in:
tux 2024-11-16 23:13:37 +01:00
parent 754682afcf
commit d56c11c5ff
2 changed files with 25 additions and 36 deletions

View File

@ -139,43 +139,32 @@ generalLayout = \layout {
} }
#})) #}))
% If you add this engraver to ChordNames Context chords get only printed on chordchanges and not at newline. % If you add this engraver to ChordNames Context chords get only printed on chordchanges and if its the first chord after line break.
% See https://lists.gnu.org/archive/html/lilypond-user/2020-07/msg00187.html Ensure_first_chord_after_line_break_printed_engraver =
Ignoring_newline_chord_changes_engraver =
#(lambda (ctx) #(lambda (ctx)
(let* ((chord #f) (define last-system-column-rank 0)
(last-chord #f))
(define (at-line-beginning? grob)
(let* ((col (ly:item-get-column grob))
(ln (ly:grob-object col 'left-neighbor))
(col-to-check (if (ly:grob? ln) ln col)))
(and (eq? #t (ly:grob-property col-to-check 'non-musical))
(= 1 (ly:item-break-dir col-to-check)))))
(make-engraver (make-engraver
(acknowledgers (acknowledgers
((chord-name-interface this-engraver grob source-engraver) ((chord-name-interface this-engraver grob source-engraver)
(ly:grob-set-property! grob 'after-line-breaking
(lambda (grob)
(let ((current-system-column-rank (car (ly:grob-spanned-column-rank-interval (ly:grob-system grob)))))
(if (and
(ly:context-property ctx 'chordChanges #f)
(ly:grob-property grob 'begin-of-line-visible #f)
(not (= last-system-column-rank current-system-column-rank)))
; the current chord handling implementation in lilypond uses 'begin-of-line-visible to mark repeated chords
(ly:grob-set-property! grob 'begin-of-line-visible #f))
(set! last-system-column-rank current-system-column-rank)
(ly:chord-name::after-line-breaking grob)
)))))))
(if chord % If you add this engraver to ChordNames Context chords get only printed on chordchanges and not at newline.
(begin Ignoring_newline_chord_changes_engraver =
(set! last-chord chord) #(lambda (ctx)
(set! chord #f))) (make-engraver
(acknowledgers
(set! chord (ly:grob-property grob 'text)) ((chord-name-interface this-engraver grob source-engraver)
(when (and (ly:context-property ctx 'chordChanges #f) (ly:grob-property grob 'begin-of-line-visible #f))
;; If two subsequent chords are equal and chordChanges is enabled, (ly:grob-suicide! grob)
;; set 'after-line-breaking to a procedure which sets the stencil )))))
;; to an empty-stencil if the new chord is at line-start.
(if (and (equal? chord last-chord)
(ly:context-property ctx 'chordChanges #f))
(ly:grob-set-property! grob 'after-line-breaking
(lambda (grob)
(if (at-line-beginning? grob)
(ly:grob-set-property! grob 'stencil empty-stencil))
;; keep default
(ly:chord-name::after-line-breaking grob))))))
((finalize this-engraver)
;; house keeping
(set! chord #f)
(set! last-chord #f)))))

View File

@ -277,7 +277,7 @@
\ChordNames \ChordNames
\override VerticalAxisGroup.staff-affinity = ##f \override VerticalAxisGroup.staff-affinity = ##f
\override ChordName.extra-spacing-width = #'(-0.1 . 0.1) \override ChordName.extra-spacing-width = #'(-0.1 . 0.1)
\consists \Ignoring_newline_chord_changes_engraver \consists \Ensure_first_chord_after_line_break_printed_engraver
} }
\context { \context {
\Score \Score