factor/basis/concurrency/count-downs/count-downs.factor

34 lines
1.0 KiB
Factor
Raw Normal View History

2008-02-18 10:08:59 -05:00
! Copyright (C) 2008 Slava Pestov.
! See http://factorcode.org/license.txt for BSD license.
USING: dlists kernel math concurrency.promises
concurrency.mailboxes debugger accessors ;
2008-02-18 10:08:59 -05:00
IN: concurrency.count-downs
! http://java.sun.com/j2se/1.5.0/docs/api/java/util/concurrent/CountDownLatch.html
TUPLE: count-down n promise ;
: count-down-check ( count-down -- )
dup n>> zero? [ t swap promise>> fulfill ] [ drop ] if ;
2008-02-18 10:08:59 -05:00
: <count-down> ( n -- count-down )
dup 0 < [ "Invalid count for count down" throw ] when
<promise> \ count-down boa
dup count-down-check ;
2008-02-18 10:08:59 -05:00
: count-down ( count-down -- )
dup n>> dup zero?
[ "Count down already done" throw ]
[ 1- >>n count-down-check ] if ;
2008-02-18 10:08:59 -05:00
: await-timeout ( count-down timeout -- )
>r promise>> r> ?promise-timeout ?linked t assert= ;
2008-02-18 10:08:59 -05:00
: await ( count-down -- )
f await-timeout ;
: spawn-stage ( quot count-down -- )
[ [ count-down ] curry compose ] keep
"Count down stage"
swap promise>> mailbox>> spawn-linked-to drop ;