]> git.donarmstrong.com Git - lilypond.git/blob - scm/clef.scm
53d0d6232cf8509d89fa08c3dfc84b9bf1726168
[lilypond.git] / scm / clef.scm
1 ;;
2 ;; (name . (glyph clef-position octavation))
3 ;; -- the name clefOctavation is misleading the value 7 is 1 octave not 7 Octaves.
4 ;;
5 (define supported-clefs '(
6           ("treble" . ("clefs-G" -2 0))
7           ("violin" . ("clefs-G" -2 0))
8           ("G" . ("clefs-G" -2 0))
9           ("G2" . ("clefs-G" -2 0))
10           ("french" . ("clefs-G" -4  0))
11           ("soprano" . ("clefs-C" -4  0))
12           ("mezzosoprano" . ("clefs-C" -2  0))
13           ("alto" . ("clefs-C" 0 0))
14           ("tenor" . ("clefs-C" 2 0))
15           ("baritone" . ("clefs-C" 4  0))
16           ("varbaritone"  . ("clefs-F" 0 0))
17           ("bass" . ("clefs-F" 2  0))
18           ("F" . ( "clefs-F" 2 0))
19           ("subbass" . ("clefs-F" 4 0))
20           ("percussion" . ("clefs-percussion" 0 0))
21           ("tab" . ("clefs-tab" 0 0))
22
23           ;; should move mensural stuff to separate file? 
24           ("vaticana_do1" . ("clefs-vaticana_do" -1 0))
25           ("vaticana_do2" . ("clefs-vaticana_do" 1 0))
26           ("vaticana_do3" . ("clefs-vaticana_do" 3 0))
27           ("vaticana_fa1" . ("clefs-vaticana_fa" -1 0))
28           ("vaticana_fa2" . ("clefs-vaticana_fa" 1 0))
29           ("medicaea_do1" . ("clefs-medicaea_do" -1 0))
30           ("medicaea_do2" . ("clefs-medicaea_do" 1 0))
31           ("medicaea_do3" . ("clefs-medicaea_do" 3 0))
32           ("medicaea_fa1" . ("clefs-medicaea_fa" -1 0))
33           ("medicaea_fa2" . ("clefs-medicaea_fa" 1 0))
34           ("hufnagel_do1" . ("clefs-hufnagel_do" -1 0))
35           ("hufnagel_do2" . ("clefs-hufnagel_do" 1 0))
36           ("hufnagel_do3" . ("clefs-hufnagel_do" 3 0))
37           ("hufnagel_fa1" . ("clefs-hufnagel_fa" -1 0))
38           ("hufnagel_fa2" . ("clefs-hufnagel_fa" 1 0))
39           ("hufnagel_do_fa" . ("clefs-hufnagel_do_fa" 4 0))
40           ("mensural1_c1" . ("clefs-mensural1_c" -4 0))
41           ("mensural1_c2" . ("clefs-mensural1_c" -2 0))
42           ("mensural1_c3" . ("clefs-mensural1_c" 0 0))
43           ("mensural1_c4" . ("clefs-mensural1_c" 2 0))
44           ("mensural2_c1" . ("clefs-mensural2_c" -4 0))
45           ("mensural2_c2" . ("clefs-mensural2_c" -2 0))
46           ("mensural2_c3" . ("clefs-mensural2_c" 0 0))
47           ("mensural2_c4" . ("clefs-mensural2_c" 2 0))
48           ("mensural2_c5" . ("clefs-mensural2_c" 4 0))
49           ("mensural3_c1" . ("clefs-mensural3_c" -2 0))
50           ("mensural3_c2" . ("clefs-mensural3_c" 0 0))
51           ("mensural3_c3" . ("clefs-mensural3_c" 2 0))
52           ("mensural3_c4" . ("clefs-mensural3_c" 4 0))
53           ("mensural1_f" . ("clefs-mensural1_f" 2 0))
54           ("mensural2_f" . ("clefs-mensural2_f" 2 0))
55           ("mensural_g" . ("clefs-mensural_g" -2 0))
56         )
57 )
58
59 (define (clef-name-to-properties cl)
60   (let ((e '())
61         (oct 0)
62         (l (string-length cl))
63         )
64
65     ;; ugh. cleanme
66     (if (equal? "8" (substring cl (- l 1) l))
67         (begin
68         (if (equal? "^" (substring cl (- l 2) (- l 1)))
69             (set! oct 7)
70             (set! oct -7))
71         
72         (set! cl (substring cl 0 (- l 2)))))
73
74
75     (set! e  (assoc cl supported-clefs))
76     (if (pair? e)
77         `(((symbol . clefGlyph)
78            (iterator-ctor . ,Property_iterator::constructor)
79            (value . ,(cadr e))
80            )
81           
82 ;         ((symbol . forceClef)
83 ;          (iterator-ctor . ,Property_iterator::constructor)
84 ;          (value . #t)
85 ;          )
86
87           ((symbol . clefPosition)
88            (iterator-ctor . ,Property_iterator::constructor)
89            (value . ,(caddr e))
90            )
91           ((symbol . clefOctavation)
92                  (iterator-ctor . ,Property_iterator::constructor)
93                  (value . ,oct)
94                )
95           )
96         (begin
97           (ly-warn (string-append "Unknown clef type `" cl "'\nSee scm/lily.scm for supported clefs"))
98           '())
99     )))
100
101