X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;f=tests%2Fprint.impure.lisp;h=68420b18ebe5d4c7af37cc624ba387588f34285c;hb=df679ed627975948b1cee190f4d79c397588c43e;hp=d9fa69e0998f31c7a279591dff73a928eb8bd4c4;hpb=8097f555eb90f15c51b96e20bd88db15757247b9;p=sbcl.git diff --git a/tests/print.impure.lisp b/tests/print.impure.lisp index d9fa69e..68420b1 100644 --- a/tests/print.impure.lisp +++ b/tests/print.impure.lisp @@ -1,6 +1,18 @@ -(in-package :cl-user) +;;;; miscellaneous tests of printing stuff + +;;;; This software is part of the SBCL system. See the README file for +;;;; more information. +;;;; +;;;; While most of SBCL is derived from the CMU CL system, the test +;;;; files (like this one) were written from scratch after the fork +;;;; from CMU CL. +;;;; +;;;; This software is in the public domain and is provided with +;;;; absolutely no warranty. See the COPYING and CREDITS files for +;;;; more information. (load "assertoid.lisp") +(use-package "ASSERTOID") ;;; We should be able to output X readably (at least when *READ-EVAL*). (defun assert-readable-output (x) @@ -85,5 +97,30 @@ (assert (string= (format nil "~/cl-user:print-foo:print-foo/" 2) "2")) (assert (string= (format nil "~/cl-user::print-foo:print-foo/" 2) "2")) +;;; Check for error detection of illegal directives in a~<..~> justify +;;; block (see ANSI section 22.3.5.2) +(assert (raises-error? (format nil "~<~W~>" 'foo))) +(assert (raises-error? (format nil "~<~<~A~:>~>" '(foo)))) +(assert (string= (format nil "~<~<~A~>~>" 'foo) "FOO")) + +;;; Check that arrays that we print while *PRINT-READABLY* is true are +;;; in fact generating similar objects. +(assert (equal (array-dimensions + (read-from-string + (with-output-to-string (s) + (let ((*print-readably* t)) + (print (make-array '(1 2 0)) s))))) + '(1 2 0))) + +(assert (multiple-value-bind (result error) + (ignore-errors (read-from-string + (with-output-to-string (s) + (let ((*print-readably* t)) + (print (make-array '(1 0 1)) s))))) + ;; it might not be readably-printable + (or (typep error 'print-not-readable) + ;; or else it had better have the same dimensions + (equal (array-dimensions result) '(1 0 1))))) + ;;; success (quit :unix-status 104)