From f19f97599d0d6617906bddf3e8488d5c3eb159a1 Mon Sep 17 00:00:00 2001 From: Nikodemus Siivola Date: Sat, 2 Dec 2006 13:08:42 +0000 Subject: [PATCH] 1.0.0.12: fix docstrings.lisp to deal with unfinalized classes * needed since with the *max-emf-precumentation-methods* change classes like sb-bsd-socket:local-socket don't get finalized untill the first instance is created. --- doc/manual/docstrings.lisp | 7 ++++++- version.lisp-expr | 2 +- 2 files changed, 7 insertions(+), 2 deletions(-) diff --git a/doc/manual/docstrings.lisp b/doc/manual/docstrings.lisp index b703642..e5db38a 100644 --- a/doc/manual/docstrings.lisp +++ b/doc/manual/docstrings.lisp @@ -118,6 +118,11 @@ you deserve to lose.") (defmethod specializer-name ((specializer class)) (class-name specializer)) +(defun ensure-class-precedence-list (class) + (unless (class-finalized-p class) + (finalize-inheritance class)) + (class-precedence-list class)) + (defun specialized-lambda-list (method) ;; courtecy of AMOP p. 61 (let* ((specializers (method-specializers method)) @@ -699,7 +704,7 @@ followed another tabulation label or a tabulation body." ;; class precedence list (format *texinfo-output* "Class precedence list: @code{~(~{@w{~A}~^, ~}~)}~%~%" (remove-if (lambda (class) (hide-superclass-p name class)) - (mapcar #'class-name (class-precedence-list (find-class name))))) + (mapcar #'class-name (ensure-class-precedence-list (find-class name))))) ;; slots (let ((slots (remove-if (lambda (slot) (hide-slot-p name slot)) (class-direct-slots (find-class name))))) diff --git a/version.lisp-expr b/version.lisp-expr index 37ddb33..d70f6ba 100644 --- a/version.lisp-expr +++ b/version.lisp-expr @@ -17,4 +17,4 @@ ;;; checkins which aren't released. (And occasionally for internal ;;; versions, especially for internal versions off the main CVS ;;; branch, it gets hairier, e.g. "0.pre7.14.flaky4.13".) -"1.0.0.11" +"1.0.0.12" -- 1.7.10.4