Mercurial > hg > xemacs-beta
view lisp/gpm.el @ 5294:bbff29a01820
Add compiler macros and compilation sanity-checks for functions with keywords.
2010-10-25 Aidan Kehoe <kehoea@parhasard.net>
Add compiler macros and compilation sanity-checking for various
functions that take keywords.
* byte-optimize.el (side-effect-free-fns): #'symbol-value is
side-effect free and not error free.
* bytecomp.el (byte-compile-normal-call): Check keyword argument
lists for sanity; store information about the positions where
keyword arguments start using the new byte-compile-keyword-start
property.
* cl-macs.el (cl-const-expr-val): Take a new optional argument,
cl-not-constant, defaulting to nil, in this function; return it if
the expression is not constant.
(cl-non-fixnum-number-p): Make this into a separate function, we
want to pass it to #'every.
(eql): Use it.
(define-star-compiler-macros): Use the same code to generate the
member*, assoc* and rassoc* compiler macros; special-case some
code in #'add-to-list in subr.el.
(remove, remq): Add compiler macros for these two functions, in
preparation for #'remove being in C.
(define-foo-if-compiler-macros): Transform (remove-if-not ...) calls to
(remove ... :if-not) at compile time, which will be a real win
once the latter is in C.
(define-substitute-if-compiler-macros)
(define-subst-if-compiler-macros): Similarly for these functions.
(delete-duplicates): Change this compiler macro to use
#'plists-equal; if we don't have information about the type of
SEQUENCE at compile time, don't bother attempting to inline the
call, the function will be in C soon enough.
(equalp): Remove an old commented-out compiler macro for this, if
we want to see it it's in version control.
(subst-char-in-string): Transform this to a call to nsubstitute or
nsubstitute, if that is appropriate.
* cl.el (ldiff): Don't call setf here, this makes for a load-time
dependency problem in cl-macs.el
author | Aidan Kehoe <kehoea@parhasard.net> |
---|---|
date | Mon, 25 Oct 2010 13:04:04 +0100 |
parents | 023b83f4e54b |
children | 308d34e9f07d |
line wrap: on
line source
;;; gpm.el --- Support the mouse when emacs run on a Linux console. ;; Copyright (C) 1999 Free Software Foundation ;; Author: William Perry <wmperry@gnu.org> ;; Keywords: mouse, terminals ;; This file is part of XEmacs. ;; XEmacs is free software; you can redistribute it and/or modify ;; it under the terms of the GNU General Public License as published by ;; the Free Software Foundation; either version 2, or (at your option) ;; any later version. ;; XEmacs is distributed in the hope that it will be useful, ;; but WITHOUT ANY WARRANTY; without even the implied warranty of ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the ;; GNU General Public License for more details. ;; You should have received a copy of the GNU General Public License ;; along with XEmacs; see the file COPYING. If not, write to the ;; Free Software Foundation, Inc., 59 Temple Place - Suite 330, ;; Boston, MA 02111-1307, USA. (defvar gpm-enabled-devices (make-hash-table :test 'eq :size 13 :weakness 'key) "A hash table of devices with GPM currently turned on.") (defun gpm-mode (&optional arg device) "Toggle GPM mouse mode. With prefix arg, turn GPM mouse mode on if and only if arg is positive." (interactive (list current-prefix-arg (selected-device))) (with-fboundp 'gpm-enable (cond ((null arg) ; Toggle (if (gethash device gpm-enabled-devices) (progn (gpm-enable device nil) (remhash device gpm-enabled-devices)) (gpm-enable device t) (puthash device t gpm-enabled-devices))) ((> arg 0) ; Turn on (gpm-enable device t) (puthash device t gpm-enabled-devices)) ((gethash device gpm-enabled-devices) ; Turn off (gpm-enable device nil) (remhash device gpm-enabled-devices))))) (defun turn-on-gpm-mouse-tracking (&optional device) ;; Enable mouse tracking on linux console (gpm-mode 5 device)) (defun turn-off-gpm-mouse-tracking (&optional device) ;; Disable mouse tracking on linux console (gpm-mode -5 device)) (defun gpm-is-supported-p (device) "Returns non-nil if GPM is usable right now on DEVICE in this XEmacs session. This checks whether GPM support was compiled in, TTY support was compiled in, XEmacs is running on Linux, the current console/device is TTY, and its terminal type has been set to `linux'." (and (not noninteractive) ; Don't want to do this in batch mode (fboundp 'gpm-enable) ; Must have C-level GPM support (eq system-type 'linux) ; Must be running linux (eq (device-type device) 'tty) ; on a tty (equal "linux" (declare-fboundp ; an a linux terminal type (console-tty-terminal-type (device-console device)))))) (defun gpm-create-device-hook (device) (if (gpm-is-supported-p device) (turn-on-gpm-mouse-tracking device))) (defun gpm-delete-device-hook (device) (if (gpm-is-supported-p device) (turn-off-gpm-mouse-tracking device))) ;; Restore normal mouse behavior outside Emacs (add-hook 'suspend-hook 'turn-off-gpm-mouse-tracking) (add-hook 'suspend-resume-hook 'turn-on-gpm-mouse-tracking) (add-hook 'create-device-hook 'gpm-create-device-hook) (add-hook 'delete-device-hook 'gpm-delete-device-hook) (provide 'gpm)