295 lines
7.1 KiB
Plaintext
295 lines
7.1 KiB
Plaintext
(
|
|
app/neralie : clock with arvelie date
|
|
|
|
TODO
|
|
- Implement higher resolution time rather than counting fps
|
|
)
|
|
|
|
;fps { current 1 next 1 second 1 }
|
|
;number { started 1 count 1 }
|
|
;lines { x1 2 x2 2 y1 2 y2 2 addr 2 }
|
|
;neralie { n0123 2 n4 1 n5 1 n6 1 n7 1 n8 1 n9 1 color 1 x 2 y 2 w 2 h 2 }
|
|
;mul { ahi 1 alo 1 bhi 1 blo 1 }
|
|
|
|
|0100 ;System { vector 2 pad 6 r 2 g 2 b 2 }
|
|
|0110 ;Console { pad 8 char 1 byte 1 short 2 }
|
|
|0120 ;Screen { vector 2 width 2 height 2 pad 2 x 2 y 2 addr 2 color 1 }
|
|
|01a0 ;DateTime { year 2 month 1 day 1 hour 1 minute 1 second 1 dotw 1 doty 2 isdst 1 pad 4 refresh 1 }
|
|
|
|
( program )
|
|
|
|
|0200
|
|
|
|
( theme ) #03fd =System.r #0ef3 =System.g #0bf2 =System.b
|
|
( vectors ) ,on-screen =Screen.vector
|
|
#01 =fps.current
|
|
|
|
#000c
|
|
DUP2 =lines.x1
|
|
DUP2 =lines.y1
|
|
DUP2 ~Screen.width SWP2 SUB2 #0001 SUB2 =lines.x2
|
|
~Screen.height SWP2 SUB2 =lines.y2
|
|
|
|
#02 =neralie.color
|
|
~lines.x1 ~lines.x2
|
|
OVR2 OVR2 ~lines.y1 ,h JSR2
|
|
~lines.y2 ,h JSR2
|
|
~lines.y1 #0001 SUB2 ~lines.y2 #0001 ADD2
|
|
OVR2 OVR2 ~lines.x1 ,v JSR2
|
|
~lines.x2 ,v JSR2
|
|
|
|
@on-screen
|
|
,update-fps JSR2
|
|
#00 =neralie.color
|
|
,neralie-lines JSR2
|
|
,neralie-calc JSR2
|
|
#02 =neralie.color
|
|
,arvelie-text JSR2
|
|
,neralie-text JSR2
|
|
,neralie-lines JSR2
|
|
BRK
|
|
|
|
#22 =Screen.color
|
|
#0000 #00 ~number.count DUP2 ,h JSR2
|
|
~number.count #01 ADD =number.count
|
|
|
|
@neralie-calc ( -- )
|
|
( add up fractions of a pulse, store tenths in n6 )
|
|
#0120 #00 ~DateTime.hour MUL2
|
|
#00c0 #00 ~DateTime.minute MUL2 ADD2
|
|
#00f8 #00 ~DateTime.second MUL2 ADD2
|
|
#0271 #00 ~fps.next MUL2 #00 ~fps.current DIV2 #0008 MUL2 ADD2
|
|
#01b0 ,modf JSR2 SWP2 #0017 MUL2 #03e8 DIV2 =neralie.n6 POP
|
|
|
|
( add up units and tens of pulses, store in n5 and n4 )
|
|
#0042 #00 ~DateTime.hour MUL2 ADD2
|
|
#005e #00 ~DateTime.minute MUL2 ADD2
|
|
#000b #00 ~DateTime.second MUL2 ADD2
|
|
#000a ,modf JSR2 SWP2 =neralie.n5 POP
|
|
#000a ,modf JSR2 SWP2 =neralie.n4 POP
|
|
|
|
( add up hundreds of pulses + 10 x beats, store in n0123 )
|
|
#01a0 #00 ~DateTime.hour MUL2 ADD2
|
|
#0006 #00 ~DateTime.minute MUL2 ADD2 =neralie.n0123
|
|
|
|
JMP2r
|
|
|
|
@arvelie-text ( -- )
|
|
~Screen.width #0002 DIV2 #0034 SUB2 =Screen.x
|
|
~Screen.height #0008 SUB2 =Screen.y
|
|
~DateTime.year #07d6 SUB2
|
|
#000a ,modf JSR2 ,digit JSR2
|
|
,digit JSR2
|
|
~DateTime.doty
|
|
#000e ,modf JSR2 ^letter JSR
|
|
#000a ,modf JSR2 ^digit JSR
|
|
^digit JSR
|
|
JMP2r
|
|
|
|
@neralie-text ( -- )
|
|
~Screen.width #0002 DIV2 #0004 SUB2 =Screen.x
|
|
~neralie.n0123
|
|
#03e8 ,modf JSR2 ^digit JSR
|
|
#0064 ,modf JSR2 ^digit JSR
|
|
#000a ,modf JSR2 ^digit JSR
|
|
#000b ^digit JSR ( the colon )
|
|
^digit JSR
|
|
#00 ~neralie.n4 ^digit JSR
|
|
#00 ~neralie.n5 ^digit JSR
|
|
JMP2r
|
|
|
|
@letter ( index* -- )
|
|
#0008 MUL2 ,font-letters ADD2 =Screen.addr
|
|
^digit-middle JMP
|
|
|
|
@digit ( index* -- )
|
|
#0008 MUL2 ,font-numbers ADD2 =Screen.addr
|
|
$middle
|
|
~neralie.color #20 ADD =Screen.color
|
|
~Screen.x #0008 ADD2 =Screen.x
|
|
JMP2r
|
|
|
|
@neralie-lines ( -- )
|
|
~lines.x2 ~lines.x1 DUP2 =neralie.x SUB2 =neralie.w
|
|
~lines.y2 ~lines.y1 DUP2 =neralie.y SUB2 =neralie.h
|
|
|
|
,neralie.n4 SWP POP ~neralie.n0123
|
|
DUP2 ,$h JSR2
|
|
,$next JSR2 #0001 =Screen.x ~neralie.y #0003 SUB2 =Screen.y ^digit JSR
|
|
DUP2 ,$v JSR2
|
|
#04 ,v-spacing POK2
|
|
~lines.y1 #0003 SUB2 ~neralie.y ~neralie.x ,v JSR2
|
|
#01 ,v-spacing POK2
|
|
^$next JSR #0001 =Screen.y ~neralie.x #0003 SUB2 =Screen.x ,digit JSR2
|
|
DUP2 ^$h JSR
|
|
^$next JSR ~Screen.width #0009 SUB2 =Screen.x ~neralie.y #0003 SUB2 =Screen.y ,digit JSR2
|
|
DUP2 ^$v JSR
|
|
^$next JSR POP2
|
|
DUP2 ^$h JSR
|
|
^$next JSR POP2
|
|
DUP2 ^$v JSR
|
|
POP2 POP
|
|
JMP2r
|
|
|
|
$next ( digit-addr number* -- next-digit-addr next-number* prev-digit* )
|
|
#03e8 ,modf JSR2 STH2 #000a MUL2
|
|
ROT DUP STH #01 ADD ROT ROT
|
|
#00 STHr PEK ADD2
|
|
STH2r
|
|
JMP2r
|
|
|
|
$h ( number* -- )
|
|
^scale JSR
|
|
~neralie.h ,mul2hi JSR2
|
|
DUP2 #0000 NEQ2 #02 JNZ POP2 JMP2r
|
|
DUP2 ~neralie.y ADD2 =neralie.y
|
|
~neralie.h SWP2 SUB2 =neralie.h
|
|
~neralie.x DUP2 ~neralie.w ADD2 ~neralie.y ^h JMP
|
|
|
|
$v ( number* -- )
|
|
^scale JSR
|
|
~neralie.w ,mul2hi JSR2
|
|
DUP2 #0000 NEQ2 #02 JNZ POP2 JMP2r
|
|
DUP2 ~neralie.x ADD2 =neralie.x
|
|
~neralie.w SWP2 SUB2 =neralie.w
|
|
~neralie.y DUP2 ~neralie.h ADD2 ~neralie.x ^v JMP
|
|
|
|
@scale ( 0..10000* -- 0..65535* )
|
|
DUP2 #8db8 ,mul2hi JSR2
|
|
SWP2 #0006 MUL2 ADD2
|
|
JMP2r
|
|
|
|
@h ( x1* x2* y* -- )
|
|
=Screen.y
|
|
,Screen.x =lines.addr
|
|
^v-draw-line JMP
|
|
|
|
@v ( y1* y2* x* -- )
|
|
=Screen.x
|
|
,Screen.y =lines.addr
|
|
|
|
$draw-line ( v1* v2* -- )
|
|
OVR2 OVR2 LTH2 #01 JNZ SWP2
|
|
STH2
|
|
|
|
$loop
|
|
LIT2 [ 00 ] $spacing [ 01 ] ADD2
|
|
DUP2 DUP2r STH2r LTH2 ^$keep-going JNZ
|
|
POP2 POP2r
|
|
JMP2r
|
|
|
|
$keep-going
|
|
DUP2 ~lines.addr STR2
|
|
~neralie.color =Screen.color
|
|
^$loop JMP
|
|
|
|
@update-fps ( -- )
|
|
#00 =DateTime.refresh
|
|
~fps.next #01 ADD =fps.next
|
|
~DateTime.second ~fps.second NEQ JMP JMP2r
|
|
~DateTime.second =fps.second
|
|
~fps.next =fps.current
|
|
|
|
( ~fps.next ^print-byte-decimal JSR
|
|
,strings-fps ^print-string JSR )
|
|
|
|
#00 =fps.next
|
|
JMP2r
|
|
|
|
@print-string ( string* -- )
|
|
DUP2 PEK2 DUP ^$not-end JNZ
|
|
POP POP2 JMP2r
|
|
|
|
$not-end
|
|
=Console.char
|
|
#0001 ADD2 ^print-string JMP
|
|
|
|
@print-byte-decimal ( byte -- )
|
|
#00 =number.started
|
|
#00 SWP
|
|
^print-short-decimal-byte-start JMP
|
|
|
|
@print-short-decimal ( short* -- )
|
|
#00 =number.started
|
|
#2710 ^modf JSR ^$digit JSR
|
|
#03e8 ^modf JSR ^$digit JSR
|
|
$byte-start
|
|
#0064 ^modf JSR ^$digit JSR
|
|
#000a ^modf JSR ^$digit JSR
|
|
^$digit JSR
|
|
~number.started ^$end JNZ
|
|
#30 =Console.char
|
|
$end JMP2r
|
|
|
|
$digit
|
|
SWP POP
|
|
DUP ~number.started ORA #02 JNZ
|
|
POP JMP2r
|
|
#30 ADD =Console.char
|
|
#01 =number.started
|
|
JMP2r
|
|
|
|
@modf ( dividend* divisor* -- remainder* quotient* )
|
|
OVR2 OVR2 DIV2 DUP2 STH2 MUL2 SUB2 STH2r JMP2r
|
|
|
|
@mul2hi ( a* b* -- product-top-16-bits* )
|
|
(
|
|
Multiplying two 16-bit numbers yields a 32-bit number.
|
|
MUL2 returns the lowest 16 bits, we want the highest.
|
|
|
|
We split each short into hi and lo bytes, then sum
|
|
the following multiplications:
|
|
|
|
31..24 23..16 15..08 07..00
|
|
{ ahi * bhi }
|
|
{ alo * bhi }
|
|
{ ahi * blo }
|
|
{ alo * blo }
|
|
|
|
Bits 07..00 can be ignored, but each sum in bits 23..16
|
|
can end up overflowing into bit 24.
|
|
)
|
|
,mul.bhi STR2 ,mul.ahi STR2
|
|
#00
|
|
#00
|
|
#00 ~mul.alo #00 ~mul.blo MUL2
|
|
POP
|
|
#00 ~mul.ahi #00 ~mul.blo MUL2 ^$adc JSR
|
|
#00 ~mul.alo #00 ~mul.bhi MUL2 ^$adc JSR
|
|
POP
|
|
#00 ~mul.ahi #00 ~mul.bhi MUL2 ADD2
|
|
JMP2r
|
|
|
|
$adc ( 31..24 a* b* -- 31..24 sum* )
|
|
OVR2 ADD2 SWP2 OVR2
|
|
GTH2 ^$carry JNZ
|
|
JMP2r
|
|
$carry
|
|
ROT #01 ADD ROT ROT
|
|
JMP2r
|
|
|
|
@strings
|
|
$fps [ 20 fps 0a 00 ]
|
|
|
|
@font-numbers
|
|
[
|
|
7cc6 ced6 e6c6 7c00 1838 1818 1818 7e00 3c66 063c 6066 7e00
|
|
3c66 061c 0666 3c00 1c3c 6ccc fe0c 1e00 7e62 607c 0666 3c00
|
|
3c66 607c 6666 3c00 7e66 060c 1818 1800 3c66 663c 6666 3c00
|
|
3c66 663e 0666 3c00 7cc6 ced6 e6c6 7c00 0018 1800 1818 0000
|
|
]
|
|
|
|
@font-letters
|
|
[
|
|
183c 6666 7e66 6600 fc66 667c 6666 fc00 3c66 c0c0 c066 3c00
|
|
f86c 6666 666c f800 fe62 6878 6862 fe00 fe62 6878 6860 f000
|
|
3c66 c0c0 ce66 3e00 6666 667e 6666 6600 7e18 1818 1818 7e00
|
|
1e0c 0c0c cccc 7800 e666 6c78 6c66 e600 f060 6060 6266 fe00
|
|
c6ee fefe d6c6 c600 c6e6 f6de cec6 c600 386c c6c6 c66c 3800
|
|
fc66 667c 6060 f000 386c c6c6 dacc 7600 fc66 667c 6c66 e600
|
|
3c66 603c 0666 3c00 7e5a 1818 1818 3c00 6666 6666 6666 3c00
|
|
6666 6666 663c 1800 c6c6 c6d6 feee c600 c66c 3838 6cc6 c600
|
|
6666 663c 1818 3c00 fec6 8c18 3266 fe00 0018 187e 1818 0000
|
|
]
|
|
|