Mercurial > hg > xemacs-beta
view lisp/gtk-mouse.el @ 4716:dca5bb2adff1
Don't cons with #'mapcar calls where the result is discarded,
decide on mapc-internal at compile time if the Common Lisp functionality is
not being used.
2009-10-12 Aidan Kehoe <kehoea@parhasard.net>
* cl-macs.el (mapc):
New compiler macro, use mapc-internal at
compile time if we're not using the Common Lisp functionality.
* bytecomp.el (byte-compile-mapcar, byte-compile-maplist): New.
If the return value of mapcar is being discarded, compile it to a
mapc-internal call instead, and warn, because the programmer
probably can't rely on always being compiled by an XEmacs that
does this. Similarly for maplist and mapl; and use
byte-compile-funarg for map, mapl, mapcan, mapcon.
author | Aidan Kehoe <kehoea@parhasard.net> |
---|---|
date | Mon, 12 Oct 2009 17:19:52 +0100 |
parents | 0784d089fdc9 |
children | 308d34e9f07d |
line wrap: on
line source
;;; gtk-mouse.el --- Mouse support for GTK window system. ;; Copyright (C) 1985, 1992-4, 1997 Free Software Foundation, Inc. ;; Copyright (C) 1995, 1996 Ben Wing. ;; Copyright (C) 2000 William Perry ;; Maintainer: XEmacs Development Team ;; Keywords: mouse, dumped ;; 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. ;;; Synched up with: Not synched. ;;; Commentary: ;; This file is dumped with XEmacs (when GTK support is compiled in). ;;; Code: (defvar gtk-pointers-initialized nil) (defun gtk-init-pointers () (if gtk-pointers-initialized nil (set-glyph-image text-pointer-glyph [gtk-resource :resource-type cursor :resource-id xterm] 'gtk) (set-glyph-image nontext-pointer-glyph [gtk-resource :resource-type cursor :resource-id xterm] 'gtk) (set-glyph-image selection-pointer-glyph [gtk-resource :resource-type cursor :resource-id top-left-arrow] 'gtk) (set-glyph-image modeline-pointer-glyph [gtk-resource :resource-type cursor :resource-id sb-v-double-arrow] 'gtk) (set-glyph-image divider-pointer-glyph [gtk-resource :resource-type cursor :resource-id sb-h-double-arrow] 'gtk) (set-glyph-image busy-pointer-glyph [gtk-resource :resource-type cursor :resource-id watch] 'gtk) (set-glyph-image gc-pointer-glyph [gtk-resource :resource-type cursor :resource-id watch] 'gtk) (when (featurep 'toolbar) (set-glyph-image toolbar-pointer-glyph [gtk-resource :resource-type cursor :resource-id top-left-arrow] 'gtk)) (when (featurep 'scrollbar) (set-glyph-image scrollbar-pointer-glyph [gtk-resource :resource-type cursor :resource-id top-left-arrow] 'gtk)) (setq gtk-pointers-initialized t)))