X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=ly%2Fspanners-init.ly;h=9f18169c71761a2ab6c57e6371ed670ebe9c7c1e;hb=d232ec8f99f1bcdf4781119ba28fc94a24a1e8db;hp=c7fd8f93cf2b07065d16b5f14312e4a02d5b9b30;hpb=955f829883aa125b2b633b1e71f6256da5b773fa;p=lilypond.git diff --git a/ly/spanners-init.ly b/ly/spanners-init.ly index c7fd8f93cf..9f18169c71 100644 --- a/ly/spanners-init.ly +++ b/ly/spanners-init.ly @@ -1,4 +1,4 @@ -\version "1.9.0" +\version "2.4.0" startGroup = #(make-span-event 'NoteGroupingEvent START) stopGroup = #(make-span-event 'NoteGroupingEvent STOP) @@ -9,46 +9,74 @@ decr = #(make-span-event 'DecrescendoEvent START) enddecr = #(make-span-event 'DecrescendoEvent STOP) endcr = #(make-span-event 'CrescendoEvent STOP) -%% TODO: remove for 2.0 -rc = \endcr -rced = \enddecr startTextSpan = #(make-span-event 'TextSpanEvent START) stopTextSpan = #(make-span-event 'TextSpanEvent STOP) -cresc = \notes { + +startTrillSpan = #(make-span-event 'TrillSpanEvent START) +stopTrillSpan = #(make-span-event 'TrillSpanEvent STOP) + + +% STOP: junkme! +cresc = { #(ly:export (make-event-chord (list cr))) - \property Voice.crescendoText = \markup { \italic "cresc." } - \property Voice.crescendoSpanner = #'dashed-line + \set crescendoText = \markup { \italic "cresc." } + \set crescendoSpanner = #'dashed-line +} + + +dim = { + #(ly:export (make-event-chord (list decr))) + + \set decrescendoText = \markup { \italic "dim." } + \set decrescendoSpanner = #'dashed-line +} + +enddim = { + #(ly:export (make-event-chord (list enddecr))) + \unset decrescendoText + \unset decrescendoSpanner } % ah, this is handy: maybe drop resetting of properties in % dynamic-engraver ? -endcresc = \notes { - #(ly:export (make-event-chord (list rc))) - \property Voice.crescendoText \unset - \property Voice.crescendoSpanner \unset +endcresc = { + #(ly:export (make-event-chord (list endcr))) + \unset crescendoText + \unset crescendoSpanner } -dim = \notes { - #(ly:export (make-event-chord (list decr))) +%%%%%%%%%%%%%%%% - \property Voice.decrescendoText = \markup { \italic "dim." } - \property Voice.decrescendoSpanner = #'dashed-line +setTextCresc = { + \set crescendoText = \markup { \italic "cresc." } + \set crescendoSpanner = #'dashed-line } -enddim = \notes { - #(ly:export (make-event-chord (list rced))) - \property Voice.decrescendoText \unset - \property Voice.decrescendoSpanner \unset +setTextDecresc = { + \set decrescendoText = \markup { \italic "decr." } + \set decrescendoSpanner = #'dashed-line } -%{ +setTextDim = { + \set decrescendoText = \markup { \italic "dim." } + \set decrescendoSpanner = #'dashed-line +} +setHairpinCresc = { + \unset crescendoText + \unset crescendoSpanner +} +setHairpinDecresc = { + \unset decrescendoText + \unset decrescendoSpanner +} +setHairpinDim = { + \unset decrescendoText + \unset decrescendoSpanner +} -cresc = \spanevent \start "crescendo" -endcresc = \spanevent \stop "crescendo" -%} % better name sustainstart/stop? sustainUp = #(make-span-event 'SustainEvent STOP) @@ -60,6 +88,30 @@ treCorde = #(make-span-event 'UnaCordaEvent STOP) sostenutoDown = #(make-span-event 'SostenutoEvent START) sostenutoUp = #(make-span-event 'SostenutoEvent STOP) -%crescpoco = \property Voice.crescendoText = "cresc. poco a poco" -%decresc = \property Voice.crescendoText = "decr." -%dim = \property Voice.crescendoText = "dim." +%crescpoco = \set crescendoText = "cresc. poco a poco" +%decresc = \set crescendoText = "decr." +%dim = \set crescendoText = "dim." + + +% for regression testing purposes. +assertBeamQuant = +#(def-music-function (parser location l r) (pair? pair?) + (let* ((f (check-quant-callbacks l r))) + + #{ + \once \override Beam #'position-callbacks = $f + #} + +)) + +% for regression testing purposes. +assertBeamSlope = +#(def-music-function (parser location comp) (procedure?) + (let* ((f (check-slope-callbacks comp))) + + #{ + \once \override Beam #'position-callbacks = $f + #} + +)) +