X-Git-Url: http://repo.macrolet.net/gitweb/?a=blobdiff_plain;f=src%2Fcode%2Ferror.lisp;h=51acf0e238dd5c6c8d64f4bc1781ce3ed213dd96;hb=771b864c8f32af7734bc0550aeaf1539fc4df194;hp=f871e902d05533f9b68163e87d9d9f49185d95a6;hpb=2f3c0044ba37b2b33ab60b283e4612aa1ba643eb;p=sbcl.git diff --git a/src/code/error.lisp b/src/code/error.lisp index f871e90..51acf0e 100644 --- a/src/code/error.lisp +++ b/src/code/error.lisp @@ -32,7 +32,7 @@ :datum arguments :expected-type 'null :format-control "You may not supply additional arguments ~ - when giving ~S to ~S." + when giving ~S to ~S." :format-arguments (list datum fun-name))) datum) ((symbolp datum) ; roughly, (SUBTYPEP DATUM 'CONDITION) @@ -70,6 +70,16 @@ (case-failure-name condition) (case-failure-possibilities condition))))) +(define-condition compiled-program-error (program-error) + ((message :initarg :message :reader program-error-message) + (source :initarg :source :reader program-error-source)) + (:report (lambda (condition stream) + (format stream "Execution of a form compiled with errors.~%~ + Form:~% ~A~%~ + Compile-time-error:~% ~A" + (program-error-source condition) + (program-error-message condition))))) + (define-condition simple-control-error (simple-condition control-error) ()) (define-condition simple-file-error (simple-condition file-error) ()) (define-condition simple-program-error (simple-condition program-error) ())