2008-02-18 10:08:59 -05:00
|
|
|
! Copyright (C) 2008 Slava Pestov.
|
|
|
|
! See http://factorcode.org/license.txt for BSD license.
|
|
|
|
USING: concurrency.futures concurrency.count-downs sequences
|
|
|
|
kernel ;
|
|
|
|
IN: concurrency.combinators
|
|
|
|
|
|
|
|
: parallel-map ( seq quot -- newseq )
|
|
|
|
[ curry future ] curry map dup [ ?future ] change-each ;
|
|
|
|
inline
|
|
|
|
|
|
|
|
: parallel-each ( seq quot -- )
|
2008-02-18 17:20:18 -05:00
|
|
|
over length <count-down>
|
|
|
|
[ [ >r curry r> spawn-stage ] 2curry each ] keep await ;
|
|
|
|
inline
|
|
|
|
|
2008-04-26 00:17:08 -04:00
|
|
|
: parallel-filter ( seq quot -- newseq )
|
2008-02-18 17:20:18 -05:00
|
|
|
over >r pusher >r each r> r> like ; inline
|