2010-02-24 03:18:29 -05:00
|
|
|
! Copyright (C) 2008, 2010 Slava Pestov
|
2008-04-11 13:18:39 -04:00
|
|
|
! See http://factorcode.org/license.txt for BSD license.
|
2010-06-22 02:49:11 -04:00
|
|
|
USING: accessors alien alien.c-types alien.syntax calendar
|
|
|
|
classes.struct combinators core-foundation
|
|
|
|
core-foundation.file-descriptors core-foundation.strings
|
|
|
|
core-foundation.time core-foundation.timers deques destructors
|
|
|
|
heaps kernel math namespaces sequences system threads unix
|
|
|
|
unix.time ;
|
|
|
|
FROM: calendar.unix => system-micros ;
|
2008-04-11 13:18:39 -04:00
|
|
|
IN: core-foundation.run-loop
|
|
|
|
|
2009-02-22 20:13:08 -05:00
|
|
|
CONSTANT: kCFRunLoopRunFinished 1
|
|
|
|
CONSTANT: kCFRunLoopRunStopped 2
|
|
|
|
CONSTANT: kCFRunLoopRunTimedOut 3
|
|
|
|
CONSTANT: kCFRunLoopRunHandledSource 4
|
2008-04-11 13:18:39 -04:00
|
|
|
|
|
|
|
TYPEDEF: void* CFRunLoopRef
|
2008-12-06 18:35:04 -05:00
|
|
|
TYPEDEF: void* CFRunLoopSourceRef
|
2008-04-11 13:18:39 -04:00
|
|
|
|
2008-04-11 14:20:03 -04:00
|
|
|
FUNCTION: CFRunLoopRef CFRunLoopGetMain ( ) ;
|
2008-07-14 23:21:10 -04:00
|
|
|
FUNCTION: CFRunLoopRef CFRunLoopGetCurrent ( ) ;
|
2008-04-11 14:20:03 -04:00
|
|
|
|
2008-04-11 13:18:39 -04:00
|
|
|
FUNCTION: SInt32 CFRunLoopRunInMode (
|
2008-12-18 19:09:22 -05:00
|
|
|
CFStringRef mode,
|
|
|
|
CFTimeInterval seconds,
|
|
|
|
Boolean returnAfterSourceHandled
|
2008-04-11 13:18:39 -04:00
|
|
|
) ;
|
|
|
|
|
2008-12-06 18:35:04 -05:00
|
|
|
FUNCTION: CFRunLoopSourceRef CFFileDescriptorCreateRunLoopSource (
|
|
|
|
CFAllocatorRef allocator,
|
|
|
|
CFFileDescriptorRef f,
|
|
|
|
CFIndex order
|
|
|
|
) ;
|
|
|
|
|
|
|
|
FUNCTION: void CFRunLoopAddSource (
|
2008-12-18 19:09:22 -05:00
|
|
|
CFRunLoopRef rl,
|
|
|
|
CFRunLoopSourceRef source,
|
|
|
|
CFStringRef mode
|
2008-12-06 18:35:04 -05:00
|
|
|
) ;
|
|
|
|
|
2008-12-11 23:48:19 -05:00
|
|
|
FUNCTION: void CFRunLoopRemoveSource (
|
2008-12-18 19:09:22 -05:00
|
|
|
CFRunLoopRef rl,
|
|
|
|
CFRunLoopSourceRef source,
|
|
|
|
CFStringRef mode
|
2008-12-11 23:48:19 -05:00
|
|
|
) ;
|
|
|
|
|
2008-12-12 02:11:37 -05:00
|
|
|
FUNCTION: void CFRunLoopAddTimer (
|
2008-12-18 19:09:22 -05:00
|
|
|
CFRunLoopRef rl,
|
|
|
|
CFRunLoopTimerRef timer,
|
|
|
|
CFStringRef mode
|
2008-12-12 02:11:37 -05:00
|
|
|
) ;
|
|
|
|
|
|
|
|
FUNCTION: void CFRunLoopRemoveTimer (
|
2008-12-18 19:09:22 -05:00
|
|
|
CFRunLoopRef rl,
|
|
|
|
CFRunLoopTimerRef timer,
|
|
|
|
CFStringRef mode
|
2008-12-12 02:11:37 -05:00
|
|
|
) ;
|
|
|
|
|
2009-09-12 20:43:23 -04:00
|
|
|
CFSTRING: CFRunLoopDefaultMode "kCFRunLoopDefaultMode"
|
2008-12-13 00:57:16 -05:00
|
|
|
|
|
|
|
TUPLE: run-loop fds sources timers ;
|
|
|
|
|
|
|
|
: <run-loop> ( -- run-loop )
|
|
|
|
V{ } clone V{ } clone V{ } clone \ run-loop boa ;
|
|
|
|
|
|
|
|
: run-loop ( -- run-loop )
|
2009-02-20 21:51:13 -05:00
|
|
|
\ run-loop [ <run-loop> ] initialize-alien ;
|
2008-12-13 00:57:16 -05:00
|
|
|
|
|
|
|
: add-source-to-run-loop ( source -- )
|
|
|
|
[ run-loop sources>> push ]
|
|
|
|
[
|
|
|
|
CFRunLoopGetMain
|
|
|
|
swap CFRunLoopDefaultMode
|
|
|
|
CFRunLoopAddSource
|
|
|
|
] bi ;
|
|
|
|
|
|
|
|
: create-fd-source ( CFFileDescriptor -- source )
|
|
|
|
f swap 0 CFFileDescriptorCreateRunLoopSource ;
|
|
|
|
|
|
|
|
: add-fd-to-run-loop ( fd callback -- )
|
|
|
|
[
|
|
|
|
<CFFileDescriptor> |CFRelease
|
2012-08-01 13:57:58 -04:00
|
|
|
[ enable-all-callbacks ]
|
2008-12-13 00:57:16 -05:00
|
|
|
[ run-loop fds>> push ]
|
|
|
|
[ create-fd-source |CFRelease add-source-to-run-loop ]
|
2012-08-01 13:57:58 -04:00
|
|
|
tri
|
2008-12-13 00:57:16 -05:00
|
|
|
] with-destructors ;
|
|
|
|
|
2012-08-01 13:57:58 -04:00
|
|
|
<PRIVATE
|
|
|
|
|
|
|
|
: (reset-timer) ( timer timestamp -- )
|
|
|
|
>CFAbsoluteTime CFRunLoopTimerSetNextFireDate ;
|
|
|
|
|
|
|
|
: reset-timer ( timer -- )
|
|
|
|
sleep-time
|
|
|
|
[ 1000 /f ] [ 1,000,000 ] if* system-micros +
|
|
|
|
(reset-timer) ;
|
|
|
|
|
|
|
|
PRIVATE>
|
|
|
|
|
2008-12-13 00:57:16 -05:00
|
|
|
: add-timer-to-run-loop ( timer -- )
|
2012-08-01 13:57:58 -04:00
|
|
|
[ reset-timer ]
|
2008-12-13 00:57:16 -05:00
|
|
|
[ run-loop timers>> push ]
|
|
|
|
[
|
|
|
|
CFRunLoopGetMain
|
|
|
|
swap CFRunLoopDefaultMode
|
|
|
|
CFRunLoopAddTimer
|
2012-08-01 13:57:58 -04:00
|
|
|
] tri ;
|
2008-12-13 00:57:16 -05:00
|
|
|
|
2010-02-24 02:50:34 -05:00
|
|
|
: invalidate-run-loop-timers ( -- )
|
2010-02-24 03:18:29 -05:00
|
|
|
run-loop [
|
|
|
|
[ [ CFRunLoopTimerInvalidate ] [ CFRelease ] bi ] each
|
|
|
|
V{ } clone
|
|
|
|
] change-timers drop ;
|
2010-02-24 02:50:34 -05:00
|
|
|
|
2008-12-13 00:57:16 -05:00
|
|
|
: reset-run-loop ( -- )
|
|
|
|
run-loop
|
|
|
|
[ timers>> [ reset-timer ] each ]
|
|
|
|
[ fds>> [ enable-all-callbacks ] each ] bi ;
|
|
|
|
|
|
|
|
: timer-callback ( -- callback )
|
2010-03-31 22:20:35 -04:00
|
|
|
void { CFRunLoopTimerRef void* } cdecl
|
2012-08-01 13:57:58 -04:00
|
|
|
[ drop reset-timer yield ] alien-callback ;
|
2008-12-13 00:57:16 -05:00
|
|
|
|
|
|
|
: init-thread-timer ( -- )
|
2011-10-19 18:30:55 -04:00
|
|
|
60 timer-callback <CFTimer> add-timer-to-run-loop ;
|
2008-12-13 00:57:16 -05:00
|
|
|
|
2009-11-19 15:18:27 -05:00
|
|
|
: run-one-iteration ( nanos -- handled? )
|
2008-12-13 00:57:16 -05:00
|
|
|
CFRunLoopDefaultMode
|
2012-08-01 14:53:33 -04:00
|
|
|
swap [ 1,000,000,000 / ] [ 300 ] if*
|
2008-12-13 00:57:16 -05:00
|
|
|
t CFRunLoopRunInMode kCFRunLoopRunHandledSource = ;
|