X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=scm%2Fpredefined-fretboards.scm;h=5f4d7005cd518af052ee8d7bee690ce5d5529be7;hb=b041343efb7173ad24aa6d014acd32dc2f0528c8;hp=cad0c3b62021809a803a9636299be9cd79a0148f;hpb=c054eb280fd9953596eb164f67b0f9d5555c5a32;p=lilypond.git diff --git a/scm/predefined-fretboards.scm b/scm/predefined-fretboards.scm index cad0c3b620..5f4d7005cd 100644 --- a/scm/predefined-fretboards.scm +++ b/scm/predefined-fretboards.scm @@ -38,20 +38,17 @@ and return a marking list, which can be used with a fretboard grob." (if (string? diagram-definition) (parse-terse-string diagram-definition) diagram-definition))) - (map (lambda(item) - (let ((code (car item))) - (cond - ((eq? code 'barre) - (list-set! item 3 - (+ fret-offset (list-ref item 3))) - item) - ((eq? code 'capo) - (list-set! item 1 - (+ fret-offset (list-ref item 1))) - item) - ((eq? code 'place-fret) - (list-set! item 2 - (+ fret-offset (list-ref item 2))) - item) - (else item)))) + (map (lambda (item) + (let* ((code (car item)) + (nth (assq-ref '((barre . 3) (capo . 1) (place-fret . 2)) + code))) + (if nth + ;; offset nth element of item by offset-fret + ;; without modifying the original list but + ;; sharing its tail + (let ((tail (list-tail item nth))) + (append! (list-head item nth) + (cons (+ (car tail) fret-offset) + (cdr tail)))) + item))) verbose-definition)))