From 4b6d70a61b0113c98f42841518a4e844b6e8a68c Mon Sep 17 00:00:00 2001 From: Bonta <40473493+Bonta0@users.noreply.github.com> Date: Sun, 20 Jun 2021 12:41:12 +0200 Subject: [PATCH] Quickswap: Fix consecutive special swaps --- inventory.asm | 2 +- quickswap.asm | 44 +++++++++++++++----------------------------- 2 files changed, 16 insertions(+), 30 deletions(-) diff --git a/inventory.asm b/inventory.asm index 7226629..08944f7 100644 --- a/inventory.asm +++ b/inventory.asm @@ -23,7 +23,7 @@ ; - ; - ; - -; - +; q = quickswap lock ;-------------------------------------------------------------------------------- ; ProcessMenuButtons: ; out: Carry - 0 = No Button, 1 = Yes Button diff --git a/quickswap.asm b/quickswap.asm index 96f5d0d..e73938c 100644 --- a/quickswap.asm +++ b/quickswap.asm @@ -28,6 +28,7 @@ QuickSwap: BRA .store .special_swap + LDA !INVENTORY_SWAP_2 : ORA #$01 : STA !INVENTORY_SWAP_2 CPX.b #$02 : BEQ + ; boomerang CPX.b #$01 : BEQ + ; bow CPX.b #$05 : BEQ + ; powder @@ -47,22 +48,14 @@ QuickSwap: LDA.b $F6 : AND.b #$40 ;what we wrote over RTL RCode: - LDA.w $0202 : TAX + LDX.w $0202 + LDA.b $F2 : BIT #$20 : BNE ++ ; Still holding L from a previous frame + LDA !INVENTORY_SWAP_2 : AND #$FE : STA !INVENTORY_SWAP_2 + BRA + + ++ + LDA !INVENTORY_SWAP_2 : BIT #$01 : BEQ + + RTS - -; CPX.b #$0F : BNE + ; incrementing into bottle -; LDX.b #$00 : BRA ++ -; + CPX.b #$10 : BNE + ; incrementing bottle -; LDA.l $7EF34F : TAX -; -- : ++ -; CPX.b #$04 : BEQ .noMoreBottles -; INX -; LDA.l $7EF35B,X : BEQ -- -; TXA : STA.l $7EF34F -; LDX #$10 -; RTS -; .noMoreBottles -; LDX #$11 -; BRA .nextItem + CPX.b #$14 : BNE + : LDX.b #$00 ;will wrap around to 1 + INX .nextItem @@ -70,21 +63,14 @@ RCode: RTS LCode: - LDA.w $0202 : TAX + LDX.w $0202 + LDA.b $F2 : BIT #$10 : BNE ++ ; Still holding R from a previous frame + LDA !INVENTORY_SWAP_2 : AND #$FE : STA !INVENTORY_SWAP_2 + BRA + + ++ + LDA !INVENTORY_SWAP_2 : BIT #$01 : BEQ + + RTS - -; CPX.b #$11 : BNE + ; decrementing into bottle -; LDX.b #$05 : BRA ++ -; + CPX.b #$10 : BNE + ; decrementing bottle -; LDA.l $7EF34F : TAX -; -- : ++ -; CPX.b #$01 : BEQ .noMoreBottles -; DEX -; LDA.l $7EF35B,X : BEQ -- -; TXA : STA.l $7EF34F -; LDX.b #$10 -; RTS -; .noMoreBottles -; LDX.b #$0F : BRA .nextItem + CPX.b #$01 : BNE + : LDX.b #$15 ; will wrap around to $14 + DEX .nextItem