[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
commonlisp types
- To: gls%Think.COM@Riverside.Symbolics.COM, jwz%spice.cs.cmu.edu@Riverside.SCRC.Symbolics.COM, common-lisp%sail.stanford.edu@Riverside.SCRC.Symbolics.COM
- Subject: commonlisp types
- From: Robert W. Kerns <RWK@FUJI.ILA.Dialnet.Symbolics.COM>
- Date: Fri, 6 Jan 89 15:33 EST
- Comments: Retransmission of failed mail.
- In-reply-to: <881222151736.1.KMP@BOBOLINK.SCRC.Symbolics.COM>
- Supersedes: <19890103102924.8.RWK@F.ILA.Dialnet.Symbolics.COM>
Date: Thu, 22 Dec 88 15:17 EST
From: Kent M Pitman <KMP@STONY-BROOK.SCRC.Symbolics.COM>
Fyi, it turns out this rationale doesn't hold as much water as you'd think.
Consider:
(defun bar (x) (symbolp x))
(defun foo (x)
(flet ((bar (y) (integerp y)))
(typep x '(satisfies bar))))
(foo 'x)
The correct answer is T, but I bet a lot of implementations return NIL
in compiled code.
Like the Symbolics system, Boo, Hiss!
In terms of source transformations, this would have to compile the TYPEP
as follows:
(defun foo (x)
(flet ((bar (y) (integerp y)))
(let ((#:G0002 x))
(macrolet ((bar (a) `(funcall (symbol-function 'bar) ,a)))
(bar #:G0002)))))
Which is obviously going to require either a codewalker or a typewalker
to identify either locally defined functions or functions used in the
type expansion to shadow with MACROLET.
So I'm curious. Does any compiler actually get this right? Really,
this is a general problem with any form of source-code rewrites. The
Symbolics compiler does get this right with inlined functions, but I'll
bet it doesn't with some other internal in-lined things that work as
source transformations.