shithub: pokered

Download patch

ref: 9391ee1da476dc6e28f879925ecca76d6697fc02
parent: fee7ef6a9e9dd53a015375a670d54c389b580364
author: YamaArashi <[email protected]>
date: Sat Feb 18 09:21:56 EST 2012

disasm of item use code for healing items, vitamins, evolution stones, TM's/HM's, PP Ups, PP restoring items

hg-commit-id: e3686b7c9370


--- a/main.asm
+++ b/main.asm
@@ -15448,61 +15448,61 @@
 	dw $59B4            ;ItemUseSurfBoard (UNUSED, glitchy!)
 	dw ItemUseBall      ;$5687 Safariball
 	dw ItemUsePokedex   ;$DA56 pokedex
-	dw $5A5B            ; MOON_STONE
-	dw $5ABB            ; ANTIDOTE
-	dw $5ABB            ; BURN_HEAL
-	dw $5ABB            ; ICE_HEAL
-	dw $5ABB            ; AWAKENING
-	dw $5ABB            ; PARLYZ_HEAL
-	dw $5ABB            ; FULL_RESTORE
-	dw $5ABB            ; MAX_POTION
-	dw $5ABB            ; HYPER_POTION
-	dw $5ABB            ; SUPER_POTION
-	dw $5ABB            ; POTION
+	dw ItemUseEvoStone  ; MOON_STONE
+	dw ItemUseMedicine  ; ANTIDOTE
+	dw ItemUseMedicine  ; BURN_HEAL
+	dw ItemUseMedicine  ; ICE_HEAL
+	dw ItemUseMedicine  ; AWAKENING
+	dw ItemUseMedicine  ; PARLYZ_HEAL
+	dw ItemUseMedicine  ; FULL_RESTORE
+	dw ItemUseMedicine  ; MAX_POTION
+	dw ItemUseMedicine  ; HYPER_POTION
+	dw ItemUseMedicine  ; SUPER_POTION
+	dw ItemUseMedicine  ; POTION
 	dw $5F52            ; BOULDERBADGE
 	dw $5F67            ; CASCADEBADGE
-	dw $6476            ; THUNDERBADGE
-	dw $6476            ; RAINBOWBADGE
-	dw $6476            ; SOULBADGE
-	dw $6476            ; MARSHBADGE
-	dw $6476            ; VOLCANOBADGE
-	dw $6476            ; EARTHBADGE
+	dw UnusableItem     ; THUNDERBADGE
+	dw UnusableItem     ; RAINBOWBADGE
+	dw UnusableItem     ; SOULBADGE
+	dw UnusableItem     ; MARSHBADGE
+	dw UnusableItem     ; VOLCANOBADGE
+	dw UnusableItem     ; EARTHBADGE
 	dw $5FAF            ; ESCAPE_ROPE
 	dw $6003            ; REPEL
-	dw $6476            ; OLD_AMBER
-	dw $5A5B            ; FIRE_STONE
-	dw $5A5B            ; THUNDER_STONE
-	dw $5A5B            ; WATER_STONE
-	dw $5AB4            ; HP_UP
-	dw $5AB4            ; PROTEIN
-	dw $5AB4            ; IRON
-	dw $5AB4            ; CARBOS
-	dw $5AB4            ; CALCIUM
-	dw $5AB4            ; RARE_CANDY
-	dw $6476            ; DOME_FOSSIL
-	dw $6476            ; HELIX_FOSSIL
-	dw $6476            ; SECRET_KEY
-	dw $6476
-	dw $6476            ; BIKE_VOUCHER
+	dw UnusableItem     ; OLD_AMBER
+	dw ItemUseEvoStone  ; FIRE_STONE
+	dw ItemUseEvoStone  ; THUNDER_STONE
+	dw ItemUseEvoStone  ; WATER_STONE
+	dw ItemUseVitamin   ; HP_UP
+	dw ItemUseVitamin   ; PROTEIN
+	dw ItemUseVitamin   ; IRON
+	dw ItemUseVitamin   ; CARBOS
+	dw ItemUseVitamin   ; CALCIUM
+	dw ItemUseVitamin   ; RARE_CANDY
+	dw UnusableItem     ; DOME_FOSSIL
+	dw UnusableItem     ; HELIX_FOSSIL
+	dw UnusableItem     ; SECRET_KEY
+	dw UnusableItem
+	dw UnusableItem     ; BIKE_VOUCHER
 	dw $6013            ; X_ACCURACY
-	dw $5A5B            ; LEAF_STONE
+	dw ItemUseEvoStone  ; LEAF_STONE
 	dw $6022            ; CARD_KEY
-	dw $6476            ; NUGGET
-	dw $6476            ; ??? PP_UP
+	dw UnusableItem     ; NUGGET
+	dw UnusableItem     ; ??? PP_UP
 	dw $60CD            ; POKE_DOLL
-	dw $5ABB            ; FULL_HEAL
-	dw $5ABB            ; REVIVE
-	dw $5ABB            ; MAX_REVIVE
+	dw ItemUseMedicine  ; FULL_HEAL
+	dw ItemUseMedicine  ; REVIVE
+	dw ItemUseMedicine  ; MAX_REVIVE
 	dw $60DC            ; GUARD_SPEC_
 	dw $60EB            ; SUPER_REPL
 	dw $60F0            ; MAX_REPEL
 	dw $60F5            ; DIRE_HIT
-	dw $6476            ; COIN
-	dw $5ABB            ; FRESH_WATER
-	dw $5ABB            ; SODA_POP
-	dw $5ABB            ; LEMONADE
-	dw $6476            ; S_S__TICKET
-	dw $6476            ; GOLD_TEETH
+	dw UnusableItem     ; COIN
+	dw ItemUseMedicine  ; FRESH_WATER
+	dw ItemUseMedicine  ; SODA_POP
+	dw ItemUseMedicine  ; LEMONADE
+	dw UnusableItem     ; S_S__TICKET
+	dw UnusableItem     ; GOLD_TEETH
 	dw $6104            ; X_ATTACK
 	dw $6104            ; X_DEFEND
 	dw $6104            ; X_SPEED
@@ -15510,18 +15510,18 @@
 	dw $623A            ; COIN_CASE
 	dw $62DE            ; OAKS_PARCEL
 	dw $62E1            ; ITEMFINDER
-	dw $6476            ; SILPH_SCOPE
+	dw UnusableItem     ; SILPH_SCOPE
 	dw $6140            ; POKE_FLUTE
-	dw $6476            ; LIFT_KEY
-	dw $6476            ; EXP__ALL
+	dw UnusableItem     ; LIFT_KEY
+	dw UnusableItem     ; EXP__ALL
 	dw OldRodCode       ; OLD_ROD
 	dw GoodRodCode 		; GOOD_ROD $6259
 	dw SuperRodCode     ; SUPER_ROD $6283
-	dw $6317            ; PP_UP (see other?)
-	dw $631E            ; ETHER
-	dw $631E            ; MAX_ETHER
-	dw $631E            ; ELIXER
-	dw $631E            ; MAX_ELIXER
+	dw ItemUsePPUp      ; PP_UP (see other?)
+	dw ItemUsePPRestore ; ETHER
+	dw ItemUsePPRestore ; MAX_ETHER
+	dw ItemUsePPRestore ; ELIXER
+	dw ItemUsePPRestore ; MAX_ELIXER
 
 ItemUseBall: ; 03:5687
 	ld a,[W_ISINBATTLE]
@@ -15528,7 +15528,7 @@
 	and a
 	jp z,ItemUseNotTime ; not in battle
 	dec a
-	jp nz,$658b ; in trainer battle
+	jp nz,ThrowBallAtTrainerMon
 	ld a,[W_BATTLETYPE]
 	dec a
 	jr z,.UseBall\@
@@ -15537,7 +15537,7 @@
 	jr nz,.UseBall\@
 	ld a,[W_NUMINBOX]	;is Box full?
 	cp a,20
-	jp z,$65b1
+	jp z,BoxFullCannotThrowBall
 .UseBall\@	;$56a7
 ;ok, you can use a ball
 	xor a
@@ -15949,29 +15949,704 @@
 	jp $3e6d
 ; 0xda5b
 
-INCBIN "baserom.gbc",$da5b,$df24 - $da5b
+ItemUseEvoStone: ; 5A5B
+	ld a,[W_ISINBATTLE]
+	and a
+	jp nz,ItemUseNotTime
+	ld a,[$cf92]
+	push af
+	ld a,[$cf91]
+	ld [$d156],a
+	push af
+	ld a,$05 ; evolution stone party menu
+	ld [$d07d],a
+	ld a,$ff
+	ld [$cfcb],a
+	call DisplayPartyMenu
+	pop bc
+	jr c,.canceledItemUse\@
+	ld a,b
+	ld [$cf91],a
+	ld a,$01
+	ld [$ccd4],a
+	ld a,$8e
+	call $3740 ; play sound
+	call $3748 ; wait for sound to end
+	ld hl,$6d0e
+	ld b,$0e
+	call Bankswitch ; try to evolve pokemon
+	ld a,[$d121]
+	and a
+	jr z,.noEffect\@
+	pop af
+	ld [$cf92],a
+	ld hl,W_NUMBAGITEMS
+	ld a,1 ; remove 1 stone
+	ld [$cf96],a
+	jp RemoveItemFromInventory
+.noEffect\@
+	call ItemUseNoEffect
+.canceledItemUse\@
+	xor a
+	ld [$cd6a],a
+	pop af
+	ret
 
-UnnamedText_df24: ; 0xdf24
-	TX_FAR _UnnamedText_df24
+ItemUseVitamin: ; 5AB4
+	ld a,[W_ISINBATTLE]
+	and a
+	jp nz,ItemUseNotTime
+
+ItemUseMedicine: ; 5ABB
+	ld a,[W_NUMINPARTY]
+	and a
+	jp z,.emptyParty\@
+	ld a,[$cf92]
+	push af
+	ld a,[$cf91]
+	push af
+	ld a,$01
+	ld [$d07d],a ; item use party menu
+	ld a,$ff
+	ld [$cfcb],a
+	ld a,[$d152]
+	and a ; using Softboiled?
+	jr z,.notUsingSoftboiled\@
+; if using softboiled
+	call GoBackToPartyMenu
+	jr .getPartyMonDataAddress\@
+.emptyParty\@
+	ld hl,.emptyPartyText\@
+	xor a
+	ld [$cd6a],a ; item use failed
+	jp PrintText
+.emptyPartyText\@
+	db $0,"You don't have",$4F
+	db "any #MON!",$58
+.notUsingSoftboiled\@
+	call DisplayPartyMenu
+.getPartyMonDataAddress\@
+	jp c,.canceledItemUse\@
+	ld hl,W_PARTYMON1DATA
+	ld bc,44
+	ld a,[$cf92]
+	call AddNTimes
+	ld a,[$cf92]
+	ld [$cf06],a
+	ld d,a
+	ld a,[$cf91]
+	ld e,a
+	ld [$d0b5],a
+	pop af
+	ld [$cf91],a
+	pop af
+	ld [$cf92],a
+	ld a,[$d152]
+	and a ; using Softboiled?
+	jr z,.checkItemType\@
+; if using softboiled
+	ld a,[$cf92]
+	cp d ; is the pokemon trying to use softboiled on itself?
+	jr z,ItemUseMedicine ; if so, force another choice
+.checkItemType\@
+	ld a,[$cf91]
+	cp a,REVIVE
+	jr nc,.healHP\@ ; if it's a Revive or Max Revive
+	cp a,FULL_HEAL
+	jr z,.cureStatusAilment\@ ; if it's a Full Heal
+	cp a,HP_UP
+	jp nc,.useVitamin\@ ; if it's a vitamin or Rare Candy
+	cp a,FULL_RESTORE
+	jr nc,.healHP\@ ; if it's a Full Restore or one of the potions
+; fall through if it's one of the status-specifc healing items
+.cureStatusAilment\@
+	ld bc,4
+	add hl,bc ; hl now points to status
+	ld a,[$cf91]
+	ld bc,$f008
+	cp a,ANTIDOTE
+	jr z,.checkMonStatus\@
+	ld bc,$f110
+	cp a,BURN_HEAL
+	jr z,.checkMonStatus\@
+	ld bc,$f220
+	cp a,ICE_HEAL
+	jr z,.checkMonStatus\@
+	ld bc,$f307
+	cp a,AWAKENING
+	jr z,.checkMonStatus\@
+	ld bc,$f440
+	cp a,PARLYZ_HEAL
+	jr z,.checkMonStatus\@
+	ld bc,$f6ff ; Full Heal
+.checkMonStatus\@
+	ld a,[hl] ; pokemon's status
+	and c ; does the pokemon have a status ailment the item can cure?
+	jp z,.healingItemNoEffect\@
+; if the pokemon has a status the item can heal
+	xor a
+	ld [hl],a ; remove the status ailment in the party data
+	ld a,b
+	ld [$d07d],a ; the message to display for the item used
+	ld a,[W_PLAYERMONNUMBER]
+	cp d ; is pokemon the item was used on active in battle?
+	jp nz,.doneHealing\@
+; if it is active in battle
+	xor a
+	ld [W_PLAYERMONSTATUS],a ; remove the status ailment in the in-battle pokemon data
+	push hl
+	ld hl,W_PLAYERBATTSTATUS3
+	res 0,[hl] ; heal Toxic status
+	pop hl
+	ld bc,30
+	add hl,bc ; hl now points to party stats
+	ld de,W_PLAYERMONMAXHP
+	ld bc,10
+	call CopyData ; copy party stats to in-battle stat data
+	ld a,$28
+	call Predef
+	jp .doneHealing\@
+.healHP\@
+	inc hl ; hl = address of current HP
+	ld a,[hli]
+	ld b,a
+	ld [$ceec],a
+	ld a,[hl]
+	ld c,a
+	ld [$ceeb],a ; current HP stored at $ceeb (2 bytes, big-endian)
+	or b
+	jr nz,.notFainted\@
+.fainted\@
+	ld a,[$cf91]
+	cp a,REVIVE
+	jr z,.updateInBattleFaintedData\@
+	cp a,MAX_REVIVE
+	jr z,.updateInBattleFaintedData\@
+	jp .healingItemNoEffect\@
+.updateInBattleFaintedData\@
+	ld a,[W_ISINBATTLE]
+	and a
+	jr z,.compareCurrentHPToMaxHP\@
+	push hl
+	push de
+	push bc
+	ld a,[$cf06]
+	ld c,a
+	ld hl,$ccf5
+	ld b,$02
+	ld a,$10
+	call Predef
+	ld a,c
+	and a
+	jr z,.next\@
+	ld a,[$cf06]
+	ld c,a
+	ld hl,$d058
+	ld b,$01
+	ld a,$10
+	call Predef
+.next\@
+	pop bc
+	pop de
+	pop hl
+	jr .compareCurrentHPToMaxHP\@
+.notFainted\@
+	ld a,[$cf91]
+	cp a,REVIVE
+	jp z,.healingItemNoEffect\@
+	cp a,MAX_REVIVE
+	jp z,.healingItemNoEffect\@
+.compareCurrentHPToMaxHP\@
+	push hl
+	push bc
+	ld bc,32
+	add hl,bc ; hl now points to max HP
+	pop bc
+	ld a,[hli]
+	cp b
+	jr nz,.skipComparingLSB\@ ; no need to compare the LSB's if the MSB's don't match
+	ld a,[hl]
+	cp c
+.skipComparingLSB\@
+	pop hl
+	jr nz,.notFullHP\@
+.fullHP\@ ; if the pokemon's current HP equals its max HP
+	ld a,[$cf91]
+	cp a,FULL_RESTORE
+	jp nz,.healingItemNoEffect\@
+	inc hl
+	inc hl
+	ld a,[hld] ; status ailment
+	and a ; does the pokemon have a status ailment?
+	jp z,.healingItemNoEffect\@
+	ld a,FULL_HEAL
+	ld [$cf91],a
+	dec hl
+	dec hl
+	dec hl
+	jp .cureStatusAilment\@
+.notFullHP\@ ; if the pokemon's current HP doesn't equal its max HP
+	xor a
+	ld [$d083],a
+	ld [$c02a],a
+	push hl
+	push de
+	ld bc,32
+	add hl,bc ; hl now points to max HP
+	ld a,[hli]
+	ld [$ceea],a
+	ld a,[hl]
+	ld [$cee9],a ; max HP stored at $cee9 (2 bytes, big-endian)
+	ld a,[$d152]
+	and a ; using Softboiled?
+	jp z,.notUsingSoftboiled2\@
+; if using softboiled
+	ld hl,$cee9
+	ld a,[hli]
+	push af
+	ld a,[hli]
+	push af
+	ld a,[hli]
+	push af
+	ld a,[hl]
+	push af
+	ld hl,W_PARTYMON1_MAXHP
+	ld a,[$cf92]
+	ld bc,44
+	call AddNTimes
+	ld a,[hli]
+	ld [$ceea],a
+	ld [H_DIVIDEND],a
+	ld a,[hl]
+	ld [$cee9],a
+	ld [H_DIVIDEND + 1],a
+	ld a,5
+	ld [H_DIVISOR],a
+	ld b,2 ; number of bytes
+	call Divide ; get 1/5 of max HP of pokemon that used Softboiled
+	ld bc,-33
+	add hl,bc ; hl now points to LSB of current HP of pokemon that used Softboiled
+; subtract 1/5 of max HP from current HP of pokemon that used Softboiled
+	ld a,[H_QUOTIENT + 3]
+	push af
+	ld b,a
+	ld a,[hl]
+	ld [$ceeb],a
+	sub b
+	ld [hld],a
+	ld [$ceed],a
+	ld a,[H_QUOTIENT + 2]
+	ld b,a
+	ld a,[hl]
+	ld [$ceec],a
+	sbc b
+	ld [hl],a
+	ld [$ceee],a
+	ld hl,$c3b8
+	ld a,[$cf92]
+	ld bc,2 * 20
+	call AddNTimes ; calculate coordinates of HP bar of pokemon that used Softboiled
+	ld a,$8d
+	call $3740 ; play sound
+	ld a,[$fff6]
+	set 0,a
+	ld [$fff6],a
+	ld a,$02
+	ld [$cf94],a
+	ld a,$48
+	call Predef ; animate HP bar decrease of pokemon that used Softboiled
+	ld a,[$fff6]
+	res 0,a
+	ld [$fff6],a
+	pop af
+	ld b,a ; store heal amount (1/5 of max HP)
+	ld hl,$ceec
+	pop af
+	ld [hld],a
+	pop af
+	ld [hld],a
+	pop af
+	ld [hld],a
+	pop af
+	ld [hl],a
+	jr .addHealAmount\@
+.notUsingSoftboiled2\@
+	ld a,[$cf91]
+	cp a,SODA_POP
+	ld b,60 ; Soda Pop heal amount
+	jr z,.addHealAmount\@
+	ld b,80 ; Lemonade heal amount
+	jr nc,.addHealAmount\@
+	cp a,FRESH_WATER
+	ld b,50 ; Fresh Water heal amount
+	jr z,.addHealAmount\@
+	cp a,SUPER_POTION
+	ld b,200 ; Hyper Potion heal amount
+	jr c,.addHealAmount\@
+	ld b,50 ; Super Potion heal amount
+	jr z,.addHealAmount\@
+	ld b,20 ; Potion heal amount
+.addHealAmount\@
+	pop de
+	pop hl
+	ld a,[hl]
+	add b
+	ld [hld],a
+	ld [$ceed],a
+	ld a,[hl]
+	ld [$ceee],a
+	jr nc,.noCarry\@
+	inc [hl]
+	ld a,[hl]
+	ld [$ceee],a
+.noCarry\@
+	push de
+	inc hl
+	ld d,h
+	ld e,l ; de now points to current HP
+	ld hl,33
+	add hl,de ; hl now points to max HP
+	ld a,[$cf91]
+	cp a,REVIVE
+	jr z,.setCurrentHPToHalfMaxHP\@
+	ld a,[hld]
+	ld b,a
+	ld a,[de]
+	sub b
+	dec de
+	ld b,[hl]
+	ld a,[de]
+	sbc b
+	jr nc,.setCurrentHPToMaxHp\@ ; if current HP exceeds max HP after healing
+	ld a,[$cf91]
+	cp a,HYPER_POTION
+	jr c,.setCurrentHPToMaxHp\@ ; if using a Full Restore or Max Potion
+	cp a,MAX_REVIVE
+	jr z,.setCurrentHPToMaxHp\@ ; if using a Max Revive
+	jr .updateInBattleData\@
+.setCurrentHPToHalfMaxHP\@
+	dec hl
+	dec de
+	ld a,[hli]
+	srl a
+	ld [de],a
+	ld [$ceee],a
+	ld a,[hl]
+	rr a
+	inc de
+	ld [de],a
+	ld [$ceed],a
+	dec de
+	jr .doneHealingPartyHP\@
+.setCurrentHPToMaxHp\@
+	ld a,[hli]
+	ld [de],a
+	ld [$ceee],a
+	inc de
+	ld a,[hl]
+	ld [de],a
+	ld [$ceed],a
+	dec de
+.doneHealingPartyHP\@ ; done updating the pokemon's current HP in the party data structure
+	ld a,[$cf91]
+	cp a,FULL_RESTORE
+	jr nz,.updateInBattleData\@
+	ld bc,-31
+	add hl,bc
+	xor a
+	ld [hl],a ; remove the status ailment in the party data
+.updateInBattleData\@
+	ld h,d
+	ld l,e
+	pop de
+	ld a,[W_PLAYERMONNUMBER]
+	cp d ; is pokemon the item was used on active in battle?
+	jr nz,.calculateHPBarCoords\@
+; copy party HP to in-battle HP
+	ld a,[hli]
+	ld [W_PLAYERMONCURHP],a
+	ld a,[hld]
+	ld [W_PLAYERMONCURHP + 1],a
+	ld a,[$cf91]
+	cp a,FULL_RESTORE
+	jr nz,.calculateHPBarCoords\@
+	xor a
+	ld [W_PLAYERMONSTATUS],a ; remove the status ailment in the in-battle pokemon data
+.calculateHPBarCoords\@
+	ld hl,$c390
+	ld bc,2 * 20
+	inc d
+.calculateHPBarCoordsLoop\@
+	add hl,bc
+	dec d
+	jr nz,.calculateHPBarCoordsLoop\@
+	jr .doneHealing\@
+.healingItemNoEffect\@
+	call ItemUseNoEffect
+	jp .done\@
+.doneHealing\@
+	ld a,[$d152]
+	and a ; using Softboiled?
+	jr nz,.skipRemovingItem\@ ; no item to remove if using Softboiled
+	push hl
+	call RemoveUsedItem
+	pop hl
+.skipRemovingItem\@
+	ld a,[$cf91]
+	cp a,FULL_RESTORE
+	jr c,.playStatusAilmentCuringSound\@
+	cp a,FULL_HEAL
+	jr z,.playStatusAilmentCuringSound\@
+	ld a,$8d ; HP healing sound
+	call $3740 ; play sound
+	ld a,[$fff6]
+	set 0,a
+	ld [$fff6],a
+	ld a,$02
+	ld [$cf94],a
+	ld a,$48
+	call Predef ; animate the HP bar lengthening
+	ld a,[$fff6]
+	res 0,a
+	ld [$fff6],a
+	ld a,$f7 ; revived message
+	ld [$d07d],a
+	ld a,[$cf91]
+	cp a,REVIVE
+	jr z,.showHealingItemMessage\@
+	cp a,MAX_REVIVE
+	jr z,.showHealingItemMessage\@
+	ld a,$f5 ; standard HP healed message
+	ld [$d07d],a
+	jr .showHealingItemMessage\@
+.playStatusAilmentCuringSound\@
+	ld a,$8e ; status ailment curing sound
+	call $3740 ; play sound
+.showHealingItemMessage\@
+	xor a
+	ld [H_AUTOBGTRANSFERENABLED],a
+	call ClearScreen
+	dec a
+	ld [$cfcb],a
+	call RedrawPartyMenu ; redraws the party menu and displays the message
+	ld a,1
+	ld [H_AUTOBGTRANSFERENABLED],a
+	ld c,50
+	call DelayFrames
+	call $3865 ; wait for a button press
+	jr .done\@
+.canceledItemUse\@
+	xor a
+	ld [$cd6a],a ; item use failed
+	pop af
+	pop af
+.done\@
+	ld a,[$d152]
+	and a ; using Softboiled?
+	ret nz ; if so, return
+	call GBPalWhiteOut
+	call z,GoPAL_SET_CF1C
+	ld a,[W_ISINBATTLE]
+	and a
+	ret nz
+	jp $3071 ; restore saved screen
+.useVitamin\@
+	push hl
+	ld a,[hl]
+	ld [$d0b5],a
+	ld [$d11e],a
+	ld bc,33
+	add hl,bc ; hl now points to level
+	ld a,[hl] ; a = level
+	ld [$d127],a ; store level
+	call GetBaseStats
+	push de
+	ld a,d
+	ld hl,W_PARTYMON1NAME
+	call GetPartyMonName
+	pop de
+	pop hl
+	ld a,[$cf91]
+	cp a,RARE_CANDY
+	jp z,.useRareCandy\@
+	push hl
+	sub a,HP_UP
+	add a
+	ld bc,17
+	add hl,bc
+	add l
+	ld l,a
+	jr nc,.noCarry2\@
+	inc h
+.noCarry2\@
+	ld a,10
+	ld b,a
+	ld a,[hl] ; a = MSB of stat experience of the appropriate stat
+	cp a,100 ; is there already at least 25600 (256 * 100) stat experience?
+	jr nc,.vitaminNoEffect\@ ; if so, vitamins can't add any more
+	add b ; add 2560 (256 * 10) stat experience
+	jr nc,.noCarry3\@ ; a carry should be impossible here, so this will always jump
+	ld a,255
+.noCarry3\@
+	ld [hl],a
+	pop hl
+	call .recalculateStats\@
+	ld hl,VitaminText
+	ld a,[$cf91]
+	sub a,HP_UP - 1
+	ld c,a
+.vitaminNameLoop\@ ; loop to get the address of the name of the vitamin
+	dec c
+	jr z,.next34\@
+.vitaminNameInnerLoop\@
+	ld a,[hli]
+	ld b,a
+	ld a,$50
+	cp b
+	jr nz,.vitaminNameInnerLoop\@
+	jr .vitaminNameLoop\@
+.next34\@
+	ld de,$cf4b
+	ld bc,10
+	call CopyData ; copy the vitamin's name to $cf4b
+	ld a,$8e
+	call $23b1 ; play sound
+	ld hl,VitaminStatRoseText
+	call PrintText
+	jp RemoveUsedItem
+.vitaminNoEffect\@
+	pop hl
+	ld hl,VitaminNoEffectText
+	call PrintText
+	jp GBPalWhiteOut
+.recalculateStats\@
+	ld bc,34
+	add hl,bc
+	ld d,h
+	ld e,l ; de now points to stats
+	ld bc,-18
+	add hl,bc ; hl now points to byte 3 of experience
+	ld b,1
+	jp $3936 ; recalculate stats
+.useRareCandy\@
+	push hl
+	ld bc,33
+	add hl,bc ; hl now points to level
+	ld a,[hl] ; a = level
+	cp a,100
+	jr z,.vitaminNoEffect\@ ; can't raise level above 100
+	inc a
+	ld [hl],a ; store incremented level
+	ld [$d127],a
+	push hl
+	push de
+	ld d,a
+	ld hl,$4f6a
+	ld b,$16
+	call Bankswitch ; calculate experience for next level and store it at $ff96
+	pop de
+	pop hl
+	ld bc,-19
+	add hl,bc ; hl now points to experience
+; update experience to minimum for new level
+	ld a,[$ff96]
+	ld [hli],a
+	ld a,[$ff97]
+	ld [hli],a
+	ld a,[$ff98]
+	ld [hl],a
+	pop hl
+	ld a,[$cf92]
+	push af
+	ld a,[$cf91]
+	push af
+	push de
+	push hl
+	ld bc,34
+	add hl,bc ; hl now points to MSB of max HP
+	ld a,[hli]
+	ld b,a
+	ld c,[hl]
+	pop hl
+	push bc
+	push hl
+	call .recalculateStats\@
+	pop hl
+	ld bc,35 ; hl now points to LSB of max HP
+	add hl,bc
+	pop bc
+	ld a,[hld]
+	sub c
+	ld c,a
+	ld a,[hl]
+	sbc b
+	ld b,a ; bc = the amount of max HP gained from leveling up
+; add the amount gained to the current HP
+	ld de,-32
+	add hl,de ; hl now points to MSB of current HP
+	ld a,[hl]
+	add c
+	ld [hld],a
+	ld a,[hl]
+	adc b
+	ld [hl],a
+	ld a,$f8 ; level up message
+	ld [$d07d],a
+	call RedrawPartyMenu
+	pop de
+	ld a,d
+	ld [$cf92],a
+	ld a,e
+	ld [$d11e],a
+	xor a
+	ld [$cc49],a ; load from player's party
+	call LoadMonData
+	ld d,$01
+	ld hl,$6ae4
+	ld b,$04
+	call Bankswitch ; display new stats text box
+	call $3865 ; wait for button press
+	xor a
+	ld [$cc49],a
+	ld a,$1a
+	call Predef ; learn level up move, if any
+	xor a
+	ld [$ccd4],a
+	ld hl,$6d0e
+	ld b,$0e
+	call Bankswitch ; evolve pokemon, if appropriate
+	ld a,$01
+	ld [$cfcb],a
+	pop af
+	ld [$cf91],a
+	pop af
+	ld [$cf92],a
+	jp RemoveUsedItem
+
+VitaminStatRoseText: ; 5F24
+	TX_FAR _VitaminStatRoseText
 	db $50
-; 0xdf24 + 5 bytes
 
-UnnamedText_df29: ; 0xdf29
-	TX_FAR _UnnamedText_df29
+VitaminNoEffectText: ; 5F29
+	TX_FAR _VitaminNoEffectText
 	db $50
-; 0xdf29 + 5 bytes
 
-INCBIN "baserom.gbc",$df2e,$dfa5 - $df2e
+VitaminText: ; 5F2E
+	db "HEALTH@"
+	db "ATTACK@"
+	db "DEFENSE@"
+	db "SPEED@"
+	db "SPECIAL@"
 
-UnnamedText_dfa5: ; 0xdfa5
-	TX_FAR _UnnamedText_dfa5
+INCBIN "baserom.gbc",$df52,$dfa5 - $df52
+
+ThrewBaitText: ; 0xdfa5
+	TX_FAR _ThrewBaitText
 	db $50
-; 0xdfa5 + 5 bytes
 
-UnnamedText_dfaa: ; 0xdfaa
-	TX_FAR _UnnamedText_dfaa
+ThrewRockText: ; 0xdfaa
+	TX_FAR _ThrewRockText
 	db $50
-; 0xdfaa + 5 bytes
 
 INCBIN "baserom.gbc",$dfaf,$e20b - $dfaf
 
@@ -16073,62 +16748,610 @@
 	db $50
 ; 0xe312 + 5 bytes
 
-INCBIN "baserom.gbc",$e317,$e45d - $e317
+ItemUsePPUp: ; 6317
+	ld a,[W_ISINBATTLE]
+	and a
+	jp nz,ItemUseNotTime
 
-UnnamedText_e45d: ; 0xe45d
-	TX_FAR _UnnamedText_e45d
+ItemUsePPRestore: ; 631E
+	ld a,[$cf92]
+	push af
+	ld a,[$cf91]
+	ld [$cd3d],a
+.chooseMon\@
+	xor a
+	ld [$cfcb],a
+	ld a,$01 ; item use party menu
+	ld [$d07d],a
+	call DisplayPartyMenu
+	jr nc,.chooseMove\@
+	jp .itemNotUsed\@
+.chooseMove\@
+	ld a,[$cd3d]
+	cp a,ELIXER
+	jp nc,.useElixir\@ ; if Elixir or Max Elixir
+	ld a,$02
+	ld [$ccdb],a
+	ld hl,RaisePPWhichTechniqueText
+	ld a,[$cd3d]
+	cp a,ETHER ; is it a PP Up?
+	jr c,.printWhichTechniqueMessage\@ ; if so, print the raise PP message
+	ld hl,RestorePPWhichTechniqueText ; otherwise, print the restore PP message
+.printWhichTechniqueMessage\@
+	call PrintText
+	xor a
+	ld [$cc2e],a
+	ld hl,$5219
+	ld b,$0f
+	call Bankswitch ; move selection menu
+	ld a,0
+	ld [$cc2e],a
+	jr nz,.chooseMon\@
+	ld hl,W_PARTYMON1_MOVE1
+	ld bc,44
+	call GetSelectedMoveOffset
+	push hl
+	ld a,[hl]
+	ld [$d11e],a
+	call GetMoveName
+	call $3826 ; copy name to $cf4b
+	pop hl
+	ld a,[$cd3d]
+	cp a,ETHER
+	jr nc,.useEther\@ ; if Ether or Max Ether
+.usePPUp\@
+	ld bc,21
+	add hl,bc
+	ld a,[hl] ; move PP
+	cp a,3 << 6 ; have 3 PP Ups already been used?
+	jr c,.PPNotMaxedOut\@
+	ld hl,PPMaxedOutText
+	call PrintText
+	jr .chooseMove\@
+.PPNotMaxedOut\@
+	ld a,[hl]
+	add a,1 << 6 ; increase PP Up count by 1
+	ld [hl],a
+	ld a,1 ; 1 PP Up used
+	ld [$d11e],a
+	call RestoreBonusPP ; add the bonus PP to current PP
+	ld hl,PPIncreasedText
+	call PrintText
+.done\@
+	pop af
+	ld [$cf92],a
+	call GBPalWhiteOut
+	call GoPAL_SET_CF1C
+	jp RemoveUsedItem
+.afterRestoringPP\@ ; after using a (Max) Ether/Elixir
+	ld a,[$cf92]
+	ld b,a
+	ld a,[W_PLAYERMONNUMBER]
+	cp b ; is the pokemon whose PP was restored active in battle?
+	jr nz,.skipUpdatingInBattleData\@
+	ld hl,W_PARTYMON1_MOVE1PP
+	ld bc,44
+	call AddNTimes
+	ld de,W_PLAYERMONPP
+	ld bc,4
+	call CopyData ; copy party data to in-battle data
+.skipUpdatingInBattleData\@
+	ld a,$8e
+	call $23b1
+	ld hl,PPRestoredText
+	call PrintText
+	jr .done\@
+.useEther\@
+	call .restorePP\@
+	jr nz,.afterRestoringPP\@
+	jp .noEffect\@
+; unsets zero flag if PP was restored, sets zero flag if not
+; however, this is bugged for Max Ethers and Max Elixirs (see below)
+.restorePP\@
+	xor a
+	ld [$cc49],a ; party pokemon
+	call GetMaxPP
+	ld hl,W_PARTYMON1_MOVE1
+	ld bc,44
+	call GetSelectedMoveOffset
+	ld bc,21
+	add hl,bc ; hl now points to move's PP
+	ld a,[$d11e]
+	ld b,a ; b = max PP
+	ld a,[$cd3d]
+	cp a,MAX_ETHER
+	jr z,.fullyRestorePP\@
+	ld a,[hl] ; move PP
+	and a,%00111111 ; lower 6 bit bits store current PP
+	cp b ; does current PP equal max PP?
+	ret z ; if so, return
+	add a,10 ; increase current PP by 10
+; b holds the max PP amount and b will hold the new PP amount.
+; So, if the new amount meets or exceeds the max amount,
+; cap the amount to the max amount by leaving b unchanged.
+; Otherwise, store the new amount in b.
+	cp b ; does the new amount meet or exceed the maximum?
+	jr nc,.storeNewAmount\@
+	ld b,a
+.storeNewAmount\@
+	ld a,[hl] ; move PP
+	and a,%11000000 ; PP Up counter bits
+	add b
+	ld [hl],a
+	ret
+.fullyRestorePP\@
+	ld a,[hl] ; move PP
+; Note that this code has a bug. It doesn't mask out the upper two bits, which
+; are used to count how many PP Ups have been used on the move. So, Max Ethers
+; and Max Elixirs will not be detected as having no effect on a move with full
+; PP if the move has had any PP Ups used on it.
+	cp b ; does current PP equal max PP?
+	ret z
+	jr .storeNewAmount\@
+.useElixir\@
+; decrement the item ID so that ELIXER becomes ETHER and MAX_ELIXER becomes MAX_ETHER
+	ld hl,$cd3d
+	dec [hl]
+	dec [hl]
+	xor a
+	ld hl,W_CURMENUITEMID
+	ld [hli],a
+	ld [hl],a ; zero the counter for number of moves that had their PP restored
+	ld b,4
+; loop through each move and restore PP
+.elixirLoop\@
+	push bc
+	ld hl,W_PARTYMON1_MOVE1
+	ld bc,44
+	call GetSelectedMoveOffset
+	ld a,[hl]
+	and a ; does the current slot have a move?
+	jr z,.nextMove\@
+	call .restorePP\@
+	jr z,.nextMove\@
+; if some PP was restored
+	ld hl,$cc27 ; counter for number of moves that had their PP restored
+	inc [hl]
+.nextMove\@
+	ld hl,W_CURMENUITEMID
+	inc [hl]
+	pop bc
+	dec b
+	jr nz,.elixirLoop\@
+	ld a,[$cc27]
+	and a ; did any moves have their PP restored?
+	jp nz,.afterRestoringPP\@
+.noEffect\@
+	call ItemUseNoEffect
+.itemNotUsed\@
+	call GBPalWhiteOut
+	call GoPAL_SET_CF1C
+	pop af
+	xor a
+	ld [$cd6a],a ; item use failed
+	ret
+
+RaisePPWhichTechniqueText: ; 645D
+	TX_FAR _RaisePPWhichTechniqueText
 	db $50
-; 0xe45d + 5 bytes
 
-UnnamedText_e462: ; 0xe462
-	TX_FAR _UnnamedText_e462
+RestorePPWhichTechniqueText: ; 6462
+	TX_FAR _RestorePPWhichTechniqueText
 	db $50
-; 0xe462 + 5 bytes
 
-UnnamedText_e467: ; 0xe467
-	TX_FAR _UnnamedText_e467
+PPMaxedOutText: ; 6467
+	TX_FAR _PPMaxedOutText
 	db $50
-; 0xe467 + 5 bytes
 
-UnnamedText_e46c: ; 0xe46c
-	TX_FAR _UnnamedText_e46c
+PPIncreasedText: ; 646C
+	TX_FAR _PPIncreasedText
 	db $50
-; 0xe46c + 5 bytes
 
-UnnamedText_e471: ; 0xe471
-	TX_FAR _UnnamedText_e471
+PPRestoredText: ; 6471
+	TX_FAR _PPRestoredText
 	db $50
-; 0xe471 + 5 bytes
 
-; 0xe476 XXX
-db $c3, $81, $65
+; for items that can't be used from the Item menu
+UnusableItem: ; 6476
+	jp ItemUseNotTime
 
-ItemUseTMHM: ; 03:6479
-	INCBIN "baserom.gbc",$E479,$E581 - $E479
-ItemUseNotTime: ; 03:6581
-	INCBIN "baserom.gbc",$E581,$E5E8 - $E581
-ItemUseText00: ; 03:65e8
+ItemUseTMHM: ; 6479
+	ld a,[W_ISINBATTLE]
+	and a
+	jp nz,ItemUseNotTime
+	ld a,[$cf91]
+	sub a,TM_01
+	push af
+	jr nc,.skipAdding\@
+	add a,55 ; if item is an HM, add 55
+.skipAdding\@
+	inc a
+	ld [$d11e],a
+	ld a,$44
+	call Predef ; get move ID from TM/HM ID
+	ld a,[$d11e]
+	ld [$d0e0],a
+	call GetMoveName
+	call $3826 ; copy name to $cf4b
+	pop af
+	ld hl,BootedUpTMText
+	jr nc,.printBootedUpMachineText\@
+	ld hl,BootedUpHMText
+.printBootedUpMachineText\@
+	call PrintText
+	ld hl,TeachMachineMoveText
+	call PrintText
+	FuncCoord 14,7
+	ld hl,Coord
+	ld bc,$080f
+	ld a,$14
+	ld [$d125],a
+	call DisplayTextBoxID ; yes/no menu
+	ld a,[W_CURMENUITEMID]
+	and a
+	jr z,.useMachine\@
+	ld a,2
+	ld [$cd6a],a ; item not used
+	ret
+.useMachine\@
+	ld a,[$cf92]
+	push af
+	ld a,[$cf91]
+	push af
+.chooseMon\@
+	ld hl,$cf4b
+	ld de,$d036
+	ld bc,14
+	call CopyData
+	ld a,$ff
+	ld [$cfcb],a
+	ld a,$03 ; teach TM/HM party menu
+	ld [$d07d],a
+	call DisplayPartyMenu
+	push af
+	ld hl,$d036
+	ld de,$cf4b
+	ld bc,14
+	call CopyData
+	pop af
+	jr nc,.checkIfAbleToLearnMove\@
+; if the player canceled teaching the move
+	pop af
+	pop af
+	call GBPalWhiteOutWithDelay3
+	call CleanLCD_OAM
+	call GoPAL_SET_CF1C
+	jp $3725 ; restore saved screen
+.checkIfAbleToLearnMove\@
+	ld a,$43
+	call Predef ; check if the pokemon can learn the move
+	push bc
+	ld a,[$cf92]
+	ld hl,W_PARTYMON1NAME
+	call GetPartyMonName
+	pop bc
+	ld a,c
+	and a ; can the pokemon learn the move?
+	jr nz,.checkIfAlreadyLearnedMove\@
+; if the pokemon can't learn the move
+	ld a,$a5
+	call $3740 ; play sound
+	ld hl,MonCannotLearnMachineMoveText
+	call PrintText
+	jr .chooseMon\@
+.checkIfAlreadyLearnedMove\@
+	ld hl,$7e18
+	ld b,$0b
+	call Bankswitch ; check if the pokemon already knows the move
+	jr c,.chooseMon\@
+	ld a,$1b
+	call Predef ; teach move
+	pop af
+	ld [$cf91],a
+	pop af
+	ld [$cf92],a
+	ld a,b
+	and a
+	ret z
+	ld a,[$cf91]
+	call IsItemHM
+	ret c
+	jp RemoveUsedItem
+
+BootedUpTMText: ; 654F
+	TX_FAR _BootedUpTMText
+	db $50
+
+BootedUpHMText: ; 6554
+	TX_FAR _BootedUpHMText
+	db $50
+
+TeachMachineMoveText: ; 6559
+	TX_FAR _TeachMachineMoveText
+	db $50
+
+MonCannotLearnMachineMoveText: ; 655E
+	TX_FAR _MonCannotLearnMachineMoveText
+	db $50
+
+PrintItemUseTextAndRemoveItem: ; 6563
+	ld hl,ItemUseText00
+	call PrintText
+	ld a,$8e
+	call $23b1 ; play sound
+	call $3865 ; wait for button press
+
+RemoveUsedItem: ; 6571
+	ld hl,W_NUMBAGITEMS
+	ld a,1 ; one item
+	ld [$cf96],a ; store quantity
+	jp RemoveItemFromInventory
+
+ItemUseNoEffect: ; 657C
+	ld hl,ItemUseNoEffectText
+	jr ItemUseFailed
+
+ItemUseNotTime: ; 6581
+	ld hl,ItemUseNotTimeText
+	jr ItemUseFailed
+
+ItemUseNotYoursToUse: ; 6586
+	ld hl,ItemUseNotYoursToUseText
+	jr ItemUseFailed
+
+ThrowBallAtTrainerMon: ; 658B
+	call GoPAL_SET_CF1C
+	call $3725 ; restore saved screen
+	call Delay3
+	ld a,TOSS_ANIM
+	ld [W_ANIMATIONID],a
+	ld a,$08
+	call Predef ; do animation
+	ld hl,ThrowBallAtTrainerMonText1
+	call PrintText
+	ld hl,ThrowBallAtTrainerMonText2
+	call PrintText
+	jr RemoveUsedItem
+
+NoCyclingAllowedHere: ; 65AC
+	ld hl,NoCyclingAllowedHereText
+	jr ItemUseFailed
+
+BoxFullCannotThrowBall: ; 65B1
+	ld hl,BoxFullCannotThrowBallText
+	jr ItemUseFailed
+
+SurfingAttemptFailed: ; 65B6
+	ld hl,NoSurfingHereText
+
+ItemUseFailed: ; 65B9
+	xor a
+	ld [$cd6a],a ; item use failed
+	jp PrintText
+
+ItemUseNotTimeText: ; 65C0
+	TX_FAR _ItemUseNotTimeText
+	db $50
+
+ItemUseNotYoursToUseText: ; 65C5
+	TX_FAR _ItemUseNotYoursToUseText
+	db $50
+
+ItemUseNoEffectText: ; 65CA
+	TX_FAR _ItemUseNoEffectText
+	db $50
+
+ThrowBallAtTrainerMonText1: ; 65CF
+	TX_FAR _ThrowBallAtTrainerMonText1
+	db $50
+
+ThrowBallAtTrainerMonText2: ; 65D4
+	TX_FAR _ThrowBallAtTrainerMonText2
+	db $50
+
+NoCyclingAllowedHereText: ; 65D9
+	TX_FAR _NoCyclingAllowedHereText
+	db $50
+
+NoSurfingHereText: ; 65DE
+	TX_FAR _NoSurfingHereText
+	db $50
+
+BoxFullCannotThrowBallText: ; 65E3
+	TX_FAR _BoxFullCannotThrowBallText
+	db $50
+
+ItemUseText00: ; 65E8
 	TX_FAR _ItemUseText001
 	db $05
 	TX_FAR _ItemUseText002
-	db "@"
+	db $50
 
-INCBIN "baserom.gbc",$e5f2,$e5f7 - $e5f2
+GotOnBicycleText: ; 65F2
+	TX_FAR _GotOnBicycleText1
+	db $05
+	TX_FAR _GotOnBicycleText2
+	db $50
 
-UnnamedText_e5f7: ; 0xe5f7
-	TX_FAR _UnnamedText_e5f7
+GotOffBicycleText: ; 65FC
+	TX_FAR _GotOffBicycleText1
+	db $05
+	TX_FAR _GotOffBicycleText2
 	db $50
-; 0xe5f7 + 5 bytes
 
-INCBIN "baserom.gbc",$e5fc,$e601 - $e5fc
+; restores bonus PP (from PP Ups) when healing at a pokemon center
+; also, when a PP Up is used, it increases the current PP by one PP Up bonus
+; INPUT:
+; [$cf92] = index of pokemon in party
+; [$d11e] = mode
+; 0: Pokemon Center healing
+; 1: using a PP Up
+; [CURMENUITEMID] = index of move (when using a PP Up)
+RestoreBonusPP: ; 6606
+	ld hl,W_PARTYMON1_MOVE1
+	ld bc,44
+	ld a,[$cf92]
+	call AddNTimes
+	push hl
+	ld de,$cd78 - 1
+	ld a,$5e
+	call Predef ; loads the normal max PP of each of the pokemon's moves to $cd78
+	pop hl
+	ld c,21
+	ld b,0
+	add hl,bc ; hl now points to move 1 PP
+	ld de,$cd78
+	ld b,0 ; initialize move counter to zero
+; loop through the pokemon's moves
+.loop\@
+	inc b
+	ld a,b
+	cp a,5 ; reached the end of the pokemon's moves?
+	ret z ; if so, return
+	ld a,[$d11e]
+	dec a ; using a PP Up?
+	jr nz,.skipMenuItemIDCheck\@
+; if using a PP Up, check if this is the move it's being used on
+	ld a,[W_CURMENUITEMID]
+	inc a
+	cp b
+	jr nz,.nextMove\@
+.skipMenuItemIDCheck\@
+	ld a,[hl]
+	and a,%11000000 ; have any PP Ups been used?
+	call nz,AddBonusPP ; if so, add bonus PP
+.nextMove\@
+	inc hl
+	inc de
+	jr .loop\@
 
-UnnamedText_e601: ; 0xe601
-	TX_FAR _UnnamedText_e601
-	db $50
-; 0xe601 + 5 bytes
+; adds bonus PP from PP Ups to current PP
+; 1/5 of normal max PP (capped at 7) is added for each PP Up
+; INPUT:
+; [de] = normal max PP
+; [hl] = move PP
+; [$d11e] = max number of times to add bonus
+; set to 1 when using a PP Up, set to 255 otherwise
+AddBonusPP: ; 6642
+	push bc
+	ld a,[de] ; normal max PP of move
+	ld [H_DIVIDEND + 3],a
+	xor a
+	ld [H_DIVIDEND],a
+	ld [H_DIVIDEND + 1],a
+	ld [H_DIVIDEND + 2],a
+	ld a,5
+	ld [H_DIVISOR],a
+	ld b,4
+	call Divide
+	ld a,[hl] ; move PP
+	ld b,a
+	swap a
+	and a,%00001111
+	srl a
+	srl a
+	ld c,a ; c = number of PP Ups used
+.loop\@
+	ld a,[H_QUOTIENT + 3]
+	cp a,8 ; is the amount greater than or equal to 8?
+	jr c,.addAmount\@
+	ld a,7 ; cap the amount at 7
+.addAmount\@
+	add b
+	ld b,a
+	ld a,[$d11e]
+	dec a
+	jr z,.done\@
+	dec c
+	jr nz,.loop\@
+.done\@
+	ld [hl],b
+	pop bc
+	ret
 
-INCBIN "baserom.gbc",$e606,$e6f1 - $e606
+; gets max PP of a pokemon's move (including PP from PP Ups)
+; INPUT:
+; [$cf92] = index of pokemon within party/box
+; [$cc49] = pokemon source
+; 00: player's party
+; 01: enemy's party
+; 02: current box
+; 03: daycare
+; 04: player's in-battle pokemon
+; [W_CURMENUITEMID] = move index
+; OUTPUT:
+; [$d11e] = max PP
+GetMaxPP: ; 6677
+	ld a,[$cc49]
+	and a
+	ld hl,W_PARTYMON1_MOVE1
+	ld bc,44
+	jr z,.sourceWithMultipleMon\@
+	ld hl,$d8ac ; enemy party
+	dec a
+	jr z,.sourceWithMultipleMon\@
+	ld hl,$da9e ; current box
+	ld bc,33
+	dec a
+	jr z,.sourceWithMultipleMon\@
+	ld hl,$da67 ; daycare
+	dec a
+	jr z,.sourceWithOneMon\@
+	ld hl,$d01c ; player's in-battle pokemon
+.sourceWithOneMon\@
+	call GetSelectedMoveOffset2
+	jr .next\@
+.sourceWithMultipleMon\@
+	call GetSelectedMoveOffset
+.next\@
+	ld a,[hl]
+	dec a
+	push hl
+	ld hl,Moves
+	ld bc,6
+	call AddNTimes
+	ld de,$cd6d
+	ld a,BANK(Moves)
+	call FarCopyData
+	ld de,$cd72
+	ld a,[de]
+	ld b,a ; b = normal max PP
+	pop hl
+	push bc
+	ld bc,21 ; PP offset if not player's in-battle pokemon data
+	ld a,[$cc49]
+	cp a,4 ; player's in-battle pokemon?
+	jr nz,.addPPOffset\@
+	ld bc,17 ; PP offset if player's in-battle pokemon data
+.addPPOffset\@
+	add hl,bc
+	ld a,[hl] ; a = current PP
+	and a,%11000000 ; get PP Up count
+	pop bc
+	or b ; place normal max PP in 6 lower bits of a
+	ld h,d
+	ld l,e
+	inc hl ; hl = $cd73
+	ld [hl],a
+	xor a
+	ld [$d11e],a ; no limit on PP Up amount
+	call AddBonusPP ; add bonus PP from PP Ups
+	ld a,[hl]
+	and a,%00111111 ; mask out the PP Up count
+	ld [$d11e],a ; store max PP
+	ret
 
+GetSelectedMoveOffset: ; 66E3
+	ld a,[$cf92]
+	call AddNTimes
+
+GetSelectedMoveOffset2: ; 66E9
+	ld a,[W_CURMENUITEMID]
+	ld c,a
+	ld b,0
+	add hl,bc
+	ret
+
 ; confirms the item toss and then tosses the item
 ; INPUT:
 ; hl = address of inventory (either W_NUMBAGITEMS or W_NUMBOXITEMS)
@@ -84695,50 +85918,38 @@
 
 _ItemUseBallText06:
 	db 0,"New #DEX data",$4F
-	db "will be added for",$55,"@",1
-	dw $CFDA
+	db "will be added for",$55,"@"
+	TX_RAM $cfda
 	db 0,"!@@"
 
 _UnnamedText_da4c: ; 0xa685e
 	db $0, $52, " got on", $4f
 	db "@"
-; 0xa685e + 11 bytes
-
-UnnamedText_a6869: ; 0xa6869
 	TX_RAM $cd6d
 	db $0, "!", $58
-; 0xa686f
 
 _UnnamedText_da51: ; 0xa686f
 	db $0, "There's no place", $4f
 	db "to get off!", $58
-; 0xa686f + 29 bytes
 
-_UnnamedText_df24: ; 0xa688c
+_VitaminStatRoseText: ; 0xa688c
 	TX_RAM $cd6d
 	db $0, "'s", $4f
 	db "@"
-; 0xa688c + 7 bytes
-
-UnnamedText_a6893: ; 0xa6893
 	TX_RAM $cf4b
 	db $0, " rose.", $58
-; 0xa689e
 
-_UnnamedText_df29: ; 0xa689e
+_VitaminNoEffectText: ; 0xa689e
 	db $0, "It won't have any", $4f
 	db "effect.", $58
-; 0xa689e + 26 bytes
 
-_UnnamedText_dfa5: ; 0xa68b8
+_ThrewBaitText: ; 0xa68b8
 	db $0, $52, " threw", $4f
 	db "some BAIT.", $57
-; 0xa68b8 + 20 bytes
 
-_UnnamedText_dfaa: ; 0xa68cc
+_ThrewRockText: ; 0xa68cc
 	db $0, $52, " threw a", $4f
 	db "ROCK.", $57
-; 0xa68cc + 17 bytes
 
 _UnnamedText_e20b: ; 0xa68dd
 	db $0, "Played the #", $4f
@@ -84777,41 +85988,39 @@
 	db "isn't responding.", $58
 ; 0xa6981 + 35 bytes
 
-_UnnamedText_e45d: ; 0xa69a4
+_RaisePPWhichTechniqueText: ; 0xa69a4
 	db $0, "Raise PP of which", $4f
 	db "technique?", $57
 ; 0xa69a4 + 30 bytes
 
-_UnnamedText_e462: ; 0xa69c2
+_RestorePPWhichTechniqueText: ; 0xa69c2
 	db $0, "Restore PP of", $4f
 	db "which technique?", $57
 ; 0xa69c2 + 32 bytes
 
-_UnnamedText_e467: ; 0xa69e2
+_PPMaxedOutText: ; 0xa69e2
 	TX_RAM $cf4b
 	db $0, "'s PP", $4f
 	db "is maxed out.", $58
 ; 0xa69e2 + 23 bytes
 
-_UnnamedText_e46c: ; 0xa69f9
+_PPIncreasedText: ; 0xa69f9
 	TX_RAM $cf4b
 	db $0, "'s PP", $4f
 	db "increased.", $58
 ; 0xa69f9 + 20 bytes
 
-_UnnamedText_e471: ; 0xa6a0d
+_PPRestoredText: ; 0xa6a0d
 	db $0, "PP was restored.", $58
 ; 0xa6a0d + 18 bytes
 
-UnnamedText_a6a1f: ; 0xa6a1f
+_BootedUpTMText: ; 0xa6a1f
 	db $0, "Booted up a TM!", $58
-; 0xa6a30
 
-UnnamedText_a6a30: ; 0xa6a30
+_BootedUpHMText: ; 0xa6a30
 	db $0, "Booted up an HM!", $58
-; 0xa6a42
 
-UnnamedText_a6a42: ; 0xa6a42
+_TeachMachineMoveText: ; 0xa6a42
 	db $0, "It contained", $4f
 	db "@"
 	TX_RAM $cf4b
@@ -84820,9 +86029,8 @@
 	TX_RAM $cf4b
 	db $0, $4f
 	db "to a #MON?", $57
-; 0xa6a6e
 
-UnnamedText_a6a6e: ; 0xa6a6e
+_MonCannotLearnMachineMoveText: ; 0xa6a6e
 	TX_RAM $cd6d
 	db $0, " is not", $4f
 	db "compatible with", $55
@@ -84831,57 +86039,43 @@
 	db $0, ".", $51
 	db "It can't learn", $4f
 	db "@"
-; 0xa6a8b + 21 bytes = 0xa6aa0
-
-UnnamedText_a6aa0: ; 0xa6aa0
 	TX_RAM $cf4b
 	db $0, ".", $58
-; 0xa6aa0 + 6 bytes = 0xa6aa6
 
-UnnamedText_a6aa6: ; 0xa6aa6
+_ItemUseNotTimeText: ; 0xa6aa6
 	db $0, "OAK: ", $52, "!", $4f
 	db "This isn't the", $55
 	db "time to use that! ", $58
-; 0xa6aa6 + 42 bytes = 0xa6ad0
 
-UnnamedText_a6ad0: ; 0xa6ad0
+_ItemUseNotYoursToUseText: ; 0xa6ad0
 	db $0, "This isn't yours", $4f
 	db "to use!", $58
-; 0xa6ad0 + 25 bytes = 0xa6ae9
 
-UnnamedText_a6ae9: ; 0xa6ae9
+_ItemUseNoEffectText: ; 0xa6ae9
 	db $0, "It won't have any", $4f
 	db "effect.", $58
 ; 0xa6ae9 + 26 bytes = 0xa6b03
 
-UnnamedText_a6b03: ; 0xa6b03
+_ThrowBallAtTrainerMonText1: ; 0xa6b03
 	db $0, "The trainer", $4f
 	db "blocked the BALL!", $58
-; 0xa6b03 + 31 bytes = 0xa6b22
 
-UnnamedText_a6b22: ; 0xa6b22
+_ThrowBallAtTrainerMonText2: ; 0xa6b22
 	db $0, "Don't be a thief!", $58
-; 0xa6b22 + 18 bytes = 0xa6b34
 
-UnnamedText_a6b34: ; 0xa6b34
+_NoCyclingAllowedHereText: ; 0xa6b34
 	db $0, "No cycling", $4e, "allowed here.", $58
-; 0xa6b34 + 26 bytes = 0xa6b4e
 
-UnnamedText_a6b4e: ; 0xa6b4e
+_NoSurfingHereText: ; 0xa6b4e
 	db $0, "No SURFing on", $4f
 	db "@"
-; 0xa6b4e + 16 bytes = 0xa6b5e
-
-UnnamedText_a6b5e: ; 0xa6b5e
 	TX_RAM $cd6d
 	db $0, " here!", $58
-; 0xa6b5e + 11 bytes = 0xa6b69
 
-UnnamedText_a6b69: ; 0xa6b69
+_BoxFullCannotThrowBallText: ; 0xa6b69
 	db $0, "The #MON BOX", $4f
 	db "is full! Can't", $55
 	db "use that item!", $58
-; 0xa6b69 + 43 bytes = 0xa6b94
 
 SECTION "bank2A",DATA,BANK[$2A]
 
@@ -84891,62 +86085,46 @@
 _ItemUseText002: ; 0xa8009
 	TX_RAM $cf4b
 	db $0, "!", $57
-; 0xa800e
 
-UnnamedText_a800f: ; 0xa800f
+_GotOnBicycleText1: ; 0xa800f
 	db $0, $52, " got on the@@"
-; 0xa801e
 
-_UnnamedText_e5f7: ; 0xa801e
+_GotOnBicycleText2: ; 0xa801e
 	TX_RAM $cf4b
 	db $0, "!", $58
-; 0xa801e + 6 bytes
 
-UnnamedText_a8024: ; 0xa8024
+_GotOffBicycleText1: ; 0xa8024
 	db $0, $52, " got off@@"
-; 0xa8030
 
-_UnnamedText_e601: ; 0xa8030
+_GotOffBicycleText2: ; 0xa8030
 	db $0, "the @"
 	TX_RAM $cf4b
 	db $0, ".", $58
-; 0xa803c
 
 _ThrewAwayItemText: ; 0xa803c
 	db $0, "Threw away", $4f
 	db "@"
-; 0xa803c + 13 bytes
 
 UnnamedText_a8049: ; 0xa8049
 	TX_RAM $cd6d
 	db $0, ".", $58
-; 0xa804f
 
 _IsItOKToTossItemText: ; 0xa804f
 	db $0, "Is it OK to toss", $4f
 	db "@"
-; 0xa804f + 19 bytes
-
-UnnamedText_a8062: ; 0xa8062
 	TX_RAM $cf4b
 	db $0, "?", $58
-; 0xa8068
 
 _TooImportantToTossText: ; 0xa8068
 	db $0, "That's too impor-", $4f
 	db "tant to toss!", $58
-; 0xa8068 + 32 bytes
 
 _UnnamedText_2fe3b: ; 0xa8088
 	TX_RAM $cd6d
 	db $0, " knows", $4f
 	db "@"
-; 0xa8088 + 12 bytes
-
-UnnamedText_a8094: ; 0xa8094
 	TX_RAM $cf4b
 	db $0, "!", $58
-; 0xa809a
 
 _UnnamedText_71d88: ; 0xa809a
 	db $0, "Okay, connect the", $4f
@@ -84956,21 +86134,15 @@
 _UnnamedText_71d8d: ; 0xa80bc
 	db $0, $52, " traded", $4f
 	db "@"
-
-UnnamedText_a80c7: ; 0xa80c7
 	TX_RAM $cd13
 	db $0, " for", $55
 	db "@"
 	TX_RAM $cd1e
 	db $0, "!@@"
-; 0xa80d8
 
 _UnnamedText_71d94: ; 0xa80d8
 	db $0, "I'm looking for", $4f
 	db "@"
-; 0xa80d8 + 17 bytes
-
-UnnamedText_a80e9: ; 0xa80e9
 	TX_RAM $cd13
 	db $0, "! Wanna", $51
 	db "trade one for", $4f
@@ -84977,7 +86149,6 @@
 	db "@"
 	TX_RAM $cd1e
 	db $0, "? ", $57
-; 0xa810b
 
 _UnnamedText_71d99: ; 0xa810b
 	db $0, "Awww!", $4f
@@ -85003,26 +86174,18 @@
 _UnnamedText_71da8: ; 0xa8162
 	db $0, "Isn't my old", $4f
 	db "@"
-; 0xa8162 + 14 bytes
-
-UnnamedText_a8170: ; 0xa8170
 	TX_RAM $cd1e
 	db $0, " great?", $57
-; 0xa8170
 
 _UnnamedText_71dad: ; 0xa817c
 	db $0, "Hello there! Do", $4f
 	db "you want to trade", $51
 	db "your @"
-; 0xa817c + 41 bytes
-
-UnnamedText_a81a5: ; 0xa81a5
 	TX_RAM $cd13
 	db $0, $4f
 	db "for @"
 	TX_RAM $cd1e
 	db $0, "?", $57
-; 0xa81b5
 
 _UnnamedText_71db2: ; 0xa81b5
 	db $0, "Well, if you", $4f
@@ -85090,11 +86253,11 @@
 ; 0xa82f8
 
 ; XXX
-db $0, $93, $a7, $a4, $b1, $a4, $7f, $a8, $b2, $ad, $be, $4f
-db $a0, $ad, $b8, $b3, $a7, $a8, $ad, $a6, $7f, $b3, $ae, $7f, $82, $94, $93, $e7, $58
-db $1, $6d, $cd
-db $0, $7f, $a7, $a0, $a2, $aa, $a4, $a3, $4f
-db $a0, $b6, $a0, $b8, $7f, $b6, $a8, $b3, $a7, $7f, $82, $94, $93, $e7, $58
+	db $0, "There isn't", $4f
+	db "anything to CUT!", $58
+	TX_RAM $cd6d
+	db $0, " hacked", $4f
+	db "away with CUT!", $58
 
 SECTION "bank2B",DATA,BANK[$2B]