X-Git-Url: https://git.donarmstrong.com/?a=blobdiff_plain;f=scm%2Ffont.scm;h=eefc1c26ee9627316e43e11e09101d9e4ceebbe2;hb=46153fde3123b7c01c27d30328e71deb366ac2a9;hp=8c2fbea6d886a1ee1a4509bfab349ec3c47acd7b;hpb=2032679f3ca5a83b851c0f5dc415143ffa28c4af;p=lilypond.git diff --git a/scm/font.scm b/scm/font.scm index 8c2fbea6d8..eefc1c26ee 100644 --- a/scm/font.scm +++ b/scm/font.scm @@ -2,7 +2,7 @@ ;;;; ;;;; source file of the GNU LilyPond music typesetter ;;;; -;;;; (c) 2004--2005 Han-Wen Nienhuys +;;;; (c) 2004--2007 Han-Wen Nienhuys ;; TODO: ;; @@ -34,9 +34,11 @@ (define-method (display (leaf ) port) (map (lambda (x) (display x port)) (list - "Font-size-family: \n" + "#" + ))) (define-method (display (node ) port) @@ -66,6 +68,7 @@ (define-method (add-font (node ) fprops size-family) (define (assoc-delete key alist) (assoc-remove! (list-copy alist) key)) + (define (make-node fprops size-family) (if (null? fprops) (make-font-tree-leaf (car size-family) (cdr size-family)) @@ -319,29 +322,45 @@ (ly:pt 12))))))) (add-node 'upright 'normal) + (add-node 'caps 'normal) (add-node 'upright 'bold) (add-node 'italic 'normal) (add-node 'italic 'bold)) (define-public (make-cmr-tree factor) - (let ((n (make-font-tree-node 'font-encoding 'fetaMusic))) + (let* + ((n (make-font-tree-node 'font-encoding 'fetaMusic)) + (module (resolve-module '(scm kpathsea))) + (find (eval 'ly:kpathsea-find-file module)) + ) (add-music-fonts n factor) (add-cmr-fonts n factor) - (if (defined? 'ly:kpathsea-find-file) - (begin - (if (ly:kpathsea-find-file "lmr10.pfb") - (add-cork-lm-fonts n factor)) - (if (ly:kpathsea-find-file "ecrm10.pfa") - (add-ec-fonts n factor)))) + + (if (find "lmr10.pfb") + (add-cork-lm-fonts n factor)) + (if (find "ecrm10.pfa") + (add-ec-fonts n factor)) n)) -(define-public (make-century-schoolbook-tree factor) + + + +(define-public (make-pango-font-tree roman-str sans-str typewrite-str factor) (let ((n (make-font-tree-node 'font-encoding 'fetaMusic))) (add-music-fonts n factor) - (add-pango-fonts n 'roman "Century Schoolbook L" factor) - (add-pango-fonts n 'sans "Sans" factor) - (add-pango-fonts n 'typewriter "Mono" factor) + (add-pango-fonts n 'roman roman-str factor) + (add-pango-fonts n 'sans sans-str factor) + (add-pango-fonts n 'typewriter typewrite-str factor) n)) -(define-public (magstep x) - (exp (* (/ x 6) (log 2)))) + +(define-public (make-century-schoolbook-tree factor) + (make-pango-font-tree + "Century Schoolbook L" + "Sans" "Mono" factor)) + +(define-public (magstep s) + (exp (* (/ s 6) (log 2)))) + +(define-public (magnification->font-size m) + (* 6 (/ (log m) (log 2))))