X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;f=contrib%2Fsb-introspect%2Fxref-test-data.lisp;h=aebc327fda61fdb003deb7993ff62e6e59352341;hb=7169796933b86601eaf70d3a9064600730cb2b40;hp=a839a440a214973c9a19b804f68acf2656e8d470;hpb=30e65b004ace56e530469a364c35a6f5f5d686eb;p=sbcl.git diff --git a/contrib/sb-introspect/xref-test-data.lisp b/contrib/sb-introspect/xref-test-data.lisp index a839a44..aebc327 100644 --- a/contrib/sb-introspect/xref-test-data.lisp +++ b/contrib/sb-introspect/xref-test-data.lisp @@ -194,4 +194,33 @@ (defun inline/4-user () (inline/4 :a :b :c)) -;;; Test references to / from compiler-macros +;;; Test references to / from compiler-macros and source-transforms + +(define-compiler-macro cmacro (x) + `(+ ,x 42)) +(defstruct struct slot) +(defun source-user (x) + (cmacro (struct-slot x))) + +;;; Test specialization + +(defclass a-class () ()) +(defclass a-subclass (a-class) ()) + +(defstruct a-structure) +(defstruct (a-substructure (:include a-structure))) + +(defvar *an-instance-of-a-class* (make-instance 'a-class)) +(defvar *an-instance-of-a-subclass* (make-instance 'a-subclass)) + +(defvar *an-instance-of-a-structure* (make-a-structure)) +(defvar *an-instance-of-a-substructure* (make-a-substructure)) + +(defmethod a-gf-1 ((x a-class))) +(defmethod a-gf-1 ((x a-structure))) + +(defmethod a-gf-2 ((x (eql *an-instance-of-a-class*)))) +(defmethod a-gf-2 ((x (eql *an-instance-of-a-structure*)))) + +(defmethod a-gf-3 ((x (eql *an-instance-of-a-subclass*)))) +(defmethod a-gf-3 ((x (eql *an-instance-of-a-substructure*))))