changeset 95807:43c1eff6b631

* t-mouse.el (gpm-mouse-enable, gpm-mouse-disable): New functions. (gpm-mouse-mode): Make it into a proper global minor mode. * term/linux.el (terminal-init-linux): Use gpm-mouse-enable.
author Stefan Monnier <monnier@iro.umontreal.ca>
date Wed, 11 Jun 2008 02:16:45 +0000
parents 2e2ae1dd33cc
children 6f2d537d8c7a
files lisp/ChangeLog lisp/t-mouse.el lisp/term/linux.el
diffstat 3 files changed, 35 insertions(+), 16 deletions(-) [+]
line wrap: on
line diff
--- a/lisp/ChangeLog	Wed Jun 11 01:47:48 2008 +0000
+++ b/lisp/ChangeLog	Wed Jun 11 02:16:45 2008 +0000
@@ -1,5 +1,10 @@
 2008-06-11  Stefan Monnier  <monnier@iro.umontreal.ca>
 
+	* term/linux.el (terminal-init-linux): Use gpm-mouse-enable.
+
+	* t-mouse.el (gpm-mouse-enable, gpm-mouse-disable): New functions.
+	(gpm-mouse-mode): Make it into a proper global minor mode.
+
 	* files.el (save-some-buffers-action-alist): Only use recursive-edit
 	if the user enabled recursive-minibuffers.
 
--- a/lisp/t-mouse.el	Wed Jun 11 01:47:48 2008 +0000
+++ b/lisp/t-mouse.el	Wed Jun 11 02:16:45 2008 +0000
@@ -41,6 +41,27 @@
 ;; Prevent warning when compiling in an Emacs without gpm support.
 (declare-function gpm-mouse-start "term.c" ())
 
+(defun gpm-mouse-enable ()
+  "Try to enable gpm mouse support on the current terminal."
+  (let ((activated nil))
+    (unwind-protect
+        (progn
+          (unless (fboundp 'gpm-mouse-start)
+            (error "Emacs must be built with Gpm to use this mode"))
+          (when gpm-mouse-mode
+            (gpm-mouse-start)
+            (set-terminal-parameter nil 'gpm-mouse-active t)
+            (setq activated t)))
+      ;; If something failed to turn it on, try to turn it off as well,
+      ;; just in case.
+      (unless activated (gpm-mouse-disable)))))
+
+(defun gpm-mouse-disable ()
+  "Try to disable gpm mouse support on the current terminal."
+  (when (fboundp 'gpm-mouse-stop)
+    (gpm-mouse-stop))
+  (set-terminal-parameter nil 'gpm-mouse-active nil))
+
 ;;;###autoload
 (define-obsolete-function-alias 't-mouse-mode 'gpm-mouse-mode "23.1")
 ;;;###autoload
@@ -52,21 +73,14 @@
 This allows the use of the mouse when operating on a GNU/Linux console,
 in the same way as you can use the mouse under X11.
 It relies on the `gpm' daemon being activated."
-  :global t :group 'mouse
-  (let ((activated nil))
-    (unwind-protect
-        (progn
-          (unless (fboundp 'gpm-mouse-start)
-            (error "Emacs must be built with Gpm to use this mode"))
-          (when gpm-mouse-mode
-            (gpm-mouse-start)
-            (setq activated t)))
-      ;; If the user asked to turn it off do that.
-      ;; If something failed to turn it on, try to turn it off as well,
-      ;; just in case.
-      (when (and (fboundp 'gpm-mouse-stop) (not activated))
-        (setq gpm-mouse-mode nil)
-        (gpm-mouse-stop)))))
+  :global t :group 'mouse :init-value t
+  (dolist (terminal (terminal-list))
+    (when (and (eq t (terminal-live-p terminal))
+               (not (eq gpm-mouse-mode
+                        (terminal-parameter terminal 'gpm-mouse-active))))
+      ;; Simulate selecting a terminal by selecting one of its frames ;-(
+      (with-selected-frame (car (frames-on-display-list terminal))
+        (if gpm-mouse-mode (gpm-mouse-enable) (gpm-mouse-disable))))))
 
 (provide 't-mouse)
 
--- a/lisp/term/linux.el	Wed Jun 11 01:47:48 2008 +0000
+++ b/lisp/term/linux.el	Wed Jun 11 02:16:45 2008 +0000
@@ -9,7 +9,7 @@
   ;; It can't really display underlines.
   (tty-no-underline)
 
-  (ignore-errors (gpm-mouse-mode 1))
+  (ignore-errors (if gpm-mouse-mode (gpm-mouse-enable)))
 
   ;; Make Latin-1 input characters work, too.
   ;; Meta will continue to work, because the kernel