mirror of
git://git.sv.gnu.org/emacs.git
synced 2026-01-03 10:31:37 -08:00
Handle calling defface on a face with existing theme settings (Bug#8454).
* lisp/cus-face.el (custom-declare-face): Call custom-theme-recalc-face if the face has existing theme settings.
This commit is contained in:
parent
2a86a00c4f
commit
027f966de4
2 changed files with 23 additions and 16 deletions
|
|
@ -1,3 +1,8 @@
|
||||||
|
2011-05-08 Chong Yidong <cyd@stupidchicken.com>
|
||||||
|
|
||||||
|
* cus-face.el (custom-declare-face): Call custom-theme-recalc-face
|
||||||
|
if the face has existing theme settings (Bug#8454).
|
||||||
|
|
||||||
2011-05-08 Ralph Schleicher <rs@ralph-schleicher.de>
|
2011-05-08 Ralph Schleicher <rs@ralph-schleicher.de>
|
||||||
|
|
||||||
* progmodes/perl-mode.el (perl-imenu-generic-expression): Only
|
* progmodes/perl-mode.el (perl-imenu-generic-expression): Only
|
||||||
|
|
|
||||||
|
|
@ -34,28 +34,30 @@
|
||||||
(defun custom-declare-face (face spec doc &rest args)
|
(defun custom-declare-face (face spec doc &rest args)
|
||||||
"Like `defface', but FACE is evaluated as a normal argument."
|
"Like `defface', but FACE is evaluated as a normal argument."
|
||||||
(unless (get face 'face-defface-spec)
|
(unless (get face 'face-defface-spec)
|
||||||
(when (fboundp 'facep)
|
(unless (facep face)
|
||||||
(unless (facep face)
|
;; If the user has already created the face, respect that.
|
||||||
;; If the user has already created the face, respect that.
|
(let ((value (or (get face 'saved-face) spec))
|
||||||
(let ((value (or (get face 'saved-face) spec))
|
(have-window-system (memq initial-window-system '(x w32))))
|
||||||
(have-window-system (memq initial-window-system '(x w32))))
|
;; Create global face.
|
||||||
;; Create global face.
|
(make-empty-face face)
|
||||||
(make-empty-face face)
|
;; Create frame-local faces
|
||||||
;; Create frame-local faces
|
(dolist (frame (frame-list))
|
||||||
(dolist (frame (frame-list))
|
(face-spec-set-2 face frame value)
|
||||||
(face-spec-set-2 face frame value)
|
(when (memq (window-system frame) '(x w32 ns))
|
||||||
(when (memq (window-system frame) '(x w32 ns))
|
(setq have-window-system t)))
|
||||||
(setq have-window-system t)))
|
;; When making a face after frames already exist
|
||||||
;; When making a face after frames already exist
|
(if have-window-system
|
||||||
(if have-window-system
|
(make-face-x-resource-internal face))))
|
||||||
(make-face-x-resource-internal face)))))
|
|
||||||
;; Don't record SPEC until we see it causes no errors.
|
;; Don't record SPEC until we see it causes no errors.
|
||||||
(put face 'face-defface-spec (purecopy spec))
|
(put face 'face-defface-spec (purecopy spec))
|
||||||
(push (cons 'defface face) current-load-list)
|
(push (cons 'defface face) current-load-list)
|
||||||
(when (and doc (null (face-documentation face)))
|
(when (and doc (null (face-documentation face)))
|
||||||
(set-face-documentation face (purecopy doc)))
|
(set-face-documentation face (purecopy doc)))
|
||||||
(custom-handle-all-keywords face args 'custom-face)
|
(custom-handle-all-keywords face args 'custom-face)
|
||||||
(run-hooks 'custom-define-hook))
|
(run-hooks 'custom-define-hook)
|
||||||
|
;; If the face has an existing theme setting, recalculate it.
|
||||||
|
(if (get face 'theme-face)
|
||||||
|
(custom-theme-recalc-face face)))
|
||||||
face)
|
face)
|
||||||
|
|
||||||
;;; Face attributes.
|
;;; Face attributes.
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue