annotate lisp/cl-compat.el @ 793:e38acbeb1cae

[xemacs-hg @ 2002-03-29 04:46:17 by ben] lots o' fixes etc/ChangeLog: New file. Separated out all entries for etc/ into their own ChangeLog. Includes entries for the following files: etc/BABYL, etc/BETA, etc/CHARSETS, etc/DISTRIB, etc/Emacs.ad, etc/FTP, etc/GNUS-NEWS, etc/GOATS, etc/HELLO, etc/INSTALL, etc/MACHINES, etc/MAILINGLISTS, etc/MSDOS, etc/MYTHOLOGY, etc/NEWS, etc/OXYMORONS, etc/PACKAGES, etc/README, etc/TUTORIAL, etc/TUTORIAL.de, etc/TUTORIAL.ja, etc/TUTORIAL.ko, etc/TUTORIAL.se, etc/aliases.ksh, etc/altrasoft-logo.xpm, etc/check_cygwin_setup.sh, etc/custom/example-themes/europe-theme.el, etc/custom/example-themes/ex-custom-file, etc/custom/example-themes/example-theme.el, etc/e/eterm.ti, etc/edt-user.doc, etc/enriched.doc, etc/etags.1, etc/gnuserv.1, etc/gnuserv.README, etc/package-index.LATEST.gpg, etc/package-index.LATEST.pgp, etc/photos/jan.png, etc/recycle.xpm, etc/refcard.tex, etc/sample.Xdefaults, etc/sample.emacs, etc/sgml/CATALOG, etc/sgml/HTML32.dtd, etc/skk/SKK.tut.E, etc/smilies/Face_ase.xbm, etc/smilies/Face_ase2.xbm, etc/smilies/Face_ase3.xbm, etc/smilies/Face_smile.xbm, etc/smilies/Face_weep.xbm, etc/sounds, etc/toolbar, etc/toolbar/workshop-cap-up.xpm, etc/xemacs-ja.1, etc/xemacs.1, etc/yow.lines, etc\BETA, etc\NEWS, etc\README, etc\TUTORIAL, etc\TUTORIAL.de, etc\check_cygwin_setup.sh, etc\sample.init.el, etc\unicode\README, etc\unicode\mule-ucs\*, etc\unicode\other\* unicode/unicode-consortium/8859-16.TXT: New file. mule/english.el: Define this charset now, since a bug was fixed that formerly prevented it. mule/ethio-util.el: Fix compile errors involving Unicode `characters', which should be integers. Makefile.in.in: Always include gui.c, to fix compile error when TTY-only. EmacsFrame.c, abbrev.c, alloc.c, buffer.c, buffer.h, bytecode.c, bytecode.h, callint.c, callproc.c, casetab.c, casetab.h, charset.h, chartab.c, chartab.h, cmds.c, console-msw.c, console-msw.h, console-tty.c, console-x.c, console-x.h, console.c, console.h, data.c, database.c, device-gtk.c, device-msw.c, device-x.c, device.c, device.h, dialog-msw.c, doc.c, doprnt.c, dumper.c, dynarr.c, editfns.c, eldap.c, eldap.h, elhash.c, elhash.h, emacs.c, eval.c, event-Xt.c, event-gtk.c, event-msw.c, event-stream.c, event-tty.c, event-unixoid.c, events.c, events.h, extents.c, extents.h, faces.c, faces.h, file-coding.c, file-coding.h, fileio.c, filelock.c, fns.c, frame-gtk.c, frame-msw.c, frame-tty.c, frame-x.c, frame.c, frame.h, free-hook.c, general-slots.h, glyphs-eimage.c, glyphs-gtk.c, glyphs-msw.c, glyphs-widget.c, glyphs-x.c, glyphs.c, glyphs.h, gpmevent.c, gtk-xemacs.c, gui-msw.c, gui-x.c, gui-x.h, gui.c, gui.h, gutter.c, gutter.h, indent.c, input-method-xlib.c, insdel.c, keymap.c, keymap.h, lisp-disunion.h, lisp-union.h, lisp.h, lread.c, lrecord.h, lstream.c, lstream.h, marker.c, menubar-gtk.c, menubar-msw.c, menubar-x.c, menubar.c, minibuf.c, mule-canna.c, mule-ccl.c, mule-charset.c, mule-wnnfns.c, native-gtk-toolbar.c, objects-msw.c, objects-tty.c, objects-x.c, objects.c, objects.h, opaque.c, opaque.h, postgresql.c, postgresql.h, print.c, process-unix.c, process.c, process.h, rangetab.c, rangetab.h, redisplay-gtk.c, redisplay-msw.c, redisplay-output.c, redisplay-tty.c, redisplay-x.c, redisplay.c, scrollbar-gtk.c, scrollbar-msw.c, scrollbar-x.c, scrollbar.c, scrollbar.h, search.c, select-gtk.c, select-x.c, sound.c, specifier.c, specifier.h, strftime.c, symbols.c, symeval.h, syntax.h, text.c, text.h, toolbar-common.c, toolbar-msw.c, toolbar.c, toolbar.h, tooltalk.c, tooltalk.h, ui-gtk.c, ui-gtk.h, undo.c, vm-limit.c, window.c, window.h: Eliminate XSETFOO. Replace all usages with wrap_foo(). Make symbol->name a Lisp_Object, not Lisp_String *. Eliminate nearly all uses of Lisp_String * in favor of Lisp_Object, and correct macros so most of them favor Lisp_Object. Create new error-behavior ERROR_ME_DEBUG_WARN -- output warnings, but at level `debug' (usually ignored). Use it when instantiating specifiers, so problems can be debugged. Move log-warning-minimum-level into C so that we can optimize ERROR_ME_DEBUG_WARN. Fix warning levels consistent with new definitions. Add default_ and parent fields to char table; not yet implemented. New fun Dynarr_verify(); use for further error checking on Dynarrs. Rearrange code at top of lisp.h in conjunction with dynarr changes. Fix eifree(). Use Eistrings in various places (format_event_object(), where_is_to_char(), and callers thereof) to avoid fixed-size strings buffers. New fun write_eistring(). Reindent and fix GPM code to follow standards. Set default MS Windows font to Lucida Console (same size as Courier New but less interline spacing, so more lines fit). Increase default frame size on Windows to 50 lines. (If that's too big for the workspace, the frame will be shrunk as necessary.) Fix problem with text files with no newlines (). (Change `convert-eol' coding system to use `nil' for autodetect, consistent with make-coding-system.) Correct compile warnings in vm-limit.c. Fix handling of reverse-direction charsets to avoid errors when opening (e.g.) mule-ucs/lisp/reldata/uiso8859-6.el. Recode some object printing methods to use write_fmt_string() instead of a fixed buffer and sprintf. Turn on display of png comments as warnings (level `info'), now that they're unobtrusive. Revamped the sound documentation. Fixed bug in redisplay w.r.t. hscroll/truncation/continuation glyphs causing jumping up and down of the lines, since they're bigger than the line size. (It was seen most obviously when there's a horizontal scroll bar, e.g. do C-h a glyph or something like that.) The problem was that the glyph-contrib-p setting on glyphs was ignored even if it was set properly, which it wasn't until now.
author ben
date Fri, 29 Mar 2002 04:49:13 +0000
parents 023b83f4e54b
children 393039450288
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
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
11 ;; XEmacs is free software; you can redistribute it and/or modify it
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
12 ;; under the terms of the GNU General Public License as published by
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
13 ;; the Free Software Foundation; either version 2, or (at your option)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
14 ;; any later version.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
15
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
16 ;; XEmacs is distributed in the hope that it will be useful, but
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
17 ;; WITHOUT ANY WARRANTY; without even the implied warranty of
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
18 ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
19 ;; General Public License for more details.
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
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
22 ;; along with XEmacs; see the file COPYING. If not, write to the Free
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
23 ;; Software Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
24 ;; 02111-1307, USA.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
25
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
26 ;;; Synched up with: FSF 19.34.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
27
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
28 ;;; Commentary:
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
29
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
30 ;; These are extensions to Emacs Lisp that provide a degree of
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
31 ;; Common Lisp compatibility, beyond what is already built-in
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
32 ;; in Emacs Lisp.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
33 ;;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
34 ;; This package was written by Dave Gillespie; it is a complete
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
35 ;; rewrite of Cesar Quiroz's original cl.el package of December 1986.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
36 ;;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
37 ;; This package works with Emacs 18, Emacs 19, and XEmacs/Lucid Emacs 19.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
38 ;;
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
39 ;; Bug reports, comments, and suggestions are welcome!
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
40
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
41 ;; This file contains emulations of internal routines of the older
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
42 ;; CL package which users may have called directly from their code.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
43 ;; Use (require 'cl-compat) to get these routines.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
44
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
45 ;; See cl.el for Change Log.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
46
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
47
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
48 ;;; Code:
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
49
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
50 ;; Require at load-time, but not when compiling cl-compat.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
51 (or (featurep 'cl) (require 'cl))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
52
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
53
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
54 ;;; Keyword routines not supported by new package.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
55
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
56 (defmacro defkeyword (x &optional doc)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
57 (list* 'defconst x (list 'quote x) (and doc (list doc))))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
58
406
b8cc9ab3f761 Import from CVS: tag r21-2-33
cvs
parents: 209
diff changeset
59 ;; XEmacs change.
b8cc9ab3f761 Import from CVS: tag r21-2-33
cvs
parents: 209
diff changeset
60 ;; We have built-in function.
b8cc9ab3f761 Import from CVS: tag r21-2-33
cvs
parents: 209
diff changeset
61 ;;(defun keywordp (sym)
b8cc9ab3f761 Import from CVS: tag r21-2-33
cvs
parents: 209
diff changeset
62 ;; (and (symbolp sym) (eq (aref (symbol-name sym) 0) ?\:) (set sym sym)))
209
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
63
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
64 (defun keyword-of (sym)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
65 (or (keywordp sym) (keywordp (intern (format ":%s" sym)))))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
66
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
67
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
68 ;;; Multiple values. Note that the new package uses a different
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
69 ;;; convention for multiple values. The following definitions
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
70 ;;; emulate the old convention; all function names have been changed
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
71 ;;; by capitalizing the first letter: Values, Multiple-value-*,
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
72 ;;; to avoid conflict with the new-style definitions in cl-macs.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
73
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
74 (put 'Multiple-value-bind 'lisp-indent-function 2)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
75 (put 'Multiple-value-setq 'lisp-indent-function 2)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
76 (put 'Multiple-value-call 'lisp-indent-function 1)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
77 (put 'Multiple-value-prog1 'lisp-indent-function 1)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
78
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
79 (defvar *mvalues-values* nil)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
80
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
81 (defun Values (&rest val-forms)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
82 (setq *mvalues-values* val-forms)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
83 (car val-forms))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
84
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
85 (defun Values-list (val-forms)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
86 (apply 'values val-forms))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
87
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
88 (defmacro Multiple-value-list (form)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
89 (list 'let* (list '(*mvalues-values* nil) (list '*mvalues-temp* form))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
90 '(or (and (eq *mvalues-temp* (car *mvalues-values*)) *mvalues-values*)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
91 (list *mvalues-temp*))))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
92
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
93 (defmacro Multiple-value-call (function &rest args)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
94 (list 'apply function
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
95 (cons 'append
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
96 (mapcar (function (lambda (x) (list 'Multiple-value-list x)))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
97 args))))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
98
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
99 (defmacro Multiple-value-bind (vars form &rest body)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
100 (list* 'multiple-value-bind vars (list 'Multiple-value-list form) body))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
101
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
102 (defmacro Multiple-value-setq (vars form)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
103 (list 'multiple-value-setq vars (list 'Multiple-value-list form)))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
104
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
105 (defmacro Multiple-value-prog1 (form &rest body)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
106 (list 'prog1 form (list* 'let '((*mvalues-values* nil)) body)))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
107
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
108
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
109 ;;; Routines for parsing keyword arguments.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
110
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
111 (defun build-klist (arglist keys &optional allow-others)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
112 (let ((res (Multiple-value-call 'mapcar* 'cons (unzip-lists arglist))))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
113 (or allow-others
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
114 (let ((bad (set-difference (mapcar 'car res) keys)))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
115 (if bad (error "Bad keywords: %s not in %s" bad keys))))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
116 res))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
117
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
118 (defun extract-from-klist (klist key &optional def)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
119 (let ((res (assq key klist))) (if res (cdr res) def)))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
120
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
121 (defun keyword-argument-supplied-p (klist key)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
122 (assq key klist))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
123
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
124 (defun elt-satisfies-test-p (item elt klist)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
125 (let ((test-not (cdr (assq ':test-not klist)))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
126 (test (cdr (assq ':test klist)))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
127 (key (cdr (assq ':key klist))))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
128 (if key (setq elt (funcall key elt)))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
129 (if test-not (not (funcall test-not item elt))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
130 (funcall (or test 'eql) item elt))))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
131
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
132
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
133 ;;; Rounding functions with old-style multiple value returns.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
134
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
135 (defun cl-floor (a &optional b) (Values-list (floor* a b)))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
136 (defun cl-ceiling (a &optional b) (Values-list (ceiling* a b)))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
137 (defun cl-round (a &optional b) (Values-list (round* a b)))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
138 (defun cl-truncate (a &optional b) (Values-list (truncate* a b)))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
139
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
140 (defun safe-idiv (a b)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
141 (let* ((q (/ (abs a) (abs b)))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
142 (s (* (signum a) (signum b))))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
143 (Values q (- a (* s q b)) s)))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
144
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
145
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
146 ;; Internal routines.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
147
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
148 (defun pair-with-newsyms (oldforms)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
149 (let ((newsyms (mapcar (function (lambda (x) (gensym))) oldforms)))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
150 (Values (mapcar* 'list newsyms oldforms) newsyms)))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
151
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
152 (defun zip-lists (evens odds)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
153 (mapcan 'list evens odds))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
154
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
155 (defun unzip-lists (list)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
156 (let ((e nil) (o nil))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
157 (while list
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
158 (setq e (cons (car list) e) o (cons (cadr list) o) list (cddr list)))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
159 (Values (nreverse e) (nreverse o))))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
160
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
161 (defun reassemble-argslists (list)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
162 (let ((n (apply 'min (mapcar 'length list))) (res nil))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
163 (while (>= (setq n (1- n)) 0)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
164 (setq res (cons (mapcar (function (lambda (x) (elt x n))) list) res)))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
165 res))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
166
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
167 (defun duplicate-symbols-p (list)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
168 (let ((res nil))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
169 (while list
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
170 (if (memq (car list) (cdr list)) (setq res (cons (car list) res)))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
171 (setq list (cdr list)))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
172 res))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
173
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
174
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
175 ;;; Setf internals.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
176
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
177 (defun setnth (n list x)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
178 (setcar (nthcdr n list) x))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
179
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
180 (defun setnthcdr (n list x)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
181 (setcdr (nthcdr (1- n) list) x))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
182
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
183 (defun setelt (seq n x)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
184 (if (consp seq) (setcar (nthcdr n seq) x) (aset seq n x)))
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
185
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
186
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
187 ;;; Functions omitted: case-clausify, check-do-stepforms, check-do-endforms,
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
188 ;;; extract-do-inits, extract-do[*]-steps, select-stepping-forms,
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
189 ;;; elt-satisfies-if[-not]-p, with-keyword-args, mv-bind-clausify,
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
190 ;;; all names with embedded `$'.
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
191
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
192
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
193 (provide 'cl-compat)
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
194
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
195 ;;; cl-compat.el ends here
41ff10fd062f Import from CVS: tag r20-4b3
cvs
parents:
diff changeset
196