SHA256
1
0
forked from pool/xemacs
xemacs/suse-xft-init.el

123 lines
4.0 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)
'global
nil
'remove-all)
;; 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)
'global
(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 (and (eq 'bold (plist-get (cadr (assoc t (custom-face-get-spec face))) :weight))
(eq 'italic (plist-get (cadr (assoc t (custom-face-get-spec face))) :slant)))
(make-face-bold-italic face)
(if (eq 'bold (plist-get (cadr (assoc t (custom-face-get-spec face))) :weight))
(make-face-bold face))
(if (eq 'italic (plist-get (cadr (assoc t (custom-face-get-spec face))) :slant))
(make-face-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-set-size (size)
(interactive "nset all fonts to point-size: ")
(setq suse-xft-current-size size)
(if (> 1 suse-xft-current-size)
(setq suse-xft-current-size 1))
(suse-xft-set-all-faces suse-xft-current-size))
(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)