[Openmcl-devel] User contributions

Ron Garret ron at awun.net
Sat Jun 13 17:58:13 PDT 2009


On Jun 13, 2009, at 4:43 PM, Brian Mastenbrook wrote:

> On Jun 13, 2009, at 5:51 PM, Ron Garret wrote:
>
>> And just in case anyone actually tried this, it won't work.  The
>> reason is that I'm doing (essentially) this:
>>
>> (defconstant +guardian+ (gensym))
>>
>> as part of my iterators code.  But it turns out this is a broken  
>> idiom
>> because, as Gary points out in http://trac.clozure.com/ccl/ticket/ 
>> 539:
>>
>> The spec says:
>>
>> "If a defconstant form appears as a top level form, the compiler must
>> recognize that name names a constant variable. An implementation may
>> choose to evaluate the value-form at compile time, load time, or  
>> both.
>> Therefore, users must ensure that the initial-value can be evaluated
>> at compile time (regardless of whether or not references to name
>> appear in the file) and that it always evaluates to the same value."
>>
>>
>> I am open to suggestions on how to fix this because this leave me  
>> at a
>> bit of a loss.
>
> Use a symbol-macro instead:
>
> (macrolet ((define-guardian (name) `(define-symbol-macro ,name ', 
> (gensym))))
>   (define-guardian +guardian+))

That fails if you reload an uncompiled version of the file.

Ironically, using DEFVAR instead of DEFCONSTANT or DEFINE-SYMBOL-MACRO  
comes closest to doing the Right Thing -- but then you can't rely on  
the system to prohibit assignment and rebinding.

rg




More information about the Openmcl-devel mailing list