~ chicken-core (chicken-5) 479041d91e71cc242dc954090b943083d525e0d5


commit 479041d91e71cc242dc954090b943083d525e0d5
Author:     Evan Hanson <evhan@foldling.org>
AuthorDate: Sat May 27 15:01:27 2017 +1200
Commit:     Evan Hanson <evhan@foldling.org>
CommitDate: Sat May 27 15:33:46 2017 +1200

    Make `condition->list` use property lists for condition properties
    
    This makes `condition->list` use the same list-based representation of
    condition properties as the new `condition` procedure introduced in
    d6e89287. Where previously an association list-style representation was
    used (though it was not exactly an alist), we now use a property list.

diff --git a/library.scm b/library.scm
index 4007fe37..16c47833 100644
--- a/library.scm
+++ b/library.scm
@@ -4456,8 +4456,8 @@ EOF
 (import scheme)
 (import chicken.fixnum)
 (import chicken.foreign)
-(import (only chicken get-output-string open-output-string
-	      define-constant when fixnum? let-optionals make-parameter))
+(import (only chicken get-output-string open-output-string when unless
+	      define-constant fixnum? let-optionals make-parameter))
 
 ;;; Access backtrace:
 
@@ -4736,20 +4736,20 @@ EOF
 (define (condition? x) (##sys#structure? x 'condition))
 
 (define (condition->list x)
-  (or (condition? x)
-      (##sys#signal-hook
-       #:type-error 'condition->list
-       "argument is not a condition object" x))
-  (map
-   (lambda (k)
-     (cons k (let loop ((props (##sys#slot x 2))
-			(res '()))
-	       (cond ((null? props)
-		      res)
-		     ((eq? k (caar props))
-		      (loop (cddr props) (cons (list (cdar props) (cadr props)) res)))
-		     (else (loop (cddr props) res))))))
-   (##sys#slot x 1)))
+  (unless (condition? x)
+    (##sys#signal-hook
+     #:type-error 'condition->list
+     "argument is not a condition object" x))
+  (map (lambda (k)
+	 (cons k (let loop ((props (##sys#slot x 2)))
+		   (cond ((null? props) '())
+			 ((eq? (caar props) k)
+			  (cons (cdar props)
+				(cons (cadr props)
+				      (loop (cddr props)))))
+			 (else
+			  (loop (cddr props)))))))
+       (##sys#slot x 1)))
 
 (define (condition-predicate kind)
   (lambda (c) 
diff --git a/tests/condition-tests.scm b/tests/condition-tests.scm
index e74ba36c..5a9789b2 100644
--- a/tests/condition-tests.scm
+++ b/tests/condition-tests.scm
@@ -26,7 +26,8 @@
 ;testing condition conversion
 
 (assert (equal? (condition->list condition1)
-		'((exn (location test) (arguments ("bar")) (message "foo")))))
+		'((exn message "foo" arguments ("bar") location test))))
 
 (assert (equal? (condition->list condition3)
-		'((exn (location test) (arguments ("bar")) (message "foo")) (sam (partner "max") (age 23)))))
+		'((exn message "foo" arguments ("bar") location test)
+		  (sam age 23 partner "max"))))
Trap