annotate lisp/gpm.el @ 5753:dbd8305e13cb

Warn about non-string non-integer ARG to #'gensym, bytecomp.el. lisp/ChangeLog addition: 2013-08-21 Aidan Kehoe <kehoea@parhasard.net> * bytecomp.el: * bytecomp.el (gensym): * bytecomp.el (byte-compile-gensym): New. Warn that gensym called in a for-effect context is unlikely to be useful. Warn about non-string non-integer ARGs, this is incorrect. Am not changing the function to error with same, most code that makes the mistake is has no problems, which is why it has survived so long. * window-xemacs.el (save-window-excursion/mapping): * window.el (save-window-excursion): Call #'gensym with a string, not a symbol.
author Aidan Kehoe <kehoea@parhasard.net>
date Wed, 21 Aug 2013 19:02:59 +0100
parents 308d34e9f07d
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
398
74fd4e045ea6 Import from CVS: tag r21-2-29
cvs
parents:
diff changeset
1 ;;; gpm.el --- Support the mouse when emacs run on a Linux console.
74fd4e045ea6 Import from CVS: tag r21-2-29
cvs
parents:
diff changeset
2
74fd4e045ea6 Import from CVS: tag r21-2-29
cvs
parents:
diff changeset
3 ;; Copyright (C) 1999 Free Software Foundation
74fd4e045ea6 Import from CVS: tag r21-2-29
cvs
parents:
diff changeset
4
74fd4e045ea6 Import from CVS: tag r21-2-29
cvs
parents:
diff changeset
5 ;; Author: William Perry <wmperry@gnu.org>
74fd4e045ea6 Import from CVS: tag r21-2-29
cvs
parents:
diff changeset
6 ;; Keywords: mouse, terminals
74fd4e045ea6 Import from CVS: tag r21-2-29
cvs
parents:
diff changeset
7
74fd4e045ea6 Import from CVS: tag r21-2-29
cvs
parents:
diff changeset
8 ;; This file is part of XEmacs.
74fd4e045ea6 Import from CVS: tag r21-2-29
cvs
parents:
diff changeset
9
5402
308d34e9f07d Changed bulk of GPLv2 or later files identified by script
Mats Lidell <matsl@xemacs.org>
parents: 613
diff changeset
10 ;; XEmacs is free software: you can redistribute it and/or modify it
308d34e9f07d Changed bulk of GPLv2 or later files identified by script
Mats Lidell <matsl@xemacs.org>
parents: 613
diff changeset
11 ;; under the terms of the GNU General Public License as published by the
308d34e9f07d Changed bulk of GPLv2 or later files identified by script
Mats Lidell <matsl@xemacs.org>
parents: 613
diff changeset
12 ;; Free Software Foundation, either version 3 of the License, or (at your
308d34e9f07d Changed bulk of GPLv2 or later files identified by script
Mats Lidell <matsl@xemacs.org>
parents: 613
diff changeset
13 ;; option) any later version.
398
74fd4e045ea6 Import from CVS: tag r21-2-29
cvs
parents:
diff changeset
14
5402
308d34e9f07d Changed bulk of GPLv2 or later files identified by script
Mats Lidell <matsl@xemacs.org>
parents: 613
diff changeset
15 ;; XEmacs is distributed in the hope that it will be useful, but WITHOUT
308d34e9f07d Changed bulk of GPLv2 or later files identified by script
Mats Lidell <matsl@xemacs.org>
parents: 613
diff changeset
16 ;; ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
308d34e9f07d Changed bulk of GPLv2 or later files identified by script
Mats Lidell <matsl@xemacs.org>
parents: 613
diff changeset
17 ;; FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
308d34e9f07d Changed bulk of GPLv2 or later files identified by script
Mats Lidell <matsl@xemacs.org>
parents: 613
diff changeset
18 ;; for more details.
398
74fd4e045ea6 Import from CVS: tag r21-2-29
cvs
parents:
diff changeset
19
74fd4e045ea6 Import from CVS: tag r21-2-29
cvs
parents:
diff changeset
20 ;; You should have received a copy of the GNU General Public License
5402
308d34e9f07d Changed bulk of GPLv2 or later files identified by script
Mats Lidell <matsl@xemacs.org>
parents: 613
diff changeset
21 ;; along with XEmacs. If not, see <http://www.gnu.org/licenses/>.
398
74fd4e045ea6 Import from CVS: tag r21-2-29
cvs
parents:
diff changeset
22
74fd4e045ea6 Import from CVS: tag r21-2-29
cvs
parents:
diff changeset
23 (defvar gpm-enabled-devices (make-hash-table :test 'eq
74fd4e045ea6 Import from CVS: tag r21-2-29
cvs
parents:
diff changeset
24 :size 13
74fd4e045ea6 Import from CVS: tag r21-2-29
cvs
parents:
diff changeset
25 :weakness 'key)
74fd4e045ea6 Import from CVS: tag r21-2-29
cvs
parents:
diff changeset
26 "A hash table of devices with GPM currently turned on.")
502
7039e6323819 [xemacs-hg @ 2001-05-04 22:41:46 by ben]
ben
parents: 442
diff changeset
27
398
74fd4e045ea6 Import from CVS: tag r21-2-29
cvs
parents:
diff changeset
28 (defun gpm-mode (&optional arg device)
74fd4e045ea6 Import from CVS: tag r21-2-29
cvs
parents:
diff changeset
29 "Toggle GPM mouse mode.
74fd4e045ea6 Import from CVS: tag r21-2-29
cvs
parents:
diff changeset
30 With prefix arg, turn GPM mouse mode on if and only if arg is positive."
74fd4e045ea6 Import from CVS: tag r21-2-29
cvs
parents:
diff changeset
31 (interactive (list current-prefix-arg (selected-device)))
502
7039e6323819 [xemacs-hg @ 2001-05-04 22:41:46 by ben]
ben
parents: 442
diff changeset
32 (with-fboundp 'gpm-enable
7039e6323819 [xemacs-hg @ 2001-05-04 22:41:46 by ben]
ben
parents: 442
diff changeset
33 (cond
7039e6323819 [xemacs-hg @ 2001-05-04 22:41:46 by ben]
ben
parents: 442
diff changeset
34 ((null arg) ; Toggle
7039e6323819 [xemacs-hg @ 2001-05-04 22:41:46 by ben]
ben
parents: 442
diff changeset
35 (if (gethash device gpm-enabled-devices)
7039e6323819 [xemacs-hg @ 2001-05-04 22:41:46 by ben]
ben
parents: 442
diff changeset
36 (progn
7039e6323819 [xemacs-hg @ 2001-05-04 22:41:46 by ben]
ben
parents: 442
diff changeset
37 (gpm-enable device nil)
7039e6323819 [xemacs-hg @ 2001-05-04 22:41:46 by ben]
ben
parents: 442
diff changeset
38 (remhash device gpm-enabled-devices))
7039e6323819 [xemacs-hg @ 2001-05-04 22:41:46 by ben]
ben
parents: 442
diff changeset
39 (gpm-enable device t)
7039e6323819 [xemacs-hg @ 2001-05-04 22:41:46 by ben]
ben
parents: 442
diff changeset
40 (puthash device t gpm-enabled-devices)))
7039e6323819 [xemacs-hg @ 2001-05-04 22:41:46 by ben]
ben
parents: 442
diff changeset
41 ((> arg 0) ; Turn on
398
74fd4e045ea6 Import from CVS: tag r21-2-29
cvs
parents:
diff changeset
42 (gpm-enable device t)
502
7039e6323819 [xemacs-hg @ 2001-05-04 22:41:46 by ben]
ben
parents: 442
diff changeset
43 (puthash device t gpm-enabled-devices))
7039e6323819 [xemacs-hg @ 2001-05-04 22:41:46 by ben]
ben
parents: 442
diff changeset
44 ((gethash device gpm-enabled-devices) ; Turn off
7039e6323819 [xemacs-hg @ 2001-05-04 22:41:46 by ben]
ben
parents: 442
diff changeset
45 (gpm-enable device nil)
7039e6323819 [xemacs-hg @ 2001-05-04 22:41:46 by ben]
ben
parents: 442
diff changeset
46 (remhash device gpm-enabled-devices)))))
398
74fd4e045ea6 Import from CVS: tag r21-2-29
cvs
parents:
diff changeset
47
74fd4e045ea6 Import from CVS: tag r21-2-29
cvs
parents:
diff changeset
48 (defun turn-on-gpm-mouse-tracking (&optional device)
74fd4e045ea6 Import from CVS: tag r21-2-29
cvs
parents:
diff changeset
49 ;; Enable mouse tracking on linux console
74fd4e045ea6 Import from CVS: tag r21-2-29
cvs
parents:
diff changeset
50 (gpm-mode 5 device))
74fd4e045ea6 Import from CVS: tag r21-2-29
cvs
parents:
diff changeset
51
74fd4e045ea6 Import from CVS: tag r21-2-29
cvs
parents:
diff changeset
52 (defun turn-off-gpm-mouse-tracking (&optional device)
74fd4e045ea6 Import from CVS: tag r21-2-29
cvs
parents:
diff changeset
53 ;; Disable mouse tracking on linux console
74fd4e045ea6 Import from CVS: tag r21-2-29
cvs
parents:
diff changeset
54 (gpm-mode -5 device))
74fd4e045ea6 Import from CVS: tag r21-2-29
cvs
parents:
diff changeset
55
502
7039e6323819 [xemacs-hg @ 2001-05-04 22:41:46 by ben]
ben
parents: 442
diff changeset
56 (defun gpm-is-supported-p (device)
7039e6323819 [xemacs-hg @ 2001-05-04 22:41:46 by ben]
ben
parents: 442
diff changeset
57 "Returns non-nil if GPM is usable right now on DEVICE in this XEmacs session.
7039e6323819 [xemacs-hg @ 2001-05-04 22:41:46 by ben]
ben
parents: 442
diff changeset
58 This checks whether GPM support was compiled in, TTY support was
7039e6323819 [xemacs-hg @ 2001-05-04 22:41:46 by ben]
ben
parents: 442
diff changeset
59 compiled in, XEmacs is running on Linux, the current console/device is
7039e6323819 [xemacs-hg @ 2001-05-04 22:41:46 by ben]
ben
parents: 442
diff changeset
60 TTY, and its terminal type has been set to `linux'."
7039e6323819 [xemacs-hg @ 2001-05-04 22:41:46 by ben]
ben
parents: 442
diff changeset
61 (and (not noninteractive) ; Don't want to do this in batch mode
7039e6323819 [xemacs-hg @ 2001-05-04 22:41:46 by ben]
ben
parents: 442
diff changeset
62 (fboundp 'gpm-enable) ; Must have C-level GPM support
7039e6323819 [xemacs-hg @ 2001-05-04 22:41:46 by ben]
ben
parents: 442
diff changeset
63 (eq system-type 'linux) ; Must be running linux
7039e6323819 [xemacs-hg @ 2001-05-04 22:41:46 by ben]
ben
parents: 442
diff changeset
64 (eq (device-type device) 'tty) ; on a tty
7039e6323819 [xemacs-hg @ 2001-05-04 22:41:46 by ben]
ben
parents: 442
diff changeset
65 (equal "linux" (declare-fboundp ; an a linux terminal type
7039e6323819 [xemacs-hg @ 2001-05-04 22:41:46 by ben]
ben
parents: 442
diff changeset
66 (console-tty-terminal-type (device-console device))))))
7039e6323819 [xemacs-hg @ 2001-05-04 22:41:46 by ben]
ben
parents: 442
diff changeset
67
398
74fd4e045ea6 Import from CVS: tag r21-2-29
cvs
parents:
diff changeset
68 (defun gpm-create-device-hook (device)
502
7039e6323819 [xemacs-hg @ 2001-05-04 22:41:46 by ben]
ben
parents: 442
diff changeset
69 (if (gpm-is-supported-p device)
398
74fd4e045ea6 Import from CVS: tag r21-2-29
cvs
parents:
diff changeset
70 (turn-on-gpm-mouse-tracking device)))
74fd4e045ea6 Import from CVS: tag r21-2-29
cvs
parents:
diff changeset
71
74fd4e045ea6 Import from CVS: tag r21-2-29
cvs
parents:
diff changeset
72 (defun gpm-delete-device-hook (device)
502
7039e6323819 [xemacs-hg @ 2001-05-04 22:41:46 by ben]
ben
parents: 442
diff changeset
73 (if (gpm-is-supported-p device)
398
74fd4e045ea6 Import from CVS: tag r21-2-29
cvs
parents:
diff changeset
74 (turn-off-gpm-mouse-tracking device)))
74fd4e045ea6 Import from CVS: tag r21-2-29
cvs
parents:
diff changeset
75
442
abe6d1db359e Import from CVS: tag r21-2-36
cvs
parents: 398
diff changeset
76 ;; Restore normal mouse behavior outside Emacs
398
74fd4e045ea6 Import from CVS: tag r21-2-29
cvs
parents:
diff changeset
77
74fd4e045ea6 Import from CVS: tag r21-2-29
cvs
parents:
diff changeset
78 (add-hook 'suspend-hook 'turn-off-gpm-mouse-tracking)
74fd4e045ea6 Import from CVS: tag r21-2-29
cvs
parents:
diff changeset
79 (add-hook 'suspend-resume-hook 'turn-on-gpm-mouse-tracking)
74fd4e045ea6 Import from CVS: tag r21-2-29
cvs
parents:
diff changeset
80 (add-hook 'create-device-hook 'gpm-create-device-hook)
74fd4e045ea6 Import from CVS: tag r21-2-29
cvs
parents:
diff changeset
81 (add-hook 'delete-device-hook 'gpm-delete-device-hook)
74fd4e045ea6 Import from CVS: tag r21-2-29
cvs
parents:
diff changeset
82
74fd4e045ea6 Import from CVS: tag r21-2-29
cvs
parents:
diff changeset
83 (provide 'gpm)