+;;; bug-lp#488979
+
+(defclass a-class-name () ())
+
+(assert (find #\Newline
+ (let ((*print-pretty* t)
+ (*print-right-margin* 10))
+ (format nil "~A" (make-instance 'a-class-name)))
+ :test #'char=))
+
+(assert (not (find #\Newline
+ (let ((*print-pretty* nil)
+ (*print-right-margin* 10))
+ (format nil "~A" (make-instance 'a-class-name)))
+ :test #'char=)))
+
+;;; The PRINT-OBJECT method for RANDOM-STATE used to have a bogus
+;;; dimension argument for MAKE-ARRAY.
+(with-test (:name :print-random-state)
+ (assert (equalp *random-state*
+ (read-from-string
+ (write-to-string *random-state*)))))
+
+(with-test (:name :write-return-value)
+ (assert (= 123 (funcall (compile nil (lambda ()
+ (write 123)))))))
+
+(with-test (:name :write/write-to-string-compiler-macro-lp/598374+581564)
+ (let ((test (compile nil
+ `(lambda (object &optional output-stream)
+ (write object
+ :stream output-stream)))))
+ (assert (equal "(HELLO WORLD)"
+ (with-output-to-string (*standard-output*)
+ (let ((list '(hello world)))
+ (assert (eq list (funcall test list)))))))
+ (assert (equal "12"
+ (with-output-to-string (*standard-output*)
+ (assert (eql 12 (funcall test 12)))))))
+ (let ((test (compile nil
+ `(lambda ()
+ (let ((*print-length* 42))
+ (write-to-string *print-length* :length nil))))))
+ (assert (equal "42" (funcall test)))))
+
+(with-test (:name (:format :compile-literal-dest-string))
+ (assert (eq :warned
+ (handler-case
+ (compile nil
+ `(lambda (x) (format "~A" x)))
+ ((and warning (not style-warning)) ()
+ :warned)))))
+
+(with-test (:name :bug-308961)
+ (assert (string= (format nil "~4,1F" 0.001) " 0.0"))
+ (assert (string= (format nil "~4,1@F" 0.001) "+0.0"))
+ (assert (string= (format nil "~E" 0.01) "1.e-2"))
+ (assert (string= (format nil "~G" 0.01) "1.00e-2")))
+
+(with-test (:name (:fp-print-read-consistency single-float))
+ (let ((*random-state* (make-random-state t))
+ (oops))
+ (loop for f = most-positive-single-float then (/ f 2.0)
+ while (> f 0.0)
+ do (loop repeat 10
+ for fr = (random f)
+ do (unless (eql fr (read-from-string (prin1-to-string fr)))
+ (push fr oops)
+ (return))))
+ (loop for f = most-negative-single-float then (/ f 2.0)
+ while (< f -0.0)
+ do (loop repeat 10
+ for fr = (- (random (- f)))
+ do (unless (eql fr (read-from-string (prin1-to-string fr)))
+ (push fr oops)
+ (return))))
+ (when oops
+ (error "FP print-read inconsistencies:~%~:{ ~S => ~S~%~}"
+ (mapcar (lambda (f)
+ (list f (read-from-string (prin1-to-string f))))
+ oops)))))
+
+(with-test (:name (:fp-print-read-consistency double-float))
+ (let ((*random-state* (make-random-state t))
+ (oops))
+ ;; FIXME skipping denormalized floats due to bug 793774.
+ (loop for f = most-positive-double-float then (/ f 2d0)
+ while (> f 0d0)
+ do (loop repeat 10
+ for fr = (random f)
+ do (unless (float-denormalized-p fr)
+ (unless (eql fr (read-from-string (prin1-to-string fr)))
+ (push fr oops)
+ (return)))))
+ (loop for f = most-negative-double-float then (/ f 2d0)
+ while (< f -0d0)
+ do (loop repeat 10
+ for fr = (- (random (- f)))
+ do (unless (float-denormalized-p fr)
+ (unless (eql fr (read-from-string (prin1-to-string fr)))
+ (push fr oops)
+ (return)))))
+ (when oops
+ (error "FP print-read inconsistencies:~%~:{ ~S => ~S~%~}"
+ (mapcar (lambda (f)
+ (list f (read-from-string (prin1-to-string f))))
+ oops)))))
+
+(with-test (:name :bug-811386)
+ (assert (equal " 0.00" (format nil "~7,2,-2f" 0)))
+ (assert (equal " 0.00" (format nil "~7,2,2f" 0)))
+ (assert (equal " 0.01" (format nil "~7,2,-2f" 1)))
+ (assert (equal " 100.00" (format nil "~7,2,2f" 1)))
+ (assert (equal " 0.00" (format nil "~7,2,-2f" 0.1)))
+ (assert (equal " 10.00" (format nil "~7,2,2f" 0.1)))
+ (assert (equal " 0.01" (format nil "~7,2,-2f" 0.5))))
+
+(with-test (:name :bug-867684)
+ (assert (equal "ab" (format nil "a~0&b"))))
+
+(with-test (:name :print-unreadably-function)
+ (assert (equal "\"foo\""
+ (handler-bind ((print-not-readable #'sb-ext:print-unreadably))
+ (write-to-string (coerce "foo" 'base-string) :readably t)))))
+
+(with-test (:name :printing-specialized-arrays-readably)
+ (let ((*read-eval* t)
+ (dimss (loop repeat 10
+ collect (loop repeat (1+ (random 3))
+ collect (1+ (random 10)))))
+ (props sb-vm::*specialized-array-element-type-properties*))
+ (labels ((random-elt (type)
+ (case type
+ (base-char
+ (code-char (random 128)))
+ (character
+ (code-char (random char-code-limit)))
+ (single-float
+ (+ least-positive-normalized-single-float
+ (random most-positive-single-float)))
+ (double-float
+ (+ least-positive-normalized-double-float
+ (random most-positive-double-float)))
+ (bit
+ (random 2))
+ (fixnum
+ (random most-positive-fixnum))
+ ((t)
+ t)
+ (otherwise
+ (destructuring-bind (type x) type
+ (ecase type
+ (unsigned-byte
+ (random (1- (expt 2 x))))
+ (signed-byte
+ (- (random (expt 2 (1- x)))))
+ (complex
+ (complex (random-elt x) (random-elt x)))))))))
+ (dotimes (i (length props))
+ (let ((et (sb-vm::saetp-specifier (aref props i))))
+ (when et
+ (when (eq 'base-char et)
+ ;; base-strings not included in the #. printing.
+ (go :next))
+ (dolist (dims dimss)
+ (let ((a (make-array dims :element-type et)))
+ (assert (equal et (array-element-type a)))
+ (dotimes (i (array-total-size a))
+ (setf (row-major-aref a i) (random-elt et)))
+ (let ((copy (read-from-string (write-to-string a :readably t))))
+ (assert (equal dims (array-dimensions copy)))
+ (assert (equal et (array-element-type copy)))
+ (assert (equal (array-total-size a) (array-total-size copy)))
+ (dotimes (i (array-total-size a))
+ (assert (equal (row-major-aref a i) (row-major-aref copy i)))))))))
+ :next))))
+
+(with-test (:name (:format :negative-colinc-and-mincol))
+ (assert (raises-error? (format nil "~-2a" 1)))
+ (assert (raises-error? (format nil "~,0a" 1))))
+
+(with-test (:name :bug-905817)
+ ;; The bug manifests itself in an endless loop in FORMAT.
+ ;; Correct behaviour is to signal an error.
+ (handler-case
+ (with-timeout 5
+ (assert (raises-error? (format nil "e~8,0s" 12395))))
+ (timeout ()
+ (error "Endless loop in FORMAT"))))
+
+(with-test (:name :format-type-check)
+ (assert (equal "1/10" (format nil "~2r" 1/2)))
+ (assert (raises-error? (format nil "~r" 1.32) sb-format:format-error))
+ (assert (raises-error? (format nil "~c" 1.32) sb-format:format-error))
+ (assert (equal "1/10" (eval '(format nil "~2r" 1/2))))
+ (assert (raises-error? (eval '(format nil "~r" 1.32)) sb-format:format-error))
+ (assert (raises-error? (eval '(format nil "~c" 1.32)) sb-format:format-error)))
+