"bar"
(incf x y)))
-(with-test (:name (documentation closure))
+(with-test (:name (documentation :closure))
(assert (string= (documentation 'docfoo 'function) "bar"))
- (assert (string= (documentation #'docfoo t) "bar"))
(assert (string= (setf (documentation 'docfoo 'function) "baz") "baz"))
(assert (string= (documentation 'docfoo 'function) "baz"))
- (assert (string= (documentation #'docfoo t) "bar"))
+ (assert (string= (documentation #'docfoo t) "baz"))
(assert (string= (setf (documentation #'docfoo t) "zot") "zot"))
(assert (string= (documentation #'docfoo t) "zot"))
- (assert (string= (documentation 'docfoo 'function) "baz"))
+ (assert (string= (documentation 'docfoo 'function) "zot"))
(assert (not (setf (documentation 'docfoo 'function) nil)))
- (assert (string= (documentation 'docfoo 'function) "zot")))
+ (assert (not (documentation 'docfoo 'function))))
-(with-test (:name (documentation built-in-macro) :skipped-on '(not :sb-doc))
+(with-test (:name (documentation :built-in-macro) :skipped-on '(not :sb-doc))
(assert (documentation 'trace 'function)))
-(with-test (:name (documentation built-in-function) :skipped-on '(not :sb-doc))
+(with-test (:name (documentation :built-in-function) :skipped-on '(not :sb-doc))
(assert (documentation 'cons 'function)))
(with-test (:name :describe-generic-function-with-assumed-type)
(assert
(or (member :big-endian *features*)
(member :little-endian *features*))))
+
+(with-test (:name :function-documentation-mismatch)
+ (defun test ()
+ "X"
+ nil)
+ (setf (symbol-function 'test2) #'test)
+ (setf (documentation 'test 'function) "Y")
+ (assert (equal (documentation #'test t)
+ (documentation 'test 'function)))
+ (setf (documentation 'test2 'function) "Z")
+ (assert (not
+ (equal (documentation 'test 'function)
+ (documentation 'test2 'function)))))
+
+(with-test (:name :setf-documentation-on-nil)
+ (assert
+ (handler-case
+ (assert (equal (setf (documentation nil 'function) "foo") "foo"))
+ (style-warning () t)
+ (:no-error (x)
+ (declare (ignore x))
+ nil))))
+
\f
;;;; success