From a8cd39d587719e7f68a05f1130bda961b61d1c86 Mon Sep 17 00:00:00 2001
From: shoofle <xsigma@gmail.com>
Date: Tue, 7 Jan 2025 13:15:35 -0500
Subject: [PATCH] adds a third card and cleans up some code

---
 KeyArtTiles.asm           | 120 +++++++++++++
 tarot.asm                 | 355 ++++++++++++--------------------------
 thehighpriestess.aseprite | Bin 0 -> 6131 bytes
 3 files changed, 235 insertions(+), 240 deletions(-)
 create mode 100644 KeyArtTiles.asm
 create mode 100644 thehighpriestess.aseprite

diff --git a/KeyArtTiles.asm b/KeyArtTiles.asm
new file mode 100644
index 0000000..8485e0f
--- /dev/null
+++ b/KeyArtTiles.asm
@@ -0,0 +1,120 @@
+	; original export script by gabriel reis, modified by shoofle
+ 
+ 
+KeyArtTiles:
+
+	db $00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00
+	db $00,$00,$00,$01,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00
+	db $00,$00,$00,$00,$00,$ff,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00
+	db $00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$04
+	db $00,$3f,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00
+	db $00,$ff,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00
+	db $00,$f8,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00
+	db $00,$00,$00,$40,$00,$ff,$00,$42,$00,$42,$00,$42,$00,$42,$00,$42
+	db $00,$42,$00,$42,$00,$42,$00,$42,$00,$42,$00,$42,$00,$42,$00,$42
+	db $10,$00,$00,$10,$00,$10,$80,$10,$40,$10,$40,$10,$20,$18,$10,$28
+	db $00,$28,$00,$28,$00,$24,$00,$24,$00,$e4,$00,$22,$00,$a2,$00,$41
+	db $00,$00,$00,$00,$00,$01,$00,$06,$00,$99,$00,$20,$00,$00,$00,$fc
+	db $00,$40,$00,$c0,$00,$20,$00,$60,$00,$60,$00,$60,$00,$50,$00,$50
+	db $00,$07,$00,$00,$00,$00,$00,$00,$00,$ff,$00,$00,$00,$00,$00,$00
+	db $00,$00,$00,$c2,$00,$62,$00,$52,$00,$8a,$00,$06,$00,$02,$00,$02
+	db $00,$48,$00,$44,$00,$43,$00,$40,$00,$40,$00,$5f,$00,$20,$00,$00
+	db $00,$00,$00,$00,$00,$00,$00,$c0,$00,$30,$00,$88,$00,$08,$00,$04
+	db $00,$03,$00,$03,$00,$01,$00,$01,$00,$01,$00,$03,$00,$03,$00,$06
+	db $00,$04,$00,$04,$00,$02,$00,$02,$00,$02,$00,$02,$00,$04,$00,$18
+	db $00,$08,$00,$10,$00,$20,$00,$20,$00,$40,$00,$80,$00,$80,$00,$80
+	db $00,$00,$00,$03,$00,$04,$00,$04,$00,$04,$00,$04,$00,$03,$00,$00
+	db $00,$20,$00,$c0,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$f8
+	db $00,$00,$00,$01,$00,$01,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00
+	db $00,$80,$00,$00,$00,$00,$00,$80,$00,$78,$00,$06,$00,$01,$00,$00
+	db $00,$31,$00,$31,$00,$11,$00,$11,$00,$11,$00,$11,$00,$11,$00,$91
+	db $00,$07,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00
+	db $00,$e0,$00,$1f,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00
+	db $00,$00,$00,$9f,$00,$60,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00
+	db $00,$81,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00
+	db $41,$00,$20,$00,$10,$00,$08,$00,$04,$00,$02,$00,$01,$00,$00,$01
+	db $00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$7e,$00,$81,$00,$01
+	db $00,$42,$00,$44,$00,$44,$00,$22,$00,$21,$00,$18,$00,$06,$00,$01
+	db $00,$82,$00,$82,$00,$05,$00,$08,$00,$f0,$00,$80,$00,$00,$00,$00
+	db $00,$10,$80,$10,$80,$10,$80,$10,$00,$30,$00,$1f,$00,$78,$00,$94
+	db $02,$08,$01,$08,$00,$08,$00,$08,$00,$08,$00,$e8,$00,$1f,$00,$08
+	db $01,$00,$00,$00,$80,$00,$40,$00,$20,$00,$10,$00,$08,$80,$04,$40
+	db $80,$06,$80,$08,$80,$10,$40,$10,$40,$10,$20,$10,$20,$10,$10,$00
+	db $02,$30,$01,$08,$00,$04,$00,$02,$00,$02,$00,$01,$00,$00,$00,$80
+	db $08,$04,$04,$00,$80,$04,$40,$04,$00,$04,$00,$08,$00,$88,$00,$88
+	db $00,$00,$00,$80,$00,$80,$00,$80,$00,$80,$00,$80,$00,$80,$00,$41
+	db $00,$80,$00,$40,$00,$40,$00,$40,$00,$40,$00,$40,$00,$41,$00,$41
+	db $00,$88,$00,$88,$00,$88,$00,$88,$00,$88,$00,$88,$20,$08,$10,$08
+	db $00,$80,$00,$40,$00,$20,$00,$18,$00,$07,$00,$00,$00,$00,$00,$00
+	db $00,$08,$00,$e8,$00,$30,$00,$c0,$00,$00,$00,$02,$00,$01,$00,$00
+	db $08,$00,$00,$08,$00,$88,$00,$48,$00,$28,$00,$78,$00,$98,$00,$88
+	db $00,$f8,$00,$a8,$00,$a8,$00,$a8,$00,$a8,$00,$a8,$00,$a9,$00,$a9
+	db $00,$29,$00,$31,$00,$31,$00,$31,$00,$31,$00,$31,$00,$31,$00,$31
+	db $00,$28,$00,$24,$00,$24,$00,$24,$00,$24,$00,$27,$00,$27,$00,$2e
+	db $00,$2d,$00,$26,$00,$25,$00,$25,$00,$25,$00,$25,$00,$25,$00,$25
+	db $00,$25,$00,$25,$00,$25,$00,$25,$00,$15,$00,$15,$00,$15,$00,$15
+	db $00,$15,$00,$15,$00,$15,$00,$15,$00,$11,$00,$02,$00,$02,$00,$02
+	db $00,$02,$00,$02,$00,$02,$00,$04,$00,$04,$00,$08,$00,$08,$00,$00
+	db $00,$a9,$00,$a9,$00,$a9,$00,$a9,$00,$a9,$00,$a9,$00,$a9,$00,$a9
+	db $02,$00,$02,$00,$80,$03,$40,$04,$20,$08,$00,$10,$00,$10,$00,$10
+	db $01,$00,$00,$00,$00,$e0,$00,$10,$00,$10,$00,$08,$00,$08,$0c,$00
+	db $00,$0b,$00,$08,$00,$04,$00,$03,$00,$00,$00,$00,$00,$00,$00,$00
+	db $00,$00,$00,$00,$00,$00,$00,$01,$00,$03,$00,$0c,$01,$f4,$00,$04
+	db $00,$04,$00,$04,$00,$24,$00,$24,$02,$24,$02,$24,$01,$24,$01,$24
+	db $00,$78,$00,$80,$00,$00,$00,$60,$00,$18,$00,$07,$00,$00,$00,$00
+	db $00,$60,$00,$1c,$00,$03,$00,$00,$00,$01,$00,$fe,$00,$00,$00,$00
+	db $02,$40,$01,$20,$00,$f8,$00,$78,$00,$88,$00,$08,$00,$08,$00,$10
+	db $08,$20,$06,$40,$01,$80,$10,$00,$08,$00,$04,$00,$02,$00,$81,$00
+	db $00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$1f,$00,$e7
+	db $00,$00,$00,$00,$00,$00,$00,$07,$00,$00,$00,$00,$00,$fe,$00,$81
+	db $00,$20,$00,$40,$00,$80,$00,$00,$00,$00,$00,$00,$04,$00,$04,$80
+	db $00,$00,$00,$02,$00,$02,$00,$02,$00,$02,$00,$02,$00,$02,$00,$06
+	db $00,$22,$00,$22,$00,$22,$00,$22,$00,$22,$00,$02,$00,$02,$00,$02
+	db $00,$02,$00,$02,$00,$02,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00
+	db $02,$28,$02,$28,$01,$28,$00,$28,$00,$28,$00,$28,$00,$28,$00,$28
+	db $00,$0a,$00,$0a,$00,$0a,$00,$0a,$00,$0a,$00,$0a,$00,$0a,$00,$0a
+	db $00,$12,$00,$12,$00,$12,$00,$22,$00,$22,$00,$22,$00,$22,$00,$22
+	db $00,$22,$00,$22,$00,$22,$00,$22,$00,$22,$00,$22,$00,$22,$00,$22
+	db $00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$7f,$00,$00
+	db $00,$0c,$00,$18,$80,$0c,$40,$0b,$20,$04,$10,$04,$08,$02,$00,$02
+	db $00,$00,$00,$00,$00,$00,$00,$00,$00,$ff,$00,$00,$00,$00,$00,$00
+	db $00,$00,$00,$00,$00,$00,$00,$00,$00,$fc,$00,$00,$00,$00,$00,$00
+	db $00,$01,$a0,$00,$70,$00,$10,$00,$08,$00,$04,$00,$02,$00,$01,$00
+	db $00,$00,$00,$80,$00,$80,$00,$40,$00,$3f,$00,$04,$00,$04,$00,$04
+	db $00,$80,$00,$40,$00,$20,$00,$18,$00,$06,$00,$01,$00,$00,$00,$03
+	db $00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$80,$00,$3f,$00,$c0
+	db $00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$f8,$00,$00,$00,$00
+	db $00,$04,$80,$04,$80,$04,$40,$04,$20,$04,$20,$04,$10,$04,$10,$04
+	db $00,$00,$00,$00,$00,$00,$00,$00,$00,$ff,$00,$00,$00,$84,$00,$44
+	db $00,$48,$00,$88,$00,$88,$00,$88,$00,$88,$00,$88,$00,$08,$00,$08
+	db $00,$44,$00,$44,$00,$44,$00,$44,$00,$44,$00,$44,$00,$44,$00,$44
+	db $00,$08,$00,$08,$00,$08,$00,$08,$00,$08,$00,$08,$00,$08,$00,$08
+	db $00,$08,$00,$08,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00
+	db $00,$00,$00,$00,$00,$00,$00,$00,$00,$01,$00,$02,$00,$0c,$00,$10
+	db $00,$00,$00,$00,$00,$00,$00,$78,$00,$86,$00,$01,$00,$00,$00,$00
+	db $00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$fc,$00,$02,$00,$01
+	db $00,$28,$00,$28,$00,$28,$00,$28,$00,$28,$00,$28,$08,$20,$04,$28
+	db $00,$00,$01,$00,$00,$00,$00,$00,$40,$00,$20,$00,$10,$00,$08,$00
+	db $04,$00,$03,$00,$c0,$00,$20,$00,$10,$00,$10,$00,$08,$00,$04,$00
+	db $02,$00,$01,$00,$80,$00,$40,$00,$20,$00,$20,$00,$18,$00,$06,$00
+	db $00,$00,$80,$00,$40,$00,$20,$00,$10,$00,$08,$00,$04,$00,$04,$00
+
+ 
+ 
+BackgroundCopy:
+	db $00, $00, $57, $58, $59, $00, $00, $00
+	db $3e, $3f, $40, $5b, $5e, $4e, $4f, $50
+	db $3a, $3b, $3c, $5c, $5d, $49, $4a, $4b
+	db $48, $38, $3d, $35, $36, $4c, $4d, $52
+	db $41, $39, $1d, $21, $22, $23, $51, $54
+	db $45, $5a, $24, $37, $2b, $25, $26, $54
+	db $46, $44, $09, $27, $1e, $28, $29, $54
+	db $47, $2f, $0a, $1f, $0b, $20, $2c, $54
+	db $47, $30, $0c, $2a, $0d, $0e, $2d, $53
+	db $47, $31, $0f, $10, $00, $11, $34, $55
+	db $47, $32, $00, $12, $00, $13, $2e, $55
+	db $42, $33, $14, $15, $16, $17, $18, $55
+	db $43, $00, $00, $19, $1a, $1b, $1c, $56
+	db $00, $00, $01, $02, $07, $02, $00, $00
+	db $00, $00, $00, $00, $08, $03, $00, $00
+	db $00, $00, $00, $04, $05, $06, $00, $00
diff --git a/tarot.asm b/tarot.asm
index 3ab6566..88fa255 100644
--- a/tarot.asm
+++ b/tarot.asm
@@ -23,8 +23,9 @@ DEF vPreviousCardIndex EQU $FFA0+3
 DEF vSafeCopySource EQU $FFA0+4 
 DEF vSafeCopyDest EQU vSafeCopySource + 2
 DEF vSafeCopyCount EQU vSafeCopyDest + 2 ; check this for safe transfer being complete
+DEF vSafeCopyOriginalCount EQU vSafeCopyCount + 2 
 ; stash previous interrupt state before using the interrupts
-DEF vSafeCopyLYC EQU vSafeCopyCount + 2 ; stashes $FF45, the LYC register
+DEF vSafeCopyLYC EQU vSafeCopyOriginalCount + 2 ; stashes $FF45, the LYC register
 DEF vSafeCopySTAT EQU vSafeCopyLYC + 1 ; stashes $FF41, the STAT register
 DEF vSafeCopyInterruptFirst EQU vSafeCopySTAT + 1 ; stashes $0048 the STAT interrupt
 DEF vSafeCopyInterruptSecond EQU vSafeCopyInterruptFirst + 1
@@ -141,15 +142,12 @@ Loop:
   ld a, b
   ld [rMYBTN], a
 
-  di
   call SCENE_UPDATE - 1
-  ei
+  
   ld b, 144
   call AwaitLine
 
-  di
   call SCENE_DRAW - 1
-  ei
   jp Loop
 
 
@@ -169,22 +167,16 @@ CardReadSetup:
   ld bc, LetterTilesEnd - LetterTiles
   call CopyRangeUnsafe
 
-  ld hl, BigLetterTiles
-  ld de, $8000 + (128 + 16 + 32)*16
-  ld bc, BigLetterTilesEnd - BigLetterTiles
-  ; call CopyRangeUnsafe
-
-  ld de, UITilemap ; origin
-  ld hl, $9800 ; destination
+  ld hl, UITilemap ; origin
+  ld de, $9800 ; destination
   ld b, 18 ; height
   ld c, 20 ; width
-  call CopyTilesToMap
-
-  ld de, BigLetters
-  ld hl, $9800 + 32*1 + 10
-  ld b, 2
-  ld c, 8
-  call CopyTilesToMap
+  call CopyTilesToMapUnsafe
+  
+  ;ld hl, FoolTiles
+  ;ld de, $8000
+  ;ld bc, FoolTilesEnd - FoolTiles
+  ;call CopyRangeUnsafe
 
   ; Turn the LCD on
   ld a, LCDCF_BLK01 | LCDCF_ON | LCDCF_BGON
@@ -205,73 +197,83 @@ CardReadSetup:
 CardReadUpdate:
   ldh a, [rMYBTNP]
   and a, %0000_1000 ; select the down key
-  jp z, CardReadUpdateDoneDown
+  jp z, :+ ; skip the following code if down is not pressed
   ldh a, [vSelectedTileIndex]
-  inc a ; increment when they press down because the stack has card 0 at the top
+  inc a ; increment when they press down because the deck has card 0 at the top
   ldh [vSelectedTileIndex], a
-CardReadUpdateDoneDown:
+:
   ldh a, [rMYBTNP]
   and a, %0000_0100 ; select the up key
-  jp z, CardReadUpdateDoneUp
+  jp z, :+ ; skip the following code if up is not pressed
   ldh a, [vSelectedTileIndex]
-  dec a ; decrement when they press up because the stack has card 0 at the top
+  dec a ; decrement when they press up because the deck has card 0 at the top
   ldh [vSelectedTileIndex], a
-CardReadUpdateDoneUp:
-  ldh a, [vSelectedTileIndex]
-  cp a, 2
-  jp nz, CardReadUpdateDoneZero
-  ld a, 0
+:
+  ldh a, [vSelectedTileIndex] ; load current selected tile index
+  ld hl, Cards ; deck length
+  cp a, [hl] ; ddoes the index equal the deck length?
+  jp nz, :+
+  ld a, 0 ; if the index equals the deck length replace it with zero
   ldh [vSelectedTileIndex], a
-CardReadUpdateDoneZero:
-  cp a, $FF
-  jp nz, CardReadUpdateReturn
-  ld a, 1
+:
+  cp a, $FF ;  if the tile index is $FF (underflowed from dec)
+  jp nz, :+
+  ld a, [hl] 
+  dec a ;replace with deck length - 1
   ldh [vSelectedTileIndex], a
-CardReadUpdateReturn:
+:
   ret
 
 CardReadDraw:
-  ld b, 1 ; 11 rows, and we stop before drawing row zero
+; this function mostly just refreshes the deck view on the right side
+; should probably be factored out into its own thing?
+; it's also not vblank-safe; this could be up to 22 iterations of a loop...
+  ld a, [Cards]
+  srl a ; divide by two because we're drawing icons for pairs of cards 
+  ld b, a ; length of the cards data
   ld hl, $9800+32*4+19 ; start point
   ld de, 32 ; stride
 CardReadDrawCopyTile:
-  ld a, $81
-  ld [hl], a
-  add hl, de
-  dec b
-  jp nz, CardReadDrawCopyTile
-  ld a, $87
-  ld [hl], a ; draw the cap at the end
+  ld [hl], $81 ; load the tile for "unselected pair of tiles"
+  add hl, de ; step forward by stride (de is the address we're drawing to on screen)
+  dec b ; sets zero flag because it's an 8-bit register
+  jp nz, CardReadDrawCopyTile ; repeat if there's more cards in the deck to draw
+  ld [hl], $87 ; draw the cap at the end
+  
+  ; the rest of this stuff deals with drawing the set-out card for the current
+  ; selected card 
 CardReadDrawSelectedTile:
   ldh a, [vSelectedTileIndex]
+  srl a
   ld b, a
-  srl b
   ld hl, $9800+32*4+19 ; start point
   ld de, 32 ; stride
+  ; if the card we need to draw is in the zeroth spot, jump straight to drawing.
   jp z, CardReadDrawDrawSelectedTile
 CardReadDrawCountDownTile:
+  ; otherwise, decrement b until we're there
   add hl, de
   dec b
   jp nz, CardReadDrawCountDownTile
 CardReadDrawDrawSelectedTile:
   ldh a, [vSelectedTileIndex]
   and a, 1
-  jp z, CardReadDraw_PickTileWithTop
-  ld a, $90
-  ld [hl], a
-  add hl, de
-  ld a, $81
-  cp a, [hl]
-  ld a, $91
-  ld [hl], a
+  ; if we're on an odd tile, draw the tile with the top card selected.
+  ; no other tile needs to change.
+  ld [hl], $82 
   jp z, CardReadDrawReturn
-  ld a, $92
-  ld [hl], a
-  jp CardReadDrawReturn
-CardReadDraw_PickTileWithTop:
-  ld a, $82
-  ld [hl], a
+  ; otherwise we need to draw the tile with the bottom card selected.
+  ; this is more complicated because the tile underneath needs to change as well.
+  ld [hl], $90 ; draw the "bottom card is selected"
+  add hl, de ; look down one tile (de has stride, remember)
+  ld a, $81
+  cp a, [hl] ; check if the existing tile at that spot is $81 (cards) or not (end cap)
+  ld [hl], $91 ; draw the tile of "cards but the card above is selected"
+  jp z, CardReadDrawReturn ; if that was right, then jump to the end
+  ld [hl], $92 ; if that was wrong, draw "end cap but the card above is selected"
 CardReadDrawReturn:
+  ; check if the current selected tile is different from the previous;
+  ; if it is different, then load new card data
   ldh a, [vSelectedTileIndex]
   ld hl, vPreviousCardIndex
   cp a, [hl]
@@ -287,7 +289,6 @@ LoadCardData:
 
   ld b, 144
   call AwaitLine ; wait for vblank before starting to work
-LoadCardData_DoneTurningOff:
   ld a, [vSelectedTileIndex]
   ld b, 0
   ld c, a ; load bc from a. coming into this we have the number of the card in the card array in a
@@ -332,14 +333,26 @@ LoadCardData_DoneTurningOff:
   ld a, [hl+]
   ld d, a ; de has source of tile range copy
   push hl ; save the pointer to the next bit of card data (tile map)
+  
+  
+  ld h, d 
+  ld l, e  ; source
+  ld de, $9800 + 32 + 1 ; destination
+  ld b, 16 ; height
+  ld c, 8 ; width
+  call CopyTilesSafe
 
-  ld h, d
-  ld l, e ; hl takes the source
-
-  ld de, $8000 ; always load tile data into the same spot in vram
-
-  call CopyRangeSafe
-
+  ei
+WaitForSafeCopy:
+  ld b, 140
+  call AwaitLine
+  ldh a, [vSafeCopyCount]
+  ld b, a 
+  ldh a, [vSafeCopyCount+1]
+  or a, b 
+  jp nz, WaitForSafeCopy 
+  di
+  
   pop hl
   ld a, [hl+]
   ld c, a
@@ -350,15 +363,24 @@ LoadCardData_DoneTurningOff:
   ld a, [hl+]
   ld d, a ; de has source of tile range copy
 
+  ; push hl ; we don't need to keep track of hl at this point and our stack is clean.
   ld h, d
   ld l, e ; hl takes the source
 
-  ; push hl ; we don't need to keep track of hl at this point and our stack is clean.
-  ld hl, $9800 + 32 + 1 ; destination
-  ld b, 16 ; height
-  ld c, 8 ; width
-  call CopyTilesToMap
-
+  ld de, $8000 ; always load tile data into the same spot in vram
+  call CopyRangeSafe
+  
+  ei
+WaitForSafeCopy2:
+  ld b, 140
+  call AwaitLine
+  ldh a, [vSafeCopyCount]
+  ld b, a 
+  ldh a, [vSafeCopyCount+1]
+  or a, b 
+  jp nz, WaitForSafeCopy2
+  di
+  
   ret 
 
 
@@ -402,168 +424,16 @@ CopyRangeUnsafe:
   jp nz, CopyRangeUnsafe
   ret
 
-CopyRangeSafe: 
-  ; hl is source
-  ; de is destination
-  ; bc is length to copy
-; copy an array of bytes to a destination in memory.
-; this is completely different from CopyRangeUnsafe.
-; this initiates an asynchronous, interrupt-driven copy of BC bytes of memory
-; from HL to DE.
-; it may return a memory address to look at for progress of the transfer,
-; or else it's just going to do it with a hard-coded address.
-; check the transfer status address for zero; when it's zero, the transfer is done!
-; this works by using the STAT interrupt in LYC mode to interrupt its own execution at 
-; two scanlines inside the vblank interval to know when to start and stop.
-  ; stash arguments in memory
-  di
-  ld a, l 
-  ldh [vSafeCopySource], a
-  ld a, h 
-  ldh [vSafeCopySource+1], a 
-  ld a, e 
-  ldh [vSafeCopyDest], a
-  ld a, d 
-  ldh [vSafeCopyDest+1], a 
-  ld a, c 
-  ldh [vSafeCopyCount], a
-  ld a, b 
-  ldh [vSafeCopyCount+1], a 
-  
-  ; stash interrupt state in memory
-  ldh a, [$ff41]
-  ldh [vSafeCopySTAT], a ; stashes $FF41, the STAT register
-  ldh a, [$ff45]
-  ldh [vSafeCopyLYC], a ; stashes $FF45, the LYC register
-  ld a, [INTERRUPT_LCD]
-  ld [vSafeCopyInterruptFirst], a
-  ld a, [INTERRUPT_LCD + 1]
-  ld [vSafeCopyInterruptSecond], a ; stashes $0048 the STAT interrupt handler
-  ld a, [$ffff]
-  and a, %0000_0010
-  ld [vSafeCopyInterruptEnable], a ; stashes whether LCD interrupt are enabled
-  
-  ld a, 148 ; adjust this to change timing of copy
-  ld [$ff45], a 
-  
-  ld hl, CopyRangeSafe_EnterSafeMode
-  ld a, l 
-  ld [INTERRUPT_LCD], a
-  ld a, h
-  ld [INTERRUPT_LCD + 1], a; set interrupt handler to "ENTER SAFE MODE"
-  ld a, 148 ; CHANGE ME TO ADJUST SAFE TRANSFER TIMING
-  ld [$ff45], a 
-  ld hl, $ffff 
-  set 1, [hl]
-  ld a, %0100_0000
-  ld [$ff41], a 
-  
-  ld hl, vSafeCopyCount
-  ei
-  ret ; return address of bytes remaining to copy
+INCLUDE "CopyRangeSafe.inc"
 
-CopyRangeSafe_EnterSafeMode:
-  ld hl, CopyRangeSafe_ExitSafeMode
-  ld a, l 
-  ld [INTERRUPT_LCD], a 
-  ld a, h 
-  ld [INTERRUPT_LCD+1], a 
-  ld a, 153 ; CHANGE ME TO ADJUST SAFE TRANSFER TIMING
-  ld [$ff45], a  ; set lcd interrupt handler to EXIT SAFE MODE on line 153
-  ldh a, [vSafeCopySource]
-  ld l, a 
-  ldh a, [vSafeCopySource+1]
-  ld h, a ; fetch the source
-  ldh a, [vSafeCopyDest]
-  ld e, a 
-  ldh a, [vSafeCopyDest+1]
-  ld d, a ; fetch the dest
-  ldh a, [vSafeCopyCount]
-  ld c, a 
-  ldh a, [vSafeCopyCount+1]
-  ld b, a ; fetch the count
-  
-  
-  ; before starting transfer, make sure the zero flag is false.
-  ld a, 1 
-  cp a, 0
-CopyRangeSafe_TransferLoop:
-  ei
-  nop ; ei only sets the flag one instruction later apparently. safety nop!
-  nop
-  di ; process interrupts
-  jp z, CopyRangeSafe_CleanUp ; zero flag will only be set if the exitsafemode handler fired
-  ld a, [hl+]
-  ld [de], a ; 
-  inc de
-  dec bc
-  ld a, b 
-  or a, c
-  jp nz, CopyRangeSafe_TransferLoop
-  jp CopyRangeSafe_Done
-
-CopyRangeSafe_ExitSafeMode:
-  ld a, 0 
-  cp a, 0 ; set the zero flag, which we're using as a signal to stop transferring
-  reti ; set a to zero and set the zero flag true. now the transfer loop will end
-  
-CopyRangeSafe_CleanUp:
-  ld a, l 
-  ldh [vSafeCopySource], a
-  ld a, h 
-  ldh [vSafeCopySource+1], a  ; store new source
-  ld a, e 
-  ldh [vSafeCopyDest], a
-  ld a, d 
-  ldh [vSafeCopyDest+1], a ; store new dest
-  ld a, c 
-  ldh [vSafeCopyCount], a
-  ld a, b 
-  ldh [vSafeCopyCount+1], a ; store new count
-  
-  ld hl, CopyRangeSafe_EnterSafeMode
-  ld a, l 
-  ld [INTERRUPT_LCD], a 
-  ld a, h 
-  ld [INTERRUPT_LCD+1], a 
-  ld a, 148 ; CHANGE ME TO ADJUST SAFE TRANSFER TIMING
-  ld [$ff45], a  ; set lcd interrupt handler to ENTER SAFE MODE on line 148
-  reti ; we're done with this memcpy cycle so we return from interrupt.
-
-CopyRangeSafe_Done: ; called when the complete transfer is finished, 
-; this restores interrupts to how they were.
-  ; stash interrupt state in memory
-  ldh a, [vSafeCopySTAT]
-  ldh [$ff41], a 
-  ldh a, [vSafeCopyLYC]
-  ldh [$ff45], a 
-  ldh a, [vSafeCopyInterruptFirst]
-  ld [INTERRUPT_LCD], a 
-  ldh a, [vSafeCopyInterruptSecond]
-  ldh [INTERRUPT_LCD+1], a 
-  
-  ld hl, $ffff
-  ld a, [hl] 
-  cpl 
-  set 1, a 
-  cpl ; turn off the lcd interrupt enable
-  ld [hl], a 
-  
-  ld a, [vSafeCopyInterruptEnable]
-  cp a, 0 ; if the stashed enable was 0 return. if the stashed enable was 1 then turn it on 
-  jp z, CopyRangeSafe_Return
-  set 1, [hl] ; turn on the lcd interrupt
-CopyRangeSafe_Return:
-  ret
-
-CopyTilesToMap:
+CopyTilesToMapUnsafe:
   ; copy tiles from where they are linearly packed at an origin (de)
   ; to a rectangle in the tilemap in vram (hl)
   ; assuming it has height in b and width in c.
   push bc
 CopyTile:
-  ld a, [de] ; load from the tile map into a
-  ld [hl], a ; load from a into the destination
+  ld a, [hl] ; load from the tile map into a
+  ld [de], a ; load from a into the destination
   inc hl ; this is slower than using hli but i'm trying to work with this here
   inc de
   dec c
@@ -574,22 +444,27 @@ CopyTile:
 DoneWithLine:
   pop bc
 
-  ld a, l
+  ld a, e
   add a, 32
-  ld l, a
-  ld a, h
+  ld e, a
+  ld a, d
   adc a, 0
-  ld h, a
-  ld a, l
+  ld d, a
+  ld a, e
   sub a, c
-  ld l, a
-  ld a, h
+  ld e, a
+  ld a, d
   sbc a, 0
-  ld h, a
+  ld d, a
 
   dec b
-  jp nz, CopyTilesToMap
+  ld a, b
+  cp a, 0
+  jp nz, CopyTilesToMapUnsafe
   ret
+  
+INCLUDE "CopyTilesSafe.inc"
+
 
 SECTION "Card Data", ROM0
 
@@ -610,10 +485,10 @@ TheFool:
   db 9, "-begin   "
   db 9, "-leap    "
   db 9, "-naivete "
-  dw FoolTilesEnd - FoolTiles
-  dw FoolTiles
   dw FoolMapEnd - FoolMap
   dw FoolMap
+  dw FoolTilesEnd - FoolTiles
+  dw FoolTiles
 FoolTiles:
 	db $00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00
 	db $00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$01,$00,$01,$00,$02
@@ -710,10 +585,10 @@ TheMagician:
   db 9, "-capacity"
   db 9, "-knowing "
   db 9, "-manifest"
-  dw MagicianTilesEnd - MagicianTiles
-  dw MagicianTiles
   dw MagicianMapEnd - MagicianMap
   dw MagicianMap
+  dw MagicianTilesEnd - MagicianTiles
+  dw MagicianTiles
 
 MagicianTiles:
   db $00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00,$00
diff --git a/thehighpriestess.aseprite b/thehighpriestess.aseprite
new file mode 100644
index 0000000000000000000000000000000000000000..bdc363e1ecf058768df7d6b69100fc68fe98509a
GIT binary patch
literal 6131
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
NGk%FF2dfrq`ZrQbiN*i`

literal 0
HcmV?d00001