X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;f=tests%2Fmop.impure.lisp;h=6735c818c058c7c8d841a421849b1af5ceb93ab1;hb=0957d59ccfaf3db9aaf79a7f4909a40ea0ca0dcd;hp=9e09e315d04695717b9f4dc917a8f6aeef20d13e;hpb=27f66b547413b4a3e1b285270d468ee1e588153c;p=sbcl.git diff --git a/tests/mop.impure.lisp b/tests/mop.impure.lisp index 9e09e31..6735c81 100644 --- a/tests/mop.impure.lisp +++ b/tests/mop.impure.lisp @@ -22,6 +22,13 @@ (in-package "MOP-TEST") +;;; Readers for Class Metaobjects (pp. 212--214 of AMOP) +(defclass red-herring (forward-ref) ()) + +(assert (null (sb-pcl:class-direct-slots (sb-pcl:find-class 'forward-ref)))) +(assert (null (sb-pcl:class-direct-default-initargs + (sb-pcl:find-class 'forward-ref)))) + ;;; Readers for Generic Function Metaobjects (pp. 216--218 of AMOP) (defgeneric fn-with-odd-arg-precedence (a b c) (:argument-precedence-order b c a)) @@ -37,6 +44,16 @@ (sb-pcl:generic-function-argument-precedence-order #'documentation) (let ((ll (sb-pcl:generic-function-lambda-list #'documentation))) (list (nth 1 ll) (nth 0 ll))))) + +(assert (null + (sb-pcl:generic-function-declarations #'fn-with-odd-arg-precedence))) +(defgeneric gf-with-declarations (x) + (declare (optimize (speed 3))) + (declare (optimize (safety 0)))) +(let ((decls (sb-pcl:generic-function-declarations #'gf-with-declarations))) + (assert (= (length decls) 2)) + (assert (member '(optimize (speed 3)) decls :test #'equal)) + (assert (member '(optimize (safety 0)) decls :test #'equal))) ;;; Readers for Slot Definition Metaobjects (pp. 221--224 of AMOP) @@ -70,5 +87,13 @@ (make-instance 'finalization-test-2) (assert (= (get-count) 3)) +;;; Bits of FUNCALLABLE-STANDARD-CLASS are easy to break; make sure +;;; that it is at least possible to define classes with that as a +;;; metaclass. +(defclass gf-class (standard-generic-function) () + (:metaclass sb-pcl::funcallable-standard-class)) +(defgeneric g (a b c) + (:generic-function-class gf-class)) + ;;;; success (sb-ext:quit :unix-status 104)