* lily/beam-performer.cc (process_music): idem.
[lilypond.git] / scm / define-music-types.scm
blob68f6357b588c431999c24d022b6ac4b0f8bc8434
1 ;;;; define-music-types.scm --
2 ;;;;
3 ;;;;  source file of the GNU LilyPond music typesetter
4 ;;;; 
5 ;;;; (c)  1998--2004 Han-Wen Nienhuys <hanwen@cs.uu.nl>
6 ;;;;                 Jan Nieuwenhuizen <janneke@gnu.org>
9 ;; TODO: should link back into user manual.
11 (define-public music-descriptions
12   `(
13     (AbsoluteDynamicEvent
14      . (
15    (description . "Creates a dynamic mark.
17 Syntax: @var{note}@code{\\x},
18 where x is one of \\ppp, \\pp, \\p, \\mp, \\mf, \\f, \\ff, \\fff.")
19         (internal-class-name . "Event")
20         (types . (general-music event dynamic-event absolute-dynamic-event))
21         ))
22     (ApplyContext
23      . (
24         (description . "Call the argument with the current context during interpreting phase")
25         (internal-class-name . "Music")
26         (types . (general-music apply-context))
27         (iterator-ctor . ,Apply_context_iterator::constructor)
28         ))
29     (ApplyOutputEvent
30      . (
31         (description . "
32 Call the argument with all current grobs during interpreting phase.
34 Syntax
36 \\applyoutput FUNC
38 arguments to func are 1. the grob, 2. the originating context,
39 3. context where FUNC is called.
42         (internal-class-name . "Event")
43         (iterator-ctor . ,Output_property_music_iterator::constructor)
44         (types . (general-music layout-instruction))
45         ))
46     (ArpeggioEvent 
47      . (
48         (description .  "Make an arpeggio on this note.
50 Syntax:
51 @var{note}-@code{\\arpeggio}")
52         (internal-class-name .  "Event")
53         (types . (general-music arpeggio-event event))
54         ))
56     ;; todo: use articulation-event for slur as well.
57     ;; separate non articulation scripts  
58     (ArticulationEvent
59      . (
60    (description .  "Adds an articulation marking to a note.  
62 Syntax:
63 @var{note}@code{X}@code{Y}, where X is a direction (up @code{^}, down
64 @code{_}, or LilyPond's choice (no direction specified)), and where Y
65 is an articulation (such as @code{-.}, @code{->}, @code{\\tenuto},
66 @code{\\downbow}).  See the user manual for details.")
68         (internal-class-name . "Event")
69         (types . (general-music event articulation-event script-event))
70         )) 
71     (AutoChangeMusic
72      . (
73         (description .  "Used for making voices that switch between piano staves automatically.")
75         (internal-class-name . "Music_wrapper")
76         (iterator-ctor . ,Auto_change_iterator::constructor)
77         (types . (general-music music-wrapper-music auto-change-instruction))
78         ))
79     (BarCheck
80      . (
81         (description .
82                      "Check whether this music coincides with the start of the measure.")
83         (internal-class-name . "Music")
84         (types . (general-music bar-check))
85         (iterator-ctor . ,Bar_check_iterator::constructor)
86         ))
87     (BassFigureEvent
88      . (
89         (description .  "Print a bass-figure text")
91         (internal-class-name . "Event")
92         (types . (general-music event rhythmic-event bass-figure-event))
93         ))
94     (BeamEvent
95      . (
96    (description .  "Starts or stops a beam.  
98 Syntax for manual control:
99 c8-[ c c-] c8")
100         (internal-class-name . "Event")
101         (types . (general-music event beam-event span-event))
102         ))
103     (BreakEvent
104      . (
105    (description .  "Creates a line break.  
107 Syntax: \\break.")
109         (internal-class-name . "Event")
110         (types . (general-music break-event event))
111         ))
112     (BreathingSignEvent
113      . (
114         (description .  "Creates a `breath mark' or `comma'.  
116 Syntax:
117 @var{note}\\breathe.")
119         (internal-class-name . "Event")
120         (types . (general-music event breathing-event))
121         )) 
122     (BusyPlayingEvent
123      . (
124         (description .  "Used internally to signal beginning and ending of notes.")
126         (internal-class-name . "Event")
127         (types . (general-music event busy-playing-event))
128         ))
129     (StartPlayingEvent
130      . (
131         (description .  "Used internally to signal beginning of notes.")
133         (internal-class-name . "Event")
134         (types . (general-music event start-playing-event))
135         ))
136     
137     (ClusterNoteEvent
138      . (
139         (description .  "A note that is part of a cluster.")
140         (internal-class-name . "Event")
142         ; not a note-event, to ensure that Note_engraver doesn't eat it. 
143         (types . (general-music cluster-note-event melodic-event rhythmic-event event))
144         ))
145     
146     (ContextSpeccedMusic
147      . (
148         (description .  "Interpret the argument music within a specific context.")
149         (iterator-ctor . ,Context_specced_music_iterator::constructor)
150         (internal-class-name . "Music_wrapper")
151         (types . (context-specification general-music music-wrapper-music))
152         ))
153     
154     (CrescendoEvent
155      . (
156         (description .  "Begins or ends a crescendo.  
158 Syntax: @var{note}\\cr
159 ... @var{note}\\rc (you can also use \\<, \\!, \\cresc, and
160 \\endcresc.  See the user manual for details.).")
162         (internal-class-name . "Event")
163         (types . (general-music dynamic-event crescendo-event event))
164         )) 
165     (DecrescendoEvent
166      . (
167         (description .  "See @ref{CrescendoEvent}.")
169         (internal-class-name . "Event")
170         (types . (general-music dynamic-event decrescendo-event event))
171         ))
173     (ExtenderEvent
174      . (
175         (description .  "Extend lyrics.")
177         (internal-class-name . "Event")
178         (types . (general-music extender-event event))
179         ))
180     (FingerEvent
181      . (
182         (description . "Specify what finger to use for this note.")
183         (internal-class-name . "Event")
184         (types . (general-music fingering-event event))
185         ))
186     (BeamForbidEvent
187      . (
188         (description . "Specify that a note may not auto-beamed ")
189         (internal-class-name . "Event")
190         (types . (general-music event beam-forbid-event))
191         ))
192     (GlissandoEvent
193      . (
194         (description .  "Start  a glissando on this note.")
195         (internal-class-name . "Event")
196         (types . (general-music glissando-event event))
197         ))
198     
199     (GraceMusic
200      . (
201         (description .  "Interpret the argument as grace notes. ")
203         (internal-class-name . "Grace_music")
204         (iterator-ctor . ,Grace_iterator::constructor)
205         (types . (grace-music music-wrapper-music general-music))
206         ))
207     (NoteGroupingEvent
208      . (
209         (description . "Start or stop grouping brackets.")
210         (internal-class-name . "Event")
211         (types . (general-music event note-grouping-event))
212         ))
213     (HarmonicEvent
214      . (
215         (description . "Mark a note as harmonic")
216         (internal-class-name . "Event")
217         (types . (general-music event harmonic-event))
218         ))
219     (HyphenEvent
220      . (
221         (description .  "A hyphen between lyric syllables.")
223         (internal-class-name . "Event")
224         (types . (general-music hyphen-event event))
225         ))
226     
227     (KeyChangeEvent
228      . (
229         (description .  "Change the key signature. 
231 Syntax: @code{\\key } @var{name} @var{scale}.")
233         (internal-class-name . "Key_change_ev")
234         (types . (general-music key-change-event event))
235         ))
236     
237     (LigatureEvent
238      . (
239         (description .  "(docme).")
241         (internal-class-name . "Event")
242         (span-type . ligature)
243         (types . (general-music span-event ligature-event event))
244         ))
245     
246     (LyricCombineMusic
247      . (
248         (description .  "Align lyrics to the start of notes.
251 Syntax @var{\\addlyrics }@var{music} @var{lyrics}.")
253         (internal-class-name . "Lyric_combine_music")
254         (types . (general-music lyric-combine-music))
255         (iterator-ctor . ,Lyric_combine_music_iterator::constructor)
256         ))
257     
258     (NewLyricCombineMusic
259      . (
260         (description .  "Align lyrics to the start of notes.
263 Syntax @var{\\addlyrics }@var{music} @var{lyrics}.")
264         (internal-class-name . "Music")
265         (length . ,(ly:make-moment 0 1))
266         (types . (general-music lyric-combine-music))
267         (iterator-ctor . ,New_lyric_combine_music_iterator::constructor)
268         ))
270     (LyricEvent
271      . (
272         (description .  "A lyric syllable. Must be entered in lyrics mode, i.e.
273 @code{\\lyrics @{ twinkle4 twinkle4 @} } .")
275         (internal-class-name . "Event")
276         (types . (general-music rhythmic-event lyric-event event))
277         ))
278     (MarkEvent
279      . (
280         (description .  "Insert a rehearsal mark. 
282 Syntax: @code{\\mark} @var{marker},
283 e.g. @code{\\mark \"A\"}.")
285         (internal-class-name . "Event")
286         (types . (general-music mark-event event))
287         ))
288     (MelismaPlayingEvent
289      . (
290         (description .  "Used internally to signal melismas.")
291         (internal-class-name . "Event")
292         (types . (general-music melisma-playing-event event))
293         ))
294     (ManualMelismaEvent
295      . (
296         (description .  "Start or stop a melisma.
300 Syntax:@code{c4\\melisma d\\melismaEnd}.")
301         (internal-class-name . "Event")
302         (types . (general-music melisma-span-event event))
303         ))
304     
305     (MultiMeasureRestEvent
306      . (
307         (description . "Rests that may be compressed into Multi rests. 
309 Syntax
310 @code{R2.*4} for 4 measures in 3/4 time. Note the capital R.")
311         (internal-class-name . "Event")
312         (types . (general-music event rhythmic-event multi-measure-rest-event))
313         ))
314     
315     (MultiMeasureTextEvent
316      . (
317         (description . "Texts on mm rests. 
319 Syntax
320 @code{R-\\markup @{ \\roman \"bla\" @}}. Note the explicit font switch.")
321         (internal-class-name . "Event")
322         (types . (general-music event multi-measure-text-event))
323         ))
325     (Music
326      . (
327         (description .  "Generic type for music expressions.")
329         (internal-class-name . "Music")
330         (types . (general-music)) 
331         ))
332     (NoteEvent
333      . (
334         (description .  "A note.")
336         (internal-class-name . "Event")
337         (types . (general-music event note-event rhythmic-event melodic-event))
338         ))
339     
340     (OverrideProperty
341      . (
342         (description .  "Extend the definition of a graphical object.
344 SYNTAX
346 @code{\\propery Foo.Bar \\override} @var{SYMBOL} = @var{VALUE}
350         (internal-class-name . "Music")
351         (types . (general-music layout-instruction))
352         (iterator-ctor . ,      Push_property_iterator::constructor)
353         ))
354     (PartCombineMusic
355      . (
356         (description .  "Combine two parts on a staff, either merged or
357 as separate voices.")
359         (internal-class-name . "Simultaneous_music")
360         (types . (general-music part-combine-music))
361         (iterator-ctor . ,Part_combine_iterator::constructor)
362         ))
363     (PhrasingSlurEvent
364      . (
365         (description . "Start or end phrasing slur. 
367 Syntax NOTE \\(  and \\) NOTE")
368         (internal-class-name . "Event")
369         (types . (general-music span-event phrasing-slur-event))
370         ))
371     
372     (PropertySet
373      . (
374         (description .  "Set a context property.
378 Syntax: @code{\\property @var{context}.@var{prop} = @var{scheme-val}}.")
379         (internal-class-name . "Music")
380         (types . (layout-instruction general-music))
381         (iterator-ctor . ,Property_iterator::constructor)
382         )
383      )
384     
385     (PropertyUnset
386      . (
387         (description .  "Remove the definition of a context @code{\\property}.")
389         (internal-class-name . "Music")
390         (types . (layout-instruction general-music))
391         (iterator-ctor . ,Property_unset_iterator::constructor)
392         )
393      )
394     
395     (PesOrFlexaEvent
396      . (
397         (description .  "Within a ligature, mark the previous and the
398 following note to form a pes (if melody goes up) or a flexa (if melody
399 goes down).")
401         (internal-class-name . "Event")
402         (types . (general-music pes-or-flexa-event event))
403         ))
405     (QuoteMusic
406      . (
407         (description . "Quote preprocessed snippets of music. ")
408         (internal-class-name . "Event") ;;  so we get Event::get_length ().
409         (iterator-ctor . ,Quote_iterator::constructor)
410         (types . (general-music))
411         ))
412     
413     (RelativeOctaveCheck
414      . ((description . "Check if a pitch is in the correct octave.")
415         (internal-class-name . "Relative_octave_check")
416         (types . (general-music relative-octave-check))
417         ))
418     
419     (RepeatedMusic
420      . (
421         (description .  "Repeat music in different ways")
423         (type .  repeated-music)
424         (types . (general-music repeated-music))
425         ))
426     
427     (Event
428      . (
429         (description .  "Atomic music event.")
431         (internal-class-name . "Event")
432         (types . (general-music event))
433         ))
434     
435     (RestEvent
436      . (
437         (description .  "A Rest. 
439 Syntax @code{r4} for a quarter rest. ")
441         (internal-class-name . "Event")
442         (types . (general-music event rhythmic-event rest-event))
443         )) 
444     (SequentialMusic
445      . (
446         (description .  "Music expressions concatenated. 
448 Syntax \\sequential @{..@} or simply @{..@} .")
450         (internal-class-name . "Sequential_music")
451         (iterator-ctor . ,Sequential_music_iterator::constructor)
452         (types . (general-music sequential-music))
453         ))
454     
455     (MultiMeasureRestMusicGroup
456      . (
457         (description .  "Like sequential-music, but specifically intended
458 to group start-mmrest, skip, stop-mmrest sequence. 
460 Syntax @code{R2.*5} for 5 measures in 3/4 time.")
461         (internal-class-name . "Sequential_music")
462         (iterator-ctor . ,Sequential_music_iterator::constructor)
463         (types . (general-music sequential-music))
464         ))
466     (SoloOneEvent
467      . (
468         (description . "Print Solo.1")
469         (internal-class-name . "Event")
470         (part-combine-status . solo1)
471         (types . (general-music event part-combine-event))
472         ))
473     (SoloTwoEvent
474      . (
475         (description . "Print Solo.2")
476         (internal-class-name . "Event")
477         (part-combine-status . solo2)
478         (types . (general-music event part-combine-event))
479         ))
480     (UnisonoEvent
481      . ((description . "Print a2")
482         (internal-class-name .  "Event")
483         (part-combine-status . unisono)
484         (types . (general-music event part-combine-event))))
485     
486     (SimultaneousMusic
487      . (
488         (description .  "Music playing together.
490 SYNTAX
492 @code{ \\simultaneous @{ .. @}} or < .. >.")
494         (internal-class-name . "Simultaneous_music")
495         (iterator-ctor . ,Simultaneous_music_iterator::constructor)
496         
497         (types . (general-music simultaneous-music))
498         ))
499     
500     (SlurEvent
501      . (
502         (description . "Start or end slur. 
504 Syntax NOTE(     and )NOTE")
505         (internal-class-name . "Event")
506         (types . (general-music span-event slur-event))
507         ))
509     (RevertProperty
510      . (
511         (description .  "The opposite of @ref{OverrideProperty}: remove a
512 previously added property from a graphical object definition
513  ")
515         (internal-class-name . "Music")
516         (types . (general-music layout-instruction))
517         (iterator-ctor . ,      Pop_property_iterator::constructor)
518         ))
520     (OutputPropertySetMusic
521      . (
522         (description .  "Set grob properties in objects
523 individually. 
525 Syntax @code{\\outputproperty @var{predicate} @var{prop}
526 = @var{val}}.")
528         (internal-class-name . "Music")
529         (iterator-ctor . ,Output_property_music_iterator::constructor)
530         (types . (general-music layout-instruction))
531         ))
532     
533     (TextSpanEvent
534      . (
535         (description . "Start a text spanner like 8va.....|")
536         (internal-class-name . "Event")
537         (types . (general-music span-event text-span-event))
538         ))
539     
540     (ContextChange
541      . (
542         (description .  "Change staffs in Piano staff. 
544 Syntax @code{\\translator Staff = @var{new-id}}.")
545         (internal-class-name . "Music")
546         (iterator-ctor . , Change_iterator::constructor)
547         (types . (general-music translator-change-instruction))
548         ))
549     
550     (TimeScaledMusic
551      . (
552         (description .  "Multiply durations, as in tuplets. 
554 Syntax @code{\\times @var{fraction} @var{music}}, e.g.
555 @code{\\times 2/3 @{ ... @}} for triplets.
556  ")
557         (internal-class-name . "Time_scaled_music")
558         (iterator-ctor . ,Time_scaled_music_iterator::constructor)
559         (types . (time-scaled-music music-wrapper-music general-music))
560         ))
561     
562     (TransposedMusic
563      . (
564         (description .  "Music that has been transposed.")
565         (internal-class-name . "Transposed_music")
566         (types . (music-wrapper-music general-music transposed-music))
567         ))
569     (UntransposableMusic
570      . (
571         (description .  "Music that can not be transposed.")
573         (internal-class-name . "Untransposable_music")
574         (types . (music-wrapper-music general-music untransposable-music)) 
575         ))
577     (UnrelativableMusic
578      . (
579         (description .  "Music that can not be converted from relative to absolute notation.
580 For example, transposed music.")
581         (internal-class-name . "Un_relativable_music")
582         (types . (music-wrapper-music general-music unrelativable-music))
583         ))
585     (RelativeOctaveMusic
586      . (
587         (description .  "Music that was entered in relative octave notation.")
589         (internal-class-name . "Relative_octave_music")
590         (types . (music-wrapper-music general-music relative-octave-music))
591         ))
592     
593     (EventChord
594      . (
595         (description .  "Internally used to group a set of events.")
596         (internal-class-name . "Event_chord")
597         (iterator-ctor . ,Event_chord_iterator::constructor)
598         (types . (general-music event-chord simultaneous-music))
599         )
600      )
601     
602     (ScriptEvent
603      . (
604         (description .  "Add an articulation mark to a note. ")
606         (internal-class-name . "Event")
607         (types . (general-music event))
608         ))
610     (SkipMusic
611      . (
612         (description .  "Filler that takes up duration, does not print anything, and also
613 does not create staffs or voices implicitly.
617 Syntax: @code{\\skip }@var{duration}.")
618         (internal-class-name . "Music")
619         (length . ,ly:music-duration-length)
620         (iterator-ctor . ,Simple_music_iterator::constructor)
621         (types . (general-music event rhythmic-event skip-event))
622         ))
623      
624     (SkipEvent
625      . (
626         (description .  "Filler that takes up duration, but does not print anything.
630 Syntax: @code{s}@var{duration}")
632         (internal-class-name . "Event")
633         (types . (general-music event rhythmic-event skip-event))
634         ))
635     (SpanEvent
636      . (
637         (description .  "Event for anything that is started at a different time than stopped.")
639         (internal-class-name . "Event")
640         (types . (general-music event))
641         ))
642     
643     (SustainEvent
644      . (
645         (description . "Depress or release sustain pedal. ")
646         (internal-class-name . "Event")
647         (types . (general-music pedal-event sustain-pedal-event))
648         ))
649     
650     (SostenutoEvent
651      . (
652         (description . "Depress or release sostenuto pedal. ")
653         (internal-class-name . "Event")
654         (types . (general-music pedal-event sostenuto-pedal-event))
655         ))
656     
657     (UnaCordaEvent
658      . (
659         (description . "Depress or release una-corda pedal.")
660         (internal-class-name . "Event")
661         (types . (general-music pedal-event una-corda-pedal-event))
662         ))
663     
664     (StringNumberEvent
665      . (
666         (description .  "Specify on which string to play this note. 
668 Syntax: @code{\\@var{number}}.")
670         (internal-class-name . "Event")
671         (types . (general-music string-number-event event))
672         )) 
674     (MetronomeChangeEvent
675      . (
676         (description .  "Change tempo setting (in beats per minute).")
677         (internal-class-name . "Event")
678         (types . (general-music metronome-change-event tempo-event event))
679         ))
680     
681     (TextScriptEvent
682      . (
683         (description .  "")
684         (internal-class-name . "Event")
685         (types . (general-music script-event text-script-event event))
686         )) 
687     (TieEvent
688      . (
689         (description .  "A tie.  Entered as @var{note}-~.")
690         (internal-class-name . "Event")
691         (types . (general-music tie-event event))
692         ))
693     (TremoloEvent
694      . (
695         (description . "Un measured tremolo.")
696         (internal-class-name . "Event")
697         (types . (general-music event tremolo-event))
698         ))
699     
700     (VoiceSeparator
701      . (
702         (description .  "Separate polyphonic voices in simultaneous music. 
704 Syntax: @code{\\\\}")
706         (internal-class-name . "Music")
707         (types . (separator general-music))
708         ))
710     (VoltaRepeatedMusic
711      . (
712         (iterator-ctor . ,Volta_repeat_iterator::constructor)
713         (internal-class-name . "Repeated_music")
714         (description . "")
715         (start-moment-function .  ,Repeated_music::first_start)
716         (length . ,Repeated_music::volta_music_length)
717         (types . (general-music repeated-music volta-repeated-music))
718         ))
719     
720     (UnfoldedRepeatedMusic
721      . (
722         (iterator-ctor . ,Unfolded_repeat_iterator::constructor)
723         (description .  "")
724         (start-moment-function .  ,Repeated_music::first_start)
725         (internal-class-name . "Repeated_music")
726         (types . (general-music repeated-music unfolded-repeated-music))
727         (length . ,Repeated_music::unfolded_music_length)
728         ))
729     (PercentRepeatedMusic
730      . (
731         (internal-class-name . "Repeated_music")
732         (description .  "Repeats encoded by percents.")
733         (iterator-ctor . ,Percent_repeat_iterator::constructor)
734         (start-moment-function .  ,Repeated_music::first_start)
735         (length . ,Repeated_music::unfolded_music_length)
736         (types . (general-music repeated-music percent-repeated-music))
737         ))
738     
739     (TremoloRepeatedMusic
740      . (
741         (iterator-ctor . ,Chord_tremolo_iterator::constructor)
742         (description .  "Repeated notes denoted by tremolo beams.")
743         (internal-class-name . "Repeated_music")
744         (start-moment-function .  ,Repeated_music::first_start)
746         ;; the length of the repeat is handled by shifting the note logs
747         (length . ,Repeated_music::folded_music_length)
748         (types . (general-music repeated-music tremolo-repeated-music))
749         
750         ))
751     
752     (FoldedRepeatedMusic
753      . (
754         (internal-class-name . "Repeated_music")
755         (description .  "Repeats with alternatives placed in parallel. ")
756         (iterator-ctor  . ,Folded_repeat_iterator::constructor)
757         (start-moment-function .  ,Repeated_music::minimum_start)
758         (length . ,Repeated_music::folded_music_length)
759         (types . (general-music repeated-music folded-repeated-music))
760         ))
761     ))
763 (set! music-descriptions
764       (sort music-descriptions alist<?))
766 (define music-name-to-property-table (make-vector 59 '()))
769 ;; init hash table,
770 ;; transport description to an object property.
771 (set!
772  music-descriptions
773  (map (lambda (x)
774         (set-object-property! (car x)
775                               'music-description
776                               (cdr (assq 'description (cdr x))))
777         (let
778             ((l (cdr x)))
779           (set! l (assoc-set! l 'name (car x)))
780           (set! l (assq-remove!  l 'description))
781           (hashq-set! music-name-to-property-table (car x) l)
782           (cons (car x) l)
783           ))
784       music-descriptions))
786 (define-public (make-music name . music-properties)
787   "Create a music object of given name, and set its properties
788 according to `music-properties', a list of alterning property symbols
789 and values. E.g:
790   (make-music 'OverrideProperty 
791               'symbol 'Stem
792               'grob-property 'thickness
793               'grob-value (* 2 1.5))"
794   (if (not (symbol? name))
795       (error (format "Not a symbol: ~a" name)))
796   (let ((props (hashq-ref music-name-to-property-table name '())))
797     (if (not (pair? props))
798         (error "Can not find music object" name))
799     (let ((m (ly:make-bare-music (cdr (assoc 'internal-class-name props)) props)))
800       (define (set-props mus-props)
801         (if (and (not (null? mus-props))
802                  (not (null? (cdr mus-props))))
803             (begin
804               (set! (ly:music-property m (car mus-props)) (cadr mus-props))
805               (set-props (cddr mus-props)))))
806       (set-props music-properties)
807       m)))
810 (define-public (make-repeated-music name)
811   (let* ((handle (assoc name '(("volta" . VoltaRepeatedMusic)
812                                ("unfold" . UnfoldedRepeatedMusic)
813                                ("percent" . PercentRepeatedMusic)
814                                ("tremolo" . TremoloRepeatedMusic)
815                                ("fold" . FoldedRepeatedMusic))))
816          (music-name (if (pair? handle)
817                          (cdr handle)
818                          (begin
819                            (ly:warn (string-append "Unknown repeat type `" name
820                                                    "'\nSee music-types.scm for supported repeats"))
821                            'VoltaRepeatedMusic))))
822     (make-music music-name)))