From 4155d4e6b292a25f47c3a438040f88418e0d0bf2 Mon Sep 17 00:00:00 2001 From: Ryan Dwyer Date: Thu, 28 Nov 2019 18:29:34 +1000 Subject: [PATCH] Decompile aiIfHasFlag --- src/game/chr/chraicommands.c | 73 ++++++++-------------------- src/include/game/chr/chraicommands.h | 2 +- src/setup/setup_000000.c | 2 +- 3 files changed, 22 insertions(+), 55 deletions(-) diff --git a/src/game/chr/chraicommands.c b/src/game/chr/chraicommands.c index 49fdca316..a4bcd9e4a 100644 --- a/src/game/chr/chraicommands.c +++ b/src/game/chr/chraicommands.c @@ -4836,59 +4836,26 @@ bool aiUnsetFlag(void) /** * @cmd 009d */ -GLOBAL_ASM( -glabel ai009d -/* f053e04: 3c07800a */ lui $a3,%hi(g_Vars) -/* f053e08: 24e79fc0 */ addiu $a3,$a3,%lo(g_Vars) -/* f053e0c: 8cee0434 */ lw $t6,0x434($a3) -/* f053e10: 8cef0438 */ lw $t7,0x438($a3) -/* f053e14: 27bdffe0 */ addiu $sp,$sp,-32 -/* f053e18: afbf0014 */ sw $ra,0x14($sp) -/* f053e1c: 01cf1821 */ addu $v1,$t6,$t7 -/* f053e20: 90780002 */ lbu $t8,0x2($v1) -/* f053e24: 90680003 */ lbu $t0,0x3($v1) -/* f053e28: 906b0004 */ lbu $t3,0x4($v1) -/* f053e2c: 0018ce00 */ sll $t9,$t8,0x18 -/* f053e30: 00084c00 */ sll $t1,$t0,0x10 -/* f053e34: 906e0005 */ lbu $t6,0x5($v1) -/* f053e38: 03295025 */ or $t2,$t9,$t1 -/* f053e3c: 000b6200 */ sll $t4,$t3,0x8 -/* f053e40: 014c6825 */ or $t5,$t2,$t4 -/* f053e44: 90660007 */ lbu $a2,0x7($v1) -/* f053e48: afa30018 */ sw $v1,0x18($sp) -/* f053e4c: 8ce40424 */ lw $a0,0x424($a3) -/* f053e50: 0fc12790 */ jal chrHasFlag -/* f053e54: 01ae2825 */ or $a1,$t5,$t6 -/* f053e58: 8fa30018 */ lw $v1,0x18($sp) -/* f053e5c: 3c07800a */ lui $a3,%hi(g_Vars) -/* f053e60: 24e79fc0 */ addiu $a3,$a3,%lo(g_Vars) -/* f053e64: 906f0006 */ lbu $t7,0x6($v1) -/* f053e68: 00402025 */ or $a0,$v0,$zero -/* f053e6c: 15e00002 */ bnez $t7,.L0f053e78 -/* f053e70: 00000000 */ sll $zero,$zero,0x0 -/* f053e74: 2c440001 */ sltiu $a0,$v0,0x1 -.L0f053e78: -/* f053e78: 5080000a */ beqzl $a0,.L0f053ea4 -/* f053e7c: 8cf80438 */ lw $t8,0x438($a3) -/* f053e80: 8ce40434 */ lw $a0,0x434($a3) -/* f053e84: 8ce50438 */ lw $a1,0x438($a3) -/* f053e88: 0fc13583 */ jal chraiGoToLabel -/* f053e8c: 90660008 */ lbu $a2,0x8($v1) -/* f053e90: 3c07800a */ lui $a3,%hi(g_Vars) -/* f053e94: 24e79fc0 */ addiu $a3,$a3,%lo(g_Vars) -/* f053e98: 10000004 */ beqz $zero,.L0f053eac -/* f053e9c: ace20438 */ sw $v0,0x438($a3) -/* f053ea0: 8cf80438 */ lw $t8,0x438($a3) -.L0f053ea4: -/* f053ea4: 27080009 */ addiu $t0,$t8,0x9 -/* f053ea8: ace80438 */ sw $t0,0x438($a3) -.L0f053eac: -/* f053eac: 8fbf0014 */ lw $ra,0x14($sp) -/* f053eb0: 27bd0020 */ addiu $sp,$sp,0x20 -/* f053eb4: 00001025 */ or $v0,$zero,$zero -/* f053eb8: 03e00008 */ jr $ra -/* f053ebc: 00000000 */ sll $zero,$zero,0x0 -); +bool aiIfHasFlag(void) +{ + bool result; + u8 *cmd = g_Vars.ailist + g_Vars.aioffset; + u32 flags = (cmd[3] << 16) | (cmd[4] << 8) | cmd[5] | (cmd[2] << 24); + + result = chrHasFlag(g_Vars.chrdata, flags, cmd[7]); + + if (cmd[6] == 0) { + result = !result; + } + + if (result) { + g_Vars.aioffset = chraiGoToLabel(g_Vars.ailist, g_Vars.aioffset, cmd[8]); + } else { + g_Vars.aioffset += 9; + } + + return false; +} /** * @cmd 009e diff --git a/src/include/game/chr/chraicommands.h b/src/include/game/chr/chraicommands.h index 11ffb8ad4..0255ad489 100644 --- a/src/include/game/chr/chraicommands.h +++ b/src/include/game/chr/chraicommands.h @@ -159,7 +159,7 @@ /*0x009a*/ bool aiSetAccuracy(void); /*0x009b*/ bool aiSetFlag(void); /*0x009c*/ bool aiUnsetFlag(void); -/*0x009d*/ bool ai009d(void); +/*0x009d*/ bool aiIfHasFlag(void); /*0x009e*/ bool aiChrSetFlag(void); /*0x009f*/ bool aiChrUnsetFlag(void); /*0x00a0*/ bool aiIfChrHasFlag(void); diff --git a/src/setup/setup_000000.c b/src/setup/setup_000000.c index 70cb44305..d7105449a 100644 --- a/src/setup/setup_000000.c +++ b/src/setup/setup_000000.c @@ -14289,7 +14289,7 @@ bool (*g_CommandPointers[])(void) = { /*0x009a*/ aiSetAccuracy, /*0x009b*/ aiSetFlag, /*0x009c*/ aiUnsetFlag, - /*0x009d*/ ai009d, + /*0x009d*/ aiIfHasFlag, /*0x009e*/ aiChrSetFlag, /*0x009f*/ aiChrUnsetFlag, /*0x00a0*/ aiIfChrHasFlag,