mirror of
https://github.com/A2osX/A2osX.git
synced 2024-11-29 02:49:54 +00:00
467 lines
7.8 KiB
Plaintext
467 lines
7.8 KiB
Plaintext
NEW
|
||
AUTO 3,1
|
||
*--------------------------------------
|
||
CP.JSRX lda #$20 JSR
|
||
jsr CP.Emit.Byte
|
||
lda I.KEYWORDS,x
|
||
jsr CP.Emit.Byte
|
||
lda I.KEYWORDS+1,x
|
||
jmp CP.Emit.Byte
|
||
*--------------------------------------
|
||
CP.ECOLON lda #$60 RTS
|
||
jsr CP.Emit.Byte
|
||
|
||
stz bCompile
|
||
|
||
clc
|
||
rts
|
||
*--------------------------------------
|
||
CP.INVALID lda #E.CSYN
|
||
sec
|
||
rts
|
||
*--------------------------------------
|
||
* : TEST ." hello" CR ;
|
||
*--------------------------------------
|
||
CP.PRINT ldy #$ff
|
||
|
||
.1 iny
|
||
lda (ZPCLBufPtr),y
|
||
|
||
beq CP.INVALID
|
||
cmp #'"'
|
||
beq .2
|
||
|
||
sta (ZPDataPtr),y
|
||
bra .1
|
||
|
||
.2 lda #0
|
||
sta (ZPDataPtr),y
|
||
|
||
phy
|
||
|
||
>LDYA ZPDataPtr
|
||
jsr CP.Emit.LDYAI
|
||
|
||
ldx #SYS.PutS
|
||
jsr CP.Emit.SYSCALL
|
||
|
||
pla
|
||
pha
|
||
sec skip "
|
||
adc ZPCLBufPtr
|
||
sta ZPCLBufPtr
|
||
bcc .3
|
||
|
||
inc ZPCLBufPtr+1
|
||
|
||
.3 pla
|
||
sec include \0
|
||
adc ZPDataPtr
|
||
sta ZPDataPtr
|
||
bcc .4
|
||
|
||
inc ZPDataPtr+1
|
||
|
||
.4
|
||
clc
|
||
rts
|
||
*--------------------------------------
|
||
CP.DO jsr CP.Emit.DO I,n -> RP
|
||
|
||
ldy RP
|
||
|
||
lda ZPCodePtr+1
|
||
sta (pData),y
|
||
dey
|
||
|
||
lda ZPCodePtr
|
||
sta (pData),y
|
||
dey push CodePtr=DOTEST on RP for LOOP/LEAVE
|
||
|
||
sty RP
|
||
|
||
jsr CP.Emit.DOTEST CODE: I < n ?
|
||
|
||
ldx #KW.DO.ID
|
||
jsr CP.Emit.JMP0000 to put jmp LOOPEND
|
||
|
||
clc
|
||
rts
|
||
*--------------------------------------
|
||
CP.LOOP lda #$00
|
||
jsr CP.Emit.PUSHBI >PUSHBI 0
|
||
|
||
lda #$01 >PUSHBI 1
|
||
jsr CP.Emit.PUSHBI
|
||
*--------------------------------------
|
||
CP.pLOOP ldy RP
|
||
iny
|
||
bmi .9
|
||
|
||
lda (pData),y
|
||
cmp #KW.DO.ID
|
||
bne .9
|
||
|
||
phy
|
||
jsr CP.Emit.LOOP CODE: I=I+n
|
||
ply
|
||
|
||
iny POP LOOPEND@ -> Ptr1
|
||
lda (pData),y
|
||
sta ZPPtr1
|
||
|
||
iny
|
||
lda (pData),y
|
||
sta ZPPtr1+1
|
||
|
||
jsr CP.Emit.JMPBack CODE: JMP to DOTEST
|
||
|
||
sty RP discard ID DOTEST@ LOOPEND@
|
||
|
||
jsr CP.UpdatePtr1 update JMP LOOPEND@ with CodePtr
|
||
|
||
jsr CP.Emit.LOOPEND
|
||
|
||
clc
|
||
rts
|
||
|
||
.9 lda #E.NODO
|
||
sec
|
||
rts
|
||
*--------------------------------------
|
||
CP.I jsr CP.Emit.I
|
||
clc
|
||
rts
|
||
*--------------------------------------
|
||
CP.LEAVE ldy RP
|
||
|
||
.1 iny
|
||
bmi .9
|
||
|
||
lda (pData),y
|
||
cmp #KW.DO.ID
|
||
beq .2
|
||
|
||
iny
|
||
iny
|
||
bpl .1 skip 3 bytes on RP
|
||
|
||
.9 lda #E.NODO
|
||
sec
|
||
rts
|
||
|
||
.2 phy
|
||
jsr CP.Emit.LEAVE set I = END on RP
|
||
ply
|
||
|
||
iny skip LOOPEND ptr
|
||
iny
|
||
|
||
jsr CP.Emit.JMPBack jmp DOTEST
|
||
|
||
clc
|
||
rts
|
||
*--------------------------------------
|
||
CP.IF jsr CP.Emit.TESTTRUE
|
||
ldx #KW.IF.ID
|
||
jsr CP.Emit.JMP0000 to put jmp -> ELSE/THEN later
|
||
|
||
clc
|
||
rts
|
||
*--------------------------------------
|
||
CP.ELSE jsr CP.PopCodePtr get previous JMP -> ptr1
|
||
ldx #KW.IF.ID
|
||
jsr CP.Emit.JMP0000 to put jmp -> THEN later
|
||
jsr CP.UpdatePtr1
|
||
|
||
clc
|
||
rts
|
||
*--------------------------------------
|
||
CP.THEN jsr CP.PopCodePtr
|
||
jsr CP.UpdatePtr1
|
||
|
||
clc
|
||
rts
|
||
*--------------------------------------
|
||
CP.BEGIN jsr CP.PushCodePtr X = BEGIN ID
|
||
|
||
clc
|
||
rts
|
||
*--------------------------------------
|
||
CP.UNTIL jsr CP.Emit.TESTFALSE
|
||
|
||
bra CP.WHILE.1
|
||
*--------------------------------------
|
||
CP.REPEAT ldy RP
|
||
iny
|
||
bmi CP.E.NOBEGIN
|
||
|
||
jsr CP.Emit.JMPBack
|
||
|
||
clc
|
||
rts
|
||
*--------------------------------------
|
||
CP.WHILE jsr CP.Emit.TESTTRUE
|
||
|
||
CP.WHILE.1 ldy RP
|
||
iny
|
||
bmi CP.E.NOBEGIN
|
||
|
||
jsr CP.Emit.JMPBack
|
||
jsr CP.Emit.RPDROP2
|
||
|
||
clc
|
||
rts
|
||
*--------------------------------------
|
||
CP.E.NOBEGIN lda #E.NOFOR
|
||
sec
|
||
rts
|
||
*--------------------------------------
|
||
KW.gR
|
||
*--------------------------------------
|
||
KW.Rg
|
||
*--------------------------------------
|
||
KW.R
|
||
lda #E.SYN
|
||
sec
|
||
rts
|
||
*--------------------------------------
|
||
CP.Emit.JMP0000 lda #$4C JMP
|
||
jsr CP.Emit.Byte
|
||
|
||
jsr CP.PushCodePtr
|
||
|
||
lda #0
|
||
jsr CP.Emit.Byte
|
||
jsr CP.Emit.Byte
|
||
|
||
rts
|
||
*--------------------------------------
|
||
CP.Emit.JMPBack lda #$4C JMP
|
||
jsr CP.Emit.Byte
|
||
|
||
iny
|
||
lda (pData),y
|
||
jsr CP.Emit.Byte
|
||
|
||
iny
|
||
lda (pData),y
|
||
jmp CP.Emit.Byte
|
||
*--------------------------------------
|
||
CP.Emit.RPDROP2 ldx #CODE.RPDROP2.L
|
||
ldy #0
|
||
|
||
.1 lda CODE.RPDROP2,y
|
||
jsr CP.Emit.Byte
|
||
iny
|
||
dex
|
||
bne .1
|
||
|
||
rts
|
||
*--------------------------------------
|
||
CP.Emit.TESTTRUE
|
||
ldx #CODE.TESTTRUE.L
|
||
ldy #0
|
||
|
||
.1 lda CODE.TESTTRUE,y
|
||
jsr CP.Emit.Byte
|
||
iny
|
||
dex
|
||
bne .1
|
||
|
||
rts
|
||
*--------------------------------------
|
||
CP.Emit.TESTFALSE
|
||
ldx #CODE.TESTFALSE.L
|
||
ldy #0
|
||
|
||
.1 lda CODE.TESTFALSE,y
|
||
jsr CP.Emit.Byte
|
||
iny
|
||
dex
|
||
bne .1
|
||
|
||
rts
|
||
*--------------------------------------
|
||
CP.Emit.PULLA ldx #CODE.PULLA.L
|
||
ldy #0
|
||
|
||
.1 lda CODE.PULLA,y
|
||
jsr CP.Emit.Byte
|
||
iny
|
||
dex
|
||
bne .1
|
||
|
||
rts
|
||
*--------------------------------------
|
||
CP.Emit.PUSHBI pha
|
||
lda #$A9 lda #imm
|
||
jsr CP.Emit.Byte
|
||
pla
|
||
jsr CP.Emit.Byte
|
||
*--------------------------------------
|
||
CP.Emit.PUSHA ldx #CODE.PUSHA.L
|
||
ldy #0
|
||
|
||
.1 lda CODE.PUSHA,y
|
||
jsr CP.Emit.Byte
|
||
iny
|
||
dex
|
||
bne .1
|
||
|
||
rts
|
||
*--------------------------------------
|
||
CP.Emit.DO ldx #CODE.DO.L
|
||
ldy #0
|
||
|
||
.1 lda CODE.DO,y
|
||
jsr CP.Emit.Byte
|
||
iny
|
||
dex
|
||
bne .1
|
||
|
||
rts
|
||
*--------------------------------------
|
||
CP.Emit.DOTEST ldx #CODE.DOTEST.L
|
||
ldy #0
|
||
|
||
.1 lda CODE.DOTEST,y
|
||
jsr CP.Emit.Byte
|
||
iny
|
||
dex
|
||
bne .1
|
||
|
||
rts
|
||
*--------------------------------------
|
||
CP.Emit.LOOP ldx #CODE.LOOP.L
|
||
ldy #0
|
||
|
||
.1 lda CODE.LOOP,y
|
||
jsr CP.Emit.Byte
|
||
iny
|
||
dex
|
||
bne .1
|
||
|
||
rts
|
||
*--------------------------------------
|
||
CP.Emit.LOOPEND ldx #CODE.LOOPEND.L
|
||
ldy #0
|
||
|
||
.1 lda CODE.LOOPEND,y
|
||
jsr CP.Emit.Byte
|
||
iny
|
||
dex
|
||
bne .1
|
||
|
||
rts
|
||
*--------------------------------------
|
||
CP.Emit.I ldx #CODE.I.L
|
||
ldy #0
|
||
|
||
.1 lda CODE.I,y
|
||
jsr CP.Emit.Byte
|
||
iny
|
||
dex
|
||
bne .1
|
||
|
||
rts
|
||
*--------------------------------------
|
||
CP.Emit.LEAVE ldx #CODE.LEAVE.L
|
||
ldy #0
|
||
|
||
.1 lda CODE.LEAVE,y
|
||
jsr CP.Emit.Byte
|
||
iny
|
||
dex
|
||
bne .1
|
||
|
||
rts
|
||
*--------------------------------------
|
||
CP.Emit.LDYAI pha
|
||
lda #$A0 LDY #imm
|
||
jsr CP.Emit.Byte
|
||
tya
|
||
jsr CP.Emit.Byte
|
||
|
||
lda #$A9 LDA #imm
|
||
jsr CP.Emit.Byte
|
||
pla
|
||
jmp CP.Emit.Byte
|
||
*--------------------------------------
|
||
CP.Emit.SYSCALL lda #$A2 LDX #imm
|
||
jsr CP.Emit.Byte
|
||
txa
|
||
jsr CP.Emit.Byte
|
||
lda #$20 JSR
|
||
jsr CP.Emit.Byte
|
||
lda #A2osX.SYSCALL
|
||
jsr CP.Emit.Byte
|
||
lda /A2osX.SYSCALL
|
||
jmp CP.Emit.Byte
|
||
*--------------------------------------
|
||
CP.Emit.JsrYA pha
|
||
lda #$20
|
||
jsr CP.Emit.Byte
|
||
tya
|
||
jsr CP.Emit.Byte
|
||
pla
|
||
*--------------------------------------
|
||
CP.Emit.Byte sta (ZPCodePtr)
|
||
inc ZPCodePtr
|
||
bne .8
|
||
inc ZPCodePtr+1
|
||
.8 rts
|
||
*--------------------------------------
|
||
CP.PushCodePtr ldy RP
|
||
|
||
lda ZPCodePtr+1
|
||
sta (pData),y
|
||
dey
|
||
|
||
lda ZPCodePtr
|
||
sta (pData),y
|
||
dey
|
||
|
||
txa
|
||
sta (pData),y
|
||
dey
|
||
|
||
sty RP
|
||
rts
|
||
*--------------------------------------
|
||
CP.PopCodePtr ldy RP
|
||
iny
|
||
lda (pData),y
|
||
cmp #KW.IF.ID
|
||
bne .9
|
||
|
||
iny
|
||
lda (pData),y
|
||
sta ZPPtr1
|
||
|
||
iny
|
||
lda (pData),y
|
||
sta ZPPtr1+1
|
||
|
||
sty RP
|
||
|
||
clc
|
||
rts
|
||
|
||
.9 lda #E.NOIF
|
||
sec
|
||
rts
|
||
*--------------------------------------
|
||
CP.UpdatePtr1 lda ZPCodePtr
|
||
sta (ZPPtr1)
|
||
|
||
ldy #1
|
||
lda ZPCodePtr+1
|
||
sta (ZPPtr1),y
|
||
rts
|
||
*--------------------------------------
|
||
MAN
|
||
SAVE usr/src/bin/forth.s.cp
|
||
LOAD usr/src/bin/forth.s
|
||
ASM
|