summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorDizzyEggg <jajkodizzy@wp.pl>2018-08-15 15:49:50 +0200
committerDizzyEggg <jajkodizzy@wp.pl>2018-08-15 15:49:50 +0200
commita54fa23b5f30b0c6cc24f211137b3f6c892b3cd5 (patch)
tree8481dd7726e866f400ebddedb820edc7fae58b86 /src
parent6dac87abfd2bea0ddf126cdc1e9c31757c8fee36 (diff)
Begin battle frontier 1
Diffstat (limited to 'src')
-rw-r--r--src/battle_frontier_1.c1235
1 files changed, 1235 insertions, 0 deletions
diff --git a/src/battle_frontier_1.c b/src/battle_frontier_1.c
new file mode 100644
index 000000000..b84e91973
--- /dev/null
+++ b/src/battle_frontier_1.c
@@ -0,0 +1,1235 @@
+#include "global.h"
+#include "battle.h"
+#include "battle_setup.h"
+#include "battle_frontier_1.h"
+#include "event_data.h"
+#include "overworld.h"
+#include "util.h"
+#include "malloc.h"
+#include "constants/species.h"
+
+struct Unknown_0203BC8C_Struct
+{
+ u16 field_0;
+ u8 field_2;
+ u8 field_3;
+ u8 field_4;
+ u8 field_5;
+ u8 field_6;
+ u8 field_7;
+ u8 field_8;
+ u8 field_9;
+ u8 field_A;
+ u8 field_B;
+ u8 field_C;
+ u8 field_D;
+ u8 field_E;
+};
+
+extern struct Unknown_0203BC8C_Struct *gUnknown_0203BC8C;
+
+extern void sub_81B8558(void);
+extern u32 sub_81A39C4(void);
+extern u16 sub_8162548(u8, u8);
+extern u16 sub_8163524(u16);
+extern u8 sub_8165C40(void);
+
+extern u8 gUnknown_0203CEF8[];
+
+extern void (* const gUnknown_0860D090[])(void);
+extern const u32 gUnknown_0860D0EC[][2];
+extern const u32 gUnknown_0860D0FC[][2];
+
+// This file's functions.
+u8 sub_8190168(u16);
+void sub_818F720(u16 species, s32 level, s32 ivs, u8 evBits, u8 nature, s32 *stats);
+
+// code
+void sub_818E9AC(void)
+{
+ gUnknown_0860D090[gSpecialVar_0x8004]();
+}
+
+void sub_818E9CC(void)
+{
+ u32 lvlMode = gSaveBlock2Ptr->frontier.chosenLvl;
+ u32 id = VarGet(VAR_0x40CE);
+
+ gSaveBlock2Ptr->frontier.field_CA8 = 0;
+ gSaveBlock2Ptr->frontier.field_CB2 = 0;
+ gSaveBlock2Ptr->frontier.field_CA9_a = 0;
+ gSaveBlock2Ptr->frontier.field_CA9_b = 0;
+ if (!(gSaveBlock2Ptr->frontier.field_CDC & gUnknown_0860D0EC[id][lvlMode]))
+ gSaveBlock2Ptr->frontier.field_D0C[id][lvlMode] = 0;
+
+ saved_warp2_set(0, gSaveBlock1Ptr->location.mapGroup, gSaveBlock1Ptr->location.mapNum, -1);
+ gTrainerBattleOpponent_A = 0;
+}
+
+void sub_818EA84(void)
+{
+ u32 lvlMode = gSaveBlock2Ptr->frontier.chosenLvl;
+ u32 id = VarGet(VAR_0x40CE);
+
+ switch (gSpecialVar_0x8005)
+ {
+ case 0:
+ gSpecialVar_Result = gSaveBlock2Ptr->frontier.field_D0C[id][lvlMode];
+ break;
+ case 1:
+ gSpecialVar_Result = ((gSaveBlock2Ptr->frontier.field_CDC & gUnknown_0860D0EC[id][lvlMode]) != 0);
+ break;
+ case 2:
+ gSpecialVar_Result = gSaveBlock2Ptr->frontier.field_D08_0;
+ break;
+ case 3:
+ gSpecialVar_Result = gSaveBlock2Ptr->frontier.field_D08_1;
+ break;
+ case 4:
+ gSpecialVar_Result = gSaveBlock2Ptr->frontier.field_D08_2;
+ break;
+ case 5:
+ gSpecialVar_Result = gSaveBlock2Ptr->frontier.field_D08_3;
+ break;
+ case 6:
+ if (VarGet(VAR_0x40CE) == 1)
+ {
+ if (lvlMode)
+ gSpecialVar_Result = gSaveBlock2Ptr->frontier.field_D08_5;
+ else
+ gSpecialVar_Result = gSaveBlock2Ptr->frontier.field_D08_4;
+ }
+ else
+ {
+ if (lvlMode)
+ gSpecialVar_Result = gSaveBlock2Ptr->frontier.field_D08_1;
+ else
+ gSpecialVar_Result = gSaveBlock2Ptr->frontier.field_D08_0;
+ }
+ break;
+ case 7:
+ if (VarGet(VAR_0x40CE) == 1)
+ {
+ if (lvlMode)
+ gSpecialVar_Result = gSaveBlock2Ptr->frontier.field_D08_7;
+ else
+ gSpecialVar_Result = gSaveBlock2Ptr->frontier.field_D08_6;
+ }
+ else
+ {
+ if (lvlMode)
+ gSpecialVar_Result = gSaveBlock2Ptr->frontier.field_D08_3;
+ else
+ gSpecialVar_Result = gSaveBlock2Ptr->frontier.field_D08_2;
+ }
+ break;
+ case 8:
+ sub_81B8558();
+ gUnknown_0203CEF8[0] = gSaveBlock2Ptr->frontier.field_CB0;
+ gUnknown_0203CEF8[1] = gSaveBlock2Ptr->frontier.field_CB0 >> 8;
+ break;
+ case 9:
+ gSpecialVar_Result = (gSaveBlock2Ptr->frontier.field_D0A * 2) - 3 + gSaveBlock2Ptr->frontier.field_D0B;
+ break;
+ }
+}
+
+void sub_818ED28(void)
+{
+ u32 lvlMode = gSaveBlock2Ptr->frontier.chosenLvl;
+ u32 id = VarGet(VAR_0x40CE);
+
+ switch (gSpecialVar_0x8005)
+ {
+ case 0:
+ gSaveBlock2Ptr->frontier.field_D0C[id][lvlMode] = gSpecialVar_0x8006;
+ break;
+ case 1:
+ if (gSpecialVar_0x8006)
+ gSaveBlock2Ptr->frontier.field_CDC |= gUnknown_0860D0EC[id][lvlMode];
+ else
+ gSaveBlock2Ptr->frontier.field_CDC &= gUnknown_0860D0FC[id][lvlMode];
+ break;
+ case 2:
+ gSaveBlock2Ptr->frontier.field_D08_0 = gSpecialVar_0x8006;
+ break;
+ case 3:
+ gSaveBlock2Ptr->frontier.field_D08_1 = gSpecialVar_0x8006;
+ break;
+ case 4:
+ gSaveBlock2Ptr->frontier.field_D08_2 = gSpecialVar_0x8006;
+ break;
+ case 5:
+ gSaveBlock2Ptr->frontier.field_D08_3 = gSpecialVar_0x8006;
+ break;
+ case 6:
+ if (VarGet(VAR_0x40CE) == 1)
+ {
+ if (lvlMode)
+ gSaveBlock2Ptr->frontier.field_D08_5 = gSpecialVar_0x8006;
+ else
+ gSaveBlock2Ptr->frontier.field_D08_4 = gSpecialVar_0x8006;
+ }
+ else
+ {
+ if (lvlMode)
+ gSaveBlock2Ptr->frontier.field_D08_1 = gSpecialVar_0x8006;
+ else
+ gSaveBlock2Ptr->frontier.field_D08_0 = gSpecialVar_0x8006;
+ }
+ break;
+ case 7:
+ if (VarGet(VAR_0x40CE) == 1)
+ {
+ if (lvlMode)
+ gSaveBlock2Ptr->frontier.field_D08_7 = gSpecialVar_0x8006;
+ else
+ gSaveBlock2Ptr->frontier.field_D08_6 = gSpecialVar_0x8006;
+ }
+ else
+ {
+ if (lvlMode)
+ gSaveBlock2Ptr->frontier.field_D08_3 = gSpecialVar_0x8006;
+ else
+ gSaveBlock2Ptr->frontier.field_D08_2 = gSpecialVar_0x8006;
+ }
+ break;
+ case 8:
+ gSaveBlock2Ptr->frontier.field_CB0 = T1_READ_16(gUnknown_0203CEF8);
+ break;
+ }
+}
+
+#ifdef NONMATCHING
+// Not even close, this function is insane.
+void sub_818F02C(void)
+{
+ s32 i, j, k, l;
+ u32 array[16];
+ u32 var_28;
+ u32 var_24;
+ s32 var_38;
+ s32 monTypesBits, monTypesCount;
+ u32 var_54 = 0;
+ u32 var_50 = 0;
+ u32 var_4C = 0;
+ u32 *var_40 = AllocZeroed(0x20);
+ u16 *var_44 = AllocZeroed(0x18);
+ u32 var_48;
+
+ gSaveBlock2Ptr->frontier.field_D0A = gSaveBlock2Ptr->frontier.chosenLvl + 1;
+ gSaveBlock2Ptr->frontier.field_D0B = VarGet(VAR_0x40CE) + 1;
+ gSaveBlock2Ptr->frontier.field_D24[0].unk0 = 0x3FF;
+ gSaveBlock2Ptr->frontier.field_D24[0].unk1 = 0;
+ gSaveBlock2Ptr->frontier.field_D24[0].unk2 = 0;
+ gSaveBlock2Ptr->frontier.field_D24[0].unk3 = 0;
+
+ for (i = 0; i < 3; i++)
+ {
+ gSaveBlock2Ptr->frontier.field_D64[i] = GetMonData(&gPlayerParty[gSaveBlock2Ptr->frontier.field_CAA[i] - 1], MON_DATA_SPECIES, NULL);
+ for (j = 0; j < 4; j++)
+ gSaveBlock2Ptr->frontier.field_EFC[i].moves[j] = GetMonData(&gPlayerParty[gSaveBlock2Ptr->frontier.field_CAA[i] - 1], MON_DATA_MOVE1 + j, NULL);
+ for (j = 0; j < 6; j++)
+ gSaveBlock2Ptr->frontier.field_EFC[i].evs[j] = GetMonData(&gPlayerParty[gSaveBlock2Ptr->frontier.field_CAA[i] - 1], MON_DATA_HP_EV + j, NULL);
+
+ gSaveBlock2Ptr->frontier.field_EFC[i].nature = GetNature(&gPlayerParty[gSaveBlock2Ptr->frontier.field_CAA[i] - 1]);
+ }
+
+ var_28 = 4;
+ var_24 = 6;
+ for (l = j; l < 16; l++)
+ {
+ u16 val;
+ if (l > 5)
+ {
+ while (1)
+ {
+ val = sub_8162548(sub_81A39C4(), 0);
+ for (k = 1; k < l; k++)
+ {
+ if (gSaveBlock2Ptr->frontier.field_D24[k].unk0 == val)
+ break;
+ }
+ if (k != l)
+ {
+ gSaveBlock2Ptr->frontier.field_D24[var_28].unk0 = val;
+ break;
+ }
+ }
+ }
+ else
+ {
+ while (1)
+ {
+ val = sub_8162548(sub_81A39C4() + 1, 0);
+ for (k = 1; k < l; k++)
+ {
+ if (gSaveBlock2Ptr->frontier.field_D24[k].unk0 == val)
+ break;
+ }
+ if (k != l)
+ {
+ gSaveBlock2Ptr->frontier.field_D24[var_28].unk0 = val;
+ break;
+ }
+ }
+ }
+
+ for (var_38 = 0; var_38 < 3; var_38++)
+ {
+ u16 val2;
+ do
+ {
+ val2 = sub_8163524(val);
+ for (i = 0; i < l; i++)
+ {
+ if (gSaveBlock2Ptr->frontier.field_D64[i] == val2)
+ break;
+ if (var_54 == gUnknown_0203BC8C[val2].field_0)
+ break;
+ if (var_50 == gUnknown_0203BC8C[val2].field_0)
+ break;
+ if (gUnknown_0203BC8C[gSaveBlock2Ptr->frontier.field_D64[i]].field_A == gUnknown_0203BC8C[val2].field_A)
+ break;
+ }
+ } while (i != var_38);
+
+ gSaveBlock2Ptr->frontier.field_D64[var_24] = val2;
+ array[var_38] = gUnknown_0203BC8C[val2].field_0;
+ }
+
+ gSaveBlock2Ptr->frontier.field_D24[var_28].unk1 = 0;
+ gSaveBlock2Ptr->frontier.field_D24[var_28].unk2 = 0;
+ gSaveBlock2Ptr->frontier.field_D24[var_28].unk3 = 0;
+ }
+
+ for (i = 0; i < 3; i++)
+ {
+ struct Pokemon *mon = &gPlayerParty[gSaveBlock2Ptr->frontier.field_CAA[i] - 1];
+ var_44[0] += GetMonData(mon, MON_DATA_ATK, NULL);
+ var_44[0] += GetMonData(mon, MON_DATA_DEF, NULL);
+ var_44[0] += GetMonData(mon, MON_DATA_SPATK, NULL);
+ var_44[0] += GetMonData(mon, MON_DATA_SPDEF, NULL);
+ var_44[0] += GetMonData(mon, MON_DATA_SPEED, NULL);
+ var_44[0] += GetMonData(mon, MON_DATA_MAX_HP, NULL);
+ monTypesBits |= gBitTable[gBaseStats[GetMonData(mon, MON_DATA_SPECIES, NULL)].type1];
+ monTypesBits |= gBitTable[gBaseStats[GetMonData(mon, MON_DATA_SPECIES, NULL)].type2];
+ }
+
+ for (monTypesCount = 0, i = 0; i < 31; i++)
+ {
+ if (monTypesBits & 1)
+ monTypesCount++;
+ monTypesBits >>= 1;
+ }
+
+ var_48 = sub_8165C40();
+ var_44[0] += (monTypesCount * var_48) / 20;
+
+ for (i = 0; i < 16; i++)
+ {
+ u8 r8;
+
+ var_44[i + 1] = 0;
+ r8 = sub_8190168(gSaveBlock2Ptr->frontier.field_D24[i].unk0);
+ for (j = 0; j < 3; j++)
+ {
+ sub_818F720(gSaveBlock2Ptr->frontier.field_D64[i]);
+ }
+ }
+
+ Free(var_44);
+ Free(var_40);
+}
+#else
+NAKED
+void sub_818F02C(void)
+{
+ asm_unified("\n\
+ push {r4-r7,lr}\n\
+ mov r7, r10\n\
+ mov r6, r9\n\
+ mov r5, r8\n\
+ push {r5-r7}\n\
+ sub sp, 0x3C\n\
+ movs r0, 0\n\
+ str r0, [sp, 0x8]\n\
+ str r0, [sp, 0xC]\n\
+ str r0, [sp, 0x10]\n\
+ movs r0, 0x20\n\
+ bl AllocZeroed\n\
+ str r0, [sp, 0x18]\n\
+ movs r0, 0x18\n\
+ bl AllocZeroed\n\
+ str r0, [sp, 0x1C]\n\
+ ldr r4, =gSaveBlock2Ptr\n\
+ ldr r1, [r4]\n\
+ ldr r2, =0x00000ca9\n\
+ adds r0, r1, r2\n\
+ ldrb r0, [r0]\n\
+ lsls r0, 30\n\
+ lsrs r0, 30\n\
+ adds r0, 0x1\n\
+ ldr r3, =0x00000d0a\n\
+ adds r1, r3\n\
+ strb r0, [r1]\n\
+ ldr r0, =0x000040ce\n\
+ bl VarGet\n\
+ ldr r1, [r4]\n\
+ adds r0, 0x1\n\
+ ldr r5, =0x00000d0b\n\
+ adds r1, r5\n\
+ strb r0, [r1]\n\
+ ldr r2, [r4]\n\
+ ldr r7, =0x00000d24\n\
+ adds r3, r2, r7\n\
+ ldrh r0, [r3]\n\
+ ldr r5, =0x000003ff\n\
+ adds r1, r5, 0\n\
+ orrs r0, r1\n\
+ strh r0, [r3]\n\
+ ldr r3, =0x00000d25\n\
+ adds r2, r3\n\
+ ldrb r1, [r2]\n\
+ movs r0, 0x5\n\
+ negs r0, r0\n\
+ ands r0, r1\n\
+ strb r0, [r2]\n\
+ ldr r1, [r4]\n\
+ adds r1, r3\n\
+ ldrb r2, [r1]\n\
+ movs r0, 0x19\n\
+ negs r0, r0\n\
+ ands r0, r2\n\
+ strb r0, [r1]\n\
+ ldr r1, [r4]\n\
+ adds r1, r3\n\
+ ldrb r2, [r1]\n\
+ movs r0, 0x1F\n\
+ ands r0, r2\n\
+ strb r0, [r1]\n\
+ movs r7, 0\n\
+ mov r10, r7\n\
+ mov r8, r4\n\
+ ldr r0, =gBattleScripting + 0x14\n\
+ mov r9, r0\n\
+ movs r4, 0\n\
+_0818F0BA:\n\
+ mov r1, r8\n\
+ ldr r0, [r1]\n\
+ ldr r2, =0x00000caa\n\
+ adds r0, r2\n\
+ adds r0, r4\n\
+ ldrh r0, [r0]\n\
+ movs r3, 0x64\n\
+ muls r0, r3\n\
+ add r0, r9\n\
+ movs r1, 0xB\n\
+ movs r2, 0\n\
+ bl GetMonData\n\
+ mov r5, r8\n\
+ ldr r1, [r5]\n\
+ ldr r7, =0x00000d64\n\
+ adds r1, r7\n\
+ adds r1, r4\n\
+ strh r0, [r1]\n\
+ movs r5, 0\n\
+ mov r0, r10\n\
+ lsls r7, r0, 4\n\
+ adds r6, r7, 0\n\
+_0818F0E8:\n\
+ mov r1, r8\n\
+ ldr r0, [r1]\n\
+ ldr r2, =0x00000caa\n\
+ adds r0, r2\n\
+ adds r0, r4\n\
+ ldrh r0, [r0]\n\
+ movs r3, 0x64\n\
+ muls r0, r3\n\
+ add r0, r9\n\
+ adds r1, r5, 0\n\
+ adds r1, 0xD\n\
+ movs r2, 0\n\
+ bl GetMonData\n\
+ mov r2, r8\n\
+ ldr r1, [r2]\n\
+ ldr r3, =0x00000efc\n\
+ adds r1, r3\n\
+ adds r1, r6\n\
+ strh r0, [r1]\n\
+ adds r6, 0x2\n\
+ adds r5, 0x1\n\
+ cmp r5, 0x3\n\
+ ble _0818F0E8\n\
+ movs r5, 0\n\
+ ldr r6, =gSaveBlock2Ptr\n\
+_0818F11C:\n\
+ ldr r0, [r6]\n\
+ ldr r1, =0x00000caa\n\
+ adds r0, r1\n\
+ adds r0, r4\n\
+ ldrh r0, [r0]\n\
+ movs r2, 0x64\n\
+ muls r0, r2\n\
+ add r0, r9\n\
+ adds r1, r5, 0\n\
+ adds r1, 0x1A\n\
+ movs r2, 0\n\
+ bl GetMonData\n\
+ ldr r1, [r6]\n\
+ adds r2, r5, r7\n\
+ ldr r3, =0x00000f04\n\
+ adds r1, r3\n\
+ adds r1, r2\n\
+ strb r0, [r1]\n\
+ adds r5, 0x1\n\
+ cmp r5, 0x5\n\
+ ble _0818F11C\n\
+ mov r5, r8\n\
+ ldr r0, [r5]\n\
+ ldr r1, =0x00000caa\n\
+ adds r0, r1\n\
+ adds r0, r4\n\
+ ldrh r0, [r0]\n\
+ movs r2, 0x64\n\
+ muls r0, r2\n\
+ add r0, r9\n\
+ bl GetNature\n\
+ ldr r1, [r5]\n\
+ adds r1, r7\n\
+ ldr r3, =0x00000f0a\n\
+ adds r1, r3\n\
+ strb r0, [r1]\n\
+ adds r4, 0x2\n\
+ movs r5, 0x1\n\
+ add r10, r5\n\
+ mov r7, r10\n\
+ cmp r7, 0x2\n\
+ ble _0818F0BA\n\
+ mov r10, r5\n\
+ movs r0, 0x4\n\
+ str r0, [sp, 0x34]\n\
+ movs r1, 0x6\n\
+ str r1, [sp, 0x38]\n\
+_0818F17E:\n\
+ mov r2, r10\n\
+ cmp r2, 0x5\n\
+ ble _0818F22C\n\
+_0818F184:\n\
+ bl sub_81A39C4\n\
+ lsls r0, 24\n\
+ lsrs r0, 24\n\
+ movs r1, 0\n\
+ bl sub_8162548\n\
+ lsls r0, 16\n\
+ lsrs r4, r0, 16\n\
+ movs r5, 0x1\n\
+ cmp r5, r10\n\
+ bge _0818F1CA\n\
+ ldr r3, =gSaveBlock2Ptr\n\
+ ldr r0, [r3]\n\
+ ldr r7, =0x00000d28\n\
+ adds r0, r7\n\
+ ldrh r0, [r0]\n\
+ lsls r0, 22\n\
+ lsrs r0, 22\n\
+ adds r2, r3, 0\n\
+ cmp r0, r4\n\
+ beq _0818F1CA\n\
+ ldr r3, =0x00000d24\n\
+_0818F1B2:\n\
+ adds r5, 0x1\n\
+ cmp r5, r10\n\
+ bge _0818F1CA\n\
+ ldr r0, [r2]\n\
+ lsls r1, r5, 2\n\
+ adds r0, r1\n\
+ adds r0, r3\n\
+ ldrh r0, [r0]\n\
+ lsls r0, 22\n\
+ lsrs r0, 22\n\
+ cmp r0, r4\n\
+ bne _0818F1B2\n\
+_0818F1CA:\n\
+ cmp r5, r10\n\
+ bne _0818F184\n\
+ ldr r0, =gSaveBlock2Ptr\n\
+ ldr r3, [r0]\n\
+ ldr r1, [sp, 0x34]\n\
+ adds r3, r1\n\
+ ldr r2, =0x00000d24\n\
+ adds r3, r2\n\
+ ldr r5, =0x000003ff\n\
+ adds r0, r5, 0\n\
+ adds r2, r4, 0\n\
+ ands r2, r0\n\
+ ldrh r0, [r3]\n\
+ ldr r7, =0xfffffc00\n\
+ adds r1, r7, 0\n\
+ b _0818F292\n\
+ .pool\n\
+_0818F22C:\n\
+ bl sub_81A39C4\n\
+ adds r0, 0x1\n\
+ lsls r0, 24\n\
+ lsrs r0, 24\n\
+ movs r1, 0\n\
+ bl sub_8162548\n\
+ lsls r0, 16\n\
+ lsrs r4, r0, 16\n\
+ movs r5, 0x1\n\
+ cmp r5, r10\n\
+ bge _0818F274\n\
+ ldr r1, =gSaveBlock2Ptr\n\
+ ldr r0, [r1]\n\
+ ldr r2, =0x00000d28\n\
+ adds r0, r2\n\
+ ldrh r0, [r0]\n\
+ lsls r0, 22\n\
+ lsrs r0, 22\n\
+ adds r2, r1, 0\n\
+ cmp r0, r4\n\
+ beq _0818F274\n\
+ ldr r3, =0x00000d24\n\
+_0818F25C:\n\
+ adds r5, 0x1\n\
+ cmp r5, r10\n\
+ bge _0818F274\n\
+ ldr r0, [r2]\n\
+ lsls r1, r5, 2\n\
+ adds r0, r1\n\
+ adds r0, r3\n\
+ ldrh r0, [r0]\n\
+ lsls r0, 22\n\
+ lsrs r0, 22\n\
+ cmp r0, r4\n\
+ bne _0818F25C\n\
+_0818F274:\n\
+ cmp r5, r10\n\
+ bne _0818F22C\n\
+ ldr r5, =gSaveBlock2Ptr\n\
+ ldr r3, [r5]\n\
+ ldr r7, [sp, 0x34]\n\
+ adds r3, r7\n\
+ ldr r0, =0x00000d24\n\
+ adds r3, r0\n\
+ ldr r1, =0x000003ff\n\
+ adds r0, r1, 0\n\
+ adds r2, r4, 0\n\
+ ands r2, r0\n\
+ ldrh r0, [r3]\n\
+ ldr r5, =0xfffffc00\n\
+ adds r1, r5, 0\n\
+_0818F292:\n\
+ ands r0, r1\n\
+ orrs r0, r2\n\
+ strh r0, [r3]\n\
+ movs r5, 0\n\
+ lsls r4, 16\n\
+ str r4, [sp, 0x2C]\n\
+ ldr r7, [sp, 0x38]\n\
+ str r7, [sp, 0x20]\n\
+_0818F2A2:\n\
+ lsls r0, r5, 1\n\
+ mov r9, r0\n\
+ adds r1, r5, 0x1\n\
+ str r1, [sp, 0x24]\n\
+ lsls r2, r5, 2\n\
+ str r2, [sp, 0x28]\n\
+_0818F2AE:\n\
+ ldr r3, [sp, 0x2C]\n\
+ lsrs r0, r3, 16\n\
+ bl sub_8163524\n\
+ lsls r0, 16\n\
+ lsrs r6, r0, 16\n\
+ movs r7, 0\n\
+ cmp r7, r5\n\
+ bge _0818F300\n\
+ ldr r0, =gSaveBlock2Ptr\n\
+ ldr r0, [r0]\n\
+ ldr r1, [sp, 0x8]\n\
+ mov r8, r1\n\
+ ldr r2, [sp, 0xC]\n\
+ mov r12, r2\n\
+ ldr r3, =0x00000d64\n\
+ adds r0, r3\n\
+ ldr r1, [sp, 0x20]\n\
+ adds r4, r1, r0\n\
+_0818F2D4:\n\
+ ldrh r3, [r4]\n\
+ cmp r3, r6\n\
+ beq _0818F300\n\
+ ldr r2, =gUnknown_0203BC8C\n\
+ ldr r1, [r2]\n\
+ lsls r0, r6, 4\n\
+ adds r2, r0, r1\n\
+ ldrh r0, [r2]\n\
+ cmp r8, r0\n\
+ beq _0818F300\n\
+ cmp r12, r0\n\
+ beq _0818F300\n\
+ lsls r0, r3, 4\n\
+ adds r0, r1\n\
+ ldrb r0, [r0, 0xA]\n\
+ ldrb r2, [r2, 0xA]\n\
+ cmp r0, r2\n\
+ beq _0818F300\n\
+ adds r4, 0x2\n\
+ adds r7, 0x1\n\
+ cmp r7, r5\n\
+ blt _0818F2D4\n\
+_0818F300:\n\
+ cmp r7, r5\n\
+ bne _0818F2AE\n\
+ ldr r3, =gSaveBlock2Ptr\n\
+ ldr r0, [r3]\n\
+ ldr r1, [sp, 0x38]\n\
+ add r1, r9\n\
+ ldr r5, =0x00000d64\n\
+ adds r0, r5\n\
+ adds r0, r1\n\
+ strh r6, [r0]\n\
+ ldr r2, [sp, 0x28]\n\
+ add r2, sp\n\
+ adds r2, 0x8\n\
+ ldr r0, =gUnknown_0203BC8C\n\
+ ldr r1, [r0]\n\
+ lsls r0, r6, 4\n\
+ adds r0, r1\n\
+ ldrh r0, [r0]\n\
+ str r0, [r2]\n\
+ ldr r5, [sp, 0x24]\n\
+ cmp r5, 0x2\n\
+ ble _0818F2A2\n\
+ ldr r2, [r3]\n\
+ ldr r7, [sp, 0x34]\n\
+ adds r2, r7\n\
+ ldr r0, =0x00000d25\n\
+ adds r2, r0\n\
+ ldrb r0, [r2]\n\
+ movs r3, 0x5\n\
+ negs r3, r3\n\
+ adds r1, r3, 0\n\
+ ands r0, r1\n\
+ strb r0, [r2]\n\
+ ldr r5, =gSaveBlock2Ptr\n\
+ ldr r2, [r5]\n\
+ adds r2, r7\n\
+ ldr r7, =0x00000d25\n\
+ adds r2, r7\n\
+ ldrb r0, [r2]\n\
+ subs r3, 0x14\n\
+ adds r1, r3, 0\n\
+ ands r0, r1\n\
+ strb r0, [r2]\n\
+ ldr r1, [r5]\n\
+ ldr r5, [sp, 0x34]\n\
+ adds r1, r5\n\
+ adds r1, r7\n\
+ ldrb r2, [r1]\n\
+ movs r0, 0x1F\n\
+ ands r0, r2\n\
+ strb r0, [r1]\n\
+ adds r5, 0x4\n\
+ str r5, [sp, 0x34]\n\
+ ldr r7, [sp, 0x38]\n\
+ adds r7, 0x6\n\
+ str r7, [sp, 0x38]\n\
+ movs r0, 0x1\n\
+ add r10, r0\n\
+ mov r1, r10\n\
+ cmp r1, 0xF\n\
+ bgt _0818F37C\n\
+ b _0818F17E\n\
+_0818F37C:\n\
+ movs r7, 0\n\
+ ldr r2, [sp, 0x18]\n\
+ strh r7, [r2]\n\
+ movs r3, 0\n\
+ mov r10, r3\n\
+ ldr r6, =gBitTable\n\
+ ldr r5, =gBaseStats\n\
+_0818F38A:\n\
+ ldr r0, =gSaveBlock2Ptr\n\
+ ldr r0, [r0]\n\
+ mov r2, r10\n\
+ lsls r1, r2, 1\n\
+ ldr r3, =0x00000caa\n\
+ adds r0, r3\n\
+ adds r0, r1\n\
+ ldrh r0, [r0]\n\
+ subs r4, r0, 0x1\n\
+ movs r0, 0x64\n\
+ muls r4, r0\n\
+ ldr r0, =gPlayerParty\n\
+ adds r4, r0\n\
+ adds r0, r4, 0\n\
+ movs r1, 0x3B\n\
+ movs r2, 0\n\
+ bl GetMonData\n\
+ ldr r2, [sp, 0x18]\n\
+ ldrh r1, [r2]\n\
+ adds r1, r0\n\
+ strh r1, [r2]\n\
+ adds r0, r4, 0\n\
+ movs r1, 0x3C\n\
+ movs r2, 0\n\
+ bl GetMonData\n\
+ ldr r3, [sp, 0x18]\n\
+ ldrh r1, [r3]\n\
+ adds r1, r0\n\
+ strh r1, [r3]\n\
+ adds r0, r4, 0\n\
+ movs r1, 0x3E\n\
+ movs r2, 0\n\
+ bl GetMonData\n\
+ ldr r2, [sp, 0x18]\n\
+ ldrh r1, [r2]\n\
+ adds r1, r0\n\
+ strh r1, [r2]\n\
+ adds r0, r4, 0\n\
+ movs r1, 0x3F\n\
+ movs r2, 0\n\
+ bl GetMonData\n\
+ ldr r3, [sp, 0x18]\n\
+ ldrh r1, [r3]\n\
+ adds r1, r0\n\
+ strh r1, [r3]\n\
+ adds r0, r4, 0\n\
+ movs r1, 0x3D\n\
+ movs r2, 0\n\
+ bl GetMonData\n\
+ ldr r2, [sp, 0x18]\n\
+ ldrh r1, [r2]\n\
+ adds r1, r0\n\
+ strh r1, [r2]\n\
+ adds r0, r4, 0\n\
+ movs r1, 0x3A\n\
+ movs r2, 0\n\
+ bl GetMonData\n\
+ ldr r3, [sp, 0x18]\n\
+ ldrh r1, [r3]\n\
+ adds r1, r0\n\
+ strh r1, [r3]\n\
+ adds r0, r4, 0\n\
+ movs r1, 0xB\n\
+ movs r2, 0\n\
+ bl GetMonData\n\
+ lsls r1, r0, 3\n\
+ subs r1, r0\n\
+ lsls r1, 2\n\
+ adds r1, r5\n\
+ ldrb r0, [r1, 0x6]\n\
+ lsls r0, 2\n\
+ adds r0, r6\n\
+ ldr r0, [r0]\n\
+ orrs r7, r0\n\
+ adds r0, r4, 0\n\
+ movs r1, 0xB\n\
+ movs r2, 0\n\
+ bl GetMonData\n\
+ lsls r1, r0, 3\n\
+ subs r1, r0\n\
+ lsls r1, 2\n\
+ adds r1, r5\n\
+ ldrb r0, [r1, 0x7]\n\
+ lsls r0, 2\n\
+ adds r0, r6\n\
+ ldr r0, [r0]\n\
+ orrs r7, r0\n\
+ movs r0, 0x1\n\
+ add r10, r0\n\
+ mov r1, r10\n\
+ cmp r1, 0x2\n\
+ ble _0818F38A\n\
+ movs r4, 0\n\
+ movs r1, 0x1\n\
+ movs r5, 0x1F\n\
+_0818F458:\n\
+ adds r0, r7, 0\n\
+ ands r0, r1\n\
+ cmp r0, 0\n\
+ beq _0818F462\n\
+ adds r4, 0x1\n\
+_0818F462:\n\
+ asrs r7, 1\n\
+ subs r5, 0x1\n\
+ cmp r5, 0\n\
+ bge _0818F458\n\
+ bl sub_8165C40\n\
+ lsls r0, 24\n\
+ lsrs r0, 24\n\
+ str r0, [sp, 0x14]\n\
+ adds r2, r0, 0\n\
+ adds r0, r4, 0\n\
+ muls r0, r2\n\
+ movs r1, 0x14\n\
+ bl __divsi3\n\
+ ldr r3, [sp, 0x18]\n\
+ ldrh r1, [r3]\n\
+ adds r1, r0\n\
+ strh r1, [r3]\n\
+ movs r5, 0x1\n\
+ mov r10, r5\n\
+ adds r6, r3, 0\n\
+ adds r6, 0x2\n\
+ movs r7, 0x2\n\
+ str r7, [sp, 0x30]\n\
+_0818F494:\n\
+ movs r7, 0\n\
+ strh r7, [r6]\n\
+ ldr r1, =gSaveBlock2Ptr\n\
+ ldr r0, [r1]\n\
+ mov r2, r10\n\
+ lsls r1, r2, 2\n\
+ adds r0, r1\n\
+ ldr r3, =0x00000d24\n\
+ adds r0, r3\n\
+ ldrh r0, [r0]\n\
+ lsls r0, 22\n\
+ lsrs r0, 22\n\
+ bl sub_8190168\n\
+ lsls r0, 24\n\
+ lsrs r0, 24\n\
+ mov r8, r0\n\
+ movs r5, 0\n\
+ ldr r0, [sp, 0x30]\n\
+ mov r9, r0\n\
+_0818F4BC:\n\
+ ldr r1, =gSaveBlock2Ptr\n\
+ ldr r0, [r1]\n\
+ mov r4, r9\n\
+ add r4, r10\n\
+ adds r4, r5\n\
+ lsls r4, 1\n\
+ ldr r2, =0x00000d64\n\
+ adds r0, r2\n\
+ adds r0, r4\n\
+ ldrh r1, [r0]\n\
+ ldr r3, =gUnknown_0203BC8C\n\
+ ldr r0, [r3]\n\
+ lsls r1, 4\n\
+ adds r1, r0\n\
+ ldrh r0, [r1]\n\
+ ldrb r3, [r1, 0xB]\n\
+ ldrb r1, [r1, 0xC]\n\
+ str r1, [sp]\n\
+ ldr r1, [sp, 0x1C]\n\
+ str r1, [sp, 0x4]\n\
+ ldr r1, [sp, 0x14]\n\
+ mov r2, r8\n\
+ bl sub_818F720\n\
+ ldr r2, [sp, 0x1C]\n\
+ ldr r1, [r2, 0x4]\n\
+ ldrh r0, [r6]\n\
+ adds r0, r1\n\
+ ldr r1, [r2, 0x8]\n\
+ adds r0, r1\n\
+ ldr r1, [r2, 0x10]\n\
+ adds r0, r1\n\
+ ldr r1, [r2, 0x14]\n\
+ adds r0, r1\n\
+ ldr r1, [r2, 0xC]\n\
+ adds r0, r1\n\
+ ldr r1, [r2]\n\
+ adds r0, r1\n\
+ strh r0, [r6]\n\
+ ldr r3, =gSaveBlock2Ptr\n\
+ ldr r0, [r3]\n\
+ ldr r1, =0x00000d64\n\
+ adds r0, r1\n\
+ adds r0, r4\n\
+ ldrh r0, [r0]\n\
+ ldr r2, =gUnknown_0203BC8C\n\
+ ldr r1, [r2]\n\
+ lsls r0, 4\n\
+ adds r0, r1\n\
+ ldrh r0, [r0]\n\
+ lsls r1, r0, 3\n\
+ subs r1, r0\n\
+ lsls r1, 2\n\
+ ldr r3, =gBaseStats\n\
+ adds r1, r3\n\
+ ldrb r0, [r1, 0x6]\n\
+ lsls r0, 2\n\
+ ldr r2, =gBitTable\n\
+ adds r0, r2\n\
+ ldr r0, [r0]\n\
+ orrs r7, r0\n\
+ ldrb r0, [r1, 0x7]\n\
+ lsls r0, 2\n\
+ adds r0, r2\n\
+ ldr r0, [r0]\n\
+ orrs r7, r0\n\
+ adds r5, 0x1\n\
+ cmp r5, 0x2\n\
+ ble _0818F4BC\n\
+ movs r4, 0\n\
+ movs r1, 0x1\n\
+ movs r5, 0x1F\n\
+_0818F54C:\n\
+ adds r0, r7, 0\n\
+ ands r0, r1\n\
+ cmp r0, 0\n\
+ beq _0818F556\n\
+ adds r4, 0x1\n\
+_0818F556:\n\
+ asrs r7, 1\n\
+ subs r5, 0x1\n\
+ cmp r5, 0\n\
+ bge _0818F54C\n\
+ ldr r3, [sp, 0x14]\n\
+ adds r0, r4, 0\n\
+ muls r0, r3\n\
+ movs r1, 0x14\n\
+ bl __divsi3\n\
+ ldrh r1, [r6]\n\
+ adds r1, r0\n\
+ strh r1, [r6]\n\
+ adds r6, 0x2\n\
+ ldr r5, [sp, 0x30]\n\
+ adds r5, 0x2\n\
+ str r5, [sp, 0x30]\n\
+ movs r7, 0x1\n\
+ add r10, r7\n\
+ mov r0, r10\n\
+ cmp r0, 0xF\n\
+ ble _0818F494\n\
+ movs r1, 0\n\
+ mov r10, r1\n\
+ ldr r2, =0x000003ff\n\
+ mov r8, r2\n\
+_0818F58A:\n\
+ mov r5, r10\n\
+ adds r5, 0x1\n\
+ adds r7, r5, 0\n\
+ cmp r5, 0xF\n\
+ bgt _0818F626\n\
+ mov r3, r10\n\
+ lsls r0, r3, 1\n\
+ ldr r1, [sp, 0x18]\n\
+ adds r6, r0, r1\n\
+ lsls r0, r5, 1\n\
+ adds r4, r0, r1\n\
+_0818F5A0:\n\
+ ldrh r1, [r6]\n\
+ ldrh r0, [r4]\n\
+ cmp r1, r0\n\
+ bcc _0818F5C2\n\
+ cmp r1, r0\n\
+ bne _0818F61E\n\
+ ldr r0, =gSaveBlock2Ptr\n\
+ ldr r1, [r0]\n\
+ lsls r0, r5, 2\n\
+ adds r0, r1, r0\n\
+ ldr r2, =0x00000d24\n\
+ adds r0, r2\n\
+ ldrh r0, [r0]\n\
+ lsls r2, r0, 22\n\
+ lsrs r0, r2, 22\n\
+ cmp r0, r8\n\
+ bne _0818F602\n\
+_0818F5C2:\n\
+ mov r0, r10\n\
+ adds r1, r5, 0\n\
+ ldr r2, [sp, 0x18]\n\
+ bl sub_818F904\n\
+ b _0818F600\n\
+ .pool\n\
+_0818F600:\n\
+ b _0818F61E\n\
+_0818F602:\n\
+ mov r3, r10\n\
+ lsls r0, r3, 2\n\
+ adds r0, r1, r0\n\
+ ldr r1, =0x00000d24\n\
+ adds r0, r1\n\
+ ldrh r0, [r0]\n\
+ lsls r0, 22\n\
+ cmp r0, r2\n\
+ bls _0818F61E\n\
+ mov r0, r10\n\
+ adds r1, r5, 0\n\
+ ldr r2, [sp, 0x18]\n\
+ bl sub_818F904\n\
+_0818F61E:\n\
+ adds r4, 0x2\n\
+ adds r5, 0x1\n\
+ cmp r5, 0xF\n\
+ ble _0818F5A0\n\
+_0818F626:\n\
+ mov r10, r7\n\
+ mov r2, r10\n\
+ cmp r2, 0xE\n\
+ ble _0818F58A\n\
+ bl sub_81A3610\n\
+ lsls r0, 24\n\
+ cmp r0, 0\n\
+ beq _0818F6EE\n\
+ movs r3, 0\n\
+ mov r10, r3\n\
+ ldr r0, =gSaveBlock2Ptr\n\
+ ldr r1, [r0]\n\
+ ldr r4, =0x00000d24\n\
+ adds r1, r4\n\
+ ldrh r1, [r1]\n\
+ lsls r1, 22\n\
+ lsrs r1, 22\n\
+ ldr r3, =0x000003ff\n\
+ adds r2, r0, 0\n\
+ ldr r6, =gUnknown_0860D3F1\n\
+ cmp r1, r3\n\
+ beq _0818F674\n\
+ adds r5, r2, 0\n\
+_0818F656:\n\
+ movs r7, 0x1\n\
+ add r10, r7\n\
+ mov r0, r10\n\
+ cmp r0, 0xF\n\
+ bgt _0818F674\n\
+ ldr r0, [r5]\n\
+ mov r7, r10\n\
+ lsls r1, r7, 2\n\
+ adds r0, r1\n\
+ adds r0, r4\n\
+ ldrh r0, [r0]\n\
+ lsls r0, 22\n\
+ lsrs r0, 22\n\
+ cmp r0, r3\n\
+ bne _0818F656\n\
+_0818F674:\n\
+ mov r1, r10\n\
+ lsls r0, r1, 1\n\
+ adds r0, r6\n\
+ ldrb r0, [r0]\n\
+ cmp r0, 0\n\
+ beq _0818F6AC\n\
+ movs r5, 0\n\
+ ldr r2, [r2]\n\
+ ldr r3, =0x00000d24\n\
+ adds r2, r3\n\
+ ldrh r1, [r2]\n\
+ ldr r0, =0xfffffc00\n\
+ ands r0, r1\n\
+ ldr r7, =0x000003fe\n\
+ adds r1, r7, 0\n\
+ b _0818F6BE\n\
+ .pool\n\
+_0818F6AC:\n\
+ movs r5, 0x1\n\
+ ldr r2, [r2]\n\
+ ldr r0, =0x00000d28\n\
+ adds r2, r0\n\
+ ldrh r1, [r2]\n\
+ ldr r0, =0xfffffc00\n\
+ ands r0, r1\n\
+ ldr r3, =0x000003fe\n\
+ adds r1, r3, 0\n\
+_0818F6BE:\n\
+ orrs r0, r1\n\
+ strh r0, [r2]\n\
+ movs r7, 0\n\
+ mov r10, r7\n\
+ lsls r0, r5, 1\n\
+ adds r0, r5\n\
+ lsls r4, r0, 1\n\
+_0818F6CC:\n\
+ mov r1, r10\n\
+ lsls r0, r1, 24\n\
+ lsrs r0, 24\n\
+ bl sub_81A4FF0\n\
+ ldr r1, =gSaveBlock2Ptr\n\
+ ldr r1, [r1]\n\
+ ldr r2, =0x00000d64\n\
+ adds r1, r2\n\
+ adds r1, r4\n\
+ strh r0, [r1]\n\
+ adds r4, 0x2\n\
+ movs r3, 0x1\n\
+ add r10, r3\n\
+ mov r5, r10\n\
+ cmp r5, 0x2\n\
+ ble _0818F6CC\n\
+_0818F6EE:\n\
+ ldr r0, [sp, 0x18]\n\
+ bl Free\n\
+ ldr r0, [sp, 0x1C]\n\
+ bl Free\n\
+ add sp, 0x3C\n\
+ pop {r3-r5}\n\
+ mov r8, r3\n\
+ mov r9, r4\n\
+ mov r10, r5\n\
+ pop {r4-r7}\n\
+ pop {r0}\n\
+ bx r0\n\
+ .pool\n\
+\n\
+ ");
+}
+#endif // NONMATCHING
+
+#define CALC_STAT(base, statIndex) \
+{ \
+ u8 baseStat = gBaseStats[species].base; \
+ stats[statIndex] = (((2 * baseStat + ivs + evs[statIndex] / 4) * level) / 100) + 5; \
+ stats[statIndex] = (u8) ModifyStatByNature(nature, stats[statIndex], statIndex); \
+}
+
+void sub_818F720(u16 species, s32 level, s32 ivs, u8 evBits, u8 nature, s32 *stats)
+{
+ s32 i, count;
+ u8 bits;
+ u16 resultingEvs;
+ s32 evs[6];
+
+ count = 0, bits = evBits;
+ for (i = 0; i < 6; bits >>= 1, i++)
+ {
+ if (bits & 1)
+ count++;
+ }
+
+ resultingEvs = 510 / count;
+ for (i = 0; i < 6; bits <<= 1, i++)
+ {
+ evs[i] = 0;
+ if (evBits & bits)
+ evs[i] = resultingEvs;
+ }
+
+ if (species == SPECIES_SHEDINJA)
+ {
+ stats[STAT_HP] = 1;
+ }
+ else
+ {
+ s32 n = 2 * gBaseStats[species].baseHP;
+ stats[STAT_HP] = (((n + ivs + evs[STAT_HP] / 4) * level) / 100) + level + 10;
+ }
+
+ CALC_STAT(baseAttack, STAT_ATK);
+ CALC_STAT(baseDefense, STAT_DEF);
+ CALC_STAT(baseSpeed, STAT_SPEED);
+ CALC_STAT(baseSpAttack, STAT_SPATK);
+ CALC_STAT(baseSpDefense, STAT_SPDEF);
+}
+
+#define SWAP_16(x, y) \
+{ \
+ temp = x; \
+ x = y; \
+ y = temp; \
+}
+
+void sub_818F904(s32 id1, s32 id2, u16 *dst)
+{
+ s32 i;
+ u16 temp;
+
+ SWAP_16(dst[id1], dst[id2]);
+ SWAP_16(gSaveBlock2Ptr->frontier.field_D24[id1].unk0, gSaveBlock2Ptr->frontier.field_D24[id2].unk0);
+
+ for (i = 0; i < 3; i++)
+ SWAP_16(gSaveBlock2Ptr->frontier.field_D64[id1][i], gSaveBlock2Ptr->frontier.field_D64[id2][i]);
+}