diff --git a/THANKS b/THANKS index 3d59c500c..aa4877e95 100644 --- a/THANKS +++ b/THANKS @@ -2,6 +2,7 @@ Contributors since the last release: Christopher Baines Greg Benison + Rob Browning Tristan Colgate-McFarlane Aleix Conchillo Flaqué Ludovic Courtès @@ -79,6 +80,7 @@ For fixes or providing information which led to a fix: Josh Datko David Diffenbaugh Hyper Division + Erik Dominikus Alexandre Duret-Lutz Nils Durner John W Eaton diff --git a/module/scheme/base.scm b/module/scheme/base.scm index b97259f18..20e280467 100644 --- a/module/scheme/base.scm +++ b/module/scheme/base.scm @@ -129,9 +129,10 @@ (unless (procedure? =) (error "not a procedure" =)) (let lp ((ls ls)) - (if (or (null? ls) (= (car ls) x)) - ls - (lp (cdr ls))))))) + (cond + ((null? ls) #f) + ((= (car ls) x) ls) + (else (lp (cdr ls)))))))) (define* (assoc x ls #:optional (= equal?)) (cond diff --git a/test-suite/tests/r7rs.test b/test-suite/tests/r7rs.test index 0914f0c5e..1cc8cd31e 100644 --- a/test-suite/tests/r7rs.test +++ b/test-suite/tests/r7rs.test @@ -2171,7 +2171,7 @@ (let ((out (open-output-string)) (x (list 1))) (set-cdr! x x) - (write x out) + (write-shared x out) (get-output-string out)) ;; labels not guaranteed to be 0 indexed, spacing may differ '("#0=(1 . #0#)" "#1=(1 . #1#)"))