add termina vocabulary from konilo to library

FossilOrigin-Name: 6166c0e06328acc1b0dec076a7e02ff0068ec3b85d834a5218fe0158415ad6cd
This commit is contained in:
crc 2023-12-11 13:23:36 +00:00
parent a5e61c80ad
commit e0a9701691
2 changed files with 92 additions and 1 deletions

View file

@ -56,6 +56,6 @@
the device handlers
- support loading extensions at runtime via `library:load`
(searches ./library/ and ~/.config/retroforth/library/)
- library contents: block-editor x11
- library contents: block-editor termina x11
================================================================

91
library/termina.retro Normal file
View file

@ -0,0 +1,91 @@
~~~
#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 ;
~~~