2 ;; (name . (glyph clef-position octavation))
4 ;; -- the name clefOctavation is misleading. The value 7 is 1 octave, not 7 Octaves.
6 (define supported-clefs '(
7 ("treble" . ("clefs-G" -2 0))
8 ("violin" . ("clefs-G" -2 0))
9 ("G" . ("clefs-G" -2 0))
10 ("G2" . ("clefs-G" -2 0))
11 ("french" . ("clefs-G" -4 0))
12 ("soprano" . ("clefs-C" -4 0))
13 ("mezzosoprano" . ("clefs-C" -2 0))
14 ("alto" . ("clefs-C" 0 0))
15 ("C" . ("clefs-C" 0 0))
16 ("tenor" . ("clefs-C" 2 0))
17 ("baritone" . ("clefs-C" 4 0))
18 ("varbaritone" . ("clefs-F" 0 0))
19 ("bass" . ("clefs-F" 2 0))
20 ("F" . ( "clefs-F" 2 0))
21 ("subbass" . ("clefs-F" 4 0))
22 ("percussion" . ("clefs-percussion" 0 0))
23 ("tab" . ("clefs-tab" 0 0))
25 ;; should move mensural stuff to separate file?
26 ("vaticana_do1" . ("clefs-vaticana_do" -1 0))
27 ("vaticana_do2" . ("clefs-vaticana_do" 1 0))
28 ("vaticana_do3" . ("clefs-vaticana_do" 3 0))
29 ("vaticana_fa1" . ("clefs-vaticana_fa" -1 0))
30 ("vaticana_fa2" . ("clefs-vaticana_fa" 1 0))
31 ("medicaea_do1" . ("clefs-medicaea_do" -1 0))
32 ("medicaea_do2" . ("clefs-medicaea_do" 1 0))
33 ("medicaea_do3" . ("clefs-medicaea_do" 3 0))
34 ("medicaea_fa1" . ("clefs-medicaea_fa" -1 0))
35 ("medicaea_fa2" . ("clefs-medicaea_fa" 1 0))
36 ("hufnagel_do1" . ("clefs-hufnagel_do" -1 0))
37 ("hufnagel_do2" . ("clefs-hufnagel_do" 1 0))
38 ("hufnagel_do3" . ("clefs-hufnagel_do" 3 0))
39 ("hufnagel_fa1" . ("clefs-hufnagel_fa" -1 0))
40 ("hufnagel_fa2" . ("clefs-hufnagel_fa" 1 0))
41 ("hufnagel_do_fa" . ("clefs-hufnagel_do_fa" 4 0))
42 ("mensural1_c1" . ("clefs-mensural1_c" -4 0))
43 ("mensural1_c2" . ("clefs-mensural1_c" -2 0))
44 ("mensural1_c3" . ("clefs-mensural1_c" 0 0))
45 ("mensural1_c4" . ("clefs-mensural1_c" 2 0))
46 ("mensural2_c1" . ("clefs-mensural2_c" -4 0))
47 ("mensural2_c2" . ("clefs-mensural2_c" -2 0))
48 ("mensural2_c3" . ("clefs-mensural2_c" 0 0))
49 ("mensural2_c4" . ("clefs-mensural2_c" 2 0))
50 ("mensural2_c5" . ("clefs-mensural2_c" 4 0))
51 ("mensural3_c1" . ("clefs-mensural3_c" -2 0))
52 ("mensural3_c2" . ("clefs-mensural3_c" 0 0))
53 ("mensural3_c3" . ("clefs-mensural3_c" 2 0))
54 ("mensural3_c4" . ("clefs-mensural3_c" 4 0))
55 ("mensural1_f" . ("clefs-mensural1_f" 2 0))
56 ("mensural2_f" . ("clefs-mensural2_f" 2 0))
57 ("mensural_g" . ("clefs-mensural_g" -2 0))
62 ;; "an alist mapping GLYPHNAME to the position of the central C for that symbol"
63 (define c0-pitch-alist
67 ("clefs-percussion" . 0)
68 ("clefs-vaticana_do" . 0)
69 ("clefs-vaticana_fa" . 4)
70 ("clefs-medicaea_do" . 0)
71 ("clefs-medicaea_fa" . 4)
72 ("clefs-hufnagel_do" . 0)
73 ("clefs-hufnagel_fa" . 4)
74 ("clefs-hufnagel_do_fa" . 0)
75 ("clefs-mensural1_c" . 0)
76 ("clefs-mensural2_c" . 0)
77 ("clefs-mensural3_c" . 0)
78 ("clefs-mensural1_f" . 4)
79 ("clefs-mensural2_f" . 4)
80 ("clefs-mensural_g" . -4))
83 (define (clef-name-to-properties cl)
87 (l (string-length cl))
91 (if (equal? "8" (substring cl (- l 1) l))
93 (if (equal? "^" (substring cl (- l 2) (- l 1)))
97 (set! cl (substring cl 0 (- l 2)))))
100 (set! e (assoc cl supported-clefs))
103 `(((symbol . clefGlyph)
104 (iterator-ctor . ,Property_iterator::constructor)
108 ((symbol . centralCPosition)
109 (iterator-ctor . ,Property_iterator::constructor)
110 (value . ,(+ oct (caddr e) (cdr (assoc (cadr e) c0-pitch-alist))))
112 ((symbol . clefPosition)
113 (iterator-ctor . ,Property_iterator::constructor)
116 ((symbol . clefOctavation)
117 (iterator-ctor . ,Property_iterator::constructor)
122 (ly-warn (string-append "Unknown clef type `" cl "'\nSee scm/lily.scm for supported clefs"))