!!! FigForth 1.1

{{{

* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 

SCR #  0 
00 ******  fig-FORTH  MODEL  ****** 
01   
02      Through the courtesy of 
03   
04   
05       FORTH INTEREST GROUP 
06          P. O. BOX 1105 
07       SAN CARLOS, CA. 94070 
08   
09        Implemented on the 
0A          ATARI  800/400 
0B                by 
0C           Steve Calfee 
0D              1/26/81 
0E   
0F          Copywrite 1981 
10   
11             RELEASE 1 
12       WITH COMPILER SECURITY 
13                AND 
14       VARIABLE LENGTH NAMES 
15   
16   
17   
18   
19      Further distribution must 
1A      include the above notice. 
1B   
1C   
1D   
1E   
1F   


****** fig-FORTH MODEL ****** Through the courtesy of FORTH 
INTEREST GROUP P. O. BOX 1105 SAN CARLOS, 
CA. 94070 Implemented on the ATARI 800/400 by Steve Calfee 
1/26/81 Copywrite 1981 RELEASE 1 WITH COMPILER SECURITY AND 
VARIABLE LENGTH 
NAMES Further distribution must include the above notice. 

* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 

SCR #  1 
00 ******  fig-FORTH  MODEL  ****** 
01   
02      Through the courtesy of 
03   
04   
05       FORTH INTEREST GROUP 
06          P. O. BOX 1105 
07       SAN CARLOS, CA. 94070 
08   
09        Implemented on the 
0A          ATARI  800/400 
0B                by 
0C           Steve Calfee 
0D              1/26/81 
0E   
0F          Copywrite 1981 
10   
11             RELEASE 1 
12       WITH COMPILER SECURITY 
13                AND 
14       VARIABLE LENGTH NAMES 
15   
16   
17   
18   
19      Further distribution must 
1A      include the above notice. 
1B   
1C   
1D   
1E   
1F   


****** fig-FORTH MODEL ****** Through the courtesy of FORTH 
INTEREST GROUP P. O. BOX 1105 SAN CARLOS, 
CA. 94070 Implemented on the ATARI 800/400 by Steve Calfee 
1/26/81 Copywrite 1981 RELEASE 1 WITH COMPILER SECURITY AND 
VARIABLE LENGTH 
NAMES Further distribution must include the above notice. 

* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 

SCR #  2 
00 BREAK Abort. 
01   
02 IOCB already open. 
03   
04 Non-existant device. 
05   
06 IOCB is write-only. 
07   
08 Invalid command (for this device 
09 ) 
0A Device or file not open. 
0B   
0C Bad IOCB # 
0D   
0E IOCB is read-only 
0F   
10 End Of File 
11   
12 Truncated Record 
13   
14 Device Timeout 
15   
16 Device NAK (Negative AcKnowledge 
17 ) 
18 Serial Bus input framing error 
19   
1A Cursor out of range 
1B   
1C Serial Bus data-frame overrun 
1D   
1E Serial Bus data-frame checksum e 
1F rror. 


BREAK Abort. IOCB already open. Non-existant device. IOCB is 
write-only. Invalid command (for this device) Device or file 
not open. Bad IOCB # IOCB is read-only End Of File Truncated 
Record Device Timeout Device NAK (Negative AcKnowledge) Serial 
Bus input framing error Cursor out of range Serial Bus 
data-frame overrun Serial Bus data-frame checksum error. 

* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 

SCR #  3 
00 Device-done error 
01   
02 Read-after-write compare error 
03   
04 Function not implemented in hand 
05 ler 
06 Insufficient RAM 
07   
08   
09   
0A   
0B   
0C   
0D   
0E   
0F   
10   
11   
12   
13   
14   
15   
16   
17   
18   
19   
1A   
1B   
1C   
1D   
1E   
1F   


Device-done error Read-after-write compare error Function not 
implemented in handler Insufficient RAM 

* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 

SCR #  4 
00 (  ERROR MESSAGES  )   135  159 
01  9  8  7  10  ;S 
02 empty stack 
03   
04 dictionary full 
05   
06 has incorrect address mode 
07   
08 isn't unique 
09   
0A   
0B   
0C disc range ?? 
0D   
0E full stack ! 
0F   
10 disc error ! 
11   
12   
13   
14   
15   
16   
17   
18   
19   
1A   
1B   
1C   
1D   
1E   
1F   


(  ERROR MESSAGES  ) 
135 159 9 8 7 10 ;S empty stack dictionary full has incorrect 
address mode isn't unique disc range ?? full stack ! disc error 
! 

* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 

SCR #  5 
00 (  ERROR MESSAGES  ) 
01   
02 compilation only, use in definit 
03 ion 
04 execution only 
05   
06 conditionals not paired 
07   
08 definition not finished 
09   
0A in protected dictionary 
0B   
0C use only when loading 
0D   
0E off current editing screen 
0F   
10 declare vocabulary 
11   
12 outside allocated file space 
13   
14 writing off current line 
15   
16   
17   
18   
19   
1A string stack empty !! 
1B   
1C   
1D   
1E   
1F   


(  ERROR MESSAGES  ) 
compilation only, 
use in definition execution only conditionals not paired 
definition not finished in protected dictionary use only when 
loading off current editing screen declare vocabulary outside 
allocated file space writing off current line string stack 
empty !! 

* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 

SCR #  6 
00 (  TARGET COMPILER ERROR MESSAGE 
01 S                 WFR-79JUN02 ) 
02   
03   
04 below lower bound of virtual mem 
05 ory 
06 disc compiler assembly error in 
07 mode of 
08 can't find in TARGET 
09   
0A target redef. 
0B   
0C T: error, is it paired with T; 
0D ? 
0E above virtual memory bounds 
0F   
10   
11   
12   
13   
14   
15   
16   
17   
18   
19   
1A   
1B   
1C   
1D   
1E   
1F   


(  TARGET COMPILER ERROR MESSAGES                 WFR-79JUN02 ) 
below lower bound of virtual memory disc compiler assembly 
error in mode of can't find in TARGET target redef. T: error, 
is it paired with T; ? above virtual memory bounds 

* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 

SCR #  7 
00 ( <UNUSED> ) ;S 
01   
02   
03   
04   
05   
06   
07   
08   
09   
0A   
0B   
0C   
0D   
0E   
0F   
10   
11   
12   
13   
14   
15   
16   
17   
18   
19   
1A   
1B   
1C   
1D   
1E   
1F   


( <UNUSED> ) 
;S 

* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 

SCR #  8 
00 ( <UNUSED> ) ;S 
01   
02   
03   
04   
05   
06   
07   
08   
09   
0A   
0B   
0C   
0D   
0E   
0F   
10   
11   
12   
13   
14   
15   
16   
17   
18   
19   
1A   
1B   
1C   
1D   
1E   
1F   


( <UNUSED> ) 
;S 

* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 

SCR #  9 
00 (  compile assembler 
01    and editor  SRC 7/6/80   ) 
02 BASE  @  ( PRESERVE THE RADIX ) 
03   
04 DECIMAL  31  WIDTH  ! 
05   
06 13 LOAD ( ASSEMBLER ) 
07   
08 HEX 1E LOAD ( DECUS FORTH ADDS) 
09   
0A HEX 15 LOAD   ( EDITOR ) 
0B   
0C FORTH  DEFINITIONS 
0D   
0E 25 CONSTANT LPWORDS 
0F   
10 27 CONSTANT FORMY 
11 : SAVENFAs ( MOVE FORTH NFAS TO 
12 ORIGIN AREA ) #LINKS 0 DO 
13 ' FORTH 4 + I 4 * + @ 
14 22 I 2* + +ORIGIN ! LOOP ; 
15 DECIMAL 
16 HERE  28 +ORIGIN ! ( FENCE ) 
17   
18 HERE    30  +ORIGIN  !  ( DP ) 
19   
1A HERE  FENCE  ! 
1B 1 WARNING ! ( DISK WARNINGS ) 
1C SAVENFAs : TASK  ; 
1D BASE ! 
1E ;S 
1F   


(  compile assembler               and editor  SRC 7/6/80   ) 
BASE @ ( PRESERVE THE RADIX ) 
DECIMAL 31 WIDTH ! 13 LOAD 
( ASSEMBLER ) 
HEX 1E LOAD 
( DECUS FORTH ADDS) 
HEX 15 LOAD 
( EDITOR ) 
FORTH DEFINITIONS 25 CONSTANT LPWORDS 
27 CONSTANT FORMY 
: SAVENFAs 
        ( MOVE FORTH NFAS TO ORIGIN AREA ) 
        #LINKS 0 
        DO 
          ' FORTH 4 + I 4 * + @ 22 I 2* + +ORIGIN ! 
        LOOP 
        ; 
DECIMAL HERE 28 +ORIGIN ! ( FENCE ) 
HERE 30 +ORIGIN ! ( DP ) 
HERE FENCE ! 1 WARNING ! ( DISK WARNINGS ) 
SAVENFAs 
: TASK 
        ; 
BASE ! ;S 

* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 

SCR #  A 
00 ( <UNUSED> ) ;S 
01   
02   
03   
04   
05   
06   
07   
08   
09   
0A   
0B   
0C   
0D   
0E   
0F   
10   
11   
12   
13   
14   
15   
16   
17   
18   
19   
1A   
1B   
1C   
1D   
1E   
1F   


( <UNUSED> ) 
;S 

* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 

SCR #  B 
00 ( CLONING WORDS  7/21/80-SRC ) 
01  HEX FORTH DEFINITIONS 
02 : COPYDISK DR0  4E 0 DO I I 0800 
03   + EDITOR COPY FORTH LOOP ; 
04 : CLONE DR0 0 PHYSOFF ! 
05   4E B + 0 DO I I 0800 + 
06   EDITOR COPY FORTH LOOP DR0 ; 
07 : 1.2TO1.3 DR0 8 OFFSET ! 4E 0 
08   DO I  I 0803 + EDITOR COPY 
09   FORTH LOOP DR0 ; 
0A : 1.3TO1.4 DR0 B PHYSOFF ! 4E 0 
0B   DO I I 0801 + COPY LOOP DR0 ; 
0C   
0D : OBJ  DR0 0 PHYSOFF ! 
0E   C 0 DO I I 0800 + EDITOR 
0F   COPY FORTH LOOP DR0 ; 
10   CR 
11  ." INSERT SRCE DISK IN DRIVE 1 
12  " CR 
13  ." INSERT DEST DISK IN DRIVE 2" 
14  CR 
15  ." TYPE CLONE TO COPY ALL OF IT 
16 " CR ." INCLUDING BOOT PROGRAM" 
17   CR ." TYPE COPYDISK TO COPY" 
18  CR ." SCREENS 0 TO 4E" 
19   CR ." TYPE OBJ  TO COPY JUST" 
1A   CR ." THE BOOTSTRAP B BLOCKS" 
1B CR ." TYPE 1.2TO1.3 TO COPY " 
1C CR ." OR TYPE 1.3TO1.4 TO COPY" 
1D CR ." YOUR OLD DISK SOURCES " 
1E CR ." TO THE NEW VERSION " 
1F CR  ;S 


( CLONING WORDS  7/21/80-SRC ) 
HEX FORTH DEFINITIONS 
: COPYDISK 
        DR0 4E 0 
        DO 
          I I 0800 + EDITOR COPY FORTH 
        LOOP 
        ; 
: CLONE 
        DR0 0 PHYSOFF ! 4E B + 0 
        DO 
          I I 0800 + EDITOR COPY FORTH 
        LOOP 
        DR0 
        ; 
: 1.2TO1.3 
        DR0 8 OFFSET ! 4E 0 
        DO 
          I I 0803 + EDITOR COPY FORTH 
        LOOP 
        DR0 
        ; 
: 1.3TO1.4 
        DR0 B PHYSOFF ! 4E 0 
        DO 
          I I 0801 + COPY 
        LOOP 
        DR0 
        ; 
: OBJ 
        DR0 0 PHYSOFF ! C 0 
        DO 
          I I 0800 + EDITOR COPY FORTH 
        LOOP 
        DR0 
        ; 
CR ." INSERT SRCE DISK IN DRIVE 1 " CR ." INSERT DEST DISK IN 
DRIVE 2" CR ." TYPE CLONE TO COPY ALL OF IT" CR ." INCLUDING 
BOOT PROGRAM" CR ." TYPE COPYDISK TO COPY" CR ." SCREENS 0 TO 
4E" CR ." TYPE OBJ TO COPY JUST" CR ." THE BOOTSTRAP B BLOCKS" 
CR ." TYPE 1.2TO1.3 TO COPY " CR ." OR TYPE 1.3TO1.4 TO COPY" 
CR ." YOUR OLD DISK SOURCES " CR ." TO THE NEW VERSION " CR ;S 

* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 

SCR #  C 
00 ( <UNUSED> ) ;S 
01   
02   
03   
04   
05   
06   
07   
08   
09   
0A   
0B   
0C   
0D   
0E   
0F   
10   
11   
12   
13   
14   
15   
16   
17   
18   
19   
1A   
1B   
1C   
1D   
1E   
1F   


( <UNUSED> ) 
;S 

* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 

SCR #  D 
00 (  FORTH-65 ASSEMBLER 
01                   WFR-79JUN03 ) 
02 HEX 
03   
04 VOCABULARY  ASSEMBLER  IMMEDIATE 
05      ASSEMBLER  DEFINITIONS 
06   
07   
08 (  LOCATE EXISTING REGISTERS ) 
09   
0A FF CONSTANT  XSAVE     0FB  CONS 
0B TANT  W    0FD  CONSTANT  UP 
0C F8  CONSTANT  IP          F0  CO 
0D NSTANT  N 
0E   
0F   
10 (  LOCATE EXISTING CODE PROCEEDU 
11 RES ) 
12 '  (DO)  0E  +    CONSTANT  POP 
13    ( FROM COMPUTATION STACK *) 
14 '  (DO)  0C  +    CONSTANT  POPT 
15 WO 
16 '  LIT  13  +  CONSTANT  PUT 
17   
18 '  LIT  11  +  CONSTANT  PUSH 
19   
1A '  LIT  18  +  CONSTANT  NEXT 
1B   
1C '  EXECUTE  NFA  11  -  CONSTANT 
1D   SETUP 
1E     --> 
1F   


(  FORTH-65 ASSEMBLER                             WFR-79JUN03 ) 
HEX VOCABULARY ASSEMBLER IMMEDIATE ASSEMBLER DEFINITIONS 
(  LOCATE EXISTING REGISTERS ) 
FF CONSTANT XSAVE 
0FB CONSTANT W 
0FD CONSTANT UP 
F8 CONSTANT IP 
F0 CONSTANT N 
(  LOCATE EXISTING CODE PROCEEDURES ) 
' (DO) 0E + CONSTANT POP 
( FROM COMPUTATION STACK *) 
' (DO) 0C + CONSTANT POPTWO 
' LIT 13 + CONSTANT PUT 
' LIT 11 + CONSTANT PUSH 
' LIT 18 + CONSTANT NEXT 
' EXECUTE NFA 11 - CONSTANT SETUP 
--> 

* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 

SCR #  E 
00 (     ASSEMBLER, CONT. 
01                   WFR-780CT03 ) 
02 0   VARIABLE  INDEX       -2  AL 
03 LOT 
04 0909 , 1505 , 0115 , 8011 , 8009 
05  , 1D0D , 8019 , 8080 , 
06 0080 , 1404 , 8014 , 8080 , 8080 
07  , 1C0C , 801C , 2C80 , 
08   
09   
0A 2  VARIABLE  MODE 
0B   
0C : .A   0 MODE ! ;    : #    1 MO 
0D DE ! ;    : MEM  2 MODE ! ; 
0E : ,X   3 MODE ! ;    : ,Y   4 MO 
0F DE ! ;    : X)   5 MODE ! ; 
10 : )Y   6 MODE ! ;    : )    F MO 
11 DE ! ; 
12   
13   
14 : BOT       ,X    0  ;     ( ADD 
15 RESS THE BOTTOM OF THE STACK *) 
16 : SEC       ,X    2  ;        ( 
17 ADDRESS SECOND ITEM ON STACK *) 
18 : RP)       ,X  101  ;      ( AD 
19 DRESS BOTTOM OF RETURN STACK *) 
1A --> 
1B   
1C   
1D   
1E   
1F   


(     ASSEMBLER, CONT.                            WFR-780CT03 ) 
0 VARIABLE INDEX 
-2 ALLOT 0909 , 1505 , 0115 , 8011 , 8009 , 1D0D , 8019 , 8080 
, 0080 , 1404 , 8014 , 8080 , 8080 , 1C0C , 801C , 2C80 , 2 
VARIABLE MODE 
: .A 
        0 MODE ! 
        ; 
: # 
        1 MODE ! 
        ; 
: MEM 
        2 MODE ! 
        ; 
: ,X 
        3 MODE ! 
        ; 
: ,Y 
        4 MODE ! 
        ; 
: X) 
        5 MODE ! 
        ; 
: )Y 
        6 MODE ! 
        ; 
: ) 
        F MODE ! 
        ; 
: BOT 
        ,X 0 
        ; 
( ADDRESS THE BOTTOM OF THE STACK *) 
: SEC 
        ,X 2 
        ; 
( ADDRESS SECOND ITEM ON STACK *) 
: RP) 
        ,X 101 
        ; 
( ADDRESS BOTTOM OF RETURN STACK *) 
--> 

* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 

SCR #  F 
00 (  UPMODE,  CPU 
01                   WFR-78OCT23 ) 
02   
03   
04 : UPMODE   IF  MODE  C@  8  AND 
05  0=  IF  8  MODE +! ENDIF ENDIF 
06      1 MODE C@  0F AND  -DUP  IF 
07   0  DO  DUP + LOOP  ENDIF 
08      OVER  1+  @  AND  0=  ; 
09   
0A   
0B   
0C : CPU   <BUILDS  C,  DOES>  C@ 
0D  C,  MEM  ; 
0E      00 CPU BRK,   18 CPU CLC, 
0F  D8 CPU CLD,  58 CPU CLI, 
10      B8 CPU CLV,   CA CPU DEX, 
11  88 CPU DEY,  E8 CPU INX, 
12      C8 CPU INY,   EA CPU NOP, 
13  48 CPU PHA,  08 CPU PHP, 
14      68 CPU PLA,   28 CPU PLP, 
15  40 CPU RTI,  60 CPU RTS, 
16      38 CPU SEC,   F8 CPU SED, 
17  78 CPU SEI,  AA CPU TAX, 
18      A8 CPU TAY,   BA CPU TSX, 
19  8A CPU TXA,  9A CPU TXS, 
1A      98 CPU TYA, 
1B   
1C --> 
1D   
1E   
1F   


(  UPMODE,  CPU                                   WFR-78OCT23 ) 
: UPMODE 
        IF 
          MODE C@ 8 AND 0= 
          IF 
            8 MODE +! 
          ENDIF 
        ENDIF 
        1 MODE C@ 0F AND -DUP 
        IF 
          0 
          DO 
            DUP + 
          LOOP 
        ENDIF 
        OVER 1+ @ AND 0= 
        ; 
: CPU 
        <BUILDS C, DOES> C@ C, MEM 
        ; 
00 CPU BRK, 
18 CPU CLC, 
D8 CPU CLD, 
58 CPU CLI, 
B8 CPU CLV, 
CA CPU DEX, 
88 CPU DEY, 
E8 CPU INX, 
C8 CPU INY, 
EA CPU NOP, 
48 CPU PHA, 
08 CPU PHP, 
68 CPU PLA, 
28 CPU PLP, 
40 CPU RTI, 
60 CPU RTS, 
38 CPU SEC, 
F8 CPU SED, 
78 CPU SEI, 
AA CPU TAX, 
A8 CPU TAY, 
BA CPU TSX, 
8A CPU TXA, 
9A CPU TXS, 
98 CPU TYA, 
--> 

* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 

SCR #  10 
00 (  M/CPU,   MULTI-MODE OP-CODES 
01                   WFR-79MAR26 ) 
02 : M/CPU   <BUILDS  C,  ,  DOES> 
03   
04        DUP  1+  C@  80  AND  IF 
05  10  MODE  +!  ENDIF  OVER 
06        FF00  AND  UPMODE  UPMODE 
07   IF  MEM  CR  LATEST  ID. 
08        3  ERROR  ENDIF  C@  MODE 
09   C@ 
0A        INDEX  +  C@  +  C,  MODE 
0B   C@  7  AND  IF  MODE  C@ 
0C        0F  AND  7  <  IF  C,  EL 
0D SE  ,  ENDIF  ENDIF  MEM  ; 
0E   
0F   
10    1C6E 60 M/CPU ADC,  1C6E 20 M 
11 /CPU AND,  1C6E C0 M/CPU CMP, 
12    1C6E 40 M/CPU EOR,  1C6E A0 M 
13 /CPU LDA,  1C6E 00 M/CPU ORA, 
14    1C6E E0 M/CPU SBC,  1C6C 80 M 
15 /CPU STA,  0D0D 01 M/CPU ASL, 
16    0C0C C1 M/CPU DEC,  0C0C E1 M 
17 /CPU INC,  0D0D 41 M/CPU LSR, 
18    0D0D 21 M/CPU ROL,  0D0D 61 M 
19 /CPU ROR,  0414 81 M/CPU STX, 
1A    0486 E0 M/CPU CPX,  0486 C0 M 
1B /CPU CPY,  1496 A2 M/CPU LDX, 
1C    0C8E A0 M/CPU LDY,  048C 80 M 
1D /CPU STY,  0480 14 M/CPU JSR, 
1E    8480 40 M/CPU JMP,  0484 20 M 
1F /CPU BIT,       --> 


(  M/CPU,   MULTI-MODE OP-CODES                   WFR-79MAR26 ) 
: M/CPU 
        <BUILDS C, , DOES> DUP 1+ C@ 80 AND 
        IF 
          10 MODE +! 
        ENDIF 
        OVER FF00 AND UPMODE UPMODE 
        IF 
          MEM CR LATEST ID. 3 ERROR 
        ENDIF 
        C@ MODE C@ INDEX + C@ + C, MODE C@ 7 AND 
        IF 
          MODE C@ 0F AND 7 < 
          IF 
            C, 
          ELSE 
            , 
          ENDIF 
        ENDIF 
        MEM 
        ; 
1C6E 60 M/CPU ADC, 
1C6E 20 M/CPU AND, 
1C6E C0 M/CPU CMP, 
1C6E 40 M/CPU EOR, 
1C6E A0 M/CPU LDA, 
1C6E 00 M/CPU ORA, 
1C6E E0 M/CPU SBC, 
1C6C 80 M/CPU STA, 
0D0D 01 M/CPU ASL, 
0C0C C1 M/CPU DEC, 
0C0C E1 M/CPU INC, 
0D0D 41 M/CPU LSR, 
0D0D 21 M/CPU ROL, 
0D0D 61 M/CPU ROR, 
0414 81 M/CPU STX, 
0486 E0 M/CPU CPX, 
0486 C0 M/CPU CPY, 
1496 A2 M/CPU LDX, 
0C8E A0 M/CPU LDY, 
048C 80 M/CPU STY, 
0480 14 M/CPU JSR, 
8480 40 M/CPU JMP, 
0484 20 M/CPU BIT, 
--> 

* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 

SCR #  11 
00 (  ASSEMBLER CONDITIONALS 
01                   WFR-79MAR26 ) 
02 : BEGIN, HERE 1 ;    IMMEDIATE 
03 : UNTIL,    ?EXEC >R 1 ?PAIRS R> 
04  C, HERE 1+ - C, ; IMMEDIATE 
05 : IF, C, HERE 0 C, 2 ; IMMEDIATE 
06  : ENDIF, ?EXEC 2 ?PAIRS HERE 
07 OVER  C@ 
08  IF  SWAP  !  ELSE  OVER  1+  - 
09  SWAP  C!  ENDIF  ; IMMEDIATE 
0A : ELSE, 2 ?PAIRS HERE 1+ 1 JMP, 
0B SWAP HERE OVER 1+ - SWAP C! 2 ; 
0C  IMMEDIATE 
0D : THEN, [COMPILE] ENDIF, ; 
0E IMMEDIATE      : END, [COMPILE] 
0F UNTIL, ; IMMEDIATE 
10 : NOT    20  +  ; 
11      ( REVERSE ASSEMBLY TEST ) 
12 90  CONSTANT  CS    ( ASSEMBLER 
13 TEST FOR CARRY SET ) 
14 D0  CONSTANT  0=    ( ASSEMBLER 
15 TEST FOR EQUAL ZERO ) 
16 10  CONSTANT  0<    ( ASSEMBLER 
17 TEST FOR LESS THAN ZERO ) 
18 90  CONSTANT  >=    ( ASSEMBLER 
19 TEST FOR GREATER OR EQUAL ZERO ) 
1A  ( >= IS ONLY CORRECT AFTER SUB, 
1B  OR CMP,  ) 
1C 50 CONSTANT VS      ( ASSEMBLER 
1D TEST FOR OVERFLOW BIT SET ) 
1E --> 
1F   


(  ASSEMBLER CONDITIONALS                         WFR-79MAR26 ) 
: BEGIN, 
        HERE 1 
        ; 
IMMEDIATE 
: UNTIL, 
        ?EXEC >R 1 ?PAIRS R> C, HERE 1+ - C, 
        ; 
IMMEDIATE 
: IF, 
        C, HERE 0 C, 2 
        ; 
IMMEDIATE 
: ENDIF, 
        ?EXEC 2 ?PAIRS HERE OVER C@ 
        IF 
          SWAP ! 
        ELSE 
          OVER 1+ - SWAP C! 
        ENDIF 
        ; 
IMMEDIATE 
: ELSE, 
        2 ?PAIRS HERE 1+ 1 JMP, 
        SWAP HERE OVER 1+ - SWAP C! 2 
        ; 
IMMEDIATE 
: THEN, 
        [COMPILE] 
      ENDIF, 
      ; 
IMMEDIATE 
: END, 
        [COMPILE] 
      UNTIL, 
      ; 
IMMEDIATE 
: NOT 
        20 + 
        ; 
( REVERSE ASSEMBLY TEST ) 
90 CONSTANT CS 
( ASSEMBLER TEST FOR CARRY SET ) 
D0 CONSTANT 0= 
( ASSEMBLER TEST FOR EQUAL ZERO ) 
10 CONSTANT 0< 
( ASSEMBLER TEST FOR LESS THAN ZERO ) 
90 CONSTANT >= 
( ASSEMBLER TEST FOR GREATER OR EQUAL ZERO ) 
( >= IS ONLY CORRECT AFTER SUB, OR CMP,  ) 
50 CONSTANT VS 
( ASSEMBLER TEST FOR OVERFLOW BIT SET ) 
--> 

* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 

SCR #  12 
00 (  USE OF ASSEMBLER 
01                   WFR-79APR28 ) 
02 : C; 
03     ( END OF CODE DEFINITION *) 
04    CURRENT  @  CONTEXT  !  ?EXEC 
05   ?CSP  SMUDGE  ; IMMEDIATE 
06   
07   
08 FORTH  DEFINITIONS 
09   
0A : CODE      ( CREATE WORD AT ASS 
0B EMBLY CODE LEVEL *) 
0C       ?EXEC  CREATE  [COMPILE] 
0D ASSEMBLER 
0E       ASSEMBLER  MEM  !CSP  ; 
0F    IMMEDIATE 
10 DECIMAL 
11 '  ASSEMBLER  CFA    '  ;CODE  8 
12   +  !  ( OVER-WRITE SMUDGE ) 
13   
14 --> 
15   
16   
17   
18   
19   
1A   
1B   
1C   
1D   
1E   
1F   


(  USE OF ASSEMBLER                               WFR-79APR28 ) 
: C; 
        ( END OF CODE DEFINITION *) 
        CURRENT @ CONTEXT ! ?EXEC ?CSP SMUDGE 
        ; 
IMMEDIATE FORTH DEFINITIONS 
: CODE 
        ( CREATE WORD AT ASSEMBLY CODE LEVEL *) 
        ?EXEC CREATE [COMPILE] ASSEMBLER ASSEMBLER MEM !CSP 
        ; 
IMMEDIATE DECIMAL ' ASSEMBLER CFA ' 
        ;CODE 
        8 + ! ( OVER-WRITE SMUDGE ) 
        --> 

* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 

SCR #  13 
00 ( EXEC, routines ) BASE @ HEX 
01 ASSEMBLER DEFINITIONS 
02 CODE xec  IP LDA,  W STA, IP 1+ 
03 LDA, W 1+ STA, ( save IP ) 
04  PLA, CLC, 1 # ADC, IP STA, 
05  PLA, 
06  0 # ADC, IP 1+ STA, ( get new 
07  IP) 
08 W 1+ LDA,  PHA,  W LDA,  PHA, 
09 ( save last IP ) NEXT JMP, C; 
0A CODE xec2 IP LDA, W STA, IP 1+ 
0B LDA, W 1+ STA,     ( save IP to 
0C continue in the code routine ) 
0D PLA, IP STA, PLA, IP 1+ STA, 
0E ( Restore old IP ) 
0F     W ) JMP, C; 
10   
11 : EXEC,     ( addr -- ^ EXECUTE 
12 COLON WORD IN A CODE DEF ) 
13 ( addr = PFA OF COLON WORD ) 
14 ' xec JSR, 
15 CFA  , ' xec2 CFA , ; 
16   
17 FORTH  DEFINITIONS  DECIMAL 
18   
19 HERE   28  +ORIGIN  !  ( FENCE ) 
1A   
1B HERE    30  +ORIGIN  !  ( DP ) 
1C   
1D '  ASSEMBLER  2  + 
1E 32  +ORIGIN  !  ( VOC-LINK ) 
1F HERE  FENCE  !   BASE !  ;S 


( EXEC, routines ) 
BASE @ HEX ASSEMBLER DEFINITIONS 
CODE xec 
        IP LDA, 
        W STA, 
        IP 1+ LDA, 
        W 1+ STA, 
        ( save IP ) 
        PLA, 
        CLC, 
        1 # ADC, 
        IP STA, 
        PLA, 
        0 # ADC, 
        IP 1+ STA, 
        ( get new   IP) 
        W 1+ LDA, 
        PHA, 
        W LDA, 
        PHA, 
        ( save last IP ) 
        NEXT JMP, 
        C; 
CODE xec2 
        IP LDA, 
        W STA, 
        IP 1+ LDA, 
        W 1+ STA, 
        ( save IP to continue in the code routine ) 
        PLA, 
        IP STA, 
        PLA, 
        IP 1+ STA, 
        ( Restore old IP ) 
        W ) JMP, 
        C; 
: EXEC, 
        ( addr -- ^ EXECUTE COLON WORD IN A CODE DEF ) 
        ( addr = PFA OF COLON WORD ) 
        ' xec JSR, 
        CFA , ' xec2 CFA , 
        ; 
FORTH DEFINITIONS DECIMAL HERE 28 +ORIGIN ! ( FENCE ) 
HERE 30 +ORIGIN ! ( DP ) 
' ASSEMBLER 2 + 32 +ORIGIN ! ( VOC-LINK ) 
HERE FENCE ! BASE ! ;S 

* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 

SCR #  14 
00 ( LPWORDS FOR JOYSTICK CONTROLLE 
01 R JACKS ) 
02 CODE STROBE BOT LDA, D301 STA, 
03  80 # ORA, D301 STA, 
04  POP JMP, C; : PRT D303 C@ FB 
05  AND D303 C! FF D301 C! D303 
06 C@ 4 OR D303 C! BEGIN D013 C@  1 
07  AND 0= UNTIL 7F AND STROBE ; 
08 : LYP1 DUP IF 0 DO DUP I + C@ PR 
09 T LOOP DROP 
0A ELSE DROP DROP THEN ; 
0B     : LYPE LYP1 20 PRT ; 
0C : CRLP 0D PRT 0A PRT ; : FFLP 0C 
0D  PRT CRLP ; 
0E : .LP S->D SWAP OVER DABS <# #S 
0F   SIGN #> 
10     LYPE ; 
11   
12 : LISTLP DUP SCR !  CRLP 
13 0E PRT ( [ SCREEN ] LYPE ) .LP 
14 0F PRT 10 0 DO CRLP I  DUP .LP 
15  LINE C/L -TRAILING LYPE LOOP 
16 CRLP  ; : SHOWLP 1+ SWAP 
17  DO I LISTLP 3 0 DO CRLP 
18 LOOP LOOP ; 
19   
1A ;S 
1B   
1C   
1D   
1E   
1F   


( LPWORDS FOR JOYSTICK CONTROLLER JACKS ) 
CODE STROBE 
        BOT LDA, 
        D301 STA, 
        80 # ORA, 
        D301 STA, 
        POP JMP, 
        C; 
: PRT 
        D303 C@ FB AND D303 C! FF D301 C! D303 C@ 4 OR D303 C! 
        BEGIN 
          D013 C@ 1 AND 0= 
        UNTIL 
        7F AND STROBE 
        ; 
: LYP1 
        DUP 
        IF 
          0 
          DO 
            DUP I + C@ PRT 
          LOOP 
          DROP 
        ELSE 
          DROP DROP 
        THEN 
        ; 
: LYPE 
        LYP1 20 PRT 
        ; 
: CRLP 
        0D PRT 0A PRT 
        ; 
: FFLP 
        0C PRT CRLP 
        ; 
: .LP 
        S->D SWAP OVER DABS <# #S SIGN #> LYPE 
        ; 
: LISTLP 
        DUP SCR ! CRLP 0E PRT ( [ SCREEN ] LYPE ) 
        .LP 0F PRT 10 0 
        DO 
          CRLP I DUP .LP LINE C/L -TRAILING LYPE 
        LOOP 
        CRLP 
        ; 
: SHOWLP 
        1+ SWAP 
        DO 
          I LISTLP 3 0 
          DO 
            CRLP 
          LOOP 
        LOOP 
        ; 
;S 

* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 

SCR #  15 
00 HEX VOCABULARY EDITOR IMMEDIATE 
01   
02 1A LOAD 1B LOAD ( GRAPHICS ) 
03   
04 : EDIT SCR ! [COMPILE] EDITOR ; 
05   
06 EDITOR DEFINITIONS 
07 0 VARIABLE TOPFLAG 
08 : ULL DUP TOPFLAG ! 0 GR.   2203 
09   LMARGN ! 3 0 POS. ( 32 CHAR ) 
0A   1 2FE C! ( PRINT ALL CHARS ) 
0B SCR @ BLOCK + 200 TYPE ( PRINT ) 
0C   0 2FE C! ( CURSOR CNTRLS ) 
0D CR ." DOIT" CR 0AAAA 2B2 ! ; 
0E : UL 0 ULL ;     ( SHOW UPPER 16 
0F  LINES ) 
10 : LL 200 ULL ; ( SHOW  LOWER  16 
11   LINES ) 
12 : DOIT 10 0 DO -1 2B2 ! 
13   
14 3 I POS. ( POINT CURSOR ) 
15   
16 SCR @ BLOCK I 20 * + TOPFLAG @ + 
17   
18 ICBAL ! 20 ICBLL ! GET DROP 
19   
1A LOOP UPDATE 0 GR. TOPFLAG @ 0= 
1B   IF UL ELSE LL ENDIF ; 
1C : FLUSH 2602 LMARGN ! 
1D   [COMPILE] FORTH FLUSH ; 
1E --> 
1F   


HEX VOCABULARY EDITOR IMMEDIATE 1A LOAD 
1B LOAD 
( GRAPHICS ) 
: EDIT 
        SCR ! [COMPILE] EDITOR 
        ; 
EDITOR DEFINITIONS 0 VARIABLE TOPFLAG 
: ULL 
        DUP TOPFLAG ! 0 GR. 2203 LMARGN ! 3 0 POS. ( 32 CHAR ) 
        1 2FE C! ( PRINT ALL CHARS ) 
        SCR @ BLOCK + 200 TYPE ( PRINT ) 
        0 2FE C! ( CURSOR CNTRLS ) 
        CR ." DOIT" CR 0AAAA 2B2 ! 
        ; 
: UL 
        0 ULL 
        ; 
( SHOW UPPER 16 LINES ) 
: LL 
        200 ULL 
        ; 
( SHOW  LOWER  16  LINES ) 
: DOIT 
        10 0 
        DO 
          -1 2B2 ! 3 I POS. ( POINT CURSOR ) 
          SCR @ BLOCK I 20 * + TOPFLAG @ + ICBAL ! 20 ICBLL ! 
          GET DROP 
        LOOP 
        UPDATE 0 GR. TOPFLAG @ 0= 
        IF 
          UL 
        ELSE 
          LL 
        ENDIF 
        ; 
: FLUSH 
        2602 LMARGN ! [COMPILE] FORTH FLUSH 
        ; 
--> 

* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 

SCR #  16 
00 (  TEXT,  LINE, WHERE USED IN 
01  EDITOR    7/7/80-SRC ) 
02 FORTH  DEFINITIONS   HEX 
03   
04   
05   
06 : TEXT                  ( ACCEPT 
07  FOLLOWING TEXT TO PAD *) 
08     HERE  C/L  1+   BLANKS  WORD 
09   HERE  PAD  C/L  1+  CMOVE  ; 
0A : #OFLINES B/BUF B/SCR * C/L / ; 
0B   
0C : LINE             ( RELATIVE TO 
0D  SCR, LEAVE ADDRESS OF LINE *) 
0E  DUP  #OFLINES            MINUS 
0F AND IF ." NOT ON SCREEN" ABORT 
10 ENDIF  ( KEEP ON THIS SCREEN ) 
11       SCR  @  (LINE)  DROP  ; 
12   
13  --> 
14   
15   
16   
17   
18   
19   
1A   
1B   
1C   
1D   
1E   
1F   


(  TEXT,  LINE, WHERE USED IN    EDITOR    7/7/80-SRC ) 
FORTH DEFINITIONS HEX 
: TEXT 
        ( ACCEPT FOLLOWING TEXT TO PAD *) 
        HERE C/L 1+ BLANKS WORD HERE PAD C/L 1+ CMOVE 
        ; 
: #OFLINES 
        B/BUF B/SCR * C/L / 
        ; 
: LINE 
        ( RELATIVE TO SCR, LEAVE ADDRESS OF LINE *) 
        DUP #OFLINES MINUS AND 
        IF 
          ." NOT ON SCREEN" ABORT 
        ENDIF 
        ( KEEP ON THIS SCREEN ) 
        SCR @ (LINE) DROP 
        ; 
--> 

* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 

SCR #  17 
00 (  LINE EDITING COMMANDS ) 
01      EDITOR DEFINITIONS 
02 : -MOVE   ( MOVE IN BLOCK BUFFER 
03  ADDR FROM-2,  LINE TO-1 *) 
04      LINE  C/L  CMOVE  UPDATE  ; 
05   
06 : HL                      ( HOLD 
07  NUMBERED LINE AT PAD *) 
08     LINE  PAD  1+  C/L  DUP  PAD 
09   C!  CMOVE  ; 
0A : BL                     ( ERASE 
0B  LINE-1 WITH BLANKS *) 
0C LINE  C/L  BLANKS  UPDATE ; 
0D   
0E : SL                    ( SPREAD 
0F  MAKING LINE # BLANK *) 
10       DUP  1  -  ( LIMIT ) 
11 #OFLINES 2 -  ( FIRST TO MOVE ) 
12       DO  I  LINE  I  1+  -MOVE 
13   -1  +LOOP  BL ; 
14 : DL            ( DELETE LINE-1, 
15  BUT HOLD IN PAD *) 
16    DUP  HL  #OFLINES   1   - 
17    DUP  ROT 
18       DO  I  1+  LINE  I  -MOVE 
19  LOOP  BL ; 
1A : CL  ( COPY LINE-2 OF SCREEN-1 
1B  TO PAD ) 
1C SCR @ >R SCR ! HL R> SCR ! ; 
1D   
1E --> 
1F   



(  LINE EDITING COMMANDS ) 
EDITOR DEFINITIONS 
: -MOVE 
        ( MOVE IN BLOCK BUFFER ADDR FROM-2,  LINE TO-1 *) 
        LINE C/L CMOVE UPDATE 
        ; 
: HL 
        ( HOLD NUMBERED LINE AT PAD *) 
        LINE PAD 1+ C/L DUP PAD C! CMOVE 
        ; 
: BL 
        ( ERASE LINE-1 WITH BLANKS *) 
        LINE C/L BLANKS UPDATE 
        ; 
: SL 
        ( SPREAD MAKING LINE # BLANK *) 
        DUP 1 - ( LIMIT ) 
        #OFLINES 2 - ( FIRST TO MOVE ) 
        DO 
          I LINE I 1+ -MOVE -1 
        +LOOP 
        BL 
        ; 
: DL 
        ( DELETE LINE-1, BUT HOLD IN PAD *) 
        DUP HL #OFLINES 1 - DUP ROT 
        DO 
          I 1+ LINE I -MOVE 
        LOOP 
        BL 
        ; 
: CL 
        ( COPY LINE-2 OF SCREEN-1  TO PAD ) 
        SCR @ >R SCR ! HL R> SCR ! 
        ; 
--> 

* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 

SCR #  18 
00 (  LINE EDITING COMMANDS 
01                    WFR-790105 ) 
02 : RL 
03  ( REPLACE ON LINE-1, FROM PAD ) 
04       PAD  1+  SWAP  -MOVE  ; 
05   
06   
07   
08 : $                        ( PUT 
09  FOLLOWING TEXT ON LINE-1 ) 
0A       1  TEXT  RL  QUIT  ; 
0B   
0C   
0D   
0E : %                ( INSERT TEXT 
0F  FOLLOWING AFTER LINE-1 *) 
10     1   TEXT  1+  DUP  SL  RL  ; 
11   
12   
13   
14 : IL       (  INSERT  PAD  AFTER 
15  LINE-1 ) 1+  DUP  SL  RL  ; 
16   
17   
18 : TL   ( TYPE LINE BY #-1,  SAVE 
19  ALSO IN PAD *) 
1A     DUP . ." $ " 
1B     DUP C/L *  R#  !       HL 
1C      PAD  1+  C/L  TYPE  CR ; 
1D   
1E --> 
1F   


(  LINE EDITING COMMANDS                           WFR-790105 ) 
: RL 
        ( REPLACE ON LINE-1, FROM PAD ) 
        PAD 1+ SWAP -MOVE 
        ; 
: $ 
        ( PUT FOLLOWING TEXT ON LINE-1 ) 
        1 TEXT RL QUIT 
        ; 
: % 
        ( INSERT TEXT FOLLOWING AFTER LINE-1 *) 
        1 TEXT 1+ DUP SL RL 
        ; 
: IL 
        (  INSERT  PAD  AFTER LINE-1 ) 
        1+ DUP SL RL 
        ; 
: TL 
        ( TYPE LINE BY #-1,  SAVE ALSO IN PAD *) 
        DUP . ." $ " DUP C/L * R# ! HL PAD 1+ C/L TYPE CR 
        ; 
--> 

* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 

SCR #  19 
00 (  SCREEN EDITING COMMANDS ) 
01 FORTH DEFINITIONS 
02   
03   
04 : COPY  (  DUPLICATE  SCREEN-2, 
05  ONTO SCREEN-1 *) 
06   SWAP BLOCK DROP PREV @ ! 
07   UPDATE FLUSH  ; 
08   
09   
0A : LIST 2602 LMARGN ! LIST ; 
0B   
0C   
0D : SHOW 1+ SWAP DO I LIST LOOP ; 
0E   
0F   
10 : L SCR @ LIST ( RE-LIST SCR ) ; 
11   
12 : N SCR @ 1+ LIST ;  ( LIST NEXT 
13  SCR) 
14   
15 : WHERE ( OFFSET BLK --- ) DUP 
16 SCR ! ." SCR # " . CR C/L /MOD 
17 EDITOR TL FORTH 2 + SPACES 
18 5E EMIT [COMPILE] EDITOR QUIT ; 
19   
1A BASE   @   DECIMAL 
1B     ' EDITOR 2 + 32 +ORIGIN ! 
1C  ( VOC-LINK ) BASE ! 
1D      ;S 
1E   
1F   


(  SCREEN EDITING COMMANDS ) 
FORTH DEFINITIONS 
: COPY 
        (  DUPLICATE  SCREEN-2,  ONTO SCREEN-1 *) 
        SWAP BLOCK DROP PREV @ ! UPDATE FLUSH 
        ; 
: LIST 
        2602 LMARGN ! LIST 
        ; 
: SHOW 
        1+ SWAP 
        DO 
          I LIST 
        LOOP 
        ; 
: L 
        SCR @ LIST ( RE-LIST SCR ) 
        ; 
: N 
        SCR @ 1+ LIST 
        ; 
( LIST NEXT SCR) 
: WHERE 
        ( OFFSET BLK --- ) 
        DUP SCR ! ." SCR # " . CR C/L /MOD EDITOR TL FORTH 2 + 
        SPACES 5E EMIT [COMPILE] EDITOR QUIT 
        ; 
BASE @ DECIMAL ' EDITOR 2 + 32 +ORIGIN ! ( VOC-LINK ) 
BASE ! ;S 

* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 

SCR #  1A 
00 ( OS & HDW CONSTANTS ) : CN CONS 
01 TANT ; 
02 D200 CN F1AUD D201 CN C1AUD 
03   
04 D202 CN F2AUD D203 CN C2AUD 
05   
06 D204 CN F3AUD D205 CN C3AUD 
07   
08 D206 CN F4AUD D207 CN C4AUD 
09   
0A D20F CN SKCTL D208 CN AUDCTL 
0B   
0C  230 CN DLST   22F CN DMCT 
0D   
0E   14 CN RTCLK  2F0 CN CRSINH 
0F   
10  2F4 CN CHBAS  2C4 CN COL0 
11   
12  2C5 CN COL1   2C6 CN COL2 
13   
14  2C7 CN COL3   2C8 CN COL4 
15   
16 D01F CN CONSOL 2FC CN CH 
17   
18  2BF CN BOTSC   52 CN LMARGN 
19   
1A 2FB CN ATACHR 
1B   
1C  ;S 
1D   
1E   
1F   


( OS & HDW CONSTANTS ) 
: CN 
        CONSTANT ; 
D200 CN F1AUD 
D201 CN C1AUD 
D202 CN F2AUD 
D203 CN C2AUD 
D204 CN F3AUD 
D205 CN C3AUD 
D206 CN F4AUD 
D207 CN C4AUD 
D20F CN SKCTL 
D208 CN AUDCTL 
230 CN DLST 
22F CN DMCT 
14 CN RTCLK 
2F0 CN CRSINH 
2F4 CN CHBAS 
2C4 CN COL0 
2C5 CN COL1 
2C6 CN COL2 
2C7 CN COL3 
2C8 CN COL4 
D01F CN CONSOL 
2FC CN CH 
2BF CN BOTSC 
52 CN LMARGN 
2FB CN ATACHR 
;S 

* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 

SCR #  1B 
00 ( CIO CALL ROUTINES ) 
01   
02 340 VARIABLE IOC 0 VARIABLE IOB 
03   
04 : IOCB 7 MIN 0 MAX 10 * DUP IOB 
05 ! 340 + IOC ! ; 
06 : .IOC <BUILDS , DOES> @ IOC @ + 
07  ; 
08 1 .IOC ICDNO 2 .IOC ICCOM 3 .IOC 
09  ICSTA 
0A 4 .IOC ICBAL 6 .IOC ICPTL 
0B   
0C 8 .IOC ICBLL A .IOC I1CAX B .IOC 
0D  I2CAX 
0E CODE CIO TXA, PHA, IOB LDX, E456 
0F  JSR, PLA, TAX, NEXT JMP, C; 
10 CODE Get XSAVE STX, IOB LDX, E45 
11 6 JSR, 
12 XSAVE LDX, PHA, 0 # LDA, PUSH JM 
13 P, C; 
14 : GET 7 ICCOM C! Get ; 
15   
16 : CLOSE 0C ICCOM C! CIO ; 
17   
18 : OPEN 3 ICCOM C! ICBAL ! I1CAX 
19 C! I2CAX C! CIO ; 
1A CODE ACIO XSAVE STX, BOT LDA, IO 
1B B LDX, E456 JSR, 
1C XSAVE LDX, POP JMP, C; 
1D   
1E --> 
1F   


( CIO CALL ROUTINES ) 
340 VARIABLE IOC 
0 VARIABLE IOB 
: IOCB 
        7 MIN 0 MAX 10 * DUP IOB ! 340 + IOC ! 
        ; 
: .IOC 
        <BUILDS , DOES> @ IOC @ + 
        ; 
1 .IOC ICDNO 2 .IOC ICCOM 3 .IOC ICSTA 4 .IOC ICBAL 6 .IOC 
ICPTL 8 .IOC ICBLL A .IOC I1CAX B .IOC I2CAX 
CODE CIO 
        TXA, 
        PHA, 
        IOB LDX, 
        E456 JSR, 
        PLA, 
        TAX, 
        NEXT JMP, 
        C; 
CODE Get 
        XSAVE STX, 
        IOB LDX, 
        E456 JSR, 
        XSAVE LDX, 
        PHA, 
        0 # LDA, 
        PUSH JMP, 
        C; 
: GET 
        7 ICCOM C! Get 
        ; 
: CLOSE 
        0C ICCOM C! CIO 
        ; 
: OPEN 
        3 ICCOM C! ICBAL ! I1CAX C! I2CAX C! CIO 
        ; 
CODE ACIO 
        XSAVE STX, 
        BOT LDA, 
        IOB LDX, 
        E456 JSR, 
        XSAVE LDX, 
        POP JMP, 
        C; 
--> 

* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 

SCR #  1C 
00 ( COLLEEN GRAPHICS ) 
01   
02 3A53 VARIABLE S: 2FD CONSTANT 
03        FILDAT 0 VARIABLE Qbase 
04 : PBASE Qbase @ ; : SPB HIMEM @ 
05 1+      F800 AND 800 - DUP 
06   Qbase ! 17F + HIMEM ! ; SPB 
07       : POS. 54 C! 55 ! ; 
08 : GR. 1 IOCB CLOSE 0 ICBLL ! DUP 
09  F      AND SWAP 30 AND 10 
0A   XOR 0C + S: OPEN SPB ; 
0B       : GRAPHICS GR. ; 
0C : LOC. POS. GET ; 1 VARIABLE Col 
0D or 
0E : C. DUP Color C! FILDAT C! ; 
0F       : PUT 0B ICCOM C! ACIO ; 
10 : PL. POS. ICBLL 0SET Color C@ P 
11 UT ; 
12 : SE. SWAP 10 * + SWAP 2C4 + C! 
13 ; 
14 : DR. POS. 11 ICCOM C! Color C@ 
15 DUP 2FB C! FILDAT C! CIO ; 
16 : PLOT PL. ;      : LOCATE LOC. 
17 ; 
18 : SETCOLOR SE. ;  : COLOR C. ; 
19   
1A : POSITION POS. ; : DRAWTO DR. ; 
1B   
1C : CLEAR   0 0 POS. 7D PUT ; 
1D   
1E : XIO18 ( FILL ) DUP 2FD C! 2FB 
1F C!      12 ICCOM C! CIO ; --> 


( COLLEEN GRAPHICS ) 
3A53 VARIABLE S: 
2FD CONSTANT FILDAT 
0 VARIABLE Qbase 
: PBASE 
        Qbase @ 
        ; 
: SPB 
        HIMEM @ 1+ F800 AND 800 - DUP Qbase ! 17F + HIMEM ! 
        ; 
SPB 
: POS. 
        54 C! 55 ! 
        ; 
: GR. 
        1 IOCB CLOSE 0 ICBLL ! DUP F AND SWAP 30 AND 10 XOR 0C 
        + S: OPEN SPB 
        ; 
: GRAPHICS 
        GR. 
        ; 
: LOC. 
        POS. GET 
        ; 
1 VARIABLE Color 
: C. 
        DUP Color C! FILDAT C! 
        ; 
: PUT 
        0B ICCOM C! ACIO 
        ; 
: PL. 
        POS. ICBLL 0SET Color C@ PUT 
        ; 
: SE. 
        SWAP 10 * + SWAP 2C4 + C! 
        ; 
: DR. 
        POS. 11 ICCOM C! Color C@ DUP 2FB C! FILDAT C! CIO 
        ; 
: PLOT 
        PL. 
        ; 
: LOCATE 
        LOC. 
        ; 
: SETCOLOR 
        SE. 
        ; 
: COLOR 
        C. 
        ; 
: POSITION 
        POS. 
        ; 
: DRAWTO 
        DR. 
        ; 
: CLEAR 
        0 0 POS. 7D PUT 
        ; 
: XIO18 
        ( FILL ) 
        DUP 2FD C! 2FB C! 12 ICCOM C! CIO 
        ; 
--> 

* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 

SCR #  1D 
00 ( SOUND CONTROLLERS RND PLAYER/M 
01 ISSILES ) 
02 : SOUND 3 D20F C! 0 D208 C! SWAP 
03   
04 10 * + 100 * + SWAP 2 * D200 + ! 
05  ; 
06 : PADDLE 270 + C@ ; 
07       : PTRIG 27C + C@ ; 
08 : STICK 278 + C@ ; 
09       : STRIG 284 + C@ ; 
0A : RND D20A C@ ; 
0B        22F CONSTANT DMACTL 
0C D01D CONSTANT GRACTL 
0D       D407 CONSTANT PMBASE 
0E D01B CONSTANT PRIOR 
0F       D016 CONSTANT VDELAY 
10  2C0 CONSTANT COLPM 
11        26F CONSTANT GPRIOR 
12 PBASE 1 - HIMEM ! 
13   
14 : PLAYER Qbase 1+ C@ PMBASE C! 3 
15         GRACTL C! 2 - IF 1C 
16   ELSE 0C ENDIF DMACTL @ E3 AND 
17 OR      DMACTL C! ; 
18 : HPOS! D000 + C! ; 
19         ( H-posn plyr# -> ) 
1A : SIZE! D008 + C! ; 
1B         ( size-code plyr# -> ) 
1C : COLPM! COLPM + C! ; 
1D         ( color plyr# -> ) 
1E : NOPLY GRACTL 0SET D000 11 0 FI 
1F LL      ; ;S 


( SOUND CONTROLLERS RND PLAYER/MISSILES ) 
: SOUND 
        3 D20F C! 0 D208 C! SWAP 10 * + 100 * + SWAP 2 * D200 + 
        ! 
        ; 
: PADDLE 
        270 + C@ 
        ; 
: PTRIG 
        27C + C@ 
        ; 
: STICK 
        278 + C@ 
        ; 
: STRIG 
        284 + C@ 
        ; 
: RND 
        D20A C@ 
        ; 
22F CONSTANT DMACTL 
D01D CONSTANT GRACTL 
D407 CONSTANT PMBASE 
D01B CONSTANT PRIOR 
D016 CONSTANT VDELAY 
2C0 CONSTANT COLPM 
26F CONSTANT GPRIOR 
PBASE 1 - HIMEM ! 
: PLAYER 
        Qbase 1+ C@ PMBASE C! 3 GRACTL C! 2 - 
        IF 
          1C 
        ELSE 
          0C 
        ENDIF 
        DMACTL @ E3 AND OR DMACTL C! 
        ; 
: HPOS! 
        D000 + C! 
        ; 
( H-posn plyr# -> ) 
: SIZE! 
        D008 + C! 
        ; 
( size-code plyr# -> ) 
: COLPM! 
        COLPM + C! 
        ; 
( color plyr# -> ) 
: NOPLY 
        GRACTL 0SET D000 11 0 FILL 
        ; 
;S 

* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 

SCR #  1E 
00 ( DECUS-FORTH ADDITIONS ) 
01   
02 : 1+! 1 SWAP +! ; : 1- 1 - ; 
03   
04 : 0SET 0 SWAP ! ; : 2* DUP + ; 
05   
06 : HD DUP 0A < IF 30 ELSE 37 
07  ENDIF + EMIT ; 
08 : CHH DUP 0F0 AND 10 / HD 0F AND 
09   HD ; 
0A : CH? C@ CHH ; 
0B   
0C : HH DUP 0FF00 AND 100 / 0FF AND 
0D   CHH  CHH  ; 
0E : H? @ HH ; 
0F   
10 : BDUMP 1+ SWAP DO I HH SPACE  I 
11   
12   8 0 DO DUP I + CH? SPACE  LOOP 
13   DROP  ." \"  CR  8  +LOOP ; 
14   
15 : \ 10 0 DO SP@ 0E + I - @ SP@ 
16   12 + @ I 2 / + C! 
17    2 +LOOP       DROP DROP DROP 
18 DROP DROP DROP  DROP DROP DROP 
19 QUIT ; 
1A : TBL <BUILDS DOES> ; 
1B   
1C : ALLOC DUP + ALLOT ; ( FOR RAM 
1D BASED SYSTEMS,) 
1E : ARRAY <BUILDS ALLOC DOES> ; 
1F ;S 


( DECUS-FORTH ADDITIONS ) 
: 1+! 
        1 SWAP +! 
        ; 
: 1- 
        1 - 
        ; 
: 0SET 
        0 SWAP ! 
        ; 
: 2* 
        DUP + 
        ; 
: HD 
        DUP 0A < 
        IF 
          30 
        ELSE 
          37 
        ENDIF 
        + EMIT 
        ; 
: CHH 
        DUP 0F0 AND 10 / HD 0F AND HD 
        ; 
: CH? 
        C@ CHH 
        ; 
: HH 
        DUP 0FF00 AND 100 / 0FF AND CHH CHH 
        ; 
: H? 
        @ HH 
        ; 
: BDUMP 
        1+ SWAP 
        DO 
          I HH SPACE I 8 0 
          DO 
            DUP I + CH? SPACE 
          LOOP 
          DROP ." \" CR 8 
        +LOOP 
        ; 
: \ 
        10 0 
        DO 
          SP@ 0E + I - @ SP@ 12 + @ I 2 / + C! 2 
        +LOOP 
        DROP DROP DROP DROP DROP DROP DROP DROP DROP QUIT 
        ; 
: TBL 
        <BUILDS DOES> 
        ; 
: ALLOC 
        DUP + ALLOT 
        ; 
( FOR RAM BASED SYSTEMS,) 
: ARRAY 
        <BUILDS ALLOC DOES> 
        ; 
;S 

* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 

SCR #  1F 
00 ( DISPLAY LIST STUFF ) 
01   
02 0 VARIABLE 3BYT 0 VARIABLE DLADR 
03   
04 : DINST DLADR @ C@ DUP 0F AND IF 
05   
06 DUP 0F AND 1 = IF 40 AND IF ." J 
07 VB " 
08 ELSE ." JMP " ENDIF DLADR 1+! DL 
09 ADR  @ 
0A @ DUP DLADR ! HH 3BYT 0SET ELSE 
0B DUP 0F AND 
0C 8 OVER < IF ." MAP" ELSE ." CHR" 
0D   
0E ENDIF 7 AND . DUP 10 AND IF ." H 
0F " 
10 THEN DUP 20 AND IF ." V" THEN DU 
11 P 
12 80 AND IF ." I" ENDIF DUP 0B0 
13   
14 AND IF DUP 40 AND IF ." ," ENDIF 
15   
16 ENDIF 40 AND IF 3 DLADR @ 1+ H? 
17 ELSE 
18 1 ENDIF 3BYT ! ENDIF ELSE ." BLK 
19 " 
1A DUP 80 AND IF ." I," ENDIF 70 
1B   
1C AND 10 / . 1 3BYT ! ENDIF CR 
1D   
1E 3BYT @ DLADR +! ; ;S 
1F   


( DISPLAY LIST STUFF ) 
0 VARIABLE 3BYT 
0 VARIABLE DLADR 
: DINST 
        DLADR @ C@ DUP 0F AND 
        IF 
          DUP 0F AND 1 = 
          IF 
            40 AND 
            IF 
              ." JVB " 
            ELSE 
              ." JMP " 
            ENDIF 
            DLADR 1+! DLADR @ @ DUP DLADR ! HH 3BYT 0SET 
          ELSE 
            DUP 0F AND 8 OVER < 
            IF 
              ." MAP" 
            ELSE 
              ." CHR" 
            ENDIF 
            7 AND . DUP 10 AND 
            IF 
              ." H" 
            THEN 
            DUP 20 AND 
            IF 
              ." V" 
            THEN 
            DUP 80 AND 
            IF 
              ." I" 
            ENDIF 
            DUP 0B0 AND 
            IF 
              DUP 40 AND 
              IF 
                ." ," 
              ENDIF 
            ENDIF 
            40 AND 
            IF 
              3 DLADR @ 1+ H? 
            ELSE 
              1 
            ENDIF 
            3BYT ! 
          ENDIF 
        ELSE 
          ." BLK" DUP 80 AND 
          IF 
            ." I," 
          ENDIF 
          70 AND 10 / . 1 3BYT ! 
        ENDIF 
        CR 3BYT @ DLADR +! 
        ; 
;S 

* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 

SCR #  20 
00 ( WRITE BOOTABLE OBJECT 1 OF 2 ) 
01   
02 BASE @ FORTH DEFINITIONS HEX 
03 SAVENFAs ( PRESERV ALL NFAS ) 
04 (  LATEST  0C  +ORIGIN ! ) 
05 ( TOP NFA ) 
06 HERE    1C  +ORIGIN ! ( FENCE ) 
07   
08 HERE    1E  +ORIGIN ! ( DP ) 
09   
0A HERE DUP FENCE ! 0 +ORIGIN - 80 
0B /     1+ CONSTANT #SECT 
0C CODE CALLDK XSAVE STX, E453 JSR, 
0D         TYA, PHA, ( STATUS ) 
0E   XSAVE LDX, PUSH JMP, C; 
0F   
10 : DKIO 301 ! ( CMD, DRIVE # ) 
11         30A ! ( SECT. # ) 
12   304 ! ( RAM BUFFER ADDR ) 
13         CALLDK ( JSR DKHND) 
14   DUP 0< IF ." ERROR " 0FF AND 
15         BASE @ SWAP DECIMAL 
16   . BASE ! QUIT ENDIF DROP ; 
17   
18 : WTSEC 5701 DKIO ; 
19       : RDSEC 5201 DKIO ; 
1A : FORMAT ." FORMAT DRIVE " DUP . 
1B   
1C   ." -ARE YOU SURE?" 0 PAD ! PAD 
1D  1      EXPECT PAD C@ 59 ( Y) = 
1E   IF 2100 OR PAD 0 ROT DKIO ELSE 
1F         DROP THEN ; --> 


( WRITE BOOTABLE OBJECT 1 OF 2 ) 
BASE @ FORTH DEFINITIONS HEX SAVENFAs ( PRESERV ALL NFAS ) 
(  LATEST  0C  +ORIGIN ! ) 
( TOP NFA ) 
HERE 1C +ORIGIN ! ( FENCE ) 
HERE 1E +ORIGIN ! ( DP ) 
HERE DUP FENCE ! 0 +ORIGIN - 80 / 1+ CONSTANT #SECT 
CODE CALLDK 
        XSAVE STX, 
        E453 JSR, 
        TYA, 
        PHA, 
        ( STATUS ) 
        XSAVE LDX, 
        PUSH JMP, 
        C; 
: DKIO 
        301 ! ( CMD, DRIVE # ) 
        30A ! ( SECT. # ) 
        304 ! ( RAM BUFFER ADDR ) 
        CALLDK ( JSR DKHND) 
        DUP 0< 
        IF 
          ." ERROR " 0FF AND BASE @ SWAP DECIMAL . BASE ! QUIT 
        ENDIF 
        DROP 
        ; 
: WTSEC 
        5701 DKIO 
        ; 
: RDSEC 
        5201 DKIO 
        ; 
: FORMAT 
        ." FORMAT DRIVE " DUP . ." -ARE YOU SURE?" 0 PAD ! PAD 
        1 EXPECT PAD C@ 59 ( Y) 
        = 
        IF 
          2100 OR PAD 0 ROT DKIO 
        ELSE 
          DROP 
        THEN 
        ; 
--> 

* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 

SCR #  21 
00 ( WRITE BOOTABLE OBJECT 2 OF 2 ) 
01   
02  0 VARIABLE BOOT ( ->CODE) 
03 : WTOBJ FLUSH EMPTY-BUFFERS 
04  ." INSERT NEW DISK, TYPE Y" CR 
05 0      PAD ! ( DEFAULT ) 
06  PAD 3 EXPECT PAD C@ 59 = IF BOO 
07 T      @ 1 WTSEC #SECT 0 DO I 
08  80 * +ORIGIN I 2 + WTSEC I 2 + 
09 .      LOOP ." DONE" CR THEN ; 
0A ( FOLLOWING IS BOOT SECTOR CODE 
0B )     HERE BOOT ! ( PT TO US ) 
0C ASSEMBLER 1FF , 480 , E4C0 , #SE 
0D CT     # LDA, 0= IF, 0 +ORIGIN , 
0E  1 , ENDIF, N STA, 52 # LDA, 302 
0F        STA, 48C LDA, 30A STA, 
10  48D LDA, 30B STA, ( FIRST SECTO 
11 R)     1 # LDA, ( DRV) 301 STA, 
12  48A LDA, 304 STA, 48B LDA, 
13        305 STA, ( ORIGIN) 
14  BEGIN, 30A INC, 0= IF, 30B INC, 
15        ENDIF, E453 JSR, 303 LDA, 
16  .A ASL, CS IF, RTS, ( FRETURN ) 
17        ENDIF, 304 LDA, 80 # EOR, 
18  304 STA, 0< NOT IF, 305 INC, 
19        ENDIF, ( BUMP PTR.) 
1A  N DEC, 0= UNTIL, 48A LDA, 0A ST 
1B A,     48B LDA, 0B STA, CLC, 
1C  RTS, FORTH BASE ! ." n FORMAT" 
1D CR ." to Format Disk Drive n" CR 
1E  ." WTOBJ to write boot version 
1F of        current object" CR ;S 


( WRITE BOOTABLE OBJECT 2 OF 2 ) 
0 VARIABLE BOOT 
( ->CODE) 
: WTOBJ 
        FLUSH EMPTY-BUFFERS ." INSERT NEW DISK, 
        TYPE Y" CR 0 PAD ! ( DEFAULT ) 
        PAD 3 EXPECT PAD C@ 59 = 
        IF 
          BOOT @ 1 WTSEC #SECT 0 
          DO 
            I 80 * +ORIGIN I 2 + WTSEC I 2 + . 
          LOOP 
          ." DONE" CR 
        THEN 
        ; 
( FOLLOWING IS BOOT SECTOR CODE ) 
HERE BOOT ! ( PT TO US ) 
ASSEMBLER 1FF , 480 , E4C0 , #SECT # LDA, 
0= 
IF, 
  0 +ORIGIN , 1 , 
ENDIF, 
N STA, 
52 # LDA, 
302 STA, 
48C LDA, 
30A STA, 
48D LDA, 
30B STA, 
( FIRST SECTOR) 
1 # LDA, 
( DRV) 
301 STA, 
48A LDA, 
304 STA, 
48B LDA, 
305 STA, 
( ORIGIN) 
BEGIN, 
  30A INC, 
  0= 
  IF, 
    30B INC, 
  ENDIF, 
  E453 JSR, 
  303 LDA, 
  .A ASL, 
  CS 
  IF, 
    RTS, 
    ( FRETURN ) 
  ENDIF, 
  304 LDA, 
  80 # EOR, 
  304 STA, 
  0< NOT 
  IF, 
    305 INC, 
  ENDIF, 
  ( BUMP PTR.) 
  N DEC, 
  0= 
UNTIL, 
48A LDA, 
0A STA, 
48B LDA, 
0B STA, 
CLC, 
RTS, 
FORTH BASE ! ." n FORMAT" CR ." to Format Disk Drive n" CR ." 
WTOBJ to write boot version of current object" CR ;S 

* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 

SCR #  22 
00 ( <UNUSED> ) ;S 
01   
02   
03   
04   
05   
06   
07   
08   
09   
0A   
0B   
0C   
0D   
0E   
0F   
10   
11   
12   
13   
14   
15   
16   
17   
18   
19   
1A   
1B   
1C   
1D   
1E   
1F   


( <UNUSED> ) 
;S 

* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 

SCR #  23 
00 ( COLLEEN TO DEVSYS COMMUNICATIO 
01 NS WORDS --  SEND ) 
02 D303 CONSTANT PIADIR D301 CONSTA 
03 NT PIA 
04 : NIBSEND ( SEND LOW NIBBLE OF 
05   TOS ) 
06 80 OR PIA C! ( SEND DATA ) 
07  BEGIN PIA C@ 40 AND ( WAIT FOR 
08  ACK ) END 0 PIA C! ( ACK-ACK) 
09  BEGIN PIA C@ 40 AND 0= END 
0A  ( WAIT FOR ACK-ACK-ACK )   ; 
0B : DBSND ( TOS=BLOCK PTR ) 
0C  400 0 DO I OVER + ( DATA PTR ) 
0D  C@ DUP NIBSEND 
0E  ( LOW NIBBLE ) 10 / NIBSEND  ( 
0F HIGH NIBBLE ) LOOP DROP ; 
10 : BSND ( SET UP PIA AND SEND A 
11  BLOCK -- TOS = BLOCK NUMBER ) 
12  PIADIR C@ FB AND PIADIR C! 
13  8F PIA C! ( SET DATA DIRECTION) 
14  PIADIR C@ 4 OR PIADIR C! 
15  0 PIA C! 
16  BEGIN PIA C@ 40 AND 0= END 
17  BLOCK DBSND ( SEND THE BLOCK ) 
18  ; 
19   
1A ( FRST LAST SMOV MOVE BLOCKS ) 
1B : SMOV 1+ SWAP DO I .     I BSND 
1C  LOOP ; 
1D   
1E  --> 
1F   


( COLLEEN TO DEVSYS COMMUNICATIONS WORDS --  SEND ) 
D303 CONSTANT PIADIR 
D301 CONSTANT PIA 
: NIBSEND 
        ( SEND LOW NIBBLE OF    TOS ) 
        80 OR PIA C! ( SEND DATA ) 
        BEGIN 
          PIA C@ 40 AND ( WAIT FOR  ACK ) 
        END 
        0 PIA C! ( ACK-ACK) 
        BEGIN 
          PIA C@ 40 AND 0= 
        END 
        ( WAIT FOR ACK-ACK-ACK ) 
        ; 
: DBSND 
        ( TOS=BLOCK PTR ) 
        400 0 
        DO 
          I OVER + ( DATA PTR ) 
          C@ DUP NIBSEND ( LOW NIBBLE ) 
          10 / NIBSEND ( HIGH NIBBLE ) 
        LOOP 
        DROP 
        ; 
: BSND 
        ( SET UP PIA AND SEND A   BLOCK -- TOS = BLOCK NUMBER ) 
        PIADIR C@ FB AND PIADIR C! 8F PIA C! 
        ( SET DATA DIRECTION) 
        PIADIR C@ 4 OR PIADIR C! 0 PIA C! 
        BEGIN 
          PIA C@ 40 AND 0= 
        END 
        BLOCK DBSND ( SEND THE BLOCK ) 
        ; 
( FRST LAST SMOV MOVE BLOCKS ) 
: SMOV 
        1+ SWAP 
        DO 
          I . I BSND 
        LOOP 
        ; 
--> 

* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 

SCR #  24 
00 ( COLLEEN TO DEVSYS COMMUNICATIO 
01 NS WORDS -- RECEIVE ) 
02 CODE NIBRECV 0 # LDA, PIA   STA, 
03  BEGIN, PIA  BIT, 0< UNTIL, 
04 PIA  LDA, 0F #  AND, 40 #  LDY, 
05  PIA STY, 
06 BEGIN, PIA  BIT, 0< NOT UNTIL, 
07  PHA, 0 #  LDA, PIA  STA, 
08 PUSH JMP, C; 
09  ( READY TO RECEIVE ) 
0A  : DBREC ( TOS - BLOCK POINTER ) 
0B  400 0 DO NIBRECV NIBRECV 10 * + 
0C  ( GET A BYTE ) OVER I + 
0D  C! ( AND STORE IT IN BUFFER ) 
0E  LOOP DROP ; 
0F   
10 : BREC ( SET UP PIA AND RECV A 
11  BLOCK -- TOS = BLOCK NUMBER ) 
12  PIADIR C@ FB AND PIADIR C! 
13  40 PIA C! ( ONLY SEND ACK BIT ) 
14  PIADIR C@ 4 OR PIADIR C! 
15  BUFFER DBREC ( RECV THE BLOCK ) 
16  UPDATE FLUSH ( WRITE TO DISK ) 
17  ; 
18 ( FRST LAST RMOV -- MOVE A SET 
19  OF BLOCKS ) 
1A : RMOV 1+ SWAP DO I . I BREC 
1B  LOOP ;  ;S 
1C   
1D   
1E   
1F   


( COLLEEN TO DEVSYS COMMUNICATIONS WORDS -- RECEIVE ) 
CODE NIBRECV 
        0 # LDA, 
        PIA STA, 
        BEGIN, 
          PIA BIT, 
          0< 
        UNTIL, 
        PIA LDA, 
        0F # AND, 
        40 # LDY, 
        PIA STY, 
        BEGIN, 
          PIA BIT, 
          0< NOT 
        UNTIL, 
        PHA, 
        0 # LDA, 
        PIA STA, 
        PUSH JMP, 
        C; 
( READY TO RECEIVE ) 
: DBREC 
        ( TOS - BLOCK POINTER ) 
        400 0 
        DO 
          NIBRECV NIBRECV 10 * + ( GET A BYTE ) 
          OVER I + C! ( AND STORE IT IN BUFFER ) 
        LOOP 
        DROP 
        ; 
: BREC 
        ( SET UP PIA AND RECV A   BLOCK -- TOS = BLOCK NUMBER ) 
        PIADIR C@ FB AND PIADIR C! 40 PIA C! 
        ( ONLY SEND ACK BIT ) 
        PIADIR C@ 4 OR PIADIR C! BUFFER DBREC 
        ( RECV THE BLOCK ) 
        UPDATE FLUSH ( WRITE TO DISK ) 
        ; 
( FRST LAST RMOV -- MOVE A SET   OF BLOCKS ) 
: RMOV 
        1+ SWAP 
        DO 
          I . I BREC 
        LOOP 
        ; 
;S 

* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 

SCR #  25 
00 ( LINE PRINTER WORDS 1/27/81 
01  SRC )      3A50 VARIABLE P: 
02  CODE PCIO XSAVE STX, 70 # LDX, 
03 E456 JSR, XSAVE LDX,  TYA, PHA, 
04 PUSH JMP, C; 0 VARIABLE LPCNT 
05 : PERR? DUP 0< IF FF AND 
06 ." P: ERROR "   ERROR THEN 
07  DROP ; 
08 : LPOPEN 3 3B2 C! P: 3B4 ! 2 3B8 
09  ! 8 3BA ! PCIO PERR? ; 
0A : LYP1 3B8 ! 3B4 ! 0B 3B2 C! PCI 
0B O PERR? ; : LPEMIT SP@ 1 LYP1 DR 
0C OP ; : LPCR 9B LPEMIT 1 LPCNT +! 
0D  ; : LYPE DUP IF DUP 50 > IF 
0E  1 LPCNT +! THEN LYP1 ELSE DROP 
0F DROP THEN 20 SP@ 1 LYP1 DROP ; 
10 : CRLP LPCR LPCNT @ 3D > IF 
11 LPCR LPCR LPCR LPCR 0 LPCNT ! 
12 THEN ; 
13 : FFLP CRLP BEGIN LPCNT @ WHILE 
14 CRLP REPEAT ; 
15 : SHRINK 1B LPEMIT 14 LPEMIT 
16  CRLP ; : EXPAND 1B LPEMIT 13 
17  LPEMIT CRLP ; 
18 : .CLP 0 <# # # #> LYPE ; 
19 : .LP 0 <# #S #>  LYPE ; 
1A : LINELP DUP .CLP SCR @ (LINE) 
1B  -TRAILING 1 MAX LYPE CRLP   ; 
1C 4353 VARIABLE SCR# 2052 , 2023 , 
1D  : LISTLP DUP SCR ! SCR# 6 LYPE 
1E .LP LPCR B/SCR B/BUF * C/L / 
1F 0 DO I LINELP LOOP ; --> 


( LINE PRINTER WORDS 1/27/81     SRC ) 
3A50 VARIABLE P: 
CODE PCIO 
        XSAVE STX, 
        70 # LDX, 
        E456 JSR, 
        XSAVE LDX, 
        TYA, 
        PHA, 
        PUSH JMP, 
        C; 
0 VARIABLE LPCNT 
: PERR? 
        DUP 0< 
        IF 
          FF AND ." P: ERROR " ERROR 
        THEN 
        DROP 
        ; 
: LPOPEN 
        3 3B2 C! P: 3B4 ! 2 3B8 ! 8 3BA ! PCIO PERR? 
        ; 
: LYP1 
        3B8 ! 3B4 ! 0B 3B2 C! PCIO PERR? 
        ; 
: LPEMIT 
        SP@ 1 LYP1 DROP 
        ; 
: LPCR 
        9B LPEMIT 1 LPCNT +! 
        ; 
: LYPE 
        DUP 
        IF 
          DUP 50 > 
          IF 
            1 LPCNT +! 
          THEN 
          LYP1 
        ELSE 
          DROP DROP 
        THEN 
        20 SP@ 1 LYP1 DROP 
        ; 
: CRLP 
        LPCR LPCNT @ 3D > 
        IF 
          LPCR LPCR LPCR LPCR 0 LPCNT ! 
        THEN 
        ; 
: FFLP 
        CRLP 
        BEGIN 
          LPCNT @ 
        WHILE 
          CRLP 
        REPEAT 
        ; 
: SHRINK 
        1B LPEMIT 14 LPEMIT CRLP 
        ; 
: EXPAND 
        1B LPEMIT 13 LPEMIT CRLP 
        ; 
: .CLP 
        0 <# # # #> LYPE 
        ; 
: .LP 
        0 <# #S #> LYPE 
        ; 
: LINELP 
        DUP .CLP SCR @ (LINE) -TRAILING 1 MAX LYPE CRLP 
        ; 
4353 VARIABLE SCR# 
2052 , 2023 , 
: LISTLP 
        DUP SCR ! SCR# 6 LYPE .LP LPCR B/SCR B/BUF * C/L / 0 
        DO 
          I LINELP 
        LOOP 
        ; 
--> 

* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 

SCR #  26 
00 ( MORE LINE PRINTER WORDS 
01  1/27/81  SRC             ) 
02 : LPSPC 0 DO 20 LPEMIT LOOP ; 
03 : SHOWLP 1+ SWAP C/L 20 = IF 
04   DO CRLP 
05   SCR# 6 LYPE I .LP 
06   1F LPSPC SCR# 6 LYPE I 1+ 
07   .LP CRLP 
08   I 20 0 DO DUP SCR ! I .CLP 
09   I SCR @ (LINE) LYPE 
0A   5 LPSPC 
0B   DUP 1+ SCR ! I LINELP LOOP 
0C   DROP 2 +LOOP 
0D   ELSE DO CRLP    I LISTLP LOOP 
0E   ENDIF FFLP ; 
0F   
10 : LPINDEX 1+ SWAP DO I .LP 
11 0 I (LINE) -TRAILING LYPE LPCR 
12 LOOP ; 
13 LPOPEN 
14 ;S 
15   
16   
17   
18   
19   
1A   
1B   
1C   
1D   
1E   
1F   


( MORE LINE PRINTER WORDS        1/27/81  SRC             ) 
: LPSPC 
        0 
        DO 
          20 LPEMIT 
        LOOP 
        ; 
: SHOWLP 
        1+ SWAP C/L 20 = 
        IF 
          DO 
            CRLP SCR# 6 LYPE I .LP 1F LPSPC SCR# 6 LYPE I 1+ 
            .LP CRLP I 20 0 
            DO 
              DUP SCR ! I .CLP I SCR @ (LINE) LYPE 5 LPSPC DUP 
              1+ SCR ! I LINELP 
            LOOP 
            DROP 2 
          +LOOP 
        ELSE 
          DO 
            CRLP I LISTLP 
          LOOP 
        ENDIF 
        FFLP 
        ; 
: LPINDEX 
        1+ SWAP 
        DO 
          I .LP 0 I (LINE) -TRAILING LYPE LPCR 
        LOOP 
        ; 
LPOPEN ;S 

* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 

SCR #  27 
00 ( FORMATTED LIST PROGRAM) : THAT 
01  ; VOCABULARY FORMX IMMEDIATE 
02 FORMX DEFINITIONS : CN CONSTANT 
03 ;  : OCTAL 8 BASE ! ; 
04   BASE @ OCTAL 40 CN SPACBYT 54 
05 CN COMCHR : IARRAY 0 VARIABLE -2 
06  ALLOT ; : 0> DUP 0= IF DROP  0 
07 ELSE  0< 0= THEN ; 
08 0 VARIABLE INDENT 106 CN FCONS 
09 111 CN ICONS 0 VARIABLE TLFLG 
0A 0 VARIABLE KERKNT 100 CN MAXLIN 
0B : NXSPACE >R 1+ >R 0   R> R> DO 
0C SPACBYT I C@ = IF DROP I LEAVE 
0D THEN LOOP ; : NXNSPACE >R 1+ >R 
0E 0 R> R> DO SPACBYT I C@ = 0= IF 
0F   
10  DROP I LEAVE THEN LOOP ; : GTNX 
11 WD DUP IF + OVER SWAP NXSPACE 
12 ELSE DROP THEN DUP IF OVER SWAP 
13 NXNSPACE DUP IF OVER OVER 
14 NXSPACE DUP IF OVER - ELSE DROP 
15 OVER OVER - 1+ THEN ELSE DUP 
16 THEN ELSE DUP THEN ; : TORLCR TL 
17 FLG @ IF CRLP ELSE CR THEN KERKN 
18 T 0SET ; : TORLY DUP 1+ KERKNT + 
19 ! TLFLG @ IF LYPE ELSE TYPE SPAC 
1A E THEN ; : DOIND INDENT @ 0> IF 
1B INDENT @ 0 DO 0 0 TORLY LOOP THE 
1C N ; : PRWORD DUP 1+ KERKNT @ + M 
1D AXLIN > IF TORLCR THEN KERKNT @ 
1E 0= IF DOIND THEN OVER OVER TORLY 
1F  ; : 1SET 1 SWAP ! ;  --> 


( FORMATTED LIST PROGRAM) 
: THAT 
        ; 
VOCABULARY FORMX IMMEDIATE FORMX DEFINITIONS 
: CN 
        CONSTANT ; 
: OCTAL 
        8 BASE ! 
        ; 
BASE @ OCTAL 40 CN SPACBYT 
54 CN COMCHR 
: IARRAY 
        0 VARIABLE -2 
ALLOT 
; 
: 0> 
        DUP 0= 
        IF 
          DROP 0 
        ELSE 
          0< 0= 
        THEN 
        ; 
0 VARIABLE INDENT 
106 CN FCONS 
111 CN ICONS 
0 VARIABLE TLFLG 
0 VARIABLE KERKNT 
100 CN MAXLIN 
: NXSPACE 
        >R 1+ >R 0 R> R> 
        DO 
          SPACBYT I C@ = 
          IF 
            DROP I LEAVE 
          THEN 
        LOOP 
        ; 
: NXNSPACE 
        >R 1+ >R 0 R> R> 
        DO 
          SPACBYT I C@ = 0= 
          IF 
            DROP I LEAVE 
          THEN 
        LOOP 
        ; 
: GTNXWD 
        DUP 
        IF 
          + OVER SWAP NXSPACE 
        ELSE 
          DROP 
        THEN 
        DUP 
        IF 
          OVER SWAP NXNSPACE DUP 
          IF 
            OVER OVER NXSPACE DUP 
            IF 
              OVER - 
            ELSE 
              DROP OVER OVER - 1+ 
            THEN 
          ELSE 
            DUP 
          THEN 
        ELSE 
          DUP 
        THEN 
        ; 
: TORLCR 
        TLFLG @ 
        IF 
          CRLP 
        ELSE 
          CR 
        THEN 
        KERKNT 0SET 
        ; 
: TORLY 
        DUP 1+ KERKNT +! TLFLG @ 
        IF 
          LYPE 
        ELSE 
          TYPE SPACE 
        THEN 
        ; 
: DOIND 
        INDENT @ 0> 
        IF 
          INDENT @ 0 
          DO 
            0 0 TORLY 
          LOOP 
        THEN 
        ; 
: PRWORD 
        DUP 1+ KERKNT @ + MAXLIN > 
        IF 
          TORLCR 
        THEN 
        KERKNT @ 0= 
        IF 
          DOIND 
        THEN 
        OVER OVER TORLY 
        ; 
: 1SET 
        1 SWAP ! 
        ; 
--> 

* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 

SCR #  28 
00 : ( 51 WORD 6 ALLOT ; 
01   
02 : IA IARRAY ; IA L1G 10  , ( :) 
03 ( CODE) ( ,CODE) ( SUBROUTINE) 
04  ( IA) ( IARRAY) ( LABEL) ( TBL) 
05  IA L2G 2 , ( ;) ( C;) 
06  IA L3G 2 , ( NXT,) ( NEXT,) IA 
07 L4G 6 , ( IF) ( DO) ( IF,) 
08   ( CASE) ( BEGIN) ( BEGIN,) IA 
09 L5G 3 , ( ELSE,) ( ELSE) 
0A   ( WHILE) IA L6G 16 , ( THEN,) 
0B ( THEN) ( END,) ( END) ( SOB,) 
0C ( BACK) ( UNTIL) ( AGAIN) ( REPE 
0D AT) ( ENDIF,) 
0E   ( UNTIL,) ( LOOP) ( +LOOP) ( E 
0F NDIF) IA L7G 7 , ( CONSTANT) 
10 ( IR)   ( VARIABLE)       ( CN) 
11 ( ARRAY) ( INTEGER) ( ORCON) 
12    IA L8G 1 , ( () IA L9G 3 , ( 
13 LD,) ( ST,) ( LOAD) 
14 IA LAG 1 , ( ;CODE) 
15   
16 : CMPWORD DUP >R C@ OVER = R> 
17 SWAP IF >R OVER 
18   R> SWAP OVER DUP C@ DUP 4 > IF 
19  DROP 4 THEN 0 
1A   DO I OVER + 1+ C@ >R OVER R> 
1B SWAP I + C@ 
1C   = 0= IF 0 LEAVE THEN LOOP 
1D   
1E   0= IF DROP DROP 0 THEN ELSE 0 
1F THEN ;   --> 


: ( 
        51 WORD 6 ALLOT 
        ; 
: IA 
IARRAY ; 
IA L1G 
        10 , ( :) 
        ( CODE) 
        ( ,CODE) 
        ( SUBROUTINE) 
        ( IA) 
        ( IARRAY) 
        ( LABEL) 
        ( TBL) 
IA L2G 
        2 , ( ;) 
        ( C;) 
IA L3G 
        2 , ( NXT,) 
        ( NEXT,) 
IA L4G 
        6 , ( IF) 
        ( DO) 
        ( IF,) 
        ( CASE) 
        ( BEGIN) 
        ( BEGIN,) 
IA L5G 
        3 , ( ELSE,) 
        ( ELSE) 
        ( WHILE) 
IA L6G 
        16 , ( THEN,) 
        ( THEN) 
        ( END,) 
        ( END) 
        ( SOB,) 
        ( BACK) 
        ( UNTIL) 
        ( AGAIN) 
        ( REPEAT) 
        ( ENDIF,) 
        ( UNTIL,) 
        ( LOOP) 
        ( +LOOP) 
        ( ENDIF) 
IA L7G 
        7 , ( CONSTANT) 
        ( IR) 
        ( VARIABLE) 
        ( CN) 
        ( ARRAY) 
        ( INTEGER) 
        ( ORCON) 
IA L8G 
        1 , ( () 
IA L9G 
        3 , ( LD,) 
        ( ST,) 
        ( LOAD) 
IA LAG 
        1 , ( ;CODE) 
: CMPWORD 
        DUP >R C@ OVER = R> SWAP 
        IF 
          >R OVER R> SWAP OVER DUP C@ DUP 4 > 
          IF 
            DROP 4 
          THEN 
          0 
          DO 
            I OVER + 1+ C@ >R OVER R> SWAP I + C@ = 0= 
            IF 
              0 LEAVE 
            THEN 
          LOOP 
          0= 
          IF 
            DROP DROP 0 
          THEN 
        ELSE 
          0 
        THEN 
        ; 
--> 

* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 

SCR #  29 
00 : GSCAN DUP @ SWAP 2+ SWAP 0 DO 
01 CMPWORD IF LEAVE 
02   0 ELSE 6 + THEN LOOP IF 0 ELSE 
03  DROP 1 THEN ; 
04 : NEWCR KERKNT @ IF TORLCR THEN 
05 ; 
06 : DUPBC OVER >R >R OVER R> SWAP 
07 R> ; 
08 : FINDCHAR SWAP >R SWAP 1+ R> 
09 DO DUP I C@ = 
0A   IF DROP I LEAVE 0 THEN LOOP IF 
0B  0 THEN ; 
0C : PRNEWL PRWORD TORLCR ; 
0D   
0E : >= OVER OVER = IF DROP DROP 
0F 1 ELSE > THEN ;   --> 
10   
11   
12   
13   
14   
15   
16   
17   
18   
19   
1A   
1B   
1C   
1D   
1E   
1F   


: GSCAN 
        DUP @ SWAP 2+ SWAP 0 
        DO 
          CMPWORD 
          IF 
            LEAVE 0 
          ELSE 
            6 + 
          THEN 
        LOOP 
        IF 
          0 
        ELSE 
          DROP 1 
        THEN 
        ; 
: NEWCR 
        KERKNT @ 
        IF 
          TORLCR 
        THEN 
        ; 
: DUPBC 
        OVER >R >R OVER R> SWAP R> 
        ; 
: FINDCHAR 
        SWAP >R SWAP 1+ R> 
        DO 
          DUP I C@ = 
          IF 
            DROP I LEAVE 0 
          THEN 
        LOOP 
        IF 
          0 
        THEN 
        ; 
: PRNEWL 
        PRWORD TORLCR 
        ; 
: >= 
        OVER OVER = 
        IF 
          DROP DROP 1 
        ELSE 
          > 
        THEN 
        ; 
--> 

* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 

SCR #  2A 
00 : EL1G NEWCR INDENT 0SET PRWORD 
01 GTNXWD PRNEWL 
02   10 INDENT ! ; 
03   
04 : EL2G NEWCR PRNEWL INDENT 0SET 
05 ; 
06 : EL3G NEWCR PRNEWL ; 
07   
08 : EL4G NEWCR PRNEWL 2 INDENT +! 
09 ; 
0A : EL5G NEWCR -2 INDENT +! PRNEWL 
0B  2 INDENT +! ; 
0C : EL6G NEWCR -2 INDENT +! PRNEWL 
0D  ; 
0E : EL7G PRWORD GTNXWD PRNEWL INDE 
0F NT 0SET ; 
10 : EL8G DUPBC 51 FINDCHAR DUP 
11   
12   IF SWAP DROP OVER - 1+ PRNEWL 
13 ELSE DROP PRWORD THEN ; 
14 : EL9G PRNEWL ; 
15   
16 : ELAG NEWCR 10 INDENT ! PRNEWL 
17 ; 
18 : ASSWRD DUP 4 >= IF OVER OVER + 
19  1- C@ COMCHR = IF 
1A    OVER DUP C@ ICONS =  SWAP 1+ 
1B C@ FCONS = AND 
1C   IF 2 ELSE 1 THEN ELSE 0 THEN E 
1D LSE 0 THEN ; 
1E --> 
1F   


: EL1G 
        NEWCR INDENT 0SET PRWORD GTNXWD PRNEWL 10 INDENT ! 
        ; 
: EL2G 
        NEWCR PRNEWL INDENT 0SET 
        ; 
: EL3G 
        NEWCR PRNEWL 
        ; 
: EL4G 
        NEWCR PRNEWL 2 INDENT +! 
        ; 
: EL5G 
        NEWCR -2 INDENT +! PRNEWL 2 INDENT +! 
        ; 
: EL6G 
        NEWCR -2 INDENT +! PRNEWL 
        ; 
: EL7G 
        PRWORD GTNXWD PRNEWL INDENT 0SET 
        ; 
: EL8G 
        DUPBC 51 FINDCHAR DUP 
        IF 
          SWAP DROP OVER - 1+ PRNEWL 
        ELSE 
          DROP PRWORD 
        THEN 
        ; 
: EL9G 
        PRNEWL 
        ; 
: ELAG 
        NEWCR 10 INDENT ! PRNEWL 
        ; 
: ASSWRD 
        DUP 4 >= 
        IF 
          OVER OVER + 1- C@ COMCHR = 
          IF 
            OVER DUP C@ ICONS = SWAP 1+ C@ FCONS = AND 
            IF 
              2 
            ELSE 
              1 
            THEN 
          ELSE 
            0 
          THEN 
        ELSE 
          0 
        THEN 
        ; 
--> 

* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 

SCR #  2B 
00 : PRCWRD L1G GSCAN IF EL1G ELSE 
01 L2G GSCAN IF EL2G ELSE 
02   L3G GSCAN IF EL3G ELSE L4G GSC 
03 AN IF EL4G ELSE L5G GSCAN 
04   IF EL5G ELSE L6G GSCAN IF EL6G 
05  ELSE L7G GSCAN IF EL7G 
06   ELSE L8G GSCAN IF EL8G ELSE L9 
07 G GSCAN IF EL9G ELSE 
08   LAG GSCAN IF ELAG ELSE ASSWRD 
09 IF ASSWRD 2 = 
0A   IF EL4G ELSE PRNEWL THEN ELSE 
0B PRWORD 
0C   THEN THEN THEN THEN THEN THEN 
0D THEN THEN THEN THEN THEN ; 
0E : FORLST TORLCR DUP TLFLG @ IF L 
0F ISTLP ELSE 
10  TORLCR LIST THEN TORLCR TORLCR 
11 DUP BLK ! 
12   BLOCK DUP 1777 + SWAP KERKNT 0 
13 SET INDENT 0SET 0 BEGIN GTNXWD 
14   DUP IF PRCWRD THEN DUP 0= END 
15 DROP DROP DROP BLK 0SET ; 
16 : ASTER TORLCR 40 0 DO 52 SP@ 1 
17 TORLY DROP LOOP TORLCR ; 
18 : FORSHW 1+ OVER DO ASTER I FORL 
19 ST TORLCR LOOP DROP ; 
1A FORTH DEFINITIONS : FLST FORMX T 
1B LFLG 0SET FORLST ; : FLSTLP FORM 
1C X TLFLG 1SET FORLST FFLP ; : FSH 
1D W FORMX TLFLG 0SET FORSHW ; : FS 
1E HWLP FORMX  TLFLG 1SET FORSHW 
1F FFLP  ; BASE !  ;S 


: PRCWRD 
        L1G GSCAN 
        IF 
          EL1G 
        ELSE 
          L2G GSCAN 
          IF 
            EL2G 
          ELSE 
            L3G GSCAN 
            IF 
              EL3G 
            ELSE 
              L4G GSCAN 
              IF 
                EL4G 
              ELSE 
                L5G GSCAN 
                IF 
                  EL5G 
                ELSE 
                  L6G GSCAN 
                  IF 
                    EL6G 
                  ELSE 
                    L7G GSCAN 
                    IF 
                      EL7G 
                    ELSE 
                      L8G GSCAN 
                      IF 
                        EL8G 
                      ELSE 
                        L9G GSCAN 
                        IF 
                          EL9G 
                        ELSE 
                          LAG GSCAN 
                          IF 
                            ELAG 
                          ELSE 
                            ASSWRD 
                            IF 
                              ASSWRD 2 = 
                              IF 
                                EL4G 
                              ELSE 
                                PRNEWL 
                              THEN 
                            ELSE 
                              PRWORD 
                            THEN 
                          THEN 
                        THEN 
                      THEN 
                    THEN 
                  THEN 
                THEN 
              THEN 
            THEN 
          THEN 
        THEN 
        ; 
: FORLST 
        TORLCR DUP TLFLG @ 
        IF 
          LISTLP 
        ELSE 
          TORLCR LIST 
        THEN 
        TORLCR TORLCR DUP BLK ! BLOCK DUP 1777 + SWAP KERKNT 
        0SET INDENT 0SET 0 
        BEGIN 
          GTNXWD DUP 
          IF 
            PRCWRD 
          THEN 
          DUP 0= 
        END 
        DROP DROP DROP BLK 0SET 
        ; 
: ASTER 
        TORLCR 40 0 
        DO 
          52 SP@ 1 TORLY DROP 
        LOOP 
        TORLCR 
        ; 
: FORSHW 
        1+ OVER 
        DO 
          ASTER I FORLST TORLCR 
        LOOP 
        DROP 
        ; 
FORTH DEFINITIONS 
: FLST 
        FORMX TLFLG 0SET FORLST 
        ; 
: FLSTLP 
        FORMX TLFLG 1SET FORLST FFLP 
        ; 
: FSHW 
        FORMX TLFLG 0SET FORSHW 
        ; 
: FSHWLP 
        FORMX TLFLG 1SET FORSHW FFLP 
        ; 
BASE ! ;S 

* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 

SCR #  2C 
00 ( RS232 SUPPORT ) 
01   
02 CODE SIO XSAVE STX, BOT LDA, E45 
03 9      JSR, ( SIOV) XSAVE LDX, 
04  BOT STA, BOT 1+ STY, NEXT JMP, 
05 C; 
06 : SERR DUP 0< IF 0 100 U/ BASE @ 
07         DECIMAL ." SIO ERROR " 
08   . BASE ! QUIT ELSE DROP THEN ; 
09   
0A CODE DORL XSAVE STX, 506 JSR, 
0B   
0C  HERE 8 + JSR, XSAVE LDX, NEXT 
0D        JMP, 0C ) JMP, C; 
0E : GETR: HERE 2E7 ! ( SET MEMLO ) 
0F        FLUSH EMPTY-BUFFERS 
10  150  300 !  ( DDEVIC,DUNIT) 
11   
12  403F 302 !  ( ? CMD,EXPECT DATA 
13 )      5    306 C! ( TIMEOUT) 
14  500  304 !  ( BUFFER ADDR) 
15   
16  0C   308 !  ( LENGTH ) 
17   
18  0    30A !  ( AUXES ) 
19        0 SIO SERR ( ERRORS?) 
1A  500 300 0C CMOVE 0 SIO SERR DOR 
1B L 
1C  ( RUN RELOCATOR ) 2E7 @ HERE - 
1D   
1E  ALLOT HERE FENCE ! ; --> 
1F   


( RS232 SUPPORT ) 
CODE SIO 
        XSAVE STX, 
        BOT LDA, 
        E459 JSR, 
        ( SIOV) 
        XSAVE LDX, 
        BOT STA, 
        BOT 1+ STY, 
        NEXT JMP, 
        C; 
: SERR 
        DUP 0< 
        IF 
          0 100 U/ BASE @ DECIMAL ." SIO ERROR " . BASE ! QUIT 
        ELSE 
          DROP 
        THEN 
        ; 
CODE DORL 
        XSAVE STX, 
        506 JSR, 
        HERE 8 + JSR, 
        XSAVE LDX, 
        NEXT JMP, 
        0C ) JMP, 
        C; 
: GETR: 
        HERE 2E7 ! ( SET MEMLO ) 
        FLUSH EMPTY-BUFFERS 150 300 ! ( DDEVIC,DUNIT) 
        403F 302 ! ( ? CMD,EXPECT DATA) 
        5 306 C! ( TIMEOUT) 
        500 304 ! ( BUFFER ADDR) 
        0C 308 ! ( LENGTH ) 
        0 30A ! ( AUXES ) 
        0 SIO SERR ( ERRORS?) 
        500 300 0C CMOVE 0 SIO SERR DORL ( RUN RELOCATOR ) 
        2E7 @ HERE - ALLOT HERE FENCE ! 
        ; 
--> 

* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * 

SCR #  2D 
00 ( RS232 ) 
01   
02 : R1: " R1: " DROP ; 
03   
04 : R1OPEN 0 8 R1: OPEN ICSTA CH? 
05 ; 
06 : RYPE -DUP IF 1 IOCB 0B ICCOM C 
07 !       ICBLL ! ICBAL ! CIO 
08   20 ICCOM C! 0 I1CAX ! CIO ELSE 
09         DROP THEN ; 
0A : CRR 0A9B SP@ 2 RYPE DROP ; 
0B       : REMIT SP@ 1 RYPE DROP ; 
0C : SET9600 1 IOCB 0E I1CAX ! 24 
0D         ICCOM C! R1: ICBAL ! 
0E   CIO ICSTA CH? ; 
0F   
10 : LINER SCR @ (LINE) -TRAILING 
11         RYPE ; 
12 100 VARIABLE LSPD 
13   
14 : LISTR DUP SCR ! CRR " SCR#" RY 
15 PE      0 <# #S #> RYPE CRR 10 0 
16   DO I 0 <# # # #> RYPE I LINER 
17         CRR LOOP ; 
18  ;S 
19   
1A   
1B   
1C   
1D   
1E   
1F   


( RS232 ) 
: R1: 
        " R1: " DROP 
        ; 
: R1OPEN 
        0 8 R1: OPEN ICSTA CH? 
        ; 
: RYPE 
        -DUP 
        IF 
          1 IOCB 0B ICCOM C! ICBLL ! ICBAL ! CIO 20 ICCOM C! 0 
          I1CAX ! CIO 
        ELSE 
          DROP 
        THEN 
        ; 
: CRR 
        0A9B SP@ 2 RYPE DROP 
        ; 
: REMIT 
        SP@ 1 RYPE DROP 
        ; 
: SET9600 
        1 IOCB 0E I1CAX ! 24 ICCOM C! R1: ICBAL ! CIO ICSTA CH? 
        ; 
: LINER 
        SCR @ (LINE) -TRAILING RYPE 
        ; 
100 VARIABLE LSPD 
: LISTR 
        DUP SCR ! CRR " SCR#" RYPE 0 <# #S #> RYPE CRR 10 0 
        DO 
          I 0 <# # # #> RYPE I LINER CRR 
        LOOP 
        ; 
;S 

}}}

'Screens'

{{{
SCR # 14 
  0 ( ERROR MESSAGES )
  1 Stack empty
  2 Dictionary full
  3 Wrong address mode
  4 Isn't unique
  5 Value error
  6 Disk address error
  7 Stack full
  8 Disk Error!
  9 
 10 
 11 
 12 
 13 
 14 
 15 

SCR # 15 
  0 ( ERROR MESSAGES )
  1 Use only in Definitions
  2 Execution only
  3 Conditionals not paired
  4 Definition not finished
  5 In protected dictionary
  6 Use only when loading
  7 Off current screen
  8 Declare VOCABULARY
  9 
 10 
 11 
 12 
 13 
 14 
 15 

SCR # 16 
  0 
  1 
  2 
  3 
  4 
  5 
  6 
  7 
  8 
  9 
 10 
 11 
 12 
 13 
 14 
 15 

SCR # 17 
  0 ( CASSETTE LOAD )
  1 
  2 
  3 
  4 ( LOAD DEBUG )
  5    21 LOAD
  6 
  7 ( LOAD ASSEMBLER )
  8    39 LOAD
  9 
 10 
 11 
 12 
 13 ;S
 14 
 15 

SCR # 18 
  0 ( FULL LOAD )
  1 
  2 
  3 
  4 ( LOAD DEBUG )
  5    21 LOAD
  6 
  7 ( LOAD EDITOR )
  8   27 LOAD
  9 
 10 ( LOAD ASSEMBLER )
 11    39 LOAD
 12 
 13 ;S
 14 
 15 

SCR # 19 
  0 
  1 
  2 
  3 
  4 
  5 
  6 
  7 
  8 
  9 
 10 
 11 
 12 
 13 
 14 
 15 

SCR # 20 
  0 ( ATARI FORTH DEFS )
  1     BASE @ HEX
  2 
  3 : PON    1 PFLAG ! ; ( PRT ON )
  4 : POFF   0 PFLAG ! ; ( PRT OFF )
  5 
  6 : BEEP  0C0 0 DO
  7    08 0D01F C! 6 0 DO LOOP
  8    00 0D01F C! 6 0 DO LOOP
  9    LOOP ;
 10 
 11 : ASCII BL WORD HERE 1+ C@
 12  STATE @ IF COMPILE CLIT C,
 13  THEN ;  IMMEDIATE
 14 
 15 BASE ! ;S

SCR # 21 
  0 ( DEBUGGER AIDS -- DUMP , CDUMP )
  1 
  2 BASE @ HEX
  3 
  4 
  5 
  6 
  7 
  8 : H. BASE @ HEX OVER U. BASE ! ;
  9 
 10 : B?   BASE @ DUP DECIMAL . BASE ! ;
 11 : FREE   2E5 @ HERE -  U. ." bytes" CR ;
 12 
 13 
 14 -->
 15 

SCR # 22 
  0 ( DEBUGGER AIDS -- DUMP , CDUMP )
  1     DECIMAL
  2 : ?EXIT  ?TERMINAL
  3          IF LEAVE ENDIF ;
  4 : U.R    0 SWAP D.R ;
  5 : LDMP  DUP 8 + SWAP DO I C@ 4 .R
  6          LOOP ;
  7 : DUMP   OVER + SWAP DO CR I 5 U.R I
  8          LDMP ?EXIT 8 +LOOP CR ;
  9 : CDMP   DUP 16 + SWAP DO
 10          I C@ EMIT LOOP ;
 11  HEX
 12 : CDUMP   OVER + SWAP DO CR I 5 U.R I
 13       SPACE 1 2FE C! CDMP 0 2FE C!
 14        ?EXIT 10 +LOOP CR ;
 15  DECIMAL -->

SCR # 23 
  0 ( STACK PRINTER )
  1 
  2 HEX
  3 
  4 : DEPTH SP@ 12 +ORIGIN @ SWAP - 2 / ;
  5 : S.  ( PRINTS THE STACK )
  6    DEPTH -DUP IF
  7       0 DO  CR  ." TOP+" I .
  8       SP@ I 2 * + @ U. LOOP
  9    ELSE ." Stack Empty" THEN CR ;
 10 
 11 
 12 
 13 BASE !
 14 
 15 -->

SCR # 24 
  0 ( DEFINITION TRACER )
  1      BASE @ HEX
  2 0 VARIABLE .WORD
  3 ' CLIT CFA CONSTANT .CLIT
  4 ' 0BRANCH CFA CONSTANT ZBRAN
  5 ' BRANCH CFA CONSTANT BRAN
  6 ' ;S CFA CONSTANT SEMIS
  7 ' (LOOP) CFA CONSTANT PLOOP
  8 ' (+LOOP) CFA CONSTANT PPLOOP
  9 ' (.") CFA CONSTANT PDOTQ
 10 : PWORD 2+ NFA ID.  ;
 11 : 1BYTE  PWORD .WORD @ C@ . 1 .WORD +! ;
 12 : 1WORD PWORD .WORD @ @  . 2 .WORD +! ;
 13 : NP DUP SEMIS = IF PWORD CR CR
 14     PROMPT QUIT THEN ?TERMINAL IF
 15      PROMPT QUIT THEN ;    -->

SCR # 25 
  0 ( DEFINITION TRACER )
  1 
  2 : BRNCH PWORD ." to " .WORD @ .WORD @ @ + . 2 .WORD +! ;
  3 
  4 : STG  PWORD 22 EMIT .WORD @   DUP COUNT TYPE 22 EMIT
  5    C@ .WORD @ + 1+ .WORD ! ;
  6 
  7 ' LIT CFA CONSTANT .LIT
  8 
  9 : CKIT DUP ZBRAN = OVER BRAN =
 10  OR OVER PLOOP = OR OVER PPLOOP =
 11 OR IF BRNCH ELSE DUP .LIT =
 12 IF 1WORD ELSE DUP .CLIT =
 13  IF 1BYTE ELSE DUP PDOTQ = IF STG
 14  ELSE PWORD THEN THEN THEN THEN ;
 15 -->

SCR # 26 
  0 ( DEFINITION TRACER )
  1     ' : 12 + CONSTANT DOCOL
  2 
  3 : T?PR CR CR ." Primitive" CR CR ;
  4 : ?DOCOL DUP 2 - @ DOCOL -  IF
  5   T?PR PROMPT QUIT THEN ;
  6 
  7 : .SETUP ~[COMPILE] ' ?DOCOL .WORD ! ;
  8 
  9 : NXT1  .WORD @ U. 2 SPACES .WORD
 10     @ @ 2 .WORD +! ;
 11 
 12 : DECOMP .SETUP CR CR BEGIN NXT1 NP
 13       CKIT CR AGAIN ;
 14 
 15 BASE !     ;S

SCR # 27 
  0 ( ** EDITOR ** )
  1 
  2  BASE @  HEX
  3 
  4 ( THIS EDITOR IS PATTERNED AFTER
  5 ( THE EXAMPLE EDITOR IN THE fig
  6 ( "INSTALLATION MANUAL" 8/80 WFR
  7 
  8 : TEXT HERE C/L 1+ BLANKS WORD
  9        HERE PAD C/L 1+ CMOVE ;
 10 
 11 : LINE DUP FFF0 AND 17 ?ERROR SCR
 12        @ (LINE) DROP ;
 13 
 14 : MARK  10 0 DO I LINE UPDATE
 15     DROP LOOP ;        -->

SCR # 28 
  0 ( EDITOR )
  1 VOCABULARY EDITOR IMMEDIATE
  2 : WHERE DUP B/SCR / DUP SCR ! ." SCR # " DECIMAL .
  3 SWAP C/L /MOD C/L * ROT BLOCK + CR C/L -TRAILING TYPE CR HERE
  4 C@ - SPACES 1 2FE C! 1C EMIT 0 2FE C! ~[COMPILE] EDITOR QUIT ;
  5 
  6 EDITOR DEFINITIONS
  7 
  8 : #LOCATE R# @ C/L /MOD ;
  9 : #LEAD #LOCATE LINE SWAP ;
 10 : #LAG  #LEAD DUP >R + C/L R> - ;
 11 
 12 
 13 : -MOVE LINE C/L CMOVE UPDATE ;
 14 
 15 -->

SCR # 29 
  0 ( EDITOR )
  1 : H LINE PAD 1+ C/L DUP PAD C!
  2      CMOVE ;
  3 : E LINE C/L BLANKS UPDATE ;
  4 : S DUP 1 - 0E DO I LINE I 1+
  5     -MOVE -1 +LOOP E ;
  6 : D DUP H 0F DUP ROT
  7     DO I 1+ LINE I -MOVE LOOP E ;
  8 
  9 
 10    -->
 11 
 12 
 13 
 14 
 15 

SCR # 30 
  0 ( EDITOR )
  1 
  2 : M   R# +! CR SPACE #LEAD TYPE
  3       17 EMIT #LAG TYPE #LOCATE
  4       . DROP ;
  5 : T   DUP C/L * R# ! DUP H 0 M ;
  6 : L   SCR @ LIST 0 M ;
  7 : R   PAD 1+ SWAP -MOVE ;
  8 : P   1 TEXT R ;
  9 : I   DUP S R ;
 10 : TOP   0 R# ! ;
 11 
 12 
 13   -->
 14 
 15 

SCR # 31 
  0 ( EDITOR )
  1 
  2 
  3 : CLEAR  SCR ! 10 0 DO FORTH I
  4          EDITOR E LOOP ;
  5 
  6 
  7 
  8 
  9 
 10 : COPY   B/SCR * OFFSET @ + SWAP
 11          B/SCR * B/SCR OVER +
 12          SWAP DO DUP FORTH I
 13          BLOCK 2 - ! 1+ UPDATE
 14          LOOP DROP FLUSH ;
 15   -->

SCR # 32 
  0 ( EDITOR )
  1 
  2 : 1LINE   #LAG PAD COUNT MATCH R#
  3           +! ;
  4 
  5 
  6 : FIND   BEGIN 3FF R# @ < IF TOP
  7          PAD HERE C/L 1+ CMOVE 0
  8          ERROR ENDIF 1LINE UNTIL
  9          ;
 10 
 11 : DELETE   >R #LAG + FORTH R -
 12        #LAG R MINUS R# +! #LEAD
 13        + SWAP CMOVE R> BLANKS
 14        UPDATE ;
 15 -->

SCR # 33 
  0 ( EDITOR )
  1 
  2 : N   FIND 0 M ;
  3 
  4 : F   1 TEXT N ;
  5 
  6 : B   PAD C@ MINUS M ;
  7 
  8 : X   1 TEXT FIND PAD C@ DELETE
  9       0 M ;
 10 
 11 : TILL   #LEAD + 1 TEXT 1LINE 0=
 12          0 ?ERROR #LEAD + SWAP -
 13          DELETE 0 M ;
 14 
 15 -->

SCR # 34 
  0 ( END OF EDITOR )
  1 
  2 : C   1 TEXT PAD COUNT #LAG ROT
  3       OVER MIN >R FORTH R R# +!
  4       R - >R DUP HERE R CMOVE
  5       HERE #LEAD + R> CMOVE R>
  6       CMOVE UPDATE 0 M ;
  7 
  8 
  9 FORTH DEFINITIONS DECIMAL
 10 
 11 LATEST 12 +ORIGIN !
 12 HERE 28 +ORIGIN !
 13 HERE 30 +ORIGIN !
 14 ' EDITOR 6 + 32 +ORIGIN !
 15 HERE FENCE !    BASE !    ;S

SCR # 35 
  0 
  1 
  2 
  3 
  4 
  5 
  6 
  7 
  8 
  9 
 10 
 11 
 12 
 13 
 14 
 15 

SCR # 36 
  0 ( DISK COPY ROUTINE  32K RAM )
  1 
  2    BASE @ DECIMAL
  3 16384 CONSTANT BUFHEAD
  4 0 VARIABLE BLK#  0 VARIABLE ADRS
  5 : GET   ADRS @ BLK# @ ;
  6 : RD    GET DUP 718 = IF LEAVE THEN 1 R/W ;
  7 : WRT   GET DUP 718  = IF LEAVE THEN  0 R/W ;
  8 : +BLK  1 BLK# +!  128 ADRS +! ;
  9 : DSETUP   BLK# ! BUFHEAD ADRS ! ;
 10 : GKEY ." HIT ANY KEY "  KEY CR DROP ;
 11 : RDIN  CR ." Insert SOURCE disk  "  GKEY DSETUP
 12 90 0 DO RD +BLK  LOOP ;
 13 : WRTO  CR ." Insert DESTINATION disk  "  GKEY DSETUP
 14 90 0 DO WRT +BLK  LOOP ;
 15 -->

SCR # 37 
  0 ( DISK COPY ROUTINE )
  1 
  2 ( INSERT SOURCE DISK IN DRIVE #1
  3 
  4 ( SIMPLY TYPE  "DISKCOPY" !
  5 
  6 : MS1 CR CR
  7 ." SINGLE-DRIVE DISK COPY" CR CR ;
  8 
  9 
 10 : %COPY      0 DO I 90 *
 11              DUP DUP RDIN WRTO
 12              90 +  . LOOP ;
 13 : DISKCOPY   CR MS1 CR 8 %COPY ;
 14 
 15 BASE !   ;S

SCR # 38 
  0 
  1 
  2 
  3 
  4 
  5 
  6 
  7 
  8 
  9 
 10 
 11 
 12 
 13 
 14 
 15 

SCR # 39 
  0 ( ** ASSEMBLER **   IN FORTH )
  1 
  2 (  ASSEMBLER COMFORMS TO THE
  3 ( fig "INSTALLATION GUIDE" WITH
  4 ( THE FOLLOWING EXCEPTIONS:
  5 
  6 (  SHIFTS ARE: "XXX.A" FOR A-REG.
  7 ( SHIFTS.
  8 (  CONDITIONAL BRANCHES ARE
  9 (  PATTERNED AFTER THE BRANCH OP-
 10 (  CODES:   "IFEQ," IS USED IN-
 11 ( STEAD OF "0= IF," FOR BETTER
 12 ( CLARITY.  SEE SCREEN 43.
 13 
 14 
 15 -->

SCR # 40 
  0 ( ASSEMBLER )
  1 
  2 VOCABULARY ASSEMBLER IMMEDIATE
  3 
  4 BASE @  HEX
  5 
  6 : CODE  ~[COMPILE] ASSEMBLER
  7         CREATE SMUDGE ;
  8 
  9 ASSEMBLER DEFINITIONS
 10 
 11 : SB  <BUILDS C, DOES> @ C, ;
 12       ( SINGLE BYTE OPERATORS)
 13 
 14 
 15 -->

SCR # 41 
  0 ( ASSEMBLER )
  1 
  2 00 SB BRK, 18 SB CLC, D8 SB CLD,
  3 58 SB CLI, B8 SB CLV, CA SB DEX,
  4 88 SB DEY, E8 SB INX, C8 SB INY,
  5 EA SB NOP, 48 SB PHA, 08 SB PHP,
  6 68 SB PLA, 28 SB PLP, 40 SB RTI,
  7 60 SB RTS, 38 SB SEC, F8 SB SED,
  8 78 SB SEI, A8 SB TAX, BA SB TSX,
  9 8A SB TXA, 9A SB TXS, 98 SB TYA,
 10 
 11 0A SB ASL.A,   2A SB ROL.A,
 12 4A SB LSR.A,   6A SB ROR.A,
 13 
 14 : NOT  0= ;  ( REVERSE LOGICAL )
 15 : 0=  1 ; ( PUSH A TRUE )  -->

SCR # 42 
  0 ( ASSEMBLER )
  1 
  2 : 3BY  <BUILDS C, DOES> @ C, , ;
  3 
  4 4C 3BY JMP,   6C 3BY JMP(),
  5 20 3BY JSR,
  6 
  7 : ?ER5    5 ?ERROR ;
  8 
  9 : IF.  <BUILDS C, DOES> C@ C, 0
 10         C, HERE ;
 11 : THEN,   DUP HERE SWAP - DUP
 12         7F > ?ER5 DUP -80 < ?ER5
 13   SWAP -1 + C! ;  IMMEDIATE
 14 : ENDIF, ~[COMPILE] THEN, ; IMMEDIATE
 15 -->

SCR # 43 
  0 ( ASSEMBLER )
  1 
  2 30 IF. IFPL,  ( BPL )
  3 10 IF. IFMI,  ( BMI )
  4 70 IF. IFVC,  ( BVC )
  5 50 IF. IFVS,  ( BVS )
  6 B0 IF. IFCC,  ( BCC )
  7 90 IF. IFCS,  ( BCS )
  8 F0 IF. IFNE,  ( BNE )
  9 D0 IF. IFEQ,  ( BEQ )
 10 
 11 : BEGIN,   HERE ; IMMEDIATE
 12 : END,   IF D0 ELSE F0 THEN  C,
 13          HERE 1+ - DUP
 14         -80 < ?ER5 C, ; IMMEDIATE
 15 : UNTIL,  ~[COMPILE]  END,  ; IMMEDIATE        -->

SCR # 44 
  0 ( ASSEMBLER )
  1 
  2 0D VARIABLE MODE ( ABS. MODE )
  3 
  4 : MODE=   MODE @ = ; ( CK MODE )
  5 : 256<   DUP 100 ( HEX) U< ;
  6 : MODEFIX  256< IF -08 MODE +!
  7            THEN ;
  8      ( MODE=MODE-8 IF ADR<256 )
  9 : CKMODE   MODE= IF MODEFIX
 10                  THEN ;
 11 : M0 <BUILDS C, DOES> SWAP
 12      0D CKMODE  1D CKMODE SWAP
 13      C@ MODE @ OR C,    256< IF
 14      C, ELSE , THEN 0D MODE ! ;
 15  DECIMAL  46 LOAD    ;S

SCR # 45 
  0 B jDISKNAMEDAT                                                
  1                                                                
  2 APX-20029fig-FORTH 1.1 Rev. 2.0Patrick L. Mullarky01/15/821
  3                                                                J
  4 
  5 
  6 
  7 
  8 
  9 
 10 
 11 
 12 
 13 
 14 
 15 

SCR # 46 
  0 ( ASSEMBLER )
  1     HEX
  2 : X)  01 MODE ! ;   ( ~[ADDR,X]  )
  3 : #   09 MODE ! ;   ( IMMEDIATE )
  4 : )Y  11 MODE ! ;   ( ~[ADDR],Y  )
  5 : ,X  1D MODE ! ;   ( ADDR,X    )
  6 : ,Y  19 MODE ! ;   ( ADDR,Y    )
  7 
  8 
  9 00 M0 ORA, 20 M0 AND, 40 M0 EOR,
 10 60 M0 ADC, 80 M0 STA, A0 M0 LDA,
 11 C0 M0 CMP, E0 M0 SBC,
 12 
 13 : BIT,   256< IF 24 C, C, ELSE
 14          2C C, , THEN ;
 15 -->

SCR # 47 
  0 ( ASSEMBLER )
  1 
  2 : STOREADD  C, 256<  IF C, ELSE ,
  3             THEN 0D MODE ! ;
  4 
  5 : ZPAGE      OVER 100 < IF F7 AND
  6              THEN  ;
  7 : XYMODE  MODE @ 19 = MODE @ 1D
  8           = OR ;
  9 : M1  <BUILDS C, DOES> C@ MODE @
 10       1D = IF 10 ELSE 0 THEN OR
 11       ZPAGE STOREADD ;
 12 
 13 0E M1 ASL, 2E M1 ROL, 4E M1 LSR,
 14 6E M1 ROR, CE M1 DEC, EE M1 INC,
 15 -->

SCR # 48 
  0 ( ASSEMBLER )
  1 
  2 : OPCODE  C@ ZPAGE XYMODE IF 10
  3           OR THEN ;
  4 : M2  <BUILDS C, DOES> OPCODE
  5       MODE @ 9 = IF 4 - THEN
  6       STOREADD ;
  7 
  8 AC M2 LDY,   AE M2 LDX,
  9 CC M2 CPY,   EC M2 CPX,
 10 
 11 : M3    <BUILDS C, DOES> OPCODE
 12         STOREADD ;
 13 
 14 8C M3 STY,    8E M3 STX,
 15 -->

SCR # 49 
  0 ( END OF ASSEMBLER )
  1 
  2 FORTH DEFINITIONS
  3 
  4 
  5 LATEST 0C +ORIGIN !  ( NTOP )
  6 
  7 HERE   1C +ORIGIN !  ( FENCE )
  8 
  9 HERE   1E +ORIGIN !  ( DP )
 10 
 11 
 12 
 13 
 14 
 15 BASE !      ;S

SCR # 50 
  0 ( COLOR COMMANDS )
  1 BASE @ HEX
  2 : SETCOLOR  2 * SWAP 10 * OR SWAP
  3           02C4 ( COLPF0 ) + C! ;
  4 : SE.  SETCOLOR ;  ( ALIAS )
  5 
  6 (  REGISTER#-3, COLOR-2, LUM-1
  7 
  8 (    0-3          0-F     0-7
  9 
 10 -->
 11 
 12 
 13 
 14 
 15 

SCR # 51 
  0 ( GRAPHICS COMMANDS )
  1 E456 CONSTANT CIO
  2   1C VARIABLE MASK
  3  340 CONSTANT IOCX
  4   53 VARIABLE SNAME
  5 
  6 CODE GR.  1 # LDA,  GFLAG STA,
  7          XSAVE STX,    0 ,X LDA,
  8  # 30 LDX,     IOCX 0B + ,X STA,
  9 # 3 LDA,  IOCX 2 + ,X STA,
 10 SNAME FF AND # LDA,  IOCX 4 + ,X
 11  STA,   SNAME 100 / # LDA,
 12 IOCX 5 + ,X STA,   MASK LDA,
 13 IOCX 0A + ,X STA,    CIO JSR,
 14 XSAVE LDX,   0 # LDY,  POP JMP,
 15 -->

SCR # 52 
  0 ( GRAPHICS COMMANDS )
  1 
  2 CODE &GR     XSAVE STX, # 30 LDX,
  3              # C LDA,  IOCX 2 +
  4              ,X STA,   CIO JSR,
  5              XSAVE LDX, 0 # LDA,
  6              GFLAG STA, NEXT JMP,
  7 
  8 : XGR  &GR  0 GR.  &GR ;
  9   ( EXIT GRAPHICS MODE )
 10 
 11 -->
 12 
 13 
 14 
 15 

SCR # 53 
  0 ( GRAPHICS I/O )
  1 
  2 CODE CPUT   0 ,X LDA,  PHA,
  3   XSAVE STX,  # 30 LDX,
  4   # B LDA,  IOCX 2 + ,X STA, TYA,
  5   IOCX 8 + ,X STA, IOCX 9 + ,X
  6   STA, PLA,  CIO JSR,  XSAVE LDX,
  7   POP JMP,
  8 
  9 54 CONSTANT ROWCRS
 10 55 CONSTANT COLCRS
 11 
 12 : POS  ROWCRS C! COLCRS ! ;
 13 : PLOT   POS CPUT ;
 14 
 15 -->

SCR # 54 
  0 ( GRAPHICS I/O )
  1 
  2 : GTYPE  -DUP IF OVER + SWAP
  3         DO I C@ CPUT LOOP ELSE
  4         DROP ENDIF ;
  5 
  6 : (G")  R COUNT DUP 1+ R> + >R
  7         GTYPE ;
  8 
  9 : G"  22 STATE @ IF COMPILE (G")
 10       WORD HERE C@ 1+ ALLOT
 11      ELSE WORD HERE COUNT GTYPE
 12      ENDIF  ; IMMEDIATE
 13 
 14 
 15 -->

SCR # 55 
  0 ( DRAW, FIL )
  1 
  2 2FB CONSTANT ATACHR
  3 2FD CONSTANT FILDAT
  4 
  5 CODE GCOM    XSAVE STX, 0 ,X LDA,
  6    # 30 LDX,  IOCX 2 + ,X STA,
  7    CIO JSR,  XSAVE LDX, POP JMP,
  8 
  9 : DRAW   POS ATACHR C! 11 GCOM ;
 10 
 11 : FIL  FILDAT C!  12 GCOM ;
 12 
 13 
 14 BASE ! ;S
 15 

SCR # 56 
  0 ( SOUND COMMANDS )
  1     BASE @ HEX
  2 
  3 D208 CONSTANT AUDCTL
  4 D200 CONSTANT AUDBASE
  5 
  6 : SOUND  ( CH# FREQ DIST VOL --- )
  7   3 DUP 0D20F C! 232 C!
  8   SWAP 16 * + ROT DUP + AUDBASE +
  9     ROT OVER C! 1+ C! ;
 10 
 11 : FILTER!  AUDCTL C! ;
 12    ( N --- )
 13 
 14 
 15 BASE ! ;S

SCR # 57 
  0 ( GRAPHICS TESTS )
  1 
  2 : BOX  0 10 10 PLOT  1 50 10 DRAW
  3        1 50 25 DRAW  1 10 25 DRAW
  4        1 10 10 DRAW ;
  5 
  6 : FBOX  XGR   5 GR.   BOX
  7       10 25 POS  2 FIL ;
  8 
  9 
 10 
 11 
 12 
 13 
 14 
 15 

SCR # 58 
  0 ( DOS OBJECT READER )
  1 
  2 BASE @ HEX
  3 
  4 0 VARIABLE BLOCK#  0 VARIABLE BYTES  0 VARIABLE BYTPTR
  5 0 VARIABLE ADDRSS  0 VARIABLE #BYTES
  6 : GETCOUNT  7F + C@ 7F AND  BYTES ! 0 BYTPTR ! ;
  7 : FNEXTBLK  7D + DUP C@ 100 * SWAP 1+ C@ + 3FF AND 1 - ;
  8 : LINKBLOCK  FNEXTBLK
  9   DUP BLOCK# ! DUP 0 > IF BLOCK THEN ;
 10 : BLK-CK  BYTES @ 0= IF BLOCK# @ BLOCK LINKBLOCK
 11   GETCOUNT THEN ;
 12 : NEXTBYTE  BLK-CK -1 BYTES +! BYTPTR @ 1 BYTPTR +!
 13 BLOCK# @ BLOCK + C@ ;
 14 : NEXTWORD  NEXTBYTE NEXTBYTE 100 * + ;
 15 -->

SCR # 59 
  0 ( DOS OBJECT READER )
  1 
  2 : ADRCALC  NEXTWORD DUP ADDRSS ! NEXTWORD SWAP - 1+  #BYTES ! ;
  3 
  4 : BLOCKSET  DUP BLOCK# ! BLOCK GETCOUNT ;
  5 
  6 : LOADOBJ  BLOCKSET  NEXTWORD 1+ IF CR ." Not an Object file"
  7  CR QUIT THEN
  8     BEGIN
  9          ADRCALC
 10         #BYTES @ 0 DO NEXTBYTE ADDRSS @ C! 1 ADDRSS +! LOOP
 11         BLOCK# @ BLOCK FNEXTBLK
 12    1+ 0= BYTES @ 0= AND   END ;
 13 
 14 
 15 BASE ! ;S

SCR # 60 
  0 ( FLOATING POINT WORDS )
  1  BASE @  HEX
  2 : FDROP   DROP DROP DROP ;
  3 : FDUP    >R >R DUP R> DUP ROT
  4           SWAP R ROT ROT R> ;
  5 CODE FSWAP
  6   XSAVE STX, # 6 LDY,
  7 BEGIN,  0 ,X LDA, PHA, INX, DEY,
  8 0= END, XSAVE LDX,  # 6 LDY,
  9 BEGIN, 6 ,X LDA,  0 ,X STA, INX,
 10 DEY, 0= END, XSAVE LDX,  # 6 LDY,
 11  BEGIN, PLA, 0B ,X STA, DEX, DEY,
 12 0= END,   XSAVE LDX,  NEXT JMP,
 13 
 14 XSAVE 100 * 86 + CONSTANT XSAV
 15 : XS,   XSAV ,  ;       -->

SCR # 61 
  0 ( FLOATING POINT WORDS )
  1 CODE FOVER     DEX, DEX, DEX,
  2  DEX, DEX, DEX, XSAVE STX,
  3  # 6 LDY,  BEGIN,  0C ,X LDA,
  4  0 ,X STA, INX, DEY, 0= END,
  5  XSAVE LDX,  NEXT JMP,
  6 
  7 XSAVE 100 * A6 + CONSTANT XLD
  8 : XL,   XLD  ,  ;
  9 
 10 CODE AFP   XS, D800 JSR, XL, NEXT JMP,
 11 CODE FASC  XS, D8E6 JSR, XL, NEXT JMP,
 12 CODE IFP   XS, D9AA JSR, XL, NEXT JMP,    -->
 13 
 14 
 15 

SCR # 62 
  0 ( FLOATING POINT WORDS )
  1 
  2 CODE FPI   XS, D9D2 JSR, XL, NEXT JMP,
  3 CODE FADD  XS, DA66 JSR, XL, NEXT JMP,
  4 CODE FSUB  XS, DA60 JSR, XL, NEXT JMP,
  5 CODE FMUL  XS, DADB JSR, XL, NEXT JMP,
  6 CODE FDIV  XS, DB28 JSR, XL, NEXT JMP,
  7 CODE FLG  XS, DECD JSR, XL, NEXT JMP,
  8 CODE FLG10 XS, DED1 JSR, XL, NEXT JMP,
  9 CODE FEX  XS, DDC0 JSR, XL, NEXT JMP,
 10 CODE FEX10 XS, DDCC JSR, XL, NEXT JMP,
 11 CODE FPOLY XS, DD40 JSR, XL, NEXT JMP,
 12   -->
 13 
 14 
 15 

SCR # 63 
  0 ( FLOATING POINT WORDS )
  1 
  2 D4 CONSTANT FR0
  3 E0 CONSTANT FR1
  4 FC CONSTANT FLPTR
  5 F3 CONSTANT INBUF
  6 F2 CONSTANT CIX
  7 
  8 -->
  9 
 10 
 11 
 12 
 13 
 14 
 15 


}}}