我想定义一个类型说明符来描述相同类型的事物列表.所以我想有(list-of integer)类似的(array integer)(内置).我能够为特定类型创建它,如下所示:
(defun elements-are-integer (seq)
(every #'(lambda (x) (typep x 'integer)) seq))
(deftype list-of-integer ()
'(and list (satisfies elements-are-integer)))
Run Code Online (Sandbox Code Playgroud)
但是,这意味着我必须为每种可能的类型执行此操作.如何更改此代码,以便类型将另一种类型作为参数,并动态构造satisfies谓词?问题是satisfies需要一个全局符号,我不知道如何在适当的上下文中定义谓词函数(我想我需要gensym它以某种方式,但如何?).此外,解决方案应该工作,以便可以在另一个包内创建类型.
WRe*_*ach 14
试试这个:
(defun elements-are-of-type (seq type)
(every #'(lambda (x) (typep x type)) seq))
(deftype list-of-type (type)
(let ((predicate (gensym)))
(setf (symbol-function predicate)
#'(lambda (seq) (elements-are-of-type seq type)) )
`(and list (satisfies ,predicate)) ))
(typep '(1 2 3) '(list-of-type integer))
; -> T
(typep '(1 2 a) '(list-of-type integer))
; -> NIL
(typep '(a b c) '(list-of-type symbol))
; -> T
Run Code Online (Sandbox Code Playgroud)