- (list (cons 'font-encoding (car x)))
- (cons (* factor (cadr x))
- (caddr x))))
- `(
- (fetaNumber 20
- #(
- ,(delay (ly:font-load "feta-alphabet11"))
- ,(delay (ly:font-load "feta-alphabet13"))
- ,(delay (ly:font-load "feta-alphabet14"))
- ,(delay (ly:font-load "feta-alphabet16"))
- ,(delay (ly:font-load "feta-alphabet18"))
- ,(delay (ly:font-load "feta-alphabet20"))
- ,(delay (ly:font-load "feta-alphabet23"))
- ,(delay (ly:font-load "feta-alphabet26"))))
-
- (fetaDynamic 20.0 #(
- ,(delay (ly:font-load "feta-alphabet11"))
- ,(delay (ly:font-load "feta-alphabet13"))
- ,(delay (ly:font-load "feta-alphabet14"))
- ,(delay (ly:font-load "feta-alphabet16"))
- ,(delay (ly:font-load "feta-alphabet18"))
- ,(delay (ly:font-load "feta-alphabet20"))
- ,(delay (ly:font-load "feta-alphabet23"))
- ,(delay (ly:font-load "feta-alphabet26"))))
-
- (fetaMusic 20.0
- #(
- ,(delay (ly:font-load "bigcheese11"))
- ,(delay (ly:font-load "bigcheese13"))
- ,(delay (ly:font-load "bigcheese14"))
- ,(delay (ly:font-load "bigcheese16"))
- ,(delay (ly:font-load "bigcheese18"))
- ,(delay (ly:font-load "bigcheese20"))
- ,(delay (ly:font-load "bigcheese23"))
- ,(delay (ly:font-load "bigcheese26"))))
-
- (fetaBraces 100.0 #(,(delay
- (ly:font-load "aybabtu")))))))
-
-(define-public (add-cmr-fonts node factor)
- (add-font node '((font-encoding . TeX-math))
- `(,(* factor 10) . #(,(delay (ly:font-load "msam10")))))
- (for-each
- (lambda (x)
- (add-font node `((font-encoding . TeX-text)
- (font-series . ,(vector-ref (car x) 2))
- (font-shape . ,(vector-ref (car x) 1))
- (font-family . ,(vector-ref (car x) 0)))
- (cons (* factor (cadr x))
- (cddr x))))
- `((#(roman upright medium)
- . (10.0 . #(,(delay (ly:font-load "cmr6"))
- ,(delay (ly:font-load "cmr8"))
- ,(delay (ly:font-load "cmr10"))
- ,(delay (ly:font-load "cmr17")))))
- (#(roman upright bold)
- . (10.0 . #(,(delay (ly:font-load "cmbx6"))
- ,(delay (ly:font-load "cmbx8"))
- ,(delay (ly:font-load "cmbx10"))
- ,(delay (ly:font-load "cmbx12")))))
- (#(roman italic medium)
- . (10.0 . #(,(delay (ly:font-load "cmti7"))
- ,(delay (ly:font-load "cmti10"))
- ,(delay (ly:font-load "cmti12")))))
- (#(roman italic bold)
- . (10.0 . #(,(delay (ly:font-load "cmbxti8"))
- ,(delay (ly:font-load "cmbxti10"))
- ,(delay (ly:font-load "cmbxti14")))))
- (#(roman caps medium)
- . (10.0 . #(,(delay (ly:font-load "cmcsc10")))))
- (#(roman upright bold-narrow )
- . (10.0 . #(,(delay (ly:font-load "cmb10")))))
- (#(sans upright medium)
- . (10.0 . #(,(delay (ly:font-load "cmss8"))
- ,(delay (ly:font-load "cmss10"))
- ,(delay (ly:font-load "cmss12"))
- ,(delay (ly:font-load "cmss17")))))
- (#(typewriter upright medium)
- . (10.0 . #(,(delay (ly:font-load "cmtt8"))
- ,(delay (ly:font-load "cmtt10"))
- ,(delay (ly:font-load "cmtt12"))))))))
-
-;; Debian lmodern font support.
-(define-public (add-cork-lm-fonts node factor)
- (for-each
- (lambda (x)
- (add-font node `((font-encoding . cork-lm)
- (font-series . ,(vector-ref (car x) 2))
- (font-shape . ,(vector-ref (car x) 1))
- (font-family . ,(vector-ref (car x) 0)))
- (cons (* factor (cadr x)) (cddr x))))
- `((#(roman upright medium)
- . (10.0 . #(,(delay (ly:font-load "lmr6"))
- ,(delay (ly:font-load "lmr8"))
- ,(delay (ly:font-load "lmr10"))
- ,(delay (ly:font-load "lmr17")))))
- (#(roman upright bold)
- . (10.0 . #(,(delay (ly:font-load "lmbx6"))
- ,(delay (ly:font-load "lmbx8"))
- ,(delay (ly:font-load "lmbx10"))
- ,(delay (ly:font-load "lmbx12")))))
- (#(roman italic medium)
- . (10.0 . #(,(delay (ly:font-load "lmri7"))
- ,(delay (ly:font-load "lmri10"))
- ,(delay (ly:font-load "lmri12")))))
- (#(roman italic bold)
- . (10.0 . #(,(delay (ly:font-load "lmbxi10")))))
- (#(roman caps medium)
- . (10.0 . #(,(delay (ly:font-load "lmcsc10")))))
- (#(roman upright bold-narrow )
- . (10.0 . #(,(delay (ly:font-load "lmb10")))))
- (#(sans upright medium)
- . (10.0 . #(,(delay (ly:font-load "lmss8"))
- ,(delay (ly:font-load "lmss10"))
- ,(delay (ly:font-load "lmss12"))
- ,(delay (ly:font-load "lmss17")))))
- (#(sans upright bold)
- . (10.0 . #(,(delay (ly:font-load "lmssbx10")))))
-
- (#(typewriter upright medium)
- . (10.0 . #(,(delay (ly:font-load "lmtt8"))
- ,(delay (ly:font-load "lmtt10"))
- ,(delay (ly:font-load "lmtt12"))))))))
-
-;; ec-fonts-mftraced font support.
-(define-public (add-ec-fonts node factor)
- (for-each
- (lambda (x) (add-font node
- `((font-encoding . Extended-TeX-Font-Encoding---Latin)
- (font-series . ,(vector-ref (car x) 2))
- (font-shape . ,(vector-ref (car x) 1))
- (font-family . ,(vector-ref (car x) 0)))
- (cons (* factor (cadr x)) (cddr x))))
-
- `((#(roman upright medium)
- . (10.0 . #(,(delay (ly:font-load "ecrm6"))
- ,(delay (ly:font-load "ecrm8"))
- ,(delay (ly:font-load "ecrm10"))
- ,(delay (ly:font-load "ecrm17")))))
- (#(roman upright bold)
- . (10.0 . #(,(delay (ly:font-load "ecbx6"))
- ,(delay (ly:font-load "ecbx8"))
- ,(delay (ly:font-load "ecbx10"))
- ,(delay (ly:font-load "ecbx12")))))
- (#(roman italic medium)
- . (10.0 . #(,(delay (ly:font-load "ecti7"))
- ,(delay (ly:font-load "ecti10"))
- ,(delay (ly:font-load "ecti12")))))
- (#(roman italic bold)
- . (10.0 . #(,(delay (ly:font-load "ecbi8"))
- ,(delay (ly:font-load "ecbi10"))
- ,(delay (ly:font-load "ecbi14")))))
- (#(roman caps medium)
- . (10.0 . #(,(delay (ly:font-load "eccc10")))))
- (#(roman slanted-caps medium)
- . (10.0 . #(,(delay (ly:font-load "ecsc10")))))
- (#(roman upright bold-narrow )
- . (10.0 . #(,(delay (ly:font-load "ecrb10")))))
- (#(sans upright medium)
- . (10.0 . #(,(delay (ly:font-load "ecss8"))
- ,(delay (ly:font-load "ecss10"))
- ,(delay (ly:font-load "ecss12"))
- ,(delay (ly:font-load "ecss17")))))
- (#(typewriter upright medium)
- . (10.0 . #(,(delay (ly:font-load "ectt8"))
- ,(delay (ly:font-load "ectt10"))
- ,(delay (ly:font-load "ectt12"))))))))
-
-;; (display (make-font-tree 1.0))
-
-;; Century Schoolbook fonts file names on Debian/Sid
-(define-public (add-century-schoolbook-fonts node factor)
- (add-font node
- '((font-family . roman)
- (font-shape . upright)
- (font-series . medium)
- (font-encoding . latin1))
- `(10.0 . #(,(delay (ly:font-load "uncr8a")))))
- (add-font node
- '((font-family . roman)
- (font-shape . italic)
- (font-series . medium)
- (font-encoding . latin1))
- `(10.0 . #(,(delay (ly:font-load "uncri8a")))))
- (add-font node
- '((font-family . roman)
- (font-shape . upright)
- (font-series . bold)
- (font-encoding . latin1))
- `(10.0 . #(,(delay (ly:font-load "uncb8a")))))
- (add-font node
- '((font-family . roman)
- (font-shape . italic)
- (font-series . bold)
- (font-encoding . latin1))
- `(10.0 . #(,(delay (ly:font-load "uncbi8a"))))))
-
-(define-public (make-cmr-tree factor)
+ (list (cons 'font-encoding (car x))
+ (cons 'font-family family))
+ (cons (* factor (cadr x))
+ (caddr x))))
+
+ `((fetaText ,(ly:pt 20.0)
+ ,(list->vector
+ (map (lambda (tup)
+ (cons (ly:pt (cdr tup))
+ (format #f "~a-~a ~a"
+ name
+ (car tup)
+ (ly:pt (cdr tup)))))
+ design-size-alist)))
+ (fetaMusic ,(ly:pt 20.0)
+ ,(list->vector
+ (map (lambda (size-tup)
+ (delay (ly:system-font-load
+ (format #f "~a-~a" name (car size-tup)))))
+ design-size-alist
+ )))
+ (fetaBraces ,(ly:pt 20.0)
+ #(,(delay (ly:system-font-load
+ (format #f "~a-brace" brace)))))
+ )))
+
+(define-public (add-pango-fonts node lily-family family factor)
+ ;; Synchronized with the `text-font-size' variable in
+ ;; layout-set-absolute-staff-size-in-module (see paper.scm).
+ (define text-font-size (ly:pt (* factor 11.0)))
+
+ (define (add-node shape series)
+ (add-font node
+ `((font-family . ,lily-family)
+ (font-shape . ,shape)
+ (font-series . ,series)
+ (font-encoding . latin1) ;; ugh.
+ )
+ `(,text-font-size
+ . #(,(cons
+ (ly:pt 12)
+ (ly:make-pango-description-string
+ `(((font-family . ,family)
+ (font-series . ,series)
+ (font-shape . ,shape)))
+ (ly:pt 12)))))))
+
+ (add-node 'upright 'normal)
+ (add-node 'caps 'normal)
+ (add-node 'upright 'bold)
+ (add-node 'italic 'normal)
+ (add-node 'italic 'bold))
+
+; This function allows the user to change the specific fonts, leaving others
+; to the default values. This way, "make-pango-font-tree"'s syntax doesn't
+; have to change from the user's perspective.
+;
+; Usage:
+; \paper {
+; #(define fonts
+; (set-global-fonts
+; #:music "gonville" ; (the main notation font)
+; #:roman "FreeSerif" ; (the main/serif text font)
+; ))
+; }
+;
+; Leaving out "#:brace", "#:sans", and "#:typewriter" leave them at
+; "emmentaler", "sans-serif", and "monospace", respectively. All fonts are
+; still accesible through the usual scheme symbols: 'feta, 'roman, 'sans, and
+; 'typewriter.
+;
+; Note that 'LilyPond Serif', 'LilyPond Sans Serif' and 'Lilypond Monospace'
+; are aliases that are defined in mf/00-lilypond-fonts.conf.in (source file)
+; or fonts/00-lilypond-fonts.conf (installed file).
+
+(define*-public (set-global-fonts #:key
+ (music "emmentaler")
+ (brace "emmentaler")
+ (roman (if (eq? (ly:get-option 'backend) 'svg)
+ "serif" "LilyPond Serif"))
+ (sans (if (eq? (ly:get-option 'backend) 'svg)
+ "sans-serif" "LilyPond Sans Serif"))
+ (typewriter (if (eq? (ly:get-option 'backend) 'svg)
+ "monospace" "LilyPond Monospace"))
+ (factor 1))