X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;f=tests%2Fprint.impure.lisp;h=b592d8490b671ded56b943f4e931f3fa770797fc;hb=0957d59ccfaf3db9aaf79a7f4909a40ea0ca0dcd;hp=c0064d17efb0dea2a68b4435103ba4cf818f98fd;hpb=4aef4760057ae2f236418ef5fcb410f027961a18;p=sbcl.git diff --git a/tests/print.impure.lisp b/tests/print.impure.lisp index c0064d1..b592d84 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) @@ -63,5 +75,33 @@ (assert (string= (format nil "~1,3,8,' $" 7.3) " 007.3")) (assert (string= (format nil "~2,3,8,'0$" 7.3) "00007.30")) +;;; Check for symbol lookup in ~/ / directive -- double-colon was +;;; broken in 0.7.1.36 and earlier +(defun print-foo (stream arg colonp atsignp &rest params) + (declare (ignore colonp atsignp params)) + (format stream "~d" arg)) + +(assert (string= (format nil "~/print-foo/" 2) "2")) +(assert (string= (format nil "~/cl-user:print-foo/" 2) "2")) +(assert (string= (format nil "~/cl-user::print-foo/" 2) "2")) +(assert (raises-error? (format nil "~/cl-user:::print-foo/" 2))) +(assert (raises-error? (format nil "~/cl-user:a:print-foo/" 2))) +(assert (raises-error? (format nil "~/a:cl-user:print-foo/" 2))) +(assert (raises-error? (format nil "~/cl-user:print-foo:print-foo/" 2))) + +;;; better make sure that we get this one right, too +(defun print-foo\:print-foo (stream arg colonp atsignp &rest params) + (declare (ignore colonp atsignp params)) + (format stream "~d" arg)) + +(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")) + ;;; success (quit :unix-status 104)