-
-(define default-slur-extremity-rules
- (list
-
- ;; (cons (lambda (slur dir) (begin (display "before sanity check") (newline))#f) #f)
-
- ;; urg: don't crash on a slur without note-columns
- (cons (lambda (slur dir)
- (< (length (ly:get-grob-property slur 'note-columns)) 1)) 'head)
-
- ;; (cons (lambda (slur dir) (begin (display "before loose-end") (newline))#f) #f)
- (cons (lambda (slur dir) (not (attached-to-stem slur dir))) 'loose-end)
-
- ;; (cons (lambda (slur dir) (begin (display "before head") (newline))#f) #f)
-
- (cons (lambda (slur dir)
- ;; urg, code dup
- (let* ((note-columns (ly:get-grob-property slur 'note-columns))
- (col (if (= dir 1) (car note-columns) (car (reverse note-columns))))
- (stem (ly:get-grob-property col 'stem)))
- (and stem
- (not (= (ly:get-grob-property slur 'direction)
- (ly:get-grob-property stem 'direction)))))) 'head)
-
- ;; (cons (lambda (slur dir) (begin (display "before stem") (newline))#f) #f)
-
- (cons (lambda (slur dir)
- ;; if attached-to-stem
- (and (attached-to-stem slur dir)
- ;; and got beam
- ;; urg, code dup
- (let* ((note-columns (ly:get-grob-property slur 'note-columns))
- (col (if (= dir 1) (car note-columns) (car (reverse note-columns))))
- (stem (ly:get-grob-property col 'stem)))
- (and stem
- (ly:get-grob-property stem 'beam)
- ;; and beam on same side as slur
- (let ((beaming (ly:get-grob-property stem 'beaming)))
- ;; (display "beaming (") (display dir) (display "): ") (write beaming) (newline)
- (if (pair? beaming)
- (>= (length (if (= dir -1) (cdr beaming) (car beaming)))
- 1)
- #f))))))
- 'stem)
-
- ;; (cons (lambda (slur dir) (begin (display "before loose-end") (newline))#f) #f)
- (cons (lambda (slur dir) (not (attached-to-stem slur dir))) 'loose-end)
- ;; (cons (lambda (slur dir) (begin (display "after loose-end") (newline))#f) #f)
-
- ;; default case, attach to head
- (cons (lambda (x y) #t) 'head)
+(define (calc-slur-extremity slur dir)
+ (let* ((note-columns (ly:grob-property slur 'note-columns))
+ (col (if (= dir 1)
+ (car note-columns)
+ (car (last-pair note-columns))))
+ (stem (ly:grob-property col 'stem))
+ (beaming (if (and (ly:grob? stem)
+ (ly:grob? (ly:grob-property stem 'beam)))
+ (ly:grob-property stem 'beaming)
+ '(() . ())))
+ (one-side-beaming (if (= dir RIGHT)
+ (car beaming)
+ (cdr beaming)))
+
+ )
+
+ (cond
+ ((< (length note-columns) 1) 'head)
+ ((not (attached-to-stem slur dir))
+
+ 'loose-end)
+ ((and stem
+ (not (equal? (ly:grob-property slur 'direction)
+ (ly:grob-property stem 'direction)))) 'head)
+ ((and (memq (ly:spanner-get-bound slur dir)
+ (ly:grob-property slur 'note-columns))
+ (ly:grob? stem)
+
+ ;; slur would go under beam for 'head
+ (> (length one-side-beaming ) 0)
+ ;; and beam on same side as slur
+ (equal?
+ (ly:grob-property stem 'direction)
+ (ly:grob-property slur 'direction))
+ )
+ 'stem)
+ ((not (attached-to-stem slur dir))
+ 'loose-end)
+ (else
+ 'head))