9 NOT_SMART
= _ ("Not smart enough to convert %s")
10 UPDATE_MANUALLY
= _ ("Please refer to the manual for details, and update manually.")
11 FROM_TO
= _ ( "%s has been replaced by %s")
14 class FatalConversionError
:
19 error_file
= sys
.stderr
20 lilypond_version_re_str
= '\\\\version *\"([^"]+)\"'
21 lilypond_version_re
= re
.compile (lilypond_version_re_str
)
27 if re
.search ('\\\\multi', str):
28 error_file
.write ('\n')
29 error_file
.write (NOT_SMART
% "\\multi")
30 error_file
.write ('\n')
33 conversions
.append (((0,1,9), conv
, '\\header { key = concat + with + operator }'))
37 if re
.search ('\\\\octave', str):
38 error_file
.write ('\n')
39 error_file
.write (NOT_SMART
% "\\octave")
40 error_file
.write ('\n')
41 error_file
.write (UPDATE_MANUALLY
)
42 error_file
.write ('\n')
43 # raise FatalConversionError ()
48 ((0,1,19), conv
, 'deprecated \\octave; cannot convert automatically')))
53 str = re
.sub ('\\\\textstyle([^;]+);',
54 '\\\\property Lyrics . textstyle = \\1', str)
55 # harmful to current .lys
56 # str = re.sub ('\\\\key([^;]+);', '\\\\accidentals \\1;', str)
61 ((0,1,20), conv
, 'deprecated \\textstyle, new \\key syntax')))
66 str = re
.sub ('\\\\musical_pitch', '\\\\musicalpitch',str)
67 str = re
.sub ('\\\\meter', '\\\\time',str)
72 ((0,1,21), conv
, '\\musical_pitch -> \\musicalpitch, '+
73 '\\meter -> \\time')))
80 ((1,0,0), conv
, '0.1.21 -> 1.0.0 ')))
85 str = re
.sub ('\\\\accidentals', '\\\\keysignature',str)
86 str = re
.sub ('specialaccidentals *= *1', 'keyoctaviation = 0',str)
87 str = re
.sub ('specialaccidentals *= *0', 'keyoctaviation = 1',str)
92 ((1,0,1), conv
, '\\accidentals -> \\keysignature, ' +
93 'specialaccidentals -> keyoctaviation')))
97 if re
.search ('\\\\header', str):
98 error_file
.write ('\n')
99 error_file
.write (NOT_SMART
% "new \\header format")
100 error_file
.write ('\n')
103 conversions
.append (((1,0,2), conv
, '\\header { key = concat + with + operator }'))
107 str = re
.sub ('\\\\melodic([^a-zA-Z])', '\\\\notes\\1',str)
110 conversions
.append (((1,0,3), conv
, '\\melodic -> \\notes'))
114 str = re
.sub ('default_paper *=', '',str)
115 str = re
.sub ('default_midi *=', '',str)
118 conversions
.append (((1,0,4), conv
, 'default_{paper,midi}'))
122 str = re
.sub ('ChoireStaff', 'ChoirStaff',str)
123 str = re
.sub ('\\\\output', 'output = ',str)
127 conversions
.append (((1,0,5), conv
, 'ChoireStaff -> ChoirStaff'))
131 if re
.search ('[a-zA-Z]+ = *\\translator',str):
132 error_file
.write ('\n')
133 error_file
.write (NOT_SMART
% "\\translator syntax")
134 error_file
.write ('\n')
135 # raise FatalConversionError ()
138 conversions
.append (((1,0,6), conv
, 'foo = \\translator {\\type .. } ->\\translator {\\type ..; foo; }'))
143 str = re
.sub ('\\\\lyrics*', '\\\\lyrics',str)
147 conversions
.append (((1,0,7), conv
, '\\lyric -> \\lyrics'))
151 str = re
.sub ('\\\\\\[/3+', '\\\\times 2/3 { ',str)
152 str = re
.sub ('\\[/3+', '\\\\times 2/3 { [',str)
153 str = re
.sub ('\\\\\\[([0-9/]+)', '\\\\times \\1 {',str)
154 str = re
.sub ('\\[([0-9/]+)', '\\\\times \\1 { [',str)
155 str = re
.sub ('\\\\\\]([0-9/]+)', '}', str)
156 str = re
.sub ('\\\\\\]', '}',str)
157 str = re
.sub ('\\]([0-9/]+)', '] }', str)
160 conversions
.append (((1,0,10), conv
, '[2/3 ]1/1 -> \\times 2/3 '))
165 conversions
.append (((1,0,12), conv
, 'Chord syntax stuff'))
172 str = re
.sub ('<([^>~]+)~([^>]*)>','<\\1 \\2> ~', str)
176 conversions
.append (((1,0,13), conv
, '<a ~ b> c -> <a b> ~ c'))
180 str = re
.sub ('<\\[','[<', str)
181 str = re
.sub ('\\]>','>]', str)
185 conversions
.append (((1,0,14), conv
, '<[a b> <a b]>c -> [<a b> <a b>]'))
190 str = re
.sub ('\\\\type([^\n]*engraver)','\\\\TYPE\\1', str)
191 str = re
.sub ('\\\\type([^\n]*performer)','\\\\TYPE\\1', str)
192 str = re
.sub ('\\\\type','\\\\context', str)
193 str = re
.sub ('\\\\TYPE','\\\\type', str)
194 str = re
.sub ('textstyle','textStyle', str)
198 conversions
.append (((1,0,16), conv
, '\\type -> \\context, textstyle -> textStyle'))
203 if re
.search ('\\\\repeat',str):
204 error_file
.write ('\n')
205 error_file
.write (NOT_SMART
% "\\repeat")
206 error_file
.write ('\n')
207 # raise FatalConversionError ()
210 conversions
.append (((1,0,18), conv
,
211 '\\repeat NUM Music Alternative -> \\repeat FOLDSTR Music Alternative'))
215 str = re
.sub ('SkipBars','skipBars', str)
216 str = re
.sub ('fontsize','fontSize', str)
217 str = re
.sub ('midi_instrument','midiInstrument', str)
221 conversions
.append (((1,0,19), conv
,
222 'fontsize -> fontSize, midi_instrument -> midiInstrument, SkipBars -> skipBars'))
227 str = re
.sub ('tieydirection','tieVerticalDirection', str)
228 str = re
.sub ('slurydirection','slurVerticalDirection', str)
229 str = re
.sub ('ydirection','verticalDirection', str)
233 conversions
.append (((1,0,20), conv
,
234 '{,tie,slur}ydirection -> {v,tieV,slurV}erticalDirection'))
239 str = re
.sub ('hshift','horizontalNoteShift', str)
243 conversions
.append (((1,0,21), conv
,
244 'hshift -> horizontalNoteShift'))
249 str = re
.sub ('\\\\grouping[^;]*;','', str)
253 conversions
.append (((1,1,52), conv
,
254 'deprecate \\grouping'))
259 str = re
.sub ('\\\\wheel','\\\\coda', str)
263 conversions
.append (((1,1,55), conv
,
264 '\\wheel -> \\coda'))
268 str = re
.sub ('keyoctaviation','keyOctaviation', str)
269 str = re
.sub ('slurdash','slurDash', str)
273 conversions
.append (((1,1,65), conv
,
274 'slurdash -> slurDash, keyoctaviation -> keyOctaviation'))
278 str = re
.sub ('\\\\repeat *\"?semi\"?','\\\\repeat "volta"', str)
282 conversions
.append (((1,1,66), conv
,
288 str = re
.sub ('\"?beamAuto\"? *= *\"?0?\"?','noAutoBeaming = "1"', str)
292 conversions
.append (((1,1,67), conv
,
293 'beamAuto -> noAutoBeaming'))
297 str = re
.sub ('automaticMelismas', 'automaticMelismata', str)
301 conversions
.append (((1,2,0), conv
,
302 'automaticMelismas -> automaticMelismata'))
306 str = re
.sub ('dynamicDir\\b', 'dynamicDirection', str)
310 conversions
.append (((1,2,1), conv
,
311 'dynamicDir -> dynamicDirection'))
315 str = re
.sub ('\\\\cadenza *0 *;', '\\\\cadenzaOff', str)
316 str = re
.sub ('\\\\cadenza *1 *;', '\\\\cadenzaOn', str)
320 conversions
.append (((1,3,4), conv
,
321 '\\cadenza -> \\cadenza{On|Off}'))
325 str = re
.sub ('"?beamAuto([^"=]+)"? *= *"([0-9]+)/([0-9]+)" *;*',
326 'beamAuto\\1 = #(make-moment \\2 \\3)',
330 conversions
.append (((1,3,5), conv
, 'beamAuto moment properties'))
334 str = re
.sub ('stemStyle',
339 conversions
.append (((1,3,17), conv
, 'stemStyle -> flagStyle'))
343 str = re
.sub ('staffLineLeading',
348 conversions
.append (((1,3,18), conv
, 'staffLineLeading -> staffSpace'))
353 if re
.search ('\\\\repetitions',str):
354 error_file
.write ('\n')
355 error_file
.write (NOT_SMART
% "\\repetitions")
356 error_file
.write ('\n')
357 # raise FatalConversionError ()
360 conversions
.append (((1,3,23), conv
,
361 '\\\\repetitions feature dropped'))
366 str = re
.sub ('textEmptyDimension *= *##t',
367 'textNonEmpty = ##f',
369 str = re
.sub ('textEmptyDimension *= *##f',
370 'textNonEmpty = ##t',
374 conversions
.append (((1,3,35), conv
, 'textEmptyDimension -> textNonEmpty'))
378 str = re
.sub ("([a-z]+)[ \t]*=[ \t]*\\\\musicalpitch *{([- 0-9]+)} *\n",
379 "(\\1 . (\\2))\n", str)
380 str = re
.sub ("\\\\musicalpitch *{([0-9 -]+)}",
381 "\\\\musicalpitch #'(\\1)", str)
382 if re
.search ('\\\\notenames',str):
383 error_file
.write ('\n')
384 error_file
.write (NOT_SMART
% "new \\notenames format")
385 error_file
.write ('\n')
388 conversions
.append (((1,3,38), conv
, '\musicalpitch { a b c } -> #\'(a b c)'))
393 return '\\key %s;' % string
.lower (match
.group (1))
395 str = re
.sub ("\\\\key ([^;]+);", replace
, str)
398 conversions
.append (((1,3,39), conv
, '\\key A ; ->\\key a;'))
402 if re
.search ('\\[:',str):
403 error_file
.write ('\n')
404 error_file
.write (NOT_SMART
% "new tremolo format")
405 error_file
.write ('\n')
408 conversions
.append (((1,3,41), conv
,
409 '[:16 c4 d4 ] -> \\repeat "tremolo" 2 { c16 d16 }'))
413 str = re
.sub ('Staff_margin_engraver' , 'Instrument_name_engraver', str)
416 conversions
.append (((1,3,42), conv
,
417 'Staff_margin_engraver deprecated, use Instrument_name_engraver'))
421 str = re
.sub ('note[hH]eadStyle\\s*=\\s*"?(\\w+)"?' , "noteHeadStyle = #'\\1", str)
424 conversions
.append (((1,3,49), conv
,
425 'noteHeadStyle value: string -> symbol'))
429 if re
.search ('\\\\keysignature', str):
430 error_file
.write ('\n')
431 error_file
.write (NOT_SMART
% "new tremolo format")
432 error_file
.write ('\n')
436 conversions
.append (((1,3,58), conv
,
437 'noteHeadStyle value: string -> symbol'))
441 str = re
.sub (r
"""\\key *([a-z]+) *;""", r
"""\\key \1 \major;""",str);
443 conversions
.append (((1,3,59), conv
,
444 '\key X ; -> \key X major; '))
448 str = re
.sub (r
'latexheaders *= *"\\\\input ',
452 conversions
.append (((1,3,68), conv
, 'latexheaders = "\\input global" -> latexheaders = "global"'))
457 # TODO: lots of other syntax change should be done here as well
460 str = re
.sub ('basicCollisionProperties', 'NoteCollision', str)
461 str = re
.sub ('basicVoltaSpannerProperties' , "VoltaBracket", str)
462 str = re
.sub ('basicKeyProperties' , "KeySignature", str)
464 str = re
.sub ('basicClefItemProperties' ,"Clef", str)
467 str = re
.sub ('basicLocalKeyProperties' ,"Accidentals", str)
468 str = re
.sub ('basicMarkProperties' ,"Accidentals", str)
469 str = re
.sub ('basic([A-Za-z_]+)Properties', '\\1', str)
471 str = re
.sub ('Repeat_engraver' ,'Volta_engraver', str)
474 conversions
.append (((1,3,92), conv
, 'basicXXXProperties -> XXX, Repeat_engraver -> Volta_engraver'))
478 # Ugh, but meaning of \stemup changed too
479 # maybe we should do \stemup -> \stemUp\slurUp\tieUp ?
480 str = re
.sub ('\\\\stemup', '\\\\stemUp', str)
481 str = re
.sub ('\\\\stemdown', '\\\\stemDown', str)
482 str = re
.sub ('\\\\stemboth', '\\\\stemBoth', str)
484 str = re
.sub ('\\\\slurup', '\\\\slurUp', str)
485 str = re
.sub ('\\\\slurboth', '\\\\slurBoth', str)
486 str = re
.sub ('\\\\slurdown', '\\\\slurDown', str)
487 str = re
.sub ('\\\\slurdotted', '\\\\slurDotted', str)
488 str = re
.sub ('\\\\slurnormal', '\\\\slurNoDots', str)
490 str = re
.sub ('\\\\shiftoff', '\\\\shiftOff', str)
491 str = re
.sub ('\\\\shifton', '\\\\shiftOn', str)
492 str = re
.sub ('\\\\shiftonn', '\\\\shiftOnn', str)
493 str = re
.sub ('\\\\shiftonnn', '\\\\shiftOnnn', str)
495 str = re
.sub ('\\\\onevoice', '\\\\oneVoice', str)
496 str = re
.sub ('\\\\voiceone', '\\\\voiceOne', str)
497 str = re
.sub ('\\\\voicetwo', '\\\\voiceTwo', str)
498 str = re
.sub ('\\\\voicethree', '\\\\voiceThree', str)
499 str = re
.sub ('\\\\voicefour', '\\\\voiceFour', str)
501 # I don't know exactly when these happened...
502 # ugh, we loose context setting here...
503 str = re
.sub ('\\\\property *[^ ]*verticalDirection[^=]*= *#?"?(1|(\\\\up))"?', '\\\\stemUp\\\\slurUp\\\\tieUp', str)
504 str = re
.sub ('\\\\property *[^ ]*verticalDirection[^=]*= *#?"?((-1)|(\\\\down))"?', '\\\\stemDown\\\\slurDown\\\\tieDown', str)
505 str = re
.sub ('\\\\property *[^ ]*verticalDirection[^=]*= *#?"?(0|(\\\\center))"?', '\\\\stemBoth\\\\slurBoth\\\\tieBoth', str)
507 str = re
.sub ('verticalDirection[^=]*= *#?"?(1|(\\\\up))"?', 'Stem \\\\override #\'direction = #0\nSlur \\\\override #\'direction = #0\n Tie \\\\override #\'direction = #1', str)
508 str = re
.sub ('verticalDirection[^=]*= *#?"?((-1)|(\\\\down))"?', 'Stem \\\\override #\'direction = #0\nSlur \\\\override #\'direction = #0\n Tie \\\\override #\'direction = #-1', str)
509 str = re
.sub ('verticalDirection[^=]*= *#?"?(0|(\\\\center))"?', 'Stem \\\\override #\'direction = #0\nSlur \\\\override #\'direction = #0\n Tie \\\\override #\'direction = #0', str)
511 str = re
.sub ('\\\\property *[^ .]*[.]?([a-z]+)VerticalDirection[^=]*= *#?"?(1|(\\\\up))"?', '\\\\\\1Up', str)
512 str = re
.sub ('\\\\property *[^ .]*[.]?([a-z]+)VerticalDirection[^=]*= *#?"?((-1)|(\\\\down))"?', '\\\\\\1Down', str)
513 str = re
.sub ('\\\\property *[^ .]*[.]?([a-z]+)VerticalDirection[^=]*= *#?"?(0|(\\\\center))"?', '\\\\\\1Both', str)
515 # (lacks capitalisation slur -> Slur)
516 str = re
.sub ('([a-z]+)VerticalDirection[^=]*= *#?"?(1|(\\\\up))"?', '\\1 \\\\override #\'direction = #1', str)
517 str = re
.sub ('([a-z]+)VerticalDirection[^=]*= *#?"?((-1)|(\\\\down))"?', '\\1 \\override #\'direction = #-1', str)
518 str = re
.sub ('([a-z]+)VerticalDirection[^=]*= *#?"?(0|(\\\\center))"?', '\\1 \\\\override #\'direction = #0', str)
521 str = re
.sub ('\\\\property *[^ .]*[.]?dynamicDirection[^=]*= *#?"?(1|(\\\\up))"?', '\\\\dynamicUp', str)
522 str = re
.sub ('\\\\property *[^ .]*[.]?dyn[^=]*= *#?"?((-1)|(\\\\down))"?', '\\\\dynamicDown', str)
523 str = re
.sub ('\\\\property *[^ .]*[.]?dyn[^=]*= *#?"?(0|(\\\\center))"?', '\\\\dynamicBoth', str)
525 str = re
.sub ('\\\\property *[^ .]*[.]?([a-z]+)Dash[^=]*= *#?"?(0|(""))"?', '\\\\\\1NoDots', str)
526 str = re
.sub ('\\\\property *[^ .]*[.]?([a-z]+)Dash[^=]*= *#?"?([1-9]+)"?', '\\\\\\1Dotted', str)
528 str = re
.sub ('\\\\property *[^ .]*[.]?noAutoBeaming[^=]*= *#?"?(0|(""))"?', '\\\\autoBeamOn', str)
529 str = re
.sub ('\\\\property *[^ .]*[.]?noAutoBeaming[^=]*= *#?"?([1-9]+)"?', '\\\\autoBeamOff', str)
535 conversions
.append (((1,3,93), conv
,
536 'property definiton case (eg. onevoice -> oneVoice)'))
541 str = re
.sub ('ChordNames*', 'ChordNames', str)
542 if re
.search ('\\\\textscript "[^"]* *"[^"]*"', str):
543 error_file
.write ('\n')
544 error_file
.write (NOT_SMART
% "new \\textscript markup text")
545 error_file
.write ('\n')
547 str = re
.sub ('\\textscript +("[^"]*")', '\\textscript #\\1', str)
551 conversions
.append (((1,3,97), conv
, 'ChordName -> ChordNames'))
554 # TODO: add lots of these
558 str = re
.sub ('\\\\property *"?Voice"? *[.] *"?textStyle"? *= *"([^"]*)"', '\\\\property Voice.TextScript \\\\set #\'font-style = #\'\\1', str)
559 str = re
.sub ('\\\\property *"?Lyrics"? *[.] *"?textStyle"? *= *"([^"]*)"', '\\\\property Lyrics.LyricText \\\\set #\'font-style = #\'\\1', str)
561 str = re
.sub ('\\\\property *"?([^.]+)"? *[.] *"?timeSignatureStyle"? *= *"([^"]*)"', '\\\\property \\1.TimeSignature \\\\override #\'style = #\'\\2', str)
563 str = re
.sub ('"?timeSignatureStyle"? *= *#?""', 'TimeSignature \\\\override #\'style = ##f', str)
565 str = re
.sub ('"?timeSignatureStyle"? *= *#?"([^"]*)"', 'TimeSignature \\\\override #\'style = #\'\\1', str)
567 str = re
.sub ('#\'style *= #*"([^"])"', '#\'style = #\'\\1', str)
569 str = re
.sub ('\\\\property *"?([^.]+)"? *[.] *"?horizontalNoteShift"? *= *"?#?([-0-9]+)"?', '\\\\property \\1.NoteColumn \\\\override #\'horizontal-shift = #\\2', str)
572 str = re
.sub ('\\\\property *"?([^.]+)"? *[.] *"?flagStyle"? *= *""', '\\\\property \\1.Stem \\\\override #\'flag-style = ##f', str)
574 str = re
.sub ('\\\\property *"?([^.]+)"? *[.] *"?flagStyle"? *= *"([^"]*)"', '\\\\property \\1.Stem \\\\override #\'flag-style = #\'\\2', str)
577 conversions
.append (((1,3,98), conv
, 'CONTEXT.textStyle -> GROB.#font-style '))
581 str = re
.sub ('"?beamAutoEnd_([0-9]*)"? *= *(#\\([^)]*\\))', 'autoBeamSettings \\push #\'(end 1 \\1 * *) = \\2', str)
582 str = re
.sub ('"?beamAutoBegin_([0-9]*)"? *= *(#\\([^)]*\))', 'autoBeamSettings \\push #\'(begin 1 \\1 * *) = \\2', str)
583 str = re
.sub ('"?beamAutoEnd"? *= *(#\\([^)]*\\))', 'autoBeamSettings \\push #\'(end * * * *) = \\1', str)
584 str = re
.sub ('"?beamAutoBegin"? *= *(#\\([^)]*\\))', 'autoBeamSettings \\push #\'(begin * * * *) = \\1', str)
589 conversions
.append (((1,3,102), conv
, 'beamAutoEnd -> autoBeamSettings \\push (end * * * *)'))
594 str = re
.sub ('\\\\push', '\\\\override', str)
595 str = re
.sub ('\\\\pop', '\\\\revert', str)
599 conversions
.append (((1,3,111), conv
, '\\push -> \\override, \\pop -> \\revert'))
603 str = re
.sub ('LyricVoice', 'LyricsVoice', str)
605 str = re
.sub ('Chord[Nn]ames*.Chord[Nn]ames*', 'ChordNames.ChordName', str)
606 str = re
.sub ('Chord[Nn]ames([ \t\n]+\\\\override)', 'ChordName\\1', str)
609 conversions
.append (((1,3,113), conv
, 'LyricVoice -> LyricsVoice'))
612 def regularize_id (str):
619 elif x
in string
.digits
:
620 x
= chr(ord (x
) - ord ('0') +ord ('A'))
621 elif x
not in string
.letters
:
623 elif x
in string
.lowercase
and lastx
== '_':
629 def regularize_dollar_reference (match
):
630 return regularize_id (match
.group (1))
631 def regularize_assignment (match
):
632 return '\n' + regularize_id (match
.group (1)) + ' = '
633 str = re
.sub ('\$([^\t\n ]+)', regularize_dollar_reference
, str)
634 str = re
.sub ('\n([^ \t\n]+)[ \t]*= *', regularize_assignment
, str)
637 conversions
.append (((1,3,117), conv
, 'identifier names: $!foo_bar_123 -> xfooBarABC'))
642 def regularize_paper (match
):
643 return regularize_id (match
.group (1))
645 str = re
.sub ('(paper_[a-z]+)', regularize_paper
, str)
646 str = re
.sub ('sustainup', 'sustainUp', str)
647 str = re
.sub ('nobreak', 'noBreak', str)
648 str = re
.sub ('sustaindown', 'sustainDown', str)
649 str = re
.sub ('sostenutoup', 'sostenutoUp', str)
650 str = re
.sub ('sostenutodown', 'sostenutoDown', str)
651 str = re
.sub ('unachorda', 'unaChorda', str)
652 str = re
.sub ('trechorde', 'treChorde', str)
656 conversions
.append (((1,3,120), conv
, 'paper_xxx -> paperXxxx, pedalup -> pedalUp.'))
660 str = re
.sub ('drarnChords', 'chordChanges', str)
661 str = re
.sub ('\\musicalpitch', '\\pitch', str)
664 conversions
.append (((1,3,122), conv
, 'drarnChords -> chordChanges, \\musicalpitch -> \\pitch'))
668 str = re
.sub ('ly-([sg])et-elt-property', 'ly-\\1et-grob-property', str)
671 conversions
.append (((1,3,136), conv
, 'ly-X-elt-property -> ly-X-grob-property'))
675 str = re
.sub ('point-and-click +#t', 'point-and-click line-column-location', str)
678 conversions
.append (((1,3,138), conv
, 'point-and-click argument changed to procedure.'))
682 str = re
.sub ('followThread', 'followVoice', str)
683 str = re
.sub ('Thread.FollowThread', 'Voice.VoiceFollower', str)
684 str = re
.sub ('FollowThread', 'VoiceFollower', str)
687 conversions
.append (((1,3,138), conv
, 'followThread -> followVoice.'))
691 str = re
.sub ('font-point-size', 'font-design-size', str)
694 conversions
.append (((1,3,139), conv
, 'font-point-size -> font-design-size.'))
698 str = re
.sub ('([a-zA-Z]*)NoDots', '\\1Solid', str)
701 conversions
.append (((1,3,141), conv
, 'xNoDots -> xSolid'))
705 str = re
.sub ('([Cc])hord([ea])', '\\1ord\\2', str)
708 conversions
.append (((1,3,144), conv
, 'Chorda -> Corda'))
713 str = re
.sub ('([A-Za-z]+)MinimumVerticalExtent', 'MinimumV@rticalExtent', str)
714 str = re
.sub ('([A-Za-z]+)ExtraVerticalExtent', 'ExtraV@rticalExtent', str)
715 str = re
.sub ('([A-Za-z]+)VerticalExtent', 'VerticalExtent', str)
716 str = re
.sub ('ExtraV@rticalExtent', 'ExtraVerticalExtent', str)
717 str = re
.sub ('MinimumV@rticalExtent', 'MinimumVerticalExtent', str)
720 conversions
.append (((1,3,145), conv
,
721 'ContextNameXxxxVerticalExtent -> XxxxVerticalExtent'))
725 str = re
.sub ('\\\\key[ \t]*;', '\\key \\default;', str)
726 str = re
.sub ('\\\\mark[ \t]*;', '\\mark \\default;', str)
728 # Make sure groups of more than one ; have space before
729 # them, so that non of them gets removed by next rule
730 str = re
.sub ("([^ \n\t;]);(;+)", "\\1 ;\\2", str)
732 # Only remove ; that are not after spaces, # or ;
733 # Otherwise we interfere with Scheme comments,
734 # which is badbadbad.
735 str = re
.sub ("([^ \t;#]);", "\\1", str)
738 conversions
.append (((1,3,146), conv
, 'semicolons removed'))
742 str = re
.sub ('default-neutral-direction', 'neutral-direction',str)
744 conversions
.append (((1,3,147), conv
, 'default-neutral-direction -> neutral-direction'))
748 str = re
.sub ('\(align', '(axis', str)
749 str = re
.sub ('\(rows', '(columns', str)
751 conversions
.append (((1,3,148), conv
, '"(align" -> "(axis", "(rows" -> "(columns"'))
756 str = re
.sub ('SystemStartDelimiter', 'systemStartDelimiter', str)
758 conversions
.append (((1,5,33), conv
, 'SystemStartDelimiter -> systemStartDelimiter'))
762 str = re
.sub ('arithmetic-multiplier', 'spacing-increment', str)
763 str = re
.sub ('arithmetic-basicspace', 'shortest-duration-space', str)
766 conversions
.append (((1,5,38), conv
, 'SystemStartDelimiter -> systemStartDelimiter'))
774 "Instrument_name": "instrument-name",
775 "Left_edge_item": "left-edge",
776 "Span_bar": "span-bar",
777 "Breathing_sign": "breathing-sign",
778 "Staff_bar": "staff-bar",
780 "Key_item": "key-signature",
781 "Time_signature": "time-signature",
784 props
= match
.group (1)
785 for (k
,v
) in break_dict
.items():
786 props
= re
.sub (k
, v
, props
)
787 return "breakAlignOrder = #'(%s)" % props
789 str = re
.sub ("breakAlignOrder *= *#'\\(([a-z_\n\tA-Z ]+)\\)",
794 conversions
.append (((1,5,40), conv
, 'breakAlignOrder property names'))
799 str = re
.sub ('noAutoBeaming *= *##f', 'autoBeaming = ##t', str)
800 str = re
.sub ('noAutoBeaming *= *##t', 'autoBeaming = ##f', str)
803 conversions
.append (((1,5,49), conv
, 'noAutoBeaming -> autoBeaming'))
807 str = re
.sub ('tuplet-bracket-visibility', 'bracket-visibility', str)
808 str = re
.sub ('tuplet-number-visibility', 'number-visibility', str)
811 conversions
.append (((1,5,52), conv
, 'tuplet-X-visibility -> X-visibility'))
815 str = re
.sub ('Pitch::transpose', 'ly-transpose-pitch', str)
819 conversions
.append (((1,5,56), conv
, 'Pitch::transpose -> ly-transpose-pitch'))
823 str = re
.sub ('textNonEmpty *= *##t', "TextScript \\set #'no-spacing-rods = ##f", str)
824 str = re
.sub ('textNonEmpty *= *##f', "TextScript \\set #'no-spacing-rods = ##t", str)
827 conversions
.append (((1,5,58), conv
, 'deprecate textNonEmpty'))
832 str = re
.sub ('MinimumVerticalExtent', 'minimumV@rticalExtent', str)
833 str = re
.sub ('minimumVerticalExtent', 'minimumV@rticalExtent', str)
834 str = re
.sub ('ExtraVerticalExtent', 'extraV@rticalExtent', str)
835 str = re
.sub ('extraVerticalExtent', 'extraV@rticalExtent', str)
836 str = re
.sub ('VerticalExtent', 'verticalExtent', str)
837 str = re
.sub ('extraV@rticalExtent', 'extraVerticalExtent', str)
838 str = re
.sub ('minimumV@rticalExtent', 'minimumVerticalExtent', str)
841 conversions
.append (((1,5,59), conv
,
842 'XxxxVerticalExtent -> xxxVerticalExtent'))
846 str = re
.sub ('visibility-lambda', 'break-visibility', str)
849 conversions
.append (((1,5,62), conv
,
850 'visibility-lambda -> break-visibility'))
855 if re
.search (r
'\addlyrics',str) \
856 and re
.search ('automaticMelismata', str) == None:
857 error_file
.write ('\n')
858 error_file
.write (NOT_SMART
% "automaticMelismata; turned on by default since 1.5.67.")
859 error_file
.write ('\n')
860 raise FatalConversionError ()
863 conversions
.append (((1,5,67), conv
,
864 'automaticMelismata turned on by default'))
868 str = re
.sub ('ly-set-grob-property([^!])', 'ly-set-grob-property!\1', str)
869 str = re
.sub ('ly-set-mus-property([^!])', 'ly-set-mus-property!\1', str)
872 conversions
.append (((1,5,68), conv
, 'ly-set-X-property -> ly-set-X-property!'))
876 str = re
.sub ('extent-X', 'X-extent', str)
877 str = re
.sub ('extent-Y', 'Y-extent', str)
880 conversions
.append (((1,5,71), conv
, 'extent-[XY] -> [XY]-extent'))
885 str = re
.sub ("""#\(set! +point-and-click +line-column-location\)""",
886 """#(set-point-and-click! \'line-column)""", str)
887 str = re
.sub ("""#\(set![ \t]+point-and-click +line-location\)""",
888 '#(set-point-and-click! \'line)', str)
889 str = re
.sub ('#\(set! +point-and-click +#f\)',
890 '#(set-point-and-click! \'none)', str)
893 conversions
.append (((1,5,72), conv
, 'set! point-and-click -> set-point-and-click!'))
898 str = re
.sub ('flag-style', 'stroke-style', str)
899 str = re
.sub (r
"""Stem([ ]+)\\override #'style""", r
"""Stem \\override #'flag-style""", str);
900 str = re
.sub (r
"""Stem([ ]+)\\set([ ]+)#'style""", r
"""Stem \\set #'flag-style""", str);
903 conversions
.append (((1,6,5), conv
, 'Stems: flag-style -> stroke-style; style -> flag-style'))
907 def subst_req_name (match
):
908 return "(make-music-by-name \'%sEvent)" % regularize_id (match
.group(1))
911 str = re
.sub ('\\(ly-make-music *\"([A-Z][a-z_]+)_req\"\\)', subst_req_name
, str)
912 str = re
.sub ('Request_chord', 'EventChord', str)
915 conversions
.append (((1,7,1), conv
, 'ly-make-music foo_bar_req -> make-music-by-name FooBarEvent'))
920 "text" : 'TextSpanEvent',
921 "decrescendo" : 'DecrescendoEvent',
922 "crescendo" : 'CrescendoEvent',
923 "Sustain" : 'SustainPedalEvent',
924 "slur" : 'SlurEvent',
925 "UnaCorda" : 'UnaCordaEvent',
926 "Sostenuto" : 'SostenutoEvent',
928 def subst_ev_name (match
):
930 if re
.search ('start', match
.group(1)):
933 mtype
= spanner_subst
[match
.group(2)]
934 return "(make-span-event '%s %s)" % (mtype
, stype
)
936 def subst_definition_ev_name(match
):
937 return ' = #%s' % subst_ev_name (match
)
938 def subst_inline_ev_name (match
):
939 s
= subst_ev_name (match
)
940 return '#(ly-export %s)' % s
941 def subst_csp_definition (match
):
942 return ' = #(make-event-chord (list %s))' % subst_ev_name (match
)
943 def subst_csp_inline (match
):
944 return '#(ly-export (make-event-chord (list %s)))' % subst_ev_name (match
)
947 str = re
.sub (r
' *= *\\spanrequest *([^ ]+) *"([^"]+)"', subst_definition_ev_name
, str)
948 str = re
.sub (r
'\\spanrequest *([^ ]+) *"([^"]+)"', subst_inline_ev_name
, str)
949 str = re
.sub (r
' *= *\\commandspanrequest *([^ ]+) *"([^"]+)"', subst_csp_definition
, str)
950 str = re
.sub (r
'\\commandspanrequest *([^ ]+) *"([^"]+)"', subst_csp_inline
, str)
951 str = re
.sub (r
'ly-id ', 'ly-import ', str)
953 str = re
.sub (r
' *= *\\script "([^"]+)"', ' = #(make-articulation "\\1")', str)
954 str = re
.sub (r
'\\script "([^"]+)"', '#(ly-export (make-articulation "\\1"))', str)
957 conversions
.append (((1,7,2), conv
, '\\spanrequest -> #(make-span-event .. ), \script -> #(make-articulation .. )'))
961 str = re
.sub (r
'\(ly-', '(ly:', str)
971 'music-duration-length',
976 'transpose-key-alist',
980 'set-point-and-click!',
989 'music-duration-compress',
990 'set-point-and-click!'
993 origre
= r
'\b(%s)' % string
.join (changed
, '|')
995 str = re
.sub (origre
, r
'ly:\1',str)
996 str = re
.sub ('set-point-and-click!', 'set-point-and-click', str)
1000 conversions
.append (((1,7,3), conv
, 'ly- -> ly:'))
1004 if re
.search ('new-chords-done',str):
1007 str = re
.sub (r
'<<', '< <', str)
1008 str = re
.sub (r
'>>', '> >', str)
1011 conversions
.append (((1,7,4), conv
, '<< >> -> < < > >'))
1015 str = re
.sub (r
"\\transpose", r
"\\transpose c'", str)
1016 str = re
.sub (r
"\\transpose c' *([a-z]+)'", r
"\\transpose c \1", str)
1018 conversions
.append (((1,7,5), conv
, '\\transpose TO -> \\transpose FROM TO'))
1036 origstr
= string
.join (kws
, '|')
1037 str = re
.sub (r
'([^_^-])\\(%s)\b' % origstr
, r
'\1-\\\2', str)
1039 conversions
.append (((1,7,6), conv
, 'note\\script -> note-\script'))
1044 str = re
.sub (r
"\\property *ChordNames *\. *ChordName *\\(set|override) *#'style *= *#('[a-z]+)",
1045 r
"#(set-chord-name-style \2)", str)
1046 str = re
.sub (r
"\\property *ChordNames *\. *ChordName *\\revert *#'style",
1049 conversions
.append (((1,7,10), conv
, "\property ChordName #'style -> #(set-chord-name-style 'style)"))
1055 str = re
.sub (r
"ly:transpose-pitch", "ly:pitch-transpose", str)
1058 conversions
.append (((1,7,11), conv
, "transpose-pitch -> pitch-transpose"))
1062 str = re
.sub (r
"ly:get-molecule-extent", "ly:molecule-get-extent", str)
1063 str = re
.sub (r
"ly:set-molecule-extent!", "ly:molecule-set-extent!", str)
1064 str = re
.sub (r
"ly:add-molecule", "ly:molecule-add", str)
1065 str = re
.sub (r
"ly:combine-molecule-at-edge", "ly:molecule-combine-at-edge", str)
1066 str = re
.sub (r
"ly:align-to!", "ly:molecule-align-to!", str)
1070 conversions
.append (((1,7,13), conv
, "ly:XX-molecule-YY -> ly:molecule-XX-YY"))
1074 str = re
.sub (r
"linewidth *= *-[0-9.]+ *(\\mm|\\cm|\\in|\\pt)?", 'raggedright = ##t', str )
1077 conversions
.append (((1,7,15), conv
, "linewidth = -1 -> raggedright = ##t"))
1081 str = re
.sub ("divisiomaior",
1082 "divisioMaior", str)
1083 str = re
.sub ("divisiominima",
1084 "divisioMinima", str)
1085 str = re
.sub ("divisiomaxima",
1086 "divisioMaxima", str)
1089 conversions
.append (((1,7,16), conv
, "divisiomaior -> divisioMaior"))
1093 str = re
.sub ("Skip_req_swallow_translator",
1094 "Skip_event_swallow_translator", str)
1097 conversions
.append (((1,7,17), conv
, "Skip_req -> Skip_event"))
1101 str = re
.sub ("groupOpen",
1103 str = re
.sub ("groupClose",
1105 str = re
.sub ("#'outer",
1106 "#'enclose-bounds", str)
1110 conversions
.append (((1,7,18), conv
,
1111 """groupOpen/Close -> start/stopGroup,
1112 #'outer -> #'enclose-bounds
1117 if re
.search( r
'\\GraceContext', str):
1118 error_file
.write ('\n')
1119 error_file
.write (NOT_SMART
% "GraceContext")
1120 error_file
.write (FROM_TO \
1121 % ("GraceContext", "#(add-to-grace-init .. )"))
1122 error_file
.write ('\n')
1123 error_file
.write (UPDATE_MANUALLY
)
1124 error_file
.write ('\n')
1125 raise FatalConversionError ()
1127 str = re
.sub ('HaraKiriStaffContext', 'RemoveEmptyStaffContext', str)
1130 conversions
.append (((1,7,19), conv
,"remove GraceContext"))
1137 r
"(set|override|revert) *#'type",
1142 conversions
.append (((1,7,22), conv
,"#'type -> #'style"))
1147 "barNonAuto *= *##t",
1148 "automaticBars = ##f",
1151 "barNonAuto *= *##f",
1152 "automaticBars = ##t",
1156 conversions
.append (((1,7,23), conv
,"barNonAuto -> automaticBars"))
1161 if re
.search( r
'-(start|stop)Cluster', str):
1162 error_file
.write ('\n')
1163 error_file
.write (NOT_SMART
% "Cluster syntax")
1164 error_file
.write ('\n')
1165 error_file
.write (UPDATE_MANUALLY
)
1166 error_file
.write ('\n')
1168 raise FatalConversionError ()
1172 conversions
.append (((1,7,24), conv
,"cluster syntax"))
1176 str = re
.sub (r
"\\property *Staff\.(Sustain|Sostenuto|UnaCorda)Pedal *\\(override|set) *#'pedal-type *",
1177 r
"\property Staff.pedal\1Style ", str)
1178 str = re
.sub (r
"\\property *Staff\.(Sustain|Sostenuto|UnaCorda)Pedal *\\revert *#'pedal-type", '', str)
1181 conversions
.append (((1,7,28), conv
,"new Pedal style syntax"))
1190 origstr
= '<%s>' % str
1191 if re
.search (r
'\\\\', str):
1194 if re
.search (r
'\\property', str):
1197 if re
.match (r
'^\s*\)?\s*\\[a-zA-Z]+', str):
1201 def sub_durs (m
, durs
= durs
):
1202 durs
.append(m
.group(2))
1205 str = re
.sub (r
"([a-z]+[,'!? ]*)([0-9]+\.*)", sub_durs
, str)
1212 return '<%s>' % m
.group (1)
1219 while last_str
<> str:
1222 def sub_tremolos (m
, slur_strs
= slur_strs
):
1224 if tr
not in slur_strs
:
1225 slur_strs
.append (tr
)
1228 str = re
.sub (r
"([a-z]+[',!? ]*)(:[0-9]+)",
1231 def sub_dyn_end (m
, dyns
= dyns
):
1233 return ' ' + m
.group(2)
1235 str = re
.sub (r
'(\\!)\s*([a-z]+)', sub_dyn_end
, str)
1236 def sub_slurs(m
, slur_strs
= slur_strs
):
1237 if '-)' not in slur_strs
:
1238 slur_strs
.append (')')
1241 def sub_p_slurs(m
, slur_strs
= slur_strs
):
1242 if '-\)' not in slur_strs
:
1243 slur_strs
.append ('\)')
1246 str = re
.sub (r
"\)[ ]*([a-z]+)", sub_slurs
, str)
1247 str = re
.sub (r
"\\\)[ ]*([a-z]+)", sub_p_slurs
, str)
1248 def sub_begin_slurs(m
, slur_strs
= slur_strs
):
1249 if '-(' not in slur_strs
:
1250 slur_strs
.append ('(')
1253 str = re
.sub (r
"([a-z]+[,'!?0-9 ]*)\(",
1254 sub_begin_slurs
, str)
1255 def sub_begin_p_slurs(m
, slur_strs
= slur_strs
):
1256 if '-\(' not in slur_strs
:
1257 slur_strs
.append ('\(')
1260 str = re
.sub (r
"([a-z]+[,'!?0-9 ]*)\\\(",
1261 sub_begin_p_slurs
, str)
1263 def sub_dyns (m
, slur_strs
= slur_strs
):
1265 if s
== '@STARTCRESC@':
1266 slur_strs
.append ("\\<")
1267 elif s
== '@STARTDECRESC@':
1268 slur_strs
.append ("\\>")
1270 slur_strs
.append ('\\!')
1273 str = re
.sub (r
'@STARTCRESC@', sub_dyns
, str)
1274 str = re
.sub (r
'-?\\!', sub_dyns
, str)
1276 def sub_articulations (m
, slur_strs
= slur_strs
):
1278 if a
not in slur_strs
:
1279 slur_strs
.append (a
)
1282 str = re
.sub (r
"([_^-]\@ACCENT\@)", sub_articulations
,
1284 str = re
.sub (r
"([_^-]\\[a-z]+)", sub_articulations
,
1286 str = re
.sub (r
"([_^-][>_.+|^-])", sub_articulations
,
1288 str = re
.sub (r
'([_^-]"[^"]+")', sub_articulations
,
1291 def sub_pslurs(m
, slur_strs
= slur_strs
):
1292 slur_strs
.append (' \\)')
1294 str = re
.sub (r
"\\\)[ ]*([a-z]+)", sub_pslurs
, str)
1298 suffix
= string
.join (slur_strs
, '') + string
.join (pslur_strs
,
1300 + string
.join (dyns
, '')
1302 return '@STARTCHORD@%s@ENDCHORD@%s%s' % (str , dur_str
, suffix
)
1306 def sub_chords (str):
1311 marker_str
= '%% new-chords-done %%'
1313 if re
.search (marker_str
,str):
1315 str = re
.sub ('<<', '@STARTCHORD@', str)
1316 str = re
.sub ('>>', '@ENDCHORD@', str)
1318 str = re
.sub (r
'\\<', '@STARTCRESC@', str)
1319 str = re
.sub (r
'\\>', '@STARTDECRESC@', str)
1320 str = re
.sub (r
'([_^-])>', r
'\1@ACCENT@', str)
1321 str = re
.sub (r
'<([^<>{}]+)>', sub_chord
, str)
1323 # add dash: -[, so that [<<a b>> c d] becomes
1325 # and gets skipped by articulation_substitute
1326 str = re
.sub (r
'\[ *(@STARTCHORD@[^@]+@ENDCHORD@[0-9.]*)',
1328 str = re
.sub (r
'\\! *(@STARTCHORD@[^@]+@ENDCHORD@[0-9.]*)',
1331 str = re
.sub (r
'<([^?])', r
'%s\1' % simstart
, str)
1332 str = re
.sub (r
'>([^?])', r
'%s\1' % simend
, str)
1333 str = re
.sub ('@STARTCRESC@', r
'\\<', str)
1334 str = re
.sub ('@STARTDECRESC@', r
'\\>' ,str)
1335 str = re
.sub (r
'\\context *Voice *@STARTCHORD@',
1336 '@STARTCHORD@', str)
1337 str = re
.sub ('@STARTCHORD@', chordstart
, str)
1338 str = re
.sub ('@ENDCHORD@', chordend
, str)
1339 str = re
.sub (r
'@ACCENT@', '>', str)
1342 markup_start
= re
.compile(r
"([-^_]|\\mark)\s*(#\s*'\s*)\(")
1343 musicglyph
= re
.compile(r
"\(\s*music\b")
1344 columns
= re
.compile(r
"\(\s*columns\b")
1345 submarkup_start
= re
.compile(r
"\(\s*([a-zA-Z]+)")
1346 leftpar
= re
.compile(r
"\(")
1347 rightpar
= re
.compile(r
"\)")
1349 def text_markup (str):
1351 # Find the beginning of each markup:
1352 match
= markup_start
.search (str)
1354 result
= result
+ str[:match
.end (1)] + " \markup"
1355 str = str[match
.end( 2):]
1356 # Count matching parentheses to find the end of the
1359 pars
= re
.finditer(r
"[()]",str)
1361 if par
.group () == '(':
1362 nesting_level
= nesting_level
+ 1
1364 nesting_level
= nesting_level
- 1
1365 if nesting_level
== 0:
1366 markup_end
= par
.end ()
1368 # The full markup in old syntax:
1369 markup
= str[:markup_end
]
1370 # Modify to new syntax:
1371 markup
= musicglyph
.sub (r
"{\\musicglyph", markup
)
1372 markup
= columns
.sub (r
"{", markup
)
1373 markup
= submarkup_start
.sub (r
"{\\\1", markup
)
1374 markup
= leftpar
.sub ("{", markup
)
1375 markup
= rightpar
.sub ("}", markup
)
1377 result
= result
+ markup
1379 str = str[markup_end
:]
1380 match
= markup_start
.search(str)
1381 result
= result
+ str
1384 def articulation_substitute (str):
1385 str = re
.sub (r
"""([^-])\[ *(\\?\)?[a-z]+[,']*[!?]?[0-9:]*\.*)""",
1387 str = re
.sub (r
"""([^-])\\\) *([a-z]+[,']*[!?]?[0-9:]*\.*)""",
1389 str = re
.sub (r
"""([^-\\])\) *([a-z]+[,']*[!?]?[0-9:]*\.*)""",
1391 str = re
.sub (r
"""([^-])\\! *([a-z]+[,']*[!?]?[0-9:]*\.*)""",
1395 string_or_scheme
= re
.compile ('("(?:[^"\\\\]|\\\\.)*")|(#\\s*\'?\\s*\\()')
1397 # Only apply articulation_substitute () outside strings and
1398 # Scheme expressions:
1399 def smarter_articulation_subst (str):
1401 # Find the beginning of next string or Scheme expr.:
1402 match
= string_or_scheme
.search (str)
1404 # Convert the preceding LilyPond code:
1405 previous_chunk
= str[:match
.start()]
1406 result
= result
+ articulation_substitute (previous_chunk
)
1407 if match
.group (1): # Found a string
1408 # Copy the string to output:
1409 result
= result
+ match
.group (1)
1410 str = str[match
.end(1):]
1411 else: # Found a Scheme expression. Count
1412 # matching parentheses to find its end
1413 str = str[match
.start ():]
1415 pars
= re
.finditer(r
"[()]",str)
1417 if par
.group () == '(':
1418 nesting_level
= nesting_level
+ 1
1420 nesting_level
= nesting_level
- 1
1421 if nesting_level
== 0:
1422 scheme_end
= par
.end ()
1424 # Copy the Scheme expression to output:
1425 result
= result
+ str[:scheme_end
]
1426 str = str[scheme_end
:]
1427 # Find next string or Scheme expression:
1428 match
= string_or_scheme
.search (str)
1429 # Convert the remainder of the file
1430 result
= result
+ articulation_substitute (str)
1433 def conv_relative(str):
1434 if re
.search (r
"\\relative", str):
1435 str= "#(ly:set-option 'old-relative)\n" + str
1440 str = re
.sub (r
"#'\(\)", "@SCM_EOL@", str)
1441 str = conv_relative (str)
1442 str = sub_chords (str)
1444 str = text_markup (str)
1445 str = smarter_articulation_subst (str)
1446 str = re
.sub ("@SCM_EOL@", "#'()", str)
1450 conversions
.append (((1,9,0), conv
, """New relative mode,
1451 Postfix articulations, new text markup syntax, new chord syntax."""))
1455 if re
.search ("font-style",str):
1456 error_file
.write ('\n')
1457 error_file
.write (NOT_SMART
% "font-style")
1458 error_file
.write ('\n')
1459 error_file
.write (UPDATE_MANUALLY
)
1460 error_file
.write ('\n')
1462 raise FatalConversionError ()
1464 str = re
.sub (r
'-\\markup', r
'@\\markup', str)
1465 str = re
.sub (r
'-\\', r
'\\', str)
1466 str = re
.sub (r
'-\)', ')', str)
1467 str = re
.sub (r
'-\(', '(', str)
1468 str = re
.sub ('-\[', '[', str)
1469 str = re
.sub ('-\]', ']', str)
1470 str = re
.sub ('-~', '~', str)
1471 str = re
.sub (r
'@\\markup', r
'-\\markup', str)
1474 conversions
.append (((1,9,1), conv
, """Remove - before articulation"""))
1477 str = re
.sub ('ly:set-context-property',
1478 'ly:set-context-property!', str)
1479 str = re
.sub ('\\\\newcontext', '\\\\new', str)
1480 str = re
.sub ('\\\\grace[\t\n ]*([^{ ]+)',
1481 r
'\\grace { \1 }', str)
1482 str = re
.sub ("\\\\grace[\t\n ]*{([^}]+)}",
1484 \\property Voice.Stem \\override #'stroke-style = #"grace"
1486 \\property Voice.Stem \\revert #'stroke-style }
1491 conversions
.append (((1,9,2), conv
, """\\newcontext -> \\new"""))
1494 str = re
.sub ('accacciatura',
1495 'acciaccatura', str)
1497 if re
.search ("context-spec-music", str):
1498 error_file
.write ('\n')
1499 error_file
.write (NOT_SMART
% "context-spec-music")
1500 error_file
.write ('\n')
1501 error_file
.write (UPDATE_MANUALLY
)
1502 error_file
.write ('\n')
1504 raise FatalConversionError ()
1506 str = re
.sub ('fingerHorizontalDirection *= *#(LEFT|-1)',
1507 "fingeringOrientations = #'(up down left)", str)
1508 str = re
.sub ('fingerHorizontalDirection *= *#(RIGHT|1)',
1509 "fingeringOrientations = #'(up down right)", str)
1513 conversions
.append (((1,9,3), conv
,
1514 """\\acciaccatura misspelling, fingerHorizontalDirection -> fingeringOrientations"""))
1518 if re
.search ('\\figures', str):
1519 error_file
.write ("Warning: attempting automatic \\figures conversion. Check results!");
1522 def figures_replace (m
):
1524 s
= re
.sub ('<', '@FIGOPEN@',s
)
1525 s
= re
.sub ('>', '@FIGCLOSE@',s
)
1526 return '\\figures { %s }' % s
1528 str = re
.sub (r
'\\figures[ \t\n]*{([^}]+)}', figures_replace
, str)
1529 str = re
.sub (r
'\\<', '@STARTCRESC@', str)
1530 str = re
.sub (r
'\\>', '@STARTDECRESC@', str)
1531 str = re
.sub (r
'([-^_])>', r
'\1@ACCENT@', str)
1532 str = re
.sub (r
'<<', '@STARTCHORD@', str)
1533 str = re
.sub (r
'>>', '@ENDCHORD@', str)
1534 str = re
.sub (r
'>', '@ENDSIMUL@', str)
1535 str = re
.sub (r
'<', '@STARTSIMUL@', str)
1536 str = re
.sub ('@STARTDECRESC@', '\\>', str)
1537 str = re
.sub ('@STARTCRESC@', '\\<', str)
1538 str = re
.sub ('@ACCENT@', '>', str)
1539 str = re
.sub ('@ENDCHORD@', '>', str)
1540 str = re
.sub ('@STARTCHORD@', '<', str)
1541 str = re
.sub ('@STARTSIMUL@', '<<', str)
1542 str = re
.sub ('@ENDSIMUL@', '>>', str)
1543 str = re
.sub ('@FIGOPEN@', '<', str)
1544 str = re
.sub ('@FIGCLOSE@', '>', str)
1548 conversions
.append (((1,9,4), conv
, 'Swap < > and << >>'))
1552 str = re
.sub ('HaraKiriVerticalGroup', 'RemoveEmptyVerticalGroup', str)
1556 conversions
.append (((1,9,5), conv
, 'HaraKiriVerticalGroup -> RemoveEmptyVerticalGroup'))
1559 if re
.search ("ly:get-font", str) :
1560 error_file
.write ('\n')
1561 error_file
.write (NOT_SMART
% "(ly:-get-font")
1562 error_file
.write ('\n')
1563 error_file
.write (FROM_TO \
1564 % ("(ly:paper-get-font (ly:grob-get-paper foo) .. )",
1565 "(ly:paper-get-font (ly:grob-get-paper foo) .. )"))
1566 error_file
.write (UPDATE_MANUALLY
)
1567 error_file
.write ('\n')
1568 raise FatalConversionError ()
1570 if re
.search ("\\pitch *#", str) :
1571 error_file
.write ('\n')
1572 error_file
.write (NOT_SMART
% "\\pitch")
1573 error_file
.write ('\n')
1574 error_file
.write ("Use Scheme code to construct arbitrary note events.")
1575 error_file
.write ('\n')
1577 raise FatalConversionError ()
1582 conversions
.append (((1,9,6), conv
, 'ly:get-font deprecated.'))
1585 def sub_alteration (m
):
1589 '-2': 'DOUBLE-FLAT',
1592 '2': 'DOUBLE-SHARP',
1595 return '(ly:make-pitch %s %s %s)' % (m
.group(1), m
.group (2),
1598 str =re
.sub ("\\(ly:make-pitch *([0-9-]+) *([0-9-]+) *([0-9-]+) *\\)",
1599 sub_alteration
, str)
1602 str = re
.sub ("ly:verbose", "ly:get-option 'verbose", str)
1604 m
= re
.search ("\\\\outputproperty #([^#]+)[\t\n ]*#'([^ ]+)", str)
1607 r
"""\outputproperty found,
1608 Please hand-edit, using
1610 \applyoutput #(outputproperty-compatibility %s '%s <GROB PROPERTY VALUE>)
1612 as a substitution text.""" % (m
.group (1), m
.group (2)) )
1613 raise FatalConversionError ()
1615 if re
.search ("ly:(make-pitch|pitch-alteration)", str) \
1616 or re
.search ("keySignature", str):
1617 error_file
.write ('\n')
1618 error_file
.write (NOT_SMART
% "pitches")
1619 error_file
.write ('\n')
1621 """The alteration field of Scheme pitches was multiplied by 2
1622 to support quarter tone accidentals. You must update the following constructs by manually:
1624 * calls of ly:make-pitch and ly:pitch-alteration
1625 * keySignature settings made with \property
1627 raise FatalConversionError ()
1630 conversions
.append (((1,9,7), conv
,
1631 '''use symbolic constants for alterations,
1632 remove \\outputproperty, move ly:verbose into ly:get-option'''))
1636 if re
.search ("dash-length",str):
1637 error_file
.write ('\n')
1638 error_file
.write (NOT_SMART
% "dash-length")
1639 error_file
.write ('\n')
1640 error_file
.write (FROM_TO
% ("dash-length", "dash-fraction"))
1641 error_file
.write ('\n')
1642 error_file
.write (UPDATE_MANUALLY
)
1643 error_file
.write ('\n')
1644 raise FatalConversionError ()
1647 conversions
.append (((1,9,8), conv
, """dash-length -> dash-fraction"""))
1652 return "#'font-size = #%d" % (2*string
.atoi (match
.group (1)))
1654 str =re
.sub (r
"#'font-relative-size\s*=\s*#\+?([0-9-]+)", func
, str)
1655 str =re
.sub (r
"#'font-family\s*=\s*#'ancient",
1656 r
"#'font-family = #'music", str)
1660 conversions
.append (((2,1,1), conv
, """font-relative-size -> font-size"""))
1663 str =re
.sub (r
"ly:get-music-length", "ly:music-length", str)
1666 conversions
.append (((2,1,2), conv
, """ly:get-music-length -> ly:music-length"""))
1669 str =re
.sub (r
"\.\s+stz=", ". instr ", str)
1672 conversions
.append (((2,1,3), conv
, """stanza -> instrument"""))
1683 return r
" \property %s.melismaBusyProperties \unset" % c
1685 return r
"\property %s.melismaBusyProperties = #'(melismaBusy)" % c
1687 str = re
.sub (r
"\\property ([a-zA-Z]+)\s*\.\s*automaticMelismata\s*=\s*##([ft])", func
, str)
1690 conversions
.append (((2,1,4), conv
, """removal of automaticMelismata; use melismaBusyProperties instead."""))
1695 str =re
.sub (r
"\\translator\s+([a-zA-Z]+)", r
"\\change \1", str)
1698 conversions
.append (((2,1,7), conv
, """\\translator Staff -> \\change Staff"""))
1701 str =re
.sub (r
"\\newaddlyrics", r
"\\lyricsto", str)
1704 conversions
.append (((2,1,10), conv
, """\\newaddlyrics -> \\lyricsto"""))
1707 str = re
.sub (r
'\\include\s*"paper([0-9]+)(-init)?.ly"',
1708 r
"#(set-staff-size \1)", str)
1710 def sub_note (match
):
1712 log
= string
.atoi (match
.group (1))
1713 dots
= string
.atoi (match
.group (2))
1716 dur
= '%d' % (1 << log
)
1718 dur
= { -1 : 'breve',
1724 return r
'\note #"%s" #%s' % (dur
, match
.group (3))
1726 str = re
.sub (r
'\\note\s+#([0-9-]+)\s+#([0-9]+)\s+#([0-9.-]+)',
1730 conversions
.append (((2,1,11), conv
, """\\include "paper16.ly" -> #(set-staff-size 16)
1731 \\note #3 #1 #1 -> \\note #"8." #1
1736 str =re
.sub (r
"OttavaSpanner", r
"OttavaBracket", str)
1739 conversions
.append (((2,1,12), conv
, """OttavaSpanner -> OttavaBracket"""))
1743 str =re
.sub (r
"\(set-staff-size ", r
"(set-global-staff-size ", str)
1746 conversions
.append (((2,1,13), conv
, """set-staff-size -> set-global-staff-size"""))
1749 str =re
.sub (r
"#'style\s*=\s*#'dotted-line",
1750 r
"#'dash-fraction = #0.0 ", str)
1753 conversions
.append (((2,1,14), conv
, """style = dotted -> dash-fraction = 0"""))
1756 str =re
.sub (r
'LyricsVoice\s*\.\s*instrument\s*=\s*("[^"]*")',
1757 r
'LyricsVoice . vocalName = \1', str)
1759 str =re
.sub (r
'LyricsVoice\s*\.\s*instr\s*=\s*("[^"]*")',
1760 r
'LyricsVoice . vocNam = \1', str)
1763 conversions
.append (((2,1,15), conv
, """LyricsVoice . instr(ument) -> vocalName"""))
1777 return '\\%s' % d
[m
.group (1)]
1779 str = re
.sub (r
'\\musicglyph\s*#"accidentals-([0-9-]+)"',
1783 conversions
.append (((2,1,16), conv
, """\\musicglyph #"accidentals-NUM" -> \\sharp/flat/etc."""))
1788 if re
.search (r
'\\partcombine', str):
1789 error_file
.write ('\n')
1790 error_file
.write (NOT_SMART
% "\\partcombine")
1791 error_file
.write ('\n')
1792 error_file
.write (UPDATE_MANUALLY
)
1793 error_file
.write ('\n')
1794 raise FatalConversionError ()
1796 # this rule doesn't really work,
1797 # too lazy to figure out why.
1798 str = re
.sub (r
'\\context\s+Voice\s*=\s*one\s*\\partcombine\s+Voice\s*\\context\s+Thread\s*=\s*one(.*)\s*'
1799 + r
'\\context\s+Thread\s*=\s*two',
1800 '\\\\newpartcombine\n\\1\n', str)
1805 conversions
.append (((2,1,17), conv
, """\\partcombine syntax change to \\newpartcombine"""))
1809 str = re
.sub (r
'\\newpartcombine', r
'\\partcombine', str)
1810 str = re
.sub (r
'\\autochange\s+Staff', r
'\\autochange ', str)
1813 conversions
.append (((2,1,18), conv
, """\\newpartcombine -> \\partcombine,
1814 \\autochange Staff -> \\autochange
1821 str = re
.sub (r
'\\include "drumpitch-init.ly"','', str)
1822 str = re
.sub (r
'\\pitchnames ','pitchnames = ', str)
1823 str = re
.sub (r
'\\chordmodifiers ','chordmodifiers = ', str)
1824 str = re
.sub (r
'\bdrums\b\s*=','drumContents = ', str)
1825 str = re
.sub (r
'\\drums\b','\\drumContents ', str)
1828 if re
.search ('drums->paper', str):
1829 error_file
.write ("\nDrum notation found. Check file manually!")
1831 str = re
.sub (r
"""\\apply\s+#\(drums->paper\s+'([a-z]+)\)""",
1832 r
"""\property DrumStaff.drumStyleTable = #\1-style""",
1835 if re
.search ('Thread', str):
1836 error_file
.write ("\nThread found. Check file manually!\n");
1838 str = re
.sub (r
"""(\\once\s*)?\\property\s+Thread\s*\.\s*NoteHead\s*"""
1839 + r
"""\\(set|override)\s*#'style\s*=\s*#'harmonic"""
1840 + r
"""\s+([a-z]+[,'=]*)([0-9]*\.*)"""
1841 ,r
"""<\3\\harmonic>\4""", str)
1843 str = re
.sub (r
"""\\new Thread""", """\context Voice""", str)
1844 str = re
.sub (r
"""Thread""", """Voice""", str)
1846 if re
.search ('\bLyrics\b', str):
1847 error_file
.write ("\nLyrics found. Check file manually!\n");
1849 str = re
.sub (r
"""LyricsVoice""", r
"""L@ricsVoice""", str)
1850 str = re
.sub (r
"""\bLyrics\b""", r
"""LyricsVoice""", str)
1851 str = re
.sub (r
"""LyricsContext""", r
"""LyricsVoiceContext""", str)
1852 str = re
.sub (r
"""L@ricsVoice""", r
"""LyricsVoice""",str)
1857 conversions
.append (((2,1,19), conv
, """Drum notation changes, Removing \\chordmodifiers, \\notenames.
1858 Harmonic notes. Thread context removed. Lyrics context removed."""))
1861 str = re
.sub (r
'nonevent-skip', 'skip-music', str)
1864 conversions
.append (((2,1,20), conv
, """nonevent-skip -> skip-music""" ))
1867 str = re
.sub (r
'molecule-callback', 'print-function', str)
1868 str = re
.sub (r
'brew_molecule', 'print', str)
1869 str = re
.sub (r
'brew-new-markup-molecule', 'Text_item::print', str)
1870 str = re
.sub (r
'LyricsVoice', 'Lyrics', str)
1871 str = re
.sub (r
'tupletInvisible',
1872 r
"TupletBracket \\set #'transparent", str)
1873 # str = re.sub (r'molecule', 'collage', str)
1874 #molecule -> collage
1875 str = re
.sub (r
"\\property\s+[a-zA-Z]+\s*\.\s*[a-zA-Z]+\s*"
1876 + r
"\\set\s*#'X-extent-callback\s*=\s*#Grob::preset_extent",
1881 conversions
.append (((2,1,21), conv
, """molecule-callback -> print-function,
1882 brew_molecule -> print
1883 brew-new-markup-molecule -> Text_item::print
1884 LyricsVoice -> Lyrics
1885 tupletInvisible -> TupletBracket \set #'transparent
1886 Grob::preset_extent removed.
1891 str = re
.sub (r
'(\\property[^=]+)=\s*([-0-9]+)',
1893 str = re
.sub (r
'\\property\s+([^. ]+)\s*\.\s*([^\\=]+)\s*\\(set|override)',
1894 r
"\\overrid@ \1.\2 ", str)
1895 str = re
.sub (r
'\\property\s+([^. ]+)\s*\.\s*([^\\= ]+)\s*=\s*',
1896 r
'\\s@t \1.\2 = ', str)
1897 str = re
.sub (r
'\\property\s+([^. ]+)\s*\.\s*([^\\= ]+)\s*\\unset',
1898 r
'\\uns@t \1.\2 ', str)
1899 str = re
.sub (r
'\\property\s+([^. ]+)\s*\.\s*([^\\= ]+)\s*\\revert'
1900 + r
"\s*#'([-a-z0-9_]+)",
1901 r
"\\rev@rt \1.\2 #'\3", str)
1902 str = re
.sub (r
'Voice\.', '', str)
1903 str = re
.sub (r
'Lyrics\.', '', str)
1904 str = re
.sub (r
'ChordNames\.', '', str)
1906 str = re
.sub ('rev@rt', 'revert',str)
1907 str = re
.sub ('s@t', 'set',str)
1908 str = re
.sub ('overrid@', 'override',str)
1910 str = re
.sub ('molecule', 'stencil', str)
1911 str = re
.sub ('Molecule', 'Stencil', str)
1914 conversions
.append (((2,1,22), conv
, """new syntax for property settings:
1915 \\set A.B = #C , \\unset A.B
1916 \\override A.B #C = #D, \\revert A.B #C
1921 def subst_in_trans (match
):
1923 s
= re
.sub (r
'\s([a-zA-Z]+)\s*\\override',
1924 r
' \\override \1', s
)
1925 s
= re
.sub (r
'\s([a-zA-Z]+)\s*\\set',
1926 r
' \\override \1', s
)
1927 s
= re
.sub (r
'\s([a-zA-Z]+)\s*\\revert',
1930 str = re
.sub (r
'\\(translator|with)\s*{[^}]+}', subst_in_trans
, str)
1934 context
= m
.group ('context')
1937 context
= " '%s" % context
[:-1] # -1: remove .
1941 d
['context'] = context
1943 return r
"""#(override-auto-beam-setting %(prop)s %(num)s %(den)s%(context)s)""" % d
1945 str = re
.sub (r
"""\\override\s*(?P<context>[a-zA-Z]+\s*\.\s*)?autoBeamSettings"""
1946 +r
"""\s*#(?P<prop>[^=]+)\s*=\s*#\(ly:make-moment\s+(?P<num>\d+)\s+(?P<den>\d)\s*\)""",
1951 conversions
.append (((2,1,23), conv
, """Property setting syntax in \\translator{ }"""))
1953 str = re
.sub (r
'music-list\?', 'ly:music-list?', str)
1954 str = re
.sub (r
'\|\s*~', '~ |', str)
1957 conversions
.append (((2,1,24), conv
, """music-list? -> ly:music-list?"""))
1960 str = re
.sub (r
'ly:get-spanner-bound', 'ly:spanner-get-bound', str)
1961 str = re
.sub (r
'ly:get-extent', 'ly:grob-extent', str)
1962 str = re
.sub (r
'ly:get-system', 'ly:grob-system', str)
1963 str = re
.sub (r
'ly:get-original', 'ly:grob-original', str)
1964 str = re
.sub (r
'ly:get-parent', 'ly:grob-parent', str)
1965 str = re
.sub (r
'ly:get-broken-into', 'ly:spanner-broken-into', str)
1966 str = re
.sub (r
'Melisma_engraver', 'Melisma_translator', str)
1967 if re
.search ("ly:get-paper-variable", str):
1968 error_file
.write ('\n')
1969 error_file
.write (NOT_SMART
% "ly:paper-get-variable")
1970 error_file
.write ('\n')
1971 error_file
.write ('use (ly:paper-lookup (ly:grob-paper ))')
1972 error_file
.write ('\n')
1973 raise FatalConversionError ()
1975 str = re
.sub (r
'\\defaultAccidentals', "#(set-accidental-style 'default)", str)
1976 str = re
.sub (r
'\\voiceAccidentals', "#(set-accidental-style 'voice)", str)
1977 str = re
.sub (r
'\\modernAccidentals', "#(set-accidental-style 'modern)", str)
1978 str = re
.sub (r
'\\modernCautionaries', "#(set-accidental-style 'modern-cautionary)", str)
1979 str = re
.sub (r
'\\modernVoiceAccidental', "#(set-accidental-style 'modern-voice)", str)
1980 str = re
.sub (r
'\\modernVoiceCautionaries', "#(set-accidental-style 'modern-voice-cautionary)", str)
1981 str = re
.sub (r
'\\pianoAccidentals', "#(set-accidental-style 'piano)", str)
1982 str = re
.sub (r
'\\pianoCautionaries', "#(set-accidental-style 'piano-cautionary)", str)
1983 str = re
.sub (r
'\\forgetAccidentals', "#(set-accidental-style 'forget)", str)
1984 str = re
.sub (r
'\\noResetKey', "#(set-accidental-style 'no-reset)", str)
1988 conversions
.append (((2,1,25), conv
, """Scheme grob function renaming"""))
1992 str = re
.sub ('ly:set-grob-property!', 'ly:grob-set-property!',str)
1993 str = re
.sub ('ly:set-mus-property!', 'ly:music-set-property!',str)
1994 str = re
.sub ('ly:set-context-property!', 'ly:context-set-property!', str)
1995 str = re
.sub ('ly:get-grob-property', 'ly:grob-property',str)
1996 str = re
.sub ('ly:get-mus-property', 'ly:music-property',str)
1997 str = re
.sub ('ly:get-context-property', 'ly:context-property',str)
2001 conversions
.append (((2,1,26), conv
, """More Scheme function renaming"""))
2005 g
= string
.atoi (m
.group (2))
2013 lower_pitches
= filter (lambda x
: x
<= g
, [0, 2, 4, 5, 7, 9, 11, 12])
2014 s
= len (lower_pitches
) -1
2015 a
= g
- lower_pitches
[-1]
2018 print s
, lower_pitches
, g
, a
, s
2020 str += ['eses', 'es', '', 'is', 'isis'][a
+ 2]
2022 str += ',' * (-o
- 1)
2024 str += "'" * (o
+ 1)
2026 return '\\transposition %s ' % str
2029 str = re
.sub (r
"\\set ([A-Za-z]+\s*\.\s*)?transposing\s*=\s*#([-0-9]+)",
2033 conversions
.append (((2,1,27), conv
, """property transposing -> tuning"""))
2036 str = re
.sub (r
'make-music-by-name', 'make-music', str)
2037 str = re
.sub (r
"\\override\s+.*Arpeggio\s+#.print-function\s+=\s+\\arpeggioBracket", r
"\\arpeggioBracket", str)
2040 conversions
.append (((2,1,28), conv
,
2041 """make-music-by-name -> make-music,
2042 new syntax for setting \\arpeggioBracket"""))
2045 str = re
.sub (r
'\\center([^-])', '\\center-align\\1', str)
2046 str = re
.sub (r
'\\translator', '\\context', str)
2049 conversions
.append (((2,1,29), conv
,
2050 '\\center -> \\center-align, \\translator -> \\context'))
2054 str = re
.sub (r
'\\threeq(flat|sharp)', r
'\\sesqui\1', str)
2055 str = re
.sub (r
'ly:stencil-get-extent',
2056 'ly:stencil-extent', str)
2057 str = re
.sub (r
'ly:translator-find',
2058 'ly:context-find', str)
2059 str = re
.sub ('ly:unset-context-property','ly:context-unset-property',
2062 str = re
.sub (r
'ly:get-mutable-properties',
2063 'ly:mutable-music-properties',str)
2064 str = re
.sub (r
'centralCPosition',
2065 'middleCPosition',str)
2068 conversions
.append (((2,1,30), conv
,
2069 '''\\threeq{flat,sharp} -> \\sesqui{flat,sharp}
2070 ly:get-mutable-properties -> ly:mutable-music-properties
2071 centralCPosition -> middleCPosition
2072 ly:unset-context-property -> ly:context-unset-property
2073 ly:translator-find -> ly:context-find
2074 ly:get-stencil-extent -> ly:stencil-extent
2079 str = re
.sub (r
'\\alias\s*"?Timing"?', '', str)
2082 conversions
.append (((2,1,31), conv
,
2083 '''remove \\alias Timing'''))
2086 str = re
.sub (r
"(\\set\s+)?(?P<context>(Score\.)?)breakAlignOrder\s*=\s*#'(?P<list>[^\)]+)",
2087 r
"\n\\override \g<context>BreakAlignment #'break-align-orders = "
2088 + "#(make-vector 3 '\g<list>)", str)
2092 conversions
.append (((2,1,33), conv
,
2093 '''breakAlignOrder -> break-align-orders.'''))
2096 str = re
.sub (r
"\(set-paper-size",
2097 "(set-default-paper-size",str)
2100 conversions
.append (((2,1,34), conv
,
2101 '''set-paper-size -> set-default-paper-size.'''))
2104 str = re
.sub (r
"ly:mutable-music-properties",
2105 "ly:music-mutable-properties", str)
2108 conversions
.append (((2,1, 36), conv
,
2109 '''ly:mutable-music-properties -> ly:music-mutable-properties'''))
2116 conversions
.append (((2, 2, 0), conv
,
2117 '''clean up version. '''))
2120 return re
.sub (r
'\\apply\b', r
'\\applymusic', str)
2122 conversions
.append (((2, 3, 1), conv
,
2123 '''\\apply -> \\applymusic'''))
2126 if re
.search ('textheight', str):
2127 error_file
.write ('\n')
2128 error_file
.write (NOT_SMART
% "textheight")
2129 error_file
.write ('\n')
2130 error_file
.write (UPDATE_MANUALLY
)
2131 error_file
.write ('\n')
2133 """Page layout has been changed, using paper size and margins.
2134 textheight is no longer used.
2136 str = re
.sub (r
'\\OrchestralScoreContext', '\\Score', str)
2138 if m
.group(1) not in ['RemoveEmptyStaff',
2139 'AncientRemoveEmptyStaffContext',
2141 return '\\' + m
.group (1)
2146 str = re
.sub (r
'\\([a-zA-Z]+)Context\b', func
, str)
2147 str = re
.sub ('ly:paper-lookup', 'ly:output-def-lookup', str)
2150 conversions
.append (((2, 3, 2), conv
,
2151 '''\\FooContext -> \\Foo'''))
2154 str = re
.sub (r
'\\notes\b', '', str)
2158 conversions
.append (((2, 3, 4), conv
,
2159 '''remove \\notes'''))
2164 str = re
.sub (r
'lastpagefill\s*=\s*"?1"', 'raggedlastbottom = ##t', str)
2167 conversions
.append (((2, 3, 6), conv
,
2168 '''lastpagefill -> raggedlastbottom'''))
2173 str = re
.sub (r
'\\consistsend', '\\consists', str)
2174 str = re
.sub (r
'\\lyricsto\s+("?[a-zA-Z]+"?)(\s*\\new Lyrics\s*)?\\lyrics',
2175 r
'\\lyricsto \1 \2', str)
2178 conversions
.append (((2, 3, 8), conv
,
2179 '''remove \\consistsend, strip \\lyrics from \\lyricsto.'''))
2182 str = re
.sub (r
'neo_mensural', 'neomensural', str)
2183 str = re
.sub (r
'if-text-padding', 'bound-padding', str)
2186 conversions
.append (((2, 3, 9), conv
,
2187 '''neo_mensural -> neomensural, if-text-padding -> bound-padding'''))
2192 str = re
.sub (r
'\\addlyrics', r
'\\oldaddlyrics', str)
2193 str = re
.sub (r
'\\newlyrics', r
'\\addlyrics', str)
2194 if re
.search (r
"\\override\s*TextSpanner", str):
2195 error_file
.write ("\nWarning: TextSpanner has been split into DynamicTextSpanner and TextSpanner\n")
2198 conversions
.append (((2, 3, 10), conv
,
2199 '''\\addlyrics -> \\oldaddlyrics, \\newlyrics -> \\addlyrics'''))
2202 str = re
.sub (r
'\\setMmRestFermata\s+(R[0-9.*/]*)',
2203 r
'\1^\\fermataMarkup', str)
2206 conversions
.append (((2, 3, 11), conv
,
2207 '''\\setMmRestFermata -> ^\\fermataMarkup'''))
2210 str = re
.sub (r
'\\newpage', r
'\\pageBreak', str)
2211 str = re
.sub (r
'\\scriptUp', r
"""{
2212 \\override TextScript #'direction = #1
2213 \\override Script #'direction = #1
2215 str = re
.sub (r
'\\scriptDown', r
"""{
2216 \\override TextScript #'direction = #-1
2217 \\override Script #'direction = #-1
2219 str = re
.sub (r
'\\scriptBoth', r
"""{
2220 \\revert TextScript #'direction
2221 \\revert Script #'direction
2223 str = re
.sub ('soloADue', 'printPartCombineTexts', str)
2224 str = re
.sub (r
'\\applymusic\s*#notes-to-clusters',
2225 '\\makeClusters', str)
2227 str = re
.sub (r
'pagenumber\s*=', 'firstpagenumber = ', str)
2230 conversions
.append (((2, 3, 12), conv
,
2231 '''\\newpage -> \\pageBreak, junk \\script{up,down,both},
2232 soloADue -> printPartCombineTexts, #notes-to-clusters -> \\makeClusters
2237 str = re
.sub (r
'\\chords\b', r
'\\chordmode', str)
2238 str = re
.sub (r
'\\lyrics\b', r
'\\lyricmode', str)
2239 str = re
.sub (r
'\\figures\b', r
'\\figuremode', str)
2240 str = re
.sub (r
'\\notes\b', r
'\\notemode', str)
2241 str = re
.sub (r
'\\drums\b', r
'\\drummode', str)
2242 str = re
.sub (r
'\\chordmode\s*\\new ChordNames', r
'\\chords', str)
2243 str = re
.sub (r
'\\new ChordNames\s*\\chordmode', r
'\\chords', str)
2244 str = re
.sub (r
'\\new FiguredBass\s*\\figuremode', r
'\\figures', str)
2245 str = re
.sub (r
'\\figuremode\s*\new FiguredBass', r
'\\figures', str)
2246 str = re
.sub (r
'\\new DrumStaff\s*\\drummode', r
'\\drums', str)
2247 str = re
.sub (r
'\\drummode\s*\\new DrumStaff', r
'\\drums', str)
2251 conversions
.append (((2, 3, 16), conv
,
2252 '''\foo -> \foomode (for chords, notes, etc.)
2253 fold \new FooContext \foomode into \foo.'''))
2256 str = re
.sub (r
'(slur|stem|phrasingSlur|tie|dynamic|dots|tuplet|arpeggio|)Both', r
'\1Neutral', str)
2257 str = re
.sub (r
"\\applymusic\s*#\(remove-tag\s*'([a-z-0-9]+)\)",
2258 r
"\\removeWithTag #'\1", str)
2261 conversions
.append (((2, 3, 17), conv
,
2262 '''\foo -> \foomode (for chords, notes, etc.)
2263 fold \new FooContext \foomode into \foo.'''))
2267 str = re
.sub (r
'Text_item', 'Text_interface', str)
2270 conversions
.append (((2, 3, 18),
2272 '''Text_item -> Text_interface''' ))
2275 str = re
.sub (r
'\\paper', r
'\\layout', str)
2276 str = re
.sub (r
'\\bookpaper', r
'\\paper', str)
2277 if re
.search ('paper-set-staff-size', str):
2278 error_file
.write ('''\nWarning: staff size should be changed at top-level
2281 #(set-global-staff-size <STAFF-HEIGHT-IN-POINT>)
2286 str = re
.sub (r
'#\(paper-set-staff-size', '%Use set-global-staff-size at toplevel\n% #(layout-set-staff-size', str)
2289 conversions
.append (((2, 3, 22),
2292 bookpaper -> paper''' ))
2296 str = re
.sub (r
'\\context\s+([a-zA-Z]+)\s*=\s*([a-z]+)\s',
2297 r
'\\context \1 = "\2" ',
2301 conversions
.append (((2, 3, 23),
2303 '''\context Foo = NOTENAME -> \context Foo = "NOTENAME"'''))
2307 return regularize_id (m
.group (1))
2308 str = re
.sub (r
'(maintainer_email|maintainer_web|midi_stuff|gourlay_maxmeasures)',
2312 conversions
.append (((2, 3, 24),
2314 '''regularize other identifiers.'''))
2320 conversions
.append (((2, 4, 0),
2326 str = re
.sub (r
'\\quote\s+"?([a-zA-Z0-9]+)"?\s+([0-9.*/]+)',
2327 r
'\\quoteDuring #"\1" { \skip \2 }',
2332 conversions
.append (((2, 5, 0),
2338 str = re
.sub (r
'ly:import-module',
2339 r
'ly:module-copy', str)
2342 conversions
.append (((2, 5, 1),
2344 'ly:import-module -> ly:module-copy'))
2347 str = re
.sub (r
'\\(column|fill-line|dir-column|center-align|right-align|left-align|bracketed-y-column)\s*<(([^>]|<[^>]*>)*)>',
2349 str = re
.sub (r
'\\(column|fill-line|dir-column|center-align|right-align|left-align|bracketed-y-column)\s*<(([^>]|<[^>]*>)*)>',
2351 str = re
.sub (r
'\\(column|fill-line|dir-column|center-align|right-align|left-align|bracketed-y-column)\s*<(([^>]|<[^>]*>)*)>',
2355 s
= re
.sub (r
'''((\\"|})\s*){''', '\2 \\line {', s
)
2357 str = re
.sub (r
'\\markup\s*{([^}]|{[^}]*})*}', get_markup
, str)
2360 conversions
.append (((2, 5, 2),
2362 '\markup .. < .. > .. -> \markup .. { .. } ..'))
2365 str = re
.sub ('ly:find-glyph-by-name', 'ly:font-get-glyph', str)
2366 str = re
.sub ('"(scripts|clefs|accidentals)-', r
'"\1.', str)
2367 str = re
.sub ("'hufnagel-do-fa", "'hufnagel.do.fa", str)
2368 str = re
.sub ("'(vaticana|hufnagel|medicaea|petrucci|neomensural|mensural)-", r
"'\1.", str)
2371 conversions
.append (((2, 5, 3),
2373 'ly:find-glyph-by-name -> ly:font-get-glyph, remove - from glyphnames.'))
2377 str = re
.sub (r
"\\override\s+(Voice\.)?Slur #'dashed\s*=\s*#\d*(\.\d+)?",
2378 r
"\\slurDashed", str)
2381 conversions
.append (((2, 5, 12),
2383 '\set Slur #\'dashed = #X -> \slurDashed'))
2386 input_encoding
= 'latin1'
2388 encoding
= match
.group (1)
2390 # FIXME: automatic recoding of other than latin1?
2391 if encoding
== 'latin1':
2392 return match
.group (2)
2394 error_file
.write ('\n')
2395 error_file
.write (NOT_SMART
% ("\\encoding: %s" % encoding
))
2396 error_file
.write ('\n')
2397 error_file
.write (_ ("LilyPond source must be UTF-8"))
2398 error_file
.write ('\n')
2399 if encoding
== 'TeX':
2400 error_file
.write (_ ("Try the texstrings backend"))
2401 error_file
.write ('\n')
2403 error_file
.write ( _("Do something like: %s") % \
2404 ("recode %s..utf-8 FILE" % encoding
))
2405 error_file
.write ('\n')
2406 error_file
.write (_ ("Or save as UTF-8 in your editor"))
2407 error_file
.write ('\n')
2408 raise FatalConversionError ()
2410 return match
.group (0)
2412 str = re
.sub (r
'\\encoding\s+"?([a-zA-Z0-9]+)"?(\s+)', func
, str)
2415 de_ascii
= codecs
.getdecoder ('ascii')
2416 de_utf_8
= codecs
.getdecoder ('utf_8')
2417 de_input
= codecs
.getdecoder (input_encoding
)
2418 en_utf_8
= codecs
.getencoder ('utf_8')
2421 # only in python >= 2.3
2422 # except UnicodeDecodeError:
2423 except UnicodeError:
2424 # do not re-recode UTF-8 input
2427 #except UnicodeDecodeError:
2428 except UnicodeError:
2429 str = en_utf_8 (de_input (str)[0])[0]
2433 str = re
.sub (r
"#\(ly:set-point-and-click '[a-z-]+\)", '', str)
2436 conversions
.append (((2, 5, 13),
2438 '\\encoding: smart recode latin1..utf-8. Remove ly:point-and-click'))
2442 if re
.search ("ly:stencil-set-extent!", str):
2443 error_file
.write ('\n')
2444 error_file
.write (NOT_SMART
% "ly:stencil-set-extent!")
2445 error_file
.write ('\n')
2446 error_file
.write ('use (set! VAR (ly:make-stencil (ly:stencil-expr VAR) X-EXT Y-EXT))\n')
2447 raise FatalConversionError ()
2448 if re
.search ("ly:stencil-align-to!", str):
2449 error_file
.write ('\n')
2450 error_file
.write (NOT_SMART
% "ly:stencil-align-to!")
2451 error_file
.write ('\n')
2452 error_file
.write ('use (set! VAR (ly:stencil-aligned-to VAR AXIS DIR))\n')
2453 raise FatalConversionError ()
2456 conversions
.append (((2, 5, 17),
2458 'ly:stencil-set-extent! removed'))
2461 str = re
.sub (r
"ly:warn\b", 'ly:warning', str)
2464 conversions
.append (((2, 5, 18),
2466 'ly:warn -> ly:warning'))
2468 if re
.search ("(override-|revert-)auto-beam-setting", str)\
2469 or re
.search ("autoBeamSettings", str):
2470 error_file
.write ('\n')
2471 error_file
.write (NOT_SMART
% "auto beam settings")
2472 error_file
.write ('\n')
2473 error_file
.write ('''
2474 Auto beam settings must now specify each interesting moment in a measure
2475 explicitely; 1/4 is no longer multiplied to cover moments 1/2 and 3/4 too.
2477 error_file
.write (UPDATE_MANUALLY
)
2478 error_file
.write ('\n')
2479 raise FatalConversionError ()
2482 conversions
.append (((2, 5, 21),
2484 'warn about auto beam settings'))
2487 str = re
.sub (r
"unfoldrepeats", 'unfoldRepeats', str)
2488 str = re
.sub (r
"compressmusic", 'compressMusic', str)
2491 conversions
.append (((2, 5, 25), conv
,
2493 'unfoldrepeats -> unfoldRepeats,'
2494 + 'compressmusic -> compressMusic'))
2499 conversions
.append (((2, 6, 0), conv
,
2501 'dummy rule for 2.6'))
2506 return re
.sub('ly:get-default-font', 'ly:grob-default-font', str)
2508 conversions
.append (((2, 7, 0), conv
,
2509 'ly:get-default-font -> ly:grob-default-font'))
2512 str = re
.sub('ly:parser-define', 'ly:parser-define!', str)
2513 str = re
.sub('excentricity', 'eccentricity', str)
2514 str = re
.sub(r
'\\(consists|remove) *"?Timing_engraver"?',
2515 r
'\\\1 "Timing_translator" \\\1 "Default_bar_line_engraver"',
2519 conversions
.append (((2, 7, 1), conv
,
2520 '''ly:parser-define -> ly:parser-define!
2521 excentricity -> eccentricity
2522 Timing_engraver -> Timing_translator + Default_bar_line_engraver
2527 str = re
.sub('ly:(add|mul|mod|div)-moment', r
'ly:moment-\1', str)
2530 conversions
.append (((2, 7, 2), conv
,
2531 '''ly:X-moment -> ly:moment-X'''))
2535 str = re
.sub('keyAccidentalOrder', 'keyAlterationOrder', str)
2538 conversions
.append (((2, 7, 4), conv
,
2539 '''keyAccidentalOrder->keyAlterationOrder'''))
2544 str = re
.sub('Performer_group_performer', 'Performer_group', str)
2545 str = re
.sub('Engraver_group_engraver', 'Engraver_group', str)
2546 str = re
.sub (r
"#'inside-slur\s*=\s*##t *",
2547 r
"#'avoid-slur = #'inside ", str)
2548 str = re
.sub (r
"#'inside-slur\s*=\s*##f *",
2549 r
"#'avoid-slur = #'around ", str)
2550 str = re
.sub (r
"#'inside-slur",
2551 r
"#'avoid-slur", str)
2554 conversions
.append (((2, 7, 6), conv
,
2555 '''Performer_group_performer -> Performer_group, Engraver_group_engraver -> Engraver_group
2556 inside-slur -> avoid-slur'''))