annotate lisp/cl-compat.el @ 5576:071b810ceb18

Declare labels as line where appropriate; use #'labels, not #'flet, tests. lisp/ChangeLog addition: 2011-10-03 Aidan Kehoe <kehoea@parhasard.net> * simple.el (handle-pre-motion-command-current-command-is-motion): Implement #'keysyms-equal with #'labels + (declare (inline ...)), instead of abusing macrolet to the same end. * specifier.el (let-specifier): * mule/mule-cmds.el (describe-language-environment): * mule/mule-cmds.el (set-language-environment-coding-systems): * mule/mule-x-init.el (x-use-halfwidth-roman-font): * faces.el (Face-frob-property): * keymap.el (key-sequence-list-description): * lisp-mode.el (construct-lisp-mode-menu): * loadhist.el (unload-feature): * mouse.el (default-mouse-track-check-for-activation): Declare various labels inline in dumped files when that reduces the size of the dumped image. Declaring labels inline is normally only worthwhile for inner loops and so on, but it's reasonable exercise of the related code to have these changes in core. tests/ChangeLog addition: 2011-10-03 Aidan Kehoe <kehoea@parhasard.net> * automated/case-tests.el (uni-mappings): * automated/database-tests.el (delete-database-files): * automated/hash-table-tests.el (iterations): * automated/lisp-tests.el (test1): * automated/lisp-tests.el (a): * automated/lisp-tests.el (cl-floor): * automated/lisp-tests.el (foo): * automated/lisp-tests.el (list-nreverse): * automated/lisp-tests.el (needs-lexical-context): * automated/mule-tests.el (featurep): * automated/os-tests.el (original-string): * automated/os-tests.el (with): * automated/symbol-tests.el (check-weak-list-unique): Replace #'flet with #'labels where appropriate in these tests, following my own advice on style in the docstrings of those functions.
author Aidan Kehoe <kehoea@parhasard.net>
date Mon, 03 Oct 2011 20:16:14 +0100
parents 0af042a0c116
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
613
023b83f4e54b [xemacs-hg @ 2001-06-10 10:42:16 by ben]
ben
parents: 406
diff changeset
1 ;;; cl-compat.el --- Common Lisp extensions for XEmacs Lisp (compatibility)
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
2
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
3 ;; Copyright (C) 1993 Free Software Foundation, Inc.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
4
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
5 ;; Author: Dave Gillespie <daveg@synaptics.com>
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
6 ;; Version: 2.02
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
7 ;; Keywords: extensions
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
8
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
9 ;; This file is part of XEmacs.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
10
5402
308d34e9f07d Changed bulk of GPLv2 or later files identified by script
Mats Lidell <matsl@xemacs.org>
parents: 4793
diff changeset
11 ;; 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: 4793
diff changeset
12 ;; 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: 4793
diff changeset
13 ;; 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: 4793
diff changeset
14 ;; option) any later version.
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
15
5402
308d34e9f07d Changed bulk of GPLv2 or later files identified by script
Mats Lidell <matsl@xemacs.org>
parents: 4793
diff changeset
16 ;; 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: 4793
diff changeset
17 ;; 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: 4793
diff changeset
18 ;; 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: 4793
diff changeset
19 ;; for more details.
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
20
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
21 ;; 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: 4793
diff changeset
22 ;; along with XEmacs. If not, see <http://www.gnu.org/licenses/>.
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
23
2153
393039450288 [xemacs-hg @ 2004-06-26 21:25:23 by james]
james
parents: 613
diff changeset
24 ;;; Synched up with: FSF 21.3.
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
25
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
26 ;;; Commentary:
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
27
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
28 ;; These are extensions to Emacs Lisp that provide a degree of
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
29 ;; Common Lisp compatibility, beyond what is already built-in
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
30 ;; in Emacs Lisp.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
31 ;;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
32 ;; This package was written by Dave Gillespie; it is a complete
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
33 ;; rewrite of Cesar Quiroz's original cl.el package of December 1986.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
34 ;;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
35 ;; This package works with Emacs 18, Emacs 19, and XEmacs/Lucid Emacs 19.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
36 ;;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
37 ;; Bug reports, comments, and suggestions are welcome!
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
38
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
39 ;; This file contains emulations of internal routines of the older
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
40 ;; CL package which users may have called directly from their code.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
41 ;; Use (require 'cl-compat) to get these routines.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
42
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
43 ;; See cl.el for Change Log.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
44
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
45
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
46 ;;; Code:
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
47
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
48 ;; Require at load-time, but not when compiling cl-compat.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
49 (or (featurep 'cl) (require 'cl))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
50
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
51
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
52 ;;; Keyword routines not supported by new package.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
53
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
54 (defmacro defkeyword (x &optional doc)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
55 (list* 'defconst x (list 'quote x) (and doc (list doc))))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
56
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
57 (defun keyword-of (sym)
4793
8b50bee3c88c Remove attempted support for 1996-era emacs without self-quoting keywords.
Aidan Kehoe <kehoea@parhasard.net>
parents: 4678
diff changeset
58 (or (keywordp sym) (keywordp (read (format ":%s" sym)))))
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
59
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
60 ;;; Routines for parsing keyword arguments.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
61
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
62 (defun build-klist (arglist keys &optional allow-others)
4677
8f1ee2d15784 Support full Common Lisp multiple values in C.
Aidan Kehoe <kehoea@parhasard.net>
parents: 2153
diff changeset
63 (let ((res (multiple-value-call 'mapcar* 'cons (unzip-lists arglist))))
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
64 (or allow-others
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
65 (let ((bad (set-difference (mapcar 'car res) keys)))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
66 (if bad (error "Bad keywords: %s not in %s" bad keys))))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
67 res))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
68
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
69 (defun extract-from-klist (klist key &optional def)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
70 (let ((res (assq key klist))) (if res (cdr res) def)))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
71
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
72 (defun keyword-argument-supplied-p (klist key)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
73 (assq key klist))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
74
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
75 (defun elt-satisfies-test-p (item elt klist)
5344
2a54dfbe434f Don't quote keywords, they've been self-quoting for well over a decade.
Aidan Kehoe <kehoea@parhasard.net>
parents: 4793
diff changeset
76 (let ((test-not (cdr (assq :test-not klist)))
2a54dfbe434f Don't quote keywords, they've been self-quoting for well over a decade.
Aidan Kehoe <kehoea@parhasard.net>
parents: 4793
diff changeset
77 (test (cdr (assq :test klist)))
2a54dfbe434f Don't quote keywords, they've been self-quoting for well over a decade.
Aidan Kehoe <kehoea@parhasard.net>
parents: 4793
diff changeset
78 (key (cdr (assq :key klist))))
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
79 (if key (setq elt (funcall key elt)))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
80 (if test-not (not (funcall test-not item elt))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
81 (funcall (or test 'eql) item elt))))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
82
4678
b5e1d4f6b66f Make #'floor, #'ceiling, #'round, #'truncate conform to Common Lisp.
Aidan Kehoe <kehoea@parhasard.net>
parents: 4677
diff changeset
83 ;; The rounding functions in C now have all the functionality this package
b5e1d4f6b66f Make #'floor, #'ceiling, #'round, #'truncate conform to Common Lisp.
Aidan Kehoe <kehoea@parhasard.net>
parents: 4677
diff changeset
84 ;; used to:
b5e1d4f6b66f Make #'floor, #'ceiling, #'round, #'truncate conform to Common Lisp.
Aidan Kehoe <kehoea@parhasard.net>
parents: 4677
diff changeset
85 (loop
b5e1d4f6b66f Make #'floor, #'ceiling, #'round, #'truncate conform to Common Lisp.
Aidan Kehoe <kehoea@parhasard.net>
parents: 4677
diff changeset
86 for symbol in '(floor ceiling round truncate)
b5e1d4f6b66f Make #'floor, #'ceiling, #'round, #'truncate conform to Common Lisp.
Aidan Kehoe <kehoea@parhasard.net>
parents: 4677
diff changeset
87 do (defalias (intern (format "cl-%s" symbol)) symbol))
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
88
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
89 (defun safe-idiv (a b)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
90 (let* ((q (/ (abs a) (abs b)))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
91 (s (* (signum a) (signum b))))
4677
8f1ee2d15784 Support full Common Lisp multiple values in C.
Aidan Kehoe <kehoea@parhasard.net>
parents: 2153
diff changeset
92 (values q (- a (* s q b)) s)))
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
93
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
94 ;; Internal routines.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
95
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
96 (defun pair-with-newsyms (oldforms)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
97 (let ((newsyms (mapcar (function (lambda (x) (gensym))) oldforms)))
4677
8f1ee2d15784 Support full Common Lisp multiple values in C.
Aidan Kehoe <kehoea@parhasard.net>
parents: 2153
diff changeset
98 (values (mapcar* 'list newsyms oldforms) newsyms)))
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
99
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
100 (defun zip-lists (evens odds)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
101 (mapcan 'list evens odds))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
102
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
103 (defun unzip-lists (list)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
104 (let ((e nil) (o nil))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
105 (while list
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
106 (setq e (cons (car list) e) o (cons (cadr list) o) list (cddr list)))
4677
8f1ee2d15784 Support full Common Lisp multiple values in C.
Aidan Kehoe <kehoea@parhasard.net>
parents: 2153
diff changeset
107 (values (nreverse e) (nreverse o))))
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
108
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
109 (defun reassemble-argslists (list)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
110 (let ((n (apply 'min (mapcar 'length list))) (res nil))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
111 (while (>= (setq n (1- n)) 0)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
112 (setq res (cons (mapcar (function (lambda (x) (elt x n))) list) res)))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
113 res))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
114
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
115 (defun duplicate-symbols-p (list)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
116 (let ((res nil))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
117 (while list
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
118 (if (memq (car list) (cdr list)) (setq res (cons (car list) res)))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
119 (setq list (cdr list)))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
120 res))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
121
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
122
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
123 ;;; Setf internals.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
124
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
125 (defun setnth (n list x)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
126 (setcar (nthcdr n list) x))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
127
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
128 (defun setnthcdr (n list x)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
129 (setcdr (nthcdr (1- n) list) x))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
130
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
131 (defun setelt (seq n x)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
132 (if (consp seq) (setcar (nthcdr n seq) x) (aset seq n x)))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
133
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
134
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
135 ;;; Functions omitted: case-clausify, check-do-stepforms, check-do-endforms,
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
136 ;;; extract-do-inits, extract-do[*]-steps, select-stepping-forms,
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
137 ;;; elt-satisfies-if[-not]-p, with-keyword-args, mv-bind-clausify,
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
138 ;;; all names with embedded `$'.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
139
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
140
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
141 (provide 'cl-compat)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
142
2153
393039450288 [xemacs-hg @ 2004-06-26 21:25:23 by james]
james
parents: 613
diff changeset
143 ;;; arch-tag: 9996bb4f-aaf5-4592-b436-bf64759a3163
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
144 ;;; cl-compat.el ends here