删除Common Lisp中的类型

时间:2012-09-01 16:33:44

标签: lisp common-lisp

Common Lisp是否为使用deftype创建的未定义类型提供了工具?

我在Hyperspec中没有找到任何关于它的内容。

1 个答案:

答案 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]