]> git.donarmstrong.com Git - lilypond.git/blob - ly/music-functions-init.ly
input/test fixes
[lilypond.git] / ly / music-functions-init.ly
1 \version "2.3.8"
2
3
4 applymusic = #(def-music-function (location func music) (procedure? ly:music?)
5                (func music))
6
7 addlyrics = #(def-music-function (location music lyrics) (ly:music? ly:music?)
8               (make-music 'LyricCombineMusic 
9                           'origin location
10                           'elements (list music lyrics)))
11
12 grace = #(def-grace-function startGraceMusic stopGraceMusic)
13 acciaccatura = #(def-grace-function startAcciaccaturaMusic stopAcciaccaturaMusic)
14 appoggiatura = #(def-grace-function startAppoggiaturaMusic stopAppoggiaturaMusic)
15
16 partcombine = #(def-music-function (location part1 part2) (ly:music? ly:music?)
17                 (make-part-combine-music (list part1 part2)))
18
19 autochange = #(def-music-function (location music) (ly:music?)
20                (make-autochange-music music))
21
22 applycontext = #(def-music-function (location proc) (procedure?)
23                  (make-music 'ApplyContext 
24                    'origin location
25                    'procedure proc))
26
27 applyoutput = #(def-music-function (location proc) (procedure?)
28                 (make-music 'ApplyOutputEvent 
29                   'origin location
30                   'procedure proc))
31
32 breathe = #(def-music-function (location) ()
33             (make-music 'EventChord 
34               'origin location
35               'elements (list (make-music 'BreathingSignEvent))))
36
37
38 unfoldrepeats = #(def-music-function (location music) (ly:music?)
39                   (unfold-repeats music))
40
41 compressmusic = #(def-music-function
42                   (location fraction music) (number-pair? ly:music?)
43                   (ly:music-compress music (ly:make-moment (car fraction) (cdr fraction))))
44
45
46 %% \mytag #'foo { ... } ==> OK
47 %% c-\mytag #'foo ^4    ==> KO
48 %{
49 #(use-modules (srfi srfi-1))
50 #(define-public (symbol-or-symbols? obj)
51   "Return #t iif obj is a symbol or a symbol list."
52   (or (symbol? obj)
53       (and (list? obj)
54            (null? (remove symbol? obj)))))
55
56 mytag = #(def-music-function (location tagname music) (symbol-or-symbols? ly:music?)
57         (set! (ly:music-property music 'tags)
58               ((if (list? tagname) append cons) tagname (ly:music-property music 'tags)))
59         music)
60 %}
61
62 %{
63
64 TODO:
65
66 remove these from the parser, and softcode here:
67
68  * \tag
69
70 with small syntax changes, we could also do
71
72  * \bar
73  *  ?
74
75 %}