From 64f037d91e0c9296dcaef9a0ff3eb33b19a2ed34 Mon Sep 17 00:00:00 2001 From: Bryan Newbold Date: Mon, 20 Feb 2017 00:05:38 -0800 Subject: Import Upstream version 3a5 --- collect.scm | 31 +++++++++++++++++-------------- 1 file changed, 17 insertions(+), 14 deletions(-) (limited to 'collect.scm') diff --git a/collect.scm b/collect.scm index 05bc2cf..d4ccb6f 100644 --- a/collect.scm +++ b/collect.scm @@ -117,20 +117,23 @@ ) ;@ (define (reduce . ) - (let ( (max+1 (collect:size (car ))) - (generators (map collect:gen-elts )) - ) - (let loop ( (count 0) ) - (cond - ((< count max+1) - (set! - (apply (map (lambda (g) (g)) generators))) - (loop (collect:add1 count)) - ) - (else ) - ) ) -) ) - + (define (reduce-init pred? init lst) + (if (null? lst) + init + (reduce-init pred? (pred? init (car lst)) (cdr lst)))) + (if (null? ) + (cond ((null? ) ) + ((null? (cdr )) (car )) + (else (reduce-init (car ) (cdr )))) + (let ((max+1 (collect:size (car ))) + (generators (map collect:gen-elts ))) + (let loop ((count 0)) + (cond + ((< count max+1) + (set! + (apply (map (lambda (g) (g)) generators))) + (loop (collect:add1 count))) + (else )))))) ;;@ pred true for every elt? -- cgit v1.2.3