2020-03-12 21:49:10 -04:00
|
|
|
: H HERE @ ;
|
|
|
|
: -^ SWAP - ;
|
2020-03-12 00:14:44 -04:00
|
|
|
: +! SWAP OVER @ + SWAP ! ;
|
|
|
|
: ALLOT HERE +! ;
|
2020-03-12 21:49:10 -04:00
|
|
|
: , H ! 2 ALLOT ;
|
|
|
|
: C, H C! 1 ALLOT ;
|
2020-03-15 22:46:17 -04:00
|
|
|
: BEGIN H ; IMMEDIATE
|
2020-03-16 21:31:43 -04:00
|
|
|
: COMPILE ' ['] LITN EXECUTE ['] , , ; IMMEDIATE
|
|
|
|
: AGAIN COMPILE (bbr) H -^ C, ; IMMEDIATE
|
2020-03-14 09:23:58 -04:00
|
|
|
: NOT 1 SWAP SKIP? EXIT 0 * ;
|
2020-03-15 22:46:17 -04:00
|
|
|
: ( BEGIN LITS ) WORD SCMP NOT SKIP? AGAIN ; IMMEDIATE
|
2020-03-14 19:10:39 -04:00
|
|
|
( Hello, hello, krkrkrkr... do you hear me?
|
|
|
|
Ah, voice at last! Some lines above need comments
|
|
|
|
BTW: Forth lines limited to 64 cols because of default
|
|
|
|
input buffer size in Collapse OS
|
2020-03-16 21:31:43 -04:00
|
|
|
|
|
|
|
COMPILE; Tough one. Get addr of caller word (example above
|
|
|
|
(bbr)) and then call LITN on it. However, LITN is an
|
|
|
|
immediate and has to be indirectly executed. Then, write
|
|
|
|
a reference to "," so that this word is written to HERE.
|
|
|
|
|
|
|
|
NOT: a bit convulted because we don't have IF yet )
|
2020-03-16 22:09:23 -04:00
|
|
|
|
|
|
|
: IF ( -- a | a: br cell addr )
|
|
|
|
COMPILE SKIP? ( if true, don't branch )
|
|
|
|
COMPILE (fbr)
|
|
|
|
H ( push a )
|
|
|
|
1 ALLOT ( br cell allot )
|
|
|
|
; IMMEDIATE
|
|
|
|
|
|
|
|
: THEN ( a -- | a: br cell addr )
|
|
|
|
DUP H -^ SWAP ( a-H a )
|
|
|
|
C!
|
|
|
|
; IMMEDIATE
|
|
|
|
|
|
|
|
: ELSE ( a1 -- a2 | a1: IF cell a2: ELSE cell )
|
|
|
|
COMPILE (fbr)
|
|
|
|
1 ALLOT
|
|
|
|
DUP H -^ SWAP ( a-H a )
|
|
|
|
C!
|
|
|
|
H 1 - ( push a. -1 for allot offset )
|
|
|
|
; IMMEDIATE
|
|
|
|
|
2020-03-13 19:33:16 -04:00
|
|
|
: ? @ . ;
|
|
|
|
: VARIABLE CREATE 2 ALLOT ;
|
|
|
|
: CONSTANT CREATE H ! DOES> @ ;
|
2020-03-12 00:14:44 -04:00
|
|
|
: = CMP NOT ;
|
|
|
|
: < CMP 0 1 - = ;
|
|
|
|
: > CMP 1 = ;
|
2020-03-16 22:36:29 -04:00
|
|
|
: / /MOD SWAP DROP ;
|
|
|
|
: MOD /MOD DROP ;
|
2020-03-17 12:26:28 -04:00
|
|
|
|
|
|
|
( Format decimals )
|
|
|
|
( TODO FORGET this word )
|
|
|
|
: PUSHDGTS
|
|
|
|
999 SWAP ( stop indicator )
|
|
|
|
DUP 0 = IF '0' EXIT THEN ( 0 is a special case )
|
|
|
|
BEGIN
|
|
|
|
DUP 0 = IF DROP EXIT THEN
|
|
|
|
10 /MOD ( r q )
|
|
|
|
SWAP '0' + SWAP ( d q )
|
|
|
|
AGAIN
|
|
|
|
;
|
|
|
|
|
|
|
|
: . ( n -- )
|
|
|
|
( handle negative )
|
|
|
|
( that "0 1 -" thing is because we don't parse negative
|
|
|
|
number correctly yet. )
|
|
|
|
DUP 0 < IF '-' EMIT 0 1 - * THEN
|
|
|
|
PUSHDGTS
|
|
|
|
BEGIN
|
|
|
|
DUP '9' > IF DROP EXIT THEN ( stop indicator, we're done )
|
|
|
|
EMIT
|
|
|
|
AGAIN
|
|
|
|
;
|