Пост Всеволода вдохновил меня также написать макрос:
(defmacro defpackage! (package &body options)
(let* ((classes (mapcan
(lambda (x)
(when (eq (car x) :export-from-classes)
(cdr x)))
options))
(class-objs (mapcar #'closer-common-lisp:find-class classes))
(class-slots (mapcan #'closer-mop:class-slots class-objs))
(slot-names (mapcar #'closer-mop:slot-definition-name class-slots))
(slots-with-accessors
(remove-duplicates (remove-if-not #'fboundp slot-names))))
(setf options (mapcar
(lambda (option)
(if (eq (car option) :export)
(append option
(mapcar #'symbol-name slots-with-accessors))
option))
options))
(setf options (remove-if
(lambda (option)
(eq (car option) :export-from-classes))
options))
`(defpackage ,package ,@options)))
Для использования:
CL-USER>
(defclass test-class ()
((amethod :accessor amethod :initarg :amethod :initform 0)
(bmethod :reader bmethod :initform 1)))
#<STANDARD-CLASS TEST-CLASS>
CL-USER>
(closer-mop:ensure-finalized (find-class 'test-class))
#<STANDARD-CLASS TEST-CLASS>
CL-USER>
(macroexpand-1
`(defpackage! test-package
(:export "symbol1")
(:export-from-classes test-class)))
(DEFPACKAGE TEST-PACKAGE
(:EXPORT "symbol1" "AMETHOD" "BMETHOD"))
T
CL-USER>
Это не очень хорошо проверено, и я все еще изучаю MOP API, поэтому здесь могут быть гораздо лучшие / более чистые способы достижения той же цели (особенно fboundp kludge). Кроме того, это ищет только функции доступа в классе. Есть также методы, которые специализируются на классе. Вы можете использовать СС, чтобы найти их ...