;;;;
;;;; source file of the GNU LilyPond music typesetter
;;;;
-;;;; (c) 1998--2006 Han-Wen Nienhuys <hanwen@cs.uu.nl>
+;;;; (c) 1998--2006 Han-Wen Nienhuys <hanwen@xs4all.nl>
;;;; Jan Nieuwenhuizen <janneke@gnu.org>
;;;; distances are given in line-thickness (thicknesses) and
accidental-suggestion-interface
self-alignment-interface
font-interface))))))
+
(AccidentalPlacement
. (
(left-padding . 0.2)
+ ;; for horizontally stacked scripts.
+ (script-priority . -100)
+ (direction . ,LEFT)
+
(positioning-done . ,ly:accidental-placement::calc-positioning-done)
(X-extent . ,ly:axis-group-interface::width)
(right-padding . 0.15)
(meta . ((class . Item)
(interfaces . (accidental-placement-interface))))))
+
(Ambitus
. (
(axes . (0 1))
(X-offset . ,ly:side-position-interface::x-aligned-side)
(direction . ,LEFT)
(padding . 0.5)
+ (script-priority . 0)
(side-axis . ,X)
(staff-position . 0.0)
(meta . ((class . Item)
side-position-interface
font-interface))))))
+ (BalloonTextItem
+ . ((stencil . ,ly:balloon-interface::print)
+ (text . ,(grob::calc-property-by-copy 'text))
+ (X-offset . ,(grob::calc-property-by-copy 'X-offset))
+ (Y-offset . ,(grob::calc-property-by-copy 'Y-offset))
+ (meta . ((class . Item)
+ (interfaces . (text-interface
+ font-interface))))))
(BarLine
. (
(break-align-symbol . staff-bar)
(list ly:self-alignment-interface::x-aligned-on-self)))))
(self-alignment-X . 1)
+
+ ;; want the bar number before the clef at line start.
(break-align-symbol . left-edge)
(meta .
((class . Item)
(Dots
. (
(stencil . ,ly:dots::print)
- (dot-count . 1)
+ (dot-count . ,dots::calc-dot-count)
(meta . ((class . Item)
(interfaces . (font-interface
staff-symbol-referencer-interface
(stencil . ,ly:text-interface::print)
(direction . ,ly:script-interface::calc-direction)
-
+ (text . ,fingering::calc-text)
(font-encoding . fetaNumber)
(font-size . -5) ; don't overlap when next to heads.
(meta . ((class . Item)
side-position-interface
self-alignment-interface
item-interface))))))
+ (FretBoard
+ . ((stencil . ,fret-board::calc-stencil)
+ (finger-code . below-string)
+ (meta . ((class . Item)
+ (interfaces . (fret-diagram-interface
+ font-interface
+ ))))
+ ))
(Glissando
. (
(style . line)
(stencil . ,ly:hairpin::print)
(springs-and-rods . ,ly:spanner::set-spacing-rods)
(after-line-breaking . ,ly:hairpin::after-line-breaking)
+ (grow-direction . ,hairpin::calc-grow-direction)
(circled-tip . #f)
(thickness . 1.0)
(height . 0.6666)
(thickness . 1.0)
(stencil . ,ly:horizontal-bracket::print)
(Y-offset . ,ly:side-position-interface::y-aligned-side)
+ (connect-to-neighbor . ,ly:tuplet-bracket::calc-connect-to-neighbors)
+
(padding . 0.2)
(staff-padding . 0.2)
(direction . ,DOWN)
. (
(stencil . ,ly:tie::print)
(control-points . ,ly:semi-tie::calc-control-points)
- (direction . ,ly:semi-tie::calc-direction)
+ (direction . ,ly:tie::calc-direction)
(details . ((ratio . 0.333)
(height-limit . 1.0)))
+ (head-direction . ,LEFT)
(thickness . 1.0)
(meta . ((class . Item)
(interfaces . (semi-tie-interface))
lyric-hyphen-interface spacing-interface))
))
))
+
(LyricText
. (
- (stencil . ,ly:text-interface::print)
+ (stencil . ,lyric-text::print)
+ (text . ,(grob::calc-property-by-copy 'text))
(X-offset . ,ly:self-alignment-interface::aligned-on-x-parent)
(self-alignment-X . 0)
(word-space . 0.6)
font-interface
text-interface))))))
+ (NonMusicalPaperColumn
+ . (
+ (allow-loose-spacing . #t)
+ (axes . (0))
+ (before-line-breaking . ,ly:paper-column::before-line-breaking)
+ (X-extent . ,ly:axis-group-interface::width)
+ ;; (stencil . ,ly:paper-column::print)
+
+ (non-musical . #t)
+ (line-break-permission . allow)
+ (page-break-permission . allow)
+
+ ;; debugging stuff: print column number.
+ ;; (font-size . -6) (font-name . "sans") (Y-extent . #f)
+
+ (meta . ((class . Paper_column)
+ (interfaces . (paper-column-interface
+ axis-group-interface
+ spaceable-grob-interface))))))
+
(NoteCollision
. (
(axes . (0 1))
(NoteHead
. (
(stencil . ,ly:note-head::print)
+ (duration-log . ,note-head::calc-duration-log)
(stem-attachment . ,ly:note-head::calc-stem-attachment)
(glyph-name . ,note-head::calc-glyph-name)
(Y-offset . ,ly:staff-symbol-referencer::callback)
(PaperColumn
. (
(axes . (0))
+ (allow-loose-spacing . #t)
(before-line-breaking . ,ly:paper-column::before-line-breaking)
;; (stencil . ,ly:paper-column::print)
(X-extent . ,ly:axis-group-interface::width)
(meta . ((class . Spanner)
(interfaces . (slur-interface))))))
- (NonMusicalPaperColumn
- . (
- (axes . (0))
- (before-line-breaking . ,ly:paper-column::before-line-breaking)
- (X-extent . ,ly:axis-group-interface::width)
- ;; (stencil . ,ly:paper-column::print)
-
- (non-musical . #t)
- (line-break-permission . allow)
- (page-break-permission . allow)
- ;; debugging stuff: print column number.
- ;; (font-size . -6) (font-name . "sans") (Y-extent . #f)
-
- (meta . ((class . Paper_column)
- (interfaces . (paper-column-interface
- axis-group-interface
- spaceable-grob-interface))))))
(PercentRepeat
. (
mark-interface
self-alignment-interface))))))
-
(RepeatSlash
. (
(stencil . ,ly:percent-repeat-item-interface::beat-slash)
(slope . 1.7)
(meta . ((class . Item)
(interfaces . (percent-repeat-interface))))))
+
(RepeatTie
. (
(stencil . ,ly:tie::print)
(control-points . ,ly:semi-tie::calc-control-points)
- (direction . ,ly:semi-tie::calc-direction)
+ (direction . ,ly:tie::calc-direction)
(details . ((ratio . 0.333)
(height-limit . 1.0)))
(thickness . 1.0)
+ (head-direction . ,RIGHT)
(meta . ((class . Item)
(interfaces . (semi-tie-interface))
))
. (
(X-extent . #f)
(Y-extent . #f)
+ (direction . ,ly:tie::calc-direction)
(head-direction . ,RIGHT)
+
(positioning-done . ,ly:semi-tie-column::calc-positioning-done)
(meta . ((class . Item)
(interfaces . (semi-tie-column-interface))
(Rest
. (
(stencil . ,ly:rest::print)
+ (duration-log . ,stem::calc-duration-log)
(X-extent . ,ly:rest::width)
(Y-extent . ,ly:rest::height)
(Y-offset . ,ly:rest::y-offset-callback)
;; padding set in script definitions.
(staff-padding . 0.25)
;; (script-priority . 0) priorities for scripts, see script.scm
- (X-offset . , ly:self-alignment-interface::centered-on-x-parent)
+ (X-offset . ,ly:self-alignment-interface::centered-on-x-parent)
+ (Y-offset . ,ly:side-position-interface::y-aligned-side)
+ (side-axis . ,Y)
(stencil . ,ly:script-interface::print)
(direction . ,ly:script-interface::calc-direction)
(before-line-breaking . ,ly:script-column::before-line-breaking)
(meta . ((class . Item)
(interfaces . (script-column-interface))))))
+ (ScriptRow
+ . (
+ (before-line-breaking . ,ly:script-column::row-before-line-breaking)
+ (meta . ((class . Item)
+ (interfaces . (script-column-interface))))))
(SeparationItem
. (
- (X-extent . #f)
- (Y-extent . #f)
+ (avoid-slur . inside)
+ (X-extent . ,ly:axis-group-interface::width)
+ (Y-extent . ,ly:axis-group-interface::height)
(meta . ((class . Item)
(interfaces . (spacing-interface
separation-item-interface))))))
(meta . ((class . Item)
(interfaces . (text-interface
self-alignment-interface
+ piano-pedal-script-interface
font-interface))))))
(SostenutoPedalLineSpanner
(Stem
. (
(direction . ,ly:stem::calc-direction)
+ (duration-log . ,stem::calc-duration-log)
(default-direction . ,ly:stem::calc-default-direction)
(stem-end-position . ,ly:stem::calc-stem-end-position)
+
(neutral-direction . ,DOWN)
(stem-info . ,ly:stem::calc-stem-info)
(positioning-done . ,ly:stem::calc-positioning-done)
(StringNumber
. (
(stencil . ,print-circled-text-callback)
+ (text . ,string-number::calc-text)
(padding . 0.5)
(staff-padding . 0.5)
(self-alignment-X . 0)
self-alignment-interface
item-interface))))))
+ (StrokeFinger
+ . (
+ (stencil . ,ly:text-interface::print)
+ (text . ,stroke-finger::calc-text)
+ (digit-names . #("p" "i" "m" "a" "x"))
+ (padding . 0.5)
+ (staff-padding . 0.5)
+ (self-alignment-X . 0)
+ (self-alignment-Y . 0)
+ (script-priority . 100)
+ (font-shape . italic)
+ (font-size . -4) ; don't overlap when next to heads.
+ (meta . ((class . Item)
+ (interfaces . (stroke-finger-interface
+ font-interface
+ text-script-interface
+ text-interface
+ side-position-interface
+ self-alignment-interface
+ item-interface))))))
+
+
(SustainPedal
. (
(no-spacing-rods . #t)
line-spanner-interface
text-interface
self-alignment-interface
+ piano-pedal-script-interface
font-interface))))))
(SustainPedalLineSpanner
(axes . (0 1))
(X-extent . ,ly:axis-group-interface::width)
(Y-extent . ,ly:axis-group-interface::height)
+ (skyline-spacing . #t)
(meta . ((class . System)
(interfaces . (system-interface
axis-group-interface))))))
. (
(no-spacing-rods . #t)
(X-offset . ,ly:self-alignment-interface::x-aligned-on-self)
+ (Y-offset . ,ly:side-position-interface::y-aligned-side)
+ (side-axis . ,Y)
(direction . ,DOWN)
;; sync with Fingering ?
(stencil . ,ly:accidental-interface::print)
(meta . ((class . Item)
(interfaces . (item-interface
+ trill-pitch-accidental-interface
side-position-interface
font-interface))))))
(X-offset . ,ly:self-alignment-interface::x-aligned-on-self)
(meta . ((class . Item)
(interfaces . (text-interface
+ piano-pedal-script-interface
self-alignment-interface
font-interface))))))
(Y-extent . ,ly:axis-group-interface::height)
(X-extent . ,ly:axis-group-interface::width)
(stacking-dir . -1)
+ (padding . 0.1)
(meta . ((class . Spanner)
(interfaces . (align-interface
axis-group-interface))))))
. (
(axes . (1))
(Y-offset . ,ly:hara-kiri-group-spanner::force-hara-kiri-callback)
-
(Y-extent . ,ly:hara-kiri-group-spanner::y-extent)
(X-extent . ,ly:axis-group-interface::width)
+ (skyline-spacing . #t)
(meta . ((class . Spanner)
(interfaces . (axis-group-interface
hara-kiri-group-interface
(set! all-grob-descriptions (sort all-grob-descriptions alist<?))
-
(define pure-print-callbacks
(list
- `(,ly:note-head::print . '())
- `(,ly:clef::print . '())
- `(,ly:text-interface::print . '())
- `(,ly:script-interface::print . '())))
+ ly:note-head::print
+ ly:clef::print
+ ly:text-interface::print
+ ly:script-interface::print))
;; ly:grob::stencil-extent is safe iff the print callback is safe too
(define (pure-stencil-height grob start stop)
(let ((sten (ly:grob-property-data grob 'stencil)))
(if (or
(ly:stencil? sten)
- (pair? (assq sten pure-print-callbacks)))
+ (memq sten pure-print-callbacks))
(ly:grob::stencil-height grob)
'(0 . 0))))
-(define pure-Y-extents
- (list
- `(,ly:staff-symbol::height . ())))
-
-(define Y-extent-conversions
+(define pure-conversions-alist
(list
+ `(,ly:slur::outside-slur-callback . ,ly:slur::pure-outside-slur-callback)
`(,ly:stem::height . ,ly:stem::pure-height)
`(,ly:grob::stencil-height . ,pure-stencil-height)
`(,ly:side-position-interface::y-aligned-side . ,ly:side-position-interface::pure-y-aligned-side)
`(,ly:axis-group-interface::height . ,ly:axis-group-interface::pure-height)
`(,ly:hara-kiri-group-spanner::y-extent . ,ly:hara-kiri-group-spanner::pure-height)
- `(,ly:slur::height . ,ly:slur::pure-height)))
-
-(define pure-Y-offsets
- (list
- `(,ly:staff-symbol-referencer::callback . ())))
+ `(,ly:slur::height . ,ly:slur::pure-height)
+ `(,ly:side-position-interface::y-aligned-side . ,ly:side-position-interface::pure-y-aligned-side)))
-(define Y-offset-conversions
+(define pure-functions
(list
- `(,ly:side-position-interface::y-aligned-side . ,ly:side-position-interface::pure-y-aligned-side)))
+ ly:staff-symbol-referencer::callback
+ ly:staff-symbol::height))
(define-public (pure-relevant grob)
(let ((extent-callback (ly:grob-property-data grob 'Y-extent)))
- (or
- (pair? extent-callback)
- (pair? (assq extent-callback pure-Y-extents))
- (and
- (pair? (assq extent-callback Y-extent-conversions))
- (or
- (not (eq? extent-callback ly:grob::stencil-height))
- (pair? (assq (ly:grob-property-data grob 'stencil) pure-print-callbacks))
- (ly:stencil? (ly:grob-property-data grob 'stencil)))))))
-
-(define (pure-conversion pures conversions defsymbol defreturn rettype? grob start stop)
- (let* ((normal-callback (ly:grob-property-data grob defsymbol))
- (pure-callback (assq normal-callback conversions)))
- (if (rettype? normal-callback)
- normal-callback
- (if (pair? (assq normal-callback pures))
- (normal-callback grob)
- (if (pair? pure-callback)
- ((cdr pure-callback) grob start stop)
- defreturn)))))
-
-(define-public (pure-Y-extent grob start stop)
- (pure-conversion pure-Y-extents Y-extent-conversions
- 'Y-extent '(0 . 0) pair? grob start stop))
-
-(define-public (pure-Y-offset grob start stop)
- (pure-conversion pure-Y-offsets Y-offset-conversions
- 'Y-offset 0 number? grob start stop))
+ (not (eq? #f
+ (or
+ (pair? extent-callback)
+ (memq extent-callback pure-functions)
+ (and
+ (pair? (assq extent-callback pure-conversions-alist))
+ (begin
+ (or
+ (not (eq? extent-callback ly:grob::stencil-height))
+ (memq (ly:grob-property-data grob 'stencil) pure-print-callbacks)
+ (ly:stencil? (ly:grob-property-data grob 'stencil))))))))))
+
+(define-public (call-pure-function unpure args start end)
+ (if (ly:simple-closure? unpure)
+ (ly:eval-simple-closure (car args) unpure start end)
+ (if (not (procedure? unpure))
+ unpure
+ (if (memq unpure pure-functions)
+ (apply unpure args)
+ (let ((pure (assq unpure pure-conversions-alist)))
+ (if pure
+ (apply (cdr pure) (append (list (car args) start end) (cdr args)))))))))