From 6772a791a67e1f2f704c3ef5ea84b1da3bd4794a Mon Sep 17 00:00:00 2001 From: Peter Ferrie Date: Thu, 14 Jun 2018 17:17:43 -0700 Subject: [PATCH] parse Z4 saves, standardise, cleanup --- Makefile | 2 + src/onbeyond/onbeyond.system.s | 8 +- src/zinfo/z1/z1.s | 39 +- src/zinfo/z2/z2.s | 15 +- src/zinfo/z3/z3.s | 15 +- src/zinfo/z4/gamedata.txt | 329 +++++++++++ src/zinfo/z4/z4.s | 982 +++++++++++++++++++++++++++++++++ src/zinfo/zinfo.system.s | 8 +- winmake.bat | 2 + 9 files changed, 1357 insertions(+), 43 deletions(-) create mode 100644 src/zinfo/z4/gamedata.txt create mode 100644 src/zinfo/z4/z4.s diff --git a/Makefile b/Makefile index 4998fb4..853a3a6 100644 --- a/Makefile +++ b/Makefile @@ -32,6 +32,7 @@ asm: md $(ACME) -r build/zinfo1.lst src/zinfo/z1/z1.s $(ACME) -r build/zinfo2.lst src/zinfo/z2/z2.s $(ACME) -r build/zinfo3.lst src/zinfo/z3/z3.s + $(ACME) -r build/zinfo4.lst src/zinfo/z4/z4.s dsk: md asm cp res/"Pitch Dark.master games collection.do.not.edit.2mg" build/"$(DISK)" @@ -54,6 +55,7 @@ dsk: md asm $(CADIUS) ADDFILE build/"$(DISK)" "/PITCH.DARK/LIB/" "build/ZINFO1" $(CADIUS) ADDFILE build/"$(DISK)" "/PITCH.DARK/LIB/" "build/ZINFO2" $(CADIUS) ADDFILE build/"$(DISK)" "/PITCH.DARK/LIB/" "build/ZINFO3" + $(CADIUS) ADDFILE build/"$(DISK)" "/PITCH.DARK/LIB/" "build/ZINFO4" # TODO remove these save game files, just here for development $(CADIUS) ADDFILE build/"$(DISK)" "/PITCH.DARK/Z/WISHBRINGER/" "res/R69.850920.SAV" $(CADIUS) ADDFILE build/"$(DISK)" "/PITCH.DARK/Z/ZORK.I/" "res/R88.840726.SAV" diff --git a/src/onbeyond/onbeyond.system.s b/src/onbeyond/onbeyond.system.s index 7ad192b..210dd4e 100644 --- a/src/onbeyond/onbeyond.system.s +++ b/src/onbeyond/onbeyond.system.s @@ -27,11 +27,11 @@ op_c7 jsr $bf00 !byte $c5 !word c5_parms - ldx $281 - inx - txa + lda $281 and #$0f - sta $280 + tax + inx + stx $280 lda #$2f sta $281 diff --git a/src/zinfo/z1/z1.s b/src/zinfo/z1/z1.s index fe1eb71..b4c5116 100644 --- a/src/zinfo/z1/z1.s +++ b/src/zinfo/z1/z1.s @@ -6,15 +6,17 @@ *=$3000 save_name = $2006 -read_buffer = $3500 ;512 bytes -record_size = $40 -info_buffer = $2000 ;record_size*8 (currently $200) bytes, can be anywhere +read_buffer = $2e00 ;512 bytes +info_buffer = $2000 ;record_size*8, 600 ($258) bytes zpage_info = $fe ;word zpage_ptr = $fd -name_offset = 0 ;1+37 bytes + +name_offset = 0 ;1+37 bytes, a zero-length name is an empty record time_offset = 42 ;1+8 bytes ("12:01 pm") score_offset = 51 ;1+6 bytes (-12345) moves_offset = 58 ;1+5 bytes (12345) +date_offset = 64 ;1+10 bytes (unused in this version) +record_size = 75 ;bytes ;zpage used by Infocom code @@ -89,21 +91,21 @@ fetch_info !word cc_parms quit - lda $bf30 - sta c5_parms+1 - jsr $bf00 - !byte $c5 - !word c5_parms - ldx $201 + lda $bf30 + sta c5_parms+1 + jsr $bf00 + !byte $c5 + !word c5_parms + ldx $201 inx txa - and #$0f - sta $200 - lda #$2f - sta $201 - jsr $bf00 - !byte $c6 - !word c6_parms + and #$0f + sta $200 + lda #$2f + sta $201 + jsr $bf00 + !byte $c6 + !word c6_parms exchange ldx #(zp_E7-zp_91) @@ -686,6 +688,3 @@ stack_pointer max_chars !byte 0 zpage_old -!if *+(zp_E7-zp_91)>=read_buffer { - !error "Code is too large" -} diff --git a/src/zinfo/z2/z2.s b/src/zinfo/z2/z2.s index 3001325..d534a0a 100644 --- a/src/zinfo/z2/z2.s +++ b/src/zinfo/z2/z2.s @@ -6,15 +6,17 @@ *=$3000 save_name = $2006 -read_buffer = $3500 ;512 bytes -record_size = $40 -info_buffer = $2000 ;record_size*8 (currently $200) bytes, can be anywhere +read_buffer = $2e00 ;512 bytes +info_buffer = $2000 ;record_size*8, 600 ($258) bytes zpage_info = $fe ;word zpage_ptr = $fd -name_offset = 0 ;1+37 bytes + +name_offset = 0 ;1+37 bytes, a zero-length name is an empty record time_offset = 42 ;1+8 bytes ("12:01 pm") score_offset = 51 ;1+6 bytes (-12345) moves_offset = 58 ;1+5 bytes (12345) +date_offset = 64 ;1+10 bytes (unused in this version) +record_size = 75 ;bytes ;zpage used by Infocom code @@ -91,6 +93,8 @@ fetch_info !word cc_parms quit + lda $bf30 + sta c5_parms+1 jsr $bf00 !byte $c5 !word c5_parms @@ -754,6 +758,3 @@ stack_pointer max_chars !byte 0 zpage_old -!if *+(zp_E9-zp_91)>=read_buffer { - !error "Code is too large" -} diff --git a/src/zinfo/z3/z3.s b/src/zinfo/z3/z3.s index b27af1b..8847fc1 100644 --- a/src/zinfo/z3/z3.s +++ b/src/zinfo/z3/z3.s @@ -6,15 +6,17 @@ *=$3000 save_name = $2006 -read_buffer = $3500 ;512 bytes -record_size = $40 -info_buffer = $2000 ;record_size*8 (currently $200) bytes, can be anywhere +read_buffer = $2e00 ;512 bytes +info_buffer = $2000 ;record_size*8, 600 ($258) bytes zpage_info = $fe ;word zpage_ptr = $fd -name_offset = 0 ;1+37 bytes + +name_offset = 0 ;1+37 bytes, a zero-length name is an empty record time_offset = 42 ;1+8 bytes ("12:01 pm") score_offset = 51 ;1+6 bytes (-12345) moves_offset = 58 ;1+5 bytes (12345) +date_offset = 64 ;1+10 bytes (unused in this version) +record_size = 75 ;bytes ;zpage used by Infocom code @@ -145,7 +147,7 @@ quit jsr $bf00 !byte $c6 !word c6_parms - + exchange ldx #(zp_DC-zp_8C) - ldy zpage_old-1,x @@ -818,6 +820,3 @@ stack_pointer max_chars !byte 0 zpage_old -!if *+(zp_DC-zp_8C)>=read_buffer { - !error "Code is too large" -} diff --git a/src/zinfo/z4/gamedata.txt b/src/zinfo/z4/gamedata.txt new file mode 100644 index 0000000..58b0302 --- /dev/null +++ b/src/zinfo/z4/gamedata.txt @@ -0,0 +1,329 @@ +gamelist + + !byte amfvr77e-amfvr77b +amfvr77b + !text "R77.850814.SAV" +amfvr77e + + !byte amfvr77de-amfvr77db +amfvr77db + !text "R77.DEPROT.SAV" +amfvr77de + + !byte amfvr79e-amfvr79b +amfvr79b + !text "R79.851122.SAV" +amfvr79e + + !byte amfvr79de-amfvr79db +amfvr79db + !text "R79.DEPROT.SAV" +amfvr79de + + !byte bureaur86e-bureaur86b +bureaur86b + !text "R86.870212.SAV" +bureaur86e + + !byte bureaur86de-bureaur86db +bureaur86db + !text "R86.DEPROT.SAV" +bureaur86de + + !byte bureaur116e-bureaur116b +bureaur116b + !text "R116.870602.SAV" +bureaur116e + + !byte bureaur116de-bureaur116db +bureaur116db + !text "R116.DEPROT.SAV" +bureaur116de + + !byte nordr19e-nordr19b +nordr19b + !text "R19.870722.SAV" +nordr19e + + !byte trinityr11e-trinityr11b +trinityr11b + !text "R11.860509.SAV" +trinityr11e + + !byte trinityr12e-trinityr12b +trinityr12b + !text "R12.860926.SAV" +trinityr12e + + !byte 0 ;end of list + +gameloc +;amfvr77 + !byte $a0 + +;amfvr77d + !byte $a0 + +;amfvr79 + !byte $a0 + +;amfvr79d + !byte $a0 + +;bureaur86 + !byte $b6 + +;bureaur86d + !byte $b6 + +;bureaur116 + !byte $b6 + +;bureaur116d + !byte $b6 + +;nordr19 + !byte $91 + +;trinityr11 + !byte $be + +;trinityr12 + !byte $be + +gametime +;amfvr77 + !byte $aa + +;amfvr77d + !byte $aa + +;amfvr79 + !byte $aa + +;amfvr79d + !byte $aa + +;bureaur86 + !byte 0 ;no time + +;bureaur86d + !byte 0 ;no time + +;bureaur116 + !byte 0 ;no time + +;bureaur86d + !byte 0 ;no time + +;nordr19 + !byte 0 ;no time + +;trinityr11 + !byte 0 ;no time + +;trinityr12 + !byte 0 ;no time + +gamescore +;amfvr77 + !byte 0 ;no score + +;amfvr77d + !byte 0 ;no score + +;amfvr79 + !byte 0 ;no score + +;amfvr79d + !byte 0 ;no score + +;bureaur86 + !byte $a1 + +;bureaur86d + !byte $a1 + +;bureaur116 + !byte $a1 + +;bureaur86d + !byte $a1 + +;nordr19 + !byte 0 ;per-scenario score, not supported yet + +;trinityr11 + !byte $aa + +;trinityr12 + !byte $aa + +gamemoves +;amfvr77 + !byte 0 ;no moves + +;amfvr77d + !byte 0 ;no moves + +;amfvr79 + !byte 0 ;no moves + +;amfvr79d + !byte 0 ;no moves + +;bureaur86 + !byte $8f + +;bureaur86d + !byte $8f + +;bureaur116 + !byte $8e + +;bureaur86d + !byte $8e + +;nordr19 + !byte 0 ;no moves + +;trinityr11 + !byte $95 + +;trinityr12 + !byte $95 + +gamemonth +;amfvr77 + !byte $18 + !byte $7c + +;amfvr77d + !byte $18 + !byte $7c + +;amfvr79 + !byte $18 + !byte $7c + +;amfvr79d + !byte $18 + !byte $7c + +;bureaur86 + !byte 0 ;no month + !byte 0 ;no month + +;bureaur86d + !byte 0 ;no month + !byte 0 ;no month + +;bureaur116 + !byte 0 ;no month + !byte 0 ;no month + +;bureaur86d + !byte 0 ;no month + !byte 0 ;no month + +;nordr19 + !byte 0 ;no month + !byte 0 ;no month + +;trinityr11 + !byte 0 ;no month + !byte 0 ;no month + +;trinityr12 + !byte 0 ;no month + !byte 0 ;no month + +gameday +;amfvr77 + !byte $91 + !byte $81 + +;amfvr77d + !byte $91 + !byte $81 + +;amfvr79 + !byte $91 + !byte $81 + +;amfvr79d + !byte $91 + !byte $81 + +;bureaur86 + !byte 0 ;no day + !byte 0 ;no day + +;bureaur86d + !byte 0 ;no day + !byte 0 ;no day + +;bureaur116 + !byte 0 ;no day + !byte 0 ;no day + +;bureaur86d + !byte 0 ;no day + !byte 0 ;no day + +;nordr19 + !byte 0 ;no day + !byte 0 ;no day + +;trinityr11 + !byte 0 ;no day + !byte 0 ;no day + +;trinityr12 + !byte 0 ;no day + !byte 0 ;no day + +gameyear +;amfvr77 + !byte $bb + !byte $39 + +;amfvr77d + !byte $bb + !byte $39 + +;amfvr79 + !byte $bb + !byte $39 + +;amfvr79d + !byte $bb + !byte $39 + +;bureaur86 + !byte 0 ;no year + !byte 0 ;no year + +;bureaur86d + !byte 0 ;no year + !byte 0 ;no year + +;bureaur116 + !byte 0 ;no year + !byte 0 ;no year + +;bureaur86d + !byte 0 ;no year + !byte 0 ;no year + +;nordr19 + !byte 0 ;no year + !byte 0 ;no year + +;trinityr11 + !byte 0 ;no year + !byte 0 ;no year + +;trinityr12 + !byte 0 ;no year + !byte 0 ;no year diff --git a/src/zinfo/z4/z4.s b/src/zinfo/z4/z4.s new file mode 100644 index 0000000..8dad6e1 --- /dev/null +++ b/src/zinfo/z4/z4.s @@ -0,0 +1,982 @@ +;license:MIT +;(c) 2018 by qkumba + +!cpu 6502 +!to "build/zinfo4",plain +*=$3000 + +save_name = $2006 +read_buffer = $2e00 ;512 bytes +info_buffer = $2000 ;record_size*8, 600 ($258) bytes +zpage_info = $fe ;word +zpage_ptr = $fd +zpage_gamind = $fc +name_offset = 0 ;1+37 bytes, a zero-length name is an empty record +time_offset = 42 ;1+8 bytes ("12:01 pm") +score_offset = 51 ;1+6 bytes (-12345) +moves_offset = 58 ;1+5 bytes (12345) +date_offset = 64 ;1+10 bytes ("10/10/2099") +record_size = 75 ;bytes + + +;zpage used by Infocom code + +zp_58 = $58 +zp_59 = $59 +zp_5A = $5a +zp_5B = $5b +zp_6B = $6b +zp_6C = $6c +zp_6D = $6d +zp_6E = $6e +zp_7B = $7b +zp_7C = $7c +zp_7D = $7d +zp_7E = $7e +zp_7F = $7f +zp_80 = $80 +zp_83 = $83 +zp_84 = $84 +zp_87 = $87 +zp_88 = $88 +zp_89 = $89 +zp_8A = $8a +zp_A0 = $a0 +zp_A1 = $a1 +zp_A6 = $a6 +zp_A7 = $a7 +zp_A8 = $a8 +zp_A9 = $a9 +zp_AA = $aa +zp_AB = $ab +zp_AC = $ac +zp_C7 = $c7 +zp_C8 = $c8 +zp_C9 = $c9 +zp_CA = $ca +zp_CB = $cb +zp_CC = $cc +zp_CD = $cd +zp_CE = $ce +zp_CF = $cf + + jsr exchange + jsr $bf00 + !byte $c8 ;open file + !word c8_parms + lda c8_handle + sta ce_handle + sta ca_handle + + lda #>info_buffer + sta zpage_info+1 + lda #gamelist + sta zpage_info+1 +--- ldy #0 + lda (zpage_info),y + beq close ++ pha + cmp $2006 + beq + +-- inc zpage_gamind + pla + sec + adc zpage_info + sta zpage_info + bcc --- + inc zpage_info+1 + bne --- ++ tay +- lda $2006,y + cmp (zpage_info),y + bne -- + dey + bne - + pla + + lda #>info_buffer + sta zpage_info+1 + lda #read_buffer + sta zp_6E + LDA (zp_6D),Y + STA zp_6C + INY + LDA (zp_6D),Y + STA zp_6B + pla + sta zp_6E + RTS + +sub_E174: + SEC + SBC #$10 + LDY #0 + STY zp_6E + ASL + ROL zp_6E + CLC + ADC zp_83 + STA zp_6D + LDA zp_6E + ADC zp_84 + STA zp_6E + +locret_E189: + RTS + +decompress + JSR sub_F285 + LDY #$C + jsr load_page + lda #>read_buffer + sta zp_6E + LDA (zp_6D),Y + TAX + INY + LDA (zp_6D),Y + STA zp_6D + STX zp_6E + INC zp_6D + BNE loc_E4FA + INC zp_6E + +loc_E4FA: + JSR loc_EDCE + JMP sub_F054 + +sub_E7FB: + JSR sub_E80F + LDX zp_C7 + LDA zp_C8 + rts + +sub_E80F: + LDA zp_59 + STA zp_CE + EOR zp_5B + STA zp_CD + LDA zp_58 + STA zp_C7 + LDA zp_59 + STA zp_C8 + BPL loc_E824 + JSR sub_E84D + +loc_E824: + LDA zp_5A + STA zp_C9 + LDA zp_5B + STA zp_CA + BPL loc_E831 + JSR sub_E83F + +loc_E831: + JSR sub_E85B + LDA zp_CD + BPL loc_E83B + JSR sub_E84D + +loc_E83B: + LDA zp_CE + BPL locret_E84C + +sub_E83F: + LDA #0 + SEC + SBC zp_C9 + STA zp_C9 + LDA #0 + SBC zp_CA + STA zp_CA + +locret_E84C: + RTS + +sub_E84D: + LDA #0 + SEC + SBC zp_C7 + STA zp_C7 + LDA #0 + SBC zp_C8 + STA zp_C8 + RTS + +sub_E85B: + JSR sub_E891 + +loc_E864: + ROL zp_C7 + ROL zp_C8 + ROL zp_CB + ROL zp_CC + LDA zp_CB + SEC + SBC zp_C9 + TAY + LDA zp_CC + SBC zp_CA + BCC loc_E87C + STY zp_CB + STA zp_CC + +loc_E87C: + DEX + BNE loc_E864 + ROL zp_C7 + ROL zp_C8 + LDA zp_CB + STA zp_C9 + LDA zp_CC + STA zp_CA + RTS + +sub_E891: + LDX #$10 + LDA #0 + STA zp_CB + STA zp_CC + CLC + RTS + +sub_EA09: + LDA zp_58 + STA zp_C7 + LDA zp_59 + STA zp_C8 + LDA zp_C8 + BPL loc_EA1D + LDA #$2D + JSR emit_char + JSR sub_E84D + +loc_EA1D: + LDA #0 + STA zp_CF + +loc_EA21: + LDA zp_C7 + ORA zp_C8 + BEQ loc_EA39 + LDA #$A + STA zp_C9 + LDA #0 + STA zp_CA + JSR sub_E85B + LDA zp_C9 + PHA + INC zp_CF + BNE loc_EA21 + +loc_EA39: + LDA zp_CF + BNE loc_EA42 + LDA #$30 + JMP emit_char + +loc_EA42: + PLA + CLC + ADC #$30 + JSR emit_char + DEC zp_CF + BNE loc_EA42 + RTS + +loc_EDCE: + LDA zp_6D + STA zp_7B + LDA zp_6E + STA zp_7C + LDA #0 + STA zp_7D + JMP sub_EE56 + +sub_EE56: + ldy zp_7D + LDA zp_7C + STY zp_80 + STA zp_7F + RTS + +sub_EFF9: + PHA + INC zp_7C + BNE loc_F000 + INC zp_7D + +loc_F000: + JSR sub_EE56 + PLA + RTS + +sub_F011: + LDY zp_7B + lda zp_7F + pha + jsr load_page + lda #>read_buffer + sta zp_7F + LDA (zp_7E),Y + INC zp_7B + BNE loc_F024 + JSR sub_EFF9 + +loc_F024: + TAY + pla + sta zp_7F + tya + RTS + +locret_F053: + RTS + +sub_F054: + LDX #0 + STX zp_A6 + STX zp_AA + DEX + STX zp_A7 + +loc_F05D: + JSR sub_F13A + BCS locret_F053 + STA zp_A8 + TAX + BEQ loc_F0A8 + CMP #4 + BCC loc_F0C6 + CMP #6 + BCC loc_F0AC + JSR sub_F11C + TAX + BNE loc_F080 + LDA #$5B + +loc_F077: + CLC + ADC zp_A8 + +loc_F07A: + JSR emit_char + JMP loc_F05D + +loc_F080: + CMP #1 + BNE loc_F088 + LDA #$3B + BNE loc_F077 + +loc_F088: + LDA zp_A8 + SEC + SBC #6 + BEQ loc_F096 + TAX + LDA byte_F26B,X + JMP loc_F07A + +loc_F096: + JSR sub_F13A + ASL + ASL + ASL + ASL + ASL + STA zp_A8 + JSR sub_F13A + ORA zp_A8 + JMP loc_F07A + +loc_F0A8: + LDA #$20 + BNE loc_F07A + +loc_F0AC: + SEC + SBC #3 + TAY + JSR sub_F11C + BNE loc_F0BA + STY zp_A7 + JMP loc_F05D + +loc_F0BA: + STY zp_A6 + CMP zp_A6 + BEQ loc_F05D + LDA #0 + STA zp_A6 + BEQ loc_F05D + +loc_F0C6: + SEC + SBC #1 + ASL + ASL + ASL + ASL + ASL + ASL + STA zp_A9 + JSR sub_F13A + ASL + CLC + ADC zp_A9 + TAY + lda zp_88 + pha + jsr load_page + lda #>read_buffer + sta zp_88 + LDA (zp_87),Y + STA zp_6E + INY + LDA (zp_87),Y + STA zp_6D + pla + sta zp_88 + LDA zp_7D + PHA + LDA zp_7C + PHA + LDA zp_7B + PHA + LDA zp_A6 + PHA + LDA zp_AA + PHA + LDA zp_AC + PHA + LDA zp_AB + PHA + JSR sub_F128 + JSR sub_F054 + PLA + STA zp_AB + PLA + STA zp_AC + PLA + STA zp_AA + PLA + STA zp_A6 + PLA + STA zp_7B + PLA + STA zp_7C + PLA + STA zp_7D + LDX #$FF + STX zp_A7 + JSR sub_EE56 + JMP loc_F05D + +sub_F11C: + LDA zp_A7 + BPL loc_F123 + LDA zp_A6 + RTS + +loc_F123: + LDY #$FF + STY zp_A7 + RTS + +sub_F128: + LDA zp_6D + ASL + STA zp_7B + LDA zp_6E + ROL + STA zp_7C + LDA #0 + ROL + STA zp_7D + JMP sub_EE56 + +sub_F13A: + LDA zp_AA + BPL loc_F140 + SEC + RTS + +loc_F140: + BNE loc_F155 + INC zp_AA + JSR sub_F011 + STA zp_AC + JSR sub_F011 + STA zp_AB + LDA zp_AC + LSR + LSR + JMP loc_F17E + +loc_F155: + SEC + SBC #1 + BNE loc_F170 + LDA #2 + STA zp_AA + LDA zp_AB + STA zp_6D + LDA zp_AC + ASL zp_6D + ROL + ASL zp_6D + ROL + ASL zp_6D + ROL + JMP loc_F17E + +loc_F170: + LDA #0 + STA zp_AA + LDA zp_AC + BPL loc_F17C + LDA #$FF + STA zp_AA + +loc_F17C: + LDA zp_AB + +loc_F17E: + AND #$1F + CLC + RTS + +byte_F26B: + !BYTE 0, $D, '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', '.', ',', '!', '?', '_' + !BYTE '#', $27, '"', '/', $5C, '-', ':', '(', ')' + +sub_F285: + STX zp_6E + ASL + STA zp_6D + ROL zp_6E + LDX zp_6E + ASL + ROL zp_6E + ASL + ROL zp_6E + ASL + ROL zp_6E + SEC + SBC zp_6D + STA zp_6D + LDA zp_6E + STX zp_6E + SBC zp_6E + STA zp_6E + LDA zp_6D + CLC + ADC #$70 + BCC loc_F2AD + INC zp_6E + +loc_F2AD: + CLC + ADC zp_89 + STA zp_6D + LDA zp_6E + ADC zp_8A + STA zp_6E + RTS + +emit_char + sty yreg+1 + inc zpage_ptr + ldy zpage_ptr + sta (zpage_info),y + dec max_chars + beq fail_slot +yreg + ldy #0 + rts + +fail_slot +stack_pointer + ldx #0 + txs + rts + +max_chars !byte 0 + +zpage_old diff --git a/src/zinfo/zinfo.system.s b/src/zinfo/zinfo.system.s index d8fec12..1f8b97d 100644 --- a/src/zinfo/zinfo.system.s +++ b/src/zinfo/zinfo.system.s @@ -27,11 +27,11 @@ op_c7 jsr $bf00 !byte $c5 !word c5_parms - ldx $281 - inx - txa + lda $281 and #$0f - sta $280 + tax + inx + stx $280 lda #$2f sta $281 diff --git a/winmake.bat b/winmake.bat index 15c5e1a..2ec7f54 100644 --- a/winmake.bat +++ b/winmake.bat @@ -31,6 +31,7 @@ if "%1" equ "asm" ( %ACME% -r build\zinfo1.lst src\zinfo\z1\z1.s %ACME% -r build\zinfo2.lst src\zinfo\z2\z2.s %ACME% -r build\zinfo3.lst src\zinfo\z3\z3.s +%ACME% -r build\zinfo4.lst src\zinfo\z4\z4.s goto :EOF ) @@ -57,6 +58,7 @@ cscript /nologo bin\fixFileInformation.js build\_FileInformation.txt %CADIUS% ADDFILE "build\%DISK%" "/PITCH.DARK/LIB/" "build\ZINFO1" %CADIUS% ADDFILE "build\%DISK%" "/PITCH.DARK/LIB/" "build\ZINFO2" %CADIUS% ADDFILE "build\%DISK%" "/PITCH.DARK/LIB/" "build\ZINFO3" +%CADIUS% ADDFILE "build\%DISK%" "/PITCH.DARK/LIB/" "build\ZINFO4" goto :EOF )