[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: (declare (type fixnum ---)) considered etc.
- To: masinter.pa@Xerox.COM, Fahlman@C.CS.CMU.EDU
- Subject: Re: (declare (type fixnum ---)) considered etc.
- From: Robert A. Cassels <Cassels@STONY-BROOK.SCRC.Symbolics.COM>
- Date: Wed, 23 Jul 86 15:26 EDT
- Cc: common-lisp@SU-AI.ARPA
- In-reply-to: <860721-190646-2493@Xerox>
    Date: 21 Jul 86 19:02 PDT
    From: masinter.pa@Xerox.COM
    The fixnum declaration is one of the easiest things to remove.
    a) Implementations that support (or need) fixnum declarations can add
    them to their extension. This is clearly allowed by the spec, but it
    becomes something that is an implementation's private extension rather
    than part of the public, portable standard. The cost to implementors is
    zero.
Why not leave it, but put it in the SYSTEM: package?  That way, users
are reminded that they are doing something which is
implementation-dependent.  Isn't this what that package is for?  System
programmers, who need to refer to it, will probably be :USEing SYSTEM
anyway.  [Systems programming in Lisp?  Surely you jest! :-]
Are there any other symbols which ought to go in SYSTEM:?
    b) Users who have code that has fixnum declarations could add,
    trivially, a
    (deftype fixnum () ...)
Or import the symbol.
    c) The intent of fixnum declarations is reasonably supported by a much
    more portable expression where the range of a variable is declared
    explicitly rather than depending on implementation-dependent fixnum
    ranges.
I agree.  If you're going to use declarations at all, they might as well
have some real semantic meaning.  I understand that the major current
use is to encourage smart compilers on stupid hardware to generate
more efficient code, rather than to supply program-specific semantics. 
But we should encourage users to use more meaningful declarations.
    I don't know the source of the "certainly" in your message.