mirror of
https://git.sr.ht/~crc_/retroforth
synced 2024-11-16 19:48:56 +01:00
92 lines
2.7 KiB
Forth
92 lines
2.7 KiB
Forth
|
~~~
|
||
|
#74 'ti:width var-n
|
||
|
#21 'ti:height var-n
|
||
|
|
||
|
:vt:esc (-) #27 c:put ;
|
||
|
:vt:csi (-) vt:esc $[ c:put ;
|
||
|
|
||
|
:vt:home (-) vt:csi $H c:put ;
|
||
|
:vt:row,col (nn-) vt:csi swap n:put $; c:put n:put $H c:put ;
|
||
|
:vt:up (-) vt:csi n:put $A c:put ;
|
||
|
:vt:down (-) vt:csi n:put $B c:put ;
|
||
|
:vt:right (-) vt:csi n:put $C c:put ;
|
||
|
:vt:left (-) vt:csi n:put $D c:put ;
|
||
|
:vt:clear (-) vt:csi '2J s:put ;
|
||
|
:vt:reset vt:csi '0m s:put ;
|
||
|
|
||
|
:vt:set/color (n-) vt:csi '1;34; s:put n:put $m c:put ;
|
||
|
|
||
|
:fg:black #30 vt:set/color ; :bg:black #40 vt:set/color ;
|
||
|
:fg:red #31 vt:set/color ; :bg:red #41 vt:set/color ;
|
||
|
:fg:green #32 vt:set/color ; :bg:green #42 vt:set/color ;
|
||
|
:fg:yellow #33 vt:set/color ; :bg:yellow #43 vt:set/color ;
|
||
|
:fg:blue #34 vt:set/color ; :bg:blue #44 vt:set/color ;
|
||
|
:fg:magenta #35 vt:set/color ; :bg:magenta #45 vt:set/color ;
|
||
|
:fg:cyan #36 vt:set/color ; :bg:cyan #46 vt:set/color ;
|
||
|
:fg:white #37 vt:set/color ; :bg:white #47 vt:set/color ;
|
||
|
|
||
|
'ti:Actions d:create #128 comma #128 allot
|
||
|
|
||
|
:ti:set-action (qc-) &ti:Actions swap a:store ;
|
||
|
|
||
|
:ti:reset-actions (-)
|
||
|
#128 [ #0 I ti:set-action ] indexed-times ;
|
||
|
|
||
|
:ti:get-action (c-q) &ti:Actions swap a:fetch ;
|
||
|
|
||
|
:ti:perform-action (c-)
|
||
|
ti:get-action dup n:-zero? &call &drop choose ;
|
||
|
|
||
|
:ti:input (-) c:get ti:perform-action ;
|
||
|
|
||
|
{{
|
||
|
'ti:Hints d:create #130 allot :empty (-s) '____________ ;
|
||
|
:constrain (s-s) dup s:length #12 gt? [ #12 s:left ] if ;
|
||
|
:pad (s-s) #32 empty #12 fill
|
||
|
empty over s:length copy empty ;
|
||
|
:start (n-a) #13 n:mul &ti:Hints n:add ;
|
||
|
:display (-) I n:inc dup #10 eq? [ drop #0 ] if
|
||
|
dup n:put sp start s:put sp ;
|
||
|
:clean (-) '_ s:temp constrain pad I start #13 copy ;
|
||
|
---reveal---
|
||
|
:ti:add-hint (sn-)
|
||
|
#13 n:mul &ti:Hints n:add [ constrain pad ] dip #13 copy ;
|
||
|
:ti:reset-hints (-) #10 &clean indexed-times ;
|
||
|
:ti:hints #10 [ display I #4 eq? &nl if ] indexed-times ;
|
||
|
}}
|
||
|
|
||
|
:ti:display/none ;
|
||
|
|
||
|
&ti:display/none 'ti:Display var-n
|
||
|
|
||
|
:ti:set-display (a-) !ti:Display ;
|
||
|
|
||
|
:ti:reset-display (-) &ti:display/none ti:set-display ;
|
||
|
|
||
|
:ti:display (-)
|
||
|
vt:home @ti:Display call
|
||
|
@ti:height #3 n:sub #0 vt:row,col @ti:width [ $- c:put ] times
|
||
|
nl ti:hints nl ;
|
||
|
|
||
|
'ti:ptrs d:create #0 comma #5 allot
|
||
|
:ti:add-program (a-) &ti:ptrs v:inc &ti:ptrs @ti:ptrs a:store ;
|
||
|
:ti:current (-a) &ti:ptrs @ti:ptrs a:fetch ;
|
||
|
:ti:more? (-f) @ti:ptrs n:-zero? ;
|
||
|
:ti:remove &ti:ptrs v:dec ;
|
||
|
|
||
|
:ti:load (-)
|
||
|
ti:current call
|
||
|
!ti:Display ti:reset-hints call ti:reset-actions call ;
|
||
|
|
||
|
'ti:Done var
|
||
|
:ti:done #-1 !ti:Done vt:reset nl ;
|
||
|
:ti:done? @ti:Done ;
|
||
|
|
||
|
:ti:application/run (-)
|
||
|
[ #0 !ti:Done ti:display ti:input ti:done? ] until
|
||
|
ti:remove ti:more? [ ti:load #0 !ti:Done ] if ;
|
||
|
|
||
|
:ti:application (q-)
|
||
|
ti:add-program ti:load ti:application/run ;
|
||
|
~~~
|