summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorPikalaxALT <pikalaxalt@gmail.com>2018-03-04 15:36:01 -0500
committerPikalaxALT <pikalaxalt@gmail.com>2018-03-04 15:36:01 -0500
commit44fedd861de0ea64728c93af29755c29906365ac (patch)
tree447732385442803bffc20ae5b0cee62ce73df040 /src
parent30c20bbab63f4d78e4500bcc9a0e056a491faaff (diff)
nonmatching sub_81D1B40
Diffstat (limited to 'src')
-rw-r--r--src/match_call.c116
1 files changed, 111 insertions, 5 deletions
diff --git a/src/match_call.c b/src/match_call.c
index 85cc34307..f0bc920ee 100644
--- a/src/match_call.c
+++ b/src/match_call.c
@@ -4,10 +4,13 @@
#include "battle_setup.h"
#include "event_data.h"
#include "string_util.h"
+#include "battle.h"
#include "gym_leader_rematch.h"
#define NELEMS(a) (s32)( sizeof (a) / sizeof (*(a)) )
+extern const u8 gTrainerClassNames[][13];
+
// Static type declarations
typedef struct MatchCallSusbtruct0 {
@@ -97,10 +100,7 @@ struct UnkStruct_08625388 {
u16 idx;
u16 v2;
u16 v4;
- const u8 *v8;
- const u8 *vC;
- const u8 *v10;
- const u8 *v14;
+ const u8 *v8[4];
};
// Static RAM declarations
@@ -145,7 +145,7 @@ u32 sub_81D1574(const match_call_t matchCall)
}
}
-s32 sub_81D15BC(s32 rematchIdx)
+u32 sub_81D15BC(u32 rematchIdx)
{
return gRematchTable[rematchIdx].trainerIds[0];
}
@@ -620,3 +620,109 @@ void sub_81D1B00(match_call_t matchCall, const u8 **a1, const u8 **a2)
*a1 = matchCall.type0->v4;
*a2 = matchCall.type0->v8;
}
+
+void sub_81D1B0C(u32 idx, const u8 **a1, const u8 **a2)
+{
+ const struct Trainer *trainer = gTrainers + sub_81D15BC(idx);
+ *a1 = gTrainerClassNames[trainer->trainerClass];
+ *a2 = trainer->trainerName;
+}
+
+#ifdef NONMATCHING
+const u8 *sub_81D1B40(u32 idx, u32 offset)
+{
+ u32 i;
+
+ for (i = 0; i < 4; i++)
+ {
+ if (gUnknown_08625388[i].idx == idx)
+ {
+ for (; i + 1 < 4 && gUnknown_08625388[i + 1].idx == idx; i++)
+ {
+ if (!FlagGet(gUnknown_08625388[i + 1].v4))
+ break;
+ }
+ return gUnknown_08625388[i].v8[offset];
+ }
+ }
+ return NULL;
+}
+#else
+ASM_DIRECT const u8 *sub_81D1B40(u32 idx, u32 offset)
+{
+ asm_unified("\tpush {r4-r7,lr}\n"
+ "\tmov r7, r9\n"
+ "\tmov r6, r8\n"
+ "\tpush {r6,r7}\n"
+ "\tadds r6, r0, 0\n"
+ "\tmovs r5, 0\n"
+ "\tldr r2, =gUnknown_08625388\n"
+ "\tmovs r0, 0x8\n"
+ "\tadds r0, r2\n"
+ "\tmov r9, r0\n"
+ "_081D1B54:\n"
+ "\tlsls r0, r5, 1\n"
+ "\tadds r0, r5\n"
+ "\tlsls r0, 3\n"
+ "\tadds r0, r2\n"
+ "\tldrh r0, [r0]\n"
+ "\tcmp r0, r6\n"
+ "\tbne _081D1BBC\n"
+ "\tadds r4, r5, 0x1\n"
+ "\tlsls r1, 2\n"
+ "\tmov r8, r1\n"
+ "\tcmp r4, 0x3\n"
+ "\tbhi _081D1BA8\n"
+ "\tlsls r0, r4, 1\n"
+ "\tadds r0, r4\n"
+ "\tlsls r0, 3\n"
+ "\tadds r0, r2\n"
+ "\tldrh r0, [r0]\n"
+ "\tcmp r0, r6\n"
+ "\tbne _081D1BA8\n"
+ "\tldr r7, =gUnknown_08625388\n"
+ "_081D1B7C:\n"
+ "\tlsls r0, r4, 1\n"
+ "\tadds r0, r4\n"
+ "\tlsls r0, 3\n"
+ "\tadds r1, r7, 0x4\n"
+ "\tadds r0, r1\n"
+ "\tldrh r0, [r0]\n"
+ "\tbl FlagGet\n"
+ "\tlsls r0, 24\n"
+ "\tcmp r0, 0\n"
+ "\tbeq _081D1BA8\n"
+ "\tadds r5, r4, 0\n"
+ "\tadds r4, r5, 0x1\n"
+ "\tcmp r4, 0x3\n"
+ "\tbhi _081D1BA8\n"
+ "\tlsls r0, r4, 1\n"
+ "\tadds r0, r4\n"
+ "\tlsls r0, 3\n"
+ "\tadds r0, r7\n"
+ "\tldrh r0, [r0]\n"
+ "\tcmp r0, r6\n"
+ "\tbeq _081D1B7C\n"
+ "_081D1BA8:\n"
+ "\tlsls r0, r5, 1\n"
+ "\tadds r0, r5\n"
+ "\tlsls r0, 3\n"
+ "\tadd r0, r8\n"
+ "\tadd r0, r9\n"
+ "\tldr r0, [r0]\n"
+ "\tb _081D1BC4\n"
+ "\t.pool\n"
+ "_081D1BBC:\n"
+ "\tadds r5, 0x1\n"
+ "\tcmp r5, 0x3\n"
+ "\tbls _081D1B54\n"
+ "\tmovs r0, 0\n"
+ "_081D1BC4:\n"
+ "\tpop {r3,r4}\n"
+ "\tmov r8, r3\n"
+ "\tmov r9, r4\n"
+ "\tpop {r4-r7}\n"
+ "\tpop {r1}\n"
+ "\tbx r1");
+}
+#endif