A thing I should know myself....

Faré fahree at gmail.com
Sun Jun 24 19:11:48 UTC 2018


Sorry for a late reply.

UIOP has these utilities that can help you:
(uiop:find-symbol* :unimplemented-stub :foo nil)
(uiop:match-condition-p #(unimplemented-stub foo) (make-condition
'simple-warning))
(setf uiop:*uninteresting-conditions* '(#(unimplemented-stub foo)))

Also, ASDF has the around-compile hook that is the recommended place
to locally set those things:
(defun ignoring-unimplemented-sub (f) (let
((uiop:*uninteresting-conditions* '(#(unimplemented-stub foo))))
(funcall f)))
(defsystem ... :around-compile ignoring-unimplemented-sub ...)

—♯ƒ • François-René ÐVB Rideau •Reflection&Cybernethics• http://fare.tunes.org
Do NOT question authority — they don't know either.

On Sun, Jun 24, 2018 at 8:41 AM Robert Goldman <rpgoldman at sift.info> wrote:
>
> On 22 Jun 2018, at 23:55, Stas Boukarev wrote:
>
> On Fri, Jun 22, 2018 at 5:13 PM Robert Goldman <rpgoldman at sift.info> wrote:
>>
>> I have a library that provides DEF-UNIMPLEMENTED as a macro for defining stub functions. When you compile a file with unimplemented functions, you get a warning of the type FOO:UNIMPLEMENTED-STUB in my library FOO.
>>
>> I'd like to put in an asdf system definition a file spec something like this:
>>
>> (:file "file-with-stubs"
>>   :method (:around (o c)
            (handler-bind ((foo:unimplemented-stub
>>                               #'(lambda (c)
>>                                   (print c)
>>                                   (muffle-warning c))
>>                 (call-next-method)))
>>
>> but, of course, the package foo doesn't exist when this is read (although I could put (asdf:load-system "foo") upstream of the enclosing defsystem).
>>
>> This isn't a case that's nicely consistent with Faré's hack for translating strings or keyword symbols, nor does it seem easy to use find-symbol for this purpose.
>
> You could still use FIND-SYMBOL:
> (handler-bind ((error (lambda (c) (when (typep c (find-symbol x :foo)))))) (a))
>
> That's a good point, and effectively what I ended up doing. But it's certainly not pleasing, because we end up doing our own type dispatch, on top of that which is built into CL with handler-bind. Still, this might be the best I can do.
>
> thanks,
> r



More information about the asdf-devel mailing list