Common Lisp是否为使用deftype创建的未定义类型提供了工具?
我在Hyperspec中没有找到任何关于它的内容。
答案 0 :(得分:5)
我只是unintern
派生类型说明符:
T1> (deftype foo () 'fixnum)
FOO
T1> (let ((bar 1))
(check-type bar foo))
NIL
T1> (unintern 'foo)
T
T1> (let ((bar 1))
(check-type bar foo))
Unknown type specifier: FOO
[Condition of type SIMPLE-ERROR]
此外,如果您真的担心由于某种原因删除该类型的每个跟踪,您始终可以编写与实现相关的代码来实现它,即使标准中未提及此类功能。例如,在CCL中(未经测试,我只是浏览了相关代码):
(defun delete-type (derived-type-specifier)
(ccl::clear-type-cache)
(remhash derived-type-specifier ccl::%deftype-expanders%)
(setf (documentation derived-type-specifier 'type) nil))
我们走了:
T1> (deftype foo () "frob" 'fixnum)
FOO
T1> (documentation 'foo 'type)
"frob"
T1> (let ((bar 1))
(check-type bar foo))
NIL
T1> (delete-type 'foo)
NIL
T1> (documentation 'foo 'type)
NIL
T1> (let ((bar 1))
(check-type bar foo))
Unknown type specifier: FOO
[Condition of type SIMPLE-ERROR]