1
0
mirror of https://github.com/hsoft/collapseos.git synced 2024-11-20 20:28:06 +11:00
collapseos/apps/zasm/directive.asm

160 lines
2.6 KiB
NASM
Raw Normal View History

2019-05-01 11:40:22 +10:00
; *** CONSTS ***
.equ D_DB 0x00
.equ D_DW 0x01
2019-05-12 12:11:05 +10:00
.equ D_EQU 0x02
2019-05-20 03:22:14 +10:00
.equ D_ORG 0x03
2019-05-20 22:20:00 +10:00
.equ D_FIL 0x04
.equ D_INC 0x05
.equ D_BAD 0xff
2019-05-01 11:40:22 +10:00
2019-05-12 12:11:05 +10:00
; *** Variables ***
.equ DIREC_SCRATCHPAD DIREC_RAMSTART
.equ DIREC_RAMEND DIREC_SCRATCHPAD+SCRATCHPAD_SIZE
2019-05-01 11:40:22 +10:00
; *** CODE ***
; 4 bytes per row, fill with zero
directiveNames:
.db ".DB", 0
.db ".DW", 0
2019-05-12 12:11:05 +10:00
.db ".EQU"
2019-05-20 03:22:14 +10:00
.db ".ORG"
2019-05-20 22:20:00 +10:00
.db ".FIL"
2019-05-17 11:15:00 +10:00
.db "#inc"
2019-05-01 11:40:22 +10:00
2019-05-02 01:26:41 +10:00
; This is a list of handlers corresponding to indexes in directiveNames
directiveHandlers:
.dw handleDB
.dw handleDW
2019-05-12 12:11:05 +10:00
.dw handleEQU
2019-05-20 03:22:14 +10:00
.dw handleORG
2019-05-20 22:20:00 +10:00
.dw handleFIL
2019-05-17 11:15:00 +10:00
.dw handleINC
2019-05-02 01:26:41 +10:00
handleDB:
push hl
.loop:
2019-05-02 01:26:41 +10:00
call readWord
ld hl, scratchpad
call enterDoubleQuotes
jr z, .stringLiteral
2019-05-18 07:21:49 +10:00
call parseExpr
push ix \ pop hl
ld a, l
2019-05-18 05:14:38 +10:00
call ioPutC
.stopStrLit:
call readComma
jr z, .loop
2019-05-02 01:26:41 +10:00
pop hl
ret
.stringLiteral:
ld a, (hl)
inc hl
or a ; when we encounter 0, that was what used to
jr z, .stopStrLit ; be our closing quote. Stop.
; Normal character, output
call ioPutC
jr .stringLiteral
2019-05-02 01:26:41 +10:00
handleDW:
push hl
.loop:
call readWord
ld hl, scratchpad
2019-05-15 05:26:29 +10:00
call parseExpr
2019-05-18 05:14:38 +10:00
push ix \ pop hl
ld a, l
call ioPutC
ld a, h
call ioPutC
call readComma
jr z, .loop
pop hl
ret
2019-05-02 01:26:41 +10:00
2019-05-12 12:11:05 +10:00
handleEQU:
push hl
push de
push bc
; Read our constant name
call readWord
; We can't register our symbol yet: we don't have our value!
; Let's copy it over.
ld de, DIREC_SCRATCHPAD
ld bc, SCRATCHPAD_SIZE
ldir
2019-05-12 12:11:05 +10:00
; Now, read the value associated to it
call readWord
ld hl, scratchpad
2019-05-15 05:26:29 +10:00
call parseExpr
2019-05-20 03:22:14 +10:00
jr nz, .end
2019-05-12 12:11:05 +10:00
ld hl, DIREC_SCRATCHPAD
push ix \ pop de
2019-05-12 12:11:05 +10:00
call symRegister
.end:
xor a ; 0 bytes written
pop bc
pop de
pop hl
ret
2019-05-20 03:22:14 +10:00
handleORG:
call readWord
call parseExpr
ret nz
push ix \ pop hl
jp zasmSetOrg
2019-05-20 22:20:00 +10:00
handleFIL:
call readWord
call parseExpr
ret nz
push bc
push ix \ pop bc
xor a
ld b, c
.loop:
call ioPutC
djnz .loop
pop bc
ret
2019-05-20 22:20:00 +10:00
2019-05-17 11:15:00 +10:00
handleINC:
call readWord
jr nz, .end
; HL points to scratchpad
call enterDoubleQuotes
2019-05-17 11:15:00 +10:00
jr nz, .end
call ioOpenInclude
.end:
xor a ; zero bytes written
ret
2019-05-01 11:40:22 +10:00
; Reads string in (HL) and returns the corresponding ID (D_*) in A. Sets Z if
; there's a match.
getDirectiveID:
push bc
push de
2019-05-17 11:15:00 +10:00
ld b, D_INC+1 ; D_INC is last
2019-05-01 11:40:22 +10:00
ld c, 4
ld de, directiveNames
call findStringInList
pop de
pop bc
ret
; Parse directive specified in A (D_* const) with args in I/O and act in
2019-05-02 01:26:41 +10:00
; an appropriate manner. If the directive results in writing data at its
2019-05-18 05:14:38 +10:00
; current location, that data is directly written through ioPutC.
2019-05-01 11:40:22 +10:00
parseDirective:
2019-05-02 01:26:41 +10:00
push de
; double A to have a proper offset in directiveHandlers
add a, a
ld de, directiveHandlers
call addDE
call intoDE
push de \ pop ix
2019-05-02 01:26:41 +10:00
pop de
jp (ix)