106 lines
3.3 KiB
EmacsLisp
106 lines
3.3 KiB
EmacsLisp
|
;;; -*- mode: emacs-lisp -*-
|
||
|
|
||
|
;;; Fri Jul 13 20:43:53 2007 Mike FABIAN <mfabian@suse.de>
|
||
|
|
||
|
(setq xft-debug-level 0) ;; default is 1. Set to 0 to suppress all warnings
|
||
|
|
||
|
(setq suse-xft-lang-tags
|
||
|
(list "ar"
|
||
|
"en"
|
||
|
"de"
|
||
|
"he"
|
||
|
"ko"
|
||
|
"zh-TW"
|
||
|
"zh-CN"
|
||
|
"ja"
|
||
|
"th"
|
||
|
"vi"))
|
||
|
|
||
|
(mapcar (lambda (x) (define-specifier-tag (intern x))) suse-xft-lang-tags)
|
||
|
|
||
|
(defun suse-xft-find-font-for-tag (tag)
|
||
|
"uses fc-match to find a suitable font for tag"
|
||
|
(let* ((fc-match-result (shell-command-to-string
|
||
|
(format "fc-match monospace:lang=%s" tag)))
|
||
|
(family (nth 1 (split-string fc-match-result "\"")))
|
||
|
(style (nth 3 (split-string fc-match-result "\""))))
|
||
|
(format "%s:style=%s" family style)))
|
||
|
|
||
|
|
||
|
(defun suse-xft-make-fonts-alist (tags)
|
||
|
"returns an alist of with the tags as keys and suitable fonts as values"
|
||
|
(let ((fonts-alist nil))
|
||
|
(mapcar
|
||
|
(lambda (x)
|
||
|
(setq fonts-alist
|
||
|
(cons (cons x (suse-xft-find-font-for-tag x))
|
||
|
fonts-alist)))
|
||
|
tags)
|
||
|
(reverse fonts-alist)))
|
||
|
|
||
|
(setq suse-xft-fonts-alist (suse-xft-make-fonts-alist suse-xft-lang-tags))
|
||
|
|
||
|
;; tune the defaults returned by fc-match according to taste:
|
||
|
;; For example, I prefer "DejaVu Sans Mono" as the standard
|
||
|
;; font even if another font is the default for "monospace"
|
||
|
;; because "DejaVu Sans Mono" has a lot more special symbols
|
||
|
;; than most other monospaced fonts.
|
||
|
|
||
|
(if (not (equal "" (shell-command-to-string "fc-list \"DejaVu Sans Mono\"")))
|
||
|
(setf (cdr (assoc "en" suse-xft-fonts-alist)) "DejaVu Sans Mono"))
|
||
|
|
||
|
(defun suse-xft-set-all-faces (size)
|
||
|
"tries to set reasonable fonts for all faces"
|
||
|
(interactive "nnew size for all faces: ")
|
||
|
(setq suse-xft-current-size size)
|
||
|
(when (console-on-window-system-p)
|
||
|
(mapcar
|
||
|
(lambda (face)
|
||
|
(progn
|
||
|
;; first set the English font as the standard font for all faces
|
||
|
(set-face-font face
|
||
|
(format "%s:size=%d"
|
||
|
(cdr (assoc "en" suse-xft-fonts-alist))
|
||
|
size))
|
||
|
;; then append the fonts for the other languages
|
||
|
(mapcar
|
||
|
(lambda (tag)
|
||
|
(set-face-font face
|
||
|
(format "%s:size=%d"
|
||
|
(cdr (assoc tag suse-xft-fonts-alist))
|
||
|
size)
|
||
|
nil
|
||
|
(list (intern tag))
|
||
|
'remove-tag-set-append))
|
||
|
suse-xft-lang-tags)
|
||
|
(if (string-match "bold-italic" (symbol-name face))
|
||
|
(make-face-bold-italic face)
|
||
|
(if (string-match "bold" (symbol-name face))
|
||
|
(make-face-bold face))
|
||
|
(if (string-match "italic" (symbol-name face))
|
||
|
(make-face-italic face)))
|
||
|
(if (fboundp 'custom-face-get-spec)
|
||
|
(if (and (eq t (plist-get (cadr (assoc t (custom-face-get-spec face))) :bold))
|
||
|
(eq t (plist-get (cadr (assoc t (custom-face-get-spec face))) :italic)))
|
||
|
(make-face-bold-italic face)
|
||
|
(if (eq t (plist-get (cadr (assoc t (custom-face-get-spec face))) :bold))
|
||
|
(make-face-bold face))
|
||
|
(if (eq t (plist-get (cadr (assoc t (custom-face-get-spec face))) :italic))
|
||
|
(make-face-italic face))))
|
||
|
))
|
||
|
(face-list))))
|
||
|
|
||
|
(defun suse-xft-change-size (delta)
|
||
|
(interactive "nsize change in point (may be negative): ")
|
||
|
(setq suse-xft-current-size (+ delta suse-xft-current-size))
|
||
|
(if (> 1 suse-xft-current-size)
|
||
|
(setq suse-xft-current-size 1))
|
||
|
(suse-xft-set-all-faces suse-xft-current-size))
|
||
|
|
||
|
(setq suse-xft-current-size 12)
|
||
|
|
||
|
(suse-xft-set-all-faces suse-xft-current-size)
|
||
|
|
||
|
|
||
|
|