[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Types in CL
- To: labrea!barmar%think.com@labrea.stanford.edu
- Subject: Types in CL
- From: Jon L White <edsel!jonl@labrea.stanford.edu>
- Date: Sun, 27 Dec 87 13:15:46 PST
- Cc: labrea!common-lisp%sail@labrea.stanford.edu
- In-reply-to: Barry Margolin's message of Thu, 17 Dec 87 19:04 EST <871217190451.6.BARMAR@OCCAM.THINK.COM>
re:
Actually, there is a bug in your original message, in the TYPEP call.
The predicate
(TYPEP A 'T1)
expands to
(TYPEP A '(ARRAY T2 1))
which is equivalent to
(AND (ARRAYP A)
(EQ (ARRAY-ELEMENT-TYPE A) 'T2)
(= (ARRAY-RANK A) 1)
(= (ARRAY-DIMENSION A 0) 1))
This isn't right, and is probably a good example of the single most common
error when trying to figure out what the array types mean. Since a CL
implementation of arrays is permitted to "upgrade" the :element-type
argument into something actually supported, and since there is no
requirement to preserve the original :element-type argument, then the
line above
(EQ (ARRAY-ELEMENT-TYPE A) 'T2)
should be
(SUBTYPEP 'T2 (ARRAY-ELEMENT-TYPE A))
Of course, optimizations are possible for specific T2's; but in general
the element-type might have been upgraded to, for example, T.
-- JonL --
- Follow-Ups:
- Types in CL
- From: Barry Margolin <barmar@Think.COM>
- Types in CL
- From: David A. Moon <Moon@STONY-BROOK.SCRC.Symbolics.COM>