]> git.donarmstrong.com Git - lilypond.git/blobdiff - scm/define-grobs.scm
* stepmake/aclocal.m4 (depth): make sure $srcdir is absolute.
[lilypond.git] / scm / define-grobs.scm
index dd9f7e1db9888f14e33db2f11bc878a57ecf4783..49baf4aa65e6a261a1aacf3461e044ed8c933e77 100644 (file)
   `(
     (Accidental
      . (
-       (print-function . ,Accidental_interface::print)
        (avoid-slur . inside)
        (cautionary-style . parentheses)
-       (after-line-breaking-callback . ,Accidental_interface::after_line_breaking)
+
+       (stencil . ,Accidental_interface::print)
+       (after-line-breaking
+        . ,Accidental_interface::after_line_breaking)
+                                       
        (meta . ((class . Item)
                 (interfaces . (accidental-interface
                                font-interface))))))
-
+    
     (AccidentalSuggestion
-     . ((print-function . ,Accidental_interface::print)
-       (X-offset-callbacks . (,Self_alignment_interface::centered_on_parent
-                              ,Self_alignment_interface::aligned_on_self))
+     . (
+       (stencil . ,Accidental_interface::print)
+       (X-offset . ,(ly:make-simple-closure
+                     `(,+
+                       ,(ly:make-simple-closure (list Self_alignment_interface::centered_on_x_parent))
+                       ,(ly:make-simple-closure (list Self_alignment_interface::x_aligned_on_self)))))
        (self-alignment-X . ,CENTER)
        (cautionary . #t)
        (cautionary-style . smaller)
-       (Y-offset-callbacks . (,Side_position_interface::aligned_side))
+       (Y-offset . ,Side_position_interface::y_aligned_side)
        (cautionary-style . parentheses)
        (direction . ,UP)
        (staff-padding . 0.25)
        (script-priority . 0)
+       (side-axis . ,X)
        (meta . ((class . Item)
                 (interfaces . (side-position-interface
                                script-interface
                                self-alignment-interface
                                font-interface))))))
     (AccidentalPlacement
-     . ((X-extent-callback . ,Axis_group_interface::group_extent_callback)
+     . (
        (left-padding . 0.2)
 
+       (positioning-done . ,Accidental_placement::calc_positioning_done)
+       (X-extent . ,Axis_group_interface::width)                     
+       
        ;; this is quite small, but it is very ugly to have
        ;; accs closer to the previous note than to the next one.
        (right-padding . 0.15)
@@ -58,8 +68,9 @@
     (Ambitus
      . (
        (axes . (0 1))
-       (X-extent-callback . ,Axis_group_interface::group_extent_callback)
-       (Y-extent-callback . ,Axis_group_interface::group_extent_callback)
+       (X-extent . ,Axis_group_interface::width)
+       (X-extent . ,Axis_group_interface::height)
+
        (space-alist . (
                        (clef . (extra-space . 0.5))
                        (key-signature . (extra-space . 0.0))
 
     (AmbitusLine
      . (
-       (print-function . ,Ambitus::print)
+
+       (stencil . ,Ambitus::print)
+
        (join-heads . #t)
        (thickness . 2)
-       (X-offset-callbacks . (,Self_alignment_interface::centered_on_parent))
+       (X-offset . ,Self_alignment_interface::centered_on_x_parent)
 
        (meta . ((class . Item)
                 (interfaces . (ambitus-interface
                                font-interface))))))
     (AmbitusAccidental
      . (
-       (print-function . ,Accidental_interface::print)
        (font-family . music)
        (padding . 0.5)
-       (X-offset-callbacks . (,Side_position_interface::aligned_side))
+       (X-offset . ,Side_position_interface::x_aligned_side)
        (direction . -1)
        (cautionary-style . parentheses)
-       (after-line-breaking-callback . ,Accidental_interface::after_line_breaking)
+
+       (stencil . ,Accidental_interface::print)
+       (after-line-breaking . ,Accidental_interface::after_line_breaking)
+       (side-axis . ,X)
+       
        (meta . ((class . Item)
                 (interfaces . (item-interface
                                accidental-interface
     (AmbitusNoteHead
      . (
        (duration-log . 2)
-       (print-function . ,Note_head::print)
-       (glyph-name-procedure . ,find-notehead-symbol)
-       (Y-offset-callbacks . (,Staff_symbol_referencer::callback))
+
+       (stencil . ,Note_head::print)
+       (glyph-name . ,note-head::calc-glyph-name)
+       
+       (Y-offset . ,Staff_symbol_referencer::callback)
        (meta . ((class . Item)
                 (interfaces . (font-interface
                                note-head-interface
 
     (Arpeggio
      . (
-       (X-extent-callback . ,Arpeggio::width_callback)
-       (print-function . ,Arpeggio::print)
-       (Y-offset-callbacks . (,Staff_symbol_referencer::callback))
-       (X-offset-callbacks . (,Side_position_interface::aligned_side))
+
+       (X-extent . ,Arpeggio::width)
+       (stencil . ,Arpeggio::print)
+
+       (Y-offset . ,Staff_symbol_referencer::callback)
+       (X-offset . ,Side_position_interface::x_aligned_side)
        (direction . -1)
        (padding . 0.5)
+       (side-axis . ,X)
        (staff-position . 0.0)
        (meta . ((class . Item)
                 (interfaces . (arpeggio-interface
      . (
        (break-align-symbol . staff-bar)
        (glyph . "|")
-       (break-glyph-function . ,default-break-barline)
        (layer . 0)
-       (bar-size-procedure . ,Bar_line::get_staff_bar_size)
-       (print-function . ,Bar_line::print)
        (break-visibility . ,all-visible)
        (breakable . #t)
-       (before-line-breaking-callback . ,Bar_line::before_line_breaking)
+
+       (stencil . ,Bar_line::print)
+       (glyph-name . ,bar-line::calc-glyph-name)
+       (bar-size .  ,Bar_line::calc_bar_size)
+       
        (space-alist . (
                        (time-signature . (extra-space . 0.75))
                        (custos . (minimum-space . 2.0))
 
     (BarNumber
      . (
-       (print-function . ,Text_interface::print)
+       (stencil . ,Text_interface::print)
        (breakable . #t)
        (break-visibility . ,begin-of-line-visible)
        (padding . 1.0)
        (direction . 1)
        (font-family . roman)
        (font-size . -2)
-       (Y-offset-callbacks . (,Side_position_interface::aligned_side))
-       (X-offset-callbacks . (,Self_alignment_interface::aligned_on_self))
+       (Y-offset . ,Side_position_interface::y_aligned_side)
+       (side-axis . ,Y)
+       (X-offset . ,Self_alignment_interface::x_aligned_on_self)
        (self-alignment-X . 1)
 
        (meta .
 
     (BassFigure
      . (
-       (print-function . ,Text_interface::print)
-       (Y-offset-callbacks . (,Self_alignment_interface::aligned_on_self))
+
+       (stencil . ,Text_interface::print)
+
+       (Y-offset . ,Self_alignment_interface::y_aligned_on_self)
        (direction . 1)
        (font-family . number)
 
                                bass-figure-interface
                                self-alignment-interface
                                font-interface))))))
+
+    (NewBassFigure
+     . (
+       ;
+       (stencil . ,Text_interface::print)
+
+       (meta . ((class . Item)
+                (interfaces . (text-interface
+                               rhythmic-grob-interface
+                               bass-figure-interface
+                               font-interface))))))
+    (BassFigureBracket
+     . (
+       ;
+       (stencil . ,Enclosing_bracket::print)
+
+       (edge-height . (0.2 . 0.2))
+       (meta . ((class . Item)
+                (interfaces . (enclosing-bracket-interface)) ))
+       ))
+    (BassFigureContinuation
+     . (
+
+       (stencil . ,Figured_bass_continuation::print)
+
+       (Y-offset . ,Figured_bass_continuation::center_on_figures)
+       (meta . ((class . Spanner)
+                (interfaces . (figured-bass-continuation-interface))
+                ))))
+    (BassFigureLine
+     . (
+       (axes . (,Y))
+
+       (Y-extent . ,Axis_group_interface::height)
+
+       (meta . ((class . Spanner)
+                (interfaces . (axis-group-interface
+                               ))))))
+
+    (BassFigureAlignment
+     . (
+       (axes . (,Y))
+       (threshold . (2 . 1000))
+
+       (positioning-done . ,Align_interface::calc_positioning_done)
+       (Y-extent . ,Axis_group_interface::height)
+                                       
+       (stacking-dir . -1)
+       (meta . ((class . Spanner)
+                (interfaces . (align-interface
+                               axis-group-interface))))))
+
     (Beam
      . (
        ;; todo: clean this up a bit: the list is getting
        ;; rather long.
-       (print-function . ,Beam::print)
        (gap . 0.8)
-       (positions . (#f . #f))
-       (position-callbacks . (,Beam::least_squares
-                              ,Beam::check_concave
-                              ,Beam::slope_damping
-                              ,Beam::shift_region_to_valid
-                              ,Beam::quanting))
+       (positions .  ,(ly:make-simple-closure
+                       (ly:make-simple-closure
+                        (list chain-grob-member-functions
+                          `(,cons 0 0)
+                          Beam::calc_least_squares_positions
+                          Beam::slope_damping
+                          Beam::shift_region_to_valid
+                          Beam::quanting
+                          ))))
+
+       ;; this is a hack to set stem lengths, if positions is set.
+       (quantized-positions . ,Beam::set_stem_lengths)
+       (concaveness . ,Beam::calc_concaveness)
+       (direction . ,Beam::calc_direction)
+       (stencil . ,Beam::print)
 
        ;; TODO: should be in SLT.
        (thickness . 0.48) ; in staff-space
-       (before-line-breaking-callback . ,Beam::before_line_breaking)
-       (after-line-breaking-callback . ,Beam::after_line_breaking)
        (neutral-direction . -1)
-       (dir-function . ,beam-dir-majority-median)
 
        ;; Whe have some unreferenced problems here.
        ;;
        ;; isolated shortened beams look nice and a bit shortened,
        ;; sadly possibly breaking patterns with high order beams.
        (beamed-stem-shorten . (1.0 0.5 0.25))
-
-       (flag-width-function . ,beam-flag-width-function)
        (damping . 1)
        (auto-knee-gap . 5.5)
 
        ;; only for debugging.
        (font-family . roman)
-
-       (space-function . ,Beam::space_function)
        (meta . ((class . Spanner)
                 (interfaces . (staff-symbol-referencer-interface
                                beam-interface))))))
      . (
        (breakable . #t)
        (stacking-dir . 1)
+
+       (positioning-done . ,Break_align_interface::calc_positioning_done)
+       (X-extent . ,Axis_group_interface::width)
+                                       
        (break-align-orders . ;; end of line
                            #((instrument-name
                               left-edge
                               key-signature
                               staff
                               time-signature custos)
-                             
+
                              ;; begin of line
                              (instrument-name
                               left-edge
                               time-signature
                               custos)))
        (axes . (0))
-       (X-extent-callback . ,Axis_group_interface::group_extent_callback)
        (meta . ((class . Item)
                 (interfaces . (break-alignment-interface
                                axis-group-interface))))))
     (BreakAlignGroup
      . (
        (axes . (0))
-       (X-offset-callbacks . (,Break_align_interface::alignment_callback))
-       (X-extent-callback . ,Axis_group_interface::group_extent_callback)
+
+       (X-extent . ,Axis_group_interface::width)
+
        (meta . ((class . Item)
                 (interfaces . (break-aligned-interface
                                axis-group-interface))))))
                        (ambitus . (extra-space . 2.0))
                        (custos . (minimum-space . 1.0))
                        (key-signature . (minimum-space . 1.5))
+                       (time-signature . (minimum-space . 1.5))
                        (staff-bar . (minimum-space . 1.5))
                        (clef . (minimum-space . 2.0))
                        (first-note . (fixed-space . 1.0)) ;huh?
                        (right-edge . (extra-space . 0.1))))
-       (print-function . ,Text_interface::print)
+
+       (stencil . ,Text_interface::print)
+
        (text . ,(make-musicglyph-markup "scripts.rcomma"))
-       (Y-offset-callbacks . (,Breathing_sign::offset_callback))
+       (Y-offset . ,Breathing_sign::offset_callback)
        (break-visibility . ,begin-of-line-invisible)
        (meta . ((class . Item)
                 (interfaces . (break-aligned-interface
 
     (Clef
      . (
-       (print-function . ,Clef::print)
-       (before-line-breaking-callback . ,Clef::before_line_breaking)
+
+       (stencil . ,Clef::print)
+       (glyph-name . ,Clef::calc_glyph_name)
+                                       
        (breakable . #t)
        (font-family . music)
        (break-align-symbol . clef)
        (break-visibility . ,begin-of-line-visible)
        (space-alist . ((ambitus . (extra-space . 2.0))
                        (staff-bar . (extra-space . 0.7))
-                       (key-cancellation . (minimum-space . 4.0))
-                       (key-signature . (minimum-space . 4.0))
+                       (key-cancellation . (minimum-space . 3.5))
+                       (key-signature . (minimum-space . 3.5))
                        (time-signature . (minimum-space . 4.2))
                        (first-note . (minimum-fixed-space . 5.0))
                        (next-note . (extra-space . 0.5))
                        (right-edge . (extra-space . 0.5))))
-       (Y-offset-callbacks . (,Staff_symbol_referencer::callback))
+       (Y-offset . ,Staff_symbol_referencer::callback)
        (meta . ((class . Item)
                 (interfaces . (clef-interface
                                staff-symbol-referencer-interface
 
     (ClusterSpannerBeacon
      . (
-       (print-function . #f)
-       (Y-extent-callback . ,Cluster_beacon::height)
+
+       (Y-extent . ,Cluster_beacon::height)
+
        (meta . ((class . Item)
                 (interfaces . (cluster-beacon-interface))))))
 
     (ClusterSpanner
      . (
-       (print-function . ,Cluster::print)
-       (spacing-procedure . ,Spanner::set_spacing_rods)
+
+       (springs-and-rods . ,Spanner::set_spacing_rods)
+       (stencil . ,Cluster::print)
+
+
        (minimum-length . 0.0)
        (padding . 0.25)
        (style . ramp)
 
     (ChordName
      . (
-       (print-function . ,Text_interface::print)
-       (after-line-breaking-callback . ,Chord_name::after_line_breaking)
+
+       (stencil . ,Text_interface::print)
+       (after-line-breaking . ,Chord_name::after_line_breaking)
+       
        (word-space . 0.0)
        (font-family . sans)
        (font-size . 1.5)
 
     (CombineTextScript
      . (
-       (print-function . ,Text_interface::print)
+
+       (stencil . ,Text_interface::print)
+
        (no-spacing-rods . #t)
-       (Y-offset-callbacks . (,Side_position_interface::aligned_side))
-       (X-offset-callbacks . (,Self_alignment_interface::aligned_on_self))
+       (Y-offset . ,Side_position_interface::y_aligned_side)
+       (X-offset . ,Self_alignment_interface::x_aligned_on_self)
        (direction . 1)
        (padding . 0.5)
        (staff-padding . 0.5)
        (script-priority . 200)
        ;; todo: add X self alignment?
        (baseline-skip . 2)
+       (side-axis . ,Y)
        (font-series . bold)
        (meta . ((class . Item)
                 (interfaces . (text-script-interface
      . (
        (break-align-symbol . custos)
        (breakable . #t)
-       (print-function . ,Custos::print)
+
+       (stencil . ,Custos::print)
+
        (break-visibility . ,end-of-line-visible)
        (style . vaticana)
        (neutral-direction . -1)
-       (Y-offset-callbacks . (,Staff_symbol_referencer::callback))
+       (Y-offset . ,Staff_symbol_referencer::callback)
        (space-alist . (
                        (first-note . (minimum-fixed-space . 0.0))
                        (right-edge . (extra-space . 0.1))))
      . (
        (axes . (0))
        (direction . ,RIGHT)
-       (X-extent-callback . ,Axis_group_interface::group_extent_callback)
-       (X-offset-callbacks . (,Dot_column::side_position))
+
+       (positioning-done . ,Dot_column::calc_positioning_done) 
+       (X-extent . ,Axis_group_interface::width)
+       
+       (X-offset . ,Dot_column::side_position)
        (meta . ((class . Item)
                 (interfaces . (dot-column-interface
                                axis-group-interface))))))
 
     (Dots
      . (
-       (print-function . ,Dots::print)
+
+       (stencil . ,Dots::print)
+
        (dot-count . 1)
        (meta . ((class . Item)
                 (interfaces . (font-interface
 
     (DoublePercentRepeat
      . (
-       (print-function . ,Percent_repeat_item_interface::double_percent)
+       (stencil . ,Percent_repeat_item_interface::double_percent)
        (breakable . #t)
        (slope . 1.0)
        (font-encoding . fetaMusic)
                                percent-repeat-interface))))))
 
     (DoublePercentRepeatCounter
-     . ((print-function . ,Text_interface::print)
-       (X-offset-callbacks . (,Self_alignment_interface::aligned_on_self
-                              ,Self_alignment_interface::centered_on_other_axis_parent))
-       (Y-offset-callbacks . (,Side_position_interface::aligned_side))
+     . (
+
+       (stencil . ,Text_interface::print)
+       (X-offset . ,(ly:make-simple-closure `(,+ ,(ly:make-simple-closure (list Self_alignment_interface::centered_on_y_parent))
+                                                 ,(ly:make-simple-closure (list Self_alignment_interface::x_aligned_on_self)))))
+       (Y-offset . ,Side_position_interface::y_aligned_side)
        (font-encoding . fetaNumber)
        (self-alignment-X . 0)
        (font-size . -2) 
        (direction . 1)
        (padding . 0.2)
        (staff-padding . 0.25)
+       (side-axis . ,Y)
        (meta . ((class . Item)
                 (interfaces . (side-position-interface
                                self-alignment-interface
     (DynamicLineSpanner
      . (
        (axes . (1))
-       (Y-extent-callback . ,Axis_group_interface::group_extent_callback)
-       (Y-offset-callbacks . (,Side_position_interface::aligned_side))
+       (Y-offset . ,Side_position_interface::y_aligned_side)
        (staff-padding . 0.1)
        (padding . 0.6)
        (avoid-slur . outside)
        (slur-padding . 0.3)
        (minimum-space . 1.2)
        (direction . -1)
+       (side-axis . ,Y)
+
+       (Y-extent . ,Axis_group_interface::height)
+       (X-extent . ,Axis_group_interface::width)
+
 
        (meta . ((class . Spanner)
                 (interfaces . (axis-group-interface
 
     (DynamicText
      . (
-       (print-function . ,Text_interface::print)
-       (before-line-breaking-callback . ,Script_interface::before_line_breaking)
-       (X-offset-callbacks . (,Self_alignment_interface::aligned_on_self))
+
+       ;; todo.
+
+       (stencil . ,Text_interface::print)
+       (direction . ,Script_interface::calc_direction)
+
+       (X-offset . ,Self_alignment_interface::x_aligned_on_self)
        (self-alignment-X . 0)
-       (Y-offset-callbacks . (,Self_alignment_interface::aligned_on_self))
+       (Y-offset . ,Self_alignment_interface::y_aligned_on_self)
        (self-alignment-Y . 0)
        (font-series . bold)
        (font-encoding . fetaDynamic)
                                script-interface))))))
 
     (DynamicTextSpanner
-     . ((print-function . ,Dynamic_text_spanner::print)
+     . (
+
+       (stencil . ,Dynamic_text_spanner::print)
 
        ;; rather ugh with NCSB
        ;; (font-series . bold)
 
     (Fingering
      . (
-       (print-function . ,Text_interface::print)
 
        ;; sync with TextScript (?)
 
        (self-alignment-X . 0)
        (self-alignment-Y . 0)
        (script-priority . 100)
-       (before-line-breaking-callback . ,Script_interface::before_line_breaking)
+
+       (stencil . ,Text_interface::print)
+       (direction . ,Script_interface::calc_direction)
+
        (font-encoding . fetaNumber)
        (font-size . -5)                ; don't overlap when next to heads.
        (meta . ((class . Item)
        (gap . 0.5)
        (zigzag-width . 0.75)
        (breakable . #t)
-       (X-extent-callback . #f)
-       (Y-extent-callback . #f)
-       (after-line-breaking-callback . ,Line_spanner::after_line_breaking)
-       (print-function . ,Line_spanner::print)
+       (X-extent . #f)
+       (Y-extent . #f)
+
+       (stencil . ,Line_spanner::print)
+       (after-line-breaking . ,Line_spanner::after_line_breaking)
+       
+
        (meta . ((class . Spanner)
                 (interfaces . (line-interface
                                line-spanner-interface))))))
 
     (GridLine
      . (
-       (print-function . ,Grid_line_interface::print)
-       (X-extent-callback  . ,Grid_line_interface::width_callback)
+
+       (X-extent  . ,Grid_line_interface::width)
+       (stencil . ,Grid_line_interface::print)
+
        (self-alignment-X . ,CENTER)
-       (X-offset-callbacks . (,Self_alignment_interface::aligned_on_self
-                              ,Self_alignment_interface::centered_on_parent))
+       (X-offset . ,(ly:make-simple-closure
+                     `(,+  ,(ly:make-simple-closure (list Self_alignment_interface::centered_on_x_parent))
+                           ,(ly:make-simple-closure (list Self_alignment_interface::x_aligned_on_self)))))
        (layer . 0)
        (meta . ((class . Item)
                 (interfaces . (self-alignment-interface
 
     (Hairpin
      . (
-       (print-function . ,Hairpin::print)
-       (after-line-breaking-callback . ,Hairpin::after_line_breaking)
+
+
+       (stencil . ,Hairpin::print)
+       (springs-and-rods . ,Spanner::set_spacing_rods)
+       (after-line-breaking . ,Hairpin::after_line_breaking)
+
        (thickness . 1.0)
        (height . 0.6666)
-       (spacing-procedure . ,Spanner::set_spacing_rods)
        (minimum-length . 2.0)
        (bound-padding . 1.0)
        (self-alignment-Y . 0)
-       (Y-offset-callbacks . (,Self_alignment_interface::aligned_on_self))
+       (Y-offset . ,Self_alignment_interface::y_aligned_on_self)
        (meta . ((class . Spanner)
                 (interfaces . (hairpin-interface
                                line-interface
     (HorizontalBracket
      . (
        (thickness . 1.0)
-       (print-function . ,Horizontal_bracket::print)
-       (Y-offset-callbacks . (,Side_position_interface::aligned_side))
+       (stencil . ,Horizontal_bracket::print)
+       (Y-offset . ,Side_position_interface::y_aligned_side)
        (padding . 0.2)
        (staff-padding . 0.2)
        (direction . -1)
+       (side-axis . ,Y)
        (bracket-flare . (0.5 . 0.5))
        (meta . ((class . Spanner)
                 (interfaces . (horizontal-bracket-interface
     (InstrumentName
      . (
        (breakable . #t)
-       (Y-offset-callbacks . (,Self_alignment_interface::aligned_on_self
-                              ,Side_position_interface::aligned_on_support_refpoints))
+       (Y-offset . ,(ly:make-simple-closure `(,+ ,(ly:make-simple-closure (list Self_alignment_interface::y_aligned_on_self))
+                                                 ,(ly:make-simple-closure (list Side_position_interface::y_aligned_on_support_refpoints)))))
+       
        ;; This direction is for aligned_on_support_refpoints
        ;; (?) --hwn
        (direction . 0)
                        (left-edge . (extra-space . 1.0))))
 
        (self-alignment-Y . 0)
-       (print-function . ,Text_interface::print)
+       (stencil . ,Text_interface::print)
        (break-align-symbol . instrument-name)
        (break-visibility . ,begin-of-line-visible)
        (baseline-skip . 2)
+       (side-axis . ,X)
        (meta . ((class . Item)
                 (interfaces . (font-interface
                                self-alignment-interface
 
     (KeyCancellation
      . (
-       (print-function . ,Key_signature_interface::print)
+
+       (stencil . ,Key_signature_interface::print)
+
        (space-alist . (
                        (time-signature . (extra-space . 1.25))
                        (staff-bar . (extra-space . 0.6))
                        (key-signature . (extra-space . 0.5))
                        (right-edge . (extra-space . 0.5))
                        (first-note . (fixed-space . 2.5))))
-       (Y-offset-callbacks . (,Staff_symbol_referencer::callback))
+       (Y-offset . ,Staff_symbol_referencer::callback)
        (break-align-symbol . key-cancellation)
        (break-visibility . ,begin-of-line-invisible)
        (breakable . #t)
                                break-aligned-interface))))))
     (KeySignature
      . (
-       (print-function . ,Key_signature_interface::print)
+
+       (stencil . ,Key_signature_interface::print)
+
        (space-alist . (
-                       (time-signature . (extra-space . 1.25))
+                       (time-signature . (extra-space . 1.15))
                        (staff-bar . (extra-space . 1.1))
                        (right-edge . (extra-space . 0.5))
                        (first-note . (fixed-space . 2.5))))
-       (Y-offset-callbacks . (,Staff_symbol_referencer::callback))
+       (Y-offset . ,Staff_symbol_referencer::callback)
        (break-align-symbol . key-signature)
        (break-visibility . ,begin-of-line-visible)
        (breakable . #t)
                 (interfaces . (key-signature-interface
                                font-interface
                                break-aligned-interface))))))
+    (LaissezVibrerTie
+     . (
+
+       (stencil  . ,Tie::print)
+       (control-points . ,Laissez_vibrer_tie::calc_control_points)
+       (direction . ,Laissez_vibrer_tie::calc_direction)
+       
+       (details . ((ratio . 0.333)
+                   (height-limit . 1.0)))
+       (thickness . 1.0)
+       (meta . ((class . Item)
+                (interfaces . (laissez-vibrer-tie-interface))
+                ))
+       ))
+
+    (LaissezVibrerTieColumn
+     . (
+       (X-extent . #f)
+       (Y-extent . #f)
+
+       (positioning-done . ,Laissez_vibrer_tie_column::calc_positioning_done)
+       
+       (meta . ((class . Item)
+                (interfaces . (laissez-vibrer-tie-column-interface))
+                ))
+       ))
+
     (LedgerLineSpanner
      . (
-       (print-function . ,Ledger_line_spanner::print)
-       (X-extent-callback . #f)
-       (Y-extent-callback . #f)
+
+       (springs-and-rods . ,Ledger_line_spanner::set_spacing_rods)
+
+       (stencil . ,Ledger_line_spanner::print)
+
+       (X-extent . #f)
+       (Y-extent . #f)
        (minimum-length-fraction . 0.25)
        (length-fraction . 0.25)
-       (spacing-procedure . ,Ledger_line_spanner::set_spacing_rods)
-       (print-function . ,Ledger_line_spanner::print)
        (layer . 0)
        (meta . ((class . Spanner)
                 (interfaces . (ledger-line-interface))))))
 
     (LigatureBracket
      . (
-       (ligature-primitive-callback . ,Note_head::print)
+       ;; ugh.  A ligature bracket is totally different from
+       ;; a tuplet bracket.
+
+       (direction  . ,Tuplet_bracket::calc_direction)
+       (positions . ,Tuplet_bracket::calc_positions)
+       (stencil . ,Tuplet_bracket::print)
+       
        (direction . 1)
        (gap . 0.0)
        (padding . 2.0)
        (thickness . 1.6)
        (edge-height . (0.7 . 0.7))
        (shorten-pair . (-0.2 . -0.2))
-       (before-line-breaking-callback . ,Tuplet_bracket::before_line_breaking)
-       (after-line-breaking-callback . ,Tuplet_bracket::after_line_breaking)
-       (print-function . ,Tuplet_bracket::print)
        (meta . ((class . Spanner)
                 (interfaces . (tuplet-bracket-interface
                                line-interface))))))
        (length . 0.66)
        (minimum-length . 0.3)
        (padding . 0.07)
-                                       ;       (spacing-procedure . ,Hyphen_spanner::set_spacing_rods)
-       (print-function . ,Hyphen_spanner::print)
+                                       ;       (springs-and-rods . ,Hyphen_spanner::set_spacing_rods)
+
+       (stencil . ,Hyphen_spanner::print)
+
        (Y-extent . (0 . 0))
        (meta . ((class . Spanner)
                 (interfaces . (lyric-interface
 
     (LyricExtender
      . (
-       (print-function . ,Lyric_extender::print)
+
+       (stencil . ,Lyric_extender::print)
+
        (thickness . 0.8) ; linethickness
        (minimum-length . 1.5)
        (Y-extent . (0 . 0))
                                lyric-extender-interface))))))
 
     (LyricText
-     . ((print-function . ,Text_interface::print)
-       (X-offset-callbacks . (,Self_alignment_interface::aligned_on_parent))
+     . (
+
+       (stencil . ,Text_interface::print)
+
+       (X-offset . ,Self_alignment_interface::aligned_on_x_parent)
        (self-alignment-X . 0)
        (word-space . 0.6)
        (font-series . bold-narrow)
      . (
        (thickness . 1.4)
        (flexa-width . 2.0)
-       (ligature-primitive-callback . ,Mensural_ligature::brew_ligature_primitive)
-       (print-function . ,Mensural_ligature::print)
+       (stencil . ,Mensural_ligature::print)
+
        (meta . ((class . Spanner)
                 (interfaces . (mensural-ligature-interface
                                font-interface))))))
 
     (MetronomeMark
      . (
-       (print-function . ,Text_interface::print)
-       (Y-offset-callbacks . (,Side_position_interface::aligned_side))
+
+       (stencil . ,Text_interface::print)
+
+       (Y-offset . ,Side_position_interface::y_aligned_side)
        (direction . 1)
        (padding . 0.8)
+       (side-axis . ,Y)
        (meta . ((class . Item)
                 (interfaces . (text-interface
                                side-position-interface
                                font-interface
                                metronome-mark-interface))))))
+
     (MeasureGrouping
      . (
-       (Y-offset-callbacks . (,Side_position_interface::aligned_side))
-       (print-function . ,Measure_grouping::print)
+       (Y-offset . ,Side_position_interface::y_aligned_side)
+       (side-axis . ,Y)
+
+       (stencil . ,Measure_grouping::print)
+
        (padding . 2)
        (direction . 1)
        (thickness . 1)
        (meta . ((class . Spanner)
                 (interfaces . (side-position-interface
                                measure-grouping-interface))))))
+
     (MultiMeasureRest
      . (
-       (print-function . ,Multi_measure_rest::print)
-       (Y-offset-callbacks . (,Staff_symbol_referencer::callback))
+
+       (stencil . ,Multi_measure_rest::print)
+
+       (Y-offset . ,Staff_symbol_referencer::callback)
        (staff-position . 0)
        (expand-limit . 10)
        (thick-thickness . 6.6)
                                font-interface
                                staff-symbol-referencer-interface))))))
 
+
     (MultiMeasureRestNumber
      . (
-       (print-function . ,Text_interface::print)
-       (spacing-procedure . ,Multi_measure_rest::set_spacing_rods)
-       (X-offset-callbacks . (,Self_alignment_interface::aligned_on_self
-                              ,Self_alignment_interface::centered_on_other_axis_parent))
-       (Y-offset-callbacks . (,Side_position_interface::aligned_side))
+       (springs-and-rods . ,Multi_measure_rest::set_spacing_rods)
+       (stencil . ,Text_interface::print)
+       (X-offset . ,(ly:make-simple-closure
+                     `(,+ ,(ly:make-simple-closure (list Self_alignment_interface::x_aligned_on_self))
+                          ,(ly:make-simple-closure (list Self_alignment_interface::x_centered_on_y_parent)))))
+       (Y-offset . ,Side_position_interface::y_aligned_side)
+       (side-axis . ,Y)
+
        (self-alignment-X . 0)
        (direction . 1)
        (padding . 0.4)
                                multi-measure-interface
                                self-alignment-interface
                                font-interface
-                               text-interface))))))
-    
+                               text-interface))))
+             ))
+
     (MultiMeasureRestText
      . (
-       (print-function . ,Text_interface::print)
-       (X-offset-callbacks . (,Self_alignment_interface::aligned_on_self
-                              ,Self_alignment_interface::centered_on_other_axis_parent))
-       (Y-offset-callbacks . (,Side_position_interface::aligned_side))
+       (stencil . ,Text_interface::print)
+       (X-offset . ,(ly:make-simple-closure
+                     `(,+ ,(ly:make-simple-closure (list Self_alignment_interface::x_centered_on_y_parent))
+                          ,(ly:make-simple-closure (list Self_alignment_interface::x_aligned_on_self)))))
+       
+       (Y-offset . ,Side_position_interface::y_aligned_side)
        (self-alignment-X . 0)
        (direction . 1)
        (padding . 0.2)
     (NoteCollision
      . (
        (axes . (0 1))
-       (X-extent-callback . ,Axis_group_interface::group_extent_callback)
-       (Y-extent-callback . ,Axis_group_interface::group_extent_callback)
+
+       (X-extent . ,Axis_group_interface::width)
+       (Y-extent . ,Axis_group_interface::height)
+       (positioning-done . ,Note_collision_interface::calc_positioning_done)
+       
        (meta . ((class . Item)
                 (interfaces . (note-collision-interface
                                axis-group-interface))))))
     (NoteColumn
      . (
        (axes . (0 1))
-       (X-extent-callback . ,Axis_group_interface::group_extent_callback)
-       (Y-extent-callback . ,Axis_group_interface::group_extent_callback)
+       (X-extent . ,Axis_group_interface::width)
+       (Y-extent . ,Axis_group_interface::height)
+
        (meta . ((class . Item)
                 (interfaces . (axis-group-interface
                                note-column-interface))))))
 
     (NoteHead
      . (
-       (print-function . ,Note_head::print)
-       (ligature-primitive-callback . ,Note_head::print)
-       (glyph-name-procedure . ,find-notehead-symbol)
-       (Y-offset-callbacks . (,Staff_symbol_referencer::callback))
-       (stem-attachment-function . ,note-head-style->attachment-coordinates)
+
+       (stencil . ,Note_head::print)
+       (stem-attachment . ,Note_head::calc_stem_attachment)
+       (glyph-name . ,note-head::calc-glyph-name) 
+       (Y-offset . ,Staff_symbol_referencer::callback)
+       (X-offset . ,Note_head::stem_x_shift)
        (meta . ((class . Item)
                 (interfaces . (rhythmic-grob-interface
                                rhythmic-head-interface
 
     (NoteName
      . (
-       (print-function . ,Text_interface::print)
+
+       (stencil . ,Text_interface::print)
+
        (meta . ((class . Item)
                 (interfaces . (note-name-interface
                                text-interface
      . (
        (self-alignment-X . 0)
        (break-visibility . ,begin-of-line-visible)
-       (X-offset-callbacks . (,Self_alignment_interface::centered_on_parent
-                              ,Self_alignment_interface::aligned_on_self))
-       (Y-offset-callbacks . (,Side_position_interface::aligned_side))
-       (print-function . ,Text_interface::print)
+       (X-offset . ,(ly:make-simple-closure
+                     `(,+ ,(ly:make-simple-closure (list Self_alignment_interface::x_aligned_on_self))
+                          ,(ly:make-simple-closure (list Self_alignment_interface::centered_on_x_parent)))))
+       
+       (Y-offset . ,Side_position_interface::y_aligned_side)
+
+       (stencil . ,Text_interface::print)
+
 
        ;; no Y dimensions, because of lyrics under tenor clef.
        (Y-extent . (0 . 0))
 
     (OttavaBracket
      . (
-       (Y-offset-callbacks . (,Side_position_interface::aligned_side))
-       (print-function . ,Ottava_bracket::print)
+       (Y-offset . ,Side_position_interface::y_aligned_side)
+
+       (stencil . ,Ottava_bracket::print)
+
        (font-shape . italic)
        (shorten-pair . (0.0 . -0.6))
        (staff-padding . 1.0)
        (direction . 1)
        (meta . ((class . Spanner)
                 (interfaces . (ottava-bracket-interface
+                               horizontal-bracket-interface
                                line-interface
                                side-position-interface
                                font-interface
     (PaperColumn
      . (
        (axes . (0))
-       (before-line-breaking-callback . ,Paper_column::before_line_breaking)
-       (X-extent-callback . ,Axis_group_interface::group_extent_callback)
+
+       (before-line-breaking . ,Paper_column::before_line_breaking)
+       ;; (stencil . ,Paper_column::print)
+       (X-extent . ,Axis_group_interface::width)
+       
 
        ;; debugging
-;;                     (print-function . ,Paper_column::print) (font-size . -6) (font-name . "sans") (Y-extent-callback . #f)
+       ;;                       (font-size . -6) (font-name . "sans") (Y-extent . #f)
        (meta . ((class . Paper_column)
                 (interfaces . (paper-column-interface
                                axis-group-interface
 
     (PhrasingSlur
      . ((slur-details . ,default-slur-details)
-       (print-function . ,Slur::print)
+
+       (control-points . ,Slur::calc_control_points)
+       (direction . ,Slur::calc_direction)
+       (springs-and-rods . ,Spanner::set_spacing_rods)
+       (Y-extent . ,Slur::height)
+       (stencil . ,Slur::print)                      
+       
+
        (thickness . 1.1)
-       (spacing-procedure . ,Spanner::set_spacing_rods)
        (minimum-length . 1.5)
-       (after-line-breaking-callback . ,Slur::after_line_breaking)
-       (Y-extent-callback . ,Slur::height)
        (height-limit . 2.0)
        (ratio . 0.333)
        (meta . ((class . Spanner)
     (NonMusicalPaperColumn
      . (
        (axes . (0))
-       (X-extent-callback . ,Axis_group_interface::group_extent_callback)
-       (before-line-breaking-callback . ,Paper_column::before_line_breaking)
+
+       (before-line-breaking . ,Paper_column::before_line_breaking)
+       (X-extent . ,Axis_group_interface::width)
+       ;;                    (stencil . ,Paper_column::print)
+       
        (breakable . #t)
 
        ;; debugging stuff: print column number.
-;;             (print-function . ,Paper_column::print) (font-size . -6) (font-name . "sans")   (Y-extent-callback . #f)
+       ;;               (font-size . -6) (font-name . "sans")  (Y-extent . #f)
 
        (meta . ((class . Paper_column)
                 (interfaces . (paper-column-interface
 
     (PercentRepeat
      . (
-       (spacing-procedure . ,Multi_measure_rest::set_spacing_rods)
-       (print-function . ,Multi_measure_rest::percent)
+
+       (springs-and-rods . ,Multi_measure_rest::set_spacing_rods)
+       (stencil . ,Multi_measure_rest::percent)
+
        (slope . 1.0)
        (thickness . 0.48)
        (font-encoding . fetaMusic)
                                font-interface
                                percent-repeat-interface))))))
     (PercentRepeatCounter
-     . ((print-function . ,Text_interface::print)
-       (X-offset-callbacks . (,Self_alignment_interface::aligned_on_self
-                              ,Self_alignment_interface::centered_on_other_axis_parent))
-       (Y-offset-callbacks . (,Side_position_interface::aligned_side))
+     . (
+       (stencil . ,Text_interface::print)
+       (X-offset . ,(ly:make-simple-closure
+                     `(,+ ,(ly:make-simple-closure (list Self_alignment_interface::x_centered_on_y_parent))
+                          ,(ly:make-simple-closure (list Self_alignment_interface::x_aligned_on_self)))))
+       (Y-offset . ,Side_position_interface::y_aligned_side)
        (self-alignment-X . 0)
        (direction . 1)
        (padding . 0.2)
     ;; an example of a text spanner
     (PianoPedalBracket
      . (
-       (print-function . ,Piano_pedal_bracket::print)
+
+       (stencil . ,Piano_pedal_bracket::print)
+
        (style . line)
        (bound-padding . 1.0)
        (direction . -1)
 
     (RehearsalMark
      . (
-       (print-function . ,Text_interface::print)
-       (X-offset-callbacks . (,Self_alignment_interface::aligned_on_self))
-       (Y-offset-callbacks . (,Side_position_interface::aligned_side))
-       (after-line-breaking-callback . ,shift-right-at-line-begin)
+
+       (stencil . ,Text_interface::print)
+
+       (X-offset . ,Self_alignment_interface::x_aligned_on_self)
+       (Y-offset . ,Side_position_interface::y_aligned_side)
+
+       (after-line-breaking . ,shift-right-at-line-begin)
+
        (self-alignment-X . 0)
        (direction . 1)
        (breakable . #t)
                                mark-interface
                                self-alignment-interface))))))
 
-    (RemoveEmptyVerticalGroup
-     . (
-       (Y-offset-callbacks . (,Hara_kiri_group_spanner::force_hara_kiri_callback))
-       (Y-extent-callback . ,Hara_kiri_group_spanner::y_extent)
-       (axes . (1))
-       (meta . ((class . Spanner)
-                (interfaces . (axis-group-interface
-                               vertically-spaceable-interface
-                               hara-kiri-group-interface
-                               spanner-interface))))))
 
     (RepeatSlash
      . (
-       (print-function . ,Percent_repeat_item_interface::beat_slash)
+
+       (stencil . ,Percent_repeat_item_interface::beat_slash)
+
        (thickness . 0.48)
        (slope . 1.7)
        (meta . ((class . Item)
                 (interfaces . (percent-repeat-interface))))))
     (Rest
      . (
-       (after-line-breaking-callback . ,Rest::after_line_breaking)
-       (X-extent-callback . ,Rest::extent_callback)
-       (Y-extent-callback . ,Rest::extent_callback)
-       (print-function . ,Rest::print)
-       (Y-offset-callbacks . (,Staff_symbol_referencer::callback
-                              ,Rest::polyphonic_offset_callback))
+
+       (stencil . ,Rest::print)
+       (X-extent . ,Rest::width)
+       (Y-extent . ,Rest::height)
+       (Y-offset . ,Rest::y_offset_callback)
        (minimum-distance . 0.25)
        (meta . ((class . Item)
                 (interfaces . (font-interface
     (RestCollision
      . (
        (minimum-distance . 0.75)
+       (positioning-done . ,Rest_collision::calc_positioning_done)
+                                       
        (meta . ((class . Item)
                 (interfaces . (rest-collision-interface))))))
 
     (Script
      . (
        ;; don't set direction here: it breaks staccato.
-       (print-function . ,Script_interface::print)
 
        ;; This value is sensitive: if too large, staccato dots will move a
        ;; space a away.
        (padding . 0.20)
        (staff-padding . 0.25)
        ;; (script-priority . 0) priorities for scripts, see script.scm
-       (X-offset-callbacks . (,Self_alignment_interface::centered_on_parent))
-       (before-line-breaking-callback . ,Script_interface::before_line_breaking)
+       (X-offset . , Self_alignment_interface::centered_on_x_parent)
+       
+
+       (stencil . ,Script_interface::print)
+       (direction . ,Script_interface::calc_direction)
+
        (font-encoding . fetaMusic)
        (meta . ((class . Item)
                 (interfaces . (script-interface
 
     (ScriptColumn
      . (
-       (before-line-breaking-callback . ,Script_column::before_line_breaking)
+
+       (before-line-breaking . ,Script_column::before_line_breaking)
+
        (meta . ((class . Item)
                 (interfaces . (script-column-interface))))))
 
     (SeparationItem
      . (
-       (X-extent-callback . #f)
-       (Y-extent-callback . #f)
+       (X-extent . #f)
+       (Y-extent . #f)
        (meta . ((class . Item)
                 (interfaces . (spacing-interface
                                separation-item-interface))))))
 
     (SeparatingGroupSpanner
      . (
-       (spacing-procedure . ,Separating_group_spanner::set_spacing_rods)
+
+       (springs-and-rods . ,Separating_group_spanner::set_spacing_rods)
+
        (meta . ((class . Spanner)
                 (interfaces . (only-prebreak-interface
                                spacing-interface
 
     (Slur
      . ((slur-details . ,default-slur-details)
-       (print-function . ,Slur::print)
+
+       (control-points . ,Slur::calc_control_points)
+       (direction . ,Slur::calc_direction)
+       (springs-and-rods . ,Spanner::set_spacing_rods)
+       (Y-extent . ,Slur::height)
+       (stencil . ,Slur::print)
+       
        (thickness . 1.0)
-       (spacing-procedure . ,Spanner::set_spacing_rods)
        (minimum-length . 1.5)
-       (after-line-breaking-callback . ,Slur::after_line_breaking)
-       (Y-extent-callback . ,Slur::height)
                                        ; Slur::height)
        (height-limit . 2.0)
        (ratio . 0.25)
 
     (SpacingSpanner
      . (
-       (spacing-procedure . ,Spacing_spanner::set_springs)
+
+       (springs-and-rods . ,Spacing_spanner::set_springs)
+       (average-spacing-wishes . #t)
        (grace-space-factor . 0.6)
        (shortest-duration-space . 2.0)
        (spacing-increment . 1.2)
     (SpanBar
      . (
        (break-align-symbol . staff-bar)
-       (bar-size-procedure . ,Span_bar::get_bar_size)
-       (print-function . ,Span_bar::print)
-       (X-extent-callback . ,Span_bar::width_callback)
-       (Y-extent-callback . ())
+       (Y-extent . ())
        (layer . 0)
        (breakable . #t)
-       (before-line-breaking-callback . ,Span_bar::before_line_breaking)
+
+       (stencil . ,Span_bar::print)
+       (bar-size . ,Span_bar::calc_bar_size)
+       (X-extent . ,Span_bar::width)
+       (glyph-name . ,Span_bar::calc_glyph_name)
+       (before-line-breaking . ,Span_bar::before_line_breaking)
+
        ;; ugh duplication!
 
        ;;
                                bar-line-interface))))))
 
     (StanzaNumber
-     . ((print-function . ,Text_interface::print)
+     . (
+       (stencil . ,Text_interface::print)
+
        (font-series . bold)
        (padding . 1.0)
-       (X-offset-callbacks . (,Side_position_interface::aligned_side))
+       (X-offset . ,Side_position_interface::x_aligned_side)
+       (side-axis . ,X)
        (direction . ,LEFT)
        (meta . ((class . Item)
                 (interfaces . (side-position-interface
 
     (StringNumber
      . (
-       (print-function . ,print-circled-text-callback)
+
+       (stencil . ,print-circled-text-callback)
+
        (padding . 0.5)
        (staff-padding . 0.5)
        (self-alignment-X . 0)
      . (
        (breakable . #t)
        (stem-spacing-correction . 0.4)
-
        (meta . ((class . Item)
                 (interfaces . (spacing-interface
                                staff-spacing-interface))))))
 
     (SostenutoPedal
      . (
-       (print-function . ,Text_interface::print)
+
+       (stencil . ,Text_interface::print)
+
        (direction . 1)
-       (X-offset-callbacks . (,Self_alignment_interface::aligned_on_self))
+       (X-offset . ,Self_alignment_interface::x_aligned_on_self)
        (no-spacing-rods . #t)
        (padding . 0.0) ;; padding relative to SostenutoPedalLineSpanner
        (font-shape . italic)
     (SostenutoPedalLineSpanner
      . (
        (axes . (1))
-       (Y-extent-callback . ,Axis_group_interface::group_extent_callback)
-       (Y-offset-callbacks . (,Side_position_interface::aligned_side))
+
+       (X-extent . ,Axis_group_interface::height)
+
+       (Y-offset . ,Side_position_interface::y_aligned_side)
+       (side-axis . ,Y)
 
        (padding . 1.2)
        (minimum-space . 1.0)
 
     (StaffSymbol
      . (
-       (print-function . ,Staff_symbol::print)
+
+       (stencil . ,Staff_symbol::print)
+
        (line-count . 5)
        (ledger-line-thickness . (1.0 . 0.1))
        (layer . 0)
 
     (Stem
      . (
-       ;; this list is rather long. Trim --hwn
-       (before-line-breaking-callback . ,Stem::before_line_breaking)
-       (print-function . ,Stem::print)
+       (direction . ,Stem::calc_direction)
+       (stem-end-position . ,Stem::calc_stem_end_position)
+       (stem-info . ,Stem::calc_stem_info)
+       (positioning-done . ,Stem::calc_positioning_done)
+       (stencil . ,Stem::print)
+       (X-extent . ,Stem::width)
+       (Y-extent . ,Stem::height)
+       (length . ,Stem::calc_length)
+       
        (thickness . 1.3)
 
-       ;; 3.5 (or 3 measured from note head) is standard length
-       ;; 32nd, 64th flagged stems should be longer
-       (lengths . (3.5 3.5 3.5 4.5 5.0))
+       (details
+        . (
+           ;; 3.5 (or 3 measured from note head) is standard length
+           ;; 32nd, 64th flagged stems should be longer
+           (lengths . (3.5 3.5 3.5 4.5 5.0))
 
-       ;; Stems in unnatural (forced) direction should be shortened by
-       ;; one staff space, according to [Roush & Gourlay].
-       ;; Flagged stems we shorten only half a staff space.
-       (stem-shorten . (1.0 0.5))
+           ;; FIXME.  3.5 yields too long beams (according to Ross and
+           ;; looking at Baerenreiter examples) for a number of common
+           ;; boundary cases.  Subtracting half a beam thickness fixes
+           ;; this, but the bug may well be somewhere else.
 
-       ;; default stem direction for note on middle line
-       (neutral-direction . -1)
+           ;; FIXME this should come from 'lengths
+           (beamed-lengths . (3.26 3.5 3.6))
 
-       ;; FIXME.  3.5 yields too long beams (according to Ross and
-       ;; looking at Baerenreiter examples) for a number of common
-       ;; boundary cases.  Subtracting half a beam thickness fixes
-       ;; this, but the bug may well be somewhere else.
+           ;; The 'normal' minima
+           (beamed-minimum-free-lengths . (1.83 1.5 1.25))
+                                       ;(beamed-minimum-free-lengths . (2.0 1.83 1.25))
 
-       ;; FIXME this should come from 'lengths
+           ;; The 'extreme case' minima
+           (beamed-extreme-minimum-free-lengths . (2.0 1.25))
 
-       (beamed-lengths . (3.26 3.5 3.6))
+           ;; Stems in unnatural (forced) direction should be shortened by
+           ;; one staff space, according to [Roush & Gourlay].
+           ;; Flagged stems we shorten only half a staff space.
+           (stem-shorten . (1.0 0.5))
 
-       ;; We use the normal minima as minimum for the ideal lengths,
-       ;; and the extreme minima as abolute minimum length.
+           ))
 
-       ;; The 'normal' minima
-       (beamed-minimum-free-lengths . (1.83 1.5 1.25))
-                                       ;(beamed-minimum-free-lengths . (2.0 1.83 1.25))
 
-       ;; The 'extreme case' minima
-       (beamed-extreme-minimum-free-lengths . (2.0 1.25))
+       ;; default stem direction for note on middle line
+       (neutral-direction . -1)
 
-       (X-offset-callbacks . (,Stem::offset_callback))
-       (X-extent-callback . ,Stem::width_callback)
-       (Y-extent-callback . ,Stem::height)
-       (Y-offset-callbacks . (,Staff_symbol_referencer::callback))
+       ;; We use the normal minima as minimum for the ideal lengths,
+       ;; and the extreme minima as abolute minimum length.
+
+       (X-offset . ,Stem::offset_callback)
+       (Y-offset . ,Staff_symbol_referencer::callback)
        (meta . ((class . Item)
                 (interfaces . (stem-interface
                                font-interface))))))
 
     (StemTremolo
      . (
-       (print-function . ,Stem_tremolo::print)
-       (Y-extent-callback . ,Stem_tremolo::height)
-       (X-extent-callback . #f)
-
+       (Y-extent . ,Stem_tremolo::height)
+       (stencil . ,Stem_tremolo::print)
+       (X-extent . #f)
        (beam-width . 1.6) ; staff-space
        (beam-thickness . 0.48) ; staff-space
        (meta . ((class . Item)
     (SustainPedal
      . (
        (no-spacing-rods . #t)
-       (print-function . ,Sustain_pedal::print)
+       (stencil . ,Sustain_pedal::print)
        (self-alignment-X . 0)
        (direction . 1)
        (padding . 0.0)  ;; padding relative to SustainPedalLineSpanner
-       (X-offset-callbacks . (,Self_alignment_interface::aligned_on_self))
+       (X-offset . ,Self_alignment_interface::x_aligned_on_self)
        (meta . ((class . Item)
                 (interfaces . (piano-pedal-interface
                                text-spanner-interface
     (SustainPedalLineSpanner
      . (
        (axes . (1))
-       (Y-extent-callback . ,Axis_group_interface::group_extent_callback)
-       (Y-offset-callbacks . (,Side_position_interface::aligned_side))
-
+       (X-extent . ,Axis_group_interface::height)
+       (Y-offset . ,Side_position_interface::y_aligned_side)
+       (side-axis . ,Y)
        (padding . 1.2)
        (staff-padding . 1.2)
        (minimum-space . 1.0)
     (System
      . (
        (axes . (0 1))
-       (X-extent-callback . ,Axis_group_interface::group_extent_callback)
-       (Y-extent-callback . ,Axis_group_interface::group_extent_callback)
+       (X-extent . ,Axis_group_interface::width)
+       (Y-extent . ,Axis_group_interface::height)
        (meta . ((class . System)
                 (interfaces . (system-interface
                                axis-group-interface))))))
     (SystemStartBrace
      . (
        (glyph . "brace")
-       (print-function . ,System_start_delimiter::print)
+       (stencil . ,System_start_delimiter::print)
        (collapse-height . 5.0)
        (font-encoding . fetaBraces)
-       (Y-extent-callback . #f)
+       (Y-extent . #f)
        (meta . ((class . Spanner)
                 (interfaces . (system-start-delimiter-interface
                                font-interface))))))
 
     (SystemStartBracket
      . (
-       (Y-extent-callback . #f)
-       (X-offset-callbacks . (,(lambda (g a) -0.8)))
-       (print-function . ,System_start_delimiter::print)
+       (Y-extent . #f)
+       (X-offset . -0.8)
+       (stencil . ,System_start_delimiter::print)
        (glyph . "bracket")
-       (collapse-height . 1)
+       (collapse-height . 5.0)
        (thickness . 0.45)
        (meta . ((class . Spanner)
                 (interfaces . (font-interface
 
     (SystemStartBar
      . (
-       (Y-extent-callback . #f)
-       (print-function . ,System_start_delimiter::print)
+       (Y-extent . #f)
        (glyph . "bar-line")
        (thickness . 1.6)
-       (after-line-breaking-callback . ,System_start_delimiter::after_line_breaking)
+       (stencil . ,System_start_delimiter::print)
        (meta . ((class . Spanner)
                 (interfaces . (system-start-delimiter-interface))))))
 
     (TabNoteHead
      . (
-       (print-function . ,Text_interface::print)
-       (Y-offset-callbacks . (,Staff_symbol_referencer::callback))
+
+       (stencil . ,Text_interface::print)
+       (Y-offset . ,Staff_symbol_referencer::callback)
        (font-size . -2)
-       (stem-attachment-function . ,tablature-stem-attachment-function)
+       (stem-attachment . (1.0 . 1.35))
        (font-series . bold)
        (meta . ((class . Item)
                 (interfaces
                  . (rhythmic-head-interface
-                    font-interface
+                    font-interface rhythmic-grob-interface
                     note-head-interface
                     staff-symbol-referencer-interface
                     text-interface))))))
 
     (TextScript
      . (
-       (print-function . ,Text_interface::print)
        (no-spacing-rods . #t)
-       (X-offset-callbacks . (,Self_alignment_interface::aligned_on_self))
+       (X-offset . ,Self_alignment_interface::x_aligned_on_self)
        (direction . -1)
 
        ;; sync with Fingering ?
        (padding . 0.5)
        (staff-padding . 0.5)
-       (before-line-breaking-callback . ,Script_interface::before_line_breaking)
+
+       (stencil . ,Text_interface::print)
+       (direction . ,Script_interface::calc_direction)
+
        (avoid-slur . around)
        (slur-padding . 0.5)
        (script-priority . 200)
 
     (TextSpanner
      . (
-       (print-function . ,Text_spanner::print)
+       (stencil . ,Text_spanner::print)
        (font-shape . italic)
        (style . dashed-line)
        (staff-padding . 0.8)
        (dash-fraction . 0.2)
        (dash-period . 3.0)
+       (side-axis . ,Y)
        (direction . 1)
        (meta . ((class . Spanner)
                 (interfaces . (text-spanner-interface
 
     (Tie
      . (
-       (print-function . ,Tie::print)
-       (details . ((ratio . 0.333) (height-limit . 1.0)))
+       (control-points . ,Tie::calc_control_points)
+       (direction . ,Tie::calc_direction)
+       (stencil . ,Tie::print)
+       (details . ((ratio . 0.333)
+                   (height-limit . 1.0)
+                   (between-length-limit . 1.0)))
        (thickness . 1.0)
        (meta . ((class . Spanner)
-                (interfaces . (tie-interface))))))
+                (interfaces . (tie-interface))))
+       ))
 
     (TieColumn
      . (
-       (after-line-breaking-callback . ,Tie_column::after_line_breaking)
-       (before-line-breaking-callback . ,Tie_column::before_line_breaking)
-       (X-extent-callback . #f)
-       (Y-extent-callback . #f)
+       (positioning-done . ,Tie_column::calc_positioning_done)
+       (before-line-breaking . ,Tie_column::before_line_breaking)
+       (X-extent . #f)
+       (Y-extent . #f)
        (meta . ((class . Spanner)
                 (interfaces . (tie-column-interface))))))
 
     (TimeSignature
      . (
-       (print-function . ,Time_signature::print)
+       (stencil . ,Time_signature::print)
        (break-align-symbol . time-signature)
        (break-visibility . ,all-visible)
        (space-alist . (
 
     (TrillSpanner
      . (
-       (print-function . ,Dynamic_text_spanner::print)
+       (stencil . ,Dynamic_text_spanner::print)
        (edge-text . ,(cons (make-musicglyph-markup "scripts.trill")
                            ""))
        (style . trill)
        (staff-padding . 1.0)
        (padding . 0.5)
        (direction . 1)
-       (Y-offset-callbacks . (,Side_position_interface::aligned_side))
+       (Y-offset . ,Side_position_interface::y_aligned_side)
+       (side-axis . ,Y)
        (meta . ((class . Spanner)
                 (interfaces . (text-spanner-interface
                                side-position-interface
                                font-interface))))))
 
     (TrillPitchAccidental
-     . ((X-offset-callbacks . (,Side_position_interface::aligned_side))
+     . ((X-offset . ,Side_position_interface::x_aligned_side)
        (padding . 0.2)
        (direction . ,LEFT)
        (font-size . -4)
-       (print-function . ,Accidental_interface::print)
+       (side-axis . ,X)
+       (stencil . ,Accidental_interface::print)
        (meta . ((class . Item)
                 (interfaces . (item-interface
                                accidental-interface
                                font-interface))))))
 
     (TrillPitchGroup
-     . ((X-offset-callbacks . (,Side_position_interface::aligned_side))
+     . ((X-offset . ,Side_position_interface::x_aligned_side)
        (axes . (,X))
        (font-size . -4)
-       (print-function . ,parenthesize-elements)
+       (stencil . ,parenthesize-elements)
        (direction . ,RIGHT)
+       (side-axis . ,X)
        (padding . 0.3)
        (meta . ((class . Item)
                 (interfaces . (side-position-interface
                                axis-group-interface))))))
 
     (TrillPitchHead
-     . ((print-function . ,Note_head::print)
+     . (
+       (stencil . ,Note_head::print)
        (duration-log . 2)
-       (Y-offset-callbacks . (,Staff_symbol_referencer::callback))
+       (Y-offset . ,Staff_symbol_referencer::callback)
        (font-size . -4)
        (meta . ((class . Item)
                 (interfaces . (item-interface
        (thickness . 1.6)
        (edge-height . (0.7 . 0.7))
        (shorten-pair . (-0.2 . -0.2))
-       (before-line-breaking-callback . ,Tuplet_bracket::before_line_breaking)
-       (after-line-breaking-callback . ,Tuplet_bracket::after_line_breaking)
-       (print-function . ,Tuplet_bracket::print)
+       (direction  . ,Tuplet_bracket::calc_direction)
+       (positions . ,Tuplet_bracket::calc_positions)
+       (stencil . ,Tuplet_bracket::print)
        (font-shape . italic)
-
        (font-size . -2)
        (meta . ((class . Spanner)
                 (interfaces . (text-interface
 
     (UnaCordaPedal
      . (
-       (print-function . ,Text_interface::print)
+       (stencil . ,Text_interface::print)
        (font-shape . italic)
        (no-spacing-rods . #t)
        (self-alignment-X . 0)
        (direction . 1)
        (padding . 0.0)  ;; padding relative to UnaCordaPedalLineSpanner
-       (X-offset-callbacks . (,Self_alignment_interface::aligned_on_self))
+       (X-offset . ,Self_alignment_interface::x_aligned_on_self)
        (meta . ((class . Item)
                 (interfaces . (text-interface
                                self-alignment-interface
     (UnaCordaPedalLineSpanner
      . (
        (axes . (1))
-       (Y-extent-callback . ,Axis_group_interface::group_extent_callback)
-       (Y-offset-callbacks . (,Side_position_interface::aligned_side))
+       (X-extent . ,Axis_group_interface::height)
+       (Y-offset . ,Side_position_interface::y_aligned_side)
+       (side-axis . ,Y)
        (padding . 1.2)
        (staff-padding . 1.2)
        (minimum-space . 1.0)
      . (
        (thickness . 0.6)
        (flexa-width . 2.0)
-       (ligature-primitive-callback . ,Vaticana_ligature::brew_ligature_primitive)
-       (print-function . ,Vaticana_ligature::print)
+       (stencil . ,Vaticana_ligature::print)
        (meta . ((class . Spanner)
                 (interfaces . (vaticana-ligature-interface
                                font-interface))))))
     (VerticalAlignment
      . (
        (axes . (1))
-       (Y-extent-callback . ,Axis_group_interface::group_extent_callback)
-       (X-extent-callback . ,Axis_group_interface::group_extent_callback)
+       (positioning-done . ,Align_interface::calc_positioning_done)
+       (after-line-breaking . ,Align_interface::stretch_after_break)
+       (Y-extent . ,Axis_group_interface::height)
+       (X-extent . ,Axis_group_interface::width)
        (stacking-dir . -1)
        (meta . ((class . Spanner)
                 (interfaces . (align-interface
                                axis-group-interface))))))
-
     (VerticalAxisGroup
      . (
        (axes . (1))
-       (Y-extent-callback . ,Axis_group_interface::group_extent_callback)
-       (X-extent-callback . ,Axis_group_interface::group_extent_callback)
-
+       (Y-offset . ,Hara_kiri_group_spanner::force_hara_kiri_callback)
+       (Y-extent . ,Hara_kiri_group_spanner::y_extent)
+       (X-extent . ,Axis_group_interface::width)
        (meta . ((class . Spanner)
                 (interfaces . (axis-group-interface
+                               hara-kiri-group-interface
                                vertically-spaceable-interface))))))
 
     (VocalName
      . (
        (breakable . #t)
-       (Y-offset-callbacks . (,Side_position_interface::aligned_on_support_refpoints))
+       (Y-offset . ,Side_position_interface::y_aligned_on_support_refpoints)
        (direction . 0)
        (space-alist . ((left-edge . (extra-space . 1.0))))
        (break-align-symbol . instrument-name)
-       (print-function . ,Text_interface::print)
+       (stencil . ,Text_interface::print)
        (break-align-symbol . clef)
        (break-visibility . ,begin-of-line-visible)
        (baseline-skip . 2)
+       (side-axis . ,Y)
        (meta . ((class . Item)
                 (interfaces . (font-interface
                                self-alignment-interface
 
     (VoltaBracket
      . (
-       (print-function . ,Volta_bracket_interface::print)
-       (direction . 1)
+       (stencil . ,Volta_bracket_interface::print)
+       (after-line-breaking . ,Volta_bracket_interface::after_line_breaking)
+       (direction . ,UP)
        (padding . 1)
        (font-encoding . fetaNumber)
-       (Y-offset-callbacks . (,Side_position_interface::aligned_side))
+       (Y-offset . ,Side_position_interface::y_aligned_side)
+       (side-axis . ,Y)
        (thickness . 1.6)  ;;  linethickness
-       (height . 2.0) ;; staffspace;
+       (edge-height . (2.0 . 2.0)) ;; staffspace;
        (minimum-space . 5)
        (font-size . -4)
        (meta . ((class . Spanner)
                 (interfaces . (volta-bracket-interface
+                               horizontal-bracket-interface                            
                                line-interface
                                text-interface
                                side-position-interface
-                               font-interface))))))
+                               font-interface)))
+             )))
+
 
     (VoiceFollower
      . (
        (style . line)
        (gap . 0.5)
        (breakable . #t)
-       (X-extent-callback . #f)
-       (Y-extent-callback . #f)
-       (print-function . ,Line_spanner::print)
-       (after-line-breaking-callback . ,Line_spanner::after_line_breaking)
+       (X-extent . #f)
+       (Y-extent . #f)
+       (stencil . ,Line_spanner::print)
+       (after-line-breaking . ,Line_spanner::after_line_breaking)
        (meta . ((class . Spanner)
                 (interfaces . (line-spanner-interface
-                               line-interface))))))))
+                               line-interface))))
+       ))
+
+))
 
 (define (completize-grob-entry x)
   "Transplant assoc key into 'name entry of 'meta of X.  Set interfaces for Item, Spanner etc.