diff options
| author | Craig Jennings <c@cjennings.net> | 2026-05-25 18:29:31 -0500 |
|---|---|---|
| committer | Craig Jennings <c@cjennings.net> | 2026-05-25 18:29:31 -0500 |
| commit | ed6b63b243f1b181cdc0ae414c9e41782cc9646a (patch) | |
| tree | d02a14c778384c699c975d06fd12201c78bf226f /modules | |
| parent | 7eaa47a9aeb3630fff08bc097bac68df8a4f5a91 (diff) | |
| download | dotemacs-ed6b63b243f1b181cdc0ae414c9e41782cc9646a.tar.gz dotemacs-ed6b63b243f1b181cdc0ae414c9e41782cc9646a.zip | |
fix(font-config): theme-aware browser labels and daemon-safe emoji fontset
Two font-config robustness fixes. The font-browser (cj/display-available-fonts) hardcoded a "Light Blue" foreground for each family label, which goes nearly unreadable on a light theme. I switched it to font-lock-keyword-face so the label follows the theme's contrast, keeping it bold.
The emoji-fontset cond ran once at module load behind (env-gui-p). In daemon mode there's no GUI frame at load, so env-gui-p is nil and the fontset never gets set — a later emacsclient -c GUI frame then has no emoji font. I wrapped it in cj/setup-emoji-fontset (GUI-guarded, idempotent) and, mirroring how the fontaine preset is already applied, run it from server-after-make-frame-hook in daemon mode and directly otherwise. The daemon TTY-then-GUI path can't be exercised in batch, so I left a manual-test entry for it.
Diffstat (limited to 'modules')
| -rw-r--r-- | modules/font-config.el | 35 |
1 files changed, 23 insertions, 12 deletions
diff --git a/modules/font-config.el b/modules/font-config.el index d4e2190da..39d21364c 100644 --- a/modules/font-config.el +++ b/modules/font-config.el @@ -222,17 +222,28 @@ If FRAME is nil, uses the selected frame." ;; ----------------------------- Emoji Fonts Per OS ---------------------------- ;; Set emoji fonts in priority order (first found wins) -(when (env-gui-p) - (cond - ;; Prefer Noto Color Emoji (Linux) - ((member "Noto Color Emoji" (font-family-list)) - (set-fontset-font t 'symbol (font-spec :family "Noto Color Emoji") nil 'prepend)) - ;; Then Apple Color Emoji (macOS) - ((member "Apple Color Emoji" (font-family-list)) - (set-fontset-font t 'symbol (font-spec :family "Apple Color Emoji") nil 'prepend)) - ;; Finally Segoe UI Emoji (Windows) - ((member "Segoe UI Emoji" (font-family-list)) - (set-fontset-font t 'symbol (font-spec :family "Segoe UI Emoji") nil 'prepend)))) +(defun cj/setup-emoji-fontset (&optional _frame) + "Set emoji fonts in priority order (first found wins). +No-op unless a GUI frame is present. Safe to run per-frame: setting +the fontset repeatedly is harmless, so it can be called from +`server-after-make-frame-hook' in daemon mode." + (when (env-gui-p) + (cond + ;; Prefer Noto Color Emoji (Linux) + ((member "Noto Color Emoji" (font-family-list)) + (set-fontset-font t 'symbol (font-spec :family "Noto Color Emoji") nil 'prepend)) + ;; Then Apple Color Emoji (macOS) + ((member "Apple Color Emoji" (font-family-list)) + (set-fontset-font t 'symbol (font-spec :family "Apple Color Emoji") nil 'prepend)) + ;; Finally Segoe UI Emoji (Windows) + ((member "Segoe UI Emoji" (font-family-list)) + (set-fontset-font t 'symbol (font-spec :family "Segoe UI Emoji") nil 'prepend))))) + +;; In daemon mode `env-gui-p' is nil at load time (no GUI frame yet), so run +;; the setup per-frame as GUI frames are created. Otherwise run it now. +(if (daemonp) + (add-hook 'server-after-make-frame-hook #'cj/setup-emoji-fontset) + (cj/setup-emoji-fontset)) ;; ---------------------------------- Emojify ---------------------------------- ;; converts emoji identifiers into emojis; allows for easy emoji entry. @@ -272,7 +283,7 @@ If FRAME is nil, uses the selected frame." (with-current-buffer "*Available Fonts*" (erase-buffer) (dolist (font-family font-list) - (insert (propertize (concat font-family) 'face `((:foreground "Light Blue" :weight bold)))) + (insert (propertize (concat font-family) 'face '(font-lock-keyword-face (:weight bold)))) (insert (concat "\n"(propertize "Regular: "))) (insert (propertize (concat "The quick brown fox jumps over the lazy dog I 1 l ! : ; . , 0 O o [ { ( ) } ] ?") 'face `((:family, font-family)))) |
