chiark / gitweb /
src/class-make-impl.lisp: Forbid slots with function types.
[sod] / src / final.lisp
index 05284910991f0e6196edb715a3c241896d1cf04b..96e9625b3906957a4183cf9e7ae2921da2ab9390 100644 (file)
@@ -39,7 +39,7 @@ (export '*debugout-pathname*)
 (defvar *debugout-pathname* #p"debugout.c")
 
 (export 'test-module)
-(defun test-module (path &key reason clear)
+(defun test-module (path &key reason clear backtrace)
   "Read a module from PATH, to exercise the machinery.
 
    If CLEAR is non-nil, then reset the translator's state before proceeding.
@@ -51,7 +51,8 @@ (defun test-module (path &key reason clear)
    warnings encountered while processing the module."
   (when clear (clear-the-decks))
   (multiple-value-bind (module nerror nwarning)
-      (count-and-report-errors () (read-module path))
+      (if backtrace (read-module path)
+         (count-and-report-errors () (read-module path)))
     (when (and module reason)
       (with-open-file (out *debugout-pathname*
                       :direction :output
@@ -109,16 +110,16 @@ (defmacro test-parser ((scanner &key backtrace) parser input)
                              ,scanner (make-instance
                                        'sod-token-scanner
                                        :char-scanner ,char-scanner))
-                       (multiple-value-bind (,value ,winp ,consumedp)
-                           (parse ,parser)
-                         (declare (ignore ,consumedp))
-                         (cond (,winp ,value)
-                               (t (syntax-error ,scanner ,value)
-                                  nil)))))
+                       (with-default-error-location (,scanner)
+                         (multiple-value-bind (,value ,winp ,consumedp)
+                             (parse ,parser)
+                           (declare (ignore ,consumedp))
+                           (cond (,winp ,value)
+                                 (t (syntax-error ,scanner ,value)
+                                    nil))))))
                 (if ,backtrace (,body)
                     (count-and-report-errors ()
-                      (with-default-error-location (,scanner)
-                        (,body)))))
+                      (,body))))
             (let ((,where (scanner-capture-place ,char-scanner)))
               (values ,value
                       (list ,nerror ,nwarn)