# HG changeset patch # User Richard M. Stallman # Date 782874326 0 # Node ID ca4418b4e8ec4f0abd4ad07feefbffca8558b8a8 # Parent adcb2e49f6a2b6081179c8a7f626ef6965efb0a3 (set-face-background): If color is gray, and frame can't display that directly, use corresponding stipple. (face-try-color-list): Assume gray colors are valid on any display. diff -r adcb2e49f6a2 -r ca4418b4e8ec lisp/faces.el --- a/lisp/faces.el Sat Oct 22 16:00:31 1994 +0000 +++ b/lisp/faces.el Sun Oct 23 01:05:26 1994 +0000 @@ -109,6 +109,10 @@ If the optional FRAME argument is provided, change only in that frame; otherwise change each frame." (interactive (internal-face-interactive "background")) + (if (and frame (member color '("gray" "gray1" "gray3")) + (not (x-display-color-p frame)) + (not (x-display-grayscale-p frame))) + (set-face-stipple face color frame)) (internal-set-face-1 face 'background color 5 frame)) (defsubst set-face-stipple (face name &optional frame) @@ -966,8 +970,9 @@ ;; That can't fail, so any subsequent elements after the t are ignored. (defun face-try-color-list (function face colors frame) (if (stringp colors) - (if (or (and (not (x-display-color-p)) (not (string= colors "gray"))) - (= (x-display-planes) 1)) + (if (and (not (member colors '("gray" "gray1" "gray3"))) + (or (not (x-display-color-p)) + (= (x-display-planes) 1))) nil (funcall function face colors frame)) (if (eq colors t) @@ -975,9 +980,9 @@ (let (done) (while (and colors (not done)) (if (and (stringp (car colors)) - (or (and (not (x-display-color-p)) - (not (string= (car colors) "gray"))) - (= (x-display-planes) 1))) + (and (not (member (car colors) '("gray" "gray1" "gray3"))) + (or (not (x-display-color-p)) + (= (x-display-planes) 1)))) nil (if (cdr colors) ;; If there are more colors to try, catch errors