2018-03-16 03:21:46 +03:00
|
|
|
/+ ford-turbo, tester
|
|
|
|
::
|
|
|
|
:- %say
|
|
|
|
|= [[now=@da eny=@ =beak] ~ ~]
|
|
|
|
:- %noun
|
|
|
|
=+ tester:tester
|
2018-03-30 04:36:09 +03:00
|
|
|
|^
|
2018-03-16 03:21:46 +03:00
|
|
|
^- wall
|
|
|
|
;: weld
|
2018-03-30 04:36:09 +03:00
|
|
|
test-is-schematic-live
|
|
|
|
test-date-from-schematic
|
2018-03-20 20:30:39 +03:00
|
|
|
test-unify-jugs
|
2018-03-21 01:39:22 +03:00
|
|
|
test-dependency-wire-encoding
|
2018-03-20 04:03:18 +03:00
|
|
|
test-literal
|
|
|
|
test-autocons-same
|
|
|
|
test-autocons-different
|
2018-03-20 22:30:48 +03:00
|
|
|
test-scry-clay-succeed
|
|
|
|
test-scry-clay-fail
|
2018-03-21 03:37:57 +03:00
|
|
|
test-scry-clay-block
|
2018-03-22 04:27:25 +03:00
|
|
|
test-scry-clay-live
|
2018-03-30 22:53:57 +03:00
|
|
|
test-pinned-in-live
|
2018-03-16 03:21:46 +03:00
|
|
|
==
|
2018-03-30 04:36:09 +03:00
|
|
|
++ test-is-schematic-live
|
2018-03-30 22:53:57 +03:00
|
|
|
~& %test-is-schematic-live
|
2018-03-30 04:36:09 +03:00
|
|
|
::
|
|
|
|
=/ ford (ford-turbo now=~1234.5.6 eny=0xdead.beef scry=scry-is-forbidden)
|
|
|
|
:: pinned-schematic shows a once build
|
|
|
|
::
|
|
|
|
=/ pinned-schematic=schematic:ford
|
|
|
|
[%pin now [%scry [%clay-live care=%x bel=[[~nul %desk] /foo/bar]]]]
|
|
|
|
:: live-schematic shows a live build
|
|
|
|
::
|
|
|
|
=/ live-schematic=schematic:ford
|
|
|
|
[%scry [%clay-live care=%x bel=[[~nul %desk] /baz/doo]]]
|
|
|
|
:: eternal-schematic shows a trivial live build
|
|
|
|
::
|
|
|
|
=/ eternal-schematic=schematic:ford
|
|
|
|
[head=[%$ %noun !>(42)] tail=[%$ %noun !>(43)]]
|
|
|
|
::
|
|
|
|
;: welp
|
|
|
|
::
|
|
|
|
%- expect-eq !>
|
|
|
|
[%.y (is-schematic-live:ford live-schematic)]
|
|
|
|
::
|
|
|
|
%- expect-eq !>
|
|
|
|
[%.n (is-schematic-live:ford pinned-schematic)]
|
|
|
|
::
|
|
|
|
%- expect-eq !>
|
|
|
|
[%.y (is-schematic-live:ford [%alts ~[live-schematic pinned-schematic]])]
|
|
|
|
::
|
|
|
|
%- expect-eq !>
|
|
|
|
[%.y (is-schematic-live:ford eternal-schematic)]
|
|
|
|
==
|
|
|
|
::
|
|
|
|
++ test-date-from-schematic
|
|
|
|
~& %test-date-from-schematic
|
|
|
|
::
|
|
|
|
=/ ford (ford-turbo now=~1234.5.6 eny=0xdead.beef scry=scry-is-forbidden)
|
|
|
|
::
|
|
|
|
=/ six-schematic=schematic:ford
|
|
|
|
[%pin ~1234.5.6 [%scry [%clay-live care=%x bel=[[~nul %desk] /foo/bar]]]]
|
|
|
|
=/ nine-schematic=schematic:ford
|
|
|
|
[%pin ~1234.5.9 [%scry [%clay-live care=%x bel=[[~nul %desk] /baz/doo]]]]
|
|
|
|
=/ three-schematic=schematic:ford
|
|
|
|
[%pin ~1234.5.3 [%scry [%clay-live care=%x bel=[[~nul %desk] /car/dor]]]]
|
|
|
|
;: welp
|
|
|
|
::
|
|
|
|
%- expect-eq !>
|
|
|
|
[~1234.5.9 (date-from-schematic:ford [three-schematic nine-schematic])]
|
|
|
|
::
|
|
|
|
%- expect-eq !>
|
|
|
|
:- ~1234.5.9
|
|
|
|
%- date-from-schematic:ford
|
|
|
|
[six-schematic [%alts ~[three-schematic nine-schematic]]]
|
|
|
|
==
|
2018-03-16 03:21:46 +03:00
|
|
|
::
|
2018-03-20 20:30:39 +03:00
|
|
|
++ test-unify-jugs
|
|
|
|
~& %test-unify-jugs
|
2018-03-30 04:36:09 +03:00
|
|
|
::
|
|
|
|
=/ ford (ford-turbo now=~1234.5.6 eny=0xdead.beef scry=scry-is-forbidden)
|
|
|
|
::
|
2018-03-20 20:30:39 +03:00
|
|
|
%- expect-eq !>
|
|
|
|
:- %+ unify-jugs:ford
|
|
|
|
`(jug @tas @ud)`(my ~[[%a (sy 1 2 ~)] [%b (sy 3 4 ~)]])
|
|
|
|
`(jug @tas @ud)`(my ~[[%b (sy 5 6 ~)] [%c (sy 7 8 ~)]])
|
|
|
|
::
|
|
|
|
`(jug @tas @ud)`(my ~[[%a (sy 1 2 ~)] [%b (sy 3 4 5 6 ~)] [%c (sy 7 8 ~)]])
|
|
|
|
::
|
2018-03-21 01:39:22 +03:00
|
|
|
++ test-dependency-wire-encoding
|
|
|
|
~& %test-dependency-wire-encoding
|
2018-03-30 04:36:09 +03:00
|
|
|
::
|
|
|
|
=/ ford (ford-turbo now=~1234.5.6 eny=0xdead.beef scry=scry-is-forbidden)
|
|
|
|
::
|
2018-03-21 01:39:22 +03:00
|
|
|
;: welp
|
|
|
|
%- expect-eq !>
|
|
|
|
:- `path`(to-wire:ford [%clay-live care=%x bel=[[~nul %desk] /foo/bar]])
|
2018-03-30 04:36:09 +03:00
|
|
|
/c/x/~nul/desk/0/bar/foo
|
2018-03-21 01:39:22 +03:00
|
|
|
::
|
|
|
|
%- expect-eq !>
|
|
|
|
:- `dependency:ford`[%clay-live care=%x bel=[[~nul %desk] /foo/bar]]
|
2018-03-30 04:36:09 +03:00
|
|
|
(from-wire:ford /c/x/~nul/desk/0/bar/foo)
|
2018-03-21 01:39:22 +03:00
|
|
|
::
|
|
|
|
%- expect-eq !>
|
|
|
|
:- ^- path
|
|
|
|
(to-wire:ford [%gall-live care=%x bel=[[~nul %desk] /foo/bar]])
|
2018-03-30 04:36:09 +03:00
|
|
|
/g/x/~nul/desk/0/bar/foo
|
2018-03-21 01:39:22 +03:00
|
|
|
::
|
|
|
|
%- expect-eq !>
|
|
|
|
:- ^- dependency:ford
|
|
|
|
[%gall-live care=%x bel=[[~nul %desk] /foo/bar]]
|
2018-03-30 04:36:09 +03:00
|
|
|
(from-wire:ford /g/x/~nul/desk/0/bar/foo)
|
2018-03-21 01:39:22 +03:00
|
|
|
==
|
|
|
|
::
|
2018-03-20 04:03:18 +03:00
|
|
|
++ test-literal
|
|
|
|
~& %test-literal
|
2018-03-30 04:36:09 +03:00
|
|
|
::
|
|
|
|
=/ ford (ford-turbo now=~1234.5.6 eny=0xdead.beef scry=scry-is-forbidden)
|
|
|
|
::
|
2018-03-19 21:23:04 +03:00
|
|
|
=^ moves ford
|
|
|
|
%- call:ford
|
2018-03-23 21:53:38 +03:00
|
|
|
:* duct=~ type=~ %make ~nul
|
2018-03-30 04:36:09 +03:00
|
|
|
[%pin ~1234.5.6 [%$ %noun !>(**)]]
|
2018-03-19 21:23:04 +03:00
|
|
|
==
|
2018-03-20 04:03:18 +03:00
|
|
|
%+ welp
|
|
|
|
%- expect-eq !>
|
|
|
|
:- moves
|
2018-03-30 04:36:09 +03:00
|
|
|
:~ :* duct=~ %give %made ~1234.5.6
|
|
|
|
%complete %result %pin ~1234.5.6 %result %$ %noun !>(**)
|
|
|
|
== ==
|
2018-03-20 04:03:18 +03:00
|
|
|
::
|
|
|
|
%- expect-eq !>
|
|
|
|
:- state-by-ship.+>+<.ford
|
|
|
|
(my [~nul *ford-state:ford-turbo]~)
|
|
|
|
::
|
|
|
|
++ test-autocons-same
|
|
|
|
~& %test-autocons-same
|
2018-03-30 04:36:09 +03:00
|
|
|
::
|
|
|
|
=/ ford (ford-turbo now=~1234.5.6 eny=0xdead.beef scry=scry-is-forbidden)
|
|
|
|
::
|
2018-03-20 04:03:18 +03:00
|
|
|
=^ moves ford
|
|
|
|
%- call:ford
|
2018-03-23 21:53:38 +03:00
|
|
|
:* duct=~ type=~ %make ~nul
|
2018-03-30 04:36:09 +03:00
|
|
|
[%pin ~1234.5.6 [%$ %noun !>(**)] [%$ %noun !>(**)]]
|
2018-03-20 04:03:18 +03:00
|
|
|
==
|
|
|
|
%+ welp
|
|
|
|
%- expect-eq !>
|
|
|
|
:- moves
|
|
|
|
:~ :* duct=~ %give %made ~1234.5.6 %complete
|
2018-03-30 04:36:09 +03:00
|
|
|
%result %pin ~1234.5.6 %result
|
2018-03-20 04:03:18 +03:00
|
|
|
[%result %$ %noun !>(**)]
|
|
|
|
[%result %$ %noun !>(**)]
|
|
|
|
== ==
|
|
|
|
::
|
|
|
|
%- expect-eq !>
|
|
|
|
:- state-by-ship.+>+<.ford
|
|
|
|
(my [~nul *ford-state:ford-turbo]~)
|
|
|
|
::
|
|
|
|
++ test-autocons-different
|
|
|
|
~& %test-autocons-different
|
2018-03-30 04:36:09 +03:00
|
|
|
::
|
|
|
|
=/ ford (ford-turbo now=~1234.5.6 eny=0xdead.beef scry=scry-is-forbidden)
|
|
|
|
::
|
2018-03-20 04:03:18 +03:00
|
|
|
=^ moves ford
|
|
|
|
%- call:ford
|
2018-03-23 21:53:38 +03:00
|
|
|
:* duct=~ type=~ %make ~nul
|
2018-03-30 04:36:09 +03:00
|
|
|
[%pin ~1234.5.6 [%$ %noun !>(42)] [%$ %noun !>(43)]]
|
2018-03-20 04:03:18 +03:00
|
|
|
==
|
|
|
|
%+ welp
|
|
|
|
%- expect-eq !>
|
|
|
|
:- moves
|
|
|
|
:~ :* duct=~ %give %made ~1234.5.6 %complete
|
2018-03-30 04:36:09 +03:00
|
|
|
%result %pin ~1234.5.6 %result
|
2018-03-20 04:03:18 +03:00
|
|
|
[%result %$ %noun !>(42)]
|
|
|
|
[%result %$ %noun !>(43)]
|
|
|
|
== ==
|
2018-03-19 21:23:04 +03:00
|
|
|
::
|
2018-03-16 03:21:46 +03:00
|
|
|
%- expect-eq !>
|
2018-03-19 21:23:04 +03:00
|
|
|
:- state-by-ship.+>+<.ford
|
2018-03-19 21:33:34 +03:00
|
|
|
(my [~nul *ford-state:ford-turbo]~)
|
2018-03-20 22:01:49 +03:00
|
|
|
::
|
2018-03-20 22:30:48 +03:00
|
|
|
++ test-scry-clay-succeed
|
|
|
|
~& %test-scry-clay-succeed
|
2018-03-30 04:36:09 +03:00
|
|
|
::
|
2018-03-23 21:53:38 +03:00
|
|
|
=/ scry (scry-succeed ~1234.5.6 [%noun !>(42)])
|
2018-03-30 04:36:09 +03:00
|
|
|
=/ ford (ford-turbo now=~1234.5.6 eny=0xdead.beef scry=scry)
|
2018-03-20 22:01:49 +03:00
|
|
|
::
|
|
|
|
=^ moves ford
|
|
|
|
%- call:ford
|
2018-03-23 21:53:38 +03:00
|
|
|
:* duct=~ type=~ %make ~nul
|
2018-03-30 04:36:09 +03:00
|
|
|
[%pin ~1234.5.6 [%scry %clay-live ren=%x rail=[[~nul %desk] /bar/foo]]]
|
2018-03-20 22:01:49 +03:00
|
|
|
==
|
|
|
|
%+ welp
|
|
|
|
%- expect-eq !>
|
|
|
|
:- moves
|
|
|
|
:~ :* duct=~ %give %made ~1234.5.6 %complete %result
|
2018-03-30 04:36:09 +03:00
|
|
|
[%pin ~1234.5.6 %result [%scry %noun !>(42)]]
|
2018-03-20 22:01:49 +03:00
|
|
|
== ==
|
|
|
|
::
|
|
|
|
%- expect-eq !>
|
|
|
|
:- state-by-ship.+>+<.ford
|
|
|
|
(my [~nul *ford-state:ford-turbo]~)
|
2018-03-20 22:30:48 +03:00
|
|
|
::
|
|
|
|
++ test-scry-clay-fail
|
|
|
|
~& %test-scry-clay-fail
|
2018-03-30 04:36:09 +03:00
|
|
|
::
|
2018-03-23 21:53:38 +03:00
|
|
|
=/ scry (scry-fail ~1234.5.6)
|
2018-03-30 04:36:09 +03:00
|
|
|
=/ ford (ford-turbo now=~1234.5.6 eny=0xdead.beef scry=scry)
|
2018-03-20 22:30:48 +03:00
|
|
|
::
|
|
|
|
=^ moves ford
|
|
|
|
%- call:ford
|
2018-03-23 21:53:38 +03:00
|
|
|
:* duct=~ type=~ %make ~nul
|
2018-03-30 04:36:09 +03:00
|
|
|
[%pin ~1234.5.6 [%scry %clay-live ren=%x rail=[[~nul %desk] /bar/foo]]]
|
|
|
|
::
|
2018-03-20 22:30:48 +03:00
|
|
|
==
|
|
|
|
%+ welp
|
|
|
|
%- expect-eq !>
|
|
|
|
:- moves
|
2018-03-30 04:36:09 +03:00
|
|
|
:~ :* duct=~ %give %made ~1234.5.6 %complete
|
|
|
|
%result %pin ~1234.5.6 %error
|
|
|
|
:~ leaf+"clay-live scry failed for"
|
2018-03-20 22:30:48 +03:00
|
|
|
leaf+"%cx /~nul/desk/~1234.5.6/foo/bar"
|
|
|
|
== == ==
|
|
|
|
::
|
|
|
|
%- expect-eq !>
|
|
|
|
:- state-by-ship.+>+<.ford
|
|
|
|
(my [~nul *ford-state:ford-turbo]~)
|
2018-03-21 01:39:22 +03:00
|
|
|
::
|
2018-03-21 03:37:57 +03:00
|
|
|
++ test-scry-clay-block
|
|
|
|
~& %test-scry-clay-block
|
2018-03-30 04:36:09 +03:00
|
|
|
::
|
2018-03-23 21:53:38 +03:00
|
|
|
=/ scry-blocked (scry-block ~1234.5.6)
|
2018-03-30 04:36:09 +03:00
|
|
|
=/ ford (ford-turbo now=~1234.5.6 eny=0xdead.beef scry=scry-blocked)
|
2018-03-21 03:37:57 +03:00
|
|
|
::
|
|
|
|
=^ moves ford
|
|
|
|
%- call:ford
|
2018-03-23 21:53:38 +03:00
|
|
|
:* duct=~ type=~ %make ~nul
|
2018-03-30 04:36:09 +03:00
|
|
|
[%pin ~1234.5.6 [%scry %clay-live ren=%x rail=[[~nul %desk] /bar/foo]]]
|
2018-03-21 03:37:57 +03:00
|
|
|
==
|
|
|
|
%+ welp
|
|
|
|
%- expect-eq !>
|
|
|
|
:- moves
|
2018-03-22 23:30:44 +03:00
|
|
|
:~ :* duct=~ %pass
|
2018-03-30 04:36:09 +03:00
|
|
|
wire=/~nul/dependency/c/x/~nul/desk/0/foo/bar
|
2018-03-21 03:37:57 +03:00
|
|
|
%c %warp [~nul ~nul] %desk
|
|
|
|
~ %sing %x [%da ~1234.5.6] /bar/foo
|
|
|
|
== ==
|
|
|
|
::
|
2018-03-21 04:20:11 +03:00
|
|
|
=. ford (ford now=~1234.5.7 eny=0xbeef.dead scry=scry-is-forbidden)
|
2018-03-21 03:37:57 +03:00
|
|
|
::
|
|
|
|
=^ moves2 ford
|
|
|
|
%- take:ford
|
2018-03-30 04:36:09 +03:00
|
|
|
:* wire=/~nul/dependency/c/x/~nul/desk/0/foo/bar duct=~
|
2018-03-21 03:37:57 +03:00
|
|
|
^= wrapped-sign ^- (hypo sign:ford) :- *type :: ^- sign:ford
|
|
|
|
[%c %writ ~ [%x [%da ~1234.5.6] %desk] /bar/foo %noun !>(42)]
|
|
|
|
==
|
|
|
|
::
|
|
|
|
%+ welp
|
|
|
|
%- expect-eq !>
|
|
|
|
:- moves2
|
|
|
|
:~ :* duct=~ %give %made ~1234.5.6 %complete %result
|
2018-03-30 04:36:09 +03:00
|
|
|
[%pin ~1234.5.6 %result [%scry %noun !>(42)]]
|
2018-03-21 03:37:57 +03:00
|
|
|
== ==
|
|
|
|
::
|
|
|
|
%- expect-eq !>
|
|
|
|
:- state-by-ship.+>+<.ford
|
|
|
|
(my [~nul *ford-state:ford-turbo]~)
|
2018-03-22 04:27:25 +03:00
|
|
|
::
|
|
|
|
++ test-scry-clay-live
|
|
|
|
~& %test-scry-clay-live
|
2018-03-30 04:36:09 +03:00
|
|
|
::
|
2018-03-23 21:53:38 +03:00
|
|
|
=/ scry-42 (scry-succeed ~1234.5.6 [%noun !>(42)])
|
|
|
|
=/ scry-43 (scry-succeed ~1234.5.7 [%noun !>(43)])
|
2018-03-23 05:17:00 +03:00
|
|
|
::
|
2018-03-30 04:36:09 +03:00
|
|
|
=/ ford (ford-turbo now=~1234.5.6 eny=0xdead.beef scry=scry-42)
|
|
|
|
::
|
2018-03-22 04:27:25 +03:00
|
|
|
=^ moves ford
|
|
|
|
%- call:ford
|
2018-03-23 21:53:38 +03:00
|
|
|
:* duct=~ type=~ %make ~nul
|
2018-03-30 04:36:09 +03:00
|
|
|
[%scry %clay-live care=%x rail=[[~nul %desk] /bar/foo]]
|
2018-03-22 04:27:25 +03:00
|
|
|
==
|
2018-03-30 04:36:09 +03:00
|
|
|
;: welp
|
2018-03-22 04:27:25 +03:00
|
|
|
%- expect-eq !>
|
|
|
|
:- moves
|
|
|
|
:~ :* duct=~ %give %made ~1234.5.6 %complete %result
|
|
|
|
[%scry %noun !>(42)]
|
|
|
|
==
|
2018-03-22 23:30:44 +03:00
|
|
|
:* duct=~ %pass wire=/~nul/clay-sub/~nul/desk
|
2018-03-22 04:27:25 +03:00
|
|
|
%c %warp [~nul ~nul] %desk
|
2018-03-22 23:30:44 +03:00
|
|
|
`[%mult [%da ~1234.5.6] (sy [%x /foo/bar]~)]
|
2018-03-22 04:27:25 +03:00
|
|
|
== ==
|
|
|
|
::
|
2018-03-30 04:36:09 +03:00
|
|
|
=. ford (ford now=~1234.5.7 eny=0xbeef.dead scry=scry-43)
|
|
|
|
=^ moves2 ford
|
|
|
|
%- take:ford
|
|
|
|
:* wire=/~nul/clay-sub/~nul/desk duct=~
|
|
|
|
^= wrapped-sign ^- (hypo sign:ford) :- *type
|
|
|
|
[%c %wris [%da ~1234.5.7] (sy [%x /foo/bar]~)]
|
2018-03-23 05:17:00 +03:00
|
|
|
==
|
2018-03-30 04:36:09 +03:00
|
|
|
%- expect-eq !>
|
|
|
|
:- moves2
|
|
|
|
:~ :* duct=~ %give %made ~1234.5.7 %complete %result
|
|
|
|
[%scry %noun !>(43)]
|
|
|
|
==
|
|
|
|
:* duct=~ %pass wire=/~nul/clay-sub/~nul/desk
|
|
|
|
%c %warp [~nul ~nul] %desk
|
|
|
|
`[%mult [%da ~1234.5.7] (sy [%x /foo/bar]~)]
|
|
|
|
== ==
|
|
|
|
::
|
|
|
|
=. ford (ford now=~1234.5.8 eny=0xbeef.dead scry=scry-is-forbidden)
|
|
|
|
=^ moves3 ford
|
|
|
|
(call:ford [duct=~ type=~ %kill ~nul])
|
|
|
|
::
|
|
|
|
%+ welp
|
|
|
|
%- expect-eq !>
|
|
|
|
:- moves3
|
|
|
|
:~ :* duct=~ %pass wire=/~nul/clay-sub/~nul/desk
|
|
|
|
%c %warp [~nul ~nul] %desk ~
|
|
|
|
== ==
|
|
|
|
::
|
|
|
|
%- expect-eq !>
|
|
|
|
:- state-by-ship.+>+<.ford
|
|
|
|
(my [~nul *ford-state:ford-turbo]~)
|
|
|
|
==
|
2018-03-30 22:53:57 +03:00
|
|
|
++ test-pinned-in-live
|
|
|
|
~& %test-pinned-in-live
|
|
|
|
::
|
|
|
|
=/ scry-42 (scry-succeed ~1234.5.6 [%noun !>(42)])
|
|
|
|
=/ scry-43 (scry-succeed ~1234.5.7 [%noun !>(43)])
|
|
|
|
::
|
|
|
|
=/ ford (ford-turbo now=~1234.5.6 eny=0xdead.beef scry=scry-42)
|
|
|
|
::
|
|
|
|
=/ schematic=schematic:ford
|
|
|
|
:* %same %pin ~1234.5.6
|
|
|
|
[%scry %clay-live care=%x rail=[[~nul %desk] /bar/foo]]
|
|
|
|
==
|
|
|
|
=/ build=build:ford [~1234.5.6 schematic]
|
|
|
|
=/ result=build-result:ford
|
|
|
|
[%result %same %result %pin ~1234.5.6 %result [%scry %noun !>(42)]]
|
|
|
|
::
|
|
|
|
=^ moves ford (call:ford [duct=~ type=~ %make ~nul schematic])
|
|
|
|
;: welp
|
|
|
|
%- expect-eq !>
|
|
|
|
:- moves
|
|
|
|
[duct=~ %give %made ~1234.5.6 %complete result]~
|
|
|
|
::
|
|
|
|
%- expect-eq !>
|
|
|
|
:- results:(~(got by state-by-ship.+>+<.ford) ~nul)
|
|
|
|
%- my :~
|
|
|
|
:- [~1234.5.6 [%scry %clay-live care=%x rail=[[~nul %desk] /bar/foo]]]
|
|
|
|
[%result ~1234.5.6 %result %scry %noun !>(42)]
|
|
|
|
::
|
|
|
|
:- :* ~1234.5.6 %pin ~1234.5.6
|
|
|
|
[%scry %clay-live care=%x rail=[[~nul %desk] /bar/foo]]
|
|
|
|
==
|
|
|
|
[%result ~1234.5.6 %result %pin ~1234.5.6 %result %scry %noun !>(42)]
|
|
|
|
::
|
|
|
|
:- :* ~1234.5.6 %same %pin ~1234.5.6
|
|
|
|
[%scry %clay-live care=%x rail=[[~nul %desk] /bar/foo]]
|
|
|
|
==
|
|
|
|
:* %result ~1234.5.6 %result %same %result %pin ~1234.5.6
|
|
|
|
%result %scry %noun !>(42)
|
|
|
|
==
|
|
|
|
==
|
|
|
|
::
|
|
|
|
=. ford (ford now=~1234.5.8 eny=0xbeef.dead scry=scry-is-forbidden)
|
|
|
|
=^ moves2 ford
|
|
|
|
(call:ford [duct=~ type=~ %kill ~nul])
|
|
|
|
::
|
|
|
|
%+ welp
|
|
|
|
%- expect-eq !>
|
|
|
|
[moves2 ~]
|
|
|
|
::
|
|
|
|
%- expect-eq !>
|
|
|
|
:- state-by-ship.+>+<.ford
|
|
|
|
(my [~nul *ford-state:ford-turbo]~)
|
|
|
|
==
|
2018-03-23 21:53:38 +03:00
|
|
|
::
|
|
|
|
:: |utilities: helper arms
|
|
|
|
::
|
|
|
|
::+| utilities
|
|
|
|
::
|
|
|
|
:: +scry-succeed: produces a scry function with a known request and answer
|
|
|
|
::
|
|
|
|
++ scry-succeed
|
|
|
|
|= [date=@da result=cage] ^- sley
|
|
|
|
|= [* (unit (set monk)) =term =beam]
|
|
|
|
^- (unit (unit cage))
|
|
|
|
::
|
|
|
|
~| scry-succeed+[beam+beam term+term]
|
|
|
|
?> =(term %cx)
|
|
|
|
?> =(beam [[~nul %desk %da date] /bar/foo])
|
|
|
|
::
|
|
|
|
[~ ~ result]
|
|
|
|
:: +scry-fail: produces a scry function with a known request and failed answer
|
|
|
|
::
|
|
|
|
++ scry-fail
|
|
|
|
|= date=@da ^- sley
|
|
|
|
|= [* (unit (set monk)) =term =beam]
|
|
|
|
^- (unit (unit cage))
|
|
|
|
::
|
|
|
|
~| scry-fail+[beam+beam term+term]
|
|
|
|
?> =(term %cx)
|
|
|
|
?> =(beam [[~nul %desk %da date] /bar/foo])
|
|
|
|
::
|
|
|
|
[~ ~]
|
|
|
|
:: +scry-block: produces a scry function with known request and blocked answer
|
|
|
|
::
|
|
|
|
++ scry-block
|
|
|
|
|= date=@da ^- sley
|
|
|
|
|= [* (unit (set monk)) =term =beam]
|
|
|
|
^- (unit (unit cage))
|
|
|
|
::
|
|
|
|
~| scry-block+[beam+beam term+term]
|
|
|
|
?> =(term %cx)
|
|
|
|
?> =(beam [[~nul %desk %da date] /bar/foo])
|
|
|
|
::
|
|
|
|
~
|
|
|
|
:: +scry-is-forbidden: makes sure ford does not attempt to scry
|
|
|
|
::
|
|
|
|
++ scry-is-forbidden ^- sley
|
|
|
|
|= [* (unit (set monk)) =term =beam]
|
|
|
|
^- (unit (unit cage))
|
|
|
|
::
|
|
|
|
~| scry-is-forbidden+[beam+beam term+term]
|
|
|
|
!!
|
2018-03-16 03:21:46 +03:00
|
|
|
--
|