]> git.donarmstrong.com Git - lilypond.git/blob - scm/define-music-types.scm
input/test fixes
[lilypond.git] / scm / define-music-types.scm
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>
7
8
9 ;; TODO: should link back into user manual.
10
11 (define-public music-descriptions
12   `(
13     (AbsoluteDynamicEvent
14      . (
15    (description . "Creates a dynamic mark.
16
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.
33
34 Syntax
35
36 \\applyoutput FUNC
37
38 arguments to func are 1. the grob, 2. the originating context,
39 3. context where FUNC is called.
40
41 ")
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.
49
50 Syntax:
51 @var{note}-@code{\\arpeggio}")
52         (internal-class-name .  "Event")
53         (types . (general-music arpeggio-event event))
54         ))
55
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.  
61
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.")
67
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.")
74
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")
90
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.  
97
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 .  "Create a line break, Syntax: \\break or page break, Syntax: \\pagebreak.")
106
107         (internal-class-name . "Event")
108         (types . (general-music break-event event))
109         ))
110     (BreathingSignEvent
111      . (
112         (description .  "Creates a `breath mark' or `comma'.  
113
114 Syntax:
115 @var{note}\\breathe.")
116
117         (internal-class-name . "Event")
118         (types . (general-music event breathing-event))
119         )) 
120     (BusyPlayingEvent
121      . (
122         (description .  "Used internally to signal beginning and ending of notes.")
123
124         (internal-class-name . "Event")
125         (types . (general-music event busy-playing-event))
126         ))
127     (ContextChange
128      . (
129         (description .  "Change staffs in Piano staff. 
130
131 Syntax @code{\\translator Staff = @var{new-id}}.")
132         (internal-class-name . "Music")
133         (iterator-ctor . , Change_iterator::constructor)
134         (types . (general-music translator-change-instruction))
135         ))
136
137     (ClusterNoteEvent
138      . (
139         (description .  "A note that is part of a cluster.")
140         (internal-class-name . "Event")
141
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.  
157
158 Syntax: @var{note}\\cr
159 ... @var{note}\\rc (you can also use \\<, \\!, \\cresc, and
160 \\endcresc.  See the user manual for details.).")
161
162         (internal-class-name . "Event")
163         (types . (general-music dynamic-event crescendo-event event))
164         )) 
165     (DecrescendoEvent
166      . (
167         (description .  "See @ref{CrescendoEvent}.")
168
169         (internal-class-name . "Event")
170         (types . (general-music dynamic-event decrescendo-event event))
171         ))
172  
173     (ExtenderEvent
174      . (
175         (description .  "Extend lyrics.")
176
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. ")
202
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.")
222
223         (internal-class-name . "Event")
224         (types . (general-music hyphen-event event))
225         ))
226     
227     (KeyChangeEvent
228      . (
229         (description .  "Change the key signature. 
230
231 Syntax: @code{\\key } @var{name} @var{scale}.")
232
233         (internal-class-name . "Key_change_ev")
234         (types . (general-music key-change-event event))
235         ))
236     
237     (LigatureEvent
238      . (
239         (description .  "(docme).")
240
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.
249
250
251 Syntax @var{\\addlyrics }@var{music} @var{lyrics}.")
252
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.
261
262
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         ))
269
270     (LyricEvent
271      . (
272         (description .  "A lyric syllable. Must be entered in lyrics mode, i.e.
273 @code{\\lyrics @{ twinkle4 twinkle4 @} } .")
274
275         (internal-class-name . "Event")
276         (types . (general-music rhythmic-event lyric-event event))
277         ))
278     (MarkEvent
279      . (
280         (description .  "Insert a rehearsal mark. 
281
282 Syntax: @code{\\mark} @var{marker},
283 e.g. @code{\\mark \"A\"}.")
284
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.
297
298
299
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. 
308
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. 
318
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         ))
324
325     (Music
326      . (
327         (description .  "Generic type for music expressions.")
328
329         (internal-class-name . "Music")
330         (types . (general-music)) 
331         ))
332     (NoteEvent
333      . (
334         (description .  "A note.")
335
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.
343
344 SYNTAX
345
346 @code{\\propery Foo.Bar \\override} @var{SYMBOL} = @var{VALUE}
347
348 ")
349
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.")
358
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. 
366
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.
375
376
377
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}.")
388
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).")
400
401         (internal-class-name . "Event")
402         (types . (general-music pes-or-flexa-event event))
403         ))
404
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")
422
423         (type .  repeated-music)
424         (types . (general-music repeated-music))
425         ))
426     
427     (Event
428      . (
429         (description .  "Atomic music event.")
430
431         (internal-class-name . "Event")
432         (types . (general-music event))
433         ))
434     
435     (RestEvent
436      . (
437         (description .  "A Rest. 
438
439 Syntax @code{r4} for a quarter rest. ")
440
441         (internal-class-name . "Event")
442         (types . (general-music event rhythmic-event rest-event))
443         )) 
444     (RevertProperty
445      . (
446         (description .  "The opposite of @ref{OverrideProperty}: remove a
447 previously added property from a graphical object definition
448  ")
449
450         (internal-class-name . "Music")
451         (types . (general-music layout-instruction))
452         (iterator-ctor . ,      Pop_property_iterator::constructor)
453         ))
454
455     (SequentialMusic
456      . (
457         (description .  "Music expressions concatenated. 
458
459 Syntax \\sequential @{..@} or simply @{..@} .")
460
461         (internal-class-name . "Sequential_music")
462         (iterator-ctor . ,Sequential_music_iterator::constructor)
463         (types . (general-music sequential-music))
464         ))
465     
466     (MultiMeasureRestMusicGroup
467      . (
468         (description .  "Like sequential-music, but specifically intended
469 to group start-mmrest, skip, stop-mmrest sequence. 
470
471 Syntax @code{R2.*5} for 5 measures in 3/4 time.")
472         (internal-class-name . "Sequential_music")
473         (iterator-ctor . ,Sequential_music_iterator::constructor)
474         (types . (general-music sequential-music))
475         ))
476
477     (SoloOneEvent
478      . (
479         (description . "Print Solo.1")
480         (internal-class-name . "Event")
481         (part-combine-status . solo1)
482         (types . (general-music event part-combine-event))
483         ))
484     (SoloTwoEvent
485      . (
486         (description . "Print Solo.2")
487         (internal-class-name . "Event")
488         (part-combine-status . solo2)
489         (types . (general-music event part-combine-event))
490         ))
491     (UnisonoEvent
492      . ((description . "Print a2")
493         (internal-class-name .  "Event")
494         (part-combine-status . unisono)
495         (types . (general-music event part-combine-event))))
496     
497     (SimultaneousMusic
498      . (
499         (description .  "Music playing together.
500
501 SYNTAX
502
503 @code{ \\simultaneous @{ .. @}} or < .. >.")
504
505         (internal-class-name . "Simultaneous_music")
506         (iterator-ctor . ,Simultaneous_music_iterator::constructor)
507         
508         (types . (general-music simultaneous-music))
509         ))
510     
511     (SlurEvent
512      . (
513         (description . "Start or end slur. 
514
515 Syntax NOTE(     and )NOTE")
516         (internal-class-name . "Event")
517         (types . (general-music span-event slur-event))
518         ))
519
520     (StartPlayingEvent
521      . (
522         (description .  "Used internally to signal beginning of notes.")
523
524         (internal-class-name . "Event")
525         (types . (general-music event start-playing-event))
526         ))
527     
528     (OutputPropertySetMusic
529      . (
530         (description .  "Set grob properties in objects
531 individually. 
532
533 Syntax @code{\\outputproperty @var{predicate} @var{prop}
534 = @var{val}}.")
535
536         (internal-class-name . "Music")
537         (iterator-ctor . ,Output_property_music_iterator::constructor)
538         (types . (general-music layout-instruction))
539         ))
540     
541     (TextSpanEvent
542      . (
543         (description . "Start a text spanner like 8va.....|")
544         (internal-class-name . "Event")
545         (types . (general-music span-event text-span-event))
546         ))
547     
548     (TrillSpanEvent
549      . (
550         (description . "Start a trill spanner tr~~~")
551         (internal-class-name . "Event")
552         (types . (general-music span-event trill-span-event))
553         ))
554     
555     (TimeScaledMusic
556      . (
557         (description .  "Multiply durations, as in tuplets. 
558
559 Syntax @code{\\times @var{fraction} @var{music}}, e.g.
560 @code{\\times 2/3 @{ ... @}} for triplets.
561  ")
562         (internal-class-name . "Time_scaled_music")
563         (iterator-ctor . ,Time_scaled_music_iterator::constructor)
564         (types . (time-scaled-music music-wrapper-music general-music))
565         ))
566     
567     (TransposedMusic
568      . (
569         (description .  "Music that has been transposed.")
570         (internal-class-name . "Transposed_music")
571         (types . (music-wrapper-music general-music transposed-music))
572         ))
573
574     (UntransposableMusic
575      . (
576         (description .  "Music that can not be transposed.")
577
578         (internal-class-name . "Untransposable_music")
579         (types . (music-wrapper-music general-music untransposable-music)) 
580         ))
581
582     (UnrelativableMusic
583      . (
584         (description .  "Music that can not be converted from relative to absolute notation.
585 For example, transposed music.")
586         (internal-class-name . "Un_relativable_music")
587         (types . (music-wrapper-music general-music unrelativable-music))
588         ))
589
590     (RelativeOctaveMusic
591      . (
592         (description .  "Music that was entered in relative octave notation.")
593
594         (internal-class-name . "Relative_octave_music")
595         (types . (music-wrapper-music general-music relative-octave-music))
596         ))
597     
598     (EventChord
599      . (
600         (description .  "Internally used to group a set of events.")
601         (internal-class-name . "Event_chord")
602         (iterator-ctor . ,Event_chord_iterator::constructor)
603         (types . (general-music event-chord simultaneous-music))
604         )
605      )
606     
607     (ScriptEvent
608      . (
609         (description .  "Add an articulation mark to a note. ")
610
611         (internal-class-name . "Event")
612         (types . (general-music event))
613         ))
614
615     (SkipMusic
616      . (
617         (description .  "Filler that takes up duration, does not print anything, and also
618 does not create staffs or voices implicitly.
619
620
621
622 Syntax: @code{\\skip }@var{duration}.")
623         (internal-class-name . "Music")
624         (length . ,ly:music-duration-length)
625         (iterator-ctor . ,Simple_music_iterator::constructor)
626         (types . (general-music event rhythmic-event skip-event))
627         ))
628      
629     (SkipEvent
630      . (
631         (description .  "Filler that takes up duration, but does not print anything.
632
633
634
635 Syntax: @code{s}@var{duration}")
636
637         (internal-class-name . "Event")
638         (types . (general-music event rhythmic-event skip-event))
639         ))
640     (SpanEvent
641      . (
642         (description .  "Event for anything that is started at a different time than stopped.")
643
644         (internal-class-name . "Event")
645         (types . (general-music event))
646         ))
647     
648     (SustainEvent
649      . (
650         (description . "Depress or release sustain pedal. ")
651         (internal-class-name . "Event")
652         (types . (general-music pedal-event sustain-pedal-event))
653         ))
654     
655     (SostenutoEvent
656      . (
657         (description . "Depress or release sostenuto pedal. ")
658         (internal-class-name . "Event")
659         (types . (general-music pedal-event sostenuto-pedal-event))
660         ))
661     
662     (UnaCordaEvent
663      . (
664         (description . "Depress or release una-corda pedal.")
665         (internal-class-name . "Event")
666         (types . (general-music pedal-event una-corda-pedal-event))
667         ))
668     
669     (StringNumberEvent
670      . (
671         (description .  "Specify on which string to play this note. 
672
673 Syntax: @code{\\@var{number}}.")
674
675         (internal-class-name . "Event")
676         (types . (general-music string-number-event event))
677         )) 
678
679     (MetronomeChangeEvent
680      . (
681         (description .  "Change tempo setting (in beats per minute).")
682         (internal-class-name . "Event")
683         (types . (general-music metronome-change-event tempo-event event))
684         ))
685     
686     (TextScriptEvent
687      . (
688         (description .  "")
689         (internal-class-name . "Event")
690         (types . (general-music script-event text-script-event event))
691         )) 
692     (TieEvent
693      . (
694         (description .  "A tie.  Entered as @var{note}-~.")
695         (internal-class-name . "Event")
696         (types . (general-music tie-event event))
697         ))
698     (TremoloEvent
699      . (
700         (description . "Un measured tremolo.")
701         (internal-class-name . "Event")
702         (types . (general-music event tremolo-event))
703         ))
704     
705     (VoiceSeparator
706      . (
707         (description .  "Separate polyphonic voices in simultaneous music. 
708
709 Syntax: @code{\\\\}")
710
711         (internal-class-name . "Music")
712         (types . (separator general-music))
713         ))
714
715     (VoltaRepeatedMusic
716      . (
717         (iterator-ctor . ,Volta_repeat_iterator::constructor)
718         (internal-class-name . "Repeated_music")
719         (description . "")
720         (start-moment-function .  ,Repeated_music::first_start)
721         (length . ,Repeated_music::volta_music_length)
722         (types . (general-music repeated-music volta-repeated-music))
723         ))
724     
725     (UnfoldedRepeatedMusic
726      . (
727         (iterator-ctor . ,Unfolded_repeat_iterator::constructor)
728         (description .  "")
729         (start-moment-function .  ,Repeated_music::first_start)
730         (internal-class-name . "Repeated_music")
731         (types . (general-music repeated-music unfolded-repeated-music))
732         (length . ,Repeated_music::unfolded_music_length)
733         ))
734     (PercentRepeatedMusic
735      . (
736         (internal-class-name . "Repeated_music")
737         (description .  "Repeats encoded by percents.")
738         (iterator-ctor . ,Percent_repeat_iterator::constructor)
739         (start-moment-function .  ,Repeated_music::first_start)
740         (length . ,Repeated_music::unfolded_music_length)
741         (types . (general-music repeated-music percent-repeated-music))
742         ))
743     
744     (TremoloRepeatedMusic
745      . (
746         (iterator-ctor . ,Chord_tremolo_iterator::constructor)
747         (description .  "Repeated notes denoted by tremolo beams.")
748         (internal-class-name . "Repeated_music")
749         (start-moment-function .  ,Repeated_music::first_start)
750
751         ;; the length of the repeat is handled by shifting the note logs
752         (length . ,Repeated_music::folded_music_length)
753         (types . (general-music repeated-music tremolo-repeated-music))
754         
755         ))
756     
757     (FoldedRepeatedMusic
758      . (
759         (internal-class-name . "Repeated_music")
760         (description .  "Repeats with alternatives placed in parallel. ")
761         (iterator-ctor  . ,Folded_repeat_iterator::constructor)
762         (start-moment-function .  ,Repeated_music::minimum_start)
763         (length . ,Repeated_music::folded_music_length)
764         (types . (general-music repeated-music folded-repeated-music))
765         ))
766     ))
767
768 (set! music-descriptions
769       (sort music-descriptions alist<?))
770
771 (define music-name-to-property-table (make-vector 59 '()))
772
773
774 ;; init hash table,
775 ;; transport description to an object property.
776 (set!
777  music-descriptions
778  (map (lambda (x)
779         (set-object-property! (car x)
780                               'music-description
781                               (cdr (assq 'description (cdr x))))
782         (let
783             ((l (cdr x)))
784           (set! l (assoc-set! l 'name (car x)))
785           (set! l (assq-remove!  l 'description))
786           (hashq-set! music-name-to-property-table (car x) l)
787           (cons (car x) l)
788           ))
789       music-descriptions))
790
791 (define-public (make-music name . music-properties)
792   "Create a music object of given name, and set its properties
793 according to `music-properties', a list of alterning property symbols
794 and values. E.g:
795   (make-music 'OverrideProperty 
796               'symbol 'Stem
797               'grob-property 'thickness
798               'grob-value (* 2 1.5))"
799   (if (not (symbol? name))
800       (error (format "Not a symbol: ~a" name)))
801   (let ((props (hashq-ref music-name-to-property-table name '())))
802     (if (not (pair? props))
803         (error "Can not find music object" name))
804     (let ((m (ly:make-bare-music (cdr (assoc 'internal-class-name props)) props)))
805       (define (set-props mus-props)
806         (if (and (not (null? mus-props))
807                  (not (null? (cdr mus-props))))
808             (begin
809               (set! (ly:music-property m (car mus-props)) (cadr mus-props))
810               (set-props (cddr mus-props)))))
811       (set-props music-properties)
812       m)))
813
814
815 (define-public (make-repeated-music name)
816   (let* ((handle (assoc name '(("volta" . VoltaRepeatedMusic)
817                                ("unfold" . UnfoldedRepeatedMusic)
818                                ("percent" . PercentRepeatedMusic)
819                                ("tremolo" . TremoloRepeatedMusic)
820                                ("fold" . FoldedRepeatedMusic))))
821          (music-name (if (pair? handle)
822                          (cdr handle)
823                          (begin
824                            (ly:warn "Unknown repeat type `~S'\nSee music-types.scm for supported repeats" name)
825                            'VoltaRepeatedMusic))))
826     (make-music music-name)))
827