]> git.eshelyaron.com Git - emacs.git/commitdiff
(xterm-maybe-set-dark-background-mode): Rename
authorDan Nicolaescu <dann@ics.uci.edu>
Sun, 24 Jan 2010 21:08:53 +0000 (13:08 -0800)
committerDan Nicolaescu <dann@ics.uci.edu>
Sun, 24 Jan 2010 21:08:53 +0000 (13:08 -0800)
from xterm-set-background-mode.  Return t if the background mode
was set.
(terminal-init-xterm): Move tty-set-up-initial-frame-faces
earlier, call it again in case the background mode has changed.

lisp/ChangeLog
lisp/term/xterm.el

index cee154248140c55c10eb3b64f39ed5716b6f45ef..bb7f2b41d116ba76ad618ff62cf3d95827ea4718 100644 (file)
@@ -1,3 +1,11 @@
+2010-01-24  Dan Nicolaescu  <dann@ics.uci.edu>
+
+       * term/xterm.el (xterm-maybe-set-dark-background-mode): Rename
+       from xterm-set-background-mode.  Return t if the background mode
+       was set.
+       (terminal-init-xterm): Move tty-set-up-initial-frame-faces
+       earlier, call it again in case the background mode has changed.
+
 2010-01-23  Dmitri Paduchikh  <dpaduch@k66.ru>  (tiny change)
 
        * emacs-lisp/advice.el (ad-set-orig-definition): Fix typo
index 203c538609f7a0b4b2df74acc195f7d6aa19cef1..d881e6fcc7d778c66ff34754624c862c8f0f9c44 100644 (file)
       (set-keymap-parent input-decode-map map)))
 
     (xterm-register-default-colors)
+    (tty-set-up-initial-frame-faces)
 
     ;; Try to turn on the modifyOtherKeys feature on modern xterms.
     ;; When it is turned on many more key bindings work: things like
     (let ((coding-system-for-read 'binary)
          (chr nil)
          (str nil)
+         (recompute-faces nil)
          version)
       ;; Pending input can be mistakenly returned by the calls to
       ;; read-event below.  Discard it.
                  (while (not (equal (setq chr (read-event nil nil 2)) ?\\))
                    (setq str (concat str (string chr))))
                  (when (string-match "11;rgb:\\([a-f0-9]+\\)/\\([a-f0-9]+\\)/\\([a-f0-9]+\\)" str)
-                   (xterm-set-background-mode
-                    (string-to-number (match-string 1 str) 16)
-                    (string-to-number (match-string 2 str) 16)
-                    (string-to-number (match-string 3 str) 16))))))
+                   (setq recompute-faces
+                         (xterm-maybe-set-dark-background-mode
+                          (string-to-number (match-string 1 str) 16)
+                          (string-to-number (match-string 2 str) 16)
+                          (string-to-number (match-string 3 str) 16)))))))
            ;; NUMBER2 is the xterm version number, look for something
            ;; greater than 216, the version when modifyOtherKeys was
            ;; introduced.
              ;; need to deal with modify-other-keys.
              (push (frame-terminal (selected-frame))
                    xterm-modify-other-keys-terminal-list)
-             (xterm-turn-on-modify-other-keys))))))
+             (xterm-turn-on-modify-other-keys))
 
-    ;; This recomputes all the default faces given the colors we've just set up.
-    (tty-set-up-initial-frame-faces)
+           ;; Recompute faces here in case the background mode was
+           ;; set to dark.  We used to call
+           ;; `tty-set-up-initial-frame-faces' only once, but that
+           ;; caused the light background faces to be computed
+           ;; incorrectly.  See:
+           ;; http://permalink.gmane.org/gmane.emacs.devel/119627
+           (when recompute-faces
+             (tty-set-up-initial-frame-faces))))))
 
     (run-hooks 'terminal-init-xterm-hook))
 
@@ -666,11 +675,13 @@ versions of xterm."
          (delq terminal xterm-modify-other-keys-terminal-list))
     (send-string-to-terminal "\e[>4m" terminal)))
 
-(defun xterm-set-background-mode (redc greenc bluec)
+(defun xterm-maybe-set-dark-background-mode (redc greenc bluec)
   ;; Use the heuristic in `frame-set-background-mode' to decide if a
   ;; frame is dark.
   (when (< (+ redc greenc bluec) (* .6 (+ 65535 65535 65535)))
-    (set-terminal-parameter nil 'background-mode 'dark)))
+    (setq xterm-background-mode-changed t)
+    (set-terminal-parameter nil 'background-mode 'dark)
+    t))
 
 ;; arch-tag: 12e7ebdd-1e6c-4b25-b0f9-35ace25e855a
 ;;; xterm.el ends here