Handle calling defface on a face with existing theme settings (Bug#8454).
authorChong Yidong <cyd@stupidchicken.com>
Sun, 8 May 2011 20:07:38 +0000 (16:07 -0400)
committerChong Yidong <cyd@stupidchicken.com>
Sun, 8 May 2011 20:07:38 +0000 (16:07 -0400)
* lisp/cus-face.el (custom-declare-face): Call custom-theme-recalc-face if
the face has existing theme settings.

lisp/ChangeLog
lisp/cus-face.el

index 488bd07..60b462e 100644 (file)
@@ -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>
 
        * progmodes/perl-mode.el (perl-imenu-generic-expression): Only
index f813b5b..90f21f3 100644 (file)
 (defun custom-declare-face (face spec doc &rest args)
   "Like `defface', but FACE is evaluated as a normal argument."
   (unless (get face 'face-defface-spec)
-    (when (fboundp 'facep)
-      (unless (facep face)
-       ;; If the user has already created the face, respect that.
-       (let ((value (or (get face 'saved-face) spec))
-             (have-window-system (memq initial-window-system '(x w32))))
-         ;; Create global face.
-         (make-empty-face face)
-         ;; Create frame-local faces
-         (dolist (frame (frame-list))
-           (face-spec-set-2 face frame value)
-           (when (memq (window-system frame) '(x w32 ns))
-             (setq have-window-system t)))
-         ;; When making a face after frames already exist
-         (if have-window-system
-             (make-face-x-resource-internal face)))))
+    (unless (facep face)
+      ;; If the user has already created the face, respect that.
+      (let ((value (or (get face 'saved-face) spec))
+           (have-window-system (memq initial-window-system '(x w32))))
+       ;; Create global face.
+       (make-empty-face face)
+       ;; Create frame-local faces
+       (dolist (frame (frame-list))
+         (face-spec-set-2 face frame value)
+         (when (memq (window-system frame) '(x w32 ns))
+           (setq have-window-system t)))
+       ;; When making a face after frames already exist
+       (if have-window-system
+           (make-face-x-resource-internal face))))
     ;; Don't record SPEC until we see it causes no errors.
     (put face 'face-defface-spec (purecopy spec))
     (push (cons 'defface face) current-load-list)
     (when (and doc (null (face-documentation face)))
       (set-face-documentation face (purecopy doc)))
     (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 attributes.