-%{
-You should preprocess this file with the C preprocessor. The one with
-FAKE_GRACE looks best.
-
-1.
- cpp -P -traditional -o l.ly les-nereides.ly
-
-2.
- cpp -P -traditional -o l-fake.ly -DFAKE_GRACE les-nereides.ly
-
-%}
-
-\version "1.3.148"
+#(ly:set-option 'old-relative)
+\version "2.1.22"
\header {
composer = "ARTHUR GRAY"
- title = "LES N\\'ER\\'EIDES"
+ title = "LES NÉRÉIDES"
subtitle = "THE NEREIDS"
enteredby = "JCN"
- %piece = "Allegretto scherzando"
+ piece = "Allegretto scherzando"
copyright = "public domain"
- description = "Nastiest piece of competition at http://www.orphee.com/comparison/study.html, see http://www.orphee.com/comparison/gray.pdf"
- comment = "LilyPond (1.3.93) can't really do this yet, I guess"
}
+%{
-% cpp: don't start on first column
- #(set! point-and-click line-column-location)
-
-%% cpp: don't start on first column
- #(define (grace-beam-space-function multiplicity)
- (* (if (<= multiplicity 3) 0.816 0.844) 0.8))
-
-%% cpp: don't start on first column
- #(define (make-text-checker text)
- (lambda (elt) (equal? text (ly-get-grob-property elt 'text))))
-
-% complete and move to propert.ly?
-smallFont = {
- \property Score.PaperColumn \override #'space-factor = #0.6
- \property Score.PaperColumn \override #'to-musical-spacing-factor = #0.04
- \property Voice.NoteHead \override #'font-relative-size = #-1
- \property Voice.Stem \override #'font-relative-size = #-1
- \property Voice.Stem \override #'length = #6
- \property Voice.Stem \override #'beamed-lengths =
- #(map (lambda (x) (* 1.25 x)) '(0.0 2.5 2.0 1.5))
- \property Voice.Stem \override #'beamed-minimum-lengths =
- #(map (lambda (x) (* 1.25 x)) '(0.0 1.5 1.25 1.0))
-
- \property Voice.Beam \override #'font-relative-size = #-1
- \property Voice.TextScript \override #'font-relative-size = #0
- \property Voice.Fingering \override #'font-relative-size = #-4
- \property Voice.Slur \override #'font-relative-size = #-1
- \property Staff.Accidentals \override #'font-relative-size = #-1
- \property Voice.Beam \override #'space-function = #grace-beam-space-function
-}
+Nastiest piece of competition at
+http://www.orphee.com/comparison/study.html, see
+http://www.orphee.com/comparison/gray.pdf
-unSmallFont = {
- \property Voice.NoteHead \revert #'font-relative-size
- \property Voice.Stem \revert #'font-relative-size
- \property Voice.Stem \revert #'length
- \property Voice.Stem \revert #'beamed-lengths
- \property Voice.Stem \revert #'beamed-minimum-lengths
- \property Voice.Beam \revert #'font-relative-size
- \property Voice.TextScript \revert #'font-relative-size
- \property Voice.Fingering \revert #'font-relative-size
- \property Voice.Slur \revert #'font-relative-size
- \property Staff.Accidentals \revert #'font-relative-size
- \property Voice.Beam \revert #'space-function
- \property Score.PaperColumn \revert #'space-factor
- \property Score.PaperColumn \revert #'to-musical-spacing-factor
-}
-global = \notes{
- \partial 2
- \key a \major
- \skip 2
- \skip 1*2
+lines that contain tweaks (17 currently, not counting reverts) are
+marked with %tweak
-#ifndef FAKE_GRACE /* First run this through cpp. See head les-nereides.ly */
- \skip 1
-#else % FAKE_GRACE
- \skip 2. \partial 32*24
- \skip 32*24
-#endif % FAKE_GRACE
+possibly more impressive to render without tweaks?
- \bar "||"
-}
+ grep -v tweak input/les-nereides.ly >> lnnt.ly
+ lilypond lnnt.ly
-treble = \context Voice=treble \notes\relative c''{
- % Broken?
- \property Voice.NoteColumn \override #'horizontal-shift = #0
- \outputproperty #(make-type-checker 'text-interface)
- #'extra-offset = #'(-6 . 2)
- r2^#'((Large upright) "Allegretto scherzando")
- %2
- \property Voice.Stem \revert #'direction
- \property Voice.Stem \override #'direction = #1
- r4 <cis\arpeggio eis a cis> r2
- %3
- r4 <cis\arpeggio fis a cis> r8.
-
- % Urg, this lifts us up to staff context
- \translator Staff=bass
-
- % Get back:
- \context Voice
-
- % If we don't get back to Voice, this text-checker doesn't work
- \outputproperty #(make-text-checker "m.d.")
- #'extra-offset = #'(-3 . -4)
-
- % currently, this can't be (small) italic, because in the paperblock
- % we set italic_magnifictation to get large italics.
- cis,16^2^"m.d."( <fis8 fis,> <e! e,!>
- %4
- <)dis,4 a' dis>
-
- % Urg, this lifts us up to staff context
- \translator Staff=treble
- % Get back:
- \context Voice
-
- \property Voice.Slur \revert #'direction
- \property Voice.Slur \override #'direction = #1
- \property PianoStaff.connectArpeggios = ##t
- \property Voice.TextSpanner \revert #'type
+%}
- %% Ghostview is ok, but xdvi shows a solid line
- \property Voice.TextSpanner \override #'line-thickness = #2
- \property Voice.TextSpanner \override #'dash-period = #0.5
+#(ly:set-point-and-click 'line-column)
+#(define (make-text-checker text)
+ (lambda (elt) (equal? text (ly:get-grob-property elt 'text))))
- \property Voice.TextSpanner \override #'type = #'dotted-line
- \property Voice.TextSpanner \override #'edge-height = #'(0 . 1.5)
- %% \property Voice.TextSpanner \override #'edge-text = #'("8 " . "")
- \property Voice.TextSpanner \override #'edge-text = #'("8 " . " ")
- % Urg, this lifts us up to staff context
- \property Staff.centralCPosition = #-13
+treble = \new Voice \notes\relative c''{
+ \key a \major
+ r2
+ | %2
+ \stemUp
+ r4 <cis eis a cis>\arpeggio r2
+ | %3
+ r4 <cis fis a cis>\arpeggio r8.
- % Get back:
- \context Voice
+ \change Staff=bass
- % If we don't get back to Voice, this text-checker doesn't work
- \outputproperty #(make-text-checker "m.g.")
- #'extra-offset = #'(-3 . -3)
+ \once\override TextScript #'extra-offset = #'(-3 . -4) %tweak
- % currently, this can't be (small) italic, because in the paperblock
- % we set italic_magnifictation to get large italics.
- cis''''4^"m.g."\arpeggio \spanrequest \start "text" (
-
-#ifndef FAKE_GRACE
-
- \property Voice.Stem \revert #'direction
+ cis,16^2(^\markup {\small \italic "m.d." }
+ <fis fis,>8 <e! e,!>
+ | %4
+ <dis, a' dis>4)
+
+ \change Staff=treble
+
+ \slurUp
+ \set PianoStaff.connectArpeggios = ##t
- % grace is a mess
- % maybe we should fake this and put 5/4 in this bar?
+ #(set-octavation 1)
+ \once\override TextScript #'extra-offset = #'(-3 . -2) %tweak
+
+ \tieUp
+ cis''''4^\markup { \small \italic "m.g." }\arpeggio~
\grace {
- )cis8
- \property Grace.Stem \revert #'direction
- \property Grace.Stem \override #'direction = #0
- \property Grace.Beam \override #'space-function = #grace-beam-space-function
- %% urg, dim. during grace dumps core here
- %% [a16-5( fis dis \spanrequest \stop "text" ]
- %%[cis'32 a-1 fis-4 dis] [cis a )fis-2]
- [a16-5( fis dis \spanrequest \stop "text" ]
- \property Staff.centralCPosition = #-6
+ \override Stem #'stroke-style = #"grace"
+
+ cis8
+
+ %\stemBoth Hmm
+
+ \override Stem #'direction = #0
+
+ a16[-5( fis dis]
+ #(set-octavation 0)
- [cis32 a-1 fis-4 dis] [cis a )fis-2]
+ cis32[ a-1 fis-4 dis] cis[ a fis)-2]
+ % the small grace in lower staff comes after us
+ s32
+
+ \revert Stem #'stroke-style
}
-#else % FAKE_GRACE
- \smallFont
+ \stemUp
+ cis'4( bis)
+
+ | %5
+ r8 <a' a,>8(\mf <gis gis,> <fis fis,>
- )cis16
- \property Voice.Stem \revert #'direction
- \property Voice.Stem \override #'direction = #0
- %% [a16^5( fis dis \spanrequest \stop "text" ]
- %% [cis'32 a-1 fis-4 dis] [cis a )fis-2] s s s
- [a16^5( fis dis \spanrequest \stop "text" ]
- \property Staff.centralCPosition = #-6
- [cis32 a^1 fis^4 dis] [cis a )fis-2] s % s s
-
- \unSmallFont
-#endif % FAKE_GRACE
+ % \fingerUp
+ \override Fingering #'direction = #1
+ % Manual fix for collision with slur
+ \override Fingering #'extra-offset = #'(0 . 1) %tweak
+ <gis gis,> <fis fis,> e)-1-4-5 r
- \property Voice.Stem \revert #'direction
- \property Voice.Stem \override #'direction = #1
- cis'4()bis
- r8
- <a'8( a,> <gis gis,> <fis fis,> <gis gis,> <fis fis,> )e^" "^1^4^5 r|
- r<a8( a,> <gis gis,> <fis fis,> <gis gis,> <fis fis,> )e r|
+ | %6
+ r <a a,>8(\mf <gis gis,> <fis fis,>
+ <gis gis,> <fis fis,> e) r
+
+ | %7
+ \bar "||"
}
-trebleTwo = \context Voice=trebleTwo \notes\relative c''{
- \property Voice.NoteColumn \override #'horizontal-shift = #1
+trebleTwo = \new Voice \notes\relative c''{
+ \stemDown
+ \slurDown
+ % \fingerDown
+ \override Fingering #'direction = #-1
+ \override Fingering #'extra-offset = #'(0 . 1.2)
s2
+ | %1
s1*2
+ | %4
s4
- \property Voice.Stem \revert #'direction
- \property Voice.Stem \override #'direction = #-1
- <cis'4\arpeggio a fis dis>
-
-#ifdef FAKE_GRACE
- s32*16
-#endif
-
- \property Voice.NoteColumn \override #'force-hshift = #-0.2
- <e,2 gis, e d!>
- % Hmm s/r?
- %r8 cis4. d4
+ <cis' a fis dis>4\arpeggio
+ <e, gis, e d!>2
+ | %5
s8 cis4. d4
- \property Voice.NoteColumn \revert #'force-hshift
- [<cis8( e,> <b-3 d,-1> |
- \property Voice.NoteColumn \override #'force-hshift = #-0.2
- <)a-2 cis,-1>] cis4. d4
- \property Voice.NoteColumn \revert #'force-hshift
- [<cis8( e,> <b d,> |
- <)a cis,>]
+ %%<cis e,>8[( <b-3 d,-1>
+ <cis e,>8[( <b d,>-3-1
+ | %6
+ %%<a-2 cis,-1>)] cis4. d4
+ <a cis,>)]-2-1 cis4. d4
+ <cis e,>8[( <b d,>
+ | %7
+ <a cis,>)]
}
-bass = \context Voice=bass \notes\relative c{
- % Allow ugly slurs
- \property Voice.Slur \override #'beautiful = #5.0
- \property Voice.Slur \override #'attachment-offset = #'((0 . 3) . (0 . -4))
- \property Voice.Stem \revert #'direction
- \property Voice.Slur \override #'direction = #-1
- % huh, auto-beamer?
- r8. e,16-2( [<a8 a,> <b b,>] |
- %2
- <cis4 cis,>
- % Huh, urg? Implicit \context Staff lifts us up to Staff context???
- \translator Staff=treble
- % Get back
- \context Voice
- \property Voice.Stem \revert #'direction
- \property Voice.Stem \override #'direction = #-1
- \property Voice.Slur \override #'attachment = #'(stem . stem)
- <)a''4\arpeggio eis cis>
- %\stemBoth
- \property Voice.Slur \revert #'attachment
- % Huh, urg? Implicit \context Staff lifts us up to Staff context???
- \translator Staff=bass
- % Get back
- \context Voice
- \property Voice.Stem \revert #'direction
- \property Voice.Slur \revert #'y-free
- \property Voice.Slur \override #'y-free = #0.1
- \property Voice.Slur \revert #'attachment-offset
- \property Voice.Slur \override #'attachment-offset = #'((0 . 3) . (0 . 8))
- r8. cis,,16( <fis8 fis,> <gis gis,>
- %3
- \property Voice.Stem \revert #'length
- \property Voice.Stem \override #'length = #5
- <a4 a,>
- % Huh, urg? Implicit \context Staff lifts us up to Staff context???
- \translator Staff=treble
- % Get back
- \context Voice
- \property Voice.Stem \revert #'length
- \property Voice.Stem \revert #'direction
- \property Voice.Stem \override #'direction = #-1
- <)a'\arpeggio fis cis>
- % Huh, urg? Implicit \context Staff lifts us up to Staff context???
- \translator Staff=bass
- % Get back
- \context Voice
- \property Voice.Stem \revert #'direction
+bass = \new Voice \notes\relative c{
+ \partial 2
+ \key a \major
+
+ % Allow ugly (highly blown-up) slurs
+ \override Slur #'beautiful = #5.0 %tweak
+ \override Slur #'attachment-offset = #'((0 . 3) . (0 . -4)) %tweak
+ \slurDown
+
+ \dynamicUp
+
+ r8. e,16(\f_2 <a a,>8[ <b b,>]
+ | %2
+ <cis cis,>4
+ \change Staff=treble
+ \stemDown
+ \override Slur #'attachment = #'(stem . stem) %tweak
+ <a'' eis cis>4)\arpeggio
+
+ \revert Slur #'attachment %tweak
+ \change Staff=bass
+ \stemBoth
+
+ \revert Slur #'y-free %tweak
+ \override Slur #'y-free = #0.1 %tweak
+ \revert Slur #'attachment-offset %tweak
+ \override Slur #'attachment-offset = #'((0 . 3) . (0 . 8)) %tweak
+ r8. cis,,16( <fis fis,>8 <gis gis,>
+
+ | %3
+ \override Stem #'length = #5 %tweak
+ <a a,>4
+ \change Staff=treble
+
+ \revert Stem #'length %tweak
+ \revert Stem #'direction
+ \override Stem #'direction = #-1
+ <a' fis cis>)\arpeggio
+ \change Staff=bass
+ \revert Stem #'direction
r2
- %4
- \property Voice.Slur \revert #'beautiful
- \property Voice.Slur \revert #'attachment-offset
- \property Voice.Stem \revert #'direction
- \property Voice.Stem \override #'direction = #-1
- <b,,4 b,>
+
+ | %4
+ \revert Slur #'beautiful %tweak
+ \revert Slur #'attachment-offset %tweak
+ \stemDown
+ <b,, b,>4
\clef treble
- \property Voice.Stem \revert #'direction
- \property Voice.Stem \override #'direction = #0
- <
+ \stemBoth
+ <<
%urg: staff-change: ! on dis
- <cis''\arpeggio a fis dis!>
-% { s8. \clef bass}
- >
-
-#ifndef FAKE_GRACE
- %Hmm
- %\grace { s16 s s s s32 s s s s \clef bass s }
- \clef bass
- \grace { <e,,,32( e,> } <)gis'2 e>
-#else
- s4 s8 s32 s s \clef bass
-
- \smallFont
+ <cis'' a fis dis!>\arpeggio
+ >>
+
+ \grace {
+ \override Stem #'stroke-style = #"grace"
+
+ s8
+ s16 s s
+ s32 s s
+ s s s
+ \clef bass
+ <e,,, e,>32(
- \property Voice.Slur \override #'attachment-offset = #'((-0.5 . 0) . (0.5 . 0))
- <e,,,32( e,>
-
- \unSmallFont
- <)gis'2 e>
- \property Voice.Slur \revert #'attachment-offset
-#endif
- %5
- \property Voice.Slur \revert #'direction
- \property Voice.Slur \override #'direction = #1
- a,8 [e'-5(<)a-2 cis-3>]
- r b,-5 <e4-3 gis-5 d'>
- \property Voice.Slur \revert #'direction
- \property Voice.Slur \override #'direction = #0
- [e,8-5(|
- %6
- )a-2]
- \property Voice.Slur \revert #'direction
- \property Voice.Slur \override #'direction = #1
- [e'(<)a cis>] r b, <e4 gis d'>
- \property Voice.Slur \revert #'direction
- \property Voice.Slur \override #'direction = #0
- [e,8(|
- %7
- )a]
+ \revert Stem #'stroke-style
+ }
+ <gis' e>2)
+
+ | %5
+ \slurUp
+
+ % \fingerDown
+ \override Fingering #'direction = #-1
+
+ %%a,8 e'[-5(<a-2 cis-3>])
+ a,8 e'[-5(<a cis>])-2-3
+ %%r b,-5 <e-3 gis-5 d'>4
+ r b,-5 <e gis d'>4-3-5
+ \slurBoth
+ \once \override Fingering #'extra-offset = #'(0 . -1) %tweak
+ e,8[-5(
+
+ | %6
+ \once \override Fingering #'extra-offset = #'(0 . -1) %tweak
+ a)-2]
+ \slurUp
+ e'[(<a cis>)] r b, <e gis d'>4
+ \slurBoth
+ e,8[(
+
+ | %7
+ a)]
}
-bassTwo = \context Voice=bassTwo \notes\relative c{
+bassTwo = \new Voice \notes\relative c{
\skip 2
\skip 1*2
\skip 2
-#ifdef FAKE_GRACE
- \skip 32*16
-#endif
-
- \property Voice.Stem \revert #'direction
- \property Voice.Stem \override #'direction = #1
- \property Voice.Slur \revert #'direction
- \property Voice.Slur \override #'direction = #1
+ \stemUp
+ \slurUp
- cis'4()bis
+ cis'4( bis)
}
-middleDynamics = \context Dynamics=middle \notes{
- s8 s16 s\f s4
+middleDynamics = \notes{
+ \override Dynamics.TextScript #'padding = #-1 %tweak
+ s2
s1*2
- %4
+ | %4
s2
-
-#ifdef FAKE_GRACE
- s32*12
- \outputproperty #(make-type-checker 'dynamic-interface)
- #'extra-offset = #'(0 . 1.5)
- s32\> s s \!s
-#endif
- s32
- \outputproperty #(make-type-checker 'text-interface)
- #'extra-offset = #'(0 . 1.5)
- s-"rall." s s
- s8 s4
-
- \outputproperty #(make-type-checker 'dynamic-interface)
- #'extra-offset = #'(0 . 4)
- %s1\mf-"a tempo"
-%% s2\mf-"a tempo" s4
- s2\mf-"a tempo" s8
-%% s\> \!s8
- s16 s32 s64 \> s s8 s \!s8
- \outputproperty #(make-type-checker 'dynamic-interface)
- #'extra-offset = #'(-1 . 4)
-%% s8\mf s4 s4 s8\> s32 s s \!s
- s8\mf s4 s8 s16 s32 s64 \> s s16 s8 s32 s s s\! s128
+ \grace {
+ \override Stem #'stroke-style = #"grace"
+
+ s8
+ s16 s s
+ s32 s
+ \once\override Dynamics.Hairpin #'extra-offset = #'(0 . 2) %tweak
+ s\> s
+ s32 s s s\!
+
+ \revert Stem #'stroke-style }
+
+ s32 s-"rall." s s s8 s4
+ | %5
+ s2-"a tempo" s8
+ \once\override Dynamics.Hairpin #'extra-offset = #'(1 . 0) %tweak
+ s \> s s
+ | %6
+ s8\!
+ s2 s8 s\> s
+ | %7
+ s8\!
}
-lowerDynamics = \context Dynamics=lower \notes{
+lowerDynamics = \notes{
s2
- %2
+ | %2
s2\sustainDown s8. s16\sustainUp s4
- %3
+ | %3
s2\sustainDown s8. s16\sustainUp s4
- %3
-
-#ifndef FAKE_GRACE
- s4\sustainDown s16
- s32 s s\sustainUp s
- s32\sustainDown s s s
- s8
-#else
- s2\sustainDown
- s32*12
- s32 s s\sustainUp s
- s32\sustainDown s s s
-#endif
-
- \property Dynamics.pedalSustainStrings = #'("Ped." "*Ped." "")
- s4 s16. s32\sustainUp
-
- %5
+ | %4
+ s4\sustainDown
+ \set Dynamics.pedalSustainStrings = #'("Ped." "*Ped." "*")
+
+ % grace destroys pedal-line-spanner?
+ % let's do manual tweak:
+ \once\override Dynamics.SustainPedal #'extra-offset = #'(10 . 0) %tweak
+ s8\sustainUp
+ \once\override Dynamics.SustainPedal #'extra-offset = #'(16 . 0) %tweak
+ s8\sustainDown
+%{
+ s4
+ \grace {
+ \override Stem #'stroke-style = #"grace"
+
+ s8
+ s16 s s
+ s32 s s s\sustainUp
+ s32 s s s\sustainDown
+
+ \revert Stem #'stroke-style }
+
+%}
+ s2
+
+ | %5
+ % ugh, I don't think that 'mixed should show last edge, but rather:
+ %
+ % Ped__________/\__________ *
+ %
+ % that's what gray wants, anyway.
+
+ \set Dynamics.pedalSustainStyle = #'mixed
s8\sustainDown s s
- \property Dynamics.pedalSustainStrings = #'("Ped." "-P" "*")
- s s\sustainUp\sustainDown s s
+ s s\sustainUp\sustainDown s
+ s
+ \once \set Dynamics.pedalSustainStyle = #'text
s\sustainUp
- %6
- \property Dynamics.pedalSustainStrings = #'("Ped." "*Ped." "")
+ | %6
+ \set Dynamics.pedalSustainStyle = #'mixed
s8\sustainDown s s
- \property Dynamics.pedalSustainStrings = #'("Ped." "-P" "*")
- s s\sustainUp\sustainDown s s
+ s s\sustainUp\sustainDown s
+ s
+ \once \set Dynamics.pedalSustainStyle = #'text
s\sustainUp
+ | %7
}
\score{
- \context PianoStaff <
- \context Staff=treble <
- \global
+ \context PianoStaff <<
+ \context Staff=treble <<
\treble
\trebleTwo
- >
- \context Dynamics=middle <
- \global
+ >>
+ \new Dynamics <<
\middleDynamics
- >
- \context Staff=bass <
+ >>
+ \context Staff=bass <<
\clef bass
- \global
\bass
\bassTwo
- >
- \context Dynamics=lower <
- \global
+ >>
+ \new Dynamics <<
\lowerDynamics
- >
- >
+ >>
+ >>
\paper {
- % Hmm
- % magnification_italic = 1.
\translator {
\ScoreContext
- TimeSignature \override #'style = #'C
- SpacingSpanner \override #'maximum-duration-for-spacing = #(make-moment 1 4)
-
\remove Bar_number_engraver
}
\translator {
\type "Engraver_group_engraver"
\name Dynamics
\consists "Output_property_engraver"
- Generic_property_list = #generic-voice-properties
- \consists "Property_engraver"
- MinimumVerticalExtent = #'(-1 . 1)
+ minimumVerticalExtent = #'(-1 . 1)
pedalSustainStrings = #'("Ped." "*Ped." "*")
- pedalUnaCordaStrings = #'("una corda" "" "tre corde")
\consists "Piano_pedal_engraver"
\consists "Script_engraver"
\consists "Dynamic_engraver"
\consists "Text_engraver"
- TextScript \override #'font-relative-size = #1
+ TextScript \override #'font-size = #2
TextScript \override #'font-shape = #'italic
- \consists "Skip_req_swallow_translator"
+ \consists "Skip_event_swallow_translator"
\consistsend "Axis_group_engraver"
}
\accepts Dynamics
VerticalAlignment \override #'forced-distance = #7
}
- \translator {
- \GraceContext
- Stem \override #'flag-style = #""
- }
}
}
+
+%%% Local variables:
+%%% LilyPond-indent-level:4
+%%% End:
+%% new-chords-done %%