2018-12-13 01:09:47 +03:00
|
|
|
:: %behn, just a timer
|
|
|
|
::
|
2016-11-24 07:25:07 +03:00
|
|
|
!? 164
|
|
|
|
::
|
2018-12-13 01:09:47 +03:00
|
|
|
=, behn
|
|
|
|
|= pit=vase
|
|
|
|
=> |%
|
|
|
|
+$ move [p=duct q=(wind note:able gift:able)]
|
|
|
|
+$ sign ~
|
|
|
|
::
|
|
|
|
+$ behn-state
|
|
|
|
$: timers=(list timer)
|
|
|
|
unix-duct=duct
|
|
|
|
next-wake=(unit @da)
|
|
|
|
==
|
|
|
|
::
|
|
|
|
+$ timer [date=@da =duct]
|
|
|
|
--
|
2016-11-24 07:25:07 +03:00
|
|
|
::
|
2018-12-13 01:09:47 +03:00
|
|
|
=| behn-state
|
|
|
|
=* state -
|
2018-12-06 00:41:21 +03:00
|
|
|
|= [our=ship now=@da eny=@uvJ ski=sley] :: current invocation
|
2016-11-24 07:25:07 +03:00
|
|
|
^?
|
|
|
|
|% :: poke+peek pattern
|
|
|
|
++ call :: handle request
|
2018-12-03 22:45:50 +03:00
|
|
|
|= $: hen=duct
|
|
|
|
type=*
|
|
|
|
wrapped-task=(hobo task:able)
|
2016-11-24 07:25:07 +03:00
|
|
|
==
|
2018-12-13 01:09:47 +03:00
|
|
|
^- [(list move) _..^$]
|
2018-12-03 22:45:50 +03:00
|
|
|
::
|
2018-12-13 01:09:47 +03:00
|
|
|
=/ =task:able
|
2018-12-03 22:45:50 +03:00
|
|
|
?. ?=(%soft -.wrapped-task)
|
|
|
|
wrapped-task
|
|
|
|
((hard task:able) p.wrapped-task)
|
2018-11-26 11:18:45 +03:00
|
|
|
::
|
2018-12-13 01:09:47 +03:00
|
|
|
|^ =^ moves state
|
|
|
|
::
|
|
|
|
?- -.task
|
|
|
|
:: %crud: error report; hand off to %dill to be printed
|
|
|
|
::
|
|
|
|
%crud
|
|
|
|
[[hen %slip %d %flog task]~ state]
|
|
|
|
::
|
|
|
|
:: %born: handle urbit restart
|
|
|
|
::
|
|
|
|
%born
|
|
|
|
:: store this duct for setting unix wakeup timers
|
|
|
|
::
|
|
|
|
=. unix-duct hen
|
|
|
|
:: process any elapsed timers and clear and reset :next-wake
|
|
|
|
::
|
|
|
|
=^ moves timers notify-clients
|
|
|
|
(set-wake(next-wake ~) moves)
|
|
|
|
::
|
|
|
|
:: %rest: cancel a timer, resetting :next-wake if needed
|
|
|
|
::
|
|
|
|
%rest
|
|
|
|
=. timers (unset-timer [p.task hen])
|
|
|
|
(set-wake ~)
|
|
|
|
::
|
|
|
|
:: %wait: set a new timer
|
|
|
|
::
|
|
|
|
%wait
|
|
|
|
:: process elapsed timers first to maintain sort order
|
|
|
|
::
|
|
|
|
=^ moves timers notify-clients
|
|
|
|
:: set the timer, then adjust :next-wake if needed
|
|
|
|
::
|
|
|
|
=. timers (set-timer [p.task hen])
|
|
|
|
(set-wake moves)
|
|
|
|
::
|
|
|
|
:: %wake: unix says wake up; notify clients and set next wakeup
|
|
|
|
::
|
|
|
|
%wake
|
|
|
|
=^ moves timers notify-clients
|
|
|
|
(set-wake(next-wake ~) moves)
|
|
|
|
::
|
|
|
|
:: %wegh: produce memory usage report for |mass
|
|
|
|
::
|
|
|
|
%wegh
|
|
|
|
:_ state :_ ~
|
|
|
|
:^ hen %give %mass
|
|
|
|
:- %behn
|
|
|
|
:- %|
|
|
|
|
:~ timers+[%& timers]
|
|
|
|
==
|
|
|
|
==
|
|
|
|
::
|
|
|
|
[moves ..^^$]
|
|
|
|
:: +set-timer: set a timer, maintaining the sort order of the :timers list
|
2018-11-30 23:52:32 +03:00
|
|
|
::
|
2018-12-13 01:09:47 +03:00
|
|
|
++ set-timer
|
|
|
|
|= t=timer
|
|
|
|
^+ timers
|
|
|
|
::
|
|
|
|
?~ timers
|
|
|
|
~[t]
|
|
|
|
:: timers at the same date form a lifo queue; for fifo, change +lte to +lth
|
|
|
|
::
|
|
|
|
?: (lte date.t date.i.timers)
|
|
|
|
[t timers]
|
|
|
|
::
|
|
|
|
[i.timers $(timers t.timers)]
|
|
|
|
:: +unset-timer: cancel a timer; if it already expired, no-op
|
2018-11-26 11:18:45 +03:00
|
|
|
::
|
2018-12-13 01:09:47 +03:00
|
|
|
++ unset-timer
|
|
|
|
|= [t=timer]
|
|
|
|
^+ timers
|
|
|
|
:: if we don't have this timer, no-op; for debugging, add a printf here
|
|
|
|
::
|
|
|
|
?~ timers
|
|
|
|
~
|
|
|
|
?: =(i.timers t)
|
|
|
|
t.timers
|
2016-11-24 07:25:07 +03:00
|
|
|
::
|
2018-12-13 01:09:47 +03:00
|
|
|
[i.timers $(timers t.timers)]
|
|
|
|
:: +notify-clients: wake up vanes whose timers have expired
|
|
|
|
::
|
|
|
|
++ notify-clients
|
|
|
|
=| moves=(list move)
|
|
|
|
|- ^+ [moves timers]
|
2016-11-24 07:25:07 +03:00
|
|
|
::
|
2018-12-13 01:09:47 +03:00
|
|
|
?~ timers
|
|
|
|
[moves timers]
|
2016-11-24 07:25:07 +03:00
|
|
|
::
|
2018-12-13 01:09:47 +03:00
|
|
|
?: (gth date.i.timers now)
|
|
|
|
[moves timers]
|
|
|
|
::
|
|
|
|
%_ $
|
|
|
|
timers t.timers
|
|
|
|
moves [[duct.i.timers %give %wake ~] moves]
|
2016-11-24 07:25:07 +03:00
|
|
|
==
|
2018-12-13 01:09:47 +03:00
|
|
|
:: +set-wake: set or unset a unix timer to wake us when next timer expires
|
|
|
|
::
|
|
|
|
++ set-wake
|
|
|
|
|= moves=(list move)
|
|
|
|
^+ [moves state]
|
|
|
|
:: if no timers, cancel existing wakeup timer or no-op
|
|
|
|
::
|
|
|
|
?~ timers
|
|
|
|
?~ next-wake
|
|
|
|
[~ state]
|
|
|
|
:_ state(next-wake ~)
|
|
|
|
[[unix-duct %give %doze ~] moves]
|
|
|
|
:: if :next-wake is in the past or not soon enough, reset it
|
|
|
|
::
|
|
|
|
?^ next-wake
|
|
|
|
?: &((gte date.i.timers u.next-wake) (lte now u.next-wake))
|
|
|
|
[~ state]
|
|
|
|
:_ state(next-wake `date.i.timers)
|
|
|
|
[[unix-duct %give %doze `date.i.timers] moves]
|
|
|
|
:: there was no unix wakeup timer; set one
|
|
|
|
::
|
|
|
|
:_ state(next-wake `date.i.timers)
|
|
|
|
[[unix-duct %give %doze `date.i.timers] moves]
|
|
|
|
--
|
2016-11-24 07:25:07 +03:00
|
|
|
::
|
|
|
|
++ load
|
2018-12-13 01:09:47 +03:00
|
|
|
|= old=*
|
2016-11-24 07:25:07 +03:00
|
|
|
^+ ..^$
|
2018-12-13 01:09:47 +03:00
|
|
|
?^ new=((soft behn-state) old)
|
|
|
|
~& %behn-load-new
|
|
|
|
..^$(state u.new)
|
|
|
|
~& %behn-load-wipe
|
|
|
|
..^$(state *behn-state)
|
|
|
|
:: +scry: view timer state
|
|
|
|
::
|
|
|
|
:: TODO: not referentially transparent w.r.t. elapsed timers,
|
|
|
|
:: which might or might not show up in the product
|
2016-11-24 07:25:07 +03:00
|
|
|
::
|
|
|
|
++ scry
|
2018-12-13 01:09:47 +03:00
|
|
|
|= [fur=(unit (set monk)) ren=@tas why=shop syd=desk lot=coin tyl=path]
|
2016-11-24 07:25:07 +03:00
|
|
|
^- (unit (unit cage))
|
2018-12-13 01:09:47 +03:00
|
|
|
::
|
|
|
|
?. ?=(%& -.why)
|
|
|
|
~
|
|
|
|
[~ ~ %tank !>(>timers<)]
|
2016-11-24 07:25:07 +03:00
|
|
|
::
|
2018-11-26 20:41:08 +03:00
|
|
|
++ stay state
|
2016-11-24 07:25:07 +03:00
|
|
|
++ take :: process move
|
2018-12-13 01:09:47 +03:00
|
|
|
|= [tea=wire hen=duct hin=(hypo sign)]
|
2018-12-01 22:31:54 +03:00
|
|
|
^+ [*(list move) ..^$]
|
2018-12-13 01:09:47 +03:00
|
|
|
~| %behn-take-not-implemented
|
2016-11-24 07:25:07 +03:00
|
|
|
!!
|
|
|
|
--
|