(dolist (face (face-list))
(copy-face face face frame disp-frame)))))
+(declare-function describe-variable-custom-version-info "help-fns"
+ (variable &optional type))
(defun describe-face (face &optional frame)
"Display the properties of face FACE on FRAME.
(interactive (list (read-face-name "Describe face"
(or (face-at-point t) 'default)
t)))
+ (require 'help-fns)
(let* ((attrs '((:family . "Family")
(:foundry . "Foundry")
(:width . "Width")
(re-search-backward ": \\([^:]+\\)" nil t)
(help-xref-button 1 'help-face attr)))
(insert "\n")))))
- (terpri)))))))
+ (terpri)
+ (let ((version-info (describe-variable-custom-version-info
+ f 'face)))
+ (when version-info
+ (insert version-info)
+ (terpri)))))))))
\f
;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;
(and (or any-symbol (boundp sym)) sym)))))
0)))
-(defun describe-variable-custom-version-info (variable)
+(defun describe-variable-custom-version-info (variable &optional type)
(let ((custom-version (get variable 'custom-version))
(cpv (get variable 'custom-package-version))
+ (type (or type "variable"))
(output nil))
(if custom-version
(setq output
- (format "This variable was introduced, or its default value was changed, in\nversion %s of Emacs.\n"
- custom-version))
+ (format "This %s was introduced, or its default value was changed, in\nversion %s of Emacs.\n"
+ type custom-version))
(when cpv
(let* ((package (car-safe cpv))
(version (if (listp (cdr-safe cpv))
(emacsv (cdr (assoc version pkg-versions))))
(if (and package version)
(setq output
- (format (concat "This variable was introduced, or its default value was changed, in\nversion %s of the %s package"
+ (format (concat "This %s was introduced, or its default value was changed, in\nversion %s of the %s package"
(if emacsv
(format " that is part of Emacs %s" emacsv))
".\n")
- version package))))))
+ type version package))))))
output))
;;;###autoload